39 lines
1.1 KiB
Rust
39 lines
1.1 KiB
Rust
use crate::{
|
|
config::UrlKind,
|
|
db::Actor,
|
|
error::Error,
|
|
jobs::{apub::generate_undo_follow, Deliver, JobState},
|
|
};
|
|
use background_jobs::ActixJob;
|
|
use std::{future::Future, pin::Pin};
|
|
|
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
|
pub(crate) struct Reject(pub(crate) Actor);
|
|
|
|
impl Reject {
|
|
#[tracing::instrument(name = "Reject", skip(state))]
|
|
async fn perform(self, state: JobState) -> Result<(), Error> {
|
|
state.actors.remove_connection(&self.0).await?;
|
|
|
|
let my_id = state.config.generate_url(UrlKind::Actor);
|
|
let undo = generate_undo_follow(&state.config, &self.0.id, &my_id)?;
|
|
|
|
state
|
|
.job_server
|
|
.queue(Deliver::new(self.0.inbox, undo)?)
|
|
.await?;
|
|
|
|
Ok(())
|
|
}
|
|
}
|
|
|
|
impl ActixJob for Reject {
|
|
type State = JobState;
|
|
type Future = Pin<Box<dyn Future<Output = Result<(), anyhow::Error>>>>;
|
|
|
|
const NAME: &'static str = "relay::jobs::apub::Reject";
|
|
|
|
fn run(self, state: Self::State) -> Self::Future {
|
|
Box::pin(async move { self.perform(state).await.map_err(Into::into) })
|
|
}
|
|
}
|