mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 08:07:58 +00:00
Safe and sane multi-item storage removal (#11490)
* Fix overlay prefix removal result * Second part of the overlay prefix removal fix. * Report only items deleted from storage in clear_prefix * Fix kill_prefix * Formatting * Remove unused code * Fixes * Fixes * Introduce clear_prefix host function v3 * Formatting * Use v2 for now * Fixes * Formatting * Docs * Child prefix removal should also hide v3 for now * Fixes * Fixes * Formatting * Fixes * apply_to_keys_whle takes start_at * apply_to_keys_whle takes start_at * apply_to_keys_whle takes start_at * Cursor API; force limits * Use unsafe deprecated functions * Formatting * Fixes * Grumbles * Fixes * Docs * Some nitpicks 🙈 * Update primitives/externalities/src/lib.rs Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> * Formatting * Fixes * cargo fmt * Fixes * Update primitives/io/src/lib.rs Co-authored-by: Keith Yeung <kungfukeith11@gmail.com> * Formatting * Fixes Co-authored-by: Bastian Köcher <info@kchr.de> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Keith Yeung <kungfukeith11@gmail.com>
This commit is contained in:
@@ -256,12 +256,43 @@ pub fn put_storage_value<T: Encode>(module: &[u8], item: &[u8], hash: &[u8], val
|
||||
|
||||
/// Remove all items under a storage prefix by the `module`, the map's `item` name and the key
|
||||
/// `hash`.
|
||||
#[deprecated = "Use `clear_storage_prefix` instead"]
|
||||
pub fn remove_storage_prefix(module: &[u8], item: &[u8], hash: &[u8]) {
|
||||
let mut key = vec![0u8; 32 + hash.len()];
|
||||
let storage_prefix = storage_prefix(module, item);
|
||||
key[0..32].copy_from_slice(&storage_prefix);
|
||||
key[32..].copy_from_slice(hash);
|
||||
frame_support::storage::unhashed::kill_prefix(&key, None);
|
||||
let _ = frame_support::storage::unhashed::clear_prefix(&key, None, None);
|
||||
}
|
||||
|
||||
/// Attempt to remove all values under a storage prefix by the `module`, the map's `item` name and
|
||||
/// the key `hash`.
|
||||
///
|
||||
/// All values in the client overlay will be deleted, if `maybe_limit` is `Some` then up to
|
||||
/// that number of values are deleted from the client backend by seeking and reading that number of
|
||||
/// storage values plus one. If `maybe_limit` is `None` then all values in the client backend are
|
||||
/// deleted. This is potentially unsafe since it's an unbounded operation.
|
||||
///
|
||||
/// ## Cursors
|
||||
///
|
||||
/// The `maybe_cursor` parameter should be `None` for the first call to initial removal.
|
||||
/// If the resultant `maybe_cursor` is `Some`, then another call is required to complete the
|
||||
/// removal operation. This value must be passed in as the subsequent call's `maybe_cursor`
|
||||
/// parameter. If the resultant `maybe_cursor` is `None`, then the operation is complete and no
|
||||
/// items remain in storage provided that no items were added between the first calls and the
|
||||
/// final call.
|
||||
pub fn clear_storage_prefix(
|
||||
module: &[u8],
|
||||
item: &[u8],
|
||||
hash: &[u8],
|
||||
maybe_limit: Option<u32>,
|
||||
maybe_cursor: Option<&[u8]>,
|
||||
) -> sp_io::MultiRemovalResults {
|
||||
let mut key = vec![0u8; 32 + hash.len()];
|
||||
let storage_prefix = storage_prefix(module, item);
|
||||
key[0..32].copy_from_slice(&storage_prefix);
|
||||
key[32..].copy_from_slice(hash);
|
||||
frame_support::storage::unhashed::clear_prefix(&key, maybe_limit, maybe_cursor)
|
||||
}
|
||||
|
||||
/// Take a particular item in storage by the `module`, the map's `item` name and the key `hash`.
|
||||
|
||||
Reference in New Issue
Block a user