add date and time object publishes
This commit is contained in:
		
							parent
							
								
									77e45e1d2f
								
							
						
					
					
						commit
						ed1d701d94
					
				
							
								
								
									
										4
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										4
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -342,8 +342,8 @@ dependencies = [ | ||||
| 
 | ||||
| [[package]] | ||||
| name = "mqtt-client" | ||||
| version = "2.0.1" | ||||
| source = "git+https://gitea.finnvanreenen.nl/LailaTheElf/mqttClient.git?tag=v2.0.1#e7a46b82a51556ef177c0bf1cb914c4385aefcb9" | ||||
| version = "4.0.0" | ||||
| source = "git+https://gitea.finnvanreenen.nl/LailaTheElf/mqttClient.git?tag=v4.0.0#49e8adf2eb768fcd147f0d6508a2f32eed86a641" | ||||
| dependencies = [ | ||||
|  "crossbeam", | ||||
|  "rumqttc", | ||||
|  | ||||
| @ -9,4 +9,4 @@ crossbeam = "0.8.4" | ||||
| rumqttc = "0.24.0" | ||||
| serde = { version = "1.0.217", features = ["derive"] } | ||||
| serde_yaml = "0.9.34" | ||||
| mqtt-client = { tag = "v2.0.1", git = "https://gitea.finnvanreenen.nl/LailaTheElf/mqttClient.git" } | ||||
| mqtt-client = { tag = "v4.0.0", git = "https://gitea.finnvanreenen.nl/LailaTheElf/mqttClient.git" } | ||||
|  | ||||
							
								
								
									
										7
									
								
								build.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								build.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,7 @@ | ||||
| #!/bin/sh | ||||
| 
 | ||||
| cross build --target aarch64-unknown-linux-gnu --release | ||||
| cargo build --release | ||||
| 
 | ||||
| cp target/aarch64-unknown-linux-gnu/release/mqttClock mqttClock-aarch64 | ||||
| cp target/release/mqttClock mqttClock-x86_64 | ||||
							
								
								
									
										95
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								src/main.rs
									
									
									
									
									
								
							| @ -1,9 +1,9 @@ | ||||
| use std::{fs, thread, time::Duration}; | ||||
| use std::{fs, time::Duration}; | ||||
| 
 | ||||
| use serde::Deserialize; | ||||
| use chrono::{Local, Timelike, Datelike}; | ||||
| 
 | ||||
| use mqtt_client::mqtt_client::{QoS, Sender, Receiver, MqttMessage, MqttTool}; | ||||
| use mqtt_client::{mqtt_client, MqttMessage, MqttEvent, Sender, Receiver, QoS, Client, MqttTool}; | ||||
| 
 | ||||
| fn get_u16_from_i32(value: i32) -> Option<u16> { | ||||
|     match u16::try_from(value) { | ||||
| @ -21,6 +21,9 @@ fn get_u16_from_u32(value: u32) -> Option<u16> { | ||||
| 
 | ||||
| struct Clock { | ||||
|     tx: Sender<MqttMessage>, | ||||
|     // client: Client,
 | ||||
|     connected: bool, | ||||
| 
 | ||||
|     last_year: Option<u16>, | ||||
|     last_month: Option<u16>, | ||||
|     last_dom: Option<u16>, | ||||
| @ -49,55 +52,88 @@ impl Clock { | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     fn tx_time(&self) { | ||||
|         let second = self.last_second; | ||||
|         let minute = self.last_minute; | ||||
|         let hour = self.last_hour; | ||||
|         if let (Some(second), Some(minute), Some(hour)) = (second, minute, hour) { | ||||
|             let payload = format!("{{\"second\":{second},\"minute\":{minute},\"hour\":{hour},\"time\":\"{hour}:{minute}:{second}\"}}"); | ||||
| 
 | ||||
|             let message = MqttMessage { | ||||
|                 topic: String::from("clock/time/time"), | ||||
|                 payload, | ||||
|                 retain: false, | ||||
|                 qos: QoS::AtMostOnce, | ||||
|             }; | ||||
|             match self.tx.send(message) { | ||||
|                 Err(n) => println!("ERROR: faild to send publish ({:?})", n), | ||||
|                 Ok(_) => {} | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn time(&mut self) { | ||||
|         let datetime = Local::now(); | ||||
|         if self.last_second != get_u16_from_u32(datetime.second()) { | ||||
|             self.last_second = get_u16_from_u32(datetime.second()); | ||||
|             self.tx(String::from("clock/time/second"), self.last_second, false); | ||||
|             if self.last_minute != get_u16_from_u32(datetime.minute()) { | ||||
|                 self.last_minute = get_u16_from_u32(datetime.minute()); | ||||
|                 self.tx(String::from("clock/time/minute"), self.last_minute, false); | ||||
|                 if self.last_hour != get_u16_from_u32(datetime.hour()) { | ||||
|                     self.last_hour = get_u16_from_u32(datetime.hour()); | ||||
|                     self.tx(String::from("clock/time/hour"), self.last_hour, false); | ||||
|                     self.tx(String::from("clock/time/hour"), self.last_hour, true); | ||||
|                     self.date(datetime); | ||||
|                 } | ||||
|                 self.tx(String::from("clock/time/minute"), self.last_minute, false); | ||||
|             } | ||||
|             self.tx(String::from("clock/time/second"), self.last_second, false); | ||||
|             self.tx_time(); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn date(&mut self, datetime: chrono::DateTime<Local>) { | ||||
|         if self.last_dom != get_u16_from_u32(datetime.day()) { | ||||
|             self.last_dom = get_u16_from_u32(datetime.day()); | ||||
|             self.tx(String::from("clock/date/dom"), self.last_dom, true); | ||||
|             if self.last_iso_week != get_u16_from_u32(datetime.iso_week().week()) { | ||||
|                 self.last_iso_week = get_u16_from_u32(datetime.iso_week().week()); | ||||
|                 self.tx(String::from("clock/date/isoWeek"), self.last_iso_week, true); | ||||
|                 if self.last_iso_year != get_u16_from_i32(datetime.iso_week().year()) { | ||||
|                     self.last_iso_year = get_u16_from_i32(datetime.iso_week().year()); | ||||
|                     self.tx(String::from("clock/date/isoYear"), self.last_iso_year, true); | ||||
|                 } | ||||
|                 self.tx(String::from("clock/date/isoWeek"), self.last_iso_week, true); | ||||
|             } | ||||
|             if self.last_dow != Some(datetime.weekday() as u16) { | ||||
|                 self.last_dow = Some(datetime.weekday() as u16); | ||||
|                 self.tx(String::from("clock/date/dow"), self.last_dow, true); | ||||
|             } | ||||
|             self.tx(String::from("clock/date/dom"), self.last_dom, true); | ||||
| 
 | ||||
|             if self.last_month != get_u16_from_u32(datetime.month()) { | ||||
|                 self.last_month = get_u16_from_u32(datetime.month()); | ||||
|                 self.tx(String::from("clock/date/month"), self.last_month, true); | ||||
|                 if self.last_year != get_u16_from_i32(datetime.year()) { | ||||
|                     self.last_year = get_u16_from_i32(datetime.year()); | ||||
|                     self.tx(String::from("clock/date/year"), self.last_year, true); | ||||
|                 } | ||||
|                 self.tx(String::from("clock/date/month"), self.last_month, true); | ||||
|             } | ||||
| 
 | ||||
|             self.last_dow = Some(datetime.weekday() as u16); | ||||
|             self.tx(String::from("clock/date/dow"), self.last_dow, true); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn init(&mut self) { | ||||
|         self.last_year = None; | ||||
|         self.last_month = None; | ||||
|         self.last_dom = None; | ||||
|         self.last_dow = None; | ||||
|         self.last_iso_week = None; | ||||
|         self.last_iso_year = None; | ||||
|         self.last_hour = None; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| impl MqttTool for Clock { | ||||
|     fn new(_client: rumqttc::Client, tx: Sender<MqttMessage>) -> Clock { | ||||
| impl MqttTool<i8> for Clock { | ||||
|     fn new(tx: Sender<MqttMessage>, _config: i8, _client: Client) -> Clock { | ||||
|         Clock { | ||||
|             tx, | ||||
|             // client,
 | ||||
|             connected: false, | ||||
|             last_year: None, | ||||
|             last_month: None, | ||||
|             last_dom: None, | ||||
| @ -110,10 +146,26 @@ impl MqttTool for Clock { | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     fn run(&mut self, _rx: Receiver<MqttMessage>) { | ||||
|     fn run(&mut self, event: Receiver<MqttEvent>) { | ||||
|         loop { | ||||
|             self.time(); | ||||
|             thread::sleep(Duration::from_millis(500)); | ||||
|             match event.recv_timeout(Duration::from_millis(500)) { | ||||
|                 Ok(e) => { | ||||
|                     match e { | ||||
|                         MqttEvent::Connected => { | ||||
|                             self.init(); | ||||
|                             self.connected = true; | ||||
|                         }, | ||||
|                         MqttEvent::Disconnected => { | ||||
|                             self.connected = false; | ||||
|                         }, | ||||
|                         MqttEvent::Message(_) => {/* nothing to do, no subscriptions */} | ||||
|                     } | ||||
|                 }, | ||||
|                 Err(_) => {}, | ||||
|             } | ||||
|             if self.connected { | ||||
|                 self.time(); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @ -174,7 +226,14 @@ fn main() { | ||||
|     // get setting
 | ||||
|     match read_config() { | ||||
|         Ok(conf) => | ||||
|             mqtt_client::mqtt_client::run::<Clock>(conf.mqtt.host, conf.mqtt.port, conf.mqtt.client, conf.mqtt.user, conf.mqtt.pass), | ||||
|             mqtt_client::run::<i8, Clock>( | ||||
|                 conf.mqtt.host, | ||||
|                 conf.mqtt.port, | ||||
|                 conf.mqtt.client, | ||||
|                 conf.mqtt.user, | ||||
|                 conf.mqtt.pass, | ||||
|                 0 | ||||
|             ), | ||||
|         Err(_) => {} | ||||
|     } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user