// Copyright 2019-2020 Parity Technologies (UK) Ltd. // This file is part of substrate-subxt. // // subxt 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. // // subxt 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 substrate-subxt. If not, see . //! Implements support for the frame_sudo module. use crate::{ frame::system::{ System, SystemEventsDecoder, }, Encoded, }; use codec::Encode; use core::marker::PhantomData; /// The subset of the `frame_sudo::Trait` that a client must implement. #[module] pub trait Sudo: System {} /// Execute a transaction with sudo permissions. #[derive(Clone, Debug, Eq, PartialEq, Call, Encode)] pub struct SudoCall<'a, T: Sudo> { /// Runtime marker. pub _runtime: PhantomData, /// Encoded transaction. pub call: &'a Encoded, } #[cfg(test)] mod tests { use super::*; use crate::{ error::{ Error, RuntimeError, }, extrinsic::PairSigner, frame::balances::TransferCall, tests::{ test_client, TestRuntime, }, }; use sp_keyring::AccountKeyring; #[async_std::test] async fn test_sudo() { env_logger::try_init().ok(); let alice = PairSigner::::new(AccountKeyring::Alice.pair()); let (client, _) = test_client().await; let call = client .encode(TransferCall { to: &AccountKeyring::Bob.to_account_id(), amount: 10_000, }) .unwrap(); let res = client.sudo_and_watch(&alice, &call).await; assert!( if let Err(Error::Runtime(RuntimeError::BadOrigin)) = res { true } else { false } ); } }