mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-13 00:01:09 +00:00
Remove Filter and use Contains instead (#9514)
* Remove Filter and use Contains instead * Fixes * Formatting * Update docs/Upgrading-2.0-to-3.0.md Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com> * Typo Co-authored-by: Shawn Tabrizi <shawntabrizi@gmail.com> Co-authored-by: Kian Paimani <5588131+kianenigma@users.noreply.github.com>
This commit is contained in:
@@ -129,8 +129,8 @@ pub fn expand_outer_origin(
|
||||
fn reset_filter(&mut self) {
|
||||
let filter = <
|
||||
<#runtime as #system_path::Config>::BaseCallFilter
|
||||
as #scrate::traits::Filter<<#runtime as #system_path::Config>::Call>
|
||||
>::filter;
|
||||
as #scrate::traits::Contains<<#runtime as #system_path::Config>::Call>
|
||||
>::contains;
|
||||
|
||||
self.filter = #scrate::sp_std::rc::Rc::new(Box::new(filter));
|
||||
}
|
||||
|
||||
@@ -2814,7 +2814,7 @@ mod tests {
|
||||
type Origin = OuterOrigin;
|
||||
type AccountId = u32;
|
||||
type Call = ();
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type BlockNumber = u32;
|
||||
type PalletInfo = Self;
|
||||
type DbWeight = ();
|
||||
|
||||
@@ -31,9 +31,11 @@ pub use tokens::{
|
||||
};
|
||||
|
||||
mod members;
|
||||
#[allow(deprecated)]
|
||||
pub use members::{AllowAll, DenyAll, Filter};
|
||||
pub use members::{
|
||||
All, AsContains, ChangeMembers, Contains, ContainsLengthBound, InitializeMembers, IsInVec,
|
||||
SortedMembers,
|
||||
AsContains, ChangeMembers, Contains, ContainsLengthBound, Everything, InitializeMembers,
|
||||
IsInVec, Nothing, SortedMembers,
|
||||
};
|
||||
|
||||
mod validation;
|
||||
@@ -44,10 +46,7 @@ pub use validation::{
|
||||
};
|
||||
|
||||
mod filter;
|
||||
pub use filter::{
|
||||
AllowAll, ClearFilterGuard, DenyAll, Filter, FilterStack, FilterStackGuard, InstanceFilter,
|
||||
IntegrityTest,
|
||||
};
|
||||
pub use filter::{ClearFilterGuard, FilterStack, FilterStackGuard, InstanceFilter, IntegrityTest};
|
||||
|
||||
mod misc;
|
||||
pub use misc::{
|
||||
|
||||
@@ -17,34 +17,11 @@
|
||||
|
||||
//! Traits and associated utilities for dealing with abstract constraint filters.
|
||||
|
||||
pub use super::members::Contains;
|
||||
use sp_std::marker::PhantomData;
|
||||
|
||||
/// Simple trait for providing a filter over a reference to some type.
|
||||
pub trait Filter<T> {
|
||||
/// Determine if a given value should be allowed through the filter (returns `true`) or not.
|
||||
fn filter(_: &T) -> bool;
|
||||
}
|
||||
|
||||
/// A [`Filter`] that allows any value.
|
||||
pub enum AllowAll {}
|
||||
|
||||
/// A [`Filter`] that denies any value.
|
||||
pub enum DenyAll {}
|
||||
|
||||
impl<T> Filter<T> for AllowAll {
|
||||
fn filter(_: &T) -> bool {
|
||||
true
|
||||
}
|
||||
}
|
||||
|
||||
impl<T> Filter<T> for DenyAll {
|
||||
fn filter(_: &T) -> bool {
|
||||
false
|
||||
}
|
||||
}
|
||||
|
||||
/// Trait to add a constraint onto the filter.
|
||||
pub trait FilterStack<T>: Filter<T> {
|
||||
pub trait FilterStack<T>: Contains<T> {
|
||||
/// The type used to archive the stack.
|
||||
type Stack;
|
||||
|
||||
@@ -135,15 +112,15 @@ macro_rules! impl_filter_stack {
|
||||
mod $module {
|
||||
#[allow(unused_imports)]
|
||||
use super::*;
|
||||
use $crate::traits::filter::{swap, take, RefCell, Vec, Box, Filter, FilterStack};
|
||||
use $crate::traits::filter::{swap, take, RefCell, Vec, Box, Contains, FilterStack};
|
||||
|
||||
thread_local! {
|
||||
static FILTER: RefCell<Vec<Box<dyn Fn(&$call) -> bool + 'static>>> = RefCell::new(Vec::new());
|
||||
}
|
||||
|
||||
impl Filter<$call> for $target {
|
||||
fn filter(call: &$call) -> bool {
|
||||
<$base>::filter(call) &&
|
||||
impl Contains<$call> for $target {
|
||||
fn contains(call: &$call) -> bool {
|
||||
<$base>::contains(call) &&
|
||||
FILTER.with(|filter| filter.borrow().iter().all(|f| f(call)))
|
||||
}
|
||||
}
|
||||
@@ -169,7 +146,7 @@ macro_rules! impl_filter_stack {
|
||||
mod $module {
|
||||
#[allow(unused_imports)]
|
||||
use super::*;
|
||||
use $crate::traits::{swap, take, RefCell, Vec, Box, Filter, FilterStack};
|
||||
use $crate::traits::{swap, take, RefCell, Vec, Box, Contains, FilterStack};
|
||||
|
||||
struct ThisFilter(RefCell<Vec<Box<dyn Fn(&$call) -> bool + 'static>>>);
|
||||
// NOTE: Safe only in wasm (guarded above) because there's only one thread.
|
||||
@@ -178,9 +155,9 @@ macro_rules! impl_filter_stack {
|
||||
|
||||
static FILTER: ThisFilter = ThisFilter(RefCell::new(Vec::new()));
|
||||
|
||||
impl Filter<$call> for $target {
|
||||
fn filter(call: &$call) -> bool {
|
||||
<$base>::filter(call) && FILTER.0.borrow().iter().all(|f| f(call))
|
||||
impl Contains<$call> for $target {
|
||||
fn contains(call: &$call) -> bool {
|
||||
<$base>::contains(call) && FILTER.0.borrow().iter().all(|f| f(call))
|
||||
}
|
||||
}
|
||||
|
||||
@@ -220,8 +197,8 @@ pub mod test_impl_filter_stack {
|
||||
|
||||
pub struct IsCallable;
|
||||
pub struct BaseFilter;
|
||||
impl Filter<u32> for BaseFilter {
|
||||
fn filter(x: &u32) -> bool {
|
||||
impl Contains<u32> for BaseFilter {
|
||||
fn contains(x: &u32) -> bool {
|
||||
x % 2 == 0
|
||||
}
|
||||
}
|
||||
@@ -234,76 +211,76 @@ pub mod test_impl_filter_stack {
|
||||
|
||||
#[test]
|
||||
fn impl_filter_stack_should_work() {
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
|
||||
IsCallable::push(|x| *x < 42);
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
|
||||
IsCallable::push(|x| *x % 3 == 0);
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(!IsCallable::filter(&40));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(!IsCallable::contains(&40));
|
||||
|
||||
IsCallable::pop();
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
|
||||
let saved = IsCallable::take();
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
|
||||
IsCallable::restore(saved);
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
|
||||
IsCallable::pop();
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn guards_should_work() {
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
{
|
||||
let _guard_1 = FilterStackGuard::<IsCallable, u32>::new(|x| *x < 42);
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
{
|
||||
let _guard_2 = FilterStackGuard::<IsCallable, u32>::new(|x| *x % 3 == 0);
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(!IsCallable::filter(&40));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(!IsCallable::contains(&40));
|
||||
}
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
{
|
||||
let _guard_2 = ClearFilterGuard::<IsCallable, u32>::new();
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
}
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(!IsCallable::filter(&42));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(!IsCallable::contains(&42));
|
||||
}
|
||||
assert!(IsCallable::filter(&36));
|
||||
assert!(IsCallable::filter(&40));
|
||||
assert!(IsCallable::filter(&42));
|
||||
assert!(!IsCallable::filter(&43));
|
||||
assert!(IsCallable::contains(&36));
|
||||
assert!(IsCallable::contains(&40));
|
||||
assert!(IsCallable::contains(&42));
|
||||
assert!(!IsCallable::contains(&43));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -25,14 +25,37 @@ pub trait Contains<T> {
|
||||
fn contains(t: &T) -> bool;
|
||||
}
|
||||
|
||||
/// A `Contains` implementation which always returns `true`.
|
||||
pub struct All<T>(PhantomData<T>);
|
||||
impl<T> Contains<T> for All<T> {
|
||||
/// A [`Contains`] implementation that contains every value.
|
||||
pub enum Everything {}
|
||||
impl<T> Contains<T> for Everything {
|
||||
fn contains(_: &T) -> bool {
|
||||
true
|
||||
}
|
||||
}
|
||||
|
||||
/// A [`Contains`] implementation that contains no value.
|
||||
pub enum Nothing {}
|
||||
impl<T> Contains<T> for Nothing {
|
||||
fn contains(_: &T) -> bool {
|
||||
false
|
||||
}
|
||||
}
|
||||
|
||||
#[deprecated = "Use `Everything` instead"]
|
||||
pub type AllowAll = Everything;
|
||||
#[deprecated = "Use `Nothing` instead"]
|
||||
pub type DenyAll = Nothing;
|
||||
#[deprecated = "Use `Contains` instead"]
|
||||
pub trait Filter<T> {
|
||||
fn filter(t: &T) -> bool;
|
||||
}
|
||||
#[allow(deprecated)]
|
||||
impl<T, C: Contains<T>> Filter<T> for C {
|
||||
fn filter(t: &T) -> bool {
|
||||
Self::contains(t)
|
||||
}
|
||||
}
|
||||
|
||||
#[impl_trait_for_tuples::impl_for_tuples(30)]
|
||||
impl<T> Contains<T> for Tuple {
|
||||
fn contains(t: &T) -> bool {
|
||||
|
||||
@@ -229,7 +229,7 @@ pub type BlockNumber = u64;
|
||||
pub type Index = u64;
|
||||
|
||||
impl system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Hash = H256;
|
||||
type Origin = Origin;
|
||||
type BlockNumber = BlockNumber;
|
||||
@@ -268,14 +268,14 @@ pub type UncheckedExtrinsic = generic::UncheckedExtrinsic<u32, Call, Signature,
|
||||
|
||||
mod origin_test {
|
||||
use super::{module3, nested, system, Block, UncheckedExtrinsic};
|
||||
use frame_support::traits::{Filter, OriginTrait};
|
||||
use frame_support::traits::{Contains, OriginTrait};
|
||||
|
||||
impl nested::module3::Config for RuntimeOriginTest {}
|
||||
impl module3::Config for RuntimeOriginTest {}
|
||||
|
||||
pub struct BaseCallFilter;
|
||||
impl Filter<Call> for BaseCallFilter {
|
||||
fn filter(c: &Call) -> bool {
|
||||
impl Contains<Call> for BaseCallFilter {
|
||||
fn contains(c: &Call) -> bool {
|
||||
match c {
|
||||
Call::NestedModule3(_) => true,
|
||||
_ => false,
|
||||
|
||||
@@ -275,7 +275,7 @@ pub type BlockNumber = u64;
|
||||
pub type Index = u64;
|
||||
|
||||
impl system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Hash = H256;
|
||||
type Origin = Origin;
|
||||
type BlockNumber = BlockNumber;
|
||||
|
||||
@@ -157,7 +157,7 @@ pub type Block = generic::Block<Header, UncheckedExtrinsic>;
|
||||
pub type UncheckedExtrinsic = generic::UncheckedExtrinsic<u32, Call, Signature, ()>;
|
||||
|
||||
impl system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Hash = H256;
|
||||
type Origin = Origin;
|
||||
type BlockNumber = BlockNumber;
|
||||
|
||||
@@ -493,7 +493,7 @@ frame_support::parameter_types!(
|
||||
);
|
||||
|
||||
impl frame_system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Origin = Origin;
|
||||
type Index = u64;
|
||||
type BlockNumber = u32;
|
||||
|
||||
@@ -223,7 +223,7 @@ frame_support::parameter_types!(
|
||||
);
|
||||
|
||||
impl frame_system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Origin = Origin;
|
||||
type Index = u64;
|
||||
type BlockNumber = u32;
|
||||
|
||||
@@ -206,7 +206,7 @@ impl frame_system::Config for Runtime {
|
||||
type BlockWeights = ();
|
||||
type BlockLength = ();
|
||||
type DbWeight = ();
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Origin = Origin;
|
||||
type Index = u64;
|
||||
type BlockNumber = u32;
|
||||
|
||||
@@ -243,7 +243,7 @@ frame_support::parameter_types!(
|
||||
);
|
||||
|
||||
impl frame_system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Origin = Origin;
|
||||
type Index = u64;
|
||||
type BlockNumber = u32;
|
||||
|
||||
@@ -129,7 +129,7 @@ mod tests {
|
||||
}
|
||||
|
||||
impl frame_system::Config for Runtime {
|
||||
type BaseCallFilter = frame_support::traits::AllowAll;
|
||||
type BaseCallFilter = frame_support::traits::Everything;
|
||||
type Origin = Origin;
|
||||
type Index = u64;
|
||||
type BlockNumber = u64;
|
||||
|
||||
@@ -25,7 +25,7 @@ pub trait Config: 'static + Eq + Clone {
|
||||
type Origin: Into<Result<RawOrigin<Self::AccountId>, Self::Origin>>
|
||||
+ From<RawOrigin<Self::AccountId>>;
|
||||
|
||||
type BaseCallFilter: frame_support::traits::Filter<Self::Call>;
|
||||
type BaseCallFilter: frame_support::traits::Contains<Self::Call>;
|
||||
type BlockNumber: Decode + Encode + EncodeLike + Clone + Default;
|
||||
type Hash;
|
||||
type AccountId: Encode + EncodeLike + Decode;
|
||||
|
||||
Reference in New Issue
Block a user