Crates.io | connman |
lib.rs | connman |
version | 0.1.3 |
source | src |
created_at | 2019-05-05 23:09:11.078347 |
updated_at | 2019-09-28 22:29:49.269263 |
description | A ConnMan library that abstracts the D-Bus layer |
homepage | |
repository | https://github.com/jmagnuson/connman-rs |
max_upload_size | |
id | 132300 |
size | 162,845 |
A ConnMan API library that abstracts the D-Bus layer using dbus-tokio
and
futures
.
The API is still under development, and may be subject to change.
Add connman-rs to your Cargo.toml
with:
[dependencies]
connman = "0.1"
The following example demonstrates how to create a Manager
and list
the available services.
extern crate connman;
extern crate dbus;
extern crate dbus_tokio;
extern crate tokio;
use connman::Manager;
use dbus::{BusType, Connection};
use dbus_tokio::AConnection;
use tokio::reactor::Handle;
use tokio::runtime::current_thread::Runtime;
use std::rc::Rc;
fn main() {
let mut runtime = Runtime::new().unwrap();
let conn = Rc::new(Connection::get_private(BusType::System).unwrap());
let aconn = Rc::new(AConnection::new(conn.clone(), Handle::default(), &mut runtime).unwrap());
let manager = Manager::new(aconn);
let f = manager.get_services()
.and_then(|services| {
for svc in services {
// Dump service info
println!("Found service: {:?}", svc)
}
Ok(())
});
runtime.block_on(f).unwrap();
}
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.