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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
use serde::{Deserialize, Serialize};
use serde_json::Value;
#[derive(Debug, Serialize, Deserialize)]
pub struct RpcStateChangesInBlockRequest {
#[serde(flatten)]
pub block_reference: near_primitives_v01::types::BlockReference,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct RpcStateChangesInBlockResponse {
pub block_hash: near_primitives_v01::hash::CryptoHash,
pub changes: near_primitives_v01::views::StateChangesView,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct RpcStateChangesInBlockByTypeRequest {
#[serde(flatten)]
pub block_reference: near_primitives_v01::types::BlockReference,
#[serde(flatten)]
pub state_changes_request: near_primitives_v01::views::StateChangesRequestView,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct RpcStateChangesInBlockByTypeResponse {
pub block_hash: near_primitives_v01::hash::CryptoHash,
pub changes: near_primitives_v01::views::StateChangesKindsView,
}
#[derive(thiserror::Error, Debug, Serialize, Deserialize)]
#[serde(tag = "name", content = "info", rename_all = "SCREAMING_SNAKE_CASE")]
pub enum RpcStateChangesError {
#[error("Block not found: {error_message}")]
UnknownBlock {
#[serde(skip_serializing)]
error_message: String,
},
#[error("There are no fully synchronized blocks yet")]
NotSyncedYet,
#[error("The node reached its limits. Try again later. More details: {error_message}")]
InternalError { error_message: String },
}
impl RpcStateChangesInBlockRequest {
pub fn parse(value: Option<Value>) -> Result<Self, crate::errors::RpcParseError> {
Ok(crate::utils::parse_params::<Self>(value)?)
}
}
impl RpcStateChangesInBlockByTypeRequest {
pub fn parse(value: Option<Value>) -> Result<Self, crate::errors::RpcParseError> {
Ok(crate::utils::parse_params::<Self>(value)?)
}
}
impl From<near_client_primitives::types::GetBlockError> for RpcStateChangesError {
fn from(error: near_client_primitives::types::GetBlockError) -> Self {
match error {
near_client_primitives::types::GetBlockError::UnknownBlock { error_message } => {
Self::UnknownBlock { error_message }
}
near_client_primitives::types::GetBlockError::NotSyncedYet => Self::NotSyncedYet,
near_client_primitives::types::GetBlockError::IOError { error_message } => {
Self::InternalError { error_message }
}
near_client_primitives::types::GetBlockError::Unreachable { ref error_message } => {
tracing::warn!(target: "jsonrpc", "Unreachable error occurred: {}", &error_message);
near_metrics::inc_counter_vec(
&crate::metrics::RPC_UNREACHABLE_ERROR_COUNT,
&["RpcStateChangesError"],
);
Self::InternalError { error_message: error.to_string() }
}
}
}
}
impl From<near_client_primitives::types::GetStateChangesError> for RpcStateChangesError {
fn from(error: near_client_primitives::types::GetStateChangesError) -> Self {
match error {
near_client_primitives::types::GetStateChangesError::IOError { error_message } => {
Self::InternalError { error_message }
}
near_client_primitives::types::GetStateChangesError::UnknownBlock { error_message } => {
Self::UnknownBlock { error_message }
}
near_client_primitives::types::GetStateChangesError::NotSyncedYet => Self::NotSyncedYet,
near_client_primitives::types::GetStateChangesError::Unreachable {
ref error_message,
} => {
tracing::warn!(target: "jsonrpc", "Unreachable error occurred: {}", &error_message);
near_metrics::inc_counter_vec(
&crate::metrics::RPC_UNREACHABLE_ERROR_COUNT,
&["RpcStateChangesError"],
);
Self::InternalError { error_message: error.to_string() }
}
}
}
}
impl From<RpcStateChangesError> for crate::errors::RpcError {
fn from(error: RpcStateChangesError) -> Self {
let error_data = match serde_json::to_value(error) {
Ok(value) => value,
Err(err) => {
return Self::new_internal_error(
None,
format!("Failed to serialize RpcStateChangesError: {:?}", err),
)
}
};
Self::new_internal_or_handler_error(Some(error_data.clone()), error_data)
}
}
impl From<actix::MailboxError> for RpcStateChangesError {
fn from(error: actix::MailboxError) -> Self {
Self::InternalError { error_message: error.to_string() }
}
}