-
Notifications
You must be signed in to change notification settings - Fork 10
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
feat: pallet assets pop api integration #71
Conversation
2e8f2d9
to
3fc65ba
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking really good! Left a few comments. Also, not directly related to this PR, but why is pallet-assets
labelled as TrustBackedAssets
? Makes me think this instance is for reserve transferred assets. Also seems confusing for sc devs
|
Foreign assets will technically be a local definition of a foreign asset. Taking guidance from asset hubs latest instances, they also now have PoolAssets, which are also 'local' assets. |
I like foreign assets and local assets more IMO. In the runtime we can leave it as |
Local (or native for that matter) implies that they have been created by chain governance when in reality they can be created by anyone. Trust-backed at least signals 'buyer beware'. |
I guess this essentially came about due to stablecoins on AH |
This API available to smart contracts should implement https://github.com/inkdevhub/standards/blob/master/PSPs/psp-22.md#Interfaces, including the error types. |
I am getting an error when building this branch using the What it does under the hood is:
But I am getting an error:
It works in main, and after reviewing the PR I can't see what makes it fail. |
I will first work on the Pop API before continuing the work on this PR @AlexD10S Thanks for letting me know though :) |
d88ee51
to
92a8465
Compare
f1df725
to
3d385df
Compare
# This is the 1st commit message: refactor: general # This is the commit message #2: init # This is the commit message #3: begin refactor # This is the commit message #4: refactor: error handling # This is the commit message #5: tests: add error handling tests # This is the commit message #6: WIP # This is the commit message #7: finalise error handling # This is the commit message #8: refactor: easier review
874218f
to
f824801
Compare
runtime/devnet/src/extensions/mod.rs
Outdated
params: Vec<u8>, | ||
) -> Result<RuntimeCall, DispatchError> { | ||
match pallet_index { | ||
52 => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There may be some issues with match at compilation time, but could you explore using Assets::index();
(see here)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As this is in the runtime, this can probably be changed to super::Assets::index() to obtain the index of the pallet in the runtime in a strongly typed manner. This should be the preferred approach over constants within the runtime.
match key { | ||
TotalSupply(id) => { | ||
env.charge_weight(T::DbWeight::get().reads(1_u64))?; | ||
Ok(pallet_assets::Pallet::<T, TrustBackedAssetsInstance>::total_supply(id).encode()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
}); | ||
} | ||
} | ||
// use enumflags2::BitFlags; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
0 => { | ||
let id = <AssetId>::decode(&mut ¶ms[..]) | ||
.map_err(|_| DispatchError::Other("DecodingFailed"))?; | ||
Ok(TotalSupply(id)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Call immediately its function and write to buffer
ff9ff6d
to
9dcfccb
Compare
Too late in the development cycle imo. If its already deployed to the testnet, then updating the runtime on the testnet to see if breaks things means we would have to revert the update if it did. Unless you mean using chopsticks to sync testnet state and then run tests against that. Would be nice to be able to do this purely in Rust though. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great work! I think there is still some cleanup to do before it should be merged. There seems to be some obvious compilation issues around features too.
Note: I did not review the devnet extensions implementation as I simply ran out of steam. This PR is too big to easily digest, especially with large breaks in between. My suggestion is to consider the feedback and once ready for review again I will look at the extensions implementation in more detail.
I appreciate this was a large undertaking, but a consideration for future ones is to consider trying to break things out into smaller PRs to make it easier for the reviewer to digest.
/// Move some assets from the sender account to another, keeping the sender account alive. | ||
#[inline] | ||
pub fn transfer_keep_alive(id: AssetId, target: AccountId, amount: Balance) -> Result<()> { | ||
ChainExtensionMethod::build(u32::from_le_bytes([ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we refactor this into a descriptively named function in lib.rs, taking the four parameters with proper names so that it is easy for others to call it and to ensure the correct values are provided. It should be easy for future API implementors to do this properly.
For example:
fn chain_extension_method(version: u8, function: u8, module: u8, dispatchable: u8)
Also happy with some abbreviated function name, provided not too difficult to decipher, as it will be used a lot and it would be good if it could fit on one line. Unlikely depending on parameter constant names tho.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can even omit the version in a function defined within each version module:
fn chain_extension_method(function: u8, module: u8, dispatchable: u8) {
super::chain_extension_method(0, function, module, dispatchable)
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added to #94, great suggestion
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Taking it a bit further, it could probably be
fn build(version: u8, function: u8, module: u8, dispatchable: u8) -> ChainExtensionMethod {
ChainExtensionMethod::build(u32::from_le_bytes([version, function, module, dispatchable]))
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@evilrobot-01 @Daanvdplas PR for refracting is here: #121
Please take a look and let me know if there are any feedback
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The design is quite nice, so kudos for the iterations and improvements.
I am still not sold on the implementation, in particular using integer values directly is generally not recommended, and will introduce an undue maintenance burden. However, I would like to see this PR get merged as the functionality seems sound, and then we can make further improvements and refactoring. It has also become a very large PR to review!
runtime/devnet/src/extensions/mod.rs
Outdated
params: Vec<u8>, | ||
) -> Result<RuntimeCall, DispatchError> { | ||
match pallet_index { | ||
52 => { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There may be some issues with match at compilation time, but could you explore using Assets::index();
(see here)
I disagree on the merge. When I looked at it there was clear compilation issues if other features were enabled in the I do agree that it has become too big to review, so suggested addressing what can be addressed easily and then closing the PR (to retain as reference if required) and renaming the branch to something like |
Suggestion is to review first 3 commits with last commit next to you that has small improvements. Notes:
This will be the last changes before I close the PR and open a fresh branch where further improvements will be pushed to. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just two final comments.
/// Move some assets from the sender account to another, keeping the sender account alive. | ||
#[inline] | ||
pub fn transfer_keep_alive(id: AssetId, target: AccountId, amount: Balance) -> Result<()> { | ||
ChainExtensionMethod::build(u32::from_le_bytes([ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Taking it a bit further, it could probably be
fn build(version: u8, function: u8, module: u8, dispatchable: u8) -> ChainExtensionMethod {
ChainExtensionMethod::build(u32::from_le_bytes([version, function, module, dispatchable]))
}
Closing in favour of #132 |
Pop API + partial local fungibles implementation.
Size of contract
pop-api/examples/fungibles/
compared to the psp22 extension in ink-examples:Original wasm size: 31.3K, Optimized: 7.6K
Original wasm size: 30.3K, Optimized: 7.0K
The Pop API design is 95% in its final state. #94 will be the last addition which refactors the chain extension functions directly to the functions that are currently to be found in
pop_api/src/v0/assets/fungibles.rs
(see the issue description for explanation). Then some additional refactors need to be done or looked at (see todo's below). When this is all finished, the remaining local fungibles features can be added (again see below). Finally, we want to include the new chain extension logic in an iterative manner. This is by feature gating the functionality between devnet and testnet runtime. At the moment this doesn't work because (I think) the node takes both runtimes and cannot make the separation clearly between those runtimes. Last, a contract similar to the example contract should be deployed on testnet so that we can test it while upgrading Pop Network to polkadot sdk latest version.Remaining TODOs (in the given order):
Cargo.toml
to workspace dependencies chore: pop-api and primitives to workspace dependencies #90pop-api/examples
topop-api/integration-tests/contracts/
#95handle_unknown_error
conversion logic. #91Error
from primitives to contract library #93transfer_from
anddecrease_allowance
#104FungiblesError
#99primitives
for different runtimes #100