use super::{asset_entry::AssetEntry, contract_entry::ContractEntry, ChannelEntry};
use crate::{
ans_host::state::{
ASSET_ADDRESSES, ASSET_PAIRINGS, CHANNELS, CONTRACT_ADDRESSES, POOL_METADATA,
REV_ASSET_ADDRESSES,
},
objects::{DexAssetPairing, PoolMetadata, PoolReference, UniquePoolId},
AbstractResult,
};
use cosmwasm_std::{Addr, QuerierWrapper, StdError};
use cw_asset::AssetInfo;
#[cosmwasm_schema::cw_serde]
pub struct AnsHost {
pub address: Addr,
}
impl AnsHost {
pub fn new(address: Addr) -> Self {
Self { address }
}
pub fn query_contracts(
&self,
querier: &QuerierWrapper,
contracts: &[ContractEntry],
) -> AbstractResult<Vec<Addr>> {
let mut resolved_contracts: Vec<Addr> = Vec::new();
for key in contracts.iter() {
let result = self.query_contract(querier, key)?;
resolved_contracts.push(result);
}
Ok(resolved_contracts)
}
pub fn query_contract(
&self,
querier: &QuerierWrapper,
contract: &ContractEntry,
) -> AbstractResult<Addr> {
let result: Addr = CONTRACT_ADDRESSES
.query(querier, self.address.clone(), contract)?
.ok_or_else(|| {
StdError::generic_err(format!("contract {contract} not found in ans_host"))
})?;
Ok(Addr::unchecked(result))
}
pub fn query_assets(
&self,
querier: &QuerierWrapper,
assets: &[AssetEntry],
) -> AbstractResult<Vec<AssetInfo>> {
let mut resolved_assets = Vec::new();
for asset in assets.iter() {
let result = self.query_asset(querier, asset)?;
resolved_assets.push(result);
}
Ok(resolved_assets)
}
pub fn query_asset(
&self,
querier: &QuerierWrapper,
asset: &AssetEntry,
) -> AbstractResult<AssetInfo> {
let result = ASSET_ADDRESSES
.query(querier, self.address.clone(), asset)?
.ok_or_else(|| {
StdError::generic_err(format!("asset {} not found in ans_host", &asset))
})?;
Ok(result)
}
pub fn query_assets_reverse(
&self,
querier: &QuerierWrapper,
assets: &[AssetInfo],
) -> AbstractResult<Vec<AssetEntry>> {
let mut resolved_assets = vec![];
for asset in assets.iter() {
let result = self.query_asset_reverse(querier, asset)?;
resolved_assets.push(result);
}
Ok(resolved_assets)
}
pub fn query_asset_reverse(
&self,
querier: &QuerierWrapper,
asset: &AssetInfo,
) -> AbstractResult<AssetEntry> {
let result = REV_ASSET_ADDRESSES
.query(querier, self.address.clone(), asset)?
.ok_or_else(|| {
StdError::generic_err(format!("cw-asset {} not found in ans_host", &asset))
})?;
Ok(result)
}
pub fn query_channel(
&self,
querier: &QuerierWrapper,
channel: &ChannelEntry,
) -> AbstractResult<String> {
let result: String = CHANNELS
.query(querier, self.address.clone(), channel)?
.ok_or_else(|| {
StdError::generic_err(format!("channel {channel} not found in ans_host"))
})?;
Ok(result)
}
pub fn query_asset_pairing(
&self,
querier: &QuerierWrapper,
dex_asset_pairing: &DexAssetPairing,
) -> AbstractResult<Vec<PoolReference>> {
let result: Vec<PoolReference> = ASSET_PAIRINGS
.query(querier, self.address.clone(), dex_asset_pairing)?
.ok_or_else(|| {
StdError::generic_err(format!(
"asset pairing {dex_asset_pairing} not found in ans_host"
))
})?;
Ok(result)
}
pub fn query_pool_metadata(
&self,
querier: &QuerierWrapper,
pool_id: &UniquePoolId,
) -> AbstractResult<PoolMetadata> {
let result: PoolMetadata = POOL_METADATA
.query(querier, self.address.clone(), *pool_id)?
.ok_or_else(|| {
StdError::generic_err(format!(
"pool metadata for pool {} not found in ans_host",
pool_id.as_u64()
))
})?;
Ok(result)
}
}