mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-28 22:37:57 +00:00
ff5d56fb76
* cargo +nightly fmt * add cargo-fmt check to ci * update ci * fmt * fmt * skip macro * ignore bridges
61 lines
2.0 KiB
Rust
61 lines
2.0 KiB
Rust
// Copyright 2021 Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Polkadot is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Authority discovery service interfacing.
|
|
|
|
use std::fmt::Debug;
|
|
|
|
use async_trait::async_trait;
|
|
|
|
use sc_authority_discovery::Service as AuthorityDiscoveryService;
|
|
|
|
use polkadot_primitives::v1::AuthorityDiscoveryId;
|
|
use sc_network::{Multiaddr, PeerId};
|
|
|
|
/// An abstraction over the authority discovery service.
|
|
///
|
|
/// Needed for mocking in tests mostly.
|
|
#[async_trait]
|
|
pub trait AuthorityDiscovery: Send + Debug + 'static {
|
|
/// Get the addresses for the given [`AuthorityId`] from the local address cache.
|
|
async fn get_addresses_by_authority_id(
|
|
&mut self,
|
|
authority: AuthorityDiscoveryId,
|
|
) -> Option<Vec<Multiaddr>>;
|
|
/// Get the [`AuthorityId`] for the given [`PeerId`] from the local address cache.
|
|
async fn get_authority_id_by_peer_id(
|
|
&mut self,
|
|
peer_id: PeerId,
|
|
) -> Option<AuthorityDiscoveryId>;
|
|
}
|
|
|
|
#[async_trait]
|
|
impl AuthorityDiscovery for AuthorityDiscoveryService {
|
|
async fn get_addresses_by_authority_id(
|
|
&mut self,
|
|
authority: AuthorityDiscoveryId,
|
|
) -> Option<Vec<Multiaddr>> {
|
|
AuthorityDiscoveryService::get_addresses_by_authority_id(self, authority).await
|
|
}
|
|
|
|
async fn get_authority_id_by_peer_id(
|
|
&mut self,
|
|
peer_id: PeerId,
|
|
) -> Option<AuthorityDiscoveryId> {
|
|
AuthorityDiscoveryService::get_authority_id_by_peer_id(self, peer_id).await
|
|
}
|
|
}
|