Skip to content

Commit

Permalink
fix: use SafeUrl as &str, jsonrpsee 0.20.0 fixed the issue
Browse files Browse the repository at this point in the history
- the previous issue with jsonrpsee correctly parsing the &str from
  SafeUrl seems to be solved on the latest 0.20.0 release, as per the
  discussion and CHANGELOG: https://github.com/paritytech/jsonrpsee/blob/v0.20.x/CHANGELOG.md#changed-2
  and PR: paritytech/jsonrpsee#1172
  • Loading branch information
oleonardolima committed Oct 25, 2023
1 parent 12fb3db commit bb36ee0
Showing 1 changed file with 2 additions and 22 deletions.
24 changes: 2 additions & 22 deletions fedimint-core/src/api.rs
Original file line number Diff line number Diff line change
Expand Up @@ -712,13 +712,11 @@ impl JsonRpcClient for WsClient {
#[cfg(not(target_family = "wasm"))]
return WsClientBuilder::default()
.use_webpki_rustls()
.build(url_to_string_with_default_port(url)) // Hack for default ports, see fn docs
.build(url.as_str())
.await;

#[cfg(target_family = "wasm")]
WsClientBuilder::default()
.build(url_to_string_with_default_port(url)) // Hack for default ports, see fn docs
.await
WsClientBuilder::default().build(url.as_str()).await
}

fn is_connected(&self) -> bool {
Expand Down Expand Up @@ -847,24 +845,6 @@ impl<C: JsonRpcClient> FederationPeer<C> {
}
}

/// `jsonrpsee` converts the `SafeUrl` to a `&str` internally and then parses it
/// as an `Uri`. Unfortunately the underlying `Url` type swallows ports that it
/// considers default ports (e.g. 80 and 443 for HTTP(S)) which makes the `Uri`
/// parsing fail in these cases. This function works around this limitation in a
/// limited way (not fully standard compliant, but work for our use case).
///
/// See <https://github.com/paritytech/jsonrpsee/issues/554#issue-1048646896>
fn url_to_string_with_default_port(url: &SafeUrl) -> String {
format!(
"{}://{}:{}{}",
url.scheme(),
url.host().expect("Asserted on construction"),
url.port_or_known_default()
.expect("Asserted on construction"),
url.path()
)
}

impl<C: JsonRpcClient> WsFederationApi<C> {}

/// The status of a server, including how it views its peers
Expand Down

0 comments on commit bb36ee0

Please sign in to comment.