Skip to content

Commit

Permalink
Add 'write version' to EmulateRequestModel
Browse files Browse the repository at this point in the history
  • Loading branch information
stanislav-tkach committed Oct 12, 2023
1 parent 641bc1d commit 969f457
Show file tree
Hide file tree
Showing 9 changed files with 79 additions and 37 deletions.
10 changes: 6 additions & 4 deletions evm_loader/api/src/api_context.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,19 +6,21 @@ use std::sync::Arc;
pub async fn build_rpc_client(
state: &NeonApiState,
slot: Option<u64>,
tx_index_in_block: Option<u64>,
) -> Result<Arc<dyn rpc::Rpc>, NeonError> {
if let Some(slot) = slot {
return build_call_db_client(state, slot).await;
build_call_db_client(state, slot, tx_index_in_block).await
} else {
Ok(state.rpc_client.clone())
}

Ok(state.rpc_client.clone())
}

pub async fn build_call_db_client(
state: &NeonApiState,
slot: u64,
tx_index_in_block: Option<u64>,
) -> Result<Arc<dyn rpc::Rpc>, NeonError> {
Ok(Arc::new(
CallDbClient::new(state.tracer_db.clone(), slot).await?,
CallDbClient::new(state.tracer_db.clone(), slot, tx_index_in_block).await?,
))
}
8 changes: 7 additions & 1 deletion evm_loader/api/src/api_server/handlers/emulate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,13 @@ pub async fn emulate(
) -> impl Responder {
let tx = emulate_request.tx_params.into();

let rpc_client = match api_context::build_rpc_client(&state, emulate_request.slot).await {
let rpc_client = match api_context::build_rpc_client(
&state,
emulate_request.slot,
emulate_request.tx_index_in_block,
)
.await
{
Ok(rpc_client) => rpc_client,
Err(e) => return process_error(StatusCode::BAD_REQUEST, &e),
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ pub async fn get_ether_account_data(
request_id: RequestId,
Query(req_params): Query<GetEtherRequest>,
) -> impl Responder {
let rpc_client = match api_context::build_rpc_client(&state, req_params.slot).await {
let rpc_client = match api_context::build_rpc_client(&state, req_params.slot, None).await {
Ok(rpc_client) => rpc_client,
Err(e) => return process_error(StatusCode::BAD_REQUEST, &e),
};
Expand Down
2 changes: 1 addition & 1 deletion evm_loader/api/src/api_server/handlers/get_storage_at.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ pub async fn get_storage_at(
request_id: RequestId,
Query(req_params): Query<GetStorageAtRequest>,
) -> impl Responder {
let rpc_client = match api_context::build_rpc_client(&state, req_params.slot).await {
let rpc_client = match api_context::build_rpc_client(&state, req_params.slot, None).await {
Ok(rpc_client) => rpc_client,
Err(e) => return process_error(StatusCode::BAD_REQUEST, &e),
};
Expand Down
15 changes: 10 additions & 5 deletions evm_loader/api/src/api_server/handlers/trace.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,11 +19,16 @@ pub async fn trace(
) -> impl Responder {
let tx = trace_request.emulate_request.tx_params.into();

let rpc_client =
match api_context::build_rpc_client(&state, trace_request.emulate_request.slot).await {
Ok(rpc_client) => rpc_client,
Err(e) => return process_error(StatusCode::BAD_REQUEST, &e),
};
let rpc_client = match api_context::build_rpc_client(
&state,
trace_request.emulate_request.slot,
trace_request.emulate_request.tx_index_in_block,
)
.await
{
Ok(rpc_client) => rpc_client,
Err(e) => return process_error(StatusCode::BAD_REQUEST, &e),
};

let context = Context::new(&*rpc_client, &state.config);

Expand Down
1 change: 1 addition & 0 deletions evm_loader/cli/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,7 @@ async fn run<'a>(options: &'a ArgMatches<'a>) -> NeonCliResult {
CallDbClient::new(
TracerDb::new(config.db_config.as_ref().expect("db-config not found")),
slot,
None,
)
.await?,
)
Expand Down
21 changes: 15 additions & 6 deletions evm_loader/lib/src/rpc/db_call_client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,16 @@ use std::any::Any;

pub struct CallDbClient {
tracer_db: TracerDb,
pub slot: u64,
slot: u64,
tx_index_in_block: Option<u64>,
}

impl CallDbClient {
pub async fn new(tracer_db: TracerDb, slot: u64) -> Result<Self, NeonError> {
pub async fn new(
tracer_db: TracerDb,
slot: u64,
tx_index_in_block: Option<u64>,
) -> Result<Self, NeonError> {
let earliest_rooted_slot = tracer_db
.get_earliest_rooted_slot()
.await
Expand All @@ -37,7 +42,11 @@ impl CallDbClient {
return Err(NeonError::EarlySlot(slot, earliest_rooted_slot));
}

Ok(Self { tracer_db, slot })
Ok(Self {
tracer_db,
slot,
tx_index_in_block,
})
}
}

Expand All @@ -60,7 +69,7 @@ impl Rpc for CallDbClient {

async fn get_account(&self, key: &Pubkey) -> ClientResult<Account> {
self.tracer_db
.get_account_at(key, self.slot)
.get_account_at(key, self.slot, self.tx_index_in_block)
.await
.map_err(|e| e!("load account error", key, e))?
.ok_or_else(|| e!("account not found", key))
Expand All @@ -73,7 +82,7 @@ impl Rpc for CallDbClient {
) -> RpcResult<Option<Account>> {
let account = self
.tracer_db
.get_account_at(key, self.slot)
.get_account_at(key, self.slot, self.tx_index_in_block)
.await
.map_err(|e| e!("load account error", key, e))?;

Expand All @@ -95,7 +104,7 @@ impl Rpc for CallDbClient {
for key in pubkeys {
let account = self
.tracer_db
.get_account_at(key, self.slot)
.get_account_at(key, self.slot, self.tx_index_in_block)
.await
.map_err(|e| e!("load account error", key, e))?;
result.push(account);
Expand Down
1 change: 1 addition & 0 deletions evm_loader/lib/src/types/request_models.rs
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,7 @@ pub struct EmulateRequestModel {
#[serde(flatten)]
pub emulation_params: EmulationParamsRequestModel,
pub slot: Option<u64>,
pub tx_index_in_block: Option<u64>,
}

#[derive(Deserialize, Serialize, Debug, Default)]
Expand Down
56 changes: 37 additions & 19 deletions evm_loader/lib/src/types/tracer_ch_db.rs
Original file line number Diff line number Diff line change
Expand Up @@ -221,8 +221,15 @@ impl ClickHouseDb {
}

#[allow(clippy::too_many_lines)]
pub async fn get_account_at(&self, pubkey: &Pubkey, slot: u64) -> ChResult<Option<Account>> {
info!("get_account_at {{ pubkey: {pubkey}, slot: {slot} }}");
pub async fn get_account_at(
&self,
pubkey: &Pubkey,
slot: u64,
tx_index_in_block: Option<u64>,
) -> ChResult<Option<Account>> {
info!(
"get_account_at {{ pubkey: {pubkey}, slot: {slot}, tx index in block: {tx_index_in_block:?} }}"
);
let (first, mut branch) = self.get_branch_slots(Some(slot)).await.map_err(|e| {
println!("get_branch_slots error: {:?}", e);
e
Expand All @@ -244,24 +251,35 @@ impl ClickHouseDb {
let mut row = if branch.is_empty() {
None
} else {
let query = r#"
SELECT owner, lamports, executable, rent_epoch, data, txn_signature
FROM events.update_account_distributed
WHERE pubkey = ?
AND slot IN ?
ORDER BY pubkey, slot DESC, write_version DESC
LIMIT 1
"#;
let query = if tx_index_in_block.is_some() {
r#"
SELECT owner, lamports, executable, rent_epoch, data, txn_signature
FROM events.update_account_distributed
WHERE pubkey = ?
AND write_version = ?
AND slot IN ?
ORDER BY slot DESC, write_version DESC
LIMIT 1
"#
} else {
r#"
SELECT owner, lamports, executable, rent_epoch, data, txn_signature
FROM events.update_account_distributed
WHERE pubkey = ?
AND slot IN ?
ORDER BY slot DESC, write_version DESC
LIMIT 1
"#
};

let time_start = Instant::now();
let row = Self::row_opt(
self.client
.query(query)
.bind(pubkey_str.clone())
.bind(branch.as_slice())
.fetch_one::<AccountRow>()
.await,
)
let row = Self::row_opt({
let mut row = self.client.query(query).bind(pubkey_str.clone());
if let Some(tx_index_in_block) = tx_index_in_block {
row = row.bind(tx_index_in_block);
}
row.bind(branch.as_slice()).fetch_one::<AccountRow>().await
})
.map_err(|e| {
println!("get_account_at error: {e}");
ChError::Db(e)
Expand Down Expand Up @@ -470,7 +488,7 @@ impl ClickHouseDb {

// If not found, get closest account state in one of previous slots
if let Some(parent) = slot.parent {
self.get_account_at(pubkey, parent).await
self.get_account_at(pubkey, parent, None).await
} else {
Ok(None)
}
Expand Down

0 comments on commit 969f457

Please sign in to comment.