mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-16 08:31:14 +00:00
[NFTs] Rework permissions model (#13482)
* Disallow admin to transfer or burn items he doesn't own * lock_collection should be accessible by collection's owner only * Allow admin to access lock_item_properties() * Fix do_lock_item_properties * Move update_mint_settings() to Issuer * Rename check_owner to check_origin * Typo * Make admin to be in charge of managing the metadata * Make admin the main attributes manager * offchain mint should be signed by Issuer * Remove the special case when the Issuer calls the mint() function * Rework burn and destroy methods * Return back item_metadatas * Don't repatriate the deposit on transfer * A bit more tests * One more test * Add migration * Chore * Clippy * Rename to owned_item * Address comments * Replace .filter_map with .find_map * Improve version validation in pre_upgrade() * ".git/.scripts/commands/bench/bench.sh" pallet dev pallet_nfts --------- Co-authored-by: parity-processbot <>
This commit is contained in:
@@ -0,0 +1,117 @@
|
||||
// This file is part of Substrate.
|
||||
|
||||
// Copyright (C) Parity Technologies (UK) Ltd.
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use super::*;
|
||||
use frame_support::{log, traits::OnRuntimeUpgrade};
|
||||
|
||||
pub mod v1 {
|
||||
use frame_support::{pallet_prelude::*, weights::Weight};
|
||||
|
||||
use super::*;
|
||||
|
||||
#[derive(Decode)]
|
||||
pub struct OldCollectionDetails<AccountId, DepositBalance> {
|
||||
pub owner: AccountId,
|
||||
pub owner_deposit: DepositBalance,
|
||||
pub items: u32,
|
||||
pub item_metadatas: u32,
|
||||
pub attributes: u32,
|
||||
}
|
||||
|
||||
impl<AccountId, DepositBalance> OldCollectionDetails<AccountId, DepositBalance> {
|
||||
fn migrate_to_v1(self, item_configs: u32) -> CollectionDetails<AccountId, DepositBalance> {
|
||||
CollectionDetails {
|
||||
owner: self.owner,
|
||||
owner_deposit: self.owner_deposit,
|
||||
items: self.items,
|
||||
item_metadatas: self.item_metadatas,
|
||||
item_configs,
|
||||
attributes: self.attributes,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub struct MigrateToV1<T>(sp_std::marker::PhantomData<T>);
|
||||
impl<T: Config> OnRuntimeUpgrade for MigrateToV1<T> {
|
||||
fn on_runtime_upgrade() -> Weight {
|
||||
let current_version = Pallet::<T>::current_storage_version();
|
||||
let onchain_version = Pallet::<T>::on_chain_storage_version();
|
||||
|
||||
log::info!(
|
||||
target: LOG_TARGET,
|
||||
"Running migration with current storage version {:?} / onchain {:?}",
|
||||
current_version,
|
||||
onchain_version
|
||||
);
|
||||
|
||||
if onchain_version == 0 && current_version == 1 {
|
||||
let mut translated = 0u64;
|
||||
let mut configs_iterated = 0u64;
|
||||
Collection::<T>::translate::<
|
||||
OldCollectionDetails<T::AccountId, DepositBalanceOf<T>>,
|
||||
_,
|
||||
>(|key, old_value| {
|
||||
let item_configs = ItemConfigOf::<T>::iter_prefix(&key).count() as u32;
|
||||
configs_iterated += item_configs as u64;
|
||||
translated.saturating_inc();
|
||||
Some(old_value.migrate_to_v1(item_configs))
|
||||
});
|
||||
|
||||
current_version.put::<Pallet<T>>();
|
||||
|
||||
log::info!(
|
||||
target: LOG_TARGET,
|
||||
"Upgraded {} records, storage to version {:?}",
|
||||
translated,
|
||||
current_version
|
||||
);
|
||||
T::DbWeight::get().reads_writes(translated + configs_iterated + 1, translated + 1)
|
||||
} else {
|
||||
log::info!(
|
||||
target: LOG_TARGET,
|
||||
"Migration did not execute. This probably should be removed"
|
||||
);
|
||||
T::DbWeight::get().reads(1)
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(feature = "try-runtime")]
|
||||
fn pre_upgrade() -> Result<Vec<u8>, &'static str> {
|
||||
let current_version = Pallet::<T>::current_storage_version();
|
||||
let onchain_version = Pallet::<T>::on_chain_storage_version();
|
||||
ensure!(onchain_version == 0 && current_version == 1, "migration from version 0 to 1.");
|
||||
let prev_count = Collection::<T>::iter().count();
|
||||
Ok((prev_count as u32).encode())
|
||||
}
|
||||
|
||||
#[cfg(feature = "try-runtime")]
|
||||
fn post_upgrade(prev_count: Vec<u8>) -> Result<(), &'static str> {
|
||||
let prev_count: u32 = Decode::decode(&mut prev_count.as_slice()).expect(
|
||||
"the state parameter should be something that was generated by pre_upgrade",
|
||||
);
|
||||
let post_count = Collection::<T>::iter().count() as u32;
|
||||
assert_eq!(
|
||||
prev_count, post_count,
|
||||
"the records count before and after the migration should be the same"
|
||||
);
|
||||
|
||||
ensure!(Pallet::<T>::on_chain_storage_version() == 1, "wrong storage version");
|
||||
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user