IrohBackend

Struct IrohBackend 

Source
pub struct IrohBackend { /* private fields */ }
Expand description

Backend Iroh Otimizado

Backend IPFS de alta performance com otimizações nativas:

  • Cache multinível com compressão inteligente
  • Pool de conexões com circuit breaking
  • Processamento em batch para máximo throughput
  • Monitoramento contínuo de performance

Implementations§

Source§

impl IrohBackend

Source

pub async fn new(config: &ClientConfig) -> Result<Self>

Cria uma nova instância do backend Iroh

§Argumentos
  • config - Configuração do cliente contendo path de dados
§Retorna

Nova instância configurada do backend Iroh

§Erros

Retorna erro se não conseguir inicializar o nó Iroh

Source

pub async fn get_swarm_manager( &self, ) -> Result<Arc<RwLock<Option<SwarmManager>>>>

Obtém referência para o SwarmManager se disponível

Source

pub async fn get_topic_mesh_peers(&self, topic: &str) -> Result<Vec<PeerId>>

Obtém peers do mesh do Gossipsub para um tópico específico

Source

pub async fn publish_gossip(&self, topic: &str, data: &[u8]) -> Result<()>

Publica mensagem em tópico Gossipsub

Source

pub async fn subscribe_gossip(&self, topic: &str) -> Result<()>

Subscreve a um tópico Gossipsub

Source

pub async fn discover_peer_integrated( &self, node_id: NodeId, ) -> Result<Vec<NodeAddr>>

Descobre peers usando sistema integrado DHT + Discovery

Source

pub async fn publish_node_integrated(&self, node_data: &NodeData) -> Result<u32>

Publica informações do nó no sistema integrado

Source

pub async fn get_active_discoveries_status( &self, ) -> Result<HashMap<NodeId, DiscoveryStatus>>

Obtém status das descobertas ativas

Source

pub async fn force_dht_sync(&self) -> Result<()>

Força sincronização DHT com todas as sessões ativas

Source§

impl IrohBackend

Source

pub async fn discover_peer_with_concrete_endpoint( &mut self, node_id: NodeId, ) -> Result<Vec<NodeAddr>>

Descobre um peer específico

Source

pub async fn get_discovery_cache_statistics( &self, ) -> Result<DiscoveryCacheStats>

Obtém estatísticas do cache LRU de discovery

Source

pub async fn get_cache_statistics(&self) -> Result<SimpleCacheStats>

Obtém estatísticas do cache otimizado

Source

pub async fn optimize_performance(&self) -> Result<()>

Executa otimização automática de performance

Source

pub async fn get_config_info(&self) -> String

Utiliza configuração para ajustes dinâmicos

Source

pub async fn get_connection_pool_status(&self) -> String

Obtém informações do pool de conexões

Source

pub async fn discovery_by_method( &self, node_id: NodeId, method: DiscoveryMethod, ) -> Result<Vec<String>>

Executa discovery específico por método

Source

pub async fn get_discovery_stats(&self) -> String

Obtém estatísticas do sistema de discovery como String formatada

Source

pub async fn get_performance_monitor_status(&self) -> String

Obtém status do monitor de performance

Source

pub async fn generate_performance_report(&self) -> String

Gera relatório detalhado de performance

Source§

impl IrohBackend

Source

pub fn create_pubsub_interface(self: Arc<Self>) -> IrohPubSub

Cria uma interface PubSub para este backend

Trait Implementations§

Source§

impl IpfsBackend for IrohBackend

Source§

fn add<'life0, 'async_trait>( &'life0 self, data: Pin<Box<dyn AsyncRead + Send>>, ) -> Pin<Box<dyn Future<Output = Result<AddResponse>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Adiciona dados ao IPFS e retorna o CID resultante Read more
Source§

fn cat<'life0, 'life1, 'async_trait>( &'life0 self, cid: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<Pin<Box<dyn AsyncRead + Send>>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Recupera dados do IPFS pelo CID Read more
Source§

fn pin_add<'life0, 'life1, 'async_trait>( &'life0 self, cid: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Fixa um objeto no storage local (evita garbage collection) Read more
Source§

fn pin_rm<'life0, 'life1, 'async_trait>( &'life0 self, cid: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Remove fixação de um objeto (permite garbage collection) Read more
Source§

fn pin_ls<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<Vec<PinInfo>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Lista objetos fixados Read more
Source§

fn connect<'life0, 'life1, 'async_trait>( &'life0 self, peer: &'life1 PeerId, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Conecta explicitamente a um peer Read more
Source§

fn peers<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<Vec<PeerInfo>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Lista peers atualmente conectados Read more
Source§

fn id<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<NodeInfo>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Obtém informações do nó local Read more
Source§

fn dht_find_peer<'life0, 'life1, 'async_trait>( &'life0 self, peer: &'life1 PeerId, ) -> Pin<Box<dyn Future<Output = Result<Vec<String>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Resolve um peer ID para seus endereços conhecidos Read more
Source§

fn repo_stat<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<RepoStats>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Obtém estatísticas do repositório local Read more
Source§

fn version<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<VersionInfo>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Obtém versão e informações do nó IPFS Read more
Source§

fn block_get<'life0, 'life1, 'async_trait>( &'life0 self, cid: &'life1 Cid, ) -> Pin<Box<dyn Future<Output = Result<Vec<u8>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Obtém um bloco raw pelo seu CID Read more
Source§

fn block_put<'life0, 'async_trait>( &'life0 self, data: Vec<u8>, ) -> Pin<Box<dyn Future<Output = Result<Cid>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Armazena dados raw como bloco Read more
Source§

fn block_stat<'life0, 'life1, 'async_trait>( &'life0 self, cid: &'life1 Cid, ) -> Pin<Box<dyn Future<Output = Result<BlockStats>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Verifica se um bloco existe localmente Read more
Source§

fn backend_type(&self) -> BackendType

Retorna o tipo/nome do backend
Source§

fn is_online<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = bool> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Verifica se o backend está online e operacional
Source§

fn metrics<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<BackendMetrics>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Obtém métricas de performance do backend
Source§

fn health_check<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<HealthStatus>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Executa health check completo do backend

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CompatExt for T

Source§

fn compat(self) -> Compat<T>

Applies the Compat adapter by value. Read more
Source§

fn compat_ref(&self) -> Compat<&T>

Applies the Compat adapter by shared reference. Read more
Source§

fn compat_mut(&mut self) -> Compat<&mut T>

Applies the Compat adapter by mutable reference. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FutureExt for T

Source§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
Source§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> References<RawCodec> for T

Source§

fn references<R, E>(_c: RawCodec, _r: &mut R, _set: &mut E) -> Result<(), Error>
where R: Read, E: Extend<Cid<64>>,

Scrape the references from an impl Read. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more