Switch to new rpc sending method

This commit is contained in:
Paul Hauner
2021-09-24 10:14:50 +10:00
parent 95e9407cd9
commit 31ad3239d4
2 changed files with 32 additions and 48 deletions

View File

@@ -18,6 +18,7 @@ pub enum Error {
ServerMessage(String), ServerMessage(String),
Eip155Error, Eip155Error,
NoResultOrError, NoResultOrError,
IsSyncing,
} }
impl From<reqwest::Error> for Error { impl From<reqwest::Error> for Error {

View File

@@ -1,6 +1,6 @@
use super::*; use super::*;
use async_trait::async_trait; use async_trait::async_trait;
use eth1::http::{response_result_or_error, send_rpc_request, EIP155_ERROR_STR}; use eth1::http::EIP155_ERROR_STR;
use reqwest::header::CONTENT_TYPE; use reqwest::header::CONTENT_TYPE;
pub use reqwest::Client; pub use reqwest::Client;
use sensitive_url::SensitiveUrl; use sensitive_url::SensitiveUrl;
@@ -9,6 +9,9 @@ use serde_json::json;
use std::time::Duration; use std::time::Duration;
use types::{execution_payload::serde_logs_bloom, EthSpec, FixedVector, Transaction, VariableList}; use types::{execution_payload::serde_logs_bloom, EthSpec, FixedVector, Transaction, VariableList};
const ETH_SYNCING: &str = "eth_syncing";
const ETH_SYNCING_TIMEOUT: Duration = Duration::from_millis(250);
const ENGINE_PREPARE_PAYLOAD: &str = "engine_preparePayload"; const ENGINE_PREPARE_PAYLOAD: &str = "engine_preparePayload";
const ENGINE_PREPARE_PAYLOAD_TIMEOUT: Duration = Duration::from_millis(500); const ENGINE_PREPARE_PAYLOAD_TIMEOUT: Duration = Duration::from_millis(500);
@@ -81,7 +84,21 @@ impl HttpJsonRpc {
#[async_trait] #[async_trait]
impl EngineApi for HttpJsonRpc { impl EngineApi for HttpJsonRpc {
async fn upcheck(&self) -> Result<(), Error> { async fn upcheck(&self) -> Result<(), Error> {
todo!() let result: serde_json::Value = self
.rpc_request(ETH_SYNCING, json!([]), ETH_SYNCING_TIMEOUT)
.await?;
/*
* TODO
*
* Check the network and chain ids. We omit this to save time for the merge f2f and since it
* also seems like it might get annoying during development.
*/
match result.as_bool() {
Some(false) => Ok(()),
_ => Err(Error::IsSyncing),
}
} }
async fn prepare_payload( async fn prepare_payload(
@@ -98,17 +115,13 @@ impl EngineApi for HttpJsonRpc {
fee_recipient fee_recipient
}]); }]);
let response_body = send_rpc_request( let response: JsonPreparePayloadResponse = self
&self.url, .rpc_request(
ENGINE_PREPARE_PAYLOAD, ENGINE_PREPARE_PAYLOAD,
params, params,
ENGINE_PREPARE_PAYLOAD_TIMEOUT, ENGINE_PREPARE_PAYLOAD_TIMEOUT,
) )
.await .await?;
.map_err(Error::RequestFailed)?;
let result = response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
let response: JsonPreparePayloadResponse = serde_json::from_value(result)?;
Ok(response.payload_id) Ok(response.payload_id)
} }
@@ -119,18 +132,12 @@ impl EngineApi for HttpJsonRpc {
) -> Result<ExecutePayloadResponse, Error> { ) -> Result<ExecutePayloadResponse, Error> {
let params = json!([JsonExecutionPayload::from(execution_payload)]); let params = json!([JsonExecutionPayload::from(execution_payload)]);
let response_body = send_rpc_request( self.rpc_request(
&self.url,
ENGINE_EXECUTE_PAYLOAD, ENGINE_EXECUTE_PAYLOAD,
params, params,
ENGINE_EXECUTE_PAYLOAD_TIMEOUT, ENGINE_EXECUTE_PAYLOAD_TIMEOUT,
) )
.await .await
.map_err(Error::RequestFailed)?;
let result = response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
serde_json::from_value(result).map_err(Into::into)
} }
async fn get_payload<T: EthSpec>( async fn get_payload<T: EthSpec>(
@@ -139,20 +146,8 @@ impl EngineApi for HttpJsonRpc {
) -> Result<ExecutionPayload<T>, Error> { ) -> Result<ExecutionPayload<T>, Error> {
let params = json!([payload_id]); let params = json!([payload_id]);
let response_body = send_rpc_request( self.rpc_request(ENGINE_GET_PAYLOAD, params, ENGINE_GET_PAYLOAD_TIMEOUT)
&self.url, .await
ENGINE_GET_PAYLOAD,
params,
ENGINE_GET_PAYLOAD_TIMEOUT,
)
.await
.map_err(Error::RequestFailed)?;
let result = response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
serde_json::from_value::<JsonExecutionPayload<T>>(result)
.map(Into::into)
.map_err(Into::into)
} }
async fn consensus_validated( async fn consensus_validated(
@@ -162,18 +157,12 @@ impl EngineApi for HttpJsonRpc {
) -> Result<(), Error> { ) -> Result<(), Error> {
let params = json!([JsonConsensusValidatedRequest { block_hash, status }]); let params = json!([JsonConsensusValidatedRequest { block_hash, status }]);
let response_body = send_rpc_request( self.rpc_request(
&self.url,
ENGINE_CONSENSUS_VALIDATED, ENGINE_CONSENSUS_VALIDATED,
params, params,
ENGINE_CONSENSUS_VALIDATED_TIMEOUT, ENGINE_CONSENSUS_VALIDATED_TIMEOUT,
) )
.await .await
.map_err(Error::RequestFailed)?;
response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
Ok(())
} }
async fn forkchoice_updated( async fn forkchoice_updated(
@@ -186,18 +175,12 @@ impl EngineApi for HttpJsonRpc {
finalized_block_hash finalized_block_hash
}]); }]);
let response_body = send_rpc_request( self.rpc_request(
&self.url,
ENGINE_FORKCHOICE_UPDATED, ENGINE_FORKCHOICE_UPDATED,
params, params,
ENGINE_FORKCHOICE_UPDATED_TIMEOUT, ENGINE_FORKCHOICE_UPDATED_TIMEOUT,
) )
.await .await
.map_err(Error::RequestFailed)?;
response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
Ok(())
} }
} }