diff --git a/crates/nostr-sdk/src/relay/mod.rs b/crates/nostr-sdk/src/relay/mod.rs index b8a35e252..3b4e8b6f5 100644 --- a/crates/nostr-sdk/src/relay/mod.rs +++ b/crates/nostr-sdk/src/relay/mod.rs @@ -140,6 +140,15 @@ impl fmt::Display for RelayStatus { } } +/// Relay Connection Type +#[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] +pub enum RelayConnectionType { + /// Manual: realy added manually + Manual, + /// Gossip: relay added by gossip + Gossip, +} + /// Relay event #[derive(Debug)] pub enum RelayEvent { @@ -246,6 +255,7 @@ pub struct Relay { #[cfg(not(target_arch = "wasm32"))] proxy: Option, status: Arc>, + connection_type: RelayConnectionType, #[cfg(feature = "nip11")] document: Arc>, opts: RelayOptions, @@ -271,6 +281,7 @@ impl Relay { #[cfg(not(target_arch = "wasm32"))] pub fn new( url: Url, + connection_type: RelayConnectionType, pool_sender: Sender, notification_sender: broadcast::Sender, proxy: Option, @@ -282,6 +293,7 @@ impl Relay { url, proxy, status: Arc::new(RwLock::new(RelayStatus::Initialized)), + connection_type, #[cfg(feature = "nip11")] document: Arc::new(RwLock::new(RelayInformationDocument::new())), opts, @@ -301,6 +313,7 @@ impl Relay { #[cfg(target_arch = "wasm32")] pub fn new( url: Url, + connection_type: RelayConnectionType, pool_sender: Sender, notification_sender: broadcast::Sender, opts: RelayOptions, @@ -310,6 +323,7 @@ impl Relay { Self { url, status: Arc::new(RwLock::new(RelayStatus::Initialized)), + connection_type, #[cfg(feature = "nip11")] document: Arc::new(RwLock::new(RelayInformationDocument::new())), opts, @@ -342,6 +356,11 @@ impl Relay { *status } + /// Relay Connection Type + pub fn connection_type(&self) -> RelayConnectionType { + self.connection_type + } + /// Get [`RelayStatus`] #[cfg(feature = "blocking")] pub fn status_blocking(&self) -> RelayStatus { diff --git a/crates/nostr-sdk/src/relay/pool.rs b/crates/nostr-sdk/src/relay/pool.rs index 26cbe011e..7b3fd81bf 100644 --- a/crates/nostr-sdk/src/relay/pool.rs +++ b/crates/nostr-sdk/src/relay/pool.rs @@ -19,8 +19,8 @@ use tokio::sync::{broadcast, Mutex, RwLock}; use super::options::RelayPoolOptions; use super::{ - Error as RelayError, FilterOptions, InternalSubscriptionId, Relay, RelayOptions, - RelaySendOptions, RelayStatus, + Error as RelayError, FilterOptions, InternalSubscriptionId, Relay, RelayConnectionType, + RelayOptions, RelaySendOptions, RelayStatus, }; use crate::util::TryIntoUrl; @@ -392,6 +392,7 @@ impl RelayPool { if !relays.contains_key(&url) { let relay = Relay::new( url, + RelayConnectionType::Manual, self.pool_task_sender.clone(), self.notification_sender.clone(), proxy, @@ -414,6 +415,7 @@ impl RelayPool { if !relays.contains_key(&url) { let relay = Relay::new( url, + RelayConnectionType::Manual, self.pool_task_sender.clone(), self.notification_sender.clone(), opts,