cargo fmt

This commit is contained in:
Xiretza 2024-02-02 13:57:52 +00:00
parent 798ac0c1a4
commit 97f7a5f1e2

View file

@ -35,7 +35,7 @@ pub enum StatusCode {
ConfigIOError = 10, ConfigIOError = 10,
NotSupported = 11, NotSupported = 11,
DeviceNotAvailable = 12, DeviceNotAvailable = 12,
UnknownError = 255 UnknownError = 255,
} }
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
@ -43,7 +43,7 @@ pub enum StatusCode {
pub struct Status { pub struct Status {
code: StatusCode, code: StatusCode,
reason: String, reason: String,
user_message: String user_message: String,
} }
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
@ -59,13 +59,13 @@ pub struct CommonResponseHeader {
#[serde(rename_all = "PascalCase")] #[serde(rename_all = "PascalCase")]
pub struct UnitAndValue<T> { pub struct UnitAndValue<T> {
unit: String, unit: String,
value: T value: T,
} }
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
#[serde(rename_all = "PascalCase")] #[serde(rename_all = "PascalCase")]
pub struct CommonResponseBody<T> { pub struct CommonResponseBody<T> {
data: T data: T,
} }
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
@ -88,10 +88,7 @@ pub struct ApiVersion {
pub fn get_api_version(ip: IpAddr) -> Result<ApiVersion, Box<dyn std::error::Error>> { pub fn get_api_version(ip: IpAddr) -> Result<ApiVersion, Box<dyn std::error::Error>> {
let mut url = reqwest::Url::parse("http://placeholder.local/solar_api/GetAPIVersion.cgi")?; let mut url = reqwest::Url::parse("http://placeholder.local/solar_api/GetAPIVersion.cgi")?;
let _ = url.set_ip_host(ip); let _ = url.set_ip_host(ip);
Ok(reqwest::blocking::Client::new() Ok(reqwest::blocking::Client::new().get(url).send()?.json()?)
.get(url)
.send()?
.json()?)
} }
pub enum Scope { pub enum Scope {
@ -130,8 +127,6 @@ pub enum DataCollection {
MinMaxInverterData, MinMaxInverterData,
} }
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
#[serde(rename_all = "PascalCase")] #[serde(rename_all = "PascalCase")]
pub struct CumulationInverterData<T> { pub struct CumulationInverterData<T> {
@ -139,23 +134,23 @@ pub struct CumulationInverterData<T> {
day_energy: T, day_energy: T,
year_energy: T, year_energy: T,
total_energy: T, total_energy: T,
device_status: Option<std::collections::HashMap<String, String>> device_status: Option<std::collections::HashMap<String, String>>,
} }
pub fn get_inverter_realtime_data( pub fn get_inverter_realtime_data(
ip: IpAddr, ip: IpAddr,
scope: Scope, scope: Scope,
) -> Result<FroniousResponse<>, Box<dyn std::error::Error>> { ) -> Result<FroniousResponse, Box<dyn std::error::Error>> {
let mut params: Vec<(&str, String)> = vec![]; let mut params: Vec<(&str, String)> = vec![];
match scope { match scope {
Scope::System => { Scope::System => {
params.push(("Scope", "System".to_owned())); params.push(("Scope", "System".to_owned()));
}, }
Scope::Device { device_id, data_collection } => { Scope::Device {
device_id,
data_collection,
} => {
params.push(("Scope", "Device".to_owned())); params.push(("Scope", "Device".to_owned()));
params.push(("DeviceId", (u8::from(device_id)).to_string())); params.push(("DeviceId", (u8::from(device_id)).to_string()));
params.push(("DataCollection", data_collection.to_string())); params.push(("DataCollection", data_collection.to_string()));