sui_rpc_api/service/health.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
// Copyright (c) Mysten Labs, Inc.
// SPDX-License-Identifier: Apache-2.0
use axum::extract::{Query, State};
use std::time::Duration;
use std::time::SystemTime;
use crate::Result;
use crate::RpcService;
impl RpcService {
/// Perform a simple health check on the service.
///
/// The threshold, or delta, between the server's system time and the timestamp in the most
/// recently executed checkpoint for which the server is considered to be healthy.
///
/// If not provided, the server will be considered healthy if it can simply fetch the latest
/// checkpoint from its store.
pub fn health_check(&self, threshold_seconds: Option<u32>) -> Result<()> {
let summary = self.reader.inner().get_latest_checkpoint()?;
// If we have a provided threshold, check that it's close to the current time
if let Some(threshold_seconds) = threshold_seconds {
let latest_chain_time = summary.timestamp();
let threshold = SystemTime::now() - Duration::from_secs(threshold_seconds as u64);
if latest_chain_time < threshold {
return Err(anyhow::anyhow!(
"The latest checkpoint timestamp is less than the provided threshold"
)
.into());
}
}
Ok(())
}
}
#[derive(Debug, serde::Serialize, serde::Deserialize)]
pub struct Threshold {
/// The threshold, or delta, between the server's system time and the timestamp in the most
/// recently executed checkpoint for which the server is considered to be healthy.
///
/// If not provided, the server will be considered healthy if it can simply fetch the latest
/// checkpoint from its store.
pub threshold_seconds: Option<u32>,
}
pub async fn health(
Query(Threshold { threshold_seconds }): Query<Threshold>,
State(state): State<RpcService>,
) -> impl axum::response::IntoResponse {
match state.health_check(threshold_seconds) {
Ok(()) => (axum::http::StatusCode::OK, "up"),
Err(_) => (axum::http::StatusCode::SERVICE_UNAVAILABLE, "down"),
}
}