Skip to content

Commit

Permalink
Merge pull request #74 from arkprotocol/use_ics721_creator
Browse files Browse the repository at this point in the history
  • Loading branch information
shanev authored Nov 28, 2023
2 parents 60f63c0 + 75acead commit ad678c8
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 59 deletions.
44 changes: 13 additions & 31 deletions contracts/sg-ics721/src/execute.rs
Original file line number Diff line number Diff line change
@@ -1,9 +1,6 @@
use cosmwasm_std::{from_json, to_json_binary, Addr, Binary, Deps, DepsMut, Env, StdResult};
use ics721::{
execute::Ics721Execute,
state::CollectionData,
token_types::Class,
utils::{convert_owner_chain_address, get_collection_data},
execute::Ics721Execute, state::CollectionData, token_types::Class, utils::get_collection_data,
};
use sg721_base::msg::{CollectionInfoResponse, QueryMsg};

Expand Down Expand Up @@ -40,13 +37,15 @@ impl Ics721Execute for SgIcs721Contract {
let ics721_contract_info = deps
.querier
.query_wasm_contract_info(env.contract.address.to_string())?;
// use by default ClassId, in case there's no class data with name and symbol
let mut instantiate_msg = sg721::InstantiateMsg {
// source chain may not send optional collection data
// if not, by default class id is used for name and symbol
name: class.id.clone().into(),
symbol: class.id.clone().into(),
minter: env.contract.address.to_string(),
collection_info: sg721::CollectionInfo {
// source owner could be: 1. regular wallet, 2. contract, or 3. multisig
// bech32 calculation for 2. and 3. leads to unknown address
// therefore, we use ics721 creator as owner
creator: ics721_contract_info.creator,
description: "".to_string(),
image: "https://arkprotocol.io".to_string(),
Expand All @@ -57,31 +56,14 @@ impl Ics721Execute for SgIcs721Contract {
},
};

// unwrapped to collection data and in case of success, set creator, name and symbol
if let Some(binary) = class.data.clone() {
let class_data_result: StdResult<CollectionData> = from_json(binary);
if class_data_result.is_ok() {
let class_data = class_data_result?;
match class_data.owner {
Some(owner) =>
// owner from source chain is used
{
instantiate_msg.collection_info.creator =
convert_owner_chain_address(env, owner.as_str())?
}
None =>
// ics721 creator is used, in case of none
{
let ics721_contract_info = deps
.querier
.query_wasm_contract_info(env.contract.address.to_string())?;
instantiate_msg.collection_info.creator = ics721_contract_info.creator;
}
}
// set name and symbol
instantiate_msg.symbol = class_data.symbol;
instantiate_msg.name = class_data.name;
}
// use collection data for setting name and symbol
let collection_data = class
.data
.clone()
.and_then(|binary| from_json::<CollectionData>(binary).ok());
if let Some(collection_data) = collection_data {
instantiate_msg.name = collection_data.name;
instantiate_msg.symbol = collection_data.symbol;
}

to_json_binary(&instantiate_msg)
Expand Down
22 changes: 2 additions & 20 deletions contracts/sg-ics721/src/testing/integration_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -846,20 +846,12 @@ fn test_do_instantiate_and_mint() {
.wrap()
.query_wasm_smart(nft_contract.clone(), &Sg721QueryMsg::CollectionInfo {})
.unwrap();
let (_source_hrp, source_data, source_variant) = bech32::decode(
test.app
.api()
.addr_make(COLLECTION_OWNER_SOURCE_CHAIN)
.as_str(),
)
.unwrap();
let target_owner = bech32::encode(BECH32_PREFIX_HRP, source_data, source_variant).unwrap();

assert_eq!(
collection_info,
CollectionInfoResponse {
// creator based on owner from collection in soure chain
creator: target_owner, // creator is set to owner as defined by ClassData
creator: test.app.api().addr_make(ICS721_CREATOR).to_string(),
description: "".to_string(),
image: "https://arkprotocol.io".to_string(),
external_link: None,
Expand Down Expand Up @@ -1705,20 +1697,10 @@ fn test_do_instantiate_and_mint_no_instantiate() {
.wrap()
.query_wasm_smart(nft_contract.clone(), &Sg721QueryMsg::CollectionInfo {})
.unwrap();
let (_source_hrp, source_data, source_variant) = bech32::decode(
test.app
.api()
.addr_make(COLLECTION_OWNER_SOURCE_CHAIN)
.as_str(),
)
.unwrap();
let target_owner = bech32::encode(BECH32_PREFIX_HRP, source_data, source_variant).unwrap();

assert_eq!(
collection_info,
CollectionInfoResponse {
// creator is set to owner as defined by ClassData in 1st transfer!
creator: target_owner,
creator: test.app.api().addr_make(ICS721_CREATOR).to_string(),
description: "".to_string(),
image: "https://arkprotocol.io".to_string(),
external_link: None,
Expand Down
16 changes: 8 additions & 8 deletions packages/ics721/src/execute.rs
Original file line number Diff line number Diff line change
Expand Up @@ -332,14 +332,14 @@ where
minter: env.contract.address.to_string(),
};

// unwrapped to collection data and in case of success, set name and symbol
if let Some(binary) = class.data.clone() {
let class_data_result: StdResult<CollectionData> = from_json(binary);
if class_data_result.is_ok() {
let class_data = class_data_result?;
instantiate_msg.symbol = class_data.symbol;
instantiate_msg.name = class_data.name;
}
// use collection data for setting name and symbol
let collection_data = class
.data
.clone()
.and_then(|binary| from_json::<CollectionData>(binary).ok());
if let Some(collection_data) = collection_data {
instantiate_msg.name = collection_data.name;
instantiate_msg.symbol = collection_data.symbol;
}

to_json_binary(&instantiate_msg)
Expand Down

0 comments on commit ad678c8

Please sign in to comment.