Type Alias moonbeam_runtime::BridgeKusamaMessages
source · pub type BridgeKusamaMessages = Pallet<Runtime, Instance1>;
Aliased Type§
struct BridgeKusamaMessages(/* private fields */);
Implementations
§impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
pub fn module_owner() -> Option<<T as Config>::AccountId>
pub fn module_owner() -> Option<<T as Config>::AccountId>
An auto-generated getter for [PalletOwner
].
§impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
pub fn operating_mode() -> MessagesOperatingMode
pub fn operating_mode() -> MessagesOperatingMode
An auto-generated getter for [PalletOperatingMode
].
§impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
pub fn outbound_message_data(
lane: <T as Config<I>>::LaneId,
nonce: u64,
) -> Option<Vec<u8>>
pub fn outbound_message_data( lane: <T as Config<I>>::LaneId, nonce: u64, ) -> Option<Vec<u8>>
Get stored data of the outbound message with given nonce.
pub fn inbound_message_data(
lane: <T as Config<I>>::LaneId,
payload: Vec<u8>,
outbound_details: OutboundMessageDetails,
) -> InboundMessageDetails
pub fn inbound_message_data( lane: <T as Config<I>>::LaneId, payload: Vec<u8>, outbound_details: OutboundMessageDetails, ) -> InboundMessageDetails
Prepare data, related to given inbound message.
pub fn outbound_lane_data(
lane: <T as Config<I>>::LaneId,
) -> Option<OutboundLaneData>
pub fn outbound_lane_data( lane: <T as Config<I>>::LaneId, ) -> Option<OutboundLaneData>
Return outbound lane data.
pub fn inbound_lane_data(
lane: <T as Config<I>>::LaneId,
) -> Option<InboundLaneData<<<T as Config<I>>::BridgedChain as Chain>::AccountId>>
pub fn inbound_lane_data( lane: <T as Config<I>>::LaneId, ) -> Option<InboundLaneData<<<T as Config<I>>::BridgedChain as Chain>::AccountId>>
Return inbound lane data.
§impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Pallet<T, I>where
T: Config<I>,
I: 'static,
pub fn set_owner(
origin: <T as Config>::RuntimeOrigin,
new_owner: Option<<T as Config>::AccountId>,
) -> Result<(), DispatchError>
pub fn set_owner( origin: <T as Config>::RuntimeOrigin, new_owner: Option<<T as Config>::AccountId>, ) -> Result<(), DispatchError>
Change PalletOwner
.
May only be called either by root, or by PalletOwner
.
pub fn set_operating_mode(
origin: <T as Config>::RuntimeOrigin,
operating_mode: MessagesOperatingMode,
) -> Result<(), DispatchError>
pub fn set_operating_mode( origin: <T as Config>::RuntimeOrigin, operating_mode: MessagesOperatingMode, ) -> Result<(), DispatchError>
Halt or resume all/some pallet operations.
May only be called either by root, or by PalletOwner
.
pub fn receive_messages_proof(
origin: <T as Config>::RuntimeOrigin,
relayer_id_at_bridged_chain: <<T as Config<I>>::BridgedChain as Chain>::AccountId,
proof: Box<FromBridgedChainMessagesProof<<<T as Config<I>>::BridgedChain as Chain>::Hash, <T as Config<I>>::LaneId>>,
messages_count: u32,
dispatch_weight: Weight,
) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>
pub fn receive_messages_proof( origin: <T as Config>::RuntimeOrigin, relayer_id_at_bridged_chain: <<T as Config<I>>::BridgedChain as Chain>::AccountId, proof: Box<FromBridgedChainMessagesProof<<<T as Config<I>>::BridgedChain as Chain>::Hash, <T as Config<I>>::LaneId>>, messages_count: u32, dispatch_weight: Weight, ) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>
Receive messages proof from bridged chain.
The weight of the call assumes that the transaction always brings outbound lane state update. Because of that, the submitter (relayer) has no benefit of not including this data in the transaction, so reward confirmations lags should be minimal.
The call fails if:
-
the pallet is halted;
-
the call origin is not
Signed(_)
; -
there are too many messages in the proof;
-
the proof verification procedure returns an error - e.g. because header used to craft proof is not imported by the associated finality pallet;
-
the
dispatch_weight
argument is not sufficient to dispatch all bundled messages.
The call may succeed, but some messages may not be delivered e.g. if they are not fit into the unrewarded relayers vector.
pub fn receive_messages_delivery_proof(
origin: <T as Config>::RuntimeOrigin,
proof: FromBridgedChainMessagesDeliveryProof<<<T as Config<I>>::BridgedChain as Chain>::Hash, <T as Config<I>>::LaneId>,
relayers_state: UnrewardedRelayersState,
) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>
pub fn receive_messages_delivery_proof( origin: <T as Config>::RuntimeOrigin, proof: FromBridgedChainMessagesDeliveryProof<<<T as Config<I>>::BridgedChain as Chain>::Hash, <T as Config<I>>::LaneId>, relayers_state: UnrewardedRelayersState, ) -> Result<PostDispatchInfo, DispatchErrorWithPostInfo<PostDispatchInfo>>
Receive messages delivery proof from bridged chain.
Trait Implementations
§impl<T, I> BeforeAllRuntimeMigrations for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> BeforeAllRuntimeMigrations for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn before_all_runtime_migrations() -> Weight
fn before_all_runtime_migrations() -> Weight
§impl<T, I> BridgeRuntimeFilterCall<<T as Config>::AccountId, <T as Config>::RuntimeCall> for Pallet<T, I>where
T: Config<I>,
I: 'static,
<T as Config>::RuntimeCall: CallSubType<T, I>,
impl<T, I> BridgeRuntimeFilterCall<<T as Config>::AccountId, <T as Config>::RuntimeCall> for Pallet<T, I>where
T: Config<I>,
I: 'static,
<T as Config>::RuntimeCall: CallSubType<T, I>,
§fn validate(
_who: &<T as Config>::AccountId,
call: &<T as Config>::RuntimeCall,
) -> ((), Result<ValidTransaction, TransactionValidityError>)
fn validate( _who: &<T as Config>::AccountId, call: &<T as Config>::RuntimeCall, ) -> ((), Result<ValidTransaction, TransactionValidityError>)
Validate messages in order to avoid “mining” messages delivery and delivery confirmation transactions, that are delivering outdated messages/confirmations. Without this validation, even honest relayers may lose their funds if there are multiple relays running and submitting the same messages/confirmations.
§type ToPostDispatch = ()
type ToPostDispatch = ()
post_dispatch
.§fn post_dispatch(
_who: &AccountId,
_has_failed: bool,
_to_post_dispatch: Self::ToPostDispatch,
)
fn post_dispatch( _who: &AccountId, _has_failed: bool, _to_post_dispatch: Self::ToPostDispatch, )
§impl<T, I> Callable<T> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Callable<T> for Pallet<T, I>where
T: Config<I>,
I: 'static,
type RuntimeCall = Call<T, I>
§impl<T, I> GetStorageVersion for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> GetStorageVersion for Pallet<T, I>where
T: Config<I>,
I: 'static,
§type InCodeStorageVersion = StorageVersion
type InCodeStorageVersion = StorageVersion
§fn in_code_storage_version() -> <Pallet<T, I> as GetStorageVersion>::InCodeStorageVersion
fn in_code_storage_version() -> <Pallet<T, I> as GetStorageVersion>::InCodeStorageVersion
storage_version
attribute, or
[NoStorageVersionSet
] if the attribute is missing.§fn on_chain_storage_version() -> StorageVersion
fn on_chain_storage_version() -> StorageVersion
§fn current_storage_version() -> Self::InCodeStorageVersion
fn current_storage_version() -> Self::InCodeStorageVersion
in_code_storage_version
and will be removed after March 2024.Self::current_storage_version
] instead. Read more§impl<T, I> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn on_initialize(_n: BlockNumber) -> Weight
fn on_initialize(_n: BlockNumber) -> Weight
§fn on_finalize(_n: BlockNumber)
fn on_finalize(_n: BlockNumber)
§fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
Hooks::on_finalize
]). Read more§fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)
fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)
§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Executive
pallet. Read more§fn offchain_worker(_n: BlockNumber)
fn offchain_worker(_n: BlockNumber)
§fn integrity_test()
fn integrity_test()
§impl<T, I> IntegrityTest for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> IntegrityTest for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn integrity_test()
fn integrity_test()
Hooks::integrity_test
].§impl<T, I> MessagesBridge<<T as Config<I>>::OutboundPayload, <T as Config<I>>::LaneId> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> MessagesBridge<<T as Config<I>>::OutboundPayload, <T as Config<I>>::LaneId> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§type SendMessageArgs = SendMessageArgs<T, I>
type SendMessageArgs = SendMessageArgs<T, I>
validate_message()
. Read more§fn validate_message(
lane_id: <T as Config<I>>::LaneId,
message: &<T as Config<I>>::OutboundPayload,
) -> Result<SendMessageArgs<T, I>, <Pallet<T, I> as MessagesBridge<<T as Config<I>>::OutboundPayload, <T as Config<I>>::LaneId>>::Error>
fn validate_message( lane_id: <T as Config<I>>::LaneId, message: &<T as Config<I>>::OutboundPayload, ) -> Result<SendMessageArgs<T, I>, <Pallet<T, I> as MessagesBridge<<T as Config<I>>::OutboundPayload, <T as Config<I>>::LaneId>>::Error>
§fn send_message(args: SendMessageArgs<T, I>) -> SendMessageArtifacts
fn send_message(args: SendMessageArgs<T, I>) -> SendMessageArtifacts
§impl<T, I> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn offchain_worker(
n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number,
)
fn offchain_worker( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, )
§impl<T, I> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn on_finalize(
n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number,
)
fn on_finalize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, )
Hooks::on_finalize
].§impl<T, I> OnGenesis for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnGenesis for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn on_genesis()
fn on_genesis()
§impl<T, I> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§impl<T, I> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn on_initialize(
n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number,
) -> Weight
fn on_initialize( n: <<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, ) -> Weight
Hooks::on_initialize
].§impl<T, I> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§impl<T, I> OnRuntimeUpgrade for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OnRuntimeUpgrade for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Hooks::on_runtime_upgrade
].§impl<T, I> OwnedBridgeModule<T> for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> OwnedBridgeModule<T> for Pallet<T, I>where
T: Config<I>,
I: 'static,
§const LOG_TARGET: &'static str = LOG_TARGET
const LOG_TARGET: &'static str = LOG_TARGET
§type OwnerStorage = StorageValue<_GeneratedPrefixForStoragePalletOwner<T, I>, <T as Config>::AccountId>
type OwnerStorage = StorageValue<_GeneratedPrefixForStoragePalletOwner<T, I>, <T as Config>::AccountId>
Owner
account.§type OperatingMode = MessagesOperatingMode
type OperatingMode = MessagesOperatingMode
§type OperatingModeStorage = StorageValue<_GeneratedPrefixForStoragePalletOperatingMode<T, I>, MessagesOperatingMode, ValueQuery>
type OperatingModeStorage = StorageValue<_GeneratedPrefixForStoragePalletOperatingMode<T, I>, MessagesOperatingMode, ValueQuery>
§fn ensure_owner_or_root(
origin: <T as Config>::RuntimeOrigin,
) -> Result<(), BadOrigin>
fn ensure_owner_or_root( origin: <T as Config>::RuntimeOrigin, ) -> Result<(), BadOrigin>
PalletOwner
.§fn ensure_not_halted() -> Result<(), OwnedBridgeModuleError>
fn ensure_not_halted() -> Result<(), OwnedBridgeModuleError>
§fn set_owner(
origin: <T as Config>::RuntimeOrigin,
maybe_owner: Option<<T as Config>::AccountId>,
) -> Result<(), DispatchError>
fn set_owner( origin: <T as Config>::RuntimeOrigin, maybe_owner: Option<<T as Config>::AccountId>, ) -> Result<(), DispatchError>
§fn set_operating_mode(
origin: <T as Config>::RuntimeOrigin,
operating_mode: Self::OperatingMode,
) -> Result<(), DispatchError>
fn set_operating_mode( origin: <T as Config>::RuntimeOrigin, operating_mode: Self::OperatingMode, ) -> Result<(), DispatchError>
§impl<T, I> PalletInfoAccess for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> PalletInfoAccess for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn module_name() -> &'static str
fn module_name() -> &'static str
§fn crate_version() -> CrateVersion
fn crate_version() -> CrateVersion
§impl<T, I> PalletsInfoAccess for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> PalletsInfoAccess for Pallet<T, I>where
T: Config<I>,
I: 'static,
§impl<T, I> PartialEq for Pallet<T, I>
impl<T, I> PartialEq for Pallet<T, I>
§impl<T, I> StorageInfoTrait for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> StorageInfoTrait for Pallet<T, I>where
T: Config<I>,
I: 'static,
fn storage_info() -> Vec<StorageInfo>
§impl<T, I> WhitelistedStorageKeys for Pallet<T, I>where
T: Config<I>,
I: 'static,
impl<T, I> WhitelistedStorageKeys for Pallet<T, I>where
T: Config<I>,
I: 'static,
§fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
Vec<TrackedStorageKey>
indicating the storage keys that
should be whitelisted during benchmarking. This means that those keys
will be excluded from the benchmarking performance calculation.