near_jsonrpc_primitives/types/
maintenance.rs

1use serde_json::Value;
2
3pub type RpcMaintenanceWindowsResponse = Vec<std::ops::Range<near_primitives::types::BlockHeight>>;
4
5#[derive(thiserror::Error, Debug, Clone, serde::Serialize, serde::Deserialize)]
6#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
7#[serde(tag = "name", content = "info", rename_all = "SCREAMING_SNAKE_CASE")]
8pub enum RpcMaintenanceWindowsError {
9    #[error("The node reached its limits. Try again later. More details: {error_message}")]
10    InternalError { error_message: String },
11}
12
13#[derive(serde::Serialize, serde::Deserialize, Debug)]
14#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
15pub struct RpcMaintenanceWindowsRequest {
16    pub account_id: near_primitives::types::AccountId,
17}
18
19impl From<RpcMaintenanceWindowsError> for crate::errors::RpcError {
20    fn from(error: RpcMaintenanceWindowsError) -> Self {
21        let error_data = match &error {
22            RpcMaintenanceWindowsError::InternalError { .. } => {
23                Some(Value::String(error.to_string()))
24            }
25        };
26
27        let error_data_value = match serde_json::to_value(error) {
28            Ok(value) => value,
29            Err(err) => {
30                return Self::new_internal_error(
31                    None,
32                    format!("Failed to serialize RpcMaintenanceError: {:?}", err),
33                );
34            }
35        };
36
37        Self::new_internal_or_handler_error(error_data, error_data_value)
38    }
39}