# solaredge
## Documentation
See [full documentation](https://docs.rs/solaredge)
## Usage
Add this to your Cargo.toml:
```
[dependencies]
solaredge = "0.1.2"
```
## Asynchronous SolarEdge API client for Rust
Work in progress, only basic API is implemented so far.
Enables access the SolarEdge equipment [API](https://www.solaredge.com/sites/default/files/se_monitoring_api.pdf)
(solar panels, inverters, meters) with the nice typed Rust interface.
The library requires an HTTP client, but is client-agnostic. You can use any client that implements
[`HttpClientAdapter`](https://docs.rs/solaredge/*/solaredge/trait.HttpClientAdapter.html) interface.
Check [solaredge-reqwest](https://crates.io/crates/solaredge-reqwest) for an implementation based
on [reqwest](https://crates.io/crates/reqwest).
Sample usage with [solaredge-reqwest](https://crates.io/crates/solaredge-reqwest):
```rust
use solaredge::{Client, SitesList, SortOrder, SiteStatus};
use solaredge_reqwest::ReqwestAdapter;
async fn run() -> Result<(), Box<dyn std::error::Error>> {
let client = Client::<ReqwestAdapter>::new("API_KEY");
let version = client.version_current().await?;
let mut p = SitesList::default();
p.size = Some(32);
p.sort_order = Some(SortOrder::Ascending);
p.status = Some(&[SiteStatus::Active, SiteStatus::Pending]);
let sites = client.sites_list(&p).await?;
Ok(())
}
```
License: LGPL-3.0