From f6919a12d1defb247495b69a3a8494c9a83dd776 Mon Sep 17 00:00:00 2001 From: bretheren <31092321+bretheren@users.noreply.github.com> Date: Thu, 15 Aug 2024 18:50:06 +0000 Subject: [PATCH 1/2] Update to Min Sale Calculation --- src/contract.rs | 30 ++++++++++++++++++++++++------ src/msg.rs | 1 + src/tests.rs | 3 +++ 3 files changed, 28 insertions(+), 6 deletions(-) diff --git a/src/contract.rs b/src/contract.rs index 78878c4..3d90040 100644 --- a/src/contract.rs +++ b/src/contract.rs @@ -13,7 +13,7 @@ use cw_storage_plus::Bound; use cw_utils::{NativeBalance, PaymentError}; use fuzion_flows::{FlowCreate, FlowSchedule, FlowType}; use fuzion_utilities::{Asset, AssetList, DenomUnit, LogoURIs}; -use kujira::{DenomMsg, KujiraMsg, KujiraQuery, Precision}; +use kujira::{DenomMsg, KujiraMsg, KujiraQuerier, KujiraQuery, Precision}; use kujira_orca::BidPoolsResponse; use kujira_pilot::Status; @@ -389,7 +389,10 @@ pub fn execute( .iter() .find(|d| d.denom == orca.bid_denom.clone()); - ensure!(bid_denom.is_some(), ContractError::InvalidBidDenom {}); + ensure!( + bid_denom.clone().is_some(), + ContractError::InvalidBidDenom {} + ); let categories = launch.clone().tokenomics.unwrap().categories; @@ -398,11 +401,26 @@ pub fn execute( .find(|c| c.category_type == CategoryTypes::Sale) .unwrap(); - let launch_min_raise_amount = sale_category.recipients[0].amount.mul(sale.price).mul( - Decimal::from_str(&orca.max_slot.to_string()) + let oracle_querier = KujiraQuerier::new(&deps.querier); + let oracle_price = oracle_querier.query_exchange_rate( + bid_denom .unwrap() - .mul(orca.premium_rate_per_slot), - ); + .oracle_symbol + .clone() + .unwrap_or(bid_denom.unwrap().symbol.to_string()), + )?; + let normalized_usd_price = oracle_price.normalize(bid_denom.unwrap().decimals); + let launch_min_raise_amount = sale_category.recipients[0] + .amount + .mul(sale.price) + .mul( + Decimal::one().sub( + Decimal::from_str(&orca.max_slot.to_string()) + .unwrap() + .mul(orca.premium_rate_per_slot), + ), + ) + .mul(normalized_usd_price); ensure!( launch_min_raise_amount > config.pilot.min_raise_amount, diff --git a/src/msg.rs b/src/msg.rs index 50c6c84..38e7a2f 100644 --- a/src/msg.rs +++ b/src/msg.rs @@ -214,6 +214,7 @@ impl fmt::Display for LaunchStatus { pub struct BidDenoms { pub denom: Denom, pub symbol: String, + pub oracle_symbol: Option, pub decimals: u8, } diff --git a/src/tests.rs b/src/tests.rs index 33960df..a3a278e 100644 --- a/src/tests.rs +++ b/src/tests.rs @@ -194,6 +194,7 @@ fn launch_new_token() { allowed_bid_denoms: vec![BidDenoms { denom: Denom::from("bid"), symbol: "bid".to_string(), + oracle_symbol: None, decimals: 6, }], min_raise_amount: Uint128::from(100_000_000_000u128), @@ -749,6 +750,7 @@ fn launch_own_token() { allowed_bid_denoms: vec![BidDenoms { denom: Denom::from("bid"), symbol: "bid".to_string(), + oracle_symbol: None, decimals: 6, }], min_raise_amount: Uint128::from(100_000_000_000u128), @@ -1249,6 +1251,7 @@ fn launch_own_token_18_decimals() { allowed_bid_denoms: vec![BidDenoms { denom: Denom::from("bid"), symbol: "bid".to_string(), + oracle_symbol: None, decimals: 6, }], min_raise_amount: Uint128::from(100_000_000_000u128), From 6b6c2f278b4f3572f30d31133833286c260b763d Mon Sep 17 00:00:00 2001 From: bretheren <31092321+bretheren@users.noreply.github.com> Date: Sun, 18 Aug 2024 08:31:22 +0000 Subject: [PATCH 2/2] Update check on Min Sale Amount --- src/contract.rs | 93 +++++++++++++++++++++++++++++++------------------ 1 file changed, 59 insertions(+), 34 deletions(-) diff --git a/src/contract.rs b/src/contract.rs index 3d90040..a2dd427 100644 --- a/src/contract.rs +++ b/src/contract.rs @@ -15,12 +15,12 @@ use fuzion_flows::{FlowCreate, FlowSchedule, FlowType}; use fuzion_utilities::{Asset, AssetList, DenomUnit, LogoURIs}; use kujira::{DenomMsg, KujiraMsg, KujiraQuerier, KujiraQuery, Precision}; use kujira_orca::BidPoolsResponse; -use kujira_pilot::Status; +use kujira_pilot::{CreateOrca, CreateSale, Status}; use crate::launch::Launch; use crate::msg::{ - Bow, CallbackType, CategoryTypes, Config, Fin, LaunchStatus, Pilot, ReplyInfo, ReplyTypes, - Token, Tokenomics, + BidDenoms, Bow, CallbackType, CategoryTypes, Config, Fin, LaunchStatus, Pilot, ReplyInfo, + ReplyTypes, Token, Tokenomics, TokenomicsCategories, }; use crate::state::{launch, CONFIG, REPLY}; use crate::{ContractError, ExecuteMsg, InstantiateMsg, MigrateMsg, QueryMsg}; @@ -28,6 +28,43 @@ use crate::{ContractError, ExecuteMsg, InstantiateMsg, MigrateMsg, QueryMsg}; const CONTRACT_NAME: &str = "fuzion-kujira-keiko"; const CONTRACT_VERSION: &str = env!("CARGO_PKG_VERSION"); +pub fn assert_min_sale_amount( + kujira_querier: &KujiraQuerier, + config: &Config, + bid_denom: &BidDenoms, + sale_category: &TokenomicsCategories, + sale: &CreateSale, + orca: &CreateOrca, +) -> Result<(), ContractError> { + let oracle_price = kujira_querier.query_exchange_rate( + bid_denom + .oracle_symbol + .clone() + .unwrap_or(bid_denom.symbol.to_string()), + )?; + let normalized_usd_price = oracle_price.normalize(bid_denom.decimals); + let launch_min_raise_amount = sale_category.recipients[0] + .amount + .mul(sale.price) + .mul( + Decimal::one().sub( + Decimal::from_str(&orca.max_slot.to_string()) + .unwrap() + .mul(orca.premium_rate_per_slot), + ), + ) + .mul(normalized_usd_price); + + ensure!( + launch_min_raise_amount > config.pilot.min_raise_amount, + ContractError::InvalidRaiseAmount( + launch_min_raise_amount.to_string(), + config.pilot.min_raise_amount.to_string() + ) + ); + Ok(()) +} + #[entry_point] pub fn migrate(deps: DepsMut, _env: Env, _msg: MigrateMsg) -> StdResult { set_contract_version(deps.storage, CONTRACT_NAME, CONTRACT_VERSION)?; @@ -401,34 +438,14 @@ pub fn execute( .find(|c| c.category_type == CategoryTypes::Sale) .unwrap(); - let oracle_querier = KujiraQuerier::new(&deps.querier); - let oracle_price = oracle_querier.query_exchange_rate( - bid_denom - .unwrap() - .oracle_symbol - .clone() - .unwrap_or(bid_denom.unwrap().symbol.to_string()), + assert_min_sale_amount( + &KujiraQuerier::new(&deps.querier), + &config, + bid_denom.unwrap(), + sale_category, + &sale, + &orca, )?; - let normalized_usd_price = oracle_price.normalize(bid_denom.unwrap().decimals); - let launch_min_raise_amount = sale_category.recipients[0] - .amount - .mul(sale.price) - .mul( - Decimal::one().sub( - Decimal::from_str(&orca.max_slot.to_string()) - .unwrap() - .mul(orca.premium_rate_per_slot), - ), - ) - .mul(normalized_usd_price); - - ensure!( - launch_min_raise_amount > config.pilot.min_raise_amount, - ContractError::InvalidRaiseAmount( - launch_min_raise_amount.to_string(), - config.pilot.min_raise_amount.to_string() - ) - ); let mut pilot = Pilot { idx: None, @@ -519,13 +536,21 @@ pub fn execute( launch.pilot.clone().unwrap().sale }; + let orca = launch.pilot.clone().unwrap().orca; + + assert_min_sale_amount( + &KujiraQuerier::new(&deps.querier), + &config, + bid_denom.unwrap(), + sale_category, + &sale, + &orca, + )?; + messages.push(SubMsg::reply_on_success( CosmosMsg::Wasm(wasm_execute( config.pilot.pilot_contract, - &kujira_pilot::ExecuteMsg::Create { - sale, - orca: launch.pilot.clone().unwrap().orca, - }, + &kujira_pilot::ExecuteMsg::Create { sale, orca }, vec![pilot_config.deposit, sale_funds], )?), ReplyTypes::Create as u64,