diff --git a/common/ethereum/src/eth_contracts/ptokens_router.rs b/common/ethereum/src/eth_contracts/ptokens_router.rs index 46ac50a9..16a5415a 100644 --- a/common/ethereum/src/eth_contracts/ptokens_router.rs +++ b/common/ethereum/src/eth_contracts/ptokens_router.rs @@ -5,7 +5,11 @@ use common_metadata::{MetadataChainId, METADATA_CHAIN_ID_NUMBER_OF_BYTES}; use derive_more::Constructor; use ethabi::{decode as eth_abi_decode, ParamType as EthAbiParamType, Token as EthAbiToken}; -use crate::{EthLog, EthLogExt}; +use crate::{EthLog, EthLogExt, EthReceipt}; + +crate::make_topics!( + PTOKENS_ROUTER_METADATA_EVENT_TOPIC => "41954c3bf6e497b17fc12f429900878df830619bbcccb5f61aedc91e6ccc9e64", +); #[derive(Debug, Clone, Constructor, Eq, PartialEq, Default)] pub struct PTokensRouterMetadataEvent { @@ -61,3 +65,19 @@ impl TryFrom<&EthLog> for PTokensRouterMetadataEvent { }) } } + +impl TryFrom<&EthReceipt> for PTokensRouterMetadataEvent { + type Error = AppError; + + fn try_from(receipt: &EthReceipt) -> std::result::Result { + info!("decoding `PTokensRouterMetadataEvent` from receipt..."); + + match receipt + .logs + .iter().find(|log| log.contains_topic(&PTOKENS_ROUTER_METADATA_EVENT_TOPIC)) + { + Some(log) => Self::try_from(log), + None => Err("no matching log found".to_string())?, + } + } +}