summaryrefslogtreecommitdiff
path: root/src/main.rs
diff options
context:
space:
mode:
authorSerguey Parkhomovsky <xindigo@gmail.com>2026-03-14 10:41:23 -0700
committerSerguey Parkhomovsky <xindigo@gmail.com>2026-03-14 10:41:23 -0700
commit79b4c239b61f2b130f8876eaba7a20fdf43a1a44 (patch)
tree2c4080a34e298ba2fcd2dadd00e99d8ec2af63de /src/main.rs
parent49284eaf9a57f1756f4893dc30dce81d470f0fd3 (diff)
Prusa working
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs82
1 files changed, 51 insertions, 31 deletions
diff --git a/src/main.rs b/src/main.rs
index 11a2e43..6c353e6 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -16,29 +16,40 @@ async fn main() {
for printer in config.printers {
match printer {
- Printer::Prusa { name, host, api_key, .. } => {
+ Printer::Prusa {
+ name,
+ host,
+ api_key,
+ ..
+ } => {
let state_clone = state.clone();
tokio::spawn(async move {
- let client = Client::new();
- let response = client.get(format!("http://{}", host))
- .header("X-Api-Key", api_key)
- .send()
- .await
- .unwrap()
- .json::<serde_json::Value>()
- .await
- .unwrap();
- let mut lock = state_clone.lock().await;
- println!("{:?}", &response);
- /*
- if let Ok(msg) = serde_json::from_slice::<BambuMessage>(&p.payload) {
- lock.entry(name.clone())
- .and_modify(|prs| prs.bed_temp = msg.print.bed_temper)
- .or_insert_with(|| PrinterState { name: name.clone(), bed_temp: msg.print.bed_temper, ..Default::default() });
- println!("Updated state for {}: {:?}", &name, p.payload);
+ loop {
+ let result: Result<(), Box<dyn std::error::Error + Send + Sync>> = async {
+ let client = Client::new();
+ let response = client
+ .get(format!("http://{}/api/v1/status", host))
+ .header("X-Api-Key", &api_key)
+ .send()
+ .await?
+ .json::<PrusaStatus>()
+ .await?;
+ let mut lock = state_clone.lock().await;
+ lock.entry(name.clone())
+ .and_modify(|prs| prs.bed_temp = response.printer.temp_bed)
+ .or_insert_with(|| PrinterState {
+ name: name.clone(),
+ bed_temp: response.printer.temp_bed,
+ ..Default::default()
+ });
+ Ok(())
+ }
+ .await;
+ if let Err(e) = result {
+ eprintln!("Error polling Prusa printer {}: {}", name, e);
+ }
+ tokio::time::sleep(Duration::from_secs(5)).await;
}
- */
- println!("Found Prusa: {} at {}", name, host);
});
}
Printer::Bambu {
@@ -74,10 +85,16 @@ async fn main() {
if let Event::Incoming(Packet::Publish(p)) = notification {
let mut lock = state_clone.lock().await;
println!("{:?}", &p.payload);
- if let Ok(msg) = serde_json::from_slice::<BambuMessage>(&p.payload) {
+ if let Ok(msg) =
+ serde_json::from_slice::<BambuMessage>(&p.payload)
+ {
lock.entry(name.clone())
.and_modify(|prs| prs.bed_temp = msg.print.bed_temper)
- .or_insert_with(|| PrinterState { name: name.clone(), bed_temp: msg.print.bed_temper, ..Default::default() });
+ .or_insert_with(|| PrinterState {
+ name: name.clone(),
+ bed_temp: msg.print.bed_temper,
+ ..Default::default()
+ });
println!("Updated state for {}: {:?}", &name, p.payload);
}
}
@@ -94,15 +111,18 @@ async fn main() {
}
loop {
- let state_clone = Arc::clone(&state);
- println!("-- PRINTER STATE --");
-
- let lock = state_clone.lock().await;
-
- for (key, value) in lock.iter() {
- println!("{}: {:?}", key, value);
+ tokio::select! {
+ _ = tokio::signal::ctrl_c() => {
+ println!("Shutting down...");
+ break;
+ }
+ _ = tokio::time::sleep(Duration::from_secs(1)) => {
+ println!("-- PRINTER STATE --");
+ let lock = state.lock().await;
+ for (key, value) in lock.iter() {
+ println!("{}: {:?}", key, value);
+ }
+ }
}
-
- tokio::time::sleep(Duration::from_secs(1)).await;
}
}