Skip to content

Commit

Permalink
Add minting recipient for AssetNFT and AssetFT
Browse files Browse the repository at this point in the history
  • Loading branch information
keyleu committed Nov 3, 2023
1 parent 98b46c1 commit 74c7b2a
Show file tree
Hide file tree
Showing 13 changed files with 207 additions and 149 deletions.
8 changes: 4 additions & 4 deletions integration-tests/contracts/modules/ft/Cargo.lock

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

6 changes: 3 additions & 3 deletions integration-tests/contracts/modules/ft/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,11 @@ backtraces = ["cosmwasm-std/backtraces"]
library = []

[dependencies]
cosmwasm-std = "1.4.1"
cosmwasm-storage = "1.4.1"
cosmwasm-std = "1.5.0"
cosmwasm-storage = "1.5.0"
cw-storage-plus = "1.1.0"
cw2 = "1.1.1"
thiserror = "1.0.50"
coreum-wasm-sdk = "0.2.1"
coreum-wasm-sdk = "0.2.2"
cosmwasm-schema = "1.4.1"
cw-ownable = "0.5.1"
8 changes: 2 additions & 6 deletions integration-tests/contracts/modules/ft/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,9 @@ For more detailed information of the AssetFT module and functionality go to [Ass

# Messages

### Mint (amount) [Mint](https://github.com/CoreumFoundation/coreum/tree/master/x/asset/ft/spec#mint)
### Mint (amount, recipient) [Mint](https://github.com/CoreumFoundation/coreum/tree/master/x/asset/ft/spec#mint)

The contract (issuer) will mint the amount of tokens provided.
The contract (issuer) will mint the amount of tokens provided to the corresponding recipient.

### Burn (amount) [Burn](https://github.com/CoreumFoundation/coreum/tree/master/x/asset/ft/spec#burn)

Expand All @@ -55,10 +55,6 @@ Globally unfreezes the token.

Sets a whitelisted limit for an account.

### MintAndSend (account, amount)

Combines the Mint feature described above with a bank transfer for convenience.

# Queries

### Params
Expand Down
54 changes: 13 additions & 41 deletions integration-tests/contracts/modules/ft/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@ use coreum_wasm_sdk::assetft::{
};
use coreum_wasm_sdk::core::{CoreumMsg, CoreumQueries, CoreumResult};
use coreum_wasm_sdk::pagination::PageRequest;
use cosmwasm_std::{coin, entry_point, to_binary, Binary, Deps, QueryRequest, StdResult};
use cosmwasm_std::{Coin, DepsMut, Env, MessageInfo, Response, SubMsg};
use cosmwasm_std::{coin, entry_point, to_json_binary, Binary, Deps, QueryRequest, StdResult};
use cosmwasm_std::{DepsMut, Env, MessageInfo, Response};
use cw2::set_contract_version;
use cw_ownable::{assert_owner, initialize_owner};

Expand Down Expand Up @@ -62,7 +62,7 @@ pub fn execute(
msg: ExecuteMsg,
) -> CoreumResult<ContractError> {
match msg {
ExecuteMsg::Mint { amount } => mint(deps, info, amount),
ExecuteMsg::Mint { amount, recipient } => mint(deps, info, amount, recipient),
ExecuteMsg::Burn { amount } => burn(deps, info, amount),
ExecuteMsg::Freeze { account, amount } => freeze(deps, info, account, amount),
ExecuteMsg::Unfreeze { account, amount } => unfreeze(deps, info, account, amount),
Expand All @@ -71,18 +71,18 @@ pub fn execute(
ExecuteMsg::SetWhitelistedLimit { account, amount } => {
set_whitelisted_limit(deps, info, account, amount)
}
ExecuteMsg::MintAndSend { account, amount } => mint_and_send(deps, info, account, amount),
ExecuteMsg::UpgradeTokenV1 { ibc_enabled } => upgrate_token_v1(deps, info, ibc_enabled),
}
}

// ********** Transactions **********

fn mint(deps: DepsMut, info: MessageInfo, amount: u128) -> CoreumResult<ContractError> {
fn mint(deps: DepsMut, info: MessageInfo, amount: u128, recipient: String) -> CoreumResult<ContractError> {
assert_owner(deps.storage, &info.sender)?;
let denom = DENOM.load(deps.storage)?;
let msg = CoreumMsg::AssetFT(assetft::Msg::Mint {
coin: coin(amount, denom.clone()),
recipient,
});

Ok(Response::new()
Expand Down Expand Up @@ -198,34 +198,6 @@ fn set_whitelisted_limit(
.add_message(msg))
}

fn mint_and_send(
deps: DepsMut,
info: MessageInfo,
account: String,
amount: u128,
) -> CoreumResult<ContractError> {
assert_owner(deps.storage, &info.sender)?;
let denom = DENOM.load(deps.storage)?;

let mint_msg = SubMsg::new(CoreumMsg::AssetFT(assetft::Msg::Mint {
coin: coin(amount, denom.clone()),
}));

let send_msg = SubMsg::new(cosmwasm_std::BankMsg::Send {
to_address: account,
amount: vec![Coin {
amount: amount.into(),
denom: denom.clone(),
}],
});

Ok(Response::new()
.add_attribute("method", "mint_and_send")
.add_attribute("denom", denom)
.add_attribute("amount", amount.to_string())
.add_submessages([mint_msg, send_msg]))
}

fn upgrate_token_v1(
deps: DepsMut,
info: MessageInfo,
Expand All @@ -250,17 +222,17 @@ fn upgrate_token_v1(
#[cfg_attr(not(feature = "library"), entry_point)]
pub fn query(deps: Deps<CoreumQueries>, _env: Env, msg: QueryMsg) -> StdResult<Binary> {
match msg {
QueryMsg::Params {} => to_binary(&query_params(deps)?),
QueryMsg::Token {} => to_binary(&query_token(deps)?),
QueryMsg::Tokens { issuer } => to_binary(&query_tokens(deps, issuer)?),
QueryMsg::FrozenBalance { account } => to_binary(&query_frozen_balance(deps, account)?),
QueryMsg::Params {} => to_json_binary(&query_params(deps)?),
QueryMsg::Token {} => to_json_binary(&query_token(deps)?),
QueryMsg::Tokens { issuer } => to_json_binary(&query_tokens(deps, issuer)?),
QueryMsg::FrozenBalance { account } => to_json_binary(&query_frozen_balance(deps, account)?),
QueryMsg::WhitelistedBalance { account } => {
to_binary(&query_whitelisted_balance(deps, account)?)
to_json_binary(&query_whitelisted_balance(deps, account)?)
}
QueryMsg::Balance { account } => to_binary(&query_balance(deps, account)?),
QueryMsg::FrozenBalances { account } => to_binary(&query_frozen_balances(deps, account)?),
QueryMsg::Balance { account } => to_json_binary(&query_balance(deps, account)?),
QueryMsg::FrozenBalances { account } => to_json_binary(&query_frozen_balances(deps, account)?),
QueryMsg::WhitelistedBalances { account } => {
to_binary(&query_whitelisted_balances(deps, account)?)
to_json_binary(&query_whitelisted_balances(deps, account)?)
}
}
}
Expand Down
4 changes: 1 addition & 3 deletions integration-tests/contracts/modules/ft/src/msg.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,15 +17,13 @@ pub struct InstantiateMsg {

#[cw_serde]
pub enum ExecuteMsg {
Mint { amount: u128 },
Mint { amount: u128, recipient: String },
Burn { amount: u128 },
Freeze { account: String, amount: u128 },
Unfreeze { account: String, amount: u128 },
GloballyFreeze {},
GloballyUnfreeze {},
SetWhitelistedLimit { account: String, amount: u128 },
// custom message we use to show the submission of multiple messages
MintAndSend { account: String, amount: u128 },
UpgradeTokenV1 { ibc_enabled: bool },
}

Expand Down
9 changes: 5 additions & 4 deletions integration-tests/contracts/modules/nft.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,11 @@ type IssueNFTRequest struct {
//
//nolint:tagliatelle
type NftMintRequest struct {
ID string `json:"id"`
URI string `json:"uri"`
URIHash string `json:"uri_hash"`
Data string `json:"data"`
ID string `json:"id"`
URI string `json:"uri"`
URIHash string `json:"uri_hash"`
Data string `json:"data"`
Recipient string `json:"recipient"`
}

// NftIDRequest is used to query NFT with ID.
Expand Down
8 changes: 4 additions & 4 deletions integration-tests/contracts/modules/nft/Cargo.lock

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

8 changes: 4 additions & 4 deletions integration-tests/contracts/modules/nft/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,11 @@ backtraces = ["cosmwasm-std/backtraces"]
library = []

[dependencies]
cosmwasm-std = "1.4.1"
cosmwasm-storage = "1.4.1"
cosmwasm-std = "1.5.0"
cosmwasm-storage = "1.5.0"
cw-storage-plus = "1.1.0"
cw2 = "1.1.1"
thiserror = { version = "1.0.50" }
coreum-wasm-sdk = "0.2.1"
cosmwasm-schema = "1.4.1"
coreum-wasm-sdk = "0.2.2"
cosmwasm-schema = "1.5.0"
cw-ownable = "0.5.1"
43 changes: 23 additions & 20 deletions integration-tests/contracts/modules/nft/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use coreum_wasm_sdk::core::{CoreumMsg, CoreumQueries, CoreumResult};
use coreum_wasm_sdk::nft;
use coreum_wasm_sdk::pagination::PageRequest;
use cosmwasm_std::{
entry_point, to_binary, Binary, Deps, DepsMut, Env, MessageInfo, QueryRequest, Response,
entry_point, to_json_binary, Binary, Deps, DepsMut, Env, MessageInfo, QueryRequest, Response,
StdResult,
};
use cw2::set_contract_version;
Expand Down Expand Up @@ -68,7 +68,8 @@ pub fn execute(
uri,
uri_hash,
data,
} => mint(deps, info, id, uri, uri_hash, data),
recipient,
} => mint(deps, info, id, uri, uri_hash, data, recipient),
ExecuteMsg::Burn { id } => burn(deps, info, id),
ExecuteMsg::Freeze { id } => freeze(deps, info, id),
ExecuteMsg::Unfreeze { id } => unfreeze(deps, info, id),
Expand All @@ -95,6 +96,7 @@ fn mint(
uri: Option<String>,
uri_hash: Option<String>,
data: Option<Binary>,
recipient: String,
) -> CoreumResult<ContractError> {
assert_owner(deps.storage, &info.sender)?;
let class_id = CLASS_ID.load(deps.storage)?;
Expand All @@ -105,6 +107,7 @@ fn mint(
uri,
uri_hash,
data,
recipient
});

Ok(Response::new()
Expand Down Expand Up @@ -309,26 +312,26 @@ fn remove_from_class_whitelist(
#[cfg_attr(not(feature = "library"), entry_point)]
pub fn query(deps: Deps<CoreumQueries>, _env: Env, msg: QueryMsg) -> StdResult<Binary> {
match msg {
QueryMsg::Params {} => to_binary(&query_params(deps)?),
QueryMsg::Class {} => to_binary(&query_class(deps)?),
QueryMsg::Classes { issuer } => to_binary(&query_classes(deps, issuer)?),
QueryMsg::Frozen { id } => to_binary(&query_frozen(deps, id)?),
QueryMsg::Whitelisted { id, account } => to_binary(&query_whitelisted(deps, id, account)?),
QueryMsg::Params {} => to_json_binary(&query_params(deps)?),
QueryMsg::Class {} => to_json_binary(&query_class(deps)?),
QueryMsg::Classes { issuer } => to_json_binary(&query_classes(deps, issuer)?),
QueryMsg::Frozen { id } => to_json_binary(&query_frozen(deps, id)?),
QueryMsg::Whitelisted { id, account } => to_json_binary(&query_whitelisted(deps, id, account)?),
QueryMsg::WhitelistedAccountsForNft { id } => {
to_binary(&query_whitelisted_accounts_for_nft(deps, id)?)
to_json_binary(&query_whitelisted_accounts_for_nft(deps, id)?)
}
QueryMsg::Balance { owner } => to_binary(&query_balance(deps, owner)?),
QueryMsg::Owner { id } => to_binary(&query_owner(deps, id)?),
QueryMsg::Supply {} => to_binary(&query_supply(deps)?),
QueryMsg::Nft { id } => to_binary(&query_nft(deps, id)?),
QueryMsg::Nfts { owner } => to_binary(&query_nfts(deps, owner)?),
QueryMsg::ClassNft {} => to_binary(&query_nft_class(deps)?),
QueryMsg::ClassesNft {} => to_binary(&query_nft_classes(deps)?),
QueryMsg::BurntNft { nft_id } => to_binary(&query_burnt_nft(deps, nft_id)?),
QueryMsg::BurntNftsInClass {} => to_binary(&query_burnt_nfts_in_class(deps)?),
QueryMsg::ClassFrozen { account } => to_binary(&query_class_frozen(deps, account)?),
QueryMsg::ClassFrozenAccounts {} => to_binary(&query_class_frozen_accounts(deps)?),
QueryMsg::ClassWhitelistedAccounts {} => to_binary(&query_class_whitelisted_accounts(deps)?),
QueryMsg::Balance { owner } => to_json_binary(&query_balance(deps, owner)?),
QueryMsg::Owner { id } => to_json_binary(&query_owner(deps, id)?),
QueryMsg::Supply {} => to_json_binary(&query_supply(deps)?),
QueryMsg::Nft { id } => to_json_binary(&query_nft(deps, id)?),
QueryMsg::Nfts { owner } => to_json_binary(&query_nfts(deps, owner)?),
QueryMsg::ClassNft {} => to_json_binary(&query_nft_class(deps)?),
QueryMsg::ClassesNft {} => to_json_binary(&query_nft_classes(deps)?),
QueryMsg::BurntNft { nft_id } => to_json_binary(&query_burnt_nft(deps, nft_id)?),
QueryMsg::BurntNftsInClass {} => to_json_binary(&query_burnt_nfts_in_class(deps)?),
QueryMsg::ClassFrozen { account } => to_json_binary(&query_class_frozen(deps, account)?),
QueryMsg::ClassFrozenAccounts {} => to_json_binary(&query_class_frozen_accounts(deps)?),
QueryMsg::ClassWhitelistedAccounts {} => to_json_binary(&query_class_whitelisted_accounts(deps)?),
}
}

Expand Down
1 change: 1 addition & 0 deletions integration-tests/contracts/modules/nft/src/msg.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ pub enum ExecuteMsg {
uri: Option<String>,
uri_hash: Option<String>,
data: Option<Binary>,
recipient: String,
},
Burn {
id: String,
Expand Down
19 changes: 10 additions & 9 deletions integration-tests/modules/assetft_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5186,9 +5186,10 @@ func TestAssetFTIssuingSmartContractIsAllowedToSendAndReceive(t *testing.T) {

// mint to itself
amountToMint := sdkmath.NewInt(500)
mintPayload, err := json.Marshal(map[ftMethod]amountBodyFTRequest{
mintPayload, err := json.Marshal(map[ftMethod]amountRecipientBodyFTRequest{
ftMethodMint: {
Amount: amountToMint.String(),
Amount: amountToMint.String(),
Recipient: contractAddr,
},
})
requireT.NoError(err)
Expand All @@ -5197,23 +5198,23 @@ func TestAssetFTIssuingSmartContractIsAllowedToSendAndReceive(t *testing.T) {
requireT.NoError(err)

// mint to someone else
amountToMintAndSend := sdkmath.NewInt(100)
mintAndSendPayload, err := json.Marshal(map[ftMethod]accountAmountBodyFTRequest{
ftMethodMintAndSend: {
Account: recipient.String(),
Amount: amountToMintAndSend.String(),
amountToMint = sdkmath.NewInt(100)
mintPayload, err = json.Marshal(map[ftMethod]amountRecipientBodyFTRequest{
ftMethodMint: {
Amount: amountToMint.String(),
Recipient: recipient.String(),
},
})
requireT.NoError(err)

_, err = chain.Wasm.ExecuteWASMContract(ctx, txf, admin, contractAddr, mintAndSendPayload, sdk.Coin{})
_, err = chain.Wasm.ExecuteWASMContract(ctx, txf, admin, contractAddr, mintPayload, sdk.Coin{})
requireT.NoError(err)

// send back to smart contract
msgSend := &banktypes.MsgSend{
FromAddress: recipient.String(),
ToAddress: contractAddr,
Amount: sdk.NewCoins(sdk.NewCoin(denom, amountToMintAndSend)),
Amount: sdk.NewCoins(sdk.NewCoin(denom, amountToMint)),
}
_, err = client.BroadcastTx(
ctx,
Expand Down
Loading

0 comments on commit 74c7b2a

Please sign in to comment.