111 lines
2.6 KiB
Rust
111 lines
2.6 KiB
Rust
|
use crate::jobs::JobState;
|
||
|
use activitystreams::primitives::XsdAnyUri;
|
||
|
use anyhow::Error;
|
||
|
use background_jobs::{Job, Processor};
|
||
|
use std::{future::Future, pin::Pin};
|
||
|
use tokio::sync::oneshot;
|
||
|
|
||
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
||
|
pub struct QueryInstance {
|
||
|
listener: XsdAnyUri,
|
||
|
}
|
||
|
|
||
|
impl QueryInstance {
|
||
|
pub fn new(listener: XsdAnyUri) -> Self {
|
||
|
QueryInstance { listener }
|
||
|
}
|
||
|
|
||
|
async fn perform(mut self, state: JobState) -> Result<(), Error> {
|
||
|
let listener = self.listener.clone();
|
||
|
|
||
|
let url = self.listener.as_url_mut();
|
||
|
url.set_fragment(None);
|
||
|
url.set_query(None);
|
||
|
url.set_path("api/v1/instance");
|
||
|
|
||
|
let instance = state
|
||
|
.requests
|
||
|
.fetch::<Instance>(self.listener.as_str())
|
||
|
.await?;
|
||
|
|
||
|
let description = if instance.description.is_empty() {
|
||
|
instance.short_description
|
||
|
} else {
|
||
|
instance.description
|
||
|
};
|
||
|
|
||
|
if let Some(contact) = instance.contact {
|
||
|
state
|
||
|
.node_cache
|
||
|
.set_contact(
|
||
|
listener.clone(),
|
||
|
contact.username,
|
||
|
contact.display_name,
|
||
|
contact.url,
|
||
|
contact.avatar,
|
||
|
)
|
||
|
.await;
|
||
|
}
|
||
|
|
||
|
state
|
||
|
.node_cache
|
||
|
.set_instance(
|
||
|
listener,
|
||
|
instance.title,
|
||
|
description,
|
||
|
instance.version,
|
||
|
instance.registrations,
|
||
|
instance.approval_required,
|
||
|
)
|
||
|
.await;
|
||
|
|
||
|
Ok(())
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#[derive(Clone, Debug)]
|
||
|
pub struct InstanceProcessor;
|
||
|
|
||
|
impl Job for QueryInstance {
|
||
|
type State = JobState;
|
||
|
type Processor = InstanceProcessor;
|
||
|
type Future = Pin<Box<dyn Future<Output = Result<(), Error>> + Send>>;
|
||
|
|
||
|
fn run(self, state: Self::State) -> Self::Future {
|
||
|
let (tx, rx) = oneshot::channel();
|
||
|
|
||
|
actix::spawn(async move {
|
||
|
let _ = tx.send(self.perform(state).await);
|
||
|
});
|
||
|
|
||
|
Box::pin(async move { rx.await? })
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl Processor for InstanceProcessor {
|
||
|
type Job = QueryInstance;
|
||
|
|
||
|
const NAME: &'static str = "InstanceProcessor";
|
||
|
const QUEUE: &'static str = "default";
|
||
|
}
|
||
|
|
||
|
#[derive(serde::Deserialize)]
|
||
|
struct Instance {
|
||
|
title: String,
|
||
|
short_description: String,
|
||
|
description: String,
|
||
|
version: String,
|
||
|
registrations: bool,
|
||
|
approval_required: bool,
|
||
|
|
||
|
contact: Option<Contact>,
|
||
|
}
|
||
|
|
||
|
#[derive(serde::Deserialize)]
|
||
|
struct Contact {
|
||
|
username: String,
|
||
|
display_name: String,
|
||
|
url: XsdAnyUri,
|
||
|
avatar: XsdAnyUri,
|
||
|
}
|