WMI (Windows Management Instrumentation) crate for rust.
```toml
[dependencies] wmi = "0.11" ```
Queries can be deserialized into a free-form HashMap
or a struct
:
```rust
use serde::Deserialize; use wmi::{COMLibrary, Variant, WMIConnection, WMIDateTime}; use std::collections::HashMap;
fn main() -> Result<(), Box
let results: Vec<HashMap<String, Variant>> = wmi_con.raw_query("SELECT * FROM Win32_OperatingSystem")?;
for os in results {
println!("{:#?}", os);
}
#[derive(Deserialize, Debug)]
struct Win32_OperatingSystem {
Caption: String,
Name: String,
CurrentTimeZone: i16,
Debug: bool,
EncryptionLevel: u32,
ForegroundApplicationBoost: u8,
LastBootUpTime: WMIDateTime,
}
let results: Vec<Win32_OperatingSystem> = wmi_con.query()?;
for os in results {
println!("{:#?}", os);
}
Ok(())
} ```
chrono
vs time
If you prefer to use the time
crate instead of the default chrono
, include wmi
as
toml
[dependencies]
wmi-rs = { version = "0.11", default-features = false, features = ["time"] }
and use the WMIOffsetDateTime
wrapper instead of the the WMIDateTime
wrapper.
WMI supports async queries, with methods like ExecAsyncQuery.
```rust
use serde::Deserialize; use wmi::{COMLibrary, Variant, WMIConnection, WMIDateTime}; use std::collections::HashMap; use futures::executor::block_on;
fn main() -> Result<(), Box
block_on(exec_async_query(&wmi_con))?;
Ok(())
}
async fn execasyncquery(wmicon: &WMIConnection) -> Result<(), Box
for os in results {
println!("{:#?}", os);
}
#[derive(Deserialize, Debug)]
struct Win32_OperatingSystem {
Caption: String,
Name: String,
CurrentTimeZone: i16,
Debug: bool,
EncryptionLevel: u32,
ForegroundApplicationBoost: u8,
LastBootUpTime: WMIDateTime,
}
let results: Vec<Win32_OperatingSystem> = wmi_con.async_query().await?;
for os in results {
println!("{:#?}", os);
}
Ok(())
} ```
The wmi
crate is licensed under either of
text
Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.