Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve APIs for Tries in Runtime #5756

Merged
merged 104 commits into from
Sep 30, 2024
Merged
Changes from 1 commit
Commits
Show all changes
104 commits
Select commit Hold shift + click to select a range
d50d5e4
initial ideas
shawntabrizi Mar 28, 2024
7f4422e
Update proving_trie.rs
shawntabrizi Mar 28, 2024
bdc0c84
create trait
shawntabrizi Mar 28, 2024
da385ab
use trait
shawntabrizi Mar 28, 2024
6ab4bfb
clean up trait and basic trie further
shawntabrizi Mar 28, 2024
1cfb29f
use trait in session historical
shawntabrizi Mar 28, 2024
3080c7b
fix api, add basic end to end test
shawntabrizi Mar 28, 2024
39b0fca
fix test
shawntabrizi Mar 28, 2024
599f576
Revert "use trait in session historical"
shawntabrizi Mar 28, 2024
a1c8886
Merge branch 'master' into shawntabrizi-proving-trie
shawntabrizi Mar 29, 2024
6bde2a3
Merge branch 'master' into shawntabrizi-proving-trie
Ank4n Apr 4, 2024
ead7951
Update substrate/primitives/runtime/src/proving_trie.rs
shawntabrizi Apr 4, 2024
0cac048
Merge branch 'master' into shawntabrizi-proving-trie
shawntabrizi Aug 15, 2024
acfe734
fix some feedback
shawntabrizi Aug 15, 2024
45f4287
update name
shawntabrizi Aug 15, 2024
efbe1c9
docs and multi value proof
shawntabrizi Aug 15, 2024
cfa62ce
improve test
shawntabrizi Aug 15, 2024
885fd94
add multi-value query test
shawntabrizi Aug 15, 2024
18a5c2e
Merge branch 'master' into shawntabrizi-proving-trie
shawntabrizi Aug 15, 2024
5e3e518
Create pr_3881.prdoc
shawntabrizi Aug 15, 2024
f35cacc
Merge branch 'shawntabrizi-proving-trie' of https://github.com/shawnt…
shawntabrizi Aug 15, 2024
e6c3759
use v1
shawntabrizi Aug 17, 2024
89679c3
Merge branch 'master' into shawntabrizi-proving-trie
shawntabrizi Aug 17, 2024
b40c96a
initial idea
shawntabrizi Aug 19, 2024
37052ee
some bs code to make things compile
shawntabrizi Aug 19, 2024
08f2b35
more stuff
shawntabrizi Aug 19, 2024
118a51c
complete logic
shawntabrizi Aug 19, 2024
44bc5bb
add verification check
shawntabrizi Aug 19, 2024
6e853ba
Merge branch 'master' into shawntabrizi-proving-trie
shawntabrizi Sep 2, 2024
89abcd0
initial idea
shawntabrizi Aug 19, 2024
8ad3381
some bs code to make things compile
shawntabrizi Aug 19, 2024
ae6fab7
more stuff
shawntabrizi Aug 19, 2024
115f89b
complete logic
shawntabrizi Aug 19, 2024
e5f0056
add verification check
shawntabrizi Aug 19, 2024
766790a
Merge branch 'shawntabrizi-assets-distribution' of https://github.com…
shawntabrizi Sep 2, 2024
b80589c
large refactor to proving trie
shawntabrizi Sep 3, 2024
83c66e7
fix tests
shawntabrizi Sep 3, 2024
5a4ff43
use basic proving trie
shawntabrizi Sep 3, 2024
394cc6f
Merge branch 'master' into shawntabrizi-assets-distribution
shawntabrizi Sep 3, 2024
84574e1
undo changes to binary merkle tree
shawntabrizi Sep 3, 2024
444b1f7
remove comment code
shawntabrizi Sep 3, 2024
f47b12e
make api more runtime friendly
shawntabrizi Sep 3, 2024
0305bc7
Merge remote-tracking branch 'upstream/master' into shawntabrizi-asse…
shawntabrizi Sep 4, 2024
ee90711
add basic test, and fix missing check for tracking distribution
shawntabrizi Sep 6, 2024
61162b6
introduce distribution info and active
shawntabrizi Sep 6, 2024
ae2ff18
introduce end_distribution
shawntabrizi Sep 6, 2024
fb63207
add clean distribution
shawntabrizi Sep 7, 2024
e713698
Merge branch 'master' into shawntabrizi-assets-distribution
shawntabrizi Sep 7, 2024
988b201
weight stuff
shawntabrizi Sep 7, 2024
233d339
temp fix for ui
shawntabrizi Sep 7, 2024
48fe9c6
Merge branch 'master' into pr/5400
shawntabrizi Sep 16, 2024
122f9cc
make work with binary tree
shawntabrizi Sep 17, 2024
59fdc63
initial stuff
shawntabrizi Sep 17, 2024
1f587ef
more
shawntabrizi Sep 17, 2024
dbb8368
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 17, 2024
f3a1af0
initial stuff
shawntabrizi Sep 17, 2024
daf8f50
more
shawntabrizi Sep 17, 2024
133a440
fix up binary tree
shawntabrizi Sep 17, 2024
813caae
refactor
shawntabrizi Sep 18, 2024
e270275
fixes
shawntabrizi Sep 18, 2024
a679bc9
update api for a single opaque blob
shawntabrizi Sep 18, 2024
be3e6c4
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 18, 2024
65d2b98
undo changes in assets
shawntabrizi Sep 18, 2024
ed30142
undo weight
shawntabrizi Sep 18, 2024
39e78d7
Update substrate/frame/support/src/traits/proving.rs
shawntabrizi Sep 18, 2024
aabaf76
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 19, 2024
450b6c6
consolidate apis
shawntabrizi Sep 19, 2024
d153c74
Merge branch 'shawntabrizi-binary-trie2' of https://github.com/parity…
shawntabrizi Sep 19, 2024
240a777
create a proving trie trait
shawntabrizi Sep 19, 2024
0f1e28b
implement trait for base2
shawntabrizi Sep 19, 2024
375dc12
fix tests
shawntabrizi Sep 19, 2024
99135e4
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 19, 2024
3ab4d94
update api to use references everywhere
shawntabrizi Sep 21, 2024
0c8d189
add `proof_size_to_hashes`
shawntabrizi Sep 21, 2024
cfa2a79
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 23, 2024
21a13c9
Create pr_5756.prdoc
shawntabrizi Sep 23, 2024
46ee7e0
undo changes to proving.rs
shawntabrizi Sep 23, 2024
d5bc012
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 24, 2024
39b666a
feedback
shawntabrizi Sep 24, 2024
5d05ef5
Merge branch 'shawntabrizi-binary-trie2' of https://github.com/parity…
shawntabrizi Sep 24, 2024
fd68b1b
create proof size to hashes trait
shawntabrizi Sep 24, 2024
2ad1bb2
use proof to hashes
shawntabrizi Sep 24, 2024
1b3db91
fix doc
shawntabrizi Sep 24, 2024
6e33438
Update pr_5756.prdoc
shawntabrizi Sep 24, 2024
245709e
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 25, 2024
74d9adf
Update base16.rs
shawntabrizi Sep 25, 2024
8135a69
Update prdoc/pr_5756.prdoc
shawntabrizi Sep 25, 2024
ae231f8
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 25, 2024
f1eb268
Update prdoc/pr_5756.prdoc
shawntabrizi Sep 26, 2024
02e396e
Update substrate/primitives/runtime/src/proving_trie/base2.rs
shawntabrizi Sep 26, 2024
18fb3d6
Update substrate/primitives/runtime/src/proving_trie/base2.rs
shawntabrizi Sep 26, 2024
a67c806
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 26, 2024
687f2b1
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 26, 2024
56cd568
fix test
shawntabrizi Sep 27, 2024
a25052c
Merge branch 'shawntabrizi-binary-trie2' of https://github.com/parity…
shawntabrizi Sep 27, 2024
43c93b6
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 27, 2024
fcb3714
fix docs
shawntabrizi Sep 27, 2024
fb90f63
Merge branch 'shawntabrizi-binary-trie2' of https://github.com/parity…
shawntabrizi Sep 27, 2024
fe68034
improve proof_to_hashes
shawntabrizi Sep 27, 2024
f40d0d0
impl prooftohashes for provers
shawntabrizi Sep 27, 2024
904fe42
Update pr_5756.prdoc
shawntabrizi Sep 27, 2024
bf128aa
Update Cargo.toml
shawntabrizi Sep 28, 2024
c8066ce
Merge branch 'shawntabrizi-binary-trie2' of https://github.com/parity…
shawntabrizi Sep 28, 2024
a4efeef
Merge branch 'master' into shawntabrizi-binary-trie2
shawntabrizi Sep 29, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
use basic proving trie
shawntabrizi committed Sep 3, 2024

Verified

This commit was signed with the committer’s verified signature.
shawntabrizi Shawn Tabrizi
commit 5a4ff43e6b5f33e2bb96d13e890e9456c7458955
1 change: 0 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion substrate/frame/assets/Cargo.toml
Original file line number Diff line number Diff line change
@@ -20,7 +20,6 @@ codec = { workspace = true }
impl-trait-for-tuples = "0.2.2"
log = { workspace = true }
scale-info = { features = ["derive"], workspace = true }
binary-merkle-tree = { workspace = true }
# Needed for various traits. In our case, `OnFinalize`.
sp-runtime = { workspace = true }
# Needed for type-safe access to storage DB.
50 changes: 26 additions & 24 deletions substrate/frame/assets/src/functions.rs
Original file line number Diff line number Diff line change
@@ -438,10 +438,11 @@ impl<T: Config<I>, I: 'static> Pallet<T, I> {
Ok(())
}

/// Creates a distribution in storage for asset `id`, which can be claimed via `do_claim_distribution`.
/// Creates a distribution in storage for asset `id`, which can be claimed via
/// `do_claim_distribution`.
pub(super) fn do_mint_distribution(
id: T::AssetId,
merkle_root: H256,
merkle_root: T::Hash,
maybe_check_issuer: Option<T::AccountId>,
) -> DispatchResult {
let details = Asset::<T, I>::get(&id).ok_or(Error::<T, I>::Unknown)?;
@@ -452,36 +453,37 @@ impl<T: Config<I>, I: 'static> Pallet<T, I> {
}

let distribution_count: u32 = MerklizedDistribution::<T, I>::count();
MerklizedDistribution::<T, I>::insert(&distribution_count, (id.clone(), merkle_root.clone()));
MerklizedDistribution::<T, I>::insert(
&distribution_count,
(id.clone(), merkle_root.clone()),
);

Self::deposit_event(Event::DistributionIssued { asset_id: id, merkle_root: merkle_root });
Self::deposit_event(Event::DistributionIssued { asset_id: id, merkle_root });

Ok(())
}

/// A wrapper around `do_mint`, allowing a `merkle_proof` to control the amount minted and to whom.
/// A wrapper around `do_mint`, allowing a `merkle_proof` to control the amount minted and to
/// whom.
pub(super) fn do_claim_distribution(
distribution_id: DistributionCounter,
merkle_proof: DistributionProof<T, I>,
beneficiary: T::AccountId,
amount: T::Balance,
merkle_proof: DistributionProof,
) -> DispatchResult {
let (asset_id, merkle_root) = MerklizedDistribution::<T, I>::get(distribution_id).ok_or(Error::<T, I>::Unknown)?;

ensure!(merkle_root == merkle_proof.root, "TODO ERROR");
let (beneficiary, amount) = merkle_proof.leaf;
let already_claimed = MerklizedDistributionTracker::<T, I>::contains_key(&distribution_id, &beneficiary);
ensure!(!already_claimed, "TODO ERROR");

use sp_runtime::traits::BlakeTwo256;
let verified = true;
// let verified = binary_merkle_tree::verify_proof::<BlakeTwo256, _, (T::AccountId, T::Balance)>(
// &merkle_proof.root,
// merkle_proof.proof,
// merkle_proof.number_of_leaves,
// merkle_proof.leaf_index,
// merkle_proof.leaf,
// );

ensure!(verified, "TODO ERROR");
if amount.is_zero() {
return Err(Error::<T, I>::BalanceLow.into())
}

let (asset_id, merkle_root) =
MerklizedDistribution::<T, I>::get(distribution_id).ok_or(Error::<T, I>::Unknown)?;

sp_runtime::proving_trie::verify_single_value_proof::<T::Hashing, _, _>(
merkle_root,
&merkle_proof,
&beneficiary,
Some(amount),
)?;

Self::do_mint(asset_id, &beneficiary, amount, None)?;
MerklizedDistributionTracker::<T, I>::insert(&distribution_id, &beneficiary, ());
23 changes: 12 additions & 11 deletions substrate/frame/assets/src/lib.rs
Original file line number Diff line number Diff line change
@@ -193,9 +193,6 @@ use frame_support::{
},
};
use frame_system::Config as SystemConfig;
use sp_core::H256;

use binary_merkle_tree::MerkleProof;

pub use pallet::*;
pub use weights::WeightInfo;
@@ -460,15 +457,15 @@ pub mod pallet {
>;

pub type DistributionCounter = u32;
pub type DistributionProof<T, I> = MerkleProof<H256, (<T as frame_system::Config>::AccountId, <T as Config<I>>::Balance)>;
pub type DistributionProof = Vec<Vec<u8>>;

#[pallet::storage]
/// Merklized distribution of an asset.
pub(super) type MerklizedDistribution<T: Config<I>, I: 'static = ()> = CountedStorageMap<
_,
Blake2_128Concat,
DistributionCounter,
(T::AssetId, H256),
(T::AssetId, T::Hash),
OptionQuery,
>;

@@ -668,7 +665,7 @@ pub mod pallet {
/// Some assets were withdrawn from the account (e.g. for transaction fees).
Withdrawn { asset_id: T::AssetId, who: T::AccountId, amount: T::Balance },
/// A distribution of assets were issued.
DistributionIssued { asset_id: T::AssetId, merkle_root: H256 },
DistributionIssued { asset_id: T::AssetId, merkle_root: T::Hash },
}

#[pallet::error]
@@ -1834,7 +1831,8 @@ pub mod pallet {
/// The origin must be Signed and the sender must be the Issuer of the asset `id`.
///
/// - `id`: The identifier of the asset to have some amount minted.
/// - `merkle_root`: The merkle root of a binary tree used to authorize minting.
/// - `merkle_root`: The merkle root of a compact base-16 merkle trie used to authorize
/// minting.
///
/// Emits `DistributionIssued` event when successful.
///
@@ -1844,7 +1842,7 @@ pub mod pallet {
pub fn mint_distribution(
origin: OriginFor<T>,
id: T::AssetIdParameter,
merkle_root: H256,
merkle_root: T::Hash,
) -> DispatchResult {
let origin = ensure_signed(origin)?;
let id: T::AssetId = id.into();
@@ -1857,7 +1855,8 @@ pub mod pallet {
/// Any signed origin may call this function.
///
/// - `distribution_id`: The identifier of the distribution.
/// - `merkle_proof`: The merkle proof of the account and balance in a binary tree used to authorize minting.
/// - `merkle_proof`: The merkle proof of the account and balance in a compact base-16
/// merkle trie used to authorize minting.
///
/// Emits `Issued` event when successful.
///
@@ -1867,10 +1866,12 @@ pub mod pallet {
pub fn claim_distribution(
origin: OriginFor<T>,
distribution_id: DistributionCounter,
merkle_proof: DistributionProof<T, I>,
beneficiary: T::AccountId,
amount: T::Balance,
merkle_proof: DistributionProof,
) -> DispatchResult {
ensure_signed(origin)?;
Self::do_claim_distribution(distribution_id, merkle_proof)?;
Self::do_claim_distribution(distribution_id, beneficiary, amount, merkle_proof)?;
Ok(())
}
}