connman

Crates.ioconnman
lib.rsconnman
version0.1.3
sourcesrc
created_at2019-05-05 23:09:11.078347
updated_at2019-09-28 22:29:49.269263
descriptionA ConnMan library that abstracts the D-Bus layer
homepage
repositoryhttps://github.com/jmagnuson/connman-rs
max_upload_size
id132300
size162,845
Jon Magnuson (jmagnuson)

documentation

https://docs.rs/connman

README

connman-rs

crates.io Build Status

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.

Documentation

Usage

Add connman-rs to your Cargo.toml with:

[dependencies]
connman = "0.1"

Example

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();
}

License

Licensed under either of

at your option.

Contribution

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.

Commit count: 49

cargo fmt