Skip to content

Commit

Permalink
Update mint fee distribution logic for the rest of the minters
Browse files Browse the repository at this point in the history
  • Loading branch information
MightOfOaks committed Sep 29, 2024
1 parent 9bf4f6f commit 57dedbc
Show file tree
Hide file tree
Showing 11 changed files with 75 additions and 120 deletions.
29 changes: 7 additions & 22 deletions contracts/minters/open-edition-minter-merkle-wl/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,11 @@ use open_edition_factory::msg::{OpenEditionMinterCreateMsg, ParamsResponse};
use open_edition_factory::state::OpenEditionMinterParams;
use open_edition_factory::types::NftMetadataType;
use semver::Version;
use sg1::{checked_fair_burn, ibc_denom_fair_burn};
use sg1::distribute_mint_fees;
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
use sg_std::{StargazeMsgWrapper, NATIVE_DENOM};
use sg_std::StargazeMsgWrapper;
use url::Url;
use whitelist_mtree::msg::{
ConfigResponse as WhitelistConfigResponse, HasMemberResponse, QueryMsg as WhitelistQueryMsg,
Expand Down Expand Up @@ -525,30 +525,15 @@ fn _execute_mint(
};
let network_fee = mint_price.amount * mint_fee;

// This is for the network fee msg
// send non-native fees to community pool
if mint_price.denom != NATIVE_DENOM {
// only send non-zero amounts
// send portion to dev addr
if !network_fee.is_zero() {
ibc_denom_fair_burn(
coin(network_fee.u128(), mint_price.denom.to_string()),
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}
} else if !network_fee.is_zero() {
checked_fair_burn(
&info,
network_fee.u128(),
if !network_fee.is_zero() {
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}

Expand Down
29 changes: 7 additions & 22 deletions contracts/minters/open-edition-minter-wl-flex/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,11 @@ use open_edition_factory::msg::{OpenEditionMinterCreateMsg, ParamsResponse};
use open_edition_factory::state::OpenEditionMinterParams;
use open_edition_factory::types::NftMetadataType;
use semver::Version;
use sg1::{checked_fair_burn, ibc_denom_fair_burn};
use sg1::distribute_mint_fees;
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
use sg_std::{StargazeMsgWrapper, NATIVE_DENOM};
use sg_std::StargazeMsgWrapper;
use sg_whitelist_flex::msg::{
ConfigResponse as WhitelistConfigResponse, HasMemberResponse, Member,
QueryMsg as WhitelistQueryMsg,
Expand Down Expand Up @@ -528,30 +528,15 @@ fn _execute_mint(
};
let network_fee = mint_price.amount * mint_fee;

// This is for the network fee msg
// send non-native fees to community pool
if mint_price.denom != NATIVE_DENOM {
// only send non-zero amounts
// send portion to dev addr
if !network_fee.is_zero() {
ibc_denom_fair_burn(
coin(network_fee.u128(), mint_price.denom.to_string()),
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}
} else if !network_fee.is_zero() {
checked_fair_burn(
&info,
network_fee.u128(),
if !network_fee.is_zero() {
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}

Expand Down
29 changes: 7 additions & 22 deletions contracts/minters/open-edition-minter/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,11 @@ use open_edition_factory::msg::{OpenEditionMinterCreateMsg, ParamsResponse};
use open_edition_factory::state::OpenEditionMinterParams;
use open_edition_factory::types::NftMetadataType;
use semver::Version;
use sg1::{checked_fair_burn, ibc_denom_fair_burn};
use sg1::distribute_mint_fees;
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
use sg_std::{StargazeMsgWrapper, NATIVE_DENOM};
use sg_std::StargazeMsgWrapper;
use sg_whitelist::msg::{
ConfigResponse as WhitelistConfigResponse, HasMemberResponse, QueryMsg as WhitelistQueryMsg,
};
Expand Down Expand Up @@ -502,30 +502,15 @@ fn _execute_mint(
};
let network_fee = mint_price.amount * mint_fee;

// This is for the network fee msg
// send non-native fees to community pool
if mint_price.denom != NATIVE_DENOM {
// only send non-zero amounts
// send portion to dev addr
if !network_fee.is_zero() {
ibc_denom_fair_burn(
coin(network_fee.u128(), mint_price.denom.to_string()),
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}
} else if !network_fee.is_zero() {
checked_fair_burn(
&info,
network_fee.u128(),
if !network_fee.is_zero() {
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
Some(
deps.api
.addr_validate(&factory_params.extension.dev_fee_address)?,
),
&mut res,
)?;
}

Expand Down
15 changes: 7 additions & 8 deletions contracts/minters/vending-minter-featured/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ use cw_utils::{may_pay, maybe_addr, nonpayable, parse_reply_instantiate_data};
use rand_core::{RngCore, SeedableRng};
use rand_xoshiro::Xoshiro128PlusPlus;
use semver::Version;
use sg1::checked_fair_burn;
use sg1::{checked_fair_burn, distribute_mint_fees};
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
Expand Down Expand Up @@ -664,14 +664,13 @@ fn _execute_mint(

let network_fee = mint_price.amount * mint_fee;

// send non-native fees to community pool
let pa_dao = "stars159t8e03zlmgyekmdrpxnyf70rdky28v553kj53zsapqadaunt4wsmn5m3l".to_string();

if !network_fee.is_zero() {
res = res.add_message(BankMsg::Send {
to_address: pa_dao.to_string(),
amount: vec![coin(network_fee.u128(), mint_price.denom.clone())],
});
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
true,
None,
)?;
}

let mintable_token_mapping = match token_id {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ use cw_utils::{may_pay, maybe_addr, nonpayable, parse_reply_instantiate_data};
use rand_core::{RngCore, SeedableRng};
use rand_xoshiro::Xoshiro128PlusPlus;
use semver::Version;
use sg1::checked_fair_burn;
use sg1::{checked_fair_burn, distribute_mint_fees};
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
Expand Down Expand Up @@ -701,13 +701,13 @@ fn _execute_mint(

let network_fee = mint_price.amount * mint_fee;

let pa_dao = "stars159t8e03zlmgyekmdrpxnyf70rdky28v553kj53zsapqadaunt4wsmn5m3l".to_string();

if !network_fee.is_zero() {
res = res.add_message(BankMsg::Send {
to_address: pa_dao.to_string(),
amount: vec![coin(network_fee.u128(), mint_price.denom.clone())],
});
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
true,
None,
)?;
}

let mintable_token_mapping = match token_id {
Expand Down
23 changes: 9 additions & 14 deletions contracts/minters/vending-minter-merkle-wl/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,11 @@ use cw_utils::{may_pay, maybe_addr, nonpayable, parse_reply_instantiate_data};
use rand_core::{RngCore, SeedableRng};
use rand_xoshiro::Xoshiro128PlusPlus;
use semver::Version;
use sg1::{checked_fair_burn, ibc_denom_fair_burn};
use sg1::{checked_fair_burn, distribute_mint_fees};
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
use sg_std::{StargazeMsgWrapper, GENESIS_MINT_START_TIME, NATIVE_DENOM};
use sg_std::{StargazeMsgWrapper, GENESIS_MINT_START_TIME};
use sg_whitelist::msg::{
ConfigResponse as WhitelistConfigResponse, HasMemberResponse, QueryMsg as WhitelistQueryMsg,
};
Expand Down Expand Up @@ -701,18 +701,13 @@ fn _execute_mint(

let network_fee = mint_price.amount * mint_fee;

// send non-native fees to community pool
if mint_price.denom != NATIVE_DENOM {
// only send non-zero amounts
if !network_fee.is_zero() {
ibc_denom_fair_burn(
coin(network_fee.u128(), mint_price.clone().denom),
None,
&mut res,
)?;
}
} else {
checked_fair_burn(&info, network_fee.u128(), None, &mut res)?;
if !network_fee.is_zero() {
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
None,
)?;
}

let mintable_token_mapping = match token_id {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ use cw_utils::{may_pay, maybe_addr, nonpayable, parse_reply_instantiate_data};
use rand_core::{RngCore, SeedableRng};
use rand_xoshiro::Xoshiro128PlusPlus;
use semver::Version;
use sg1::checked_fair_burn;
use sg1::{checked_fair_burn, distribute_mint_fees};
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
Expand Down Expand Up @@ -656,13 +656,13 @@ fn _execute_mint(
};
let network_fee = mint_price.amount * mint_fee;

let pa_dao = "stars159t8e03zlmgyekmdrpxnyf70rdky28v553kj53zsapqadaunt4wsmn5m3l".to_string();

if !network_fee.is_zero() {
res = res.add_message(BankMsg::Send {
to_address: pa_dao.to_string(),
amount: vec![coin(network_fee.u128(), mint_price.denom.clone())],
});
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
true,
None,
)?;
}

let mintable_token_mapping = match token_id {
Expand Down
24 changes: 10 additions & 14 deletions contracts/minters/vending-minter-wl-flex/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,11 @@ use cw_utils::{may_pay, maybe_addr, nonpayable, parse_reply_instantiate_data};
use rand_core::{RngCore, SeedableRng};
use rand_xoshiro::Xoshiro128PlusPlus;
use semver::Version;
use sg1::{checked_fair_burn, ibc_denom_fair_burn};
use sg1::{checked_fair_burn, distribute_mint_fees};
use sg2::query::Sg2QueryMsg;
use sg4::{MinterConfig, Status, StatusResponse, SudoMsg};
use sg721::{ExecuteMsg as Sg721ExecuteMsg, InstantiateMsg as Sg721InstantiateMsg};
use sg_std::{StargazeMsgWrapper, GENESIS_MINT_START_TIME, NATIVE_DENOM};
use sg_std::{StargazeMsgWrapper, GENESIS_MINT_START_TIME};
use sg_whitelist_flex::msg::{
ConfigResponse as WhitelistConfigResponse, HasMemberResponse, Member,
QueryMsg as WhitelistQueryMsg,
Expand Down Expand Up @@ -654,18 +654,14 @@ fn _execute_mint(
Decimal::bps(factory_params.mint_fee_bps)
};
let network_fee = mint_price.amount * mint_fee;
// use ibc_denom_fair_burn for non native denoms
if mint_price.denom != NATIVE_DENOM {
// only send non-zero amounts
if !network_fee.is_zero() {
ibc_denom_fair_burn(
coin(network_fee.u128(), mint_price.clone().denom),
None,
&mut res,
)?;
}
} else {
checked_fair_burn(&info, network_fee.u128(), None, &mut res)?;

if !network_fee.is_zero() {
distribute_mint_fees(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
None,
)?;
}

let mintable_token_mapping = match token_id {
Expand Down
1 change: 1 addition & 0 deletions contracts/minters/vending-minter/src/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -667,6 +667,7 @@ fn _execute_mint(
coin(network_fee.u128(), mint_price.clone().denom),
&mut res,
false,
None,
)?;
}

Expand Down
8 changes: 5 additions & 3 deletions packages/sg1/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,8 @@ pub fn distribute_mint_fees(
let liquidity_dao_ratio_featured: Decimal = Decimal::from_ratio(1u128, 8u128);

let mut event = Event::new("mint-fee-distribution");
let liquidity_dao_ratio = if is_featured {

let liquidity_dao_percentage = if is_featured {
liquidity_dao_ratio_featured
} else {
liquidity_dao_ratio
Expand All @@ -98,7 +99,8 @@ pub fn distribute_mint_fees(
let dev_coin = coin(dev_fee, fee.denom.to_string());
let remaining_coin = coin(fee.amount.u128() - dev_fee, fee.denom.clone());

let liquidity_dao_fee = (remaining_coin.amount.mul_ceil(liquidity_dao_ratio)).u128();
let liquidity_dao_fee =
(remaining_coin.amount.mul_ceil(liquidity_dao_percentage)).u128();
let liquidity_dao_coin = coin(liquidity_dao_fee, fee.denom.to_string());
let foundation_coin = coin(remaining_coin.amount.u128() - liquidity_dao_fee, fee.denom);

Expand All @@ -123,7 +125,7 @@ pub fn distribute_mint_fees(
}));
}
None => {
let liquidity_dao_fee = (fee.amount.mul_ceil(liquidity_dao_ratio)).u128();
let liquidity_dao_fee = (fee.amount.mul_ceil(liquidity_dao_percentage)).u128();
let liquidity_dao_coin = coin(liquidity_dao_fee, fee.denom.to_string());
let foundation_coin = coin(fee.amount.u128() - liquidity_dao_fee, fee.denom);

Expand Down
9 changes: 8 additions & 1 deletion test-suite/src/open_edition_minter/tests/ibc_asset_mint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ use open_edition_factory::state::{OpenEditionMinterParams, ParamsExtension};
use open_edition_minter::msg::ExecuteMsg;
use sg_std::{GENESIS_MINT_START_TIME, NATIVE_DENOM};

use crate::common_setup::setup_minter::common::constants::LIQUIDITY_DAO_ADDRESS;
use crate::common_setup::{
setup_accounts_and_block::setup_block_time,
setup_minter::{
Expand Down Expand Up @@ -172,7 +173,13 @@ fn one_hundred_percent_burned_ibc_minter() {
.wrap()
.query_balance(Addr::unchecked(FOUNDATION), denom)
.unwrap();
assert_eq!(balance.amount, mint_price.amount * Decimal::percent(50));
assert_eq!(balance.amount, mint_price.amount * Decimal::percent(40));

let balance = router
.wrap()
.query_balance(Addr::unchecked(LIQUIDITY_DAO_ADDRESS), denom)
.unwrap();
assert_eq!(balance.amount, mint_price.amount * Decimal::percent(10));
}

#[test]
Expand Down

0 comments on commit 57dedbc

Please sign in to comment.