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
122
123
124
125
#![allow(clippy::field_reassign_with_default)]
use std::str;
use futures::{future::BoxFuture, FutureExt};
use http::Response;
use hyper::Body;
use once_cell::sync::Lazy;
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};
use tracing::info;
use warp_json_rpc::Builder;
use casper_types::ProtocolVersion;
use super::{
docs::{DocExample, DOCS_EXAMPLE_PROTOCOL_VERSION},
Error, ReactorEventT, RpcRequest, RpcWithParams, RpcWithParamsExt,
};
use crate::{
components::rpc_server::rpcs::ErrorCode,
effect::EffectBuilder,
reactor::QueueKind,
types::{Deploy, DeployHash},
};
static PUT_DEPLOY_PARAMS: Lazy<PutDeployParams> = Lazy::new(|| PutDeployParams {
deploy: Deploy::doc_example().clone(),
});
static PUT_DEPLOY_RESULT: Lazy<PutDeployResult> = Lazy::new(|| PutDeployResult {
api_version: DOCS_EXAMPLE_PROTOCOL_VERSION,
deploy_hash: *Deploy::doc_example().id(),
});
#[derive(Serialize, Deserialize, Debug, JsonSchema)]
#[serde(deny_unknown_fields)]
pub struct PutDeployParams {
pub deploy: Deploy,
}
impl DocExample for PutDeployParams {
fn doc_example() -> &'static Self {
&*PUT_DEPLOY_PARAMS
}
}
#[derive(Serialize, Deserialize, Debug, JsonSchema)]
#[serde(deny_unknown_fields)]
pub struct PutDeployResult {
#[schemars(with = "String")]
pub api_version: ProtocolVersion,
pub deploy_hash: DeployHash,
}
impl DocExample for PutDeployResult {
fn doc_example() -> &'static Self {
&*PUT_DEPLOY_RESULT
}
}
pub struct PutDeploy {}
impl RpcWithParams for PutDeploy {
const METHOD: &'static str = "account_put_deploy";
type RequestParams = PutDeployParams;
type ResponseResult = PutDeployResult;
}
impl RpcWithParamsExt for PutDeploy {
fn handle_request<REv: ReactorEventT>(
effect_builder: EffectBuilder<REv>,
response_builder: Builder,
params: Self::RequestParams,
api_version: ProtocolVersion,
) -> BoxFuture<'static, Result<Response<Body>, Error>> {
async move {
let deploy_hash = *params.deploy.id();
let put_deploy_result = effect_builder
.make_request(
|responder| RpcRequest::SubmitDeploy {
deploy: Box::new(params.deploy),
responder,
},
QueueKind::Api,
)
.await;
match put_deploy_result {
Ok(_) => {
info!(%deploy_hash,
"deploy was stored"
);
let result = Self::ResponseResult {
api_version,
deploy_hash,
};
Ok(response_builder.success(result)?)
}
Err(error) => {
info!(
%deploy_hash,
%error,
"the deploy submitted by the client was invalid",
);
Ok(response_builder.error(warp_json_rpc::Error::custom(
ErrorCode::InvalidDeploy as i64,
error.to_string(),
))?)
}
}
}
.boxed()
}
}