fix(fortuna): Fortuna improvements (#1529)

* More logging on failure of deserialization
* Log chain id if the provider registration is failing
* Fix sample config
* Fix dysfunctional rpc address from blast
This commit is contained in:
Amin Moghaddam 2024-05-01 13:19:37 +02:00 committed by GitHub
parent 4e630edac0
commit b2cb7c878a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 26 additions and 7 deletions

View File

@ -1488,7 +1488,7 @@ dependencies = [
[[package]]
name = "fortuna"
version = "5.1.0"
version = "5.1.1"
dependencies = [
"anyhow",
"axum",

View File

@ -1,6 +1,6 @@
[package]
name = "fortuna"
version = "5.1.0"
version = "5.1.1"
edition = "2021"
[dependencies]

View File

@ -4,3 +4,4 @@ chains:
contract_addr: 0x8250f4aF4B972684F7b336503E2D6dFeDeB1487a
reveal_delay_blocks: 0
legacy_tx: true
gas_limit: 500000

View File

@ -143,7 +143,14 @@ pub async fn run(opts: &RunOptions) -> Result<()> {
let provider_info = contract.get_provider_info(opts.provider).call().await?;
let latest_metadata =
bincode::deserialize::<CommitmentMetadata>(&provider_info.commitment_metadata)?;
bincode::deserialize::<CommitmentMetadata>(&provider_info.commitment_metadata)
.map_err(|e| {
anyhow!(
"Chain: {} - Failed to deserialize commitment metadata: {}",
&chain_id,
e
)
})?;
provider_commitments.push(Commitment {
seed: latest_metadata.seed,

View File

@ -16,7 +16,10 @@ use {
PebbleHashChain,
},
},
anyhow::Result,
anyhow::{
anyhow,
Result,
},
ethers::{
abi::Bytes as AbiBytes,
signers::{
@ -66,7 +69,14 @@ pub async fn setup_provider(opts: &SetupProviderOptions) -> Result<()> {
register = true;
} else {
let metadata =
bincode::deserialize::<CommitmentMetadata>(&provider_info.commitment_metadata)?;
bincode::deserialize::<CommitmentMetadata>(&provider_info.commitment_metadata)
.map_err(|e| {
anyhow!(
"Chain: {} - Failed to deserialize commitment metadata: {}",
&chain_id,
e
)
})?;
let hash_chain = PebbleHashChain::from_config(
&secret,
@ -105,7 +115,8 @@ pub async fn setup_provider(opts: &SetupProviderOptions) -> Result<()> {
fee: opts.fee,
uri,
})
.await?;
.await
.map_err(|e| anyhow!("Chain: {} - Failed to register provider: {}", &chain_id, e))?;
tracing::info!("{}: registered", &chain_id);
} else {
if provider_info.fee_in_wei != opts.fee {

View File

@ -450,7 +450,7 @@
type: EvmChain
- id: blast_s2_testnet
mainnet: false
rpcUrl: https://blast-sepolia.blockpi.network/v1/rpc/public
rpcUrl: https://sepolia.blast.io
networkId: 168587773
type: EvmChain
- id: hedera_testnet