From f1715f0eb7fca0742a2ba10f731fb46d30c74f83 Mon Sep 17 00:00:00 2001 From: Chris Smith Date: Thu, 8 Feb 2024 13:49:08 -0500 Subject: [PATCH 1/2] fix: update events to array to match specs --- examples/webhook.rs | 6 ++++-- relay_rpc/src/rpc/watch.rs | 2 +- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/examples/webhook.rs b/examples/webhook.rs index 4e5241d..1294d1f 100644 --- a/examples/webhook.rs +++ b/examples/webhook.rs @@ -211,7 +211,8 @@ async fn main() -> anyhow::Result<()> { println!("[subscriber] received message: {}", message.message); let pub_data = server.recv().await; - let decoded = rpc::WatchEventClaims::try_from_str(&pub_data.payload.event_auth).unwrap(); + let decoded = + rpc::WatchEventClaims::try_from_str(pub_data.payload.event_auth.first().unwrap()).unwrap(); let decoded_json = serde_json::to_string_pretty(&decoded).unwrap(); println!( "[webhook] publisher: url={} data={}", @@ -219,7 +220,8 @@ async fn main() -> anyhow::Result<()> { ); let sub_data = server.recv().await; - let decoded = rpc::WatchEventClaims::try_from_str(&sub_data.payload.event_auth).unwrap(); + let decoded = + rpc::WatchEventClaims::try_from_str(sub_data.payload.event_auth.first().unwrap()).unwrap(); let decoded_json = serde_json::to_string_pretty(&decoded).unwrap(); println!( "[webhook] subscriber: url={} data={}", diff --git a/relay_rpc/src/rpc/watch.rs b/relay_rpc/src/rpc/watch.rs index 8cbd3ae..40909dd 100644 --- a/relay_rpc/src/rpc/watch.rs +++ b/relay_rpc/src/rpc/watch.rs @@ -116,7 +116,7 @@ impl VerifyableClaims for WatchEventClaims { #[serde(rename_all = "camelCase")] pub struct WatchWebhookPayload { /// JWT with [`WatchEventClaims`] payload. - pub event_auth: String, + pub event_auth: Vec, } #[cfg(test)] From 36b154bd288bc9efa7f68b73774bc1161a6dc172 Mon Sep 17 00:00:00 2001 From: Chris Smith Date: Thu, 8 Feb 2024 13:55:09 -0500 Subject: [PATCH 2/2] fix: alloy deps optional --- relay_rpc/Cargo.toml | 41 ++++++++++++++++++++++++++++++----------- 1 file changed, 30 insertions(+), 11 deletions(-) diff --git a/relay_rpc/Cargo.toml b/relay_rpc/Cargo.toml index ce393a4..e8c8fc1 100644 --- a/relay_rpc/Cargo.toml +++ b/relay_rpc/Cargo.toml @@ -4,19 +4,38 @@ version = "0.1.0" edition = "2021" [features] -cacao = ["dep:k256", "dep:sha3"] +cacao = [ + "dep:k256", + "dep:sha3", + "dep:alloy-providers", + "dep:alloy-transport", + "dep:alloy-transport-http", + "dep:alloy-rpc-types", + "dep:alloy-json-rpc", + "dep:alloy-json-abi", + "dep:alloy-sol-types", + "dep:alloy-primitives", +] [dependencies] bs58 = "0.4" data-encoding = "2.3" -derive_more = { version = "0.99", default-features = false, features = ["display", "from", "as_ref", "as_mut"] } +derive_more = { version = "0.99", default-features = false, features = [ + "display", + "from", + "as_ref", + "as_mut", +] } serde = { version = "1.0", features = ["derive", "rc"] } serde-aux = { version = "4.1", default-features = false } serde_json = "1.0" thiserror = "1.0" ed25519-dalek = { git = "https://github.com/dalek-cryptography/ed25519-dalek.git", rev = "7529d65" } rand = "0.7" -chrono = { version = "0.4", default-features = false, features = ["std", "clock"] } +chrono = { version = "0.4", default-features = false, features = [ + "std", + "clock", +] } regex = "1.7" once_cell = "1.16" jsonwebtoken = "8.1" @@ -25,14 +44,14 @@ sha3 = { version = "0.10", optional = true } sha2 = { version = "0.10.6" } reqwest = { version = "0.11", features = ["default-tls"] } url = "2" -alloy-providers = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1" } -alloy-transport = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1" } -alloy-transport-http = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1" } -alloy-rpc-types = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1" } -alloy-json-rpc = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1" } -alloy-json-abi = "0.6.2" -alloy-sol-types = "0.6.2" -alloy-primitives = "0.6.2" +alloy-providers = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1", optional = true } +alloy-transport = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1", optional = true } +alloy-transport-http = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1", optional = true } +alloy-rpc-types = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1", optional = true } +alloy-json-rpc = { git = "https://github.com/alloy-rs/alloy.git", rev = "e6f98e1", optional = true } +alloy-json-abi = { version = "0.6.2", optional = true } +alloy-sol-types = { version = "0.6.2", optional = true } +alloy-primitives = { version = "0.6.2", optional = true } [dev-dependencies] tokio = { version = "1.35.1", features = ["test-util", "macros"] }