1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
#[macro_use]
extern crate log;
extern crate chrono;
extern crate clap;
extern crate spa;
use chrono::prelude::*;
use clap::{value_t_or_exit, App, Arg};
use env_logger::Env;
use spa::calc_sunrise_and_set;
use std::thread;
use std::time::Duration;
fn main() {
let env = Env::default().filter_or("SCTD_LOG_LEVEL", "info");
env_logger::init_from_env(env);
let matches = App::new("sctd")
.version("0.3.0")
.about("set color temperature daemon")
.arg(
Arg::with_name("latitude")
.long("latitude")
.takes_value(true)
.allow_hyphen_values(true),
)
.arg(
Arg::with_name("longitude")
.long("longitude")
.takes_value(true)
.allow_hyphen_values(true),
)
.arg(Arg::with_name("reset").long("reset"))
.get_matches();
if matches.is_present("reset") {
sctd::reset_temp();
} else {
let latitude = value_t_or_exit!(matches, "latitude", f64);
let longitude = value_t_or_exit!(matches, "longitude", f64);
let mut temp = 0;
loop {
let utc: DateTime<Utc> = Utc::now();
match calc_sunrise_and_set(utc, latitude, longitude) {
Ok(ss) => {
let new_temp = sctd::get_temp(utc, &ss, latitude, longitude) as u32;
if new_temp != temp {
temp = new_temp;
info!("setting temperature to {temp}");
sctd::set_temp(temp);
} else {
debug!("skipping temperature change as it hasn't changed ({temp})");
}
}
Err(e) => {
error!(
"error calculating sunrise and sunset for {latitude}, {longitude}: {e:?}"
);
}
}
thread::sleep(Duration::from_secs(5));
}
}
}
|