mirror of
https://github.com/sigp/lighthouse.git
synced 2026-07-03 04:44:28 +00:00
Switch to new rpc sending method
This commit is contained in:
@@ -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 {
|
||||||
|
|||||||
@@ -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,
|
|
||||||
ENGINE_GET_PAYLOAD,
|
|
||||||
params,
|
|
||||||
ENGINE_GET_PAYLOAD_TIMEOUT,
|
|
||||||
)
|
|
||||||
.await
|
.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(())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user