relay/src/jobs/process_listeners.rs

32 lines
896 B
Rust
Raw Normal View History

use crate::jobs::{instance::QueryInstance, nodeinfo::QueryNodeinfo, JobState};
use anyhow::Error;
2020-04-21 00:56:50 +00:00
use background_jobs::ActixJob;
use std::{future::Future, pin::Pin};
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
pub struct Listeners;
impl Listeners {
async fn perform(self, state: JobState) -> Result<(), Error> {
2021-02-10 04:05:06 +00:00
for actor_id in state.state.db.connected_ids().await? {
state
.job_server
2021-02-10 04:05:06 +00:00
.queue(QueryInstance::new(actor_id.clone()))?;
state.job_server.queue(QueryNodeinfo::new(actor_id))?;
}
Ok(())
}
}
2020-03-30 15:45:44 +00:00
impl ActixJob for Listeners {
type State = JobState;
2020-03-30 15:45:44 +00:00
type Future = Pin<Box<dyn Future<Output = Result<(), Error>>>>;
2020-04-21 01:03:46 +00:00
const NAME: &'static str = "relay::jobs::Listeners";
2020-04-21 00:56:50 +00:00
fn run(self, state: Self::State) -> Self::Future {
2020-03-30 15:45:44 +00:00
Box::pin(self.perform(state))
}
}