annotate rust/src/params.rs @ 639:89818a14648b rust tip

- switch to using anyhow for errors, surf for http runs but surf has problems
author Matt Johnston <matt@ucc.asn.au>
date Thu, 28 Nov 2019 23:57:00 +0800
parents a9f353f488d0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
1 use anyhow::{Result,bail};
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
2
592
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
3 use std::time::Duration;
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
4
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
5 use std::str;
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
6
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
7 use std::cell::{RefCell};
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
8 use std::fs::File;
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
9 use std::io::Read;
627
d5075136442f futures await
Matt Johnston <matt@ucc.asn.au>
parents: 626
diff changeset
10
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
11 use serde::{Serialize,Deserialize};
592
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
12
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
13 use rand::rngs::{OsRng};
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
14 use rand::{RngCore};
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
15
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
16 use async_std::task;
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
17
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
18 use surf;
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
19
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
20 use riker::actors::*;
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
21
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
22 use super::types::*;
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
23 use super::config::Config;
592
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
24
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
25 #[derive(Deserialize, Serialize, Debug, Clone)]
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
26 pub struct Params {
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
27 pub fridge_setpoint: f32,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
28 pub fridge_difference: f32,
621
8136a6b99866 make it compile again
Matt Johnston <matt@ucc.asn.au>
parents: 618
diff changeset
29 pub overshoot_delay: u64,
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
30 pub overshoot_factor: f32,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
31 pub disabled: bool,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
32 pub nowort: bool,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
33 pub fridge_range_lower: f32,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
34 pub fridge_range_upper: f32,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
35 }
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
36
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
37 impl Params {
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
38 pub fn defaults() -> Params {
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
39 Params {
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
40 fridge_setpoint: 16.0,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
41 fridge_difference: 0.2,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
42 overshoot_delay: 720, // 12 minutes
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
43 overshoot_factor: 1.0,
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
44 disabled: true,
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
45 nowort: false,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
46 fridge_range_lower: 3.0,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
47 fridge_range_upper: 3.0,
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
48 }
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
49 }
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
50
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
51 fn try_load(filename: &str) -> Result<Params> {
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
52 let mut s = String::new();
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
53 File::open(filename)?.read_to_string(&mut s)?;
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
54 Ok(serde_json::from_str(&s)?)
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
55 }
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
56
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
57 pub fn load(config: &Config) -> Params {
635
4424a8b30f9c config crate wants everything to be lower case
Matt Johnston <matt@ucc.asn.au>
parents: 634
diff changeset
58 Self::try_load(&config.params_file)
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
59 .unwrap_or_else(|_| Params::defaults())
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
60 }
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
61
615
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
62 }
f153aec221be move Params, epoch code
Matt Johnston <matt@ucc.asn.au>
parents: 614
diff changeset
63
593
bf138339d20a fiddling with timeouts and closures
Matt Johnston <matt@ucc.asn.au>
parents: 592
diff changeset
64 pub struct ParamWaiter {
609
7bda01659426 not building, paramwaiter work
Matt Johnston <matt@ucc.asn.au>
parents: 594
diff changeset
65 limitlog: NotTooOften,
616
a85c0c9bc1fa hide epoch in ParamWaiter
Matt Johnston <matt@ucc.asn.au>
parents: 615
diff changeset
66 // last_etag is used for long-polling.
a85c0c9bc1fa hide epoch in ParamWaiter
Matt Johnston <matt@ucc.asn.au>
parents: 615
diff changeset
67 last_etag: RefCell<String>,
a85c0c9bc1fa hide epoch in ParamWaiter
Matt Johnston <matt@ucc.asn.au>
parents: 615
diff changeset
68 epoch: String,
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
69 notify: ChannelRef<Params>,
614
e1bab5b36352 using some refcells for the paramwaiter
Matt Johnston <matt@ucc.asn.au>
parents: 613
diff changeset
70
609
7bda01659426 not building, paramwaiter work
Matt Johnston <matt@ucc.asn.au>
parents: 594
diff changeset
71 config: Config,
592
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
72 }
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
73
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
74 const LOG_MINUTES: u64 = 15;
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
75 const MAX_RESPONSE_SIZE: usize = 10000;
614
e1bab5b36352 using some refcells for the paramwaiter
Matt Johnston <matt@ucc.asn.au>
parents: 613
diff changeset
76 const TIMEOUT_MINUTES: u64 = 5;
609
7bda01659426 not building, paramwaiter work
Matt Johnston <matt@ucc.asn.au>
parents: 594
diff changeset
77
593
bf138339d20a fiddling with timeouts and closures
Matt Johnston <matt@ucc.asn.au>
parents: 592
diff changeset
78 impl ParamWaiter {
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
79 pub fn new_actor((config, notify): (Config, ChannelRef<Params>)) -> Self {
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
80 Self::new(config, notify)
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
81 }
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
82
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
83 pub fn new(config: Config, notify: ChannelRef<Params>) -> Self {
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
84 let mut b = [0u8; 15]; // 15 bytes -> 20 characters base64
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
85 OsRng.fill_bytes(&mut b);
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
86 let epoch = base64::encode(&b);
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
87
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
88 ParamWaiter {
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
89 limitlog: NotTooOften::new(LOG_MINUTES*60),
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
90 last_etag: RefCell::new(String::new()),
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
91 epoch: epoch,
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
92 config: config,
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
93 notify: notify,
614
e1bab5b36352 using some refcells for the paramwaiter
Matt Johnston <matt@ucc.asn.au>
parents: 613
diff changeset
94 }
609
7bda01659426 not building, paramwaiter work
Matt Johnston <matt@ucc.asn.au>
parents: 594
diff changeset
95 }
7bda01659426 not building, paramwaiter work
Matt Johnston <matt@ucc.asn.au>
parents: 594
diff changeset
96
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
97 async fn wait_updates(uri: &str, etag: &str) -> Result<(Vec<u8>, u16)> {
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
98 debug!("wait_updates {}", uri);
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
99 // XXX Workaround for https://github.com/dtolnay/anyhow/issues/35
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
100 let mut resp = match surf::get(uri)
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
101 .set_header("etag", etag).await {
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
102 Ok(r) => r,
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
103 Err(e) => bail!(e),
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
104 };
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
105
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
106 // TODO timeout?
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
107 let status = resp.status();
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
108 let bytes = resp.body_bytes().await?;
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
109
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
110 Ok((bytes, status.into()))
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
111 }
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
112
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
113 fn handle_response(&self, contents : &Vec<u8>, status: u16) -> Result<Params> {
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
114
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
115 #[derive(Deserialize, Debug)]
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
116 struct Response {
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
117 // sent as an opaque etag: header. Has format "epoch-nonce",
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
118 // responses where the epoch do not match ParamWaiter::epoch are dropped
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
119 etag: String,
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
120 params: Params,
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
121 }
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
122
626
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
123 match status {
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
124 200 => {
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
125 // 200 OK
613
5c2b0d47bb83 Response has epoch_tag and params
Matt Johnston <matt@ucc.asn.au>
parents: 611
diff changeset
126 // new params
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
127 let r: Response = serde_json::from_slice(contents)?;
618
2d65a9f0bed3 params returning stream of success
Matt Johnston <matt@ucc.asn.au>
parents: 616
diff changeset
128 let mut le = self.last_etag.borrow_mut();
2d65a9f0bed3 params returning stream of success
Matt Johnston <matt@ucc.asn.au>
parents: 616
diff changeset
129 *le = r.etag;
626
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
130
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
131 // update params if the epoch is correct
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
132 if let Some(e) = le.split('-').next() {
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
133 if e == &self.epoch {
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
134 self.write_params(&r.params);
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
135 return Ok(r.params);
efcbe0d3afd6 fix to work with hyper
Matt Johnston <matt@ucc.asn.au>
parents: 624
diff changeset
136 }
618
2d65a9f0bed3 params returning stream of success
Matt Johnston <matt@ucc.asn.au>
parents: 616
diff changeset
137 }
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
138 bail!("Bad epoch from server '{}' expected '{}'", *le, self.epoch);
613
5c2b0d47bb83 Response has epoch_tag and params
Matt Johnston <matt@ucc.asn.au>
parents: 611
diff changeset
139 }
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
140 304 => {
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
141 // 304 Not Modified
629
3e5e52d50af5 comment
Matt Johnston <matt@ucc.asn.au>
parents: 627
diff changeset
142 // XXX this isn't really an error. Should handle_response() return
3e5e52d50af5 comment
Matt Johnston <matt@ucc.asn.au>
parents: 627
diff changeset
143 // Result<Option<Params>, TemplogError> instead?
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
144 bail!("304 unmodified (long polling timeout at the server)");
618
2d65a9f0bed3 params returning stream of success
Matt Johnston <matt@ucc.asn.au>
parents: 616
diff changeset
145 },
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
146 _ => {
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
147 let text = String::from_utf8_lossy(contents);
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
148 bail!("Wrong server response code {}: {}", status, text);
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
149 },
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
150 }
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
151 }
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
152
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
153 fn write_params(&self, params: &Params) {
635
4424a8b30f9c config crate wants everything to be lower case
Matt Johnston <matt@ucc.asn.au>
parents: 634
diff changeset
154 let p = atomicwrites::AtomicFile::new(&self.config.params_file, atomicwrites::AllowOverwrite);
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
155 let r = p.write(|f| {
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
156 serde_json::to_writer(f, params)
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
157 });
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
158 if let Err(e) = r {
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
159 // XXX notify?
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
160 error!("Couldn't write to {}: {}", self.config.params_file, e)
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
161 };
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
162 }
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
163
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
164 fn do_poll(&mut self, ctx: &Context<<Self as Actor>::Msg>) -> Result<()> {
635
4424a8b30f9c config crate wants everything to be lower case
Matt Johnston <matt@ucc.asn.au>
parents: 634
diff changeset
165 let url = self.config.settings_url.clone();
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
166 let etag = self.last_etag.borrow().clone();
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
167 let h = ctx.run(async move {
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
168 Self::wait_updates(&url, &etag).await
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
169 }).expect("spawn failed"); // XXX error handling
639
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
170 let (contents, stat) = task::block_on(h)?;
89818a14648b - switch to using anyhow for errors, surf for http
Matt Johnston <matt@ucc.asn.au>
parents: 638
diff changeset
171 let new_params = self.handle_response(&contents, stat)?;
638
a9f353f488d0 fix channels
Matt Johnston <matt@ucc.asn.au>
parents: 636
diff changeset
172 self.notify.tell(Publish{msg: new_params, topic: "params".into()}, None);
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
173 Ok(())
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
174 }
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
175 }
624
2710649ab71e read/write params local file. untested
Matt Johnston <matt@ucc.asn.au>
parents: 621
diff changeset
176
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
177 #[derive(Clone,Debug)]
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
178 pub struct PollForParams;
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
179
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
180 impl Actor for ParamWaiter {
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
181 type Msg = PollForParams;
611
f3e39e2107fd still doesn't compile, improvements to TemplogError and tokio curl though
Matt Johnston <matt@ucc.asn.au>
parents: 609
diff changeset
182
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
183 fn recv(&mut self,
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
184 ctx: &Context<Self::Msg>,
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
185 _msg: Self::Msg,
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
186 _sender: Sender) {
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
187 // schedule a retry once this iteration finishes
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
188 ctx.schedule_once(Duration::from_secs(1), ctx.myself(), None, PollForParams);
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
189
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
190 if let Err(e) = self.do_poll(ctx) {
636
43eb3cfdf769 some progress, better error handling
Matt Johnston <matt@ucc.asn.au>
parents: 635
diff changeset
191 self.limitlog.and_then(|| {
43eb3cfdf769 some progress, better error handling
Matt Johnston <matt@ucc.asn.au>
parents: 635
diff changeset
192 warn!("Problem fetching params: {}", e)
43eb3cfdf769 some progress, better error handling
Matt Johnston <matt@ucc.asn.au>
parents: 635
diff changeset
193 });
634
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
194 }
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
195 }
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
196
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
197 fn pre_start(&mut self, ctx: &Context<Self::Msg>) {
a5721c02d3ee build succeeds
Matt Johnston <matt@ucc.asn.au>
parents: 633
diff changeset
198 ctx.schedule_once(Duration::from_secs(1), ctx.myself(), None, PollForParams);
592
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
199 }
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
200 }
03b48ec0bb03 fridge, types, configwaiter
Matt Johnston <matt@ucc.asn.au>
parents:
diff changeset
201
633
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
202 // pub fn stream(config: Config, handle: Handle) -> Result<(), TemplogError> {
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
203 // let rcself = Rc::new(ParamWaiter::new(config, handle));
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
204
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
205 // let dur = Duration::from_millis(4000);
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
206 // for _ in Interval::new(dur, &rcself.handle).unwrap() {
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
207 // // fetch params
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
208 // // TODO - skip if inflight.
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
209 // let r = await!(rcself.make_request()).map_err(|e| TemplogError::new_hyper("response", e))?;
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
210 // let status = r.status();
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
211 // let b = await!(r.body().concat2()).map_err(|e| TemplogError::new_hyper("body", e))?;
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
212 // if let Ok(params) = rcself.handle_response(b, status) {
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
213 // stream_yield!(params);
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
214 // }
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
215 // }
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
216 // Ok(())
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
217 // }
490e9e15b98c move some bits to riker
Matt Johnston <matt@ucc.asn.au>
parents: 632
diff changeset
218