Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

[frame/im-online] remove network state from heartbeats #14251

Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
0073c30
[frame/im-online] remove `external_addresses` from heartbeats
melekes May 26, 2023
c8218b9
remove unused import
melekes May 29, 2023
a282042
run benchmark
melekes May 29, 2023
b60c5c4
remove external_addresses from offchain NetworkState
melekes May 29, 2023
5c7956e
add missing fn to TestNetwork
melekes May 29, 2023
97b9fd2
Revert "run benchmark"
melekes May 29, 2023
cd589f6
update weights
melekes May 29, 2023
e88d7e2
address @bkchr comments
melekes May 30, 2023
1eb8086
Merge branch 'master' into anton/7181-remove-external-addresses-from-…
melekes May 30, 2023
41bca16
remove duplicate fn
melekes May 30, 2023
619a28e
cleanup benchmarking.rs
melekes May 30, 2023
aaefc66
fix executor tests
melekes May 30, 2023
57246bf
remove peer_id from hearbeat as well
melekes May 31, 2023
8e4061d
remove MaxPeerDataEncodingSize
melekes May 31, 2023
dcc7b38
change storage value type to `()`
melekes Jun 5, 2023
81d9560
scaffold storage migration
melekes Jun 6, 2023
c822c2d
no need to check the type actually
melekes Jun 6, 2023
ace0f6e
remove unnecessary types from v0 mod
melekes Jun 6, 2023
906fa96
add a test for migration
melekes Jun 6, 2023
4092dfb
expose Config types
melekes Jun 6, 2023
9538acd
fix test
melekes Jun 7, 2023
8818c18
replace dummy type with ConstU32
melekes Jun 7, 2023
eedf528
add some comments to migration test
melekes Jun 7, 2023
11c4fd7
fix comment
melekes Jun 7, 2023
aedfdb9
respond to @bkchr comments
melekes Jun 15, 2023
f8970f6
use BoundedOpaqueNetworkState::default
melekes Jun 15, 2023
fbbbd3f
Merge branch 'master' into anton/7181-remove-external-addresses-from-…
melekes Jun 15, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
address @bkchr comments
  • Loading branch information
melekes committed May 30, 2023
commit e88d7e2bcec4f89299275aa21147451306b3cb78
56 changes: 45 additions & 11 deletions client/offchain/src/api.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,17 +16,17 @@
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.

use std::{collections::HashSet, sync::Arc, thread::sleep};
use std::{collections::HashSet, str::FromStr, sync::Arc, thread::sleep};

use crate::NetworkProvider;
use codec::{Decode, Encode};
use futures::Future;
pub use http::SharedClient;
use libp2p::PeerId;
use libp2p::{Multiaddr, PeerId};
use sp_core::{
offchain::{
self, HttpError, HttpRequestId, HttpRequestStatus, OffchainStorage, OpaqueNetworkState,
StorageKind, Timestamp,
self, HttpError, HttpRequestId, HttpRequestStatus, OffchainStorage, OpaqueMultiaddr,
OpaqueNetworkState, StorageKind, Timestamp,
},
OpaquePeerId,
};
Expand Down Expand Up @@ -159,7 +159,9 @@ impl offchain::Externalities for Api {
}

fn network_state(&self) -> Result<OpaqueNetworkState, ()> {
let state = NetworkState::new(self.network_provider.local_peer_id());
let external_addresses = self.network_provider.external_addresses();

let state = NetworkState::new(self.network_provider.local_peer_id(), external_addresses);
Ok(OpaqueNetworkState::from(state))
}

Expand Down Expand Up @@ -236,11 +238,12 @@ impl offchain::Externalities for Api {
#[derive(Clone, Eq, PartialEq, Debug)]
pub struct NetworkState {
peer_id: PeerId,
external_addresses: Vec<Multiaddr>,
}

impl NetworkState {
fn new(peer_id: PeerId) -> Self {
NetworkState { peer_id }
fn new(peer_id: PeerId, external_addresses: Vec<Multiaddr>) -> Self {
NetworkState { peer_id, external_addresses }
}
}

Expand All @@ -249,7 +252,16 @@ impl From<NetworkState> for OpaqueNetworkState {
let enc = Encode::encode(&state.peer_id.to_bytes());
let peer_id = OpaquePeerId::new(enc);

OpaqueNetworkState { peer_id }
let external_addresses: Vec<OpaqueMultiaddr> = state
.external_addresses
.iter()
.map(|multiaddr| {
let e = Encode::encode(&multiaddr.to_string());
OpaqueMultiaddr::new(e)
})
.collect();

OpaqueNetworkState { peer_id, external_addresses }
}
}

Expand All @@ -262,7 +274,20 @@ impl TryFrom<OpaqueNetworkState> for NetworkState {
let bytes: Vec<u8> = Decode::decode(&mut &inner_vec[..]).map_err(|_| ())?;
let peer_id = PeerId::from_bytes(&bytes).map_err(|_| ())?;

Ok(NetworkState { peer_id })
let external_addresses: Result<Vec<Multiaddr>, Self::Error> = state
.external_addresses
.iter()
.map(|enc_multiaddr| -> Result<Multiaddr, Self::Error> {
let inner_vec = &enc_multiaddr.0;
let bytes = <Vec<u8>>::decode(&mut &inner_vec[..]).map_err(|_| ())?;
let multiaddr_str = String::from_utf8(bytes).map_err(|_| ())?;
let multiaddr = Multiaddr::from_str(&multiaddr_str).map_err(|_| ())?;
Ok(multiaddr)
})
.collect();
let external_addresses = external_addresses?;

Ok(NetworkState { peer_id, external_addresses })
}
}

Expand Down Expand Up @@ -299,7 +324,6 @@ impl AsyncApi {
#[cfg(test)]
mod tests {
use super::*;
use libp2p::{Multiaddr, PeerId};
use sc_client_db::offchain::LocalStorage;
use sc_network::{
config::MultiaddrWithPeerId, types::ProtocolName, NetworkPeers, NetworkStateInfo,
Expand Down Expand Up @@ -385,6 +409,10 @@ mod tests {
}

impl NetworkStateInfo for TestNetwork {
fn external_addresses(&self) -> Vec<Multiaddr> {
Vec::new()
}

fn local_peer_id(&self) -> PeerId {
PeerId::random()
}
Expand Down Expand Up @@ -499,7 +527,13 @@ mod tests {
#[test]
fn should_convert_network_states() {
// given
let state = NetworkState::new(PeerId::random());
let state = NetworkState::new(
PeerId::random(),
vec![
Multiaddr::try_from("/ip4/127.0.0.1/tcp/1234".to_string()).unwrap(),
Multiaddr::try_from("/ip6/2601:9:4f81:9700:803e:ca65:66e8:c21").unwrap(),
],
);

// when
let opaque_state = OpaqueNetworkState::from(state.clone());
Expand Down
45 changes: 19 additions & 26 deletions frame/im-online/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,7 @@
//! in the current era or session.
//!
//! The heartbeat is a signed transaction, which was signed using the session key
//! and includes the recent best block number of the local validators chain as well
//! as the [NetworkState](../../client/offchain/struct.NetworkState.html).
//! and includes the recent best block number of the local validators chain.
//! It is submitted as an Unsigned Transaction via off-chain workers.
//!
//! - [`Config`]
Expand Down Expand Up @@ -94,7 +93,7 @@ use frame_system::offchain::{SendTransactionTypes, SubmitTransaction};
pub use pallet::*;
use scale_info::TypeInfo;
use sp_application_crypto::RuntimeAppPublic;
use sp_core::offchain::OpaqueNetworkState;
use sp_core::OpaquePeerId;
use sp_runtime::{
offchain::storage::{MutateStorageError, StorageRetrievalError, StorageValueRef},
traits::{AtLeast32BitUnsigned, Convert, Saturating, TrailingZeroInput},
Expand Down Expand Up @@ -222,8 +221,8 @@ where
{
/// Block number at the time heartbeat is created..
pub block_number: BlockNumber,
/// A state of local network (peer id and external addresses)
pub network_state: OpaqueNetworkState,
/// Peer ID of the local node
pub peer_id: OpaquePeerId,
melekes marked this conversation as resolved.
Show resolved Hide resolved
/// Index of the current session.
pub session_index: SessionIndex,
/// An index of the authority on the list of validators.
Expand All @@ -232,31 +231,26 @@ where
pub validators_len: u32,
}

/// A type that is the same as [`OpaqueNetworkState`] but with [`Vec`] replaced with
/// A type that is the same as [`OpaquePeerId`] but with [`Vec`] replaced with
/// [`WeakBoundedVec<Limit>`] where Limit is the respective size limit
/// `PeerIdEncodingLimit` represents the size limit of the encoding of `PeerId`
#[derive(Clone, Eq, PartialEq, Encode, Decode, MaxEncodedLen, TypeInfo)]
#[codec(mel_bound())]
#[scale_info(skip_type_params(PeerIdEncodingLimit))]
pub struct BoundedOpaqueNetworkState<PeerIdEncodingLimit>
pub struct BoundedOpaquePeerId<PeerIdEncodingLimit>(WeakBoundedVec<u8, PeerIdEncodingLimit>)
where
PeerIdEncodingLimit: Get<u32>,
{
/// PeerId of the local node in SCALE encoded.
pub peer_id: WeakBoundedVec<u8, PeerIdEncodingLimit>,
}
PeerIdEncodingLimit: Get<u32>;

impl<PeerIdEncodingLimit: Get<u32>> BoundedOpaqueNetworkState<PeerIdEncodingLimit> {
fn force_from(ons: &OpaqueNetworkState) -> Self {
let peer_id = WeakBoundedVec::<_, PeerIdEncodingLimit>::force_from(
ons.peer_id.0.clone(),
impl<PeerIdEncodingLimit: Get<u32>> BoundedOpaquePeerId<PeerIdEncodingLimit> {
fn force_from(opaque_peer_id: &OpaquePeerId) -> Self {
Self(WeakBoundedVec::<_, PeerIdEncodingLimit>::force_from(
opaque_peer_id.0.clone(),
Some(
"Warning: The size of the encoding of PeerId \
is bigger than expected. A runtime configuration \
adjustment may be needed.",
),
);
Self { peer_id }
))
}
}

Expand Down Expand Up @@ -379,7 +373,7 @@ pub mod pallet {
StorageValue<_, WeakBoundedVec<T::AuthorityId, T::MaxKeys>, ValueQuery>;

/// For each session index, we keep a mapping of `SessionIndex` and `AuthIndex` to
/// `WrapperOpaque<BoundedOpaqueNetworkState>`.
/// `WrapperOpaque<BoundedOpaquePeerId>`.
#[pallet::storage]
#[pallet::getter(fn received_heartbeats)]
pub(crate) type ReceivedHeartbeats<T: Config> = StorageDoubleMap<
Expand All @@ -388,7 +382,7 @@ pub mod pallet {
SessionIndex,
Twox64Concat,
AuthIndex,
WrapperOpaque<BoundedOpaqueNetworkState<T::MaxPeerDataEncodingSize>>,
WrapperOpaque<BoundedOpaquePeerId<T::MaxPeerDataEncodingSize>>,
>;

/// For each session index, we keep a mapping of `ValidatorId<T>` to the
Expand Down Expand Up @@ -446,14 +440,13 @@ pub mod pallet {
if let (false, Some(public)) = (exists, public) {
Self::deposit_event(Event::<T>::HeartbeatReceived { authority_id: public.clone() });

let network_state_bounded =
BoundedOpaqueNetworkState::<T::MaxPeerDataEncodingSize>::force_from(
&heartbeat.network_state,
);
let peer_id = BoundedOpaquePeerId::<T::MaxPeerDataEncodingSize>::force_from(
&heartbeat.peer_id,
);
ReceivedHeartbeats::<T>::insert(
&current_session,
&heartbeat.authority_index,
WrapperOpaque::from(network_state_bounded),
WrapperOpaque::from(peer_id),
);

Ok(())
Expand Down Expand Up @@ -669,7 +662,7 @@ impl<T: Config> Pallet<T> {
sp_io::offchain::network_state().map_err(|_| OffchainErr::NetworkState)?;
let heartbeat = Heartbeat {
block_number,
network_state,
peer_id: network_state.peer_id,
session_index,
authority_index,
validators_len,
Expand Down
6 changes: 3 additions & 3 deletions frame/im-online/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,7 @@ fn heartbeat(

let heartbeat = Heartbeat {
block_number,
network_state: OpaqueNetworkState { peer_id: OpaquePeerId(vec![1]) },
peer_id: OpaquePeerId(vec![1]),
session_index,
authority_index,
validators_len: validators.len() as u32,
Expand Down Expand Up @@ -249,7 +249,7 @@ fn should_generate_heartbeats() {
heartbeat,
Heartbeat {
block_number: block,
network_state: sp_io::offchain::network_state().unwrap(),
peer_id: sp_io::offchain::network_state().unwrap().peer_id,
session_index: 2,
authority_index: 2,
validators_len: 3,
Expand Down Expand Up @@ -364,7 +364,7 @@ fn should_not_send_a_report_if_already_online() {
heartbeat,
Heartbeat {
block_number: 4,
network_state: sp_io::offchain::network_state().unwrap(),
peer_id: sp_io::offchain::network_state().unwrap().peer_id,
session_index: 2,
authority_index: 0,
validators_len: 3,
Expand Down
2 changes: 2 additions & 0 deletions primitives/core/src/offchain/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -189,6 +189,8 @@ impl TryFrom<u32> for HttpRequestStatus {
pub struct OpaqueNetworkState {
/// PeerId of the local node in SCALE encoded.
pub peer_id: OpaquePeerId,
/// List of addresses the node knows it can be reached as.
pub external_addresses: Vec<OpaqueMultiaddr>,
}

/// Simple blob to hold a `Multiaddr` without committing to its format.
Expand Down
2 changes: 1 addition & 1 deletion primitives/core/src/offchain/testing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -217,7 +217,7 @@ impl offchain::Externalities for TestOffchainExt {
}

fn network_state(&self) -> Result<OpaqueNetworkState, ()> {
Ok(OpaqueNetworkState { peer_id: Default::default() })
Ok(OpaqueNetworkState { peer_id: Default::default(), external_addresses: vec![] })
}

fn timestamp(&mut self) -> Timestamp {
Expand Down