syndicate-rs/syndicate-server/src/services/debt_reporter.rs

36 lines
1.2 KiB
Rust
Raw Normal View History

2022-01-19 13:40:50 +00:00
use preserves_schema::Codec;
use std::sync::Arc;
use syndicate::actor::*;
2021-09-23 19:46:10 +00:00
use syndicate::enclose;
2022-01-19 13:40:50 +00:00
use syndicate::preserves::rec;
use syndicate::preserves::value::NestedValue;
2021-08-28 16:50:55 +00:00
use crate::language::language;
use crate::lifecycle;
2021-09-20 13:10:31 +00:00
use crate::schemas::internal_services::DebtReporter;
use syndicate_macros::during;
pub fn on_demand(t: &mut Activation, ds: Arc<Cap>) {
2022-01-19 13:40:50 +00:00
t.spawn(Some(AnyValue::symbol("debt_reporter_listener")), move |t| {
Ok(during!(t, ds, language(), <run-service $spec: DebtReporter>, |t: &mut Activation| {
2022-01-19 13:40:50 +00:00
t.spawn_link(Some(rec![AnyValue::symbol("debt_reporter"), language().unparse(&spec)]),
enclose!((ds) |t| run(t, ds, spec)));
2021-09-20 13:10:31 +00:00
Ok(())
}))
2021-09-01 15:31:01 +00:00
});
}
fn run(t: &mut Activation, ds: Arc<Cap>, spec: DebtReporter) -> ActorResult {
ds.assert(t, language(), &lifecycle::started(&spec));
ds.assert(t, language(), &lifecycle::ready(&spec));
t.every(core::time::Duration::from_millis((spec.interval_seconds.0 * 1000.0) as u64), |_t| {
for (id, (name, debt)) in syndicate::actor::ACCOUNTS.read().iter() {
2022-01-19 13:40:50 +00:00
tracing::info!(id, ?name, debt = ?debt.load(std::sync::atomic::Ordering::Relaxed));
}
Ok(())
})
}