Modify decoding

This commit is contained in:
Paul Hauner
2021-09-22 09:59:59 +10:00
parent 7433385fb3
commit ac1cdc5ca4
2 changed files with 17 additions and 5 deletions

View File

@@ -13,6 +13,7 @@ pub enum Error {
BadResponse(String), BadResponse(String),
RequestFailed(String), RequestFailed(String),
JsonRpc(RpcError), JsonRpc(RpcError),
Json(serde_json::Error),
} }
impl From<reqwest::Error> for Error { impl From<reqwest::Error> for Error {
@@ -21,6 +22,12 @@ impl From<reqwest::Error> for Error {
} }
} }
impl From<serde_json::Error> for Error {
fn from(e: serde_json::Error) -> Self {
Error::Json(e)
}
}
#[async_trait] #[async_trait]
pub trait EngineApi { pub trait EngineApi {
async fn upcheck(&self) -> Result<(), Error>; async fn upcheck(&self) -> Result<(), Error>;

View File

@@ -1,6 +1,6 @@
use super::*; use super::*;
use async_trait::async_trait; use async_trait::async_trait;
use eth1::http::{hex_to_u64_be, response_result_or_error, send_rpc_request}; use eth1::http::{response_result_or_error, send_rpc_request};
pub use reqwest::Client; pub use reqwest::Client;
use sensitive_url::SensitiveUrl; use sensitive_url::SensitiveUrl;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
@@ -54,11 +54,9 @@ impl EngineApi for HttpJsonRpc {
.map_err(Error::RequestFailed)?; .map_err(Error::RequestFailed)?;
let result = response_result_or_error(&response_body).map_err(Error::JsonRpc)?; let result = response_result_or_error(&response_body).map_err(Error::JsonRpc)?;
let string = result let response: PreparePayloadResponse = serde_json::from_value(result)?;
.as_str()
.ok_or(Error::BadResponse("data was not string".to_string()))?;
hex_to_u64_be(string).map_err(Error::BadResponse) Ok(response.payload_id)
} }
} }
@@ -71,3 +69,10 @@ struct PreparePayloadRequest {
random: Hash256, random: Hash256,
fee_recipient: Address, fee_recipient: Address,
} }
#[derive(Debug, PartialEq, Serialize, Deserialize)]
#[serde(transparent, rename = "camelCase")]
struct PreparePayloadResponse {
#[serde(with = "eth2_serde_utils::u64_hex_be")]
payload_id: u64,
}