use std::error::Error;
use rumqttc::{AsyncClient, Event, Incoming, MqttOptions, Transport};
use tokio_rustls::rustls::ClientConfig;
#[tokio::main(flavor = "current_thread")]
async fn main() -> Result<(), Box<dyn Error>> {
pretty_env_logger::init();
color_backtrace::install();
let mut mqttoptions = MqttOptions::new("test-1", "mqtt.example.server", 8883);
mqttoptions.set_keep_alive(std::time::Duration::from_secs(5));
mqttoptions.set_credentials("username", "password");
let mut root_cert_store = tokio_rustls::rustls::RootCertStore::empty();
root_cert_store.add_parsable_certificates(
rustls_native_certs::load_native_certs().expect("could not load platform certs"),
);
let client_config = ClientConfig::builder()
.with_root_certificates(root_cert_store)
.with_no_client_auth();
mqttoptions.set_transport(Transport::tls_with_config(client_config.into()));
let (_client, mut eventloop) = AsyncClient::new(mqttoptions, 10);
loop {
match eventloop.poll().await {
Ok(Event::Incoming(Incoming::Publish(p))) => {
println!("Topic: {}, Payload: {:?}", p.topic, p.payload);
}
Ok(Event::Incoming(i)) => {
println!("Incoming = {i:?}");
}
Ok(Event::Outgoing(o)) => println!("Outgoing = {o:?}"),
Err(e) => {
println!("Error = {e:?}");
return Ok(());
}
}
}
}