meta_srv/service/admin/
node_lease.rsuse std::collections::HashMap;
use serde::{Deserialize, Serialize};
use snafu::ResultExt;
use tonic::codegen::http;
use crate::cluster::MetaPeerClientRef;
use crate::error::{self, Result};
use crate::key::{DatanodeLeaseKey, LeaseValue};
use crate::lease;
use crate::service::admin::HttpHandler;
pub struct NodeLeaseHandler {
pub meta_peer_client: MetaPeerClientRef,
}
#[async_trait::async_trait]
impl HttpHandler for NodeLeaseHandler {
async fn handle(
&self,
_: &str,
_: http::Method,
_: &HashMap<String, String>,
) -> Result<http::Response<String>> {
let leases = lease::alive_datanodes(&self.meta_peer_client, u64::MAX).await?;
let leases = leases
.into_iter()
.map(|(k, v)| HumanLease {
name: k,
human_time: common_time::Timestamp::new_millisecond(v.timestamp_millis)
.to_local_string(),
lease: v,
})
.collect::<Vec<_>>();
let result = LeaseValues { leases }.try_into()?;
http::Response::builder()
.status(http::StatusCode::OK)
.body(result)
.context(error::InvalidHttpBodySnafu)
}
}
#[derive(Debug, Serialize, Deserialize)]
pub struct HumanLease {
pub name: DatanodeLeaseKey,
pub human_time: String,
pub lease: LeaseValue,
}
#[derive(Debug, Serialize, Deserialize)]
#[serde(transparent)]
pub struct LeaseValues {
pub leases: Vec<HumanLease>,
}
impl TryFrom<LeaseValues> for String {
type Error = error::Error;
fn try_from(vals: LeaseValues) -> Result<Self> {
serde_json::to_string(&vals).context(error::SerializeToJsonSnafu {
input: format!("{vals:?}"),
})
}
}