diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 0022321c76..2a207c1b0a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ env: RUST_BACKTRACE: 1 RUSTFLAGS: -Dwarnings RUSTDOCFLAGS: -Dwarnings - MSRV: "1.75" + MSRV: "1.76" SCCACHE_CACHE_SIZE: "50G" jobs: diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 9df233e2a0..fed6d4c250 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -27,7 +27,7 @@ env: RUST_BACKTRACE: 1 RUSTFLAGS: -Dwarnings RUSTDOCFLAGS: -Dwarnings - MSRV: "1.75" + MSRV: "1.76" SCCACHE_CACHE_SIZE: "50G" BIN_NAMES: "iroh,iroh-relay,iroh-dns-server" RELEASE_VERSION: ${{ github.event.inputs.release_version }} diff --git a/.github/workflows/test_relay_server.yml b/.github/workflows/test_relay_server.yml index ffe19901de..be81dbad97 100644 --- a/.github/workflows/test_relay_server.yml +++ b/.github/workflows/test_relay_server.yml @@ -13,7 +13,7 @@ env: RUST_BACKTRACE: 1 RUSTFLAGS: -Dwarnings RUSTDOCFLAGS: -Dwarnings - MSRV: "1.75" + MSRV: "1.76" SCCACHE_CACHE_SIZE: "50G" jobs: diff --git a/Cargo.lock b/Cargo.lock index 31aac2e02a..2e7c2c17b7 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -201,7 +201,7 @@ checksum = "7378575ff571966e99a744addeff0bff98b8ada0dedf1956d59e634db95eaac1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", "synstructure 0.13.1", ] @@ -224,7 +224,7 @@ checksum = "7b18050c2cd6fe86c3a76584ef5e0baf286d038cda203eb6223df2cc413565f7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -235,7 +235,7 @@ checksum = "c6fa2087f2753a7da8cc1c0dbfcf89579dd57458e36769de5ac750b4671737ca" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -335,7 +335,7 @@ dependencies = [ "heck 0.4.1", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -686,7 +686,7 @@ dependencies = [ "heck 0.5.0", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1034,7 +1034,7 @@ checksum = "f46882e17999c6cc590af592290432be3bce0428cb0d5f8b6715e4dc7b383eb3" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1058,7 +1058,7 @@ dependencies = [ "proc-macro2", "quote", "strsim", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1069,7 +1069,7 @@ checksum = "733cabb43482b1a1b53eee8583c2b9e8684d592215ea83efd305dd31bc2f0178" dependencies = [ "darling_core", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1138,7 +1138,7 @@ checksum = "5fe87ce4529967e0ba1dcf8450bab64d97dfd5010a6256187ffe2e43e6f0e049" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1168,7 +1168,7 @@ checksum = "2bba3e9872d7c58ce7ef0fcf1844fcc3e23ef2a58377b50df35dd98e42a5726e" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", "unicode-xid", ] @@ -1251,7 +1251,7 @@ checksum = "487585f4d0c6655fe74905e2504d8ad6908e4db67f744eb140876906c2f3175d" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1396,7 +1396,7 @@ dependencies = [ "heck 0.4.1", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1409,7 +1409,7 @@ dependencies = [ "num-traits", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1429,7 +1429,7 @@ checksum = "5c785274071b1b420972453b306eeca06acf4633829db4223b58a2a8c5953bc4" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -1684,7 +1684,7 @@ checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -2861,9 +2861,9 @@ dependencies = [ [[package]] name = "iroh-quinn" -version = "0.10.4" +version = "0.10.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b934380145fd5d53a583d01ae9500f4807efe6b0f0fe115c7be4afa2b35db99f" +checksum = "906875956feb75d3d41d708ddaffeb11fdb10cd05f23efbcb17600037e411779" dependencies = [ "bytes", "iroh-quinn-proto", @@ -2878,13 +2878,13 @@ dependencies = [ [[package]] name = "iroh-quinn-proto" -version = "0.10.7" +version = "0.10.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "16f2656b322c7f6cf3eb95e632d1c0f2fa546841915b0270da581f918c70c4be" +checksum = "c6bf92478805e67f2320459285496e1137edf5171411001a0d4d85f9bbafb792" dependencies = [ "bytes", "rand", - "ring 0.16.20", + "ring 0.17.8", "rustc-hash", "rustls 0.21.12", "rustls-native-certs", @@ -2896,9 +2896,9 @@ dependencies = [ [[package]] name = "iroh-quinn-udp" -version = "0.4.1" +version = "0.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6679979a7271c24f9dae9622c0b4a543881508aa3a7396f55dfbaaa56f01c063" +checksum = "edc7915b3a31f08ee0bc02f73f4d61a5d5be146a1081ef7f70622a11627fd314" dependencies = [ "bytes", "libc", @@ -3435,7 +3435,7 @@ dependencies = [ "proc-macro-crate", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -3655,7 +3655,7 @@ dependencies = [ "pest_meta", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -3686,7 +3686,7 @@ checksum = "2f38a4412a78282e09a2cf38d195ea5420d15ba0602cb375210efbc877243965" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -3792,7 +3792,7 @@ dependencies = [ "proc-macro2", "quote", "regex", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -4003,7 +4003,7 @@ checksum = "440f724eba9f6996b75d63681b0a92b06947f1457076d503a4d2e2c8f56442b8" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -4043,16 +4043,18 @@ dependencies = [ [[package]] name = "quic-rpc" -version = "0.9.0" +version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d6f365b77f07281f6dfc300eb5a9913185fa686e9119c787200ace337a53bdbf" +checksum = "f0d69b05325e19956f123fce85ebc4d99226552a0bb24bba4c886106297e708b" dependencies = [ "bincode", + "derive_more", "educe", "flume", "futures-lite 2.3.0", "futures-sink", "futures-util", + "hex", "iroh-quinn", "pin-project", "serde", @@ -4339,7 +4341,7 @@ checksum = "bcc303e793d3734489387d205e9b186fac9c6cfacedd98cbb2e8a5943595f3e6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -4888,7 +4890,7 @@ checksum = "6048858004bcff69094cd972ed40a32500f153bd3be9f716b2eed2e8217c4838" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -4969,7 +4971,7 @@ dependencies = [ "darling", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5204,7 +5206,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2ff9eaf853dec4c8802325d8b6d3dffa86cc707fd7a1a4cdbf416e13b061787a" dependencies = [ "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5251,7 +5253,7 @@ dependencies = [ "proc-macro2", "quote", "struct_iterable_internal", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5269,7 +5271,7 @@ dependencies = [ "proc-macro2", "quote", "structmeta-derive", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5280,7 +5282,7 @@ checksum = "a60bcaff7397072dca0017d1db428e30d5002e00b6847703e2e42005c95fbe00" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5311,7 +5313,7 @@ dependencies = [ "proc-macro2", "quote", "rustversion", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5324,7 +5326,7 @@ dependencies = [ "proc-macro2", "quote", "rustversion", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5386,9 +5388,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.65" +version = "2.0.66" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d2863d96a84c6439701d7a38f9de935ec562c8832cc55d1dde0f513b52fad106" +checksum = "c42f3f41a2de00b01c0aaad383c5a45241efc8b2d1eda5661812fda5f3cdcff5" dependencies = [ "proc-macro2", "quote", @@ -5438,7 +5440,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5524,7 +5526,7 @@ dependencies = [ "proc-macro2", "quote", "structmeta", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5558,7 +5560,7 @@ checksum = "46c3384250002a6d5af4d114f2845d37b57521033f30d5c3f46c4d70e1197533" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5656,7 +5658,7 @@ checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -5891,7 +5893,7 @@ checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -6154,7 +6156,7 @@ dependencies = [ "once_cell", "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", "wasm-bindgen-shared", ] @@ -6188,7 +6190,7 @@ checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", "wasm-bindgen-backend", "wasm-bindgen-shared", ] @@ -6374,7 +6376,7 @@ checksum = "12168c33176773b86799be25e2a2ba07c7aab9968b37541f1094dbd7a60c8946" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -6385,7 +6387,7 @@ checksum = "f6fc35f58ecd95a9b71c4f2329b911016e6bec66b3f2e6a4aad86bd2e99e2f9b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -6396,7 +6398,7 @@ checksum = "9d8dc32e0095a7eeccebd0e3f09e9509365ecb3fc6ac4d6f5f14a3f6392942d1" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -6407,7 +6409,7 @@ checksum = "08990546bf4edef8f431fa6326e032865f27138718c587dc21bc0265bbcb57cc" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] @@ -6706,7 +6708,7 @@ checksum = "15e934569e47891f7d9411f1a451d947a60e000ab3bd24fbb970f000387d1b3b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.65", + "syn 2.0.66", ] [[package]] diff --git a/iroh-base/Cargo.toml b/iroh-base/Cargo.toml index f21488401c..e004f7f3da 100644 --- a/iroh-base/Cargo.toml +++ b/iroh-base/Cargo.toml @@ -9,7 +9,7 @@ authors = ["n0 team"] repository = "https://github.com/n0-computer/iroh" # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-blobs/Cargo.toml b/iroh-blobs/Cargo.toml index 95cca51f58..15a026523e 100644 --- a/iroh-blobs/Cargo.toml +++ b/iroh-blobs/Cargo.toml @@ -10,7 +10,7 @@ repository = "https://github.com/n0-computer/iroh" keywords = ["hashing", "quic", "blake3"] # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-cli/Cargo.toml b/iroh-cli/Cargo.toml index 91ab81394e..edc784511a 100644 --- a/iroh-cli/Cargo.toml +++ b/iroh-cli/Cargo.toml @@ -45,7 +45,7 @@ parking_lot = "0.12.1" pkarr = { version = "1.1.5", default-features = false } portable-atomic = "1" postcard = "1.0.8" -quic-rpc = { version = "0.9.0", features = ["flume-transport", "quinn-transport"] } +quic-rpc = { version = "0.10.0", features = ["flume-transport", "quinn-transport"] } rand = "0.8.5" ratatui = "0.26.2" reqwest = { version = "0.12.4", default-features = false, features = ["json", "rustls-tls"] } diff --git a/iroh-docs/Cargo.toml b/iroh-docs/Cargo.toml index bc03e3ac6f..34231cd133 100644 --- a/iroh-docs/Cargo.toml +++ b/iroh-docs/Cargo.toml @@ -9,7 +9,7 @@ authors = ["n0 team"] repository = "https://github.com/n0-computer/iroh" # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-gossip/Cargo.toml b/iroh-gossip/Cargo.toml index de0c0d2b5b..fb36e76371 100644 --- a/iroh-gossip/Cargo.toml +++ b/iroh-gossip/Cargo.toml @@ -9,7 +9,7 @@ authors = ["n0 team"] repository = "https://github.com/n0-computer/iroh" # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-metrics/Cargo.toml b/iroh-metrics/Cargo.toml index 6789a13d7d..39961db6c7 100644 --- a/iroh-metrics/Cargo.toml +++ b/iroh-metrics/Cargo.toml @@ -9,7 +9,7 @@ authors = ["arqu ", "n0 team"] repository = "https://github.com/n0-computer/iroh" # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-net/Cargo.toml b/iroh-net/Cargo.toml index 9d0f7cdc36..f73a8f1ab0 100644 --- a/iroh-net/Cargo.toml +++ b/iroh-net/Cargo.toml @@ -10,7 +10,7 @@ repository = "https://github.com/n0-computer/iroh" keywords = ["quic", "networking", "holepunching", "p2p"] # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh-test/Cargo.toml b/iroh-test/Cargo.toml index 533a53ae94..54367c2cc1 100644 --- a/iroh-test/Cargo.toml +++ b/iroh-test/Cargo.toml @@ -10,7 +10,7 @@ repository = "https://github.com/n0-computer/iroh" publish = true # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true diff --git a/iroh/Cargo.toml b/iroh/Cargo.toml index 2474368cf6..f846e10dad 100644 --- a/iroh/Cargo.toml +++ b/iroh/Cargo.toml @@ -10,7 +10,7 @@ repository = "https://github.com/n0-computer/iroh" keywords = ["networking", "p2p", "holepunching", "ipfs"] # Sadly this also needs to be updated in .github/workflows/ci.yml -rust-version = "1.75" +rust-version = "1.76" [lints] workspace = true @@ -37,7 +37,7 @@ iroh-docs = { version = "0.16.0", path = "../iroh-docs" } iroh-gossip = { version = "0.16.0", path = "../iroh-gossip" } parking_lot = "0.12.1" postcard = { version = "1", default-features = false, features = ["alloc", "use-std", "experimental-derive"] } -quic-rpc = { version = "0.9.0", default-features = false, features = ["flume-transport", "quinn-transport"] } +quic-rpc = { version = "0.10.0", default-features = false, features = ["flume-transport", "quinn-transport"] } quinn = { package = "iroh-quinn", version = "0.10" } rand = "0.8" serde = { version = "1", features = ["derive"] } diff --git a/iroh/src/client/mem.rs b/iroh/src/client/mem.rs index d34cdca5ea..85f65a5d93 100644 --- a/iroh/src/client/mem.rs +++ b/iroh/src/client/mem.rs @@ -5,15 +5,15 @@ use quic_rpc::transport::flume::FlumeConnection; -use crate::rpc_protocol::{Request, Response, RpcService}; +use crate::rpc_protocol::RpcService; /// RPC client to an iroh node running in the same process. -pub type RpcClient = quic_rpc::RpcClient>; +pub type RpcClient = quic_rpc::RpcClient>; /// In-memory client to an iroh node running in the same process. /// /// This is obtained from [`crate::node::Node::client`]. -pub type Iroh = super::Iroh>; +pub type Iroh = super::Iroh>; /// In-memory document client to an iroh node running in the same process. -pub type Doc = super::docs::Doc>; +pub type Doc = super::docs::Doc>; diff --git a/iroh/src/client/quic.rs b/iroh/src/client/quic.rs index e403e4ee0b..7f7333810f 100644 --- a/iroh/src/client/quic.rs +++ b/iroh/src/client/quic.rs @@ -12,7 +12,7 @@ use quic_rpc::transport::quinn::QuinnConnection; use crate::{ node::RpcStatus, - rpc_protocol::{NodeStatusRequest, Request, Response, RpcService}, + rpc_protocol::{NodeStatusRequest, RpcService}, }; /// ALPN used by irohs RPC mechanism. @@ -20,15 +20,15 @@ use crate::{ pub(crate) const RPC_ALPN: [u8; 17] = *b"n0/provider-rpc/1"; /// RPC client to an iroh node running in a separate process. -pub type RpcClient = quic_rpc::RpcClient>; +pub type RpcClient = quic_rpc::RpcClient>; /// Client to an iroh node running in a separate process. /// /// This is obtained from [`Iroh::connect`]. -pub type Iroh = super::Iroh>; +pub type Iroh = super::Iroh>; /// RPC document client to an iroh node running in a separate process. -pub type Doc = super::docs::Doc>; +pub type Doc = super::docs::Doc>; impl Iroh { /// Connect to an iroh node running on the same computer, but in a different process. @@ -50,7 +50,7 @@ pub(crate) async fn connect_raw(rpc_port: u16) -> anyhow::Result { let endpoint = create_quinn_client(bind_addr, vec![RPC_ALPN.to_vec()], false)?; let addr = SocketAddr::new(Ipv4Addr::LOCALHOST.into(), rpc_port); let server_name = "localhost".to_string(); - let connection = QuinnConnection::new(endpoint, addr, server_name); + let connection = QuinnConnection::::new(endpoint, addr, server_name); let client = RpcClient::new(connection); // Do a status request to check if the server is running. let _version = tokio::time::timeout(Duration::from_secs(1), client.rpc(NodeStatusRequest)) diff --git a/iroh/src/node.rs b/iroh/src/node.rs index d202c2753f..aa0314d108 100644 --- a/iroh/src/node.rs +++ b/iroh/src/node.rs @@ -22,8 +22,8 @@ use tokio_util::sync::CancellationToken; use tokio_util::task::LocalPoolHandle; use tracing::debug; +use crate::client::RpcService; use crate::docs_engine::Engine; -use crate::rpc_protocol::{Request, Response}; mod builder; mod rpc; @@ -55,7 +55,7 @@ struct NodeInner { endpoint: Endpoint, secret_key: SecretKey, cancel_token: CancellationToken, - controller: FlumeConnection, + controller: FlumeConnection, #[allow(dead_code)] gc_task: Option>, #[debug("rt")] diff --git a/iroh/src/node/builder.rs b/iroh/src/node/builder.rs index 60e59d868e..7c9875f3c1 100644 --- a/iroh/src/node/builder.rs +++ b/iroh/src/node/builder.rs @@ -34,7 +34,7 @@ use crate::{ client::RPC_ALPN, docs_engine::{DefaultAuthorStorage, Engine}, node::NodeInner, - rpc_protocol::{Request, Response, RpcService}, + rpc_protocol::RpcService, util::{fs::load_secret_key, path::IrohPaths}, }; @@ -252,7 +252,7 @@ where } /// Configure the default iroh rpc endpoint. - pub async fn enable_rpc(self) -> Result>> { + pub async fn enable_rpc(self) -> Result>> { let (ep, actual_rpc_port) = make_rpc_endpoint(&self.secret_key, DEFAULT_RPC_PORT)?; if let StorageConfig::Persistent(ref root) = self.storage { // store rpc endpoint @@ -765,7 +765,7 @@ const MAX_RPC_STREAMS: u32 = 1024; fn make_rpc_endpoint( secret_key: &SecretKey, rpc_port: u16, -) -> Result<(QuinnServerEndpoint, u16)> { +) -> Result<(QuinnServerEndpoint, u16)> { let rpc_addr = SocketAddrV4::new(Ipv4Addr::LOCALHOST, rpc_port); let mut transport_config = quinn::TransportConfig::default(); transport_config @@ -800,7 +800,7 @@ fn make_rpc_endpoint( }; let actual_rpc_port = rpc_quinn_endpoint.local_addr()?.port(); - let rpc_endpoint = QuinnServerEndpoint::::new(rpc_quinn_endpoint)?; + let rpc_endpoint = QuinnServerEndpoint::::new(rpc_quinn_endpoint)?; Ok((rpc_endpoint, actual_rpc_port)) }