Skip to content

Commit

Permalink
pallet-utility: Disallow none origin
Browse files Browse the repository at this point in the history
  • Loading branch information
bkchr authored and andresilva committed Sep 21, 2022
1 parent 3f70bce commit 7c4ac35
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 5 deletions.
6 changes: 3 additions & 3 deletions frame/utility/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,7 @@ pub mod pallet {
origin: OriginFor<T>,
calls: Vec<<T as Config>::Call>,
) -> DispatchResultWithPostInfo {
let is_root = ensure_root(origin.clone()).is_ok();
let is_root = ensure_signed_or_root(origin.clone())?.is_none();
let calls_len = calls.len();
ensure!(calls_len <= Self::batched_calls_limit() as usize, Error::<T>::TooManyCalls);

Expand Down Expand Up @@ -319,7 +319,7 @@ pub mod pallet {
origin: OriginFor<T>,
calls: Vec<<T as Config>::Call>,
) -> DispatchResultWithPostInfo {
let is_root = ensure_root(origin.clone()).is_ok();
let is_root = ensure_signed_or_root(origin.clone())?.is_none();
let calls_len = calls.len();
ensure!(calls_len <= Self::batched_calls_limit() as usize, Error::<T>::TooManyCalls);

Expand Down Expand Up @@ -424,7 +424,7 @@ pub mod pallet {
origin: OriginFor<T>,
calls: Vec<<T as Config>::Call>,
) -> DispatchResultWithPostInfo {
let is_root = ensure_root(origin.clone()).is_ok();
let is_root = ensure_signed_or_root(origin.clone())?.is_none();
let calls_len = calls.len();
ensure!(calls_len <= Self::batched_calls_limit() as usize, Error::<T>::TooManyCalls);

Expand Down
14 changes: 12 additions & 2 deletions frame/utility/src/tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ use crate as utility;
use frame_support::{
assert_err_ignore_postinfo, assert_noop, assert_ok,
dispatch::{DispatchError, DispatchErrorWithPostInfo, Dispatchable},
error::BadOrigin,
parameter_types, storage,
traits::{ConstU32, ConstU64, Contains},
weights::{Pays, Weight},
Expand Down Expand Up @@ -620,7 +621,7 @@ fn force_batch_works() {
call_transfer(2, 10),
call_transfer(2, 5),
]
),);
));
System::assert_last_event(utility::Event::BatchCompletedWithErrors.into());
System::assert_has_event(
utility::Event::ItemFailed { error: DispatchError::Other("") }.into(),
Expand All @@ -631,10 +632,19 @@ fn force_batch_works() {
assert_ok!(Utility::force_batch(
Origin::signed(2),
vec![call_transfer(1, 5), call_transfer(1, 5),]
),);
));
System::assert_last_event(utility::Event::BatchCompleted.into());

assert_ok!(Utility::force_batch(Origin::signed(1), vec![call_transfer(2, 50),]),);
System::assert_last_event(utility::Event::BatchCompletedWithErrors.into());
});
}

#[test]
fn none_origin_does_not_work() {
new_test_ext().execute_with(|| {
assert_noop!(Utility::force_batch(Origin::none(), vec![]), BadOrigin);
assert_noop!(Utility::batch(Origin::none(), vec![]), BadOrigin);
assert_noop!(Utility::batch_all(Origin::none(), vec![]), BadOrigin);
})
}

0 comments on commit 7c4ac35

Please sign in to comment.