29 lines
910 B
Rust
29 lines
910 B
Rust
use crate::{error::Error, jobs::JobState};
|
|
use background_jobs::{ActixJob, Backoff};
|
|
use std::{future::Future, pin::Pin};
|
|
|
|
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
|
|
pub(crate) struct RecordLastOnline;
|
|
|
|
impl RecordLastOnline {
|
|
#[tracing::instrument(skip(state))]
|
|
async fn perform(self, state: JobState) -> Result<(), Error> {
|
|
let nodes = state.state.last_online.take();
|
|
|
|
state.state.db.mark_last_seen(nodes).await
|
|
}
|
|
}
|
|
|
|
impl ActixJob for RecordLastOnline {
|
|
type State = JobState;
|
|
type Future = Pin<Box<dyn Future<Output = Result<(), anyhow::Error>>>>;
|
|
|
|
const NAME: &'static str = "relay::jobs::RecordLastOnline";
|
|
const QUEUE: &'static str = "maintenance";
|
|
const BACKOFF: Backoff = Backoff::Linear(1);
|
|
|
|
fn run(self, state: Self::State) -> Self::Future {
|
|
Box::pin(async move { self.perform(state).await.map_err(Into::into) })
|
|
}
|
|
}
|