relay/src/jobs/deliver_many.rs

65 lines
1.5 KiB
Rust
Raw Normal View History

use crate::{
2021-09-18 17:55:39 +00:00
error::Error,
jobs::{Deliver, JobState},
};
2020-09-07 21:51:02 +00:00
use activitystreams::url::Url;
2020-04-21 00:56:50 +00:00
use background_jobs::ActixJob;
2021-09-18 17:55:39 +00:00
use std::future::{ready, Ready};
2021-09-21 19:32:25 +00:00
#[derive(Clone, serde::Deserialize, serde::Serialize)]
2021-02-10 04:17:20 +00:00
pub(crate) struct DeliverMany {
2020-06-27 22:29:23 +00:00
to: Vec<Url>,
data: serde_json::Value,
}
2021-09-21 19:32:25 +00:00
impl std::fmt::Debug for DeliverMany {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
let to = format!(
"[{}]",
self.to
.iter()
.map(|u| u.to_string())
.collect::<Vec<_>>()
.join(", ")
);
f.debug_struct("DeliverMany")
.field("to", &to)
.field("data", &self.data)
.finish()
}
}
impl DeliverMany {
2021-09-18 17:55:39 +00:00
pub(crate) fn new<T>(to: Vec<Url>, data: T) -> Result<Self, Error>
where
T: serde::ser::Serialize,
{
Ok(DeliverMany {
2020-06-27 22:29:23 +00:00
to,
data: serde_json::to_value(data)?,
})
}
2021-09-18 17:55:39 +00:00
#[tracing::instrument(name = "Deliver many")]
fn perform(self, state: JobState) -> Result<(), Error> {
for inbox in self.to {
state
.job_server
.queue(Deliver::new(inbox, self.data.clone())?)?;
}
Ok(())
}
}
2020-03-30 15:45:44 +00:00
impl ActixJob for DeliverMany {
type State = JobState;
2021-09-18 17:55:39 +00:00
type Future = Ready<Result<(), anyhow::Error>>;
2020-04-21 01:03:46 +00:00
const NAME: &'static str = "relay::jobs::DeliverMany";
2020-04-21 00:56:50 +00:00
fn run(self, state: Self::State) -> Self::Future {
2021-09-18 17:55:39 +00:00
ready(self.perform(state).map_err(Into::into))
}
}