finish for ubuntu

This commit is contained in:
Romulus21
2021-06-04 23:45:38 +02:00
parent ae322a0a38
commit 44ba86a985
4 changed files with 156 additions and 75 deletions

View File

@@ -1,64 +1,18 @@
mod topic; mod mqtt_pub;
mod system_values;
use std::{
env,
process,
time::Duration
};
use dotenv::dotenv;
extern crate paho_mqtt as mqtt; extern crate paho_mqtt as mqtt;
extern crate dotenv; extern crate dotenv;
// Define the qos.
const QOS:i32 = 1;
fn main() { fn main() {
dotenv().ok();
let host = env::args().nth(1).unwrap_or_else(|| println!("Resp Temperature : {}", system_values::get_temperature());
env::var("BROKER_ADDRESS").unwrap().to_string()
);
// Define the set of options for the create. let mut cli = mqtt_pub::init_cli();
// Use an ID for a persistent session.
let create_opts = mqtt::CreateOptionsBuilder::new()
.server_uri(host)
.client_id(env::var("BROKER_CLIENT").unwrap().to_string())
.finalize();
// Create a client. cli = mqtt_pub::publish_message(cli, "temperature", &system_values::get_temperature().to_string());
let cli = mqtt::Client::new(create_opts).unwrap_or_else(|err| { cli = mqtt_pub::publish_message(cli, "storage", &system_values::get_storage().to_string());
println!("Error creating the client: {:?}", err); cli = mqtt_pub::publish_message(cli, "mem", &system_values::get_mem().to_string());
process::exit(1);
});
// Define the set of options for the connection. mqtt_pub::disconnect(cli);
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(Duration::from_secs(20))
.clean_session(true)
.finalize();
// Connect and wait for it to complete or fail.
if let Err(e) = cli.connect(conn_opts) {
println!("Unable to connect:\n\t{:?}", e);
process::exit(1);
}
// Create a message and publish it.
// Publish message to 'test' and 'hello' topics.
let topic = topic::get_topic_name("temperature");
let content = "Hello world! ".to_string();
let msg = mqtt::Message::new(topic.clone(), content.clone(), QOS);
let tok = cli.publish(msg);
if let Err(e) = tok {
println!("Error sending message: {:?}", e);
}
// Disconnect from the broker.
let tok = cli.disconnect(None);
println!("Disconnect from the broker");
tok.unwrap();
} }

78
src/mqtt_pub.rs Normal file
View File

@@ -0,0 +1,78 @@
use std::{
env,
process,
time::Duration
};
use dotenv::dotenv;
// Define the qos.
const QOS:i32 = 1;
pub fn init_cli() -> mqtt::Client {
dotenv().ok();
let host = env::args().nth(1).unwrap_or_else(||
env::var("BROKER_ADDRESS").unwrap().to_string()
);
// Define the set of options for the create.
// Use an ID for a persistent session.
let create_opts = mqtt::CreateOptionsBuilder::new()
.server_uri(host)
.client_id(env::var("BROKER_CLIENT").unwrap().to_string())
.finalize();
// Create a client.
let cli = mqtt::Client::new(create_opts).unwrap_or_else(|err| {
println!("Error creating the client: {:?}", err);
process::exit(1);
});
// Define the set of options for the connection.
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(Duration::from_secs(20))
.clean_session(true)
.finalize();
// Connect and wait for it to complete or fail.
if let Err(e) = cli.connect(conn_opts) {
println!("Unable to connect:\n\t{:?}", e);
process::exit(1);
}
return cli;
}
pub fn publish_message(cli: mqtt::Client, topic: &str, message: &str) -> mqtt::Client {
let topic = get_topic_name(topic);
let msg = mqtt::Message::new(topic.clone(), message.clone(), QOS);
let tok = cli.publish(msg);
if let Err(e) = tok {
println!("Error sending message: {:?}", e);
}
println!("{} : {}", topic, message);
return cli;
}
pub fn disconnect(cli: mqtt::Client) {
// Disconnect from the broker.
let tok = cli.disconnect(None);
println!("Disconnect from the broker");
tok.unwrap();
}
pub fn get_topic_name(types: &str) -> String {
dotenv().ok();
let mut topic = env::var("SERVICE").unwrap().to_string();
topic.push('/');
let capteur = env::var("CAPTEUR").unwrap().to_string();
topic.push_str(&capteur);
topic.push('/');
topic.push_str(&types);
return topic;
}

70
src/system_values.rs Normal file
View File

@@ -0,0 +1,70 @@
use std::{
env,
process::Command,
};
use dotenv::dotenv;
pub fn get_temperature() -> f32 {
dotenv().ok();
let mut temperature = 0.0;
let system = env::var("SYSTEM").unwrap().to_string();
if system == "ubuntu" {
let temperature_command = Command::new("cat")
.arg("/sys/class/thermal/thermal_zone1/temp")
.output().unwrap_or_else(|e| {
panic!("failed to execute process: {}", e)
});
let temperature_string = &String::from_utf8_lossy(&temperature_command.stdout)[..5];
temperature = temperature_string.parse::<f32>().unwrap();
temperature = temperature / 1000.0;
} else {
let temperature_command = Command::new("cat")
.arg("/sys/class/thermal/thermal_zone1/temp")
.output().unwrap_or_else(|e| {
panic!("failed to execute process: {}", e)
});
let temperature_string = &String::from_utf8_lossy(&temperature_command.stdout)[..9];
println!("Raspi temp {:?}", temperature_string);
temperature += 1.0;
}
println!("Temperature {}", temperature);
return temperature;
}
pub fn get_storage() -> i8 {
let storage_command = Command::new("df")
.arg("-h")
.arg("/")
.output().unwrap_or_else(|e| {
panic!("failed to execute process: {}", e)
});
let storage_string = &String::from_utf8_lossy(&storage_command.stdout);
let vec_storage : Vec<&str> = storage_string.split_whitespace().collect();
let storage = (vec_storage[vec_storage.len() - 2][..2]).parse::<i8>().unwrap();
return storage;
}
pub fn get_mem() -> f32 {
let mem_command = Command::new("free")
.arg("-m")
.output().unwrap_or_else(|e| {
panic!("failed to execute process: {}", e)
});
let mem_string = &String::from_utf8_lossy(&mem_command.stdout);
let vec_mem : Vec<&str> = mem_string.split_whitespace().collect();
let total = vec_mem[7].parse::<f32>().unwrap();
let mem_use = vec_mem[8].parse::<f32>().unwrap();
let result = mem_use / total * 100.0 ;
return result;
}

View File

@@ -1,21 +0,0 @@
use std::{
env,
};
use dotenv::dotenv;
pub fn get_topic_name(types: &str) -> String {
dotenv().ok();
println!("In Topic");
let mut topic = env::var("SERVICE").unwrap().to_string();
topic.push('/');
let capteur = env::var("CAPTEUR").unwrap().to_string();
topic.push_str(&capteur);
topic.push('/');
topic.push_str(&types);
println!("Topic in func : {}", topic);
return topic;
}