2021-08-28 12:39:00 +00:00
|
|
|
use std::sync::Arc;
|
|
|
|
|
2021-08-27 14:19:14 +00:00
|
|
|
use syndicate::actor::*;
|
2021-08-28 16:50:55 +00:00
|
|
|
use syndicate::convert::*;
|
2021-08-28 12:39:00 +00:00
|
|
|
use syndicate::during::entity;
|
|
|
|
use syndicate::schemas::dataspace::Observe;
|
2021-08-28 16:50:55 +00:00
|
|
|
|
|
|
|
use crate::schemas::internal_services;
|
2021-08-27 14:19:14 +00:00
|
|
|
|
2021-08-28 12:39:00 +00:00
|
|
|
pub fn on_demand(t: &mut Activation, ds: Arc<Cap>) {
|
2021-08-30 10:07:30 +00:00
|
|
|
t.spawn(syndicate::name!("on_demand", module = module_path!()), move |t| {
|
2021-08-28 12:39:00 +00:00
|
|
|
let monitor = entity(())
|
2021-08-28 16:50:55 +00:00
|
|
|
.on_asserted_facet({
|
|
|
|
let ds = Arc::clone(&ds);
|
|
|
|
move |_, t, _| {
|
|
|
|
let ds = Arc::clone(&ds);
|
|
|
|
t.spawn_link(tracing::Span::current(), |t| run(t, ds));
|
|
|
|
Ok(())
|
|
|
|
}
|
2021-08-28 12:39:00 +00:00
|
|
|
})
|
|
|
|
.create_cap(t);
|
2021-08-28 16:50:55 +00:00
|
|
|
let spec = from_io_value(&internal_services::DebtReporter)?;
|
2021-08-28 12:39:00 +00:00
|
|
|
ds.assert(t, &Observe {
|
2021-08-28 16:50:55 +00:00
|
|
|
pattern: syndicate_macros::pattern!("<require-service =spec>"),
|
2021-08-28 12:39:00 +00:00
|
|
|
observer: monitor,
|
2021-08-27 14:19:14 +00:00
|
|
|
});
|
|
|
|
Ok(())
|
2021-08-28 12:39:00 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-08-28 16:50:55 +00:00
|
|
|
fn run(t: &mut Activation, ds: Arc<Cap>) -> ActorResult {
|
|
|
|
let spec = from_io_value(&internal_services::DebtReporter)?;
|
|
|
|
ds.assert(t, syndicate_macros::template!("<service-running =spec>"));
|
2021-08-28 12:39:00 +00:00
|
|
|
t.linked_task(syndicate::name!("tick"), async {
|
|
|
|
let mut timer = tokio::time::interval(core::time::Duration::from_secs(1));
|
|
|
|
loop {
|
|
|
|
timer.tick().await;
|
|
|
|
for (id, (name, debt)) in syndicate::actor::ACCOUNTS.read().unwrap().iter() {
|
|
|
|
let _enter = name.enter();
|
2021-08-30 10:06:40 +00:00
|
|
|
tracing::info!(id, debt = ?debt.load(std::sync::atomic::Ordering::Relaxed));
|
2021-08-28 12:39:00 +00:00
|
|
|
}
|
|
|
|
}
|
2021-08-27 14:19:14 +00:00
|
|
|
});
|
2021-08-28 12:39:00 +00:00
|
|
|
Ok(())
|
2021-08-27 14:19:14 +00:00
|
|
|
}
|