use std::sync::Arc; use syndicate::actor::*; use syndicate::enclose; use crate::language::language; use crate::lifecycle; use crate::schemas::internal_services::DebtReporter; use syndicate_macros::during; pub fn on_demand(t: &mut Activation, ds: Arc) { t.spawn(syndicate::name!("on_demand", module = module_path!()), move |t| { Ok(during!(t, ds, language(), , |t: &mut Activation| { t.spawn_link(tracing::Span::current(), enclose!((ds) |t| run(t, ds))); Ok(()) })) }); } fn run(t: &mut Activation, ds: Arc) -> ActorResult { ds.assert(t, language(), &lifecycle::started(&DebtReporter)); ds.assert(t, language(), &lifecycle::ready(&DebtReporter)); 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(); tracing::info!(id, debt = ?debt.load(std::sync::atomic::Ordering::Relaxed)); } } }); Ok(()) }