2023-01-09 20:23:55 +01:00
|
|
|
//! The supported cloud services.
|
|
|
|
|
2023-01-10 15:38:24 +01:00
|
|
|
pub(crate) mod hoymiles;
|
2023-01-09 20:23:55 +01:00
|
|
|
pub(crate) mod my_autarco;
|
|
|
|
|
|
|
|
use enum_dispatch::enum_dispatch;
|
|
|
|
use rocket::async_trait;
|
2023-01-09 21:25:35 +01:00
|
|
|
use serde::Deserialize;
|
2023-01-09 20:23:55 +01:00
|
|
|
|
2023-01-09 21:25:35 +01:00
|
|
|
use crate::Status;
|
|
|
|
|
|
|
|
/// The service-specific configuration necessary to access a cloud service API.
|
|
|
|
#[derive(Debug, Deserialize)]
|
|
|
|
#[serde(crate = "rocket::serde", tag = "kind")]
|
|
|
|
pub(crate) enum Config {
|
2023-01-10 15:38:24 +01:00
|
|
|
/// Hoymiles (<https://global.hoymiles.com>)
|
|
|
|
Hoymiles(hoymiles::Config),
|
|
|
|
/// My Autarco (<https://my.autarco.com>)
|
2023-01-09 21:25:35 +01:00
|
|
|
MyAutarco(my_autarco::Config),
|
|
|
|
}
|
2023-01-09 20:23:55 +01:00
|
|
|
|
|
|
|
/// Retrieves the service for the provided name (if supported).
|
2023-01-09 21:25:35 +01:00
|
|
|
pub(crate) fn get(config: Config) -> color_eyre::Result<Services> {
|
|
|
|
match config {
|
2023-01-10 15:38:24 +01:00
|
|
|
Config::Hoymiles(config) => Ok(Services::Hoymiles(hoymiles::service(config)?)),
|
2023-01-09 21:25:35 +01:00
|
|
|
Config::MyAutarco(config) => Ok(Services::MyAutarco(my_autarco::service(config)?)),
|
2023-01-09 20:23:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// The supported cloud services.
|
|
|
|
#[enum_dispatch(Service)]
|
|
|
|
pub(crate) enum Services {
|
2023-01-10 15:38:24 +01:00
|
|
|
/// Hoymiles (<https://global.hoymiles.com>)
|
|
|
|
Hoymiles(hoymiles::Service),
|
2023-01-09 20:23:55 +01:00
|
|
|
/// My Autarco (<https://my.autarco.com>)
|
|
|
|
MyAutarco(my_autarco::Service),
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Functionality trait of a cloud service.
|
|
|
|
#[async_trait]
|
|
|
|
#[enum_dispatch]
|
|
|
|
pub(crate) trait Service {
|
|
|
|
/// The interval between data polls (in seconds).
|
|
|
|
fn poll_interval(&self) -> u64;
|
|
|
|
|
|
|
|
/// Perfoms a login on the cloud service (if necessary).
|
|
|
|
async fn login(&self) -> Result<(), reqwest::Error>;
|
|
|
|
|
|
|
|
/// Retrieves a status update using the API of the cloud service.
|
|
|
|
async fn update(&self, timestamp: u64) -> Result<Status, reqwest::Error>;
|
|
|
|
}
|