Fix left overs after models refactor (#3)
Co-authored-by: Felipe Diniello <felipediniello@pm.me> Reviewed-on: #3
This commit was merged in pull request #3.
This commit is contained in:
100
kairo-common/src/mqtt.rs
Normal file
100
kairo-common/src/mqtt.rs
Normal file
@@ -0,0 +1,100 @@
|
||||
pub mod for_async {
|
||||
use mqtt::{AsyncClient, Message};
|
||||
use paho_mqtt as mqtt;
|
||||
use std::{process, time::Duration};
|
||||
|
||||
pub async fn get_mqtt_cli_and_stream(
|
||||
) -> (mqtt::AsyncClient, mqtt::AsyncReceiver<Option<Message>>) {
|
||||
let host = dotenv::var("MQTT_BROKER").unwrap_or_else(|_| {
|
||||
println! {"MQTT_BROKER not found in .evn file, using default: tcp://localhost:1883"};
|
||||
"tcp://localhost:1883".to_string()
|
||||
});
|
||||
|
||||
// Create the client. Use an ID for a persistent session.
|
||||
// A real system should try harder to use a unique ID.
|
||||
let mqtt_options = mqtt::CreateOptionsBuilder::new()
|
||||
.server_uri(host)
|
||||
.client_id("mmRTLS_async_subscribe")
|
||||
.finalize();
|
||||
|
||||
// Create the client connection
|
||||
let mut client = AsyncClient::new(mqtt_options).unwrap_or_else(|e| {
|
||||
println!("Error creating the client: {:?}", e);
|
||||
process::exit(1);
|
||||
});
|
||||
|
||||
// Get message stream before connecting.
|
||||
let stream = client.get_stream(25);
|
||||
|
||||
// Define the set of options for the connection
|
||||
let conn_opts = mqtt::ConnectOptionsBuilder::new()
|
||||
.keep_alive_interval(Duration::from_secs(30))
|
||||
.clean_session(false)
|
||||
.finalize();
|
||||
|
||||
// Make the connection to the broker
|
||||
println!("Connecting to the MQTT server...");
|
||||
client.connect(conn_opts).await.unwrap_or_else(|e| {
|
||||
println!("Error connecting to the broker: {:?}", e);
|
||||
process::exit(1);
|
||||
});
|
||||
|
||||
(client, stream)
|
||||
}
|
||||
|
||||
pub async fn mqtt_cli_reconnect(client: &mqtt::AsyncClient) {
|
||||
println!("Lost connection. Attempting reconnect.");
|
||||
while let Err(err) = client.reconnect().await {
|
||||
println!("Error reconnecting: {}", err);
|
||||
tokio::time::sleep(Duration::from_millis(1000)).await;
|
||||
}
|
||||
}
|
||||
|
||||
pub async fn mqtt_subscribe(client: &mqtt::AsyncClient, topic: &str) {
|
||||
client
|
||||
.subscribe(topic, 1)
|
||||
.await
|
||||
.expect("Unable to subscribe");
|
||||
}
|
||||
}
|
||||
|
||||
pub mod for_sync {
|
||||
use paho_mqtt as mqtt;
|
||||
use std::{process, time::Duration};
|
||||
|
||||
pub fn get_mqtt_cli() -> mqtt::Client {
|
||||
let host = dotenv::var("MQTT_BROKER").unwrap_or_else(|_| {
|
||||
println! {"MQTT_BROKER not found in .evn file, using default: tcp://localhost:1883"};
|
||||
"tcp://localhost:1883".to_string()
|
||||
});
|
||||
|
||||
let mut cli = mqtt::Client::new(host).unwrap_or_else(|e| {
|
||||
println!("Error creating the client: {:?}", e);
|
||||
process::exit(1);
|
||||
});
|
||||
|
||||
// Use 5sec timeouts for sync calls.
|
||||
cli.set_timeout(Duration::from_secs(5));
|
||||
|
||||
// Connect and wait for it to complete or fail
|
||||
if let Err(e) = cli.connect(None) {
|
||||
println!("Unable to connect: {:?}", e);
|
||||
process::exit(1);
|
||||
}
|
||||
cli
|
||||
}
|
||||
|
||||
pub fn mqtt_pub(
|
||||
client: &mqtt::Client,
|
||||
topic: &str,
|
||||
payload: &str,
|
||||
) -> Result<(), paho_mqtt::Error> {
|
||||
let msg = mqtt::MessageBuilder::new()
|
||||
.topic(topic)
|
||||
.payload(payload)
|
||||
.qos(0)
|
||||
.finalize();
|
||||
|
||||
client.publish(msg)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user