@swapkit/toolboxes 4.0.0-beta.36 → 4.0.0-beta.37

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -4,7 +4,7 @@
4
4
  "sourcesContent": [
5
5
  "import { base64, bech32 } from \"@scure/base\";\nimport { SwapKitError } from \"@swapkit/helpers\";\nimport { fromByteArray, toByteArray } from \"base64-js\";\n\nexport function bech32ToBase64(address: string) {\n return base64.encode(\n Uint8Array.from(bech32.fromWords(bech32.decode(address as `${string}1${string}`).words)),\n );\n}\n\nexport function base64ToBech32(address: string, prefix = \"thor\") {\n return bech32.encode(prefix, bech32.toWords(base64.decode(address)));\n}\n\nexport function toBase64(data: Uint8Array) {\n return fromByteArray(data);\n}\n\nexport function fromBase64(base64String: string) {\n if (!base64String.match(/^[a-zA-Z0-9+/]*={0,2}$/)) {\n throw new SwapKitError(\"toolbox_cosmos_invalid_params\", {\n error: \"Invalid base64 string format\",\n });\n }\n return toByteArray(base64String);\n}\n",
6
6
  "import type { TxBodyEncodeObject } from \"@cosmjs/proto-signing\";\nimport { AssetValue, Chain, ChainToChainId, SwapKitError } from \"@swapkit/helpers\";\n\nimport {\n createStargateClient,\n getDefaultChainFee,\n getDenomWithChain,\n getMsgSendDenom,\n} from \"../util\";\n\nimport { createDefaultAminoTypes, createDefaultRegistry } from \"./registry\";\nimport type { ThorchainCreateTransactionParams } from \"./types\";\n\ntype MsgSend = ReturnType<typeof transferMsgAmino>;\ntype MsgDeposit = ReturnType<typeof depositMsgAmino>;\ntype DirectMsgSendForBroadcast = ReturnType<typeof parseAminoMessageForDirectSigning<MsgSend>>;\ntype DirectMsgDepositForBroadcast = ReturnType<\n typeof parseAminoMessageForDirectSigning<MsgDeposit>\n>;\n\nexport const THORCHAIN_GAS_VALUE = getDefaultChainFee(Chain.THORChain).gas;\nexport const MAYA_GAS_VALUE = getDefaultChainFee(Chain.Maya).gas;\n\nexport const transferMsgAmino = ({\n sender,\n recipient,\n assetValue,\n}: {\n sender: string;\n recipient?: string;\n assetValue: AssetValue;\n}) => {\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n return {\n type: `${chain === Chain.Maya ? \"mayachain\" : \"thorchain\"}/MsgSend` as const,\n value: {\n from_address: sender,\n to_address: recipient,\n amount: [\n {\n amount: assetValue.getBaseValue(\"string\"),\n denom: getMsgSendDenom(assetValue.symbol, true),\n },\n ],\n },\n };\n};\n\nexport const depositMsgAmino = ({\n sender,\n assetValue,\n memo = \"\",\n}: {\n sender: string;\n assetValue: AssetValue;\n memo?: string;\n}) => {\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n return {\n type: `${chain === Chain.Maya ? \"mayachain\" : \"thorchain\"}/MsgDeposit` as const,\n value: {\n coins: [\n {\n amount: assetValue.getBaseValue(\"string\"),\n asset: getDenomWithChain(assetValue),\n },\n ],\n signer: sender,\n memo,\n },\n };\n};\n\nexport const buildAminoMsg = ({\n sender,\n recipient,\n assetValue,\n memo,\n}: {\n sender: string;\n recipient?: string;\n assetValue: AssetValue;\n memo?: string;\n}) => {\n const isDeposit = !recipient;\n const msg = isDeposit\n ? depositMsgAmino({ sender, assetValue, memo })\n : transferMsgAmino({ sender, recipient, assetValue });\n\n return msg;\n};\n\nexport const convertToSignable = async (\n msg: MsgSend | MsgDeposit,\n chain: Chain.THORChain | Chain.Maya,\n) => {\n const aminoTypes = await createDefaultAminoTypes(chain);\n\n return aminoTypes.fromAmino(msg);\n};\n\nconst getAccount = async ({ rpcUrl, sender }: { sender: string; rpcUrl: string }) => {\n const client = await createStargateClient(rpcUrl);\n const account = await client.getAccount(sender);\n\n if (!account) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n return account;\n};\n\nexport function getCreateTransaction(rpcUrl: string) {\n return function createTransaction(params: ThorchainCreateTransactionParams) {\n const { assetValue, recipient, memo, sender, asSignable, asAminoMessage } = params;\n\n if (recipient) {\n return buildTransferTx(rpcUrl)({\n sender,\n recipient,\n assetValue,\n memo,\n asSignable,\n asAminoMessage,\n });\n }\n\n return buildDepositTx(rpcUrl)({\n sender,\n assetValue,\n memo,\n asSignable,\n asAminoMessage,\n });\n };\n}\n\nexport const buildTransferTx =\n (rpcUrl: string) =>\n async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n asSignable = true,\n asAminoMessage = false,\n sequence,\n accountNumber,\n }: ThorchainCreateTransactionParams) => {\n const account = await getAccount({ rpcUrl, sender });\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n\n const transferMsg = transferMsgAmino({\n sender,\n recipient,\n assetValue,\n });\n\n const msg = asSignable\n ? await convertToSignable(\n asAminoMessage ? transferMsg : parseAminoMessageForDirectSigning(transferMsg),\n chain,\n )\n : transferMsg;\n\n const transaction = {\n chainId: ChainToChainId[chain],\n accountNumber: accountNumber || account.accountNumber,\n sequence: sequence || account.sequence,\n msgs: [msg],\n fee: getDefaultChainFee(assetValue.chain as Chain.THORChain | Chain.Maya),\n memo,\n };\n\n return transaction;\n };\n\nexport const buildDepositTx =\n (rpcUrl: string) =>\n async ({\n sender,\n assetValue,\n memo = \"\",\n asSignable = true,\n asAminoMessage = false,\n sequence,\n accountNumber,\n }: ThorchainCreateTransactionParams) => {\n const account = await getAccount({ rpcUrl, sender });\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n\n const depositMsg = depositMsgAmino({ sender, assetValue, memo });\n\n const msg = asSignable\n ? await convertToSignable(\n asAminoMessage ? depositMsg : parseAminoMessageForDirectSigning<MsgDeposit>(depositMsg),\n chain,\n )\n : depositMsg;\n\n const transaction = {\n chainId: ChainToChainId[chain],\n accountNumber: accountNumber || account.accountNumber,\n sequence: sequence || account.sequence,\n msgs: [msg],\n fee: getDefaultChainFee(assetValue.chain as Chain.THORChain | Chain.Maya),\n memo,\n };\n\n return transaction;\n };\n\nexport function parseAminoMessageForDirectSigning<T extends MsgDeposit | MsgSend>(msg: T) {\n if (msg.type === \"thorchain/MsgSend\" || msg.type === \"mayachain/MsgSend\") return msg as MsgSend;\n\n return {\n ...msg,\n value: {\n ...msg.value,\n coins: (msg as MsgDeposit).value.coins.map((coin: { asset: string; amount: string }) => {\n const assetValue = AssetValue.from({ asset: coin.asset });\n\n const symbol = (\n assetValue.isSynthetic ? assetValue.symbol.split(\"/\")?.[1] : assetValue.symbol\n )?.toUpperCase();\n const chain = (\n assetValue.isSynthetic ? assetValue.symbol.split(\"/\")?.[0] : assetValue.chain\n )?.toUpperCase();\n\n return {\n ...coin,\n asset: {\n chain,\n symbol,\n ticker: assetValue.ticker,\n synth: assetValue.isSynthetic,\n },\n };\n }),\n },\n };\n}\n\nexport async function buildEncodedTxBody({\n chain,\n memo,\n msgs,\n}: {\n msgs: DirectMsgDepositForBroadcast[] | DirectMsgSendForBroadcast[];\n memo: string;\n chain: Chain.THORChain | Chain.Maya;\n}) {\n const registry = await createDefaultRegistry();\n const aminoTypes = await createDefaultAminoTypes(chain);\n\n const signedTxBody: TxBodyEncodeObject = {\n typeUrl: \"/cosmos.tx.v1beta1.TxBody\",\n value: { memo, messages: msgs.map((msg) => aminoTypes.fromAmino(msg)) },\n };\n\n return registry.encode(signedTxBody);\n}\n",
7
- "import type { OfflineSigner } from \"@cosmjs/proto-signing\";\nimport type { SigningStargateClientOptions } from \"@cosmjs/stargate\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n ChainId,\n type CosmosChain,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\n\nimport type { CosmosCreateTransactionParams } from \"./thorchainUtils\";\n\nexport const USK_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1QK00H5ATUTPSV900X202PXX42NPJR9THG58DNQPA72F2P7M2LUASE444A7/UUSK\";\n\nexport const YUM_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1YGFXN0ER40KLCNCK8THLTUPRDXLCK6WVNPKF2K/UYUM\";\n\nexport const DEFAULT_COSMOS_FEE_MAINNET = {\n amount: [{ denom: \"uatom\", amount: \"500\" }],\n gas: \"200000\",\n};\n\nexport const DEFAULT_KUJI_FEE_MAINNET = {\n amount: [{ denom: \"ukuji\", amount: \"1000\" }],\n gas: \"200000\",\n};\n\nexport function getDefaultChainFee(chain: CosmosChain) {\n switch (chain) {\n case Chain.Maya:\n return { amount: [], gas: \"10000000000\" };\n case Chain.THORChain:\n return { amount: [], gas: \"500000000\" };\n case Chain.Kujira:\n return DEFAULT_KUJI_FEE_MAINNET;\n default:\n return DEFAULT_COSMOS_FEE_MAINNET;\n }\n}\n\nexport const getMsgSendDenom = (symbol: string, isThorchain = false) => {\n if (isThorchain) {\n return symbol.toLowerCase();\n }\n\n switch (symbol) {\n case \"uUSK\":\n case \"USK\":\n return USK_KUJIRA_FACTORY_DENOM;\n case \"uYUM\":\n case \"YUM\":\n return YUM_KUJIRA_FACTORY_DENOM;\n case \"uKUJI\":\n case \"KUJI\":\n return \"ukuji\";\n case \"ATOM\":\n case \"uATOM\":\n return \"uatom\";\n default:\n return symbol;\n }\n};\n\nexport const getDenomWithChain = ({ symbol, chain }: AssetValue) => {\n if (chain === Chain.Maya) {\n return (symbol.toUpperCase() !== \"CACAO\" ? symbol : `${Chain.Maya}.${symbol}`).toUpperCase();\n }\n if (chain === Chain.THORChain) {\n return (\n [\"RUNE\", \"TCY\", \"RUJI\"].includes(symbol.toUpperCase())\n ? `${Chain.THORChain}.${symbol}`\n : symbol\n ).toUpperCase();\n }\n return getMsgSendDenom(symbol, false);\n};\n\nexport async function createStargateClient(url: string) {\n const { StargateClient } = await import(\"@cosmjs/stargate\");\n\n const defaultRequestHeaders =\n typeof window !== \"undefined\"\n ? ({} as Record<string, string>)\n : { referrer: \"https://sk.thorswap.net\", referer: \"https://sk.thorswap.net\" };\n\n return StargateClient.connect({\n url,\n headers: defaultRequestHeaders,\n });\n}\n\nexport async function createSigningStargateClient(\n url: string,\n signer: any,\n optionsOrBaseGas: string | SigningStargateClientOptions = {},\n) {\n const { SigningStargateClient, GasPrice } = (await import(\"@cosmjs/stargate\")).default;\n const gasPrice = typeof optionsOrBaseGas === \"string\" ? optionsOrBaseGas : \"0.0003uatom\";\n const options = typeof optionsOrBaseGas === \"string\" ? {} : optionsOrBaseGas;\n\n return SigningStargateClient.connectWithSigner(url, signer, {\n gasPrice: GasPrice.fromString(gasPrice),\n ...options,\n });\n}\n\nexport async function createOfflineStargateClient(\n wallet: OfflineSigner,\n registry?: SigningStargateClientOptions,\n) {\n const { SigningStargateClient } = (await import(\"@cosmjs/stargate\")).default;\n\n return SigningStargateClient.offline(wallet, registry);\n}\n\nexport const getRPC = (chainId: ChainId) => {\n const { isStagenet } = SKConfig.get(\"envs\");\n const rpcUrls = SKConfig.get(\"rpcUrls\");\n\n switch (chainId) {\n case ChainId.Kujira:\n return rpcUrls.KUJI;\n\n case ChainId.THORChain:\n case \"thorchain-mainnet-v1\" as ChainId:\n return isStagenet ? rpcUrls.THOR_STAGENET : rpcUrls.THOR;\n case ChainId.Maya:\n return isStagenet ? rpcUrls.MAYA_STAGENET : rpcUrls.MAYA;\n\n default:\n return rpcUrls.GAIA;\n }\n};\n\nconst getTransferMsgTypeByChain = (chain: CosmosChain) => {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain:\n return \"/types.MsgSend\";\n case Chain.Cosmos:\n case Chain.Kujira:\n return \"/cosmos.bank.v1beta1.MsgSend\";\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\n/**\n * Used to build tx for Cosmos and Kujira\n */\nexport const cosmosCreateTransaction = async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n sequence,\n accountNumber,\n}: CosmosCreateTransactionParams) => {\n const { chain, chainId } = assetValue;\n\n const url = getRPC(chainId);\n const client = await createStargateClient(url);\n const accountOnChain = await client.getAccount(sender);\n\n if (!accountOnChain) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n const gasAsset = AssetValue.from({ chain });\n const feeAsset = getMsgSendDenom(gasAsset.symbol);\n const defaultFee = getDefaultChainFee(chain as CosmosChain);\n\n const txFee =\n feeAsset && feeRate\n ? { amount: [{ denom: feeAsset, amount: feeRate.toString() }], gas: defaultFee.gas }\n : defaultFee;\n\n const msgSend = {\n fromAddress: sender,\n toAddress: recipient,\n amount: [\n { amount: assetValue.getBaseValue(\"string\"), denom: getMsgSendDenom(assetValue.symbol) },\n ],\n };\n\n return {\n accountNumber: accountNumber ?? accountOnChain.accountNumber,\n chainId,\n fee: txFee,\n memo,\n sequence: sequence ?? accountOnChain.sequence,\n msgs: [{ typeUrl: getTransferMsgTypeByChain(chain as CosmosChain), value: msgSend }],\n };\n};\n\n// Map of known denoms to their asset configurations\nconst DENOM_MAP = {\n // THORChain denoms\n rune: { chain: Chain.THORChain, decimals: BaseDecimal[Chain.THORChain] },\n tcy: { asset: \"THOR.TCY\", decimals: BaseDecimal[Chain.THORChain] },\n \"x/kuji\": { asset: \"THOR.KUJI\", decimals: BaseDecimal[Chain.THORChain] },\n\n // Cosmos denoms\n uatom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n atom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n\n // Maya denoms\n cacao: { chain: Chain.Maya, decimals: 10 }, // Maya uses 10 decimals for CACAO\n maya: { asset: `${Chain.Maya}.${Chain.Maya}`, decimals: 4 }, // MAYA token uses 4 decimals\n\n // Kujira denoms\n ukuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n kuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n\n // USK on Kujira (lowercase version of the factory denom)\n [USK_KUJIRA_FACTORY_DENOM.toLowerCase()]: {\n asset: `${Chain.Kujira}.USK`,\n decimals: BaseDecimal[Chain.Kujira],\n },\n};\n\n/**\n * Converts a Cosmos denom and amount to an AssetValue with proper decimal handling\n * @param denom - The denomination string\n * @param amount - The amount in base units as a string\n * @returns AssetValue with the correct decimal conversion\n */\nexport const getAssetFromDenom = (denom: string, amount: string) => {\n const config = DENOM_MAP[denom.toLowerCase()];\n\n if (!config) {\n // For unknown denoms, default to 8 decimals (common for many Cosmos chains)\n // This preserves the original behavior while using fromBaseDecimal\n return AssetValue.from({\n asset: denom,\n value: amount,\n fromBaseDecimal: 8,\n });\n }\n\n const { chain, asset, decimals } = config;\n\n const assetOrChain = (\n chain\n ? {\n chain,\n }\n : { asset }\n ) as { asset: string } | { chain: CosmosChain };\n\n return AssetValue.from({\n ...assetOrChain,\n value: amount,\n fromBaseDecimal: decimals,\n });\n};\n",
7
+ "import type { OfflineSigner } from \"@cosmjs/proto-signing\";\nimport type { SigningStargateClientOptions } from \"@cosmjs/stargate\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n ChainId,\n type CosmosChain,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\n\nimport type { CosmosCreateTransactionParams } from \"./thorchainUtils\";\n\nexport const USK_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1QK00H5ATUTPSV900X202PXX42NPJR9THG58DNQPA72F2P7M2LUASE444A7/UUSK\";\n\nexport const YUM_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1YGFXN0ER40KLCNCK8THLTUPRDXLCK6WVNPKF2K/UYUM\";\n\nexport const DEFAULT_COSMOS_FEE_MAINNET = {\n amount: [{ denom: \"uatom\", amount: \"500\" }],\n gas: \"200000\",\n};\n\nexport const DEFAULT_KUJI_FEE_MAINNET = {\n amount: [{ denom: \"ukuji\", amount: \"1000\" }],\n gas: \"200000\",\n};\n\nexport function getDefaultChainFee(chain: CosmosChain) {\n switch (chain) {\n case Chain.Maya:\n return { amount: [], gas: \"10000000000\" };\n case Chain.THORChain:\n return { amount: [], gas: \"500000000\" };\n case Chain.Kujira:\n return DEFAULT_KUJI_FEE_MAINNET;\n default:\n return DEFAULT_COSMOS_FEE_MAINNET;\n }\n}\n\nexport const getMsgSendDenom = (symbol: string, isThorchain = false) => {\n if (isThorchain) {\n return symbol.toLowerCase();\n }\n\n switch (symbol) {\n case \"uUSK\":\n case \"USK\":\n return USK_KUJIRA_FACTORY_DENOM;\n case \"uYUM\":\n case \"YUM\":\n return YUM_KUJIRA_FACTORY_DENOM;\n case \"uKUJI\":\n case \"KUJI\":\n return \"ukuji\";\n case \"ATOM\":\n case \"uATOM\":\n return \"uatom\";\n default:\n return symbol;\n }\n};\n\nexport const getDenomWithChain = ({ symbol, chain }: AssetValue) => {\n if (chain === Chain.Maya) {\n return (symbol.toUpperCase() !== \"CACAO\" ? symbol : `${Chain.Maya}.${symbol}`).toUpperCase();\n }\n if (chain === Chain.THORChain) {\n return (\n [\"RUNE\", \"TCY\", \"RUJI\"].includes(symbol.toUpperCase())\n ? `${Chain.THORChain}.${symbol}`\n : symbol\n ).toUpperCase();\n }\n return getMsgSendDenom(symbol, false);\n};\n\nexport async function createStargateClient(url: string) {\n const { StargateClient } = await import(\"@cosmjs/stargate\");\n\n const defaultRequestHeaders =\n typeof window !== \"undefined\"\n ? ({} as Record<string, string>)\n : { referrer: \"https://sk.thorswap.net\", referer: \"https://sk.thorswap.net\" };\n\n return StargateClient.connect({\n url,\n headers: defaultRequestHeaders,\n });\n}\n\nexport async function createSigningStargateClient(\n url: string,\n signer: OfflineSigner,\n optionsOrBaseGas: string | SigningStargateClientOptions = {},\n) {\n const { SigningStargateClient, GasPrice } = (await import(\"@cosmjs/stargate\")).default;\n const gasPrice = typeof optionsOrBaseGas === \"string\" ? optionsOrBaseGas : \"0.0003uatom\";\n const options = typeof optionsOrBaseGas === \"string\" ? {} : optionsOrBaseGas;\n\n return SigningStargateClient.connectWithSigner(url, signer, {\n gasPrice: GasPrice.fromString(gasPrice),\n ...options,\n });\n}\n\nexport async function createOfflineStargateClient(\n wallet: OfflineSigner,\n registry?: SigningStargateClientOptions,\n) {\n const { SigningStargateClient } = (await import(\"@cosmjs/stargate\")).default;\n\n return SigningStargateClient.offline(wallet, registry);\n}\n\nexport const getRPC = (chainId: ChainId) => {\n const { isStagenet } = SKConfig.get(\"envs\");\n const rpcUrls = SKConfig.get(\"rpcUrls\");\n\n switch (chainId) {\n case ChainId.Kujira:\n return rpcUrls.KUJI;\n\n case ChainId.THORChain:\n case \"thorchain-mainnet-v1\" as ChainId:\n return isStagenet ? rpcUrls.THOR_STAGENET : rpcUrls.THOR;\n case ChainId.Maya:\n return isStagenet ? rpcUrls.MAYA_STAGENET : rpcUrls.MAYA;\n\n default:\n return rpcUrls.GAIA;\n }\n};\n\nconst getTransferMsgTypeByChain = (chain: CosmosChain) => {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain:\n return \"/types.MsgSend\";\n case Chain.Cosmos:\n case Chain.Kujira:\n return \"/cosmos.bank.v1beta1.MsgSend\";\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\n/**\n * Used to build tx for Cosmos and Kujira\n */\nexport const cosmosCreateTransaction = async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n sequence,\n accountNumber,\n}: CosmosCreateTransactionParams) => {\n const { chain, chainId } = assetValue;\n\n const url = getRPC(chainId);\n const client = await createStargateClient(url);\n const accountOnChain = await client.getAccount(sender);\n\n if (!accountOnChain) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n const gasAsset = AssetValue.from({ chain });\n const feeAsset = getMsgSendDenom(gasAsset.symbol);\n const defaultFee = getDefaultChainFee(chain as CosmosChain);\n\n const txFee =\n feeAsset && feeRate\n ? { amount: [{ denom: feeAsset, amount: feeRate.toString() }], gas: defaultFee.gas }\n : defaultFee;\n\n const msgSend = {\n fromAddress: sender,\n toAddress: recipient,\n amount: [\n { amount: assetValue.getBaseValue(\"string\"), denom: getMsgSendDenom(assetValue.symbol) },\n ],\n };\n\n return {\n accountNumber: accountNumber ?? accountOnChain.accountNumber,\n chainId,\n fee: txFee,\n memo,\n sequence: sequence ?? accountOnChain.sequence,\n msgs: [{ typeUrl: getTransferMsgTypeByChain(chain as CosmosChain), value: msgSend }],\n };\n};\n\n// Map of known denoms to their asset configurations\nconst DENOM_MAP = {\n // THORChain denoms\n rune: { chain: Chain.THORChain, decimals: BaseDecimal[Chain.THORChain] },\n tcy: { asset: \"THOR.TCY\", decimals: BaseDecimal[Chain.THORChain] },\n \"x/kuji\": { asset: \"THOR.KUJI\", decimals: BaseDecimal[Chain.THORChain] },\n\n // Cosmos denoms\n uatom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n atom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n\n // Maya denoms\n cacao: { chain: Chain.Maya, decimals: 10 }, // Maya uses 10 decimals for CACAO\n maya: { asset: `${Chain.Maya}.${Chain.Maya}`, decimals: 4 }, // MAYA token uses 4 decimals\n\n // Kujira denoms\n ukuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n kuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n\n // USK on Kujira (lowercase version of the factory denom)\n [USK_KUJIRA_FACTORY_DENOM.toLowerCase()]: {\n asset: `${Chain.Kujira}.USK`,\n decimals: BaseDecimal[Chain.Kujira],\n },\n};\n\n/**\n * Converts a Cosmos denom and amount to an AssetValue with proper decimal handling\n * @param denom - The denomination string\n * @param amount - The amount in base units as a string\n * @returns AssetValue with the correct decimal conversion\n */\nexport const getAssetFromDenom = (denom: string, amount: string) => {\n const config = DENOM_MAP[denom.toLowerCase()];\n\n if (!config) {\n // For unknown denoms, default to 8 decimals (common for many Cosmos chains)\n // This preserves the original behavior while using fromBaseDecimal\n return AssetValue.from({\n asset: denom,\n value: amount,\n fromBaseDecimal: 8,\n });\n }\n\n const { chain, asset, decimals } = config;\n\n const assetOrChain = (\n chain\n ? {\n chain,\n }\n : { asset }\n ) as { asset: string } | { chain: CosmosChain };\n\n return AssetValue.from({\n ...assetOrChain,\n value: amount,\n fromBaseDecimal: decimals,\n });\n};\n",
8
8
  "import { Chain } from \"@swapkit/helpers\";\nimport { base64ToBech32, bech32ToBase64 } from \"./addressFormat\";\n\nexport async function createDefaultRegistry() {\n const { $root } = await import(\"./types/MsgCompiled\");\n const { Registry } = (await import(\"@cosmjs/proto-signing\")).default;\n const { defaultRegistryTypes } = (await import(\"@cosmjs/stargate\")).default;\n\n return new Registry([\n ...defaultRegistryTypes,\n [\"/types.MsgSend\", $root.types.MsgSend],\n [\"/types.MsgDeposit\", $root.types.MsgDeposit],\n ]);\n}\n\nexport async function createDefaultAminoTypes(chain: Chain.THORChain | Chain.Maya) {\n const { AminoTypes } = (await import(\"@cosmjs/stargate\")).default;\n const aminoTypePrefix = chain === Chain.THORChain ? \"thorchain\" : \"mayachain\";\n\n return new AminoTypes({\n \"/types.MsgSend\": {\n aminoType: `${aminoTypePrefix}/MsgSend`,\n toAmino: ({ fromAddress, toAddress, ...rest }: any) => ({\n ...rest,\n from_address: base64ToBech32(fromAddress),\n to_address: base64ToBech32(toAddress),\n }),\n fromAmino: ({ from_address, to_address, ...rest }: any) => ({\n ...rest,\n fromAddress: bech32ToBase64(from_address),\n toAddress: bech32ToBase64(to_address),\n }),\n },\n \"/types.MsgDeposit\": {\n aminoType: `${aminoTypePrefix}/MsgDeposit`,\n toAmino: ({ signer, ...rest }: any) => ({ ...rest, signer: base64ToBech32(signer) }),\n fromAmino: ({ signer, ...rest }: any) => ({ ...rest, signer: bech32ToBase64(signer) }),\n },\n });\n}\n",
9
9
  "import { Chain, type CosmosChain, SwapKitError } from \"@swapkit/helpers\";\n\nimport type { CosmosToolboxParams } from \"../types\";\nimport { createCosmosToolbox } from \"./cosmos\";\nimport { createThorchainToolbox } from \"./thorchain\";\n\nexport type CosmosToolboxes = {\n GAIA: ReturnType<typeof createCosmosToolbox>;\n KUJI: ReturnType<typeof createCosmosToolbox>;\n MAYA: ReturnType<typeof createThorchainToolbox>;\n THOR: ReturnType<typeof createThorchainToolbox>;\n};\n\nexport const getCosmosToolbox = <T extends CosmosChain>(\n chain: T,\n params?: Omit<CosmosToolboxParams, \"chain\">,\n): CosmosToolboxes[T] => {\n switch (chain) {\n case Chain.Cosmos:\n case Chain.Kujira:\n return createCosmosToolbox({ chain, ...params }) as CosmosToolboxes[T];\n\n case Chain.Maya:\n case Chain.THORChain:\n return createThorchainToolbox({ chain, ...params }) as CosmosToolboxes[T];\n\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\nexport * from \"./cosmos\";\nexport * from \"./thorchain\";\n",
10
10
  "import type { StdFee } from \"@cosmjs/amino\";\nimport type { Account } from \"@cosmjs/stargate\";\nimport { base64, bech32 } from \"@scure/base\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n type ChainId,\n ChainToChainId,\n type CosmosChain,\n CosmosChainPrefixes,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type GenericTransferParams,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n SwapKitNumber,\n applyFeeMultiplier,\n derivationPathToString,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { SwapKitApi } from \"@swapkit/helpers/api\";\nimport { P, match } from \"ts-pattern\";\nimport type { CosmosToolboxParams } from \"../types\";\nimport {\n cosmosCreateTransaction,\n createSigningStargateClient,\n createStargateClient,\n getAssetFromDenom,\n getDenomWithChain,\n getMsgSendDenom,\n} from \"../util\";\n\nexport async function fetchFeeRateFromSwapKit(chainId: ChainId, safeDefault: number) {\n try {\n const response = await SwapKitApi.getGasRate();\n const responseGasRate = response.find((gas) => gas.chainId === chainId)?.value;\n\n return responseGasRate ? Number.parseFloat(responseGasRate) : safeDefault;\n } catch (_e) {\n return safeDefault;\n }\n}\n\nexport async function getSignerFromPhrase({\n phrase,\n prefix,\n ...derivationParams\n}: { phrase: string; prefix?: string } & (\n | { chain: Chain; index?: number }\n | { derivationPath: string }\n)) {\n const { DirectSecp256k1HdWallet } = (await import(\"@cosmjs/proto-signing\")).default;\n const { stringToPath } = (await import(\"@cosmjs/crypto\")).default;\n\n const derivationPath =\n \"derivationPath\" in derivationParams\n ? derivationParams.derivationPath\n : `${DerivationPath[derivationParams.chain]}/${derivationParams.index}`;\n\n return DirectSecp256k1HdWallet.fromMnemonic(phrase, {\n prefix,\n hdPaths: [stringToPath(derivationPath)],\n });\n}\n\nexport async function getSignerFromPrivateKey({\n privateKey,\n prefix,\n}: {\n privateKey: Uint8Array;\n prefix: string;\n}) {\n const { DirectSecp256k1Wallet } = (await import(\"@cosmjs/proto-signing\")).default;\n\n return DirectSecp256k1Wallet.fromKey(privateKey, prefix);\n}\n\nconst SafeDefaultFeeValues = {\n [Chain.Cosmos]: 500,\n [Chain.Kujira]: 1000,\n [Chain.THORChain]: 5000000,\n [Chain.Maya]: 5000000,\n};\n\nexport function verifySignature(getAccount: (address: string) => Promise<Account | null>) {\n return async function verifySignature({\n signature,\n message,\n address,\n }: {\n signature: string;\n message: string;\n address: string;\n }) {\n const account = await getAccount(address);\n if (!account?.pubkey) throw new SwapKitError(\"toolbox_cosmos_verify_signature_no_pubkey\");\n const { Secp256k1Signature, Secp256k1 } = (await import(\"@cosmjs/crypto\")).default;\n\n const secpSignature = Secp256k1Signature.fromFixedLength(base64.decode(signature));\n return Secp256k1.verifySignature(secpSignature, base64.decode(message), account.pubkey.value);\n };\n}\n\nexport async function createCosmosToolbox({ chain, ...toolboxParams }: CosmosToolboxParams) {\n const rpcUrl = SKConfig.get(\"rpcUrls\")[chain];\n const chainPrefix = CosmosChainPrefixes[chain];\n\n const index = \"index\" in toolboxParams ? toolboxParams.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in toolboxParams && toolboxParams.derivationPath\n ? toolboxParams.derivationPath\n : updateDerivationPath(NetworkDerivationPath[chain], { index }),\n );\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, ({ phrase }) =>\n getSignerFromPhrase({ phrase, prefix: chainPrefix, derivationPath }),\n )\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n async function getAccount(address: string) {\n const client = await createStargateClient(rpcUrl);\n return client.getAccount(address);\n }\n\n async function getAddress() {\n const [account] = (await signer?.getAccounts()) || [];\n return account?.address;\n }\n\n async function getPubKey() {\n const [account] = (await signer?.getAccounts()) || [];\n if (!account?.pubkey) {\n throw new SwapKitError(\"toolbox_cosmos_signer_not_defined\");\n }\n return base64.encode(account?.pubkey);\n }\n\n async function transfer({\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n feeOptionKey = FeeOption.Fast,\n }: GenericTransferParams) {\n const from = await getAddress();\n\n if (!(signer && from)) {\n throw new SwapKitError(\"toolbox_cosmos_signer_not_defined\");\n }\n\n const feeAssetValue = AssetValue.from({\n chain,\n });\n const assetDenom = getDenomWithChain(feeAssetValue);\n\n const txFee =\n feeRate ||\n feeToStdFee((await getFees(chain, SafeDefaultFeeValues[chain]))[feeOptionKey], assetDenom);\n\n const signingClient = await createSigningStargateClient(rpcUrl, signer);\n const message = [\n {\n denom: getMsgSendDenom(`u${assetValue.symbol}`).toLowerCase(),\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await signingClient.sendTokens(\n from,\n recipient,\n message,\n txFee,\n memo,\n );\n\n return transactionHash;\n }\n\n return {\n transfer,\n getAddress,\n getAccount,\n getBalance: async (address: string, _potentialScamFilter?: boolean) => {\n const denomBalances = await cosmosBalanceDenomsGetter(rpcUrl)(address);\n return await Promise.all(\n denomBalances\n .filter(({ denom }) => denom && !denom.includes(\"IBC/\"))\n .map(({ denom, amount }) => {\n const fullDenom =\n [Chain.THORChain, Chain.Maya].includes(chain) &&\n (denom.includes(\"/\") || denom.includes(\"˜\"))\n ? `${chain}.${denom}`\n : denom;\n return getAssetFromDenom(fullDenom, amount);\n }),\n );\n },\n getSignerFromPhrase: async ({\n phrase,\n derivationPath,\n }: { phrase: string; derivationPath: DerivationPathArray }) =>\n getSignerFromPhrase({\n phrase,\n prefix: chainPrefix,\n derivationPath: derivationPathToString(derivationPath),\n index,\n }),\n getSignerFromPrivateKey: async (privateKey: Uint8Array) => {\n const { DirectSecp256k1Wallet } = (await import(\"@cosmjs/proto-signing\")).default;\n return DirectSecp256k1Wallet.fromKey(privateKey, chainPrefix);\n },\n createPrivateKeyFromPhrase: createPrivateKeyFromPhrase(derivationPath),\n validateAddress: getCosmosValidateAddress(chainPrefix),\n getPubKey,\n getFees: () => getFees(chain, SafeDefaultFeeValues[chain]),\n fetchFeeRateFromSwapKit,\n getBalanceAsDenoms: cosmosBalanceDenomsGetter(rpcUrl),\n createTransaction: cosmosCreateTransaction,\n verifySignature: verifySignature(getAccount),\n };\n}\n\nexport async function getFeeRateFromThorswap(chainId: ChainId, safeDefault: number) {\n try {\n const response = await SwapKitApi.getGasRate();\n const responseGasRate = response.find((gas) => gas.chainId === chainId)?.value;\n\n return responseGasRate ? Number.parseFloat(responseGasRate) : safeDefault;\n } catch (_e) {\n return safeDefault;\n }\n}\n\nexport function cosmosValidateAddress({\n address,\n chain,\n prefix: chainPrefix,\n}: { address: string } & (\n | { prefix: string; chain?: undefined }\n | { chain: CosmosChain; prefix?: undefined }\n)) {\n const prefix = chainPrefix || getPrefix(chain);\n\n if (!(prefix && address)) {\n throw new SwapKitError(\"toolbox_cosmos_validate_address_prefix_not_found\");\n }\n\n return getCosmosValidateAddress(prefix)(address);\n}\n\nexport function estimateTransactionFee({\n assetValue: { chain },\n}: {\n assetValue: AssetValue;\n}) {\n return AssetValue.from({ chain, value: getMinTransactionFee(chain) });\n}\n\nfunction getPrefix<C extends CosmosChain>(chain?: C) {\n const { isStagenet } = SKConfig.get(\"envs\");\n const useStagenetPrefix = chain\n ? [Chain.THORChain, Chain.Maya].includes(chain) && isStagenet\n : false;\n const basePrefix = chain ? CosmosChainPrefixes[chain] : undefined;\n\n return useStagenetPrefix ? `s${basePrefix}` : basePrefix;\n}\n\nasync function getFees(chain: Chain, safeDefault: number) {\n const baseFee = await fetchFeeRateFromSwapKit(ChainToChainId[chain], safeDefault);\n return {\n average: SwapKitNumber.fromBigInt(BigInt(baseFee), BaseDecimal[chain]),\n fast: SwapKitNumber.fromBigInt(\n BigInt(applyFeeMultiplier(baseFee, FeeOption.Fast, true)),\n BaseDecimal[chain],\n ),\n fastest: SwapKitNumber.fromBigInt(\n BigInt(applyFeeMultiplier(baseFee, FeeOption.Fastest, true)),\n BaseDecimal[chain],\n ),\n } as { [key in FeeOption]: SwapKitNumber };\n}\n\nfunction feeToStdFee(fee: SwapKitNumber, denom: string): StdFee {\n return {\n amount: [{ denom, amount: fee.getBaseValue(\"string\") }],\n gas: \"200000\",\n };\n}\n\nfunction getMinTransactionFee(chain: Chain) {\n return (\n {\n [Chain.Cosmos]: 0.007,\n [Chain.Kujira]: 0.02,\n [Chain.THORChain]: 0.02,\n [Chain.Maya]: 0.02,\n }[chain as CosmosChain] || 0\n );\n}\n\nfunction getCosmosValidateAddress(prefix: string) {\n return function validateAddress(address: string) {\n if (!address.startsWith(prefix)) return false;\n\n try {\n const { prefix, words } = bech32.decode(address as `${string}1${string}`);\n const normalized = bech32.encode(prefix, words);\n\n return normalized === address.toLocaleLowerCase();\n } catch (_error) {\n return false;\n }\n };\n}\n\nfunction cosmosBalanceDenomsGetter(rpcUrl: string) {\n return async function getCosmosBalanceDenoms(address: string) {\n const client = await createStargateClient(rpcUrl);\n const allBalances = await client.getAllBalances(address);\n\n const balances = allBalances.map((balance) => ({\n ...balance,\n denom: balance.denom.includes(\"/\") ? balance.denom.toUpperCase() : balance.denom,\n }));\n\n return balances;\n };\n}\n\nfunction createPrivateKeyFromPhrase(derivationPath: string) {\n return async function createPrivateKeyFromPhrase(phrase: string) {\n const { Bip39, EnglishMnemonic, Slip10, Slip10Curve, stringToPath } = (\n await import(\"@cosmjs/crypto\")\n ).default;\n\n const mnemonicChecked = new EnglishMnemonic(phrase);\n const seed = await Bip39.mnemonicToSeed(mnemonicChecked);\n\n const { privkey } = Slip10.derivePath(\n Slip10Curve.Secp256k1,\n seed,\n stringToPath(derivationPath),\n );\n\n return privkey;\n };\n}\n",
@@ -4,7 +4,7 @@
4
4
  "sourcesContent": [
5
5
  "import { base64, bech32 } from \"@scure/base\";\nimport { SwapKitError } from \"@swapkit/helpers\";\nimport { fromByteArray, toByteArray } from \"base64-js\";\n\nexport function bech32ToBase64(address: string) {\n return base64.encode(\n Uint8Array.from(bech32.fromWords(bech32.decode(address as `${string}1${string}`).words)),\n );\n}\n\nexport function base64ToBech32(address: string, prefix = \"thor\") {\n return bech32.encode(prefix, bech32.toWords(base64.decode(address)));\n}\n\nexport function toBase64(data: Uint8Array) {\n return fromByteArray(data);\n}\n\nexport function fromBase64(base64String: string) {\n if (!base64String.match(/^[a-zA-Z0-9+/]*={0,2}$/)) {\n throw new SwapKitError(\"toolbox_cosmos_invalid_params\", {\n error: \"Invalid base64 string format\",\n });\n }\n return toByteArray(base64String);\n}\n",
6
6
  "import type { TxBodyEncodeObject } from \"@cosmjs/proto-signing\";\nimport { AssetValue, Chain, ChainToChainId, SwapKitError } from \"@swapkit/helpers\";\n\nimport {\n createStargateClient,\n getDefaultChainFee,\n getDenomWithChain,\n getMsgSendDenom,\n} from \"../util\";\n\nimport { createDefaultAminoTypes, createDefaultRegistry } from \"./registry\";\nimport type { ThorchainCreateTransactionParams } from \"./types\";\n\ntype MsgSend = ReturnType<typeof transferMsgAmino>;\ntype MsgDeposit = ReturnType<typeof depositMsgAmino>;\ntype DirectMsgSendForBroadcast = ReturnType<typeof parseAminoMessageForDirectSigning<MsgSend>>;\ntype DirectMsgDepositForBroadcast = ReturnType<\n typeof parseAminoMessageForDirectSigning<MsgDeposit>\n>;\n\nexport const THORCHAIN_GAS_VALUE = getDefaultChainFee(Chain.THORChain).gas;\nexport const MAYA_GAS_VALUE = getDefaultChainFee(Chain.Maya).gas;\n\nexport const transferMsgAmino = ({\n sender,\n recipient,\n assetValue,\n}: {\n sender: string;\n recipient?: string;\n assetValue: AssetValue;\n}) => {\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n return {\n type: `${chain === Chain.Maya ? \"mayachain\" : \"thorchain\"}/MsgSend` as const,\n value: {\n from_address: sender,\n to_address: recipient,\n amount: [\n {\n amount: assetValue.getBaseValue(\"string\"),\n denom: getMsgSendDenom(assetValue.symbol, true),\n },\n ],\n },\n };\n};\n\nexport const depositMsgAmino = ({\n sender,\n assetValue,\n memo = \"\",\n}: {\n sender: string;\n assetValue: AssetValue;\n memo?: string;\n}) => {\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n return {\n type: `${chain === Chain.Maya ? \"mayachain\" : \"thorchain\"}/MsgDeposit` as const,\n value: {\n coins: [\n {\n amount: assetValue.getBaseValue(\"string\"),\n asset: getDenomWithChain(assetValue),\n },\n ],\n signer: sender,\n memo,\n },\n };\n};\n\nexport const buildAminoMsg = ({\n sender,\n recipient,\n assetValue,\n memo,\n}: {\n sender: string;\n recipient?: string;\n assetValue: AssetValue;\n memo?: string;\n}) => {\n const isDeposit = !recipient;\n const msg = isDeposit\n ? depositMsgAmino({ sender, assetValue, memo })\n : transferMsgAmino({ sender, recipient, assetValue });\n\n return msg;\n};\n\nexport const convertToSignable = async (\n msg: MsgSend | MsgDeposit,\n chain: Chain.THORChain | Chain.Maya,\n) => {\n const aminoTypes = await createDefaultAminoTypes(chain);\n\n return aminoTypes.fromAmino(msg);\n};\n\nconst getAccount = async ({ rpcUrl, sender }: { sender: string; rpcUrl: string }) => {\n const client = await createStargateClient(rpcUrl);\n const account = await client.getAccount(sender);\n\n if (!account) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n return account;\n};\n\nexport function getCreateTransaction(rpcUrl: string) {\n return function createTransaction(params: ThorchainCreateTransactionParams) {\n const { assetValue, recipient, memo, sender, asSignable, asAminoMessage } = params;\n\n if (recipient) {\n return buildTransferTx(rpcUrl)({\n sender,\n recipient,\n assetValue,\n memo,\n asSignable,\n asAminoMessage,\n });\n }\n\n return buildDepositTx(rpcUrl)({\n sender,\n assetValue,\n memo,\n asSignable,\n asAminoMessage,\n });\n };\n}\n\nexport const buildTransferTx =\n (rpcUrl: string) =>\n async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n asSignable = true,\n asAminoMessage = false,\n sequence,\n accountNumber,\n }: ThorchainCreateTransactionParams) => {\n const account = await getAccount({ rpcUrl, sender });\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n\n const transferMsg = transferMsgAmino({\n sender,\n recipient,\n assetValue,\n });\n\n const msg = asSignable\n ? await convertToSignable(\n asAminoMessage ? transferMsg : parseAminoMessageForDirectSigning(transferMsg),\n chain,\n )\n : transferMsg;\n\n const transaction = {\n chainId: ChainToChainId[chain],\n accountNumber: accountNumber || account.accountNumber,\n sequence: sequence || account.sequence,\n msgs: [msg],\n fee: getDefaultChainFee(assetValue.chain as Chain.THORChain | Chain.Maya),\n memo,\n };\n\n return transaction;\n };\n\nexport const buildDepositTx =\n (rpcUrl: string) =>\n async ({\n sender,\n assetValue,\n memo = \"\",\n asSignable = true,\n asAminoMessage = false,\n sequence,\n accountNumber,\n }: ThorchainCreateTransactionParams) => {\n const account = await getAccount({ rpcUrl, sender });\n const chain = assetValue.chain as Chain.THORChain | Chain.Maya;\n\n const depositMsg = depositMsgAmino({ sender, assetValue, memo });\n\n const msg = asSignable\n ? await convertToSignable(\n asAminoMessage ? depositMsg : parseAminoMessageForDirectSigning<MsgDeposit>(depositMsg),\n chain,\n )\n : depositMsg;\n\n const transaction = {\n chainId: ChainToChainId[chain],\n accountNumber: accountNumber || account.accountNumber,\n sequence: sequence || account.sequence,\n msgs: [msg],\n fee: getDefaultChainFee(assetValue.chain as Chain.THORChain | Chain.Maya),\n memo,\n };\n\n return transaction;\n };\n\nexport function parseAminoMessageForDirectSigning<T extends MsgDeposit | MsgSend>(msg: T) {\n if (msg.type === \"thorchain/MsgSend\" || msg.type === \"mayachain/MsgSend\") return msg as MsgSend;\n\n return {\n ...msg,\n value: {\n ...msg.value,\n coins: (msg as MsgDeposit).value.coins.map((coin: { asset: string; amount: string }) => {\n const assetValue = AssetValue.from({ asset: coin.asset });\n\n const symbol = (\n assetValue.isSynthetic ? assetValue.symbol.split(\"/\")?.[1] : assetValue.symbol\n )?.toUpperCase();\n const chain = (\n assetValue.isSynthetic ? assetValue.symbol.split(\"/\")?.[0] : assetValue.chain\n )?.toUpperCase();\n\n return {\n ...coin,\n asset: {\n chain,\n symbol,\n ticker: assetValue.ticker,\n synth: assetValue.isSynthetic,\n },\n };\n }),\n },\n };\n}\n\nexport async function buildEncodedTxBody({\n chain,\n memo,\n msgs,\n}: {\n msgs: DirectMsgDepositForBroadcast[] | DirectMsgSendForBroadcast[];\n memo: string;\n chain: Chain.THORChain | Chain.Maya;\n}) {\n const registry = await createDefaultRegistry();\n const aminoTypes = await createDefaultAminoTypes(chain);\n\n const signedTxBody: TxBodyEncodeObject = {\n typeUrl: \"/cosmos.tx.v1beta1.TxBody\",\n value: { memo, messages: msgs.map((msg) => aminoTypes.fromAmino(msg)) },\n };\n\n return registry.encode(signedTxBody);\n}\n",
7
- "import type { OfflineSigner } from \"@cosmjs/proto-signing\";\nimport type { SigningStargateClientOptions } from \"@cosmjs/stargate\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n ChainId,\n type CosmosChain,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\n\nimport type { CosmosCreateTransactionParams } from \"./thorchainUtils\";\n\nexport const USK_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1QK00H5ATUTPSV900X202PXX42NPJR9THG58DNQPA72F2P7M2LUASE444A7/UUSK\";\n\nexport const YUM_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1YGFXN0ER40KLCNCK8THLTUPRDXLCK6WVNPKF2K/UYUM\";\n\nexport const DEFAULT_COSMOS_FEE_MAINNET = {\n amount: [{ denom: \"uatom\", amount: \"500\" }],\n gas: \"200000\",\n};\n\nexport const DEFAULT_KUJI_FEE_MAINNET = {\n amount: [{ denom: \"ukuji\", amount: \"1000\" }],\n gas: \"200000\",\n};\n\nexport function getDefaultChainFee(chain: CosmosChain) {\n switch (chain) {\n case Chain.Maya:\n return { amount: [], gas: \"10000000000\" };\n case Chain.THORChain:\n return { amount: [], gas: \"500000000\" };\n case Chain.Kujira:\n return DEFAULT_KUJI_FEE_MAINNET;\n default:\n return DEFAULT_COSMOS_FEE_MAINNET;\n }\n}\n\nexport const getMsgSendDenom = (symbol: string, isThorchain = false) => {\n if (isThorchain) {\n return symbol.toLowerCase();\n }\n\n switch (symbol) {\n case \"uUSK\":\n case \"USK\":\n return USK_KUJIRA_FACTORY_DENOM;\n case \"uYUM\":\n case \"YUM\":\n return YUM_KUJIRA_FACTORY_DENOM;\n case \"uKUJI\":\n case \"KUJI\":\n return \"ukuji\";\n case \"ATOM\":\n case \"uATOM\":\n return \"uatom\";\n default:\n return symbol;\n }\n};\n\nexport const getDenomWithChain = ({ symbol, chain }: AssetValue) => {\n if (chain === Chain.Maya) {\n return (symbol.toUpperCase() !== \"CACAO\" ? symbol : `${Chain.Maya}.${symbol}`).toUpperCase();\n }\n if (chain === Chain.THORChain) {\n return (\n [\"RUNE\", \"TCY\", \"RUJI\"].includes(symbol.toUpperCase())\n ? `${Chain.THORChain}.${symbol}`\n : symbol\n ).toUpperCase();\n }\n return getMsgSendDenom(symbol, false);\n};\n\nexport async function createStargateClient(url: string) {\n const { StargateClient } = await import(\"@cosmjs/stargate\");\n\n const defaultRequestHeaders =\n typeof window !== \"undefined\"\n ? ({} as Record<string, string>)\n : { referrer: \"https://sk.thorswap.net\", referer: \"https://sk.thorswap.net\" };\n\n return StargateClient.connect({\n url,\n headers: defaultRequestHeaders,\n });\n}\n\nexport async function createSigningStargateClient(\n url: string,\n signer: any,\n optionsOrBaseGas: string | SigningStargateClientOptions = {},\n) {\n const { SigningStargateClient, GasPrice } = (await import(\"@cosmjs/stargate\")).default;\n const gasPrice = typeof optionsOrBaseGas === \"string\" ? optionsOrBaseGas : \"0.0003uatom\";\n const options = typeof optionsOrBaseGas === \"string\" ? {} : optionsOrBaseGas;\n\n return SigningStargateClient.connectWithSigner(url, signer, {\n gasPrice: GasPrice.fromString(gasPrice),\n ...options,\n });\n}\n\nexport async function createOfflineStargateClient(\n wallet: OfflineSigner,\n registry?: SigningStargateClientOptions,\n) {\n const { SigningStargateClient } = (await import(\"@cosmjs/stargate\")).default;\n\n return SigningStargateClient.offline(wallet, registry);\n}\n\nexport const getRPC = (chainId: ChainId) => {\n const { isStagenet } = SKConfig.get(\"envs\");\n const rpcUrls = SKConfig.get(\"rpcUrls\");\n\n switch (chainId) {\n case ChainId.Kujira:\n return rpcUrls.KUJI;\n\n case ChainId.THORChain:\n case \"thorchain-mainnet-v1\" as ChainId:\n return isStagenet ? rpcUrls.THOR_STAGENET : rpcUrls.THOR;\n case ChainId.Maya:\n return isStagenet ? rpcUrls.MAYA_STAGENET : rpcUrls.MAYA;\n\n default:\n return rpcUrls.GAIA;\n }\n};\n\nconst getTransferMsgTypeByChain = (chain: CosmosChain) => {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain:\n return \"/types.MsgSend\";\n case Chain.Cosmos:\n case Chain.Kujira:\n return \"/cosmos.bank.v1beta1.MsgSend\";\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\n/**\n * Used to build tx for Cosmos and Kujira\n */\nexport const cosmosCreateTransaction = async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n sequence,\n accountNumber,\n}: CosmosCreateTransactionParams) => {\n const { chain, chainId } = assetValue;\n\n const url = getRPC(chainId);\n const client = await createStargateClient(url);\n const accountOnChain = await client.getAccount(sender);\n\n if (!accountOnChain) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n const gasAsset = AssetValue.from({ chain });\n const feeAsset = getMsgSendDenom(gasAsset.symbol);\n const defaultFee = getDefaultChainFee(chain as CosmosChain);\n\n const txFee =\n feeAsset && feeRate\n ? { amount: [{ denom: feeAsset, amount: feeRate.toString() }], gas: defaultFee.gas }\n : defaultFee;\n\n const msgSend = {\n fromAddress: sender,\n toAddress: recipient,\n amount: [\n { amount: assetValue.getBaseValue(\"string\"), denom: getMsgSendDenom(assetValue.symbol) },\n ],\n };\n\n return {\n accountNumber: accountNumber ?? accountOnChain.accountNumber,\n chainId,\n fee: txFee,\n memo,\n sequence: sequence ?? accountOnChain.sequence,\n msgs: [{ typeUrl: getTransferMsgTypeByChain(chain as CosmosChain), value: msgSend }],\n };\n};\n\n// Map of known denoms to their asset configurations\nconst DENOM_MAP = {\n // THORChain denoms\n rune: { chain: Chain.THORChain, decimals: BaseDecimal[Chain.THORChain] },\n tcy: { asset: \"THOR.TCY\", decimals: BaseDecimal[Chain.THORChain] },\n \"x/kuji\": { asset: \"THOR.KUJI\", decimals: BaseDecimal[Chain.THORChain] },\n\n // Cosmos denoms\n uatom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n atom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n\n // Maya denoms\n cacao: { chain: Chain.Maya, decimals: 10 }, // Maya uses 10 decimals for CACAO\n maya: { asset: `${Chain.Maya}.${Chain.Maya}`, decimals: 4 }, // MAYA token uses 4 decimals\n\n // Kujira denoms\n ukuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n kuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n\n // USK on Kujira (lowercase version of the factory denom)\n [USK_KUJIRA_FACTORY_DENOM.toLowerCase()]: {\n asset: `${Chain.Kujira}.USK`,\n decimals: BaseDecimal[Chain.Kujira],\n },\n};\n\n/**\n * Converts a Cosmos denom and amount to an AssetValue with proper decimal handling\n * @param denom - The denomination string\n * @param amount - The amount in base units as a string\n * @returns AssetValue with the correct decimal conversion\n */\nexport const getAssetFromDenom = (denom: string, amount: string) => {\n const config = DENOM_MAP[denom.toLowerCase()];\n\n if (!config) {\n // For unknown denoms, default to 8 decimals (common for many Cosmos chains)\n // This preserves the original behavior while using fromBaseDecimal\n return AssetValue.from({\n asset: denom,\n value: amount,\n fromBaseDecimal: 8,\n });\n }\n\n const { chain, asset, decimals } = config;\n\n const assetOrChain = (\n chain\n ? {\n chain,\n }\n : { asset }\n ) as { asset: string } | { chain: CosmosChain };\n\n return AssetValue.from({\n ...assetOrChain,\n value: amount,\n fromBaseDecimal: decimals,\n });\n};\n",
7
+ "import type { OfflineSigner } from \"@cosmjs/proto-signing\";\nimport type { SigningStargateClientOptions } from \"@cosmjs/stargate\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n ChainId,\n type CosmosChain,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\n\nimport type { CosmosCreateTransactionParams } from \"./thorchainUtils\";\n\nexport const USK_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1QK00H5ATUTPSV900X202PXX42NPJR9THG58DNQPA72F2P7M2LUASE444A7/UUSK\";\n\nexport const YUM_KUJIRA_FACTORY_DENOM =\n \"FACTORY/KUJIRA1YGFXN0ER40KLCNCK8THLTUPRDXLCK6WVNPKF2K/UYUM\";\n\nexport const DEFAULT_COSMOS_FEE_MAINNET = {\n amount: [{ denom: \"uatom\", amount: \"500\" }],\n gas: \"200000\",\n};\n\nexport const DEFAULT_KUJI_FEE_MAINNET = {\n amount: [{ denom: \"ukuji\", amount: \"1000\" }],\n gas: \"200000\",\n};\n\nexport function getDefaultChainFee(chain: CosmosChain) {\n switch (chain) {\n case Chain.Maya:\n return { amount: [], gas: \"10000000000\" };\n case Chain.THORChain:\n return { amount: [], gas: \"500000000\" };\n case Chain.Kujira:\n return DEFAULT_KUJI_FEE_MAINNET;\n default:\n return DEFAULT_COSMOS_FEE_MAINNET;\n }\n}\n\nexport const getMsgSendDenom = (symbol: string, isThorchain = false) => {\n if (isThorchain) {\n return symbol.toLowerCase();\n }\n\n switch (symbol) {\n case \"uUSK\":\n case \"USK\":\n return USK_KUJIRA_FACTORY_DENOM;\n case \"uYUM\":\n case \"YUM\":\n return YUM_KUJIRA_FACTORY_DENOM;\n case \"uKUJI\":\n case \"KUJI\":\n return \"ukuji\";\n case \"ATOM\":\n case \"uATOM\":\n return \"uatom\";\n default:\n return symbol;\n }\n};\n\nexport const getDenomWithChain = ({ symbol, chain }: AssetValue) => {\n if (chain === Chain.Maya) {\n return (symbol.toUpperCase() !== \"CACAO\" ? symbol : `${Chain.Maya}.${symbol}`).toUpperCase();\n }\n if (chain === Chain.THORChain) {\n return (\n [\"RUNE\", \"TCY\", \"RUJI\"].includes(symbol.toUpperCase())\n ? `${Chain.THORChain}.${symbol}`\n : symbol\n ).toUpperCase();\n }\n return getMsgSendDenom(symbol, false);\n};\n\nexport async function createStargateClient(url: string) {\n const { StargateClient } = await import(\"@cosmjs/stargate\");\n\n const defaultRequestHeaders =\n typeof window !== \"undefined\"\n ? ({} as Record<string, string>)\n : { referrer: \"https://sk.thorswap.net\", referer: \"https://sk.thorswap.net\" };\n\n return StargateClient.connect({\n url,\n headers: defaultRequestHeaders,\n });\n}\n\nexport async function createSigningStargateClient(\n url: string,\n signer: OfflineSigner,\n optionsOrBaseGas: string | SigningStargateClientOptions = {},\n) {\n const { SigningStargateClient, GasPrice } = (await import(\"@cosmjs/stargate\")).default;\n const gasPrice = typeof optionsOrBaseGas === \"string\" ? optionsOrBaseGas : \"0.0003uatom\";\n const options = typeof optionsOrBaseGas === \"string\" ? {} : optionsOrBaseGas;\n\n return SigningStargateClient.connectWithSigner(url, signer, {\n gasPrice: GasPrice.fromString(gasPrice),\n ...options,\n });\n}\n\nexport async function createOfflineStargateClient(\n wallet: OfflineSigner,\n registry?: SigningStargateClientOptions,\n) {\n const { SigningStargateClient } = (await import(\"@cosmjs/stargate\")).default;\n\n return SigningStargateClient.offline(wallet, registry);\n}\n\nexport const getRPC = (chainId: ChainId) => {\n const { isStagenet } = SKConfig.get(\"envs\");\n const rpcUrls = SKConfig.get(\"rpcUrls\");\n\n switch (chainId) {\n case ChainId.Kujira:\n return rpcUrls.KUJI;\n\n case ChainId.THORChain:\n case \"thorchain-mainnet-v1\" as ChainId:\n return isStagenet ? rpcUrls.THOR_STAGENET : rpcUrls.THOR;\n case ChainId.Maya:\n return isStagenet ? rpcUrls.MAYA_STAGENET : rpcUrls.MAYA;\n\n default:\n return rpcUrls.GAIA;\n }\n};\n\nconst getTransferMsgTypeByChain = (chain: CosmosChain) => {\n switch (chain) {\n case Chain.Maya:\n case Chain.THORChain:\n return \"/types.MsgSend\";\n case Chain.Cosmos:\n case Chain.Kujira:\n return \"/cosmos.bank.v1beta1.MsgSend\";\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\n/**\n * Used to build tx for Cosmos and Kujira\n */\nexport const cosmosCreateTransaction = async ({\n sender,\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n sequence,\n accountNumber,\n}: CosmosCreateTransactionParams) => {\n const { chain, chainId } = assetValue;\n\n const url = getRPC(chainId);\n const client = await createStargateClient(url);\n const accountOnChain = await client.getAccount(sender);\n\n if (!accountOnChain) {\n throw new SwapKitError(\"toolbox_cosmos_account_not_found\", { sender });\n }\n\n const gasAsset = AssetValue.from({ chain });\n const feeAsset = getMsgSendDenom(gasAsset.symbol);\n const defaultFee = getDefaultChainFee(chain as CosmosChain);\n\n const txFee =\n feeAsset && feeRate\n ? { amount: [{ denom: feeAsset, amount: feeRate.toString() }], gas: defaultFee.gas }\n : defaultFee;\n\n const msgSend = {\n fromAddress: sender,\n toAddress: recipient,\n amount: [\n { amount: assetValue.getBaseValue(\"string\"), denom: getMsgSendDenom(assetValue.symbol) },\n ],\n };\n\n return {\n accountNumber: accountNumber ?? accountOnChain.accountNumber,\n chainId,\n fee: txFee,\n memo,\n sequence: sequence ?? accountOnChain.sequence,\n msgs: [{ typeUrl: getTransferMsgTypeByChain(chain as CosmosChain), value: msgSend }],\n };\n};\n\n// Map of known denoms to their asset configurations\nconst DENOM_MAP = {\n // THORChain denoms\n rune: { chain: Chain.THORChain, decimals: BaseDecimal[Chain.THORChain] },\n tcy: { asset: \"THOR.TCY\", decimals: BaseDecimal[Chain.THORChain] },\n \"x/kuji\": { asset: \"THOR.KUJI\", decimals: BaseDecimal[Chain.THORChain] },\n\n // Cosmos denoms\n uatom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n atom: { chain: Chain.Cosmos, decimals: BaseDecimal[Chain.Cosmos] },\n\n // Maya denoms\n cacao: { chain: Chain.Maya, decimals: 10 }, // Maya uses 10 decimals for CACAO\n maya: { asset: `${Chain.Maya}.${Chain.Maya}`, decimals: 4 }, // MAYA token uses 4 decimals\n\n // Kujira denoms\n ukuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n kuji: { chain: Chain.Kujira, decimals: BaseDecimal[Chain.Kujira] },\n\n // USK on Kujira (lowercase version of the factory denom)\n [USK_KUJIRA_FACTORY_DENOM.toLowerCase()]: {\n asset: `${Chain.Kujira}.USK`,\n decimals: BaseDecimal[Chain.Kujira],\n },\n};\n\n/**\n * Converts a Cosmos denom and amount to an AssetValue with proper decimal handling\n * @param denom - The denomination string\n * @param amount - The amount in base units as a string\n * @returns AssetValue with the correct decimal conversion\n */\nexport const getAssetFromDenom = (denom: string, amount: string) => {\n const config = DENOM_MAP[denom.toLowerCase()];\n\n if (!config) {\n // For unknown denoms, default to 8 decimals (common for many Cosmos chains)\n // This preserves the original behavior while using fromBaseDecimal\n return AssetValue.from({\n asset: denom,\n value: amount,\n fromBaseDecimal: 8,\n });\n }\n\n const { chain, asset, decimals } = config;\n\n const assetOrChain = (\n chain\n ? {\n chain,\n }\n : { asset }\n ) as { asset: string } | { chain: CosmosChain };\n\n return AssetValue.from({\n ...assetOrChain,\n value: amount,\n fromBaseDecimal: decimals,\n });\n};\n",
8
8
  "import { Chain } from \"@swapkit/helpers\";\nimport { base64ToBech32, bech32ToBase64 } from \"./addressFormat\";\n\nexport async function createDefaultRegistry() {\n const { $root } = await import(\"./types/MsgCompiled\");\n const { Registry } = (await import(\"@cosmjs/proto-signing\")).default;\n const { defaultRegistryTypes } = (await import(\"@cosmjs/stargate\")).default;\n\n return new Registry([\n ...defaultRegistryTypes,\n [\"/types.MsgSend\", $root.types.MsgSend],\n [\"/types.MsgDeposit\", $root.types.MsgDeposit],\n ]);\n}\n\nexport async function createDefaultAminoTypes(chain: Chain.THORChain | Chain.Maya) {\n const { AminoTypes } = (await import(\"@cosmjs/stargate\")).default;\n const aminoTypePrefix = chain === Chain.THORChain ? \"thorchain\" : \"mayachain\";\n\n return new AminoTypes({\n \"/types.MsgSend\": {\n aminoType: `${aminoTypePrefix}/MsgSend`,\n toAmino: ({ fromAddress, toAddress, ...rest }: any) => ({\n ...rest,\n from_address: base64ToBech32(fromAddress),\n to_address: base64ToBech32(toAddress),\n }),\n fromAmino: ({ from_address, to_address, ...rest }: any) => ({\n ...rest,\n fromAddress: bech32ToBase64(from_address),\n toAddress: bech32ToBase64(to_address),\n }),\n },\n \"/types.MsgDeposit\": {\n aminoType: `${aminoTypePrefix}/MsgDeposit`,\n toAmino: ({ signer, ...rest }: any) => ({ ...rest, signer: base64ToBech32(signer) }),\n fromAmino: ({ signer, ...rest }: any) => ({ ...rest, signer: bech32ToBase64(signer) }),\n },\n });\n}\n",
9
9
  "import { Chain, type CosmosChain, SwapKitError } from \"@swapkit/helpers\";\n\nimport type { CosmosToolboxParams } from \"../types\";\nimport { createCosmosToolbox } from \"./cosmos\";\nimport { createThorchainToolbox } from \"./thorchain\";\n\nexport type CosmosToolboxes = {\n GAIA: ReturnType<typeof createCosmosToolbox>;\n KUJI: ReturnType<typeof createCosmosToolbox>;\n MAYA: ReturnType<typeof createThorchainToolbox>;\n THOR: ReturnType<typeof createThorchainToolbox>;\n};\n\nexport const getCosmosToolbox = <T extends CosmosChain>(\n chain: T,\n params?: Omit<CosmosToolboxParams, \"chain\">,\n): CosmosToolboxes[T] => {\n switch (chain) {\n case Chain.Cosmos:\n case Chain.Kujira:\n return createCosmosToolbox({ chain, ...params }) as CosmosToolboxes[T];\n\n case Chain.Maya:\n case Chain.THORChain:\n return createThorchainToolbox({ chain, ...params }) as CosmosToolboxes[T];\n\n default:\n throw new SwapKitError(\"toolbox_cosmos_not_supported\", { chain });\n }\n};\n\nexport * from \"./cosmos\";\nexport * from \"./thorchain\";\n",
10
10
  "import type { StdFee } from \"@cosmjs/amino\";\nimport type { Account } from \"@cosmjs/stargate\";\nimport { base64, bech32 } from \"@scure/base\";\nimport {\n AssetValue,\n BaseDecimal,\n Chain,\n type ChainId,\n ChainToChainId,\n type CosmosChain,\n CosmosChainPrefixes,\n DerivationPath,\n type DerivationPathArray,\n FeeOption,\n type GenericTransferParams,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n SwapKitNumber,\n applyFeeMultiplier,\n derivationPathToString,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\nimport { SwapKitApi } from \"@swapkit/helpers/api\";\nimport { P, match } from \"ts-pattern\";\nimport type { CosmosToolboxParams } from \"../types\";\nimport {\n cosmosCreateTransaction,\n createSigningStargateClient,\n createStargateClient,\n getAssetFromDenom,\n getDenomWithChain,\n getMsgSendDenom,\n} from \"../util\";\n\nexport async function fetchFeeRateFromSwapKit(chainId: ChainId, safeDefault: number) {\n try {\n const response = await SwapKitApi.getGasRate();\n const responseGasRate = response.find((gas) => gas.chainId === chainId)?.value;\n\n return responseGasRate ? Number.parseFloat(responseGasRate) : safeDefault;\n } catch (_e) {\n return safeDefault;\n }\n}\n\nexport async function getSignerFromPhrase({\n phrase,\n prefix,\n ...derivationParams\n}: { phrase: string; prefix?: string } & (\n | { chain: Chain; index?: number }\n | { derivationPath: string }\n)) {\n const { DirectSecp256k1HdWallet } = (await import(\"@cosmjs/proto-signing\")).default;\n const { stringToPath } = (await import(\"@cosmjs/crypto\")).default;\n\n const derivationPath =\n \"derivationPath\" in derivationParams\n ? derivationParams.derivationPath\n : `${DerivationPath[derivationParams.chain]}/${derivationParams.index}`;\n\n return DirectSecp256k1HdWallet.fromMnemonic(phrase, {\n prefix,\n hdPaths: [stringToPath(derivationPath)],\n });\n}\n\nexport async function getSignerFromPrivateKey({\n privateKey,\n prefix,\n}: {\n privateKey: Uint8Array;\n prefix: string;\n}) {\n const { DirectSecp256k1Wallet } = (await import(\"@cosmjs/proto-signing\")).default;\n\n return DirectSecp256k1Wallet.fromKey(privateKey, prefix);\n}\n\nconst SafeDefaultFeeValues = {\n [Chain.Cosmos]: 500,\n [Chain.Kujira]: 1000,\n [Chain.THORChain]: 5000000,\n [Chain.Maya]: 5000000,\n};\n\nexport function verifySignature(getAccount: (address: string) => Promise<Account | null>) {\n return async function verifySignature({\n signature,\n message,\n address,\n }: {\n signature: string;\n message: string;\n address: string;\n }) {\n const account = await getAccount(address);\n if (!account?.pubkey) throw new SwapKitError(\"toolbox_cosmos_verify_signature_no_pubkey\");\n const { Secp256k1Signature, Secp256k1 } = (await import(\"@cosmjs/crypto\")).default;\n\n const secpSignature = Secp256k1Signature.fromFixedLength(base64.decode(signature));\n return Secp256k1.verifySignature(secpSignature, base64.decode(message), account.pubkey.value);\n };\n}\n\nexport async function createCosmosToolbox({ chain, ...toolboxParams }: CosmosToolboxParams) {\n const rpcUrl = SKConfig.get(\"rpcUrls\")[chain];\n const chainPrefix = CosmosChainPrefixes[chain];\n\n const index = \"index\" in toolboxParams ? toolboxParams.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in toolboxParams && toolboxParams.derivationPath\n ? toolboxParams.derivationPath\n : updateDerivationPath(NetworkDerivationPath[chain], { index }),\n );\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, ({ phrase }) =>\n getSignerFromPhrase({ phrase, prefix: chainPrefix, derivationPath }),\n )\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n async function getAccount(address: string) {\n const client = await createStargateClient(rpcUrl);\n return client.getAccount(address);\n }\n\n async function getAddress() {\n const [account] = (await signer?.getAccounts()) || [];\n return account?.address;\n }\n\n async function getPubKey() {\n const [account] = (await signer?.getAccounts()) || [];\n if (!account?.pubkey) {\n throw new SwapKitError(\"toolbox_cosmos_signer_not_defined\");\n }\n return base64.encode(account?.pubkey);\n }\n\n async function transfer({\n recipient,\n assetValue,\n memo = \"\",\n feeRate,\n feeOptionKey = FeeOption.Fast,\n }: GenericTransferParams) {\n const from = await getAddress();\n\n if (!(signer && from)) {\n throw new SwapKitError(\"toolbox_cosmos_signer_not_defined\");\n }\n\n const feeAssetValue = AssetValue.from({\n chain,\n });\n const assetDenom = getDenomWithChain(feeAssetValue);\n\n const txFee =\n feeRate ||\n feeToStdFee((await getFees(chain, SafeDefaultFeeValues[chain]))[feeOptionKey], assetDenom);\n\n const signingClient = await createSigningStargateClient(rpcUrl, signer);\n const message = [\n {\n denom: getMsgSendDenom(`u${assetValue.symbol}`).toLowerCase(),\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await signingClient.sendTokens(\n from,\n recipient,\n message,\n txFee,\n memo,\n );\n\n return transactionHash;\n }\n\n return {\n transfer,\n getAddress,\n getAccount,\n getBalance: async (address: string, _potentialScamFilter?: boolean) => {\n const denomBalances = await cosmosBalanceDenomsGetter(rpcUrl)(address);\n return await Promise.all(\n denomBalances\n .filter(({ denom }) => denom && !denom.includes(\"IBC/\"))\n .map(({ denom, amount }) => {\n const fullDenom =\n [Chain.THORChain, Chain.Maya].includes(chain) &&\n (denom.includes(\"/\") || denom.includes(\"˜\"))\n ? `${chain}.${denom}`\n : denom;\n return getAssetFromDenom(fullDenom, amount);\n }),\n );\n },\n getSignerFromPhrase: async ({\n phrase,\n derivationPath,\n }: { phrase: string; derivationPath: DerivationPathArray }) =>\n getSignerFromPhrase({\n phrase,\n prefix: chainPrefix,\n derivationPath: derivationPathToString(derivationPath),\n index,\n }),\n getSignerFromPrivateKey: async (privateKey: Uint8Array) => {\n const { DirectSecp256k1Wallet } = (await import(\"@cosmjs/proto-signing\")).default;\n return DirectSecp256k1Wallet.fromKey(privateKey, chainPrefix);\n },\n createPrivateKeyFromPhrase: createPrivateKeyFromPhrase(derivationPath),\n validateAddress: getCosmosValidateAddress(chainPrefix),\n getPubKey,\n getFees: () => getFees(chain, SafeDefaultFeeValues[chain]),\n fetchFeeRateFromSwapKit,\n getBalanceAsDenoms: cosmosBalanceDenomsGetter(rpcUrl),\n createTransaction: cosmosCreateTransaction,\n verifySignature: verifySignature(getAccount),\n };\n}\n\nexport async function getFeeRateFromThorswap(chainId: ChainId, safeDefault: number) {\n try {\n const response = await SwapKitApi.getGasRate();\n const responseGasRate = response.find((gas) => gas.chainId === chainId)?.value;\n\n return responseGasRate ? Number.parseFloat(responseGasRate) : safeDefault;\n } catch (_e) {\n return safeDefault;\n }\n}\n\nexport function cosmosValidateAddress({\n address,\n chain,\n prefix: chainPrefix,\n}: { address: string } & (\n | { prefix: string; chain?: undefined }\n | { chain: CosmosChain; prefix?: undefined }\n)) {\n const prefix = chainPrefix || getPrefix(chain);\n\n if (!(prefix && address)) {\n throw new SwapKitError(\"toolbox_cosmos_validate_address_prefix_not_found\");\n }\n\n return getCosmosValidateAddress(prefix)(address);\n}\n\nexport function estimateTransactionFee({\n assetValue: { chain },\n}: {\n assetValue: AssetValue;\n}) {\n return AssetValue.from({ chain, value: getMinTransactionFee(chain) });\n}\n\nfunction getPrefix<C extends CosmosChain>(chain?: C) {\n const { isStagenet } = SKConfig.get(\"envs\");\n const useStagenetPrefix = chain\n ? [Chain.THORChain, Chain.Maya].includes(chain) && isStagenet\n : false;\n const basePrefix = chain ? CosmosChainPrefixes[chain] : undefined;\n\n return useStagenetPrefix ? `s${basePrefix}` : basePrefix;\n}\n\nasync function getFees(chain: Chain, safeDefault: number) {\n const baseFee = await fetchFeeRateFromSwapKit(ChainToChainId[chain], safeDefault);\n return {\n average: SwapKitNumber.fromBigInt(BigInt(baseFee), BaseDecimal[chain]),\n fast: SwapKitNumber.fromBigInt(\n BigInt(applyFeeMultiplier(baseFee, FeeOption.Fast, true)),\n BaseDecimal[chain],\n ),\n fastest: SwapKitNumber.fromBigInt(\n BigInt(applyFeeMultiplier(baseFee, FeeOption.Fastest, true)),\n BaseDecimal[chain],\n ),\n } as { [key in FeeOption]: SwapKitNumber };\n}\n\nfunction feeToStdFee(fee: SwapKitNumber, denom: string): StdFee {\n return {\n amount: [{ denom, amount: fee.getBaseValue(\"string\") }],\n gas: \"200000\",\n };\n}\n\nfunction getMinTransactionFee(chain: Chain) {\n return (\n {\n [Chain.Cosmos]: 0.007,\n [Chain.Kujira]: 0.02,\n [Chain.THORChain]: 0.02,\n [Chain.Maya]: 0.02,\n }[chain as CosmosChain] || 0\n );\n}\n\nfunction getCosmosValidateAddress(prefix: string) {\n return function validateAddress(address: string) {\n if (!address.startsWith(prefix)) return false;\n\n try {\n const { prefix, words } = bech32.decode(address as `${string}1${string}`);\n const normalized = bech32.encode(prefix, words);\n\n return normalized === address.toLocaleLowerCase();\n } catch (_error) {\n return false;\n }\n };\n}\n\nfunction cosmosBalanceDenomsGetter(rpcUrl: string) {\n return async function getCosmosBalanceDenoms(address: string) {\n const client = await createStargateClient(rpcUrl);\n const allBalances = await client.getAllBalances(address);\n\n const balances = allBalances.map((balance) => ({\n ...balance,\n denom: balance.denom.includes(\"/\") ? balance.denom.toUpperCase() : balance.denom,\n }));\n\n return balances;\n };\n}\n\nfunction createPrivateKeyFromPhrase(derivationPath: string) {\n return async function createPrivateKeyFromPhrase(phrase: string) {\n const { Bip39, EnglishMnemonic, Slip10, Slip10Curve, stringToPath } = (\n await import(\"@cosmjs/crypto\")\n ).default;\n\n const mnemonicChecked = new EnglishMnemonic(phrase);\n const seed = await Bip39.mnemonicToSeed(mnemonicChecked);\n\n const { privkey } = Slip10.derivePath(\n Slip10Curve.Secp256k1,\n seed,\n stringToPath(derivationPath),\n );\n\n return privkey;\n };\n}\n",
@@ -1,4 +1,4 @@
1
- var g={};u(g,{getToolbox:()=>x,getFeeEstimator:()=>f,getAddressValidator:()=>d});module.exports=C(g);var o=require("@swapkit/helpers");async function d(){let{match:r}=await import("ts-pattern"),{cosmosValidateAddress:i}=await import("@swapkit/toolboxes/cosmos"),{evmValidateAddress:n}=await import("@swapkit/toolboxes/evm"),{substrateValidateAddress:a}=await import("@swapkit/toolboxes/substrate"),{getUTXOAddressValidator:e}=await import("@swapkit/toolboxes/utxo"),{getSolanaAddressValidator:l}=await import("@swapkit/toolboxes/solana"),{validateNearAddress:p}=await import("@swapkit/toolboxes/near"),{rippleValidateAddress:m}=await import("@swapkit/toolboxes/ripple"),{radixValidateAddress:c}=await import("@swapkit/toolboxes/radix"),{getTronAddressValidator:b}=await import("@swapkit/toolboxes/tron"),y=await l(),h=await e(),w=await b();return function P({address:s,chain:T}){return r(T).with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,()=>n({address:s})).with(o.Chain.Litecoin,o.Chain.Dash,o.Chain.Dogecoin,o.Chain.BitcoinCash,o.Chain.Bitcoin,()=>h({address:s,chain:T})).with(o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Maya,o.Chain.THORChain,()=>i({address:s,chain:T})).with(o.Chain.Chainflip,o.Chain.Polkadot,()=>a({address:s,chain:T})).with(o.Chain.Radix,()=>c(s)).with(o.Chain.Near,()=>p(s)).with(o.Chain.Ripple,()=>m(s)).with(o.Chain.Solana,()=>y(s)).with(o.Chain.Tron,()=>w(s)).otherwise(()=>!1)}}function f(r){return async function i(n){let{match:a}=await import("ts-pattern");return a(r).returnType().with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,async(e)=>{let l=await x(e),p=await l.createTransaction(n);return l.estimateTransactionFee({...p,feeOption:n.feeOptionKey||o.FeeOption.Fast,chain:e})}).with(o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Dogecoin,o.Chain.Dash,o.Chain.Litecoin,o.Chain.Polkadot,o.Chain.Solana,o.Chain.Ripple,o.Chain.Tron,o.Chain.Near,async(e)=>{return(await x(e)).estimateTransactionFee(n)}).with(o.Chain.THORChain,o.Chain.Maya,o.Chain.Kujira,o.Chain.Cosmos,async()=>{let{estimateTransactionFee:e}=await import("@swapkit/toolboxes/cosmos");return e(n)}).otherwise(async()=>o.AssetValue.from({chain:r}))}}async function x(r,i){let{match:n}=await import("ts-pattern");return n(r).returnType().with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,async()=>{let{getEvmToolbox:a}=await import("@swapkit/toolboxes/evm");return await a(r,i)}).with(o.Chain.Litecoin,o.Chain.Dash,o.Chain.Dogecoin,o.Chain.BitcoinCash,o.Chain.Bitcoin,o.Chain.Zcash,async()=>{let{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo");return await a(r,i)}).with(o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Maya,o.Chain.THORChain,async()=>{let{getCosmosToolbox:a}=await import("@swapkit/toolboxes/cosmos");return await a(r,i)}).with(o.Chain.Chainflip,o.Chain.Polkadot,async()=>{let{getSubstrateToolbox:a}=await import("@swapkit/toolboxes/substrate");return await a(r,i)}).with(o.Chain.Radix,async()=>{let{RadixToolbox:a}=await import("@swapkit/toolboxes/radix");return await a(i)}).with(o.Chain.Ripple,async()=>{let{getRippleToolbox:a}=await import("@swapkit/toolboxes/ripple");return await a(i)}).with(o.Chain.Solana,async()=>{let{getSolanaToolbox:a}=await import("@swapkit/toolboxes/solana");return await a(i)}).with(o.Chain.Tron,async()=>{let{createTronToolbox:a}=await import("@swapkit/toolboxes/tron");return await a(i)}).with(o.Chain.Near,async()=>{let{getNearToolbox:a}=await import("@swapkit/toolboxes/near");return await a(i)}).otherwise(()=>{throw new o.SwapKitError("toolbox_not_supported",{chain:r})})}
1
+ var P={};d(P,{getToolbox:()=>x,getFeeEstimator:()=>g,getAddressValidator:()=>f});module.exports=u(P);var o=require("@swapkit/helpers");async function f(){let{match:r}=await import("ts-pattern"),{cosmosValidateAddress:i}=await import("@swapkit/toolboxes/cosmos"),{evmValidateAddress:n}=await import("@swapkit/toolboxes/evm"),{substrateValidateAddress:a}=await import("@swapkit/toolboxes/substrate"),{getUTXOAddressValidator:e}=await import("@swapkit/toolboxes/utxo"),{getSolanaAddressValidator:l}=await import("@swapkit/toolboxes/solana"),{getValidateNearAddress:p}=await import("@swapkit/toolboxes/near"),{rippleValidateAddress:m}=await import("@swapkit/toolboxes/ripple"),{radixValidateAddress:c}=await import("@swapkit/toolboxes/radix"),{getTronAddressValidator:b}=await import("@swapkit/toolboxes/tron"),y=await l(),h=await e(),w=await b(),C=await p();return function A({address:s,chain:T}){return r(T).with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,()=>n({address:s})).with(o.Chain.Litecoin,o.Chain.Dash,o.Chain.Dogecoin,o.Chain.BitcoinCash,o.Chain.Bitcoin,()=>h({address:s,chain:T})).with(o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Maya,o.Chain.THORChain,()=>i({address:s,chain:T})).with(o.Chain.Chainflip,o.Chain.Polkadot,()=>a({address:s,chain:T})).with(o.Chain.Radix,()=>c(s)).with(o.Chain.Near,()=>C(s)).with(o.Chain.Ripple,()=>m(s)).with(o.Chain.Solana,()=>y(s)).with(o.Chain.Tron,()=>w(s)).otherwise(()=>!1)}}function g(r){return async function i(n){let{match:a}=await import("ts-pattern");return a(r).returnType().with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,async(e)=>{let l=await x(e),p=await l.createTransaction(n);return l.estimateTransactionFee({...p,feeOption:n.feeOptionKey||o.FeeOption.Fast,chain:e})}).with(o.Chain.Bitcoin,o.Chain.BitcoinCash,o.Chain.Dogecoin,o.Chain.Dash,o.Chain.Litecoin,o.Chain.Polkadot,o.Chain.Solana,o.Chain.Ripple,o.Chain.Tron,o.Chain.Near,async(e)=>{return(await x(e)).estimateTransactionFee(n)}).with(o.Chain.THORChain,o.Chain.Maya,o.Chain.Kujira,o.Chain.Cosmos,async()=>{let{estimateTransactionFee:e}=await import("@swapkit/toolboxes/cosmos");return e(n)}).otherwise(async()=>o.AssetValue.from({chain:r}))}}async function x(r,i){let{match:n}=await import("ts-pattern");return n(r).returnType().with(o.Chain.Arbitrum,o.Chain.Avalanche,o.Chain.Optimism,o.Chain.BinanceSmartChain,o.Chain.Base,o.Chain.Polygon,o.Chain.Ethereum,async()=>{let{getEvmToolbox:a}=await import("@swapkit/toolboxes/evm");return await a(r,i)}).with(o.Chain.Litecoin,o.Chain.Dash,o.Chain.Dogecoin,o.Chain.BitcoinCash,o.Chain.Bitcoin,o.Chain.Zcash,async()=>{let{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo");return await a(r,i)}).with(o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Maya,o.Chain.THORChain,async()=>{let{getCosmosToolbox:a}=await import("@swapkit/toolboxes/cosmos");return await a(r,i)}).with(o.Chain.Chainflip,o.Chain.Polkadot,async()=>{let{getSubstrateToolbox:a}=await import("@swapkit/toolboxes/substrate");return await a(r,i)}).with(o.Chain.Radix,async()=>{let{RadixToolbox:a}=await import("@swapkit/toolboxes/radix");return await a(i)}).with(o.Chain.Ripple,async()=>{let{getRippleToolbox:a}=await import("@swapkit/toolboxes/ripple");return await a(i)}).with(o.Chain.Solana,async()=>{let{getSolanaToolbox:a}=await import("@swapkit/toolboxes/solana");return await a(i)}).with(o.Chain.Tron,async()=>{let{createTronToolbox:a}=await import("@swapkit/toolboxes/tron");return await a(i)}).with(o.Chain.Near,async()=>{let{getNearToolbox:a}=await import("@swapkit/toolboxes/near");return await a(i)}).otherwise(()=>{throw new o.SwapKitError("toolbox_not_supported",{chain:r})})}
2
2
 
3
- //# debugId=E213B61B029A580264756E2164756E21
3
+ //# debugId=2F7E180676D38DAE64756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,9 +2,9 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n Chain,\n type CosmosChain,\n type EVMChain,\n FeeOption,\n type GenericCreateTransactionParams,\n type SubstrateChain,\n SwapKitError,\n type UTXOChain,\n} from \"@swapkit/helpers\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\n\nimport type { ETHToolbox, EVMCreateTransactionParams, getEvmToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { RadixToolbox } from \"@swapkit/toolboxes/radix\";\nimport type { getRippleToolbox } from \"@swapkit/toolboxes/ripple\";\nimport type { SolanaCreateTransactionParams, getSolanaToolbox } from \"@swapkit/toolboxes/solana\";\nimport type { getSubstrateToolbox } from \"@swapkit/toolboxes/substrate\";\nimport type { createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { getUtxoToolbox } from \"@swapkit/toolboxes/utxo\";\n\nexport async function getAddressValidator() {\n const { match } = await import(\"ts-pattern\");\n const { cosmosValidateAddress } = await import(\"@swapkit/toolboxes/cosmos\");\n const { evmValidateAddress } = await import(\"@swapkit/toolboxes/evm\");\n const { substrateValidateAddress } = await import(\"@swapkit/toolboxes/substrate\");\n const { getUTXOAddressValidator } = await import(\"@swapkit/toolboxes/utxo\");\n const { getSolanaAddressValidator } = await import(\"@swapkit/toolboxes/solana\");\n const { validateNearAddress } = await import(\"@swapkit/toolboxes/near\");\n const { rippleValidateAddress } = await import(\"@swapkit/toolboxes/ripple\");\n const { radixValidateAddress } = await import(\"@swapkit/toolboxes/radix\");\n const { getTronAddressValidator } = await import(\"@swapkit/toolboxes/tron\");\n\n const solanaValidateAddress = await getSolanaAddressValidator();\n const utxoValidateAddress = await getUTXOAddressValidator();\n const tronValidateAddress = await getTronAddressValidator();\n\n return function validateAddress({ address, chain }: { address: string; chain: Chain }) {\n const isValid = match(chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n () => evmValidateAddress({ address }),\n )\n .with(Chain.Litecoin, Chain.Dash, Chain.Dogecoin, Chain.BitcoinCash, Chain.Bitcoin, () =>\n utxoValidateAddress({ address, chain: chain as UTXOChain }),\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () =>\n cosmosValidateAddress({ address, chain: chain as CosmosChain }),\n )\n .with(Chain.Chainflip, Chain.Polkadot, () =>\n substrateValidateAddress({ address, chain: chain as SubstrateChain }),\n )\n .with(Chain.Radix, () => radixValidateAddress(address))\n .with(Chain.Near, () => validateNearAddress(address))\n .with(Chain.Ripple, () => rippleValidateAddress(address))\n .with(Chain.Solana, () => solanaValidateAddress(address))\n .with(Chain.Tron, () => tronValidateAddress(address))\n .otherwise(() => false);\n\n return isValid;\n };\n}\n\nexport function getFeeEstimator<T extends keyof CreateTransactionParams>(chain: T) {\n return async function estimateFee(params: CreateTransactionParams[T]) {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<AssetValue>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n const txObject = await toolbox.createTransaction(params);\n\n return (toolbox as Awaited<ReturnType<typeof ETHToolbox>>).estimateTransactionFee({\n ...txObject,\n feeOption: params.feeOptionKey || FeeOption.Fast,\n chain,\n });\n },\n )\n .with(\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Litecoin,\n Chain.Polkadot,\n Chain.Solana,\n Chain.Ripple,\n Chain.Tron,\n Chain.Near,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n return toolbox.estimateTransactionFee(params) as Promise<AssetValue>;\n },\n )\n .with(Chain.THORChain, Chain.Maya, Chain.Kujira, Chain.Cosmos, async () => {\n const { estimateTransactionFee } = await import(\"@swapkit/toolboxes/cosmos\");\n return estimateTransactionFee(params);\n })\n .otherwise(async () => AssetValue.from({ chain }));\n };\n}\n\ntype Toolboxes = {\n [key in EVMChain]: Awaited<ReturnType<typeof getEvmToolbox>>;\n} & {\n [key in UTXOChain]: Awaited<ReturnType<typeof getUtxoToolbox>>;\n} & {\n [key in CosmosChain]: Awaited<ReturnType<typeof getCosmosToolbox>>;\n} & {\n [key in SubstrateChain]: Awaited<ReturnType<typeof getSubstrateToolbox>>;\n} & {\n [Chain.Radix]: Awaited<ReturnType<typeof RadixToolbox>>;\n [Chain.Near]: Awaited<ReturnType<typeof getNearToolbox>>;\n [Chain.Ripple]: Awaited<ReturnType<typeof getRippleToolbox>>;\n [Chain.Solana]: Awaited<ReturnType<typeof getSolanaToolbox>>;\n [Chain.Tron]: Awaited<ReturnType<typeof createTronToolbox>>;\n};\n\ntype ToolboxParams = { [key in EVMChain]: Parameters<typeof getEvmToolbox>[1] } & {\n [key in UTXOChain]: undefined;\n} & {\n [key in CosmosChain]: Parameters<typeof getCosmosToolbox>[1];\n} & {\n [key in SubstrateChain]: Parameters<typeof getSubstrateToolbox>[1];\n} & {\n [Chain.Radix]: Parameters<typeof RadixToolbox>[0];\n [Chain.Near]: Parameters<typeof getNearToolbox>[0];\n [Chain.Ripple]: Parameters<typeof getRippleToolbox>[0];\n [Chain.Solana]: Parameters<typeof getSolanaToolbox>[0];\n [Chain.Tron]: Parameters<typeof createTronToolbox>[0];\n};\n\ntype CreateTransactionParams = { [key in EVMChain]: EVMCreateTransactionParams } & {\n [key in UTXOChain]: GenericCreateTransactionParams;\n} & {\n [key in CosmosChain]: GenericCreateTransactionParams;\n} & {\n [key in SubstrateChain]: GenericCreateTransactionParams;\n} & {\n [Chain.Radix]: GenericCreateTransactionParams;\n [Chain.Ripple]: GenericCreateTransactionParams;\n [Chain.Near]: GenericCreateTransactionParams;\n [Chain.Solana]: SolanaCreateTransactionParams;\n [Chain.Tron]: GenericCreateTransactionParams;\n};\n\nexport async function getToolbox<T extends keyof Toolboxes>(\n chain: T,\n params?: ToolboxParams[T],\n): Promise<Toolboxes[T]> {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<Toolboxes[T]>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async () => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const evmToolbox = await getEvmToolbox(\n chain as EVMChain,\n params as Parameters<typeof getEvmToolbox>[1],\n );\n return evmToolbox as Toolboxes[T];\n },\n )\n .with(\n Chain.Litecoin,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.BitcoinCash,\n Chain.Bitcoin,\n Chain.Zcash,\n async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const utxoToolbox = await getUtxoToolbox(\n chain as UTXOChain,\n params as Parameters<typeof getUtxoToolbox>[1],\n );\n return utxoToolbox as Toolboxes[T];\n },\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const cosmosToolbox = await getCosmosToolbox(\n chain as CosmosChain,\n params as Parameters<typeof getCosmosToolbox>[1],\n );\n return cosmosToolbox as Toolboxes[T];\n })\n .with(Chain.Chainflip, Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const substrateToolbox = await getSubstrateToolbox(\n chain as SubstrateChain,\n params as Parameters<typeof getSubstrateToolbox>[1],\n );\n return substrateToolbox as Toolboxes[T];\n })\n .with(Chain.Radix, async () => {\n const { RadixToolbox } = await import(\"@swapkit/toolboxes/radix\");\n const radixToolbox = await RadixToolbox(params as Parameters<typeof RadixToolbox>[0]);\n return radixToolbox as Toolboxes[T];\n })\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const rippleToolbox = await getRippleToolbox(\n params as Parameters<typeof getRippleToolbox>[0],\n );\n return rippleToolbox as Toolboxes[T];\n })\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaToolbox = await getSolanaToolbox(\n params as Parameters<typeof getSolanaToolbox>[0],\n );\n return solanaToolbox as Toolboxes[T];\n })\n .with(Chain.Tron, async () => {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const tronToolbox = await createTronToolbox(params);\n return tronToolbox as Toolboxes[T];\n })\n .with(Chain.Near, async () => {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const nearToolbox = await getNearToolbox(params as Parameters<typeof getNearToolbox>[0]);\n return nearToolbox as Toolboxes[T];\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_not_supported\", { chain });\n });\n}\n"
5
+ "import {\n AssetValue,\n Chain,\n type CosmosChain,\n type EVMChain,\n FeeOption,\n type GenericCreateTransactionParams,\n type SubstrateChain,\n SwapKitError,\n type UTXOChain,\n} from \"@swapkit/helpers\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\n\nimport type { ETHToolbox, EVMCreateTransactionParams, getEvmToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { RadixToolbox } from \"@swapkit/toolboxes/radix\";\nimport type { getRippleToolbox } from \"@swapkit/toolboxes/ripple\";\nimport type { SolanaCreateTransactionParams, getSolanaToolbox } from \"@swapkit/toolboxes/solana\";\nimport type { getSubstrateToolbox } from \"@swapkit/toolboxes/substrate\";\nimport type { createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { getUtxoToolbox } from \"@swapkit/toolboxes/utxo\";\n\nexport async function getAddressValidator() {\n const { match } = await import(\"ts-pattern\");\n const { cosmosValidateAddress } = await import(\"@swapkit/toolboxes/cosmos\");\n const { evmValidateAddress } = await import(\"@swapkit/toolboxes/evm\");\n const { substrateValidateAddress } = await import(\"@swapkit/toolboxes/substrate\");\n const { getUTXOAddressValidator } = await import(\"@swapkit/toolboxes/utxo\");\n const { getSolanaAddressValidator } = await import(\"@swapkit/toolboxes/solana\");\n const { getValidateNearAddress } = await import(\"@swapkit/toolboxes/near\");\n const { rippleValidateAddress } = await import(\"@swapkit/toolboxes/ripple\");\n const { radixValidateAddress } = await import(\"@swapkit/toolboxes/radix\");\n const { getTronAddressValidator } = await import(\"@swapkit/toolboxes/tron\");\n\n const solanaValidateAddress = await getSolanaAddressValidator();\n const utxoValidateAddress = await getUTXOAddressValidator();\n const tronValidateAddress = await getTronAddressValidator();\n const nearValidateAddress = await getValidateNearAddress();\n\n return function validateAddress({ address, chain }: { address: string; chain: Chain }) {\n const isValid = match(chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n () => evmValidateAddress({ address }),\n )\n .with(Chain.Litecoin, Chain.Dash, Chain.Dogecoin, Chain.BitcoinCash, Chain.Bitcoin, () =>\n utxoValidateAddress({ address, chain: chain as UTXOChain }),\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () =>\n cosmosValidateAddress({ address, chain: chain as CosmosChain }),\n )\n .with(Chain.Chainflip, Chain.Polkadot, () =>\n substrateValidateAddress({ address, chain: chain as SubstrateChain }),\n )\n .with(Chain.Radix, () => radixValidateAddress(address))\n .with(Chain.Near, () => nearValidateAddress(address))\n .with(Chain.Ripple, () => rippleValidateAddress(address))\n .with(Chain.Solana, () => solanaValidateAddress(address))\n .with(Chain.Tron, () => tronValidateAddress(address))\n .otherwise(() => false);\n\n return isValid;\n };\n}\n\nexport function getFeeEstimator<T extends keyof CreateTransactionParams>(chain: T) {\n return async function estimateFee(params: CreateTransactionParams[T]) {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<AssetValue>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n const txObject = await toolbox.createTransaction(params);\n\n return (toolbox as Awaited<ReturnType<typeof ETHToolbox>>).estimateTransactionFee({\n ...txObject,\n feeOption: params.feeOptionKey || FeeOption.Fast,\n chain,\n });\n },\n )\n .with(\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Litecoin,\n Chain.Polkadot,\n Chain.Solana,\n Chain.Ripple,\n Chain.Tron,\n Chain.Near,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n return toolbox.estimateTransactionFee(params) as Promise<AssetValue>;\n },\n )\n .with(Chain.THORChain, Chain.Maya, Chain.Kujira, Chain.Cosmos, async () => {\n const { estimateTransactionFee } = await import(\"@swapkit/toolboxes/cosmos\");\n return estimateTransactionFee(params);\n })\n .otherwise(async () => AssetValue.from({ chain }));\n };\n}\n\ntype Toolboxes = {\n [key in EVMChain]: Awaited<ReturnType<typeof getEvmToolbox>>;\n} & {\n [key in UTXOChain]: Awaited<ReturnType<typeof getUtxoToolbox>>;\n} & {\n [key in CosmosChain]: Awaited<ReturnType<typeof getCosmosToolbox>>;\n} & {\n [key in SubstrateChain]: Awaited<ReturnType<typeof getSubstrateToolbox>>;\n} & {\n [Chain.Radix]: Awaited<ReturnType<typeof RadixToolbox>>;\n [Chain.Near]: Awaited<ReturnType<typeof getNearToolbox>>;\n [Chain.Ripple]: Awaited<ReturnType<typeof getRippleToolbox>>;\n [Chain.Solana]: Awaited<ReturnType<typeof getSolanaToolbox>>;\n [Chain.Tron]: Awaited<ReturnType<typeof createTronToolbox>>;\n};\n\ntype ToolboxParams = { [key in EVMChain]: Parameters<typeof getEvmToolbox>[1] } & {\n [key in UTXOChain]: undefined;\n} & {\n [key in CosmosChain]: Parameters<typeof getCosmosToolbox>[1];\n} & {\n [key in SubstrateChain]: Parameters<typeof getSubstrateToolbox>[1];\n} & {\n [Chain.Radix]: Parameters<typeof RadixToolbox>[0];\n [Chain.Near]: Parameters<typeof getNearToolbox>[0];\n [Chain.Ripple]: Parameters<typeof getRippleToolbox>[0];\n [Chain.Solana]: Parameters<typeof getSolanaToolbox>[0];\n [Chain.Tron]: Parameters<typeof createTronToolbox>[0];\n};\n\ntype CreateTransactionParams = { [key in EVMChain]: EVMCreateTransactionParams } & {\n [key in UTXOChain]: GenericCreateTransactionParams;\n} & {\n [key in CosmosChain]: GenericCreateTransactionParams;\n} & {\n [key in SubstrateChain]: GenericCreateTransactionParams;\n} & {\n [Chain.Radix]: GenericCreateTransactionParams;\n [Chain.Ripple]: GenericCreateTransactionParams;\n [Chain.Near]: GenericCreateTransactionParams;\n [Chain.Solana]: SolanaCreateTransactionParams;\n [Chain.Tron]: GenericCreateTransactionParams;\n};\n\nexport async function getToolbox<T extends keyof Toolboxes>(\n chain: T,\n params?: ToolboxParams[T],\n): Promise<Toolboxes[T]> {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<Toolboxes[T]>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async () => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const evmToolbox = await getEvmToolbox(\n chain as EVMChain,\n params as Parameters<typeof getEvmToolbox>[1],\n );\n return evmToolbox as Toolboxes[T];\n },\n )\n .with(\n Chain.Litecoin,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.BitcoinCash,\n Chain.Bitcoin,\n Chain.Zcash,\n async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const utxoToolbox = await getUtxoToolbox(\n chain as UTXOChain,\n params as Parameters<typeof getUtxoToolbox>[1],\n );\n return utxoToolbox as Toolboxes[T];\n },\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const cosmosToolbox = await getCosmosToolbox(\n chain as CosmosChain,\n params as Parameters<typeof getCosmosToolbox>[1],\n );\n return cosmosToolbox as Toolboxes[T];\n })\n .with(Chain.Chainflip, Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const substrateToolbox = await getSubstrateToolbox(\n chain as SubstrateChain,\n params as Parameters<typeof getSubstrateToolbox>[1],\n );\n return substrateToolbox as Toolboxes[T];\n })\n .with(Chain.Radix, async () => {\n const { RadixToolbox } = await import(\"@swapkit/toolboxes/radix\");\n const radixToolbox = await RadixToolbox(params as Parameters<typeof RadixToolbox>[0]);\n return radixToolbox as Toolboxes[T];\n })\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const rippleToolbox = await getRippleToolbox(\n params as Parameters<typeof getRippleToolbox>[0],\n );\n return rippleToolbox as Toolboxes[T];\n })\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaToolbox = await getSolanaToolbox(\n params as Parameters<typeof getSolanaToolbox>[0],\n );\n return solanaToolbox as Toolboxes[T];\n })\n .with(Chain.Tron, async () => {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const tronToolbox = await createTronToolbox(params);\n return tronToolbox as Toolboxes[T];\n })\n .with(Chain.Near, async () => {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const nearToolbox = await getNearToolbox(params as Parameters<typeof getNearToolbox>[0]);\n return nearToolbox as Toolboxes[T];\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_not_supported\", { chain });\n });\n}\n"
6
6
  ],
7
- "mappings": "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",
8
- "debugId": "E213B61B029A580264756E2164756E21",
7
+ "mappings": "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",
8
+ "debugId": "2F7E180676D38DAE64756E2164756E21",
9
9
  "names": []
10
10
  }
package/dist/src/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import{d as t,e as a}from"../chunk-s47y8512.js";import{AssetValue as u,Chain as o,FeeOption as d,SwapKitError as f}from"@swapkit/helpers";async function A(){let{match:s}=await import("ts-pattern"),{cosmosValidateAddress:r}=await import("@swapkit/toolboxes/cosmos"),{evmValidateAddress:l}=await import("@swapkit/toolboxes/evm"),{substrateValidateAddress:e}=await import("@swapkit/toolboxes/substrate"),{getUTXOAddressValidator:i}=await import("@swapkit/toolboxes/utxo"),{getSolanaAddressValidator:T}=await import("@swapkit/toolboxes/solana"),{validateNearAddress:x}=await import("@swapkit/toolboxes/near"),{rippleValidateAddress:c}=await import("@swapkit/toolboxes/ripple"),{radixValidateAddress:b}=await import("@swapkit/toolboxes/radix"),{getTronAddressValidator:y}=await import("@swapkit/toolboxes/tron"),h=await T(),w=await i(),C=await y();return function g({address:n,chain:p}){return s(p).with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,()=>l({address:n})).with(o.Litecoin,o.Dash,o.Dogecoin,o.BitcoinCash,o.Bitcoin,()=>w({address:n,chain:p})).with(o.Cosmos,o.Kujira,o.Maya,o.THORChain,()=>r({address:n,chain:p})).with(o.Chainflip,o.Polkadot,()=>e({address:n,chain:p})).with(o.Radix,()=>b(n)).with(o.Near,()=>x(n)).with(o.Ripple,()=>c(n)).with(o.Solana,()=>h(n)).with(o.Tron,()=>C(n)).otherwise(()=>!1)}}function S(s){return async function r(l){let{match:e}=await import("ts-pattern");return e(s).returnType().with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,async(i)=>{let T=await m(i),x=await T.createTransaction(l);return T.estimateTransactionFee({...x,feeOption:l.feeOptionKey||d.Fast,chain:i})}).with(o.Bitcoin,o.BitcoinCash,o.Dogecoin,o.Dash,o.Litecoin,o.Polkadot,o.Solana,o.Ripple,o.Tron,o.Near,async(i)=>{return(await m(i)).estimateTransactionFee(l)}).with(o.THORChain,o.Maya,o.Kujira,o.Cosmos,async()=>{let{estimateTransactionFee:i}=await import("@swapkit/toolboxes/cosmos");return i(l)}).otherwise(async()=>u.from({chain:s}))}}async function m(s,r){let{match:l}=await import("ts-pattern");return l(s).returnType().with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,async()=>{let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");return await e(s,r)}).with(o.Litecoin,o.Dash,o.Dogecoin,o.BitcoinCash,o.Bitcoin,o.Zcash,async()=>{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return await e(s,r)}).with(o.Cosmos,o.Kujira,o.Maya,o.THORChain,async()=>{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos");return await e(s,r)}).with(o.Chainflip,o.Polkadot,async()=>{let{getSubstrateToolbox:e}=await import("@swapkit/toolboxes/substrate");return await e(s,r)}).with(o.Radix,async()=>{let{RadixToolbox:e}=await import("@swapkit/toolboxes/radix");return await e(r)}).with(o.Ripple,async()=>{let{getRippleToolbox:e}=await import("@swapkit/toolboxes/ripple");return await e(r)}).with(o.Solana,async()=>{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana");return await e(r)}).with(o.Tron,async()=>{let{createTronToolbox:e}=await import("@swapkit/toolboxes/tron");return await e(r)}).with(o.Near,async()=>{let{getNearToolbox:e}=await import("@swapkit/toolboxes/near");return await e(r)}).otherwise(()=>{throw new f("toolbox_not_supported",{chain:s})})}export{m as getToolbox,S as getFeeEstimator,A as getAddressValidator};
1
+ import{d as t,e as a}from"../chunk-s47y8512.js";import{AssetValue as d,Chain as o,FeeOption as f,SwapKitError as g}from"@swapkit/helpers";async function S(){let{match:s}=await import("ts-pattern"),{cosmosValidateAddress:r}=await import("@swapkit/toolboxes/cosmos"),{evmValidateAddress:l}=await import("@swapkit/toolboxes/evm"),{substrateValidateAddress:e}=await import("@swapkit/toolboxes/substrate"),{getUTXOAddressValidator:i}=await import("@swapkit/toolboxes/utxo"),{getSolanaAddressValidator:T}=await import("@swapkit/toolboxes/solana"),{getValidateNearAddress:x}=await import("@swapkit/toolboxes/near"),{rippleValidateAddress:c}=await import("@swapkit/toolboxes/ripple"),{radixValidateAddress:b}=await import("@swapkit/toolboxes/radix"),{getTronAddressValidator:y}=await import("@swapkit/toolboxes/tron"),h=await T(),w=await i(),C=await y(),u=await x();return function P({address:n,chain:p}){return s(p).with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,()=>l({address:n})).with(o.Litecoin,o.Dash,o.Dogecoin,o.BitcoinCash,o.Bitcoin,()=>w({address:n,chain:p})).with(o.Cosmos,o.Kujira,o.Maya,o.THORChain,()=>r({address:n,chain:p})).with(o.Chainflip,o.Polkadot,()=>e({address:n,chain:p})).with(o.Radix,()=>b(n)).with(o.Near,()=>u(n)).with(o.Ripple,()=>c(n)).with(o.Solana,()=>h(n)).with(o.Tron,()=>C(n)).otherwise(()=>!1)}}function k(s){return async function r(l){let{match:e}=await import("ts-pattern");return e(s).returnType().with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,async(i)=>{let T=await m(i),x=await T.createTransaction(l);return T.estimateTransactionFee({...x,feeOption:l.feeOptionKey||f.Fast,chain:i})}).with(o.Bitcoin,o.BitcoinCash,o.Dogecoin,o.Dash,o.Litecoin,o.Polkadot,o.Solana,o.Ripple,o.Tron,o.Near,async(i)=>{return(await m(i)).estimateTransactionFee(l)}).with(o.THORChain,o.Maya,o.Kujira,o.Cosmos,async()=>{let{estimateTransactionFee:i}=await import("@swapkit/toolboxes/cosmos");return i(l)}).otherwise(async()=>d.from({chain:s}))}}async function m(s,r){let{match:l}=await import("ts-pattern");return l(s).returnType().with(o.Arbitrum,o.Avalanche,o.Optimism,o.BinanceSmartChain,o.Base,o.Polygon,o.Ethereum,async()=>{let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");return await e(s,r)}).with(o.Litecoin,o.Dash,o.Dogecoin,o.BitcoinCash,o.Bitcoin,o.Zcash,async()=>{let{getUtxoToolbox:e}=await import("@swapkit/toolboxes/utxo");return await e(s,r)}).with(o.Cosmos,o.Kujira,o.Maya,o.THORChain,async()=>{let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos");return await e(s,r)}).with(o.Chainflip,o.Polkadot,async()=>{let{getSubstrateToolbox:e}=await import("@swapkit/toolboxes/substrate");return await e(s,r)}).with(o.Radix,async()=>{let{RadixToolbox:e}=await import("@swapkit/toolboxes/radix");return await e(r)}).with(o.Ripple,async()=>{let{getRippleToolbox:e}=await import("@swapkit/toolboxes/ripple");return await e(r)}).with(o.Solana,async()=>{let{getSolanaToolbox:e}=await import("@swapkit/toolboxes/solana");return await e(r)}).with(o.Tron,async()=>{let{createTronToolbox:e}=await import("@swapkit/toolboxes/tron");return await e(r)}).with(o.Near,async()=>{let{getNearToolbox:e}=await import("@swapkit/toolboxes/near");return await e(r)}).otherwise(()=>{throw new g("toolbox_not_supported",{chain:s})})}export{m as getToolbox,k as getFeeEstimator,S as getAddressValidator};
2
2
 
3
- //# debugId=2C52B980D6A8E65164756E2164756E21
3
+ //# debugId=CA6DFCC222439EC364756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,9 +2,9 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n Chain,\n type CosmosChain,\n type EVMChain,\n FeeOption,\n type GenericCreateTransactionParams,\n type SubstrateChain,\n SwapKitError,\n type UTXOChain,\n} from \"@swapkit/helpers\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\n\nimport type { ETHToolbox, EVMCreateTransactionParams, getEvmToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { RadixToolbox } from \"@swapkit/toolboxes/radix\";\nimport type { getRippleToolbox } from \"@swapkit/toolboxes/ripple\";\nimport type { SolanaCreateTransactionParams, getSolanaToolbox } from \"@swapkit/toolboxes/solana\";\nimport type { getSubstrateToolbox } from \"@swapkit/toolboxes/substrate\";\nimport type { createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { getUtxoToolbox } from \"@swapkit/toolboxes/utxo\";\n\nexport async function getAddressValidator() {\n const { match } = await import(\"ts-pattern\");\n const { cosmosValidateAddress } = await import(\"@swapkit/toolboxes/cosmos\");\n const { evmValidateAddress } = await import(\"@swapkit/toolboxes/evm\");\n const { substrateValidateAddress } = await import(\"@swapkit/toolboxes/substrate\");\n const { getUTXOAddressValidator } = await import(\"@swapkit/toolboxes/utxo\");\n const { getSolanaAddressValidator } = await import(\"@swapkit/toolboxes/solana\");\n const { validateNearAddress } = await import(\"@swapkit/toolboxes/near\");\n const { rippleValidateAddress } = await import(\"@swapkit/toolboxes/ripple\");\n const { radixValidateAddress } = await import(\"@swapkit/toolboxes/radix\");\n const { getTronAddressValidator } = await import(\"@swapkit/toolboxes/tron\");\n\n const solanaValidateAddress = await getSolanaAddressValidator();\n const utxoValidateAddress = await getUTXOAddressValidator();\n const tronValidateAddress = await getTronAddressValidator();\n\n return function validateAddress({ address, chain }: { address: string; chain: Chain }) {\n const isValid = match(chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n () => evmValidateAddress({ address }),\n )\n .with(Chain.Litecoin, Chain.Dash, Chain.Dogecoin, Chain.BitcoinCash, Chain.Bitcoin, () =>\n utxoValidateAddress({ address, chain: chain as UTXOChain }),\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () =>\n cosmosValidateAddress({ address, chain: chain as CosmosChain }),\n )\n .with(Chain.Chainflip, Chain.Polkadot, () =>\n substrateValidateAddress({ address, chain: chain as SubstrateChain }),\n )\n .with(Chain.Radix, () => radixValidateAddress(address))\n .with(Chain.Near, () => validateNearAddress(address))\n .with(Chain.Ripple, () => rippleValidateAddress(address))\n .with(Chain.Solana, () => solanaValidateAddress(address))\n .with(Chain.Tron, () => tronValidateAddress(address))\n .otherwise(() => false);\n\n return isValid;\n };\n}\n\nexport function getFeeEstimator<T extends keyof CreateTransactionParams>(chain: T) {\n return async function estimateFee(params: CreateTransactionParams[T]) {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<AssetValue>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n const txObject = await toolbox.createTransaction(params);\n\n return (toolbox as Awaited<ReturnType<typeof ETHToolbox>>).estimateTransactionFee({\n ...txObject,\n feeOption: params.feeOptionKey || FeeOption.Fast,\n chain,\n });\n },\n )\n .with(\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Litecoin,\n Chain.Polkadot,\n Chain.Solana,\n Chain.Ripple,\n Chain.Tron,\n Chain.Near,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n return toolbox.estimateTransactionFee(params) as Promise<AssetValue>;\n },\n )\n .with(Chain.THORChain, Chain.Maya, Chain.Kujira, Chain.Cosmos, async () => {\n const { estimateTransactionFee } = await import(\"@swapkit/toolboxes/cosmos\");\n return estimateTransactionFee(params);\n })\n .otherwise(async () => AssetValue.from({ chain }));\n };\n}\n\ntype Toolboxes = {\n [key in EVMChain]: Awaited<ReturnType<typeof getEvmToolbox>>;\n} & {\n [key in UTXOChain]: Awaited<ReturnType<typeof getUtxoToolbox>>;\n} & {\n [key in CosmosChain]: Awaited<ReturnType<typeof getCosmosToolbox>>;\n} & {\n [key in SubstrateChain]: Awaited<ReturnType<typeof getSubstrateToolbox>>;\n} & {\n [Chain.Radix]: Awaited<ReturnType<typeof RadixToolbox>>;\n [Chain.Near]: Awaited<ReturnType<typeof getNearToolbox>>;\n [Chain.Ripple]: Awaited<ReturnType<typeof getRippleToolbox>>;\n [Chain.Solana]: Awaited<ReturnType<typeof getSolanaToolbox>>;\n [Chain.Tron]: Awaited<ReturnType<typeof createTronToolbox>>;\n};\n\ntype ToolboxParams = { [key in EVMChain]: Parameters<typeof getEvmToolbox>[1] } & {\n [key in UTXOChain]: undefined;\n} & {\n [key in CosmosChain]: Parameters<typeof getCosmosToolbox>[1];\n} & {\n [key in SubstrateChain]: Parameters<typeof getSubstrateToolbox>[1];\n} & {\n [Chain.Radix]: Parameters<typeof RadixToolbox>[0];\n [Chain.Near]: Parameters<typeof getNearToolbox>[0];\n [Chain.Ripple]: Parameters<typeof getRippleToolbox>[0];\n [Chain.Solana]: Parameters<typeof getSolanaToolbox>[0];\n [Chain.Tron]: Parameters<typeof createTronToolbox>[0];\n};\n\ntype CreateTransactionParams = { [key in EVMChain]: EVMCreateTransactionParams } & {\n [key in UTXOChain]: GenericCreateTransactionParams;\n} & {\n [key in CosmosChain]: GenericCreateTransactionParams;\n} & {\n [key in SubstrateChain]: GenericCreateTransactionParams;\n} & {\n [Chain.Radix]: GenericCreateTransactionParams;\n [Chain.Ripple]: GenericCreateTransactionParams;\n [Chain.Near]: GenericCreateTransactionParams;\n [Chain.Solana]: SolanaCreateTransactionParams;\n [Chain.Tron]: GenericCreateTransactionParams;\n};\n\nexport async function getToolbox<T extends keyof Toolboxes>(\n chain: T,\n params?: ToolboxParams[T],\n): Promise<Toolboxes[T]> {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<Toolboxes[T]>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async () => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const evmToolbox = await getEvmToolbox(\n chain as EVMChain,\n params as Parameters<typeof getEvmToolbox>[1],\n );\n return evmToolbox as Toolboxes[T];\n },\n )\n .with(\n Chain.Litecoin,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.BitcoinCash,\n Chain.Bitcoin,\n Chain.Zcash,\n async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const utxoToolbox = await getUtxoToolbox(\n chain as UTXOChain,\n params as Parameters<typeof getUtxoToolbox>[1],\n );\n return utxoToolbox as Toolboxes[T];\n },\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const cosmosToolbox = await getCosmosToolbox(\n chain as CosmosChain,\n params as Parameters<typeof getCosmosToolbox>[1],\n );\n return cosmosToolbox as Toolboxes[T];\n })\n .with(Chain.Chainflip, Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const substrateToolbox = await getSubstrateToolbox(\n chain as SubstrateChain,\n params as Parameters<typeof getSubstrateToolbox>[1],\n );\n return substrateToolbox as Toolboxes[T];\n })\n .with(Chain.Radix, async () => {\n const { RadixToolbox } = await import(\"@swapkit/toolboxes/radix\");\n const radixToolbox = await RadixToolbox(params as Parameters<typeof RadixToolbox>[0]);\n return radixToolbox as Toolboxes[T];\n })\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const rippleToolbox = await getRippleToolbox(\n params as Parameters<typeof getRippleToolbox>[0],\n );\n return rippleToolbox as Toolboxes[T];\n })\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaToolbox = await getSolanaToolbox(\n params as Parameters<typeof getSolanaToolbox>[0],\n );\n return solanaToolbox as Toolboxes[T];\n })\n .with(Chain.Tron, async () => {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const tronToolbox = await createTronToolbox(params);\n return tronToolbox as Toolboxes[T];\n })\n .with(Chain.Near, async () => {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const nearToolbox = await getNearToolbox(params as Parameters<typeof getNearToolbox>[0]);\n return nearToolbox as Toolboxes[T];\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_not_supported\", { chain });\n });\n}\n"
5
+ "import {\n AssetValue,\n Chain,\n type CosmosChain,\n type EVMChain,\n FeeOption,\n type GenericCreateTransactionParams,\n type SubstrateChain,\n SwapKitError,\n type UTXOChain,\n} from \"@swapkit/helpers\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\n\nimport type { ETHToolbox, EVMCreateTransactionParams, getEvmToolbox } from \"@swapkit/toolboxes/evm\";\nimport type { getNearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { RadixToolbox } from \"@swapkit/toolboxes/radix\";\nimport type { getRippleToolbox } from \"@swapkit/toolboxes/ripple\";\nimport type { SolanaCreateTransactionParams, getSolanaToolbox } from \"@swapkit/toolboxes/solana\";\nimport type { getSubstrateToolbox } from \"@swapkit/toolboxes/substrate\";\nimport type { createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { getUtxoToolbox } from \"@swapkit/toolboxes/utxo\";\n\nexport async function getAddressValidator() {\n const { match } = await import(\"ts-pattern\");\n const { cosmosValidateAddress } = await import(\"@swapkit/toolboxes/cosmos\");\n const { evmValidateAddress } = await import(\"@swapkit/toolboxes/evm\");\n const { substrateValidateAddress } = await import(\"@swapkit/toolboxes/substrate\");\n const { getUTXOAddressValidator } = await import(\"@swapkit/toolboxes/utxo\");\n const { getSolanaAddressValidator } = await import(\"@swapkit/toolboxes/solana\");\n const { getValidateNearAddress } = await import(\"@swapkit/toolboxes/near\");\n const { rippleValidateAddress } = await import(\"@swapkit/toolboxes/ripple\");\n const { radixValidateAddress } = await import(\"@swapkit/toolboxes/radix\");\n const { getTronAddressValidator } = await import(\"@swapkit/toolboxes/tron\");\n\n const solanaValidateAddress = await getSolanaAddressValidator();\n const utxoValidateAddress = await getUTXOAddressValidator();\n const tronValidateAddress = await getTronAddressValidator();\n const nearValidateAddress = await getValidateNearAddress();\n\n return function validateAddress({ address, chain }: { address: string; chain: Chain }) {\n const isValid = match(chain)\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n () => evmValidateAddress({ address }),\n )\n .with(Chain.Litecoin, Chain.Dash, Chain.Dogecoin, Chain.BitcoinCash, Chain.Bitcoin, () =>\n utxoValidateAddress({ address, chain: chain as UTXOChain }),\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, () =>\n cosmosValidateAddress({ address, chain: chain as CosmosChain }),\n )\n .with(Chain.Chainflip, Chain.Polkadot, () =>\n substrateValidateAddress({ address, chain: chain as SubstrateChain }),\n )\n .with(Chain.Radix, () => radixValidateAddress(address))\n .with(Chain.Near, () => nearValidateAddress(address))\n .with(Chain.Ripple, () => rippleValidateAddress(address))\n .with(Chain.Solana, () => solanaValidateAddress(address))\n .with(Chain.Tron, () => tronValidateAddress(address))\n .otherwise(() => false);\n\n return isValid;\n };\n}\n\nexport function getFeeEstimator<T extends keyof CreateTransactionParams>(chain: T) {\n return async function estimateFee(params: CreateTransactionParams[T]) {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<AssetValue>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n const txObject = await toolbox.createTransaction(params);\n\n return (toolbox as Awaited<ReturnType<typeof ETHToolbox>>).estimateTransactionFee({\n ...txObject,\n feeOption: params.feeOptionKey || FeeOption.Fast,\n chain,\n });\n },\n )\n .with(\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Dogecoin,\n Chain.Dash,\n Chain.Litecoin,\n Chain.Polkadot,\n Chain.Solana,\n Chain.Ripple,\n Chain.Tron,\n Chain.Near,\n async (chain) => {\n const toolbox = await getToolbox(chain);\n return toolbox.estimateTransactionFee(params) as Promise<AssetValue>;\n },\n )\n .with(Chain.THORChain, Chain.Maya, Chain.Kujira, Chain.Cosmos, async () => {\n const { estimateTransactionFee } = await import(\"@swapkit/toolboxes/cosmos\");\n return estimateTransactionFee(params);\n })\n .otherwise(async () => AssetValue.from({ chain }));\n };\n}\n\ntype Toolboxes = {\n [key in EVMChain]: Awaited<ReturnType<typeof getEvmToolbox>>;\n} & {\n [key in UTXOChain]: Awaited<ReturnType<typeof getUtxoToolbox>>;\n} & {\n [key in CosmosChain]: Awaited<ReturnType<typeof getCosmosToolbox>>;\n} & {\n [key in SubstrateChain]: Awaited<ReturnType<typeof getSubstrateToolbox>>;\n} & {\n [Chain.Radix]: Awaited<ReturnType<typeof RadixToolbox>>;\n [Chain.Near]: Awaited<ReturnType<typeof getNearToolbox>>;\n [Chain.Ripple]: Awaited<ReturnType<typeof getRippleToolbox>>;\n [Chain.Solana]: Awaited<ReturnType<typeof getSolanaToolbox>>;\n [Chain.Tron]: Awaited<ReturnType<typeof createTronToolbox>>;\n};\n\ntype ToolboxParams = { [key in EVMChain]: Parameters<typeof getEvmToolbox>[1] } & {\n [key in UTXOChain]: undefined;\n} & {\n [key in CosmosChain]: Parameters<typeof getCosmosToolbox>[1];\n} & {\n [key in SubstrateChain]: Parameters<typeof getSubstrateToolbox>[1];\n} & {\n [Chain.Radix]: Parameters<typeof RadixToolbox>[0];\n [Chain.Near]: Parameters<typeof getNearToolbox>[0];\n [Chain.Ripple]: Parameters<typeof getRippleToolbox>[0];\n [Chain.Solana]: Parameters<typeof getSolanaToolbox>[0];\n [Chain.Tron]: Parameters<typeof createTronToolbox>[0];\n};\n\ntype CreateTransactionParams = { [key in EVMChain]: EVMCreateTransactionParams } & {\n [key in UTXOChain]: GenericCreateTransactionParams;\n} & {\n [key in CosmosChain]: GenericCreateTransactionParams;\n} & {\n [key in SubstrateChain]: GenericCreateTransactionParams;\n} & {\n [Chain.Radix]: GenericCreateTransactionParams;\n [Chain.Ripple]: GenericCreateTransactionParams;\n [Chain.Near]: GenericCreateTransactionParams;\n [Chain.Solana]: SolanaCreateTransactionParams;\n [Chain.Tron]: GenericCreateTransactionParams;\n};\n\nexport async function getToolbox<T extends keyof Toolboxes>(\n chain: T,\n params?: ToolboxParams[T],\n): Promise<Toolboxes[T]> {\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .returnType<Promise<Toolboxes[T]>>()\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Optimism,\n Chain.BinanceSmartChain,\n Chain.Base,\n Chain.Polygon,\n Chain.Ethereum,\n async () => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const evmToolbox = await getEvmToolbox(\n chain as EVMChain,\n params as Parameters<typeof getEvmToolbox>[1],\n );\n return evmToolbox as Toolboxes[T];\n },\n )\n .with(\n Chain.Litecoin,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.BitcoinCash,\n Chain.Bitcoin,\n Chain.Zcash,\n async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const utxoToolbox = await getUtxoToolbox(\n chain as UTXOChain,\n params as Parameters<typeof getUtxoToolbox>[1],\n );\n return utxoToolbox as Toolboxes[T];\n },\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const cosmosToolbox = await getCosmosToolbox(\n chain as CosmosChain,\n params as Parameters<typeof getCosmosToolbox>[1],\n );\n return cosmosToolbox as Toolboxes[T];\n })\n .with(Chain.Chainflip, Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const substrateToolbox = await getSubstrateToolbox(\n chain as SubstrateChain,\n params as Parameters<typeof getSubstrateToolbox>[1],\n );\n return substrateToolbox as Toolboxes[T];\n })\n .with(Chain.Radix, async () => {\n const { RadixToolbox } = await import(\"@swapkit/toolboxes/radix\");\n const radixToolbox = await RadixToolbox(params as Parameters<typeof RadixToolbox>[0]);\n return radixToolbox as Toolboxes[T];\n })\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const rippleToolbox = await getRippleToolbox(\n params as Parameters<typeof getRippleToolbox>[0],\n );\n return rippleToolbox as Toolboxes[T];\n })\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaToolbox = await getSolanaToolbox(\n params as Parameters<typeof getSolanaToolbox>[0],\n );\n return solanaToolbox as Toolboxes[T];\n })\n .with(Chain.Tron, async () => {\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const tronToolbox = await createTronToolbox(params);\n return tronToolbox as Toolboxes[T];\n })\n .with(Chain.Near, async () => {\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n const nearToolbox = await getNearToolbox(params as Parameters<typeof getNearToolbox>[0]);\n return nearToolbox as Toolboxes[T];\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_not_supported\", { chain });\n });\n}\n"
6
6
  ],
7
- "mappings": "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",
8
- "debugId": "2C52B980D6A8E65164756E2164756E21",
7
+ "mappings": "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",
8
+ "debugId": "CA6DFCC222439EC364756E2164756E21",
9
9
  "names": []
10
10
  }
@@ -1,4 +1,4 @@
1
- var D1={};H1(D1,{validateNearAddress:()=>T,tgasToGas:()=>e,isSimpleTransfer:()=>C,isCustomEstimator:()=>g,isContractDeployment:()=>A,isContractCall:()=>K,isBatchTransaction:()=>I,isAccountCreation:()=>h,getNearToolbox:()=>f1,getNearSignerFromPrivateKey:()=>G,getNearSignerFromPhrase:()=>P,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>l,gasToTGas:()=>t,estimateBatchGas:()=>S,createNearContract:()=>O,createNEP141Token:()=>F,GAS_COSTS:()=>D});module.exports=R1(D1);var q=require("@swapkit/helpers");var E=require("@swapkit/helpers"),n=require("near-api-js");async function T(W){try{let{validateAccountId:Z}=await import("near-sdk-js");return Z(W)}catch{let Z=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return W.length>=2&&W.length<=64&&Z.test(W)}}async function P(W){let{parseSeedPhrase:Z}=await import("near-seed-phrase"),{KeyPair:f}=await import("near-api-js"),M=W.index||0,$=W.derivationPath?E.derivationPathToString(W.derivationPath.slice(0,3)):`m/44'/397'/${M}'`,{secretKey:X}=Z(W.phrase,$),z=f.fromString(X);return s(z)}async function G(W){let{KeyPair:Z}=await import("near-api-js/lib/utils"),f=Z.fromString(W);return s(f)}class c extends n.KeyPairSigner{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Z=Buffer.from(W.data).toString("hex");return Promise.resolve(Z)}}function s(W){return new c(W)}async function b(W,Z){let M=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Z})).keys.find((V)=>V.access_key.permission==="FullAccess");if(!M)throw new E.SwapKitError("toolbox_near_invalid_address");let{utils:$}=await import("near-api-js"),X=$.PublicKey.fromString(M.public_key),z=M.access_key.nonce||0;return{publicKey:X,nonce:z}}var D={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function C(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function K(W){return"contractId"in W&&"methodName"in W}function I(W){return"actions"in W}function h(W){return"newAccountId"in W}function A(W){return"contractCode"in W}function g(W){return"customEstimator"in W}function S(W){let Z=0;for(let f of W)switch(f.enum){case"transfer":Z+=Number(D.SIMPLE_TRANSFER);break;case"functionCall":Z+=Number(D.CONTRACT_CALL);break;case"createAccount":Z+=Number(D.ACCOUNT_CREATION);break;case"deployContract":Z+=Number(D.CONTRACT_DEPLOYMENT);break;case"addKey":Z+=Number(D.ACCESS_KEY_ADDITION);break;case"deleteKey":Z+=Number(D.ACCESS_KEY_DELETION);break;case"stake":Z+=Number(D.STAKE);break;default:Z+=Number(D.CONTRACT_CALL)}return Z.toString()}function l(W){if(W==="ft_transfer"||W==="ft_transfer_call")return D.TOKEN_TRANSFER;if(W==="storage_deposit")return D.STORAGE_DEPOSIT;return D.CONTRACT_CALL}function e(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function t(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var r="1250000000000000000000";async function F({contractId:W,account:Z}){let f=(await import("bn.js")).default,M=await O({account:Z,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),$=async(X)=>{if(!await M.storage_balance_of({account_id:X})){let B=(await M.storage_balance_bounds())?.min||r;await M.storage_deposit({account_id:X},new f("100000000000000"),new f(B))}};return{transfer:async(X,z,V)=>{return await $(X),M.ft_transfer({receiver_id:X,amount:z,memo:V},new f("100000000000000"),new f("1"))},transferCall:async(X,z,V,B)=>{return await $(X),M.ft_transfer_call({receiver_id:X,amount:z,memo:B,msg:V},new f("100000000000000"),new f("1"))},balanceOf:(X)=>M.ft_balance_of({account_id:X}),totalSupply:()=>M.ft_total_supply(),metadata:()=>M.ft_metadata(),storageBalanceOf:(X)=>M.storage_balance_of({account_id:X}),storageDeposit:(X,z)=>M.storage_deposit({account_id:X},new f("100000000000000"),new f(z||r)),ensureStorage:$,contract:M}}async function f1(W){let{P:Z,match:f}=await import("ts-pattern"),{providers:M}=await import("near-api-js"),$=await f(W).with({phrase:Z.string},async(x)=>{return await P(x)}).with({signer:Z.any},({signer:x})=>x).otherwise(()=>{return}),X=q.SKConfig.get("rpcUrls")[q.Chain.Near],z=new M.JsonRpcProvider({url:X});async function V(x){let{Account:J}=await import("near-api-js"),Q=x||await B();return new J(Q,z,$)}async function B(){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");return await $.getAddress()}async function a(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{recipient:J,assetValue:Q}=x;if(!T(J))throw new q.SwapKitError("toolbox_near_invalid_address");let Y=await V();if(Q.isGasAsset===!1){let L=Q.address;if(!L)throw new q.SwapKitError("toolbox_near_missing_contract_address");let R=Q.getBaseValue("string");return m({contractId:L,methodName:"ft_transfer",args:{receiver_id:J,amount:R,memo:x.memo}})}try{let L=Q.getBaseValue("string");return(await Y.transfer({receiverId:J,amount:L})).transaction.hash}catch(L){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:L})}}async function x1(x){let{recipient:J,assetValue:Q,memo:Y,feeRate:L,attachedDeposit:R,sender:U}=x;if(!Q.isGasAsset){let i=Q.address;if(!i)throw new q.SwapKitError("toolbox_near_missing_contract_address");return u({sender:U,contractId:i,methodName:"ft_transfer",args:{receiver_id:J,amount:Q.getBaseValue("string"),memo:Y||null},gas:L.toString()||"100000000000000",attachedDeposit:"1"})}let{publicKey:w,nonce:j}=await b(z,U),k=Q.getBaseValue("bigint"),{SCHEMA:v}=await import("near-api-js/lib/transaction"),{transactions:N,utils:_}=await import("near-api-js"),p=[N.transfer(k)];if(Y&&R)p.push(N.functionCall("memo",{memo:Y},BigInt(L),BigInt(R)));let M1=await z.block({finality:"final"}),o=_.serialize.base_decode(M1.header.hash),Y1=N.createTransaction(U,w,J,j,p,o),U1=_.serialize.serialize(v.Transaction,Y1);return{serialized:Buffer.from(U1).toString("base64"),publicKey:w.toString(),details:{signerId:U,nonce:j,blockHash:_.serialize.base_encode(o)}}}async function u(x){let{sender:J}=x,{publicKey:Q,nonce:Y}=await b(z,J),{SCHEMA:L}=await import("near-api-js/lib/transaction"),{transactions:R,utils:U}=await import("near-api-js"),w=await z.block({finality:"final"}),j=U.serialize.base_decode(w.header.hash),k=[R.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],v=R.createTransaction(J,Q,x.contractId,Y,k,j),N=U.serialize.serialize(L.Transaction,v);return{serialized:Buffer.from(N).toString("base64"),publicKey:Q.toString(),details:{signerId:J,receiverId:x.contractId,methodName:x.methodName,nonce:Y,blockHash:U.serialize.base_encode(j)}}}async function W1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let[J,Q]=await $.signTransaction(x);return Q}async function q1(x){return(await z.sendTransaction(x)).transaction.hash}async function J1(x){if("assetValue"in x){let L=BigInt("115123062500")+BigInt("108059500000"),R=await Q1(),U=L*BigInt(R.toString());return q.AssetValue.from({chain:q.Chain.Near,value:U.toString(),fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}let J=$?await V():void 0;return y(x,J)}async function Q1(){try{return await z.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function Z1(x,J,Q){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let Y=await V(),{utils:L}=await import("near-api-js"),R=L.format.parseNearAmount(Q)||"0";return(await Y.createAccount(x,L.PublicKey.fromString(J),BigInt(R))).transaction.hash}async function m(x){try{if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{transactions:J}=await import("near-api-js"),{contractId:Q,methodName:Y,args:L,deposit:R}=x,U=await V(),w=await y({methodName:Y,args:L||{},contractId:Q}),j=J.functionCall(Y,L||{},w.getBaseValue("bigint"),BigInt(R||"0"));return(await U.signAndSendTransaction({receiverId:Q,actions:[j]})).transaction.hash}catch(J){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:J})}}async function $1(x){let{createNearContract:J}=await import("../../chunk-vtd17cje.js"),Q=await V();return J({account:Q,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function X1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");if(x.actions.length===0)throw new q.SwapKitError("toolbox_near_empty_batch");return(await(await V()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function z1(x){let J=await V();return F({contractId:x,account:J})}async function L1(x){try{let J=await V(x),Q;try{let Y=await J.getBalance();Q=q.AssetValue.from({chain:q.Chain.Near,value:Y,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}catch{Q=q.AssetValue.from({chain:q.Chain.Near,value:"0",fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}return[Q]}catch(J){throw new q.SwapKitError("toolbox_near_balance_failed",{error:J})}}async function y(x,J){let Q=await f(x).when(C,()=>D.SIMPLE_TRANSFER).when(K,(U)=>l(U.methodName)).when(I,(U)=>S(U.actions)).when(h,()=>D.ACCOUNT_CREATION).when(A,()=>D.CONTRACT_DEPLOYMENT).when(g,(U)=>{if(!J)throw new q.SwapKitError("toolbox_near_no_account");return U.customEstimator(J)}).otherwise(()=>{throw new q.SwapKitError("toolbox_near_invalid_gas_params")}),Y=await d(),R=BigInt(Q)*BigInt(1000000000000)*BigInt(Y);return q.AssetValue.from({chain:q.Chain.Near,value:R,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}async function d(){try{return(await z.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:B,getPublicKey:async()=>$?(await $.getPublicKey()).toString():"",provider:z,transfer:a,createTransaction:x1,createContractFunctionCall:u,estimateTransactionFee:J1,broadcastTransaction:q1,signTransaction:W1,getBalance:L1,validateAddress:T,getSignerFromPhrase:(x)=>P(x),getSignerFromPrivateKey:G,callFunction:m,createSubAccount:Z1,createContract:$1,executeBatchTransaction:X1,nep141:z1,getGasPrice:d,estimateGas:y}}
1
+ var j1={};D1(j1,{tgasToGas:()=>e,isSimpleTransfer:()=>K,isCustomEstimator:()=>S,isContractDeployment:()=>g,isContractCall:()=>h,isBatchTransaction:()=>I,isAccountCreation:()=>A,getValidateNearAddress:()=>k,getNearToolbox:()=>R1,getNearSignerFromPrivateKey:()=>C,getNearSignerFromPhrase:()=>E,getFullAccessPublicKey:()=>P,getContractMethodGas:()=>u,gasToTGas:()=>r,estimateBatchGas:()=>l,createNearContract:()=>w,createNEP141Token:()=>_,GAS_COSTS:()=>H});module.exports=H1(j1);var q=require("@swapkit/helpers");var T=require("@swapkit/helpers"),c=require("near-api-js");async function k(){let{validateAccountId:W}=await import("near-sdk-js");return(Z)=>{try{return W(Z)}catch{let X=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return Z.length>=2&&Z.length<=64&&X.test(Z)}}}async function E(W){let{parseSeedPhrase:Z}=await import("near-seed-phrase"),{KeyPair:X}=await import("near-api-js"),U=W.index||0,z=W.derivationPath?T.derivationPathToString(W.derivationPath.slice(0,3)):`m/44'/397'/${U}'`,{secretKey:L}=Z(W.phrase,z),M=X.fromString(L);return t(M)}async function C(W){let{KeyPair:Z}=await import("near-api-js/lib/utils"),X=Z.fromString(W);return t(X)}class s extends c.KeyPairSigner{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Z=Buffer.from(W.data).toString("hex");return Promise.resolve(Z)}}function t(W){return new s(W)}async function P(W,Z){let U=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Z})).keys.find((D)=>D.access_key.permission==="FullAccess");if(!U)throw new T.SwapKitError("toolbox_near_invalid_address");let{utils:z}=await import("near-api-js"),L=z.PublicKey.fromString(U.public_key),M=U.access_key.nonce||0;return{publicKey:L,nonce:M}}var H={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function K(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function h(W){return"contractId"in W&&"methodName"in W}function I(W){return"actions"in W}function A(W){return"newAccountId"in W}function g(W){return"contractCode"in W}function S(W){return"customEstimator"in W}function l(W){let Z=0;for(let X of W)switch(X.enum){case"transfer":Z+=Number(H.SIMPLE_TRANSFER);break;case"functionCall":Z+=Number(H.CONTRACT_CALL);break;case"createAccount":Z+=Number(H.ACCOUNT_CREATION);break;case"deployContract":Z+=Number(H.CONTRACT_DEPLOYMENT);break;case"addKey":Z+=Number(H.ACCESS_KEY_ADDITION);break;case"deleteKey":Z+=Number(H.ACCESS_KEY_DELETION);break;case"stake":Z+=Number(H.STAKE);break;default:Z+=Number(H.CONTRACT_CALL)}return Z.toString()}function u(W){if(W==="ft_transfer"||W==="ft_transfer_call")return H.TOKEN_TRANSFER;if(W==="storage_deposit")return H.STORAGE_DEPOSIT;return H.CONTRACT_CALL}function e(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function r(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var a="1250000000000000000000";async function _({contractId:W,account:Z}){let X=(await import("bn.js")).default,U=await w({account:Z,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),z=async(L)=>{if(!await U.storage_balance_of({account_id:L})){let B=(await U.storage_balance_bounds())?.min||a;await U.storage_deposit({account_id:L},new X("100000000000000"),new X(B))}};return{transfer:async(L,M,D)=>{return await z(L),U.ft_transfer({receiver_id:L,amount:M,memo:D},new X("100000000000000"),new X("1"))},transferCall:async(L,M,D,B)=>{return await z(L),U.ft_transfer_call({receiver_id:L,amount:M,memo:B,msg:D},new X("100000000000000"),new X("1"))},balanceOf:(L)=>U.ft_balance_of({account_id:L}),totalSupply:()=>U.ft_total_supply(),metadata:()=>U.ft_metadata(),storageBalanceOf:(L)=>U.storage_balance_of({account_id:L}),storageDeposit:(L,M)=>U.storage_deposit({account_id:L},new X("100000000000000"),new X(M||a)),ensureStorage:z,contract:U}}async function R1(W){let{P:Z,match:X}=await import("ts-pattern"),{providers:U}=await import("near-api-js"),z=await X(W).with({phrase:Z.string},async(x)=>{return await E(x)}).with({signer:Z.any},({signer:x})=>x).otherwise(()=>{return}),L=q.SKConfig.get("rpcUrls")[q.Chain.Near],M=new U.JsonRpcProvider({url:L});async function D(x){let{Account:J}=await import("near-api-js"),Q=x||await B();return new J(Q,M,z)}async function B(){if(!z)throw new q.SwapKitError("toolbox_near_no_signer");return await z.getAddress()}async function x1(x){if(!z)throw new q.SwapKitError("toolbox_near_no_signer");let{recipient:J,assetValue:Q}=x;if(!(await k())(J))throw new q.SwapKitError("toolbox_near_invalid_address");let j=await D();if(Q.isGasAsset===!1){let Y=Q.address;if(!Y)throw new q.SwapKitError("toolbox_near_missing_contract_address");let $=Q.getBaseValue("string");return p({contractId:Y,methodName:"ft_transfer",args:{receiver_id:J,amount:$,memo:x.memo}})}try{let Y=Q.getBaseValue("string");return(await j.transfer({receiverId:J,amount:Y})).transaction_outcome.id}catch(Y){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:Y})}}async function W1(x){let{recipient:J,assetValue:Q,memo:f,feeRate:j,attachedDeposit:Y,sender:$}=x,O=await k();if(!O(J))throw new q.SwapKitError("toolbox_near_invalid_address",{address:J});if(!O($))throw new q.SwapKitError("toolbox_near_invalid_address",{address:$});if(!Q.isGasAsset){let n=Q.address;if(!n)throw new q.SwapKitError("toolbox_near_missing_contract_address");return m({sender:$,contractId:n,methodName:"ft_transfer",args:{receiver_id:J,amount:Q.getBaseValue("string"),memo:f||null},gas:j.toString()||"100000000000000",attachedDeposit:"1"})}let{publicKey:V,nonce:F}=await P(M,$),y=Q.getBaseValue("bigint"),{SCHEMA:v}=await import("near-api-js/lib/transaction"),{transactions:N,utils:G}=await import("near-api-js"),o=[N.transfer(y)];if(f&&Y)o.push(N.functionCall("memo",{memo:f},BigInt(j),BigInt(Y)));let Y1=await M.block({finality:"final"}),i=G.serialize.base_decode(Y1.header.hash),U1=N.createTransaction($,V,J,F,o,i),f1=G.serialize.serialize(v.Transaction,U1);return{serialized:Buffer.from(f1).toString("base64"),publicKey:V.toString(),details:{signerId:$,nonce:F,blockHash:G.serialize.base_encode(i)}}}async function m(x){let{sender:J}=x,{publicKey:Q,nonce:f}=await P(M,J),{SCHEMA:j}=await import("near-api-js/lib/transaction"),{transactions:Y,utils:$}=await import("near-api-js"),O=await M.block({finality:"final"}),V=$.serialize.base_decode(O.header.hash),F=[Y.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],y=Y.createTransaction(J,Q,x.contractId,f,F,V),v=$.serialize.serialize(j.Transaction,y);return{serialized:Buffer.from(v).toString("base64"),publicKey:Q.toString(),details:{signerId:J,receiverId:x.contractId,methodName:x.methodName,nonce:f,blockHash:$.serialize.base_encode(V)}}}async function q1(x){if(!z)throw new q.SwapKitError("toolbox_near_no_signer");let[J,Q]=await z.signTransaction(x);return Q}async function J1(x){return(await M.sendTransaction(x)).transaction.hash}async function Q1(x){if("assetValue"in x){let j=BigInt("115123062500")+BigInt("108059500000"),Y=await Z1(),$=j*BigInt(Y.toString());return q.AssetValue.from({chain:q.Chain.Near,value:$.toString(),fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}let J=z?await D():void 0;return b(x,J)}async function Z1(){try{return await M.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function $1(x,J,Q){if(!z)throw new q.SwapKitError("toolbox_near_no_signer");let f=await D(),{utils:j}=await import("near-api-js"),Y=j.format.parseNearAmount(Q)||"0";return(await f.createAccount(x,j.PublicKey.fromString(J),BigInt(Y))).transaction.hash}async function p(x){try{if(!z)throw new q.SwapKitError("toolbox_near_no_signer");let{transactions:J}=await import("near-api-js"),{contractId:Q,methodName:f,args:j,deposit:Y}=x,$=await D(),O=await b({methodName:f,args:j||{},contractId:Q}),V=J.functionCall(f,j||{},O.getBaseValue("bigint"),BigInt(Y||"0"));return(await $.signAndSendTransaction({receiverId:Q,actions:[V]})).transaction_outcome.id}catch(J){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:J})}}async function X1(x){let{createNearContract:J}=await import("../../chunk-vtd17cje.js"),Q=await D();return J({account:Q,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function z1(x){if(!z)throw new q.SwapKitError("toolbox_near_no_signer");if(x.actions.length===0)throw new q.SwapKitError("toolbox_near_empty_batch");return(await(await D()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function L1(x){let J=await D();return _({contractId:x,account:J})}async function M1(x){try{let J=await D(x),Q;try{let f=await J.getBalance();Q=q.AssetValue.from({chain:q.Chain.Near,value:f,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}catch{Q=q.AssetValue.from({chain:q.Chain.Near,value:"0",fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}return[Q]}catch(J){throw new q.SwapKitError("toolbox_near_balance_failed",{error:J})}}async function b(x,J){let Q=await X(x).when(K,()=>H.SIMPLE_TRANSFER).when(h,($)=>u($.methodName)).when(I,($)=>l($.actions)).when(A,()=>H.ACCOUNT_CREATION).when(g,()=>H.CONTRACT_DEPLOYMENT).when(S,($)=>{if(!J)throw new q.SwapKitError("toolbox_near_no_account");return $.customEstimator(J)}).otherwise(()=>{throw new q.SwapKitError("toolbox_near_invalid_gas_params")}),f=await d(),Y=BigInt(Q)*BigInt(1000000000000)*BigInt(f);return q.AssetValue.from({chain:q.Chain.Near,value:Y,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}async function d(){try{return(await M.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:B,getPublicKey:async()=>z?(await z.getPublicKey()).toString():"",provider:M,transfer:x1,createTransaction:W1,createContractFunctionCall:m,estimateTransactionFee:Q1,broadcastTransaction:J1,signTransaction:q1,getBalance:M1,validateAddress:await k(),getSignerFromPhrase:(x)=>E(x),getSignerFromPrivateKey:C,callFunction:p,createSubAccount:$1,createContract:X1,executeBatchTransaction:z1,nep141:L1,getGasPrice:d,estimateGas:b}}
2
2
 
3
- //# debugId=68F35FE5C1C424C564756E2164756E21
3
+ //# debugId=E8A3E4C4B7D4E9A364756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map