@swapkit/toolboxes 4.0.0-beta.37 → 4.0.0-beta.38
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.
- package/dist/chunk-0h4xdrwz.js +5 -0
- package/dist/{chunk-6f98phv2.js.map → chunk-0h4xdrwz.js.map} +2 -2
- package/dist/{chunk-5yxc1e69.js → chunk-fjfxga2v.js} +2 -2
- package/dist/{chunk-5yxc1e69.js.map → chunk-fjfxga2v.js.map} +1 -1
- package/dist/src/cosmos/index.cjs +2 -2
- package/dist/src/cosmos/index.cjs.map +4 -4
- package/dist/src/cosmos/index.js +2 -2
- package/dist/src/cosmos/index.js.map +4 -4
- package/dist/src/evm/index.js +1 -1
- package/dist/src/tron/index.cjs +2 -2
- package/dist/src/tron/index.cjs.map +6 -5
- package/dist/src/tron/index.js +2 -2
- package/dist/src/tron/index.js.map +6 -5
- package/dist/src/utxo/index.js +1 -1
- package/package.json +5 -5
- package/src/cosmos/toolbox/cosmos.ts +6 -1
- package/src/cosmos/util.ts +1 -1
- package/src/tron/helpers/trongrid.ts +54 -0
- package/src/tron/toolbox.ts +122 -33
- package/src/tron/types.ts +67 -0
- package/dist/chunk-6f98phv2.js +0 -5
|
@@ -4,13 +4,13 @@
|
|
|
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://
|
|
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://sdk.swapkit.dev\", referer: \"https://sdk.swapkit.dev\" };\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
|
-
"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",
|
|
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 getFeeRateFromSwapKit(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\n/**\n * @deprecated use getFeeRateFromSwapKit instead\n */\nexport const getFeeRateFromThorswap = getFeeRateFromSwapKit;\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",
|
|
11
11
|
"import type { Pubkey, Secp256k1HdWallet } from \"@cosmjs/amino\";\nimport { base64 } from \"@scure/base\";\nimport {\n BaseDecimal,\n Chain,\n CosmosChainPrefixes,\n FeeOption,\n type GenericTransferParams,\n NetworkDerivationPath,\n RequestClient,\n SKConfig,\n SwapKitError,\n SwapKitNumber,\n derivationPathToString,\n updateDerivationPath,\n} from \"@swapkit/helpers\";\n\nimport { P, match } from \"ts-pattern\";\nimport {\n buildAminoMsg,\n buildEncodedTxBody,\n convertToSignable,\n createDefaultAminoTypes,\n createDefaultRegistry,\n getCreateTransaction,\n parseAminoMessageForDirectSigning,\n} from \"../thorchainUtils\";\nimport type { ThorchainConstantsResponse } from \"../thorchainUtils/types/client-types\";\nimport type { MultisigTx } from \"../types\";\nimport type { CosmosToolboxParams, MultiSigSigner } from \"../types\";\nimport {\n createOfflineStargateClient,\n createSigningStargateClient,\n createStargateClient,\n getDefaultChainFee,\n} from \"../util\";\nimport { createCosmosToolbox } from \"./cosmos\";\n\nfunction secp256k1HdWalletFromMnemonic({\n prefix,\n derivationPath,\n}: {\n prefix: string;\n derivationPath?: string;\n}) {\n return async function secp256k1HdWalletFromMnemonic(mnemonic: string, index = 0) {\n const { Secp256k1HdWallet } = (await import(\"@cosmjs/amino\")).default;\n const { stringToPath } = (await import(\"@cosmjs/crypto\")).default;\n\n return Secp256k1HdWallet.fromMnemonic(mnemonic, {\n hdPaths: [stringToPath(`${derivationPath}/${index}`)],\n prefix,\n });\n };\n}\n\nfunction exportSignature(signature: Uint8Array) {\n return base64.encode(signature);\n}\n\nfunction signMultisigTx(chain: Chain.THORChain | Chain.Maya) {\n return async function signMultisigTx({\n wallet,\n tx,\n }: {\n wallet: Secp256k1HdWallet;\n tx: string | MultisigTx;\n }) {\n const { msgs, accountNumber, sequence, chainId, fee, memo } =\n typeof tx === \"string\" ? JSON.parse(tx) : tx;\n\n const address = (await wallet.getAccounts())?.[0]?.address || \"\";\n const aminoTypes = await createDefaultAminoTypes(chain);\n const registry = await createDefaultRegistry();\n const signingClient = await createOfflineStargateClient(wallet, {\n registry,\n aminoTypes,\n });\n const msgForSigning = [];\n\n for (const msg of msgs) {\n const signMsg = await convertToSignable(msg, chain);\n msgForSigning.push(signMsg);\n }\n\n const {\n signatures: [signature],\n } = await signingClient.sign(address, msgForSigning, fee, memo, {\n accountNumber,\n sequence,\n chainId,\n });\n\n const bodyBytes = await buildEncodedTxBody({\n chain,\n memo,\n msgs: msgs.map(parseAminoMessageForDirectSigning),\n });\n\n return { signature: exportSignature(signature as Uint8Array), bodyBytes };\n };\n}\n\nfunction broadcastMultisigTx({\n prefix,\n rpcUrl,\n}: {\n prefix: string;\n rpcUrl: string;\n}) {\n return async function broadcastMultisigTx(\n tx: string,\n signers: MultiSigSigner[],\n membersPubKeys: string[],\n threshold: number,\n bodyBytes: Uint8Array,\n ) {\n const { encodeSecp256k1Pubkey, pubkeyToAddress } = (await import(\"@cosmjs/amino\")).default;\n const { makeMultisignedTxBytes } = (await import(\"@cosmjs/stargate\")).default;\n\n const { sequence, fee } = JSON.parse(tx);\n const multisigPubkey = await createMultisig(membersPubKeys, threshold);\n\n const addressesAndSignatures: [string, Uint8Array][] = signers.map((signer) => [\n pubkeyToAddress(encodeSecp256k1Pubkey(base64.decode(signer.pubKey)), prefix),\n base64.decode(signer.signature),\n ]);\n\n const broadcaster = await createStargateClient(rpcUrl);\n\n const { transactionHash } = await broadcaster.broadcastTx(\n makeMultisignedTxBytes(\n multisigPubkey,\n sequence,\n fee,\n bodyBytes,\n new Map<string, Uint8Array>(addressesAndSignatures),\n ),\n );\n\n return transactionHash;\n };\n}\n\nasync function createMultisig(pubKeys: string[], threshold: number, noSortPubKeys = true) {\n const { createMultisigThresholdPubkey, encodeSecp256k1Pubkey } = (await import(\"@cosmjs/amino\"))\n .default;\n return createMultisigThresholdPubkey(\n pubKeys.map((pubKey) => encodeSecp256k1Pubkey(base64.decode(pubKey))),\n threshold,\n noSortPubKeys,\n );\n}\n\nfunction importSignature(signature: string) {\n return base64.decode(signature);\n}\n\nasync function signWithPrivateKey({\n privateKey,\n message,\n}: {\n privateKey: Uint8Array;\n message: string;\n}) {\n const { Secp256k1 } = (await import(\"@cosmjs/crypto\")).default;\n\n const signature = await Secp256k1.createSignature(base64.decode(message), privateKey);\n return base64.encode(Buffer.concat([signature.r(32), signature.s(32)]));\n}\n\nexport async function createThorchainToolbox({\n chain,\n ...toolboxParams\n}: CosmosToolboxParams<Chain.THORChain | Chain.Maya>) {\n const nodeUrl = SKConfig.get(\"nodeUrls\")[chain];\n const rpcUrl = SKConfig.get(\"rpcUrls\")[chain];\n const { isStagenet } = SKConfig.get(\"envs\");\n const isThorchain = chain === Chain.THORChain;\n const chainPrefix = `${isStagenet ? \"s\" : \"\"}${CosmosChainPrefixes[chain]}`;\n\n const index = \"index\" in toolboxParams ? toolboxParams.index || 0 : 0;\n\n const derivationPath =\n \"derivationPath\" in toolboxParams && toolboxParams.derivationPath\n ? toolboxParams.derivationPath\n : updateDerivationPath(NetworkDerivationPath[chain], { index });\n\n const cosmosToolbox = await createCosmosToolbox({\n chain,\n ...toolboxParams,\n });\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, ({ phrase }) =>\n cosmosToolbox.getSignerFromPhrase({ phrase, derivationPath }),\n )\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n const defaultFee = getDefaultChainFee(chain);\n\n async function getFees() {\n let fee: SwapKitNumber;\n\n const constantsUrl = `${nodeUrl}/${isThorchain ? \"thorchain\" : \"mayachain\"}/constants`;\n\n try {\n const {\n int_64_values: { NativeTransactionFee: nativeFee },\n } = await RequestClient.get<ThorchainConstantsResponse>(constantsUrl);\n\n if (!nativeFee || Number.isNaN(nativeFee) || nativeFee < 0) {\n throw new SwapKitError(\"toolbox_cosmos_invalid_fee\", { nativeFee: nativeFee.toString() });\n }\n\n fee = new SwapKitNumber(nativeFee);\n } catch {\n fee = new SwapKitNumber({\n value: isThorchain ? 0.02 : 1,\n decimal: BaseDecimal[chain],\n });\n }\n\n return { [FeeOption.Average]: fee, [FeeOption.Fast]: fee, [FeeOption.Fastest]: fee };\n }\n\n async function transfer({\n assetValue,\n memo = \"\",\n recipient,\n }: Omit<GenericTransferParams, \"recipient\"> & { recipient?: string }) {\n const { TxRaw } = await import(\"cosmjs-types/cosmos/tx/v1beta1/tx\");\n const sender = (await signer?.getAccounts())?.[0]?.address;\n if (!(sender && signer)) throw new SwapKitError(\"toolbox_cosmos_no_signer\");\n\n const isAminoSigner = \"signAmino\" in signer;\n const registry = await createDefaultRegistry();\n const aminoTypes = await createDefaultAminoTypes(chain);\n const signingClient = await createSigningStargateClient(rpcUrl, signer, {\n registry,\n aminoTypes,\n });\n\n const aminoMessage = buildAminoMsg({\n assetValue,\n sender,\n recipient,\n memo,\n });\n\n if (isAminoSigner) {\n const msgSign = await convertToSignable(aminoMessage, chain);\n\n const { signatures, authInfoBytes } = await signingClient.sign(\n sender,\n [msgSign],\n defaultFee,\n memo,\n );\n\n const tx = TxRaw.encode({\n signatures,\n authInfoBytes,\n bodyBytes: await buildEncodedTxBody({\n chain,\n msgs: [aminoMessage].map(parseAminoMessageForDirectSigning),\n memo,\n }),\n }).finish();\n\n const txResponse = await signingClient.broadcastTx(tx);\n\n return txResponse.transactionHash;\n }\n\n const preparedMessage = parseAminoMessageForDirectSigning(aminoMessage);\n const msgSign = await convertToSignable(preparedMessage, chain);\n const txResponse = await signingClient.signAndBroadcast(sender, [msgSign], defaultFee, memo);\n\n return txResponse.transactionHash;\n }\n\n return {\n ...cosmosToolbox,\n broadcastMultisigTx: broadcastMultisigTx({ prefix: chainPrefix, rpcUrl }),\n buildAminoMsg,\n buildEncodedTxBody,\n convertToSignable,\n createDefaultAminoTypes: () => createDefaultAminoTypes(chain),\n createDefaultRegistry,\n createMultisig,\n createTransaction: getCreateTransaction(rpcUrl),\n deposit: transfer,\n getFees,\n importSignature,\n parseAminoMessageForDirectSigning,\n secp256k1HdWalletFromMnemonic: secp256k1HdWalletFromMnemonic({\n derivationPath: derivationPathToString(derivationPath),\n prefix: chainPrefix,\n }),\n signMultisigTx: signMultisigTx(chain),\n signWithPrivateKey,\n transfer,\n pubkeyToAddress: async (pubkey: Pubkey) => {\n const { pubkeyToAddress } = (await import(\"@cosmjs/amino\")).default;\n return pubkeyToAddress(pubkey, chainPrefix);\n },\n };\n}\n"
|
|
12
12
|
],
|
|
13
|
-
"mappings": "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",
|
|
14
|
-
"debugId": "
|
|
13
|
+
"mappings": "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",
|
|
14
|
+
"debugId": "400B1DEE649380A164756E2164756E21",
|
|
15
15
|
"names": []
|
|
16
16
|
}
|
package/dist/src/evm/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{b as ut}from"../../chunk-6f98phv2.js";import{d as k,e as C}from"../../chunk-s47y8512.js";import{SKConfig as kt,warnOnce as Ct}from"@swapkit/helpers";function S(t){let u=kt.get("apis")[t];if(u)return Ct(!0,"Using custom EVM API. Be sure to implement all methods to avoid issues."),u;return Gt(t)}function cn(t){return t}function Gt(t){return{getBalance:ut(t)}}import{AssetValue as I,BaseDecimal as Pt,Chain as x,ChainToExplorerUrl as gt,ChainToHexChainId as It,FeeOption as pt,SKConfig as bt,SwapKitError as tt,SwapKitNumber as r}from"@swapkit/helpers";import{Chain as L,ContractAddress as q,FeeOption as T,SwapKitError as w,SwapKitNumber as yt,applyFeeMultiplierToBigInt as H,isGasAsset as Wt}from"@swapkit/helpers";import{erc20ABI as Z}from"@swapkit/helpers/contracts";import{BrowserProvider as $t,Contract as ot,Interface as et,getAddress as _}from"ethers";var F=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");function j({chain:t=L.Ethereum,provider:u,signer:n,isEIP1559Compatible:y=!0}){return{getAddress:()=>{return n?n.getAddress():void 0},call:v({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),estimateCall:at({provider:u,signer:n}),EIP1193SendTransaction:P(u),approve:St({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),approvedAmount:lt({provider:u,chain:t}),broadcastTransaction:u.broadcastTransaction,createApprovalTx:Kt({provider:u,signer:n,chain:t}),createContract:Yt({provider:u,chain:t}),createContractTxObject:X({provider:u,chain:t}),createTransferTx:A({provider:u,signer:n,chain:t}),createTransaction:A({provider:u,signer:n,chain:t}),estimateGasLimit:_t({provider:u,signer:n,chain:t}),estimateGasPrices:G({chain:t,provider:u,isEIP1559Compatible:y}),isApproved:Nt({provider:u,chain:t}),sendTransaction:mt({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),signMessage:n?.signMessage,transfer:ht({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),validateAddress:(o)=>Qt({address:o})}}function Qt({address:t}){try{return _(t),!0}catch(u){return!1}}function K(t){return t instanceof $t}function O(t,u,n){return new ot(t,et.from(u),n)}function Yt({provider:t}){return function u(n,y){return new ot(n,et.from(y),t)}}var Zt=["payable","nonpayable"];function Xt({abi:t,funcName:u}){let n=t.find((y)=>y.name===u);if(!n)throw new w("toolbox_evm_no_abi_fragment",{funcName:u});return n.stateMutability&&Zt.includes(n.stateMutability)}function Un(t){return _(t)}function P(t){return function u({value:n,...y}){if(!K(t))throw new w("toolbox_evm_provider_not_eip1193_compatible");return t.send("eth_sendTransaction",[{value:h(BigInt(n||0)),...y}])}}function Ln(t,u){let n=g(t,u);if(n)return _(n.toLowerCase());throw new w("toolbox_evm_invalid_gas_asset_address")}var Vt={[L.Arbitrum]:q.ARB,[L.Avalanche]:q.AVAX,[L.Base]:q.BASE,[L.BinanceSmartChain]:q.BSC,[L.Ethereum]:q.ETH,[L.Optimism]:q.OP,[L.Polygon]:q.MATIC};function g({chain:t,symbol:u,ticker:n},y){try{let o=t===L.BinanceSmartChain&&u==="BNB"&&n==="BNB",e=t===y&&u===y&&n===y,l=[L.Arbitrum,L.Base].includes(t)&&u==="ETH"&&n==="ETH";if(e||o||l)return Vt[y];return _(u.slice(n.length+1).replace(/^0X/,""))}catch(o){return null}}function X({provider:t}){return async({contractAddress:u,abi:n,funcName:y,funcParams:o=[],txOverrides:e})=>O(u,n,t).getFunction(y).populateTransaction(...o.concat(e).filter((l)=>typeof l!=="undefined"))}function G({chain:t,provider:u,isEIP1559Compatible:n=!0}){if(t===L.Arbitrum)return async function y(){try{let{gasPrice:o}=await u.getFeeData();if(!o)throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{gasPrice:o},[T.Fast]:{gasPrice:o},[T.Fastest]:{gasPrice:o}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}};if(t===L.Optimism)return async function y(){try{let{maxFeePerGas:o,maxPriorityFeePerGas:e,gasPrice:l}=await u.getFeeData(),m=d(u)(),a=l;if(!(o&&e))throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{l1GasPrice:m,gasPrice:a,maxFeePerGas:o,maxPriorityFeePerGas:e},[T.Fast]:{l1GasPrice:H(m||0n,T.Fast),gasPrice:H(a,T.Fast),maxFeePerGas:o,maxPriorityFeePerGas:H(e,T.Fast)},[T.Fastest]:{l1GasPrice:H(m||0n,T.Fastest),gasPrice:H(a,T.Fastest),maxFeePerGas:o,maxPriorityFeePerGas:H(e,T.Fastest)}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}};return async function y(){try{let{maxFeePerGas:o,maxPriorityFeePerGas:e,gasPrice:l}=await u.getFeeData();if(n){if(o===null||e===null)throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{maxFeePerGas:o,maxPriorityFeePerGas:e},[T.Fast]:{maxFeePerGas:H(o,T.Fast),maxPriorityFeePerGas:H(e,T.Fast)},[T.Fastest]:{maxFeePerGas:H(o,T.Fastest),maxPriorityFeePerGas:H(e,T.Fastest)}}}if(!l)throw new w("toolbox_evm_no_gas_price");return{[T.Average]:{gasPrice:l},[T.Fast]:{gasPrice:H(l,T.Fast)},[T.Fastest]:{gasPrice:H(l,T.Fastest)}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}}}function v({provider:t,isEIP1559Compatible:u,signer:n,chain:y}){return async function o({callProvider:e,contractAddress:l,abi:m,funcName:a,funcParams:b=[],txOverrides:i={},feeOption:M=T.Fast}){let p=e||t;if(!l)throw new w("toolbox_evm_invalid_params",{error:"contractAddress must be provided"});let s=Xt({abi:m,funcName:a});if(s&&K(p)&&n){let R=X({provider:p,chain:y}),D=i?.from||await n?.getAddress(),U=await R({contractAddress:l,abi:m,funcName:a,funcParams:b,txOverrides:{...i,from:D}});return P(p)(U)}let c=O(l,m,p);if(s){if(!n)throw new w("toolbox_evm_no_signer");let R=i?.from||await n.getAddress();if(!R)throw new w("toolbox_evm_no_signer_address");let D=c.connect(n),U=G({provider:t,isEIP1559Compatible:u,chain:y}),{maxFeePerGas:z,maxPriorityFeePerGas:B,gasPrice:E}=(await U())[M],Y=await c.getFunction(a).estimateGas(...b,i),N=await D[a](...b,{...i,gasLimit:Y,maxFeePerGas:z,maxPriorityFeePerGas:B,gasPrice:E,nonce:i?.nonce||await p.getTransactionCount(R)});return typeof N?.hash==="string"?N?.hash:N}let f=await c[a]?.(...b);return typeof f?.hash==="string"?f?.hash:f}}function lt({provider:t,chain:u}){return function n({assetAddress:y,spenderAddress:o,from:e}){return v({provider:t,isEIP1559Compatible:!0,chain:u})({contractAddress:y,abi:Z,funcName:"allowance",funcParams:[e,o]})}}function Nt({provider:t,chain:u}){return async function n({assetAddress:y,spenderAddress:o,from:e,amount:l=F}){let m=await lt({provider:t,chain:u})({assetAddress:y,spenderAddress:o,from:e});return yt.fromBigInt(m).gte(yt.fromBigInt(BigInt(l)))}}function St({signer:t,isEIP1559Compatible:u=!0,provider:n,chain:y}){return async function o({assetAddress:e,spenderAddress:l,feeOptionKey:m=T.Fast,amount:a,gasLimitFallback:b,from:i,nonce:M}){let p=[l,BigInt(a||F)],s=await t?.getAddress()||i,c={contractAddress:e,abi:Z,funcName:"approve",funcParams:p,signer:t,txOverrides:{from:s}};if(K(n)){let R=X({provider:n,chain:y}),D=P(n),U=await R(c);return D(U)}return v({provider:n,isEIP1559Compatible:u,signer:t,chain:y})({...c,funcParams:p,txOverrides:{from:s,nonce:M,gasLimit:b?BigInt(b.toString()):void 0},feeOption:m})}}function ht({signer:t,isEIP1559Compatible:u=!0,provider:n}){return async function y({assetValue:o,memo:e,recipient:l,feeOptionKey:m=T.Fast,sender:a,...b}){let{hexlify:i,toUtf8Bytes:M}=await import("ethers"),p=o.getBaseValue("bigint"),s=o.chain,c=a||await t?.getAddress(),f=mt({provider:n,signer:t,isEIP1559Compatible:u,chain:s});if(!c)throw new w("toolbox_evm_no_from_address");if(o.isGasAsset){let E={...b,from:c,to:l,value:p,data:i(M(e||"")),feeOptionKey:m};return f(E)}if(!g(o,s))throw new w("toolbox_evm_no_contract_address");let{maxFeePerGas:D,maxPriorityFeePerGas:U,gasPrice:z}=(await G({provider:n,isEIP1559Compatible:u,chain:s})())[m],B=await A({provider:n,signer:t,chain:s})({assetValue:o,memo:e,recipient:l,data:i(M(e||"")),sender:c,maxFeePerGas:D,maxPriorityFeePerGas:U,gasPrice:z});return f(B)}}function at({provider:t,signer:u}){return function n({contractAddress:y,abi:o,funcName:e,funcParams:l=[],txOverrides:m}){if(!y)throw new w("toolbox_evm_no_contract_address");let a=O(y,o,t);return u?a.connect(u).getFunction(e).estimateGas(...l,m):a.getFunction(e).estimateGas(...l,m)}}function _t({provider:t,signer:u}){return async function n({assetValue:y,recipient:o,memo:e,data:l,sender:m,funcName:a,funcParams:b,txOverrides:i}){let M=y.bigIntValue,p=y.isGasAsset?null:g(y,y.chain);if(p&&a)return at({provider:t,signer:u})({contractAddress:p,abi:Z,funcName:a,funcParams:b,txOverrides:i});let{hexlify:s,toUtf8Bytes:c}=await import("ethers");return t.estimateGas({from:m,to:o,value:M,data:l?l:e?s(c(e)):void 0})}}var jt=(t)=>t.type===2||!!t.maxFeePerGas||!!t.maxPriorityFeePerGas;function mt({provider:t,signer:u,isEIP1559Compatible:n=!0,chain:y}){return async function o({feeOptionKey:e=T.Fast,...l}){let{from:m,to:a,data:b,value:i,...M}=l;if(!u)throw new w("toolbox_evm_no_signer");if(!a)throw new w("toolbox_evm_no_to_address");let p={...M,data:b||"0x",to:a,from:m,value:BigInt(i||0)};if(K(t))return P(t)(p);let s=m||await u.getAddress(),c=l.nonce||await t.getTransactionCount(s),f=(await t.getNetwork()).chainId,R=jt(p)||n,D=G({provider:t,isEIP1559Compatible:n,chain:y}),U=R&&!(p.maxFeePerGas&&p.maxPriorityFeePerGas)||!p.gasPrice?Object.entries((await D())[e]).reduce((B,[E,Y])=>({...B,[E]:h(BigInt(Y))}),{}):{},z;try{z=h(p.gasLimit||await t.estimateGas(p)*11n/10n)}catch(B){throw new w("toolbox_evm_error_estimating_gas_limit",{error:B})}try{let B={...p,chainId:f,type:R?2:0,gasLimit:z,nonce:c,...U};try{return(await u.sendTransaction(B)).hash}catch(E){let Y=await u.signTransaction({...B,from:s});return(await t.broadcastTransaction(Y)).hash}}catch(B){throw new w("toolbox_evm_error_sending_transaction",{error:B})}}}function A({provider:t,signer:u}){return async function n({assetValue:y,memo:o,recipient:e,data:l,sender:m,maxFeePerGas:a,maxPriorityFeePerGas:b,gasPrice:i,...M}){let p=y.getBaseValue("bigint"),s=y.chain,c=m||await u?.getAddress();if(!c)throw new w("toolbox_evm_no_from_address");if(Wt(y)){let{hexlify:D,toUtf8Bytes:U}=await import("ethers");return{...M,from:c,to:e,value:p,data:l||D(U(o||""))}}let f=g(y,s);if(!f)throw new w("toolbox_evm_no_contract_address");return X({provider:t,chain:y.chain})({contractAddress:f,abi:Z,funcName:"transfer",funcParams:[e,p],txOverrides:{from:c,maxFeePerGas:a,maxPriorityFeePerGas:b,gasPrice:i}})}}function Kt({provider:t,signer:u,chain:n}){return async function y({assetAddress:o,spenderAddress:e,amount:l,from:m}){let a=await u?.getAddress()||m,b=X({provider:t,chain:n}),i=[e,BigInt(l||F)];return await b({contractAddress:o,abi:Z,funcName:"approve",funcParams:i,txOverrides:{from:a}})}}async function W(t,u){let{JsonRpcProvider:n}=await import("ethers");return new n(u||bt.get("rpcUrls")[t])}var En=async({from:t,memo:u="",feeOptionKey:n=pt.Fastest,assetValue:y,abi:o,funcName:e,funcParams:l,contractAddress:m,txOverrides:a})=>{let{getEvmToolbox:b}=await import("@swapkit/toolboxes/evm"),i=await b(y.chain),p=(await i.getBalance(t)).find(({symbol:B,chain:E})=>y?B===y.symbol:B===I.from({chain:E})?.symbol),s=(await i.estimateGasPrices())[n];if(!p)return I.from({chain:y.chain});if(y&&(p.chain!==y.chain||p.symbol!==y?.symbol))return p;let c=o&&e&&l&&m?await i.estimateCall({contractAddress:m,abi:o,funcName:e,funcParams:l,txOverrides:a}):await i.estimateGasLimit({sender:t,recipient:t,memo:u,assetValue:y}),f="maxFeePerGas"in s,R="gasPrice"in s&&s.gasPrice!==void 0;if(!(s&&(R||f)))throw new tt("toolbox_evm_no_fee_data");let D=f?(s.maxFeePerGas||1n)+(s.maxPriorityFeePerGas||1n):s.gasPrice||1n,U=c*D,z=r.fromBigInt(p.getBaseValue("bigint")).sub(U.toString());return I.from({chain:p.chain,value:z.getValue("string")})};function h(t){return t>0n?`0x${t.toString(16)}`:"0x0"}function Tt({provider:t,isEIP1559Compatible:u=!0}){return async function n({feeOption:y=pt.Fast,chain:o,...e}){let m=await G({provider:t,isEIP1559Compatible:u,chain:o})(),a=await t.estimateGas(e),b=I.from({chain:o}),{gasPrice:i,maxFeePerGas:M,maxPriorityFeePerGas:p}=m[y];if(!u&&i)return b.set(r.fromBigInt(i*a,b.decimal));if(M&&p){let s=(M+p)*a;return b.set(r.fromBigInt(s,b.decimal))}throw new tt("toolbox_evm_no_gas_price")}}function it(t){return()=>x.Ethereum===t?void 0:{...At({chain:t}),chainId:It[t],rpcUrls:[bt.get("rpcUrls")[t]],blockExplorerUrls:[gt[t]]}}function st(t){return![x.Arbitrum,x.BinanceSmartChain].includes(t)}function At({chain:t}){let u=Pt[t];switch(t){case x.Arbitrum:return{chainName:"Arbitrum One",nativeCurrency:{name:"Ethereum",symbol:x.Ethereum,decimals:u}};case x.Avalanche:return{chainName:"Avalanche Network",nativeCurrency:{name:"Avalanche",symbol:t,decimals:u}};case x.Base:return{chainName:"Base Mainnet",nativeCurrency:{name:"Ethereum",symbol:x.Ethereum,decimals:u}};case x.BinanceSmartChain:return{chainName:"BNB Chain",nativeCurrency:{name:"Binance Coin",symbol:"BNB",decimals:u}};case x.Polygon:return{chainName:"Polygon Mainnet",nativeCurrency:{name:"Polygon",symbol:x.Polygon,decimals:u}};default:throw new tt("toolbox_evm_not_supported",{chain:t})}}var Ft;((n)=>{n.Test="goerli";n.Main="homestead"})(Ft||={});import{Chain as J,SwapKitError as Tn}from"@swapkit/helpers";import{Chain as $,FeeOption as Ot,SKConfig as vt}from"@swapkit/helpers";import{HDNodeWallet as dt}from"ethers";import{P as ct,match as rt}from"ts-pattern";var wt=[{inputs:[{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"aggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes[]",name:"returnData",type:"bytes[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"blockAndAggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes32",name:"blockHash",type:"bytes32"},{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"}],name:"getBlockHash",outputs:[{internalType:"bytes32",name:"blockHash",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[],name:"getBlockNumber",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockCoinbase",outputs:[{internalType:"address",name:"coinbase",type:"address"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockDifficulty",outputs:[{internalType:"uint256",name:"difficulty",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockGasLimit",outputs:[{internalType:"uint256",name:"gaslimit",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockTimestamp",outputs:[{internalType:"uint256",name:"timestamp",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"addr",type:"address"}],name:"getEthBalance",outputs:[{internalType:"uint256",name:"balance",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getLastBlockHash",outputs:[{internalType:"bytes32",name:"blockHash",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bool",name:"requireSuccess",type:"bool"},{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"tryAggregate",outputs:[{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bool",name:"requireSuccess",type:"bool"},{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"tryBlockAndAggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes32",name:"blockHash",type:"bytes32"},{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"}];async function Mt({provider:t,...u}){let n=await Q($.Ethereum)({provider:t,...u});async function y(o,e="0x5ba1e12693dc8f9c48aad8770482f4739beed696",l="aggregate",m=Ot.Fast){let a=await n.createContractTxObject({contractAddress:e,abi:wt,funcName:l,funcParams:[o]});return n.sendTransaction({...a,feeOptionKey:m})}return{...n,multicall:y}}var ft=Q($.Arbitrum),Bt=Q($.Avalanche),Rt=Q($.Base),Dt=Q($.BinanceSmartChain),Ut=Q($.Polygon);function Q(t){return async function u({provider:n,...y}){let o=vt.get("rpcUrls")[t],e=n||await W(t,o),l=st(t),m=rt(y).with({phrase:ct.string},({phrase:b})=>dt.fromPhrase(b).connect(e)).with({signer:ct.any},({signer:b})=>b).otherwise(()=>{return});return{...j({provider:e,signer:m,isEIP1559Compatible:l,chain:t}),estimateTransactionFee:Tt({provider:e,isEIP1559Compatible:l,chain:t}),getNetworkParams:it(t),getBalance:S(t).getBalance}}}import{BaseDecimal as tn,Chain as V,ChainId as nn,ChainToExplorerUrl as un,SKConfig as Ht,SwapKitError as yn}from"@swapkit/helpers";import{Contract as on,HDNodeWallet as en}from"ethers";import{P as xt}from"ts-pattern";import{match as ln}from"ts-pattern";var Lt=[{inputs:[{internalType:"address",name:"_owner",type:"address"}],stateMutability:"nonpayable",type:"constructor"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"DecimalsUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"GasPriceUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"L1BaseFeeUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"OverheadUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"previousOwner",type:"address"},{indexed:!0,internalType:"address",name:"newOwner",type:"address"}],name:"OwnershipTransferred",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"ScalarUpdated",type:"event"},{inputs:[],name:"decimals",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"gasPrice",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes",name:"_data",type:"bytes"}],name:"getL1Fee",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes",name:"_data",type:"bytes"}],name:"getL1GasUsed",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"l1BaseFee",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"overhead",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"owner",outputs:[{internalType:"address",name:"",type:"address"}],stateMutability:"view",type:"function"},{inputs:[],name:"renounceOwnership",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[],name:"scalar",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"_decimals",type:"uint256"}],name:"setDecimals",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_gasPrice",type:"uint256"}],name:"setGasPrice",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_baseFee",type:"uint256"}],name:"setL1BaseFee",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_overhead",type:"uint256"}],name:"setOverhead",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_scalar",type:"uint256"}],name:"setScalar",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"newOwner",type:"address"}],name:"transferOwnership",outputs:[],stateMutability:"nonpayable",type:"function"}];var an="0x420000000000000000000000000000000000000f";function nt(t){return new on(an,Lt,t)}function d(t){return function u(){let n=nt(t);if(n&&"l1BaseFee"in n)return n?.l1BaseFee();return}}function zt(t){return async function u({from:n,to:y,nonce:o,...e}){let{Transaction:l}=await import("ethers");if(!y)throw new yn("toolbox_evm_invalid_transaction",{error:"Missing to address"});return l.from({...e,authorizationList:e.authorizationList,to:y,nonce:o?o:n?await t.getTransactionCount(n):0}).serialized}}function Et(t){return async function u(n){let y=nt(t),o=await zt(t)(n);if(y&&"getL1Fee"in y)return y.getL1Fee(o)}}function qt(t){return async function u(n){let y=await t.send("eth_gasPrice",[]),o=await t.estimateGas(n);return y.mul(o)}}function mn(t){return async function u(n){let y=await Et(t)(n),o=await qt(t)(n);return y.add(o)}}function pn(t){return async function u(n){let y=nt(t),o=await zt(t)(n);if(y&&"getL1GasUsed"in y)return y.getL1GasUsed(o)}}var bn=()=>({chainId:nn.OptimismHex,chainName:"Optimism",nativeCurrency:{name:"Ethereum",symbol:V.Ethereum,decimals:tn.ETH},rpcUrls:[Ht.get("rpcUrls")[V.Optimism]],blockExplorerUrls:[un[V.Optimism]]});async function Jt({provider:t,...u}){let n=V.Optimism,y=Ht.get("rpcUrls")[n],o=t||await W(n,y),e=ln(u).with({phrase:xt.string},({phrase:a})=>en.fromPhrase(a).connect(o)).with({signer:xt.any},({signer:a})=>a).otherwise(()=>{return}),l=j({provider:o,signer:e}),m=d(o);return{...l,estimateL1Gas:pn(o),estimateL1GasCost:Et(o),estimateL2GasCost:qt(o),estimateTotalGasCost:mn(o),getBalance:S(V.Optimism).getBalance,getL1GasPrice:m,getNetworkParams:bn}}async function dn(t,u){let n={...u,provider:u?.provider||await W(t)};switch(t){case J.Avalanche:return Bt(n);case J.Arbitrum:return ft(n);case J.Base:return Rt(n);case J.Optimism:return Jt(n);case J.Polygon:return Ut(n);case J.BinanceSmartChain:return Dt(n);case J.Ethereum:return Mt(n);default:throw new Tn("toolbox_evm_not_supported",{chain:t})}}export{h as toHexString,Un as toChecksumAddress,Xt as isStateChangingCall,K as isBrowserProvider,g as getTokenAddress,W as getProvider,it as getNetworkParams,d as getL1GasPriceFetcher,st as getIsEIP1559Compatible,dn as getEvmToolbox,S as getEvmApi,Tt as getEstimateTransactionFee,G as getEstimateGasPrices,P as getEIP1193SendTransaction,X as getCreateContractTxObject,Yt as getCreateContract,Ln as getChecksumAddressFromAsset,Qt as evmValidateAddress,En as estimateMaxSendableAmount,pn as estimateL1Gas,cn as createCustomEvmApi,O as createContract,Jt as OPToolbox,F as MAX_APPROVAL,Ut as MATICToolbox,Ft as EthNetwork,Mt as ETHToolbox,j as BaseEVMToolbox,Dt as BSCToolbox,Rt as BASEToolbox,Bt as AVAXToolbox,ft as ARBToolbox};
|
|
1
|
+
import{b as ut}from"../../chunk-0h4xdrwz.js";import{d as k,e as C}from"../../chunk-s47y8512.js";import{SKConfig as kt,warnOnce as Ct}from"@swapkit/helpers";function S(t){let u=kt.get("apis")[t];if(u)return Ct(!0,"Using custom EVM API. Be sure to implement all methods to avoid issues."),u;return Gt(t)}function cn(t){return t}function Gt(t){return{getBalance:ut(t)}}import{AssetValue as I,BaseDecimal as Pt,Chain as x,ChainToExplorerUrl as gt,ChainToHexChainId as It,FeeOption as pt,SKConfig as bt,SwapKitError as tt,SwapKitNumber as r}from"@swapkit/helpers";import{Chain as L,ContractAddress as q,FeeOption as T,SwapKitError as w,SwapKitNumber as yt,applyFeeMultiplierToBigInt as H,isGasAsset as Wt}from"@swapkit/helpers";import{erc20ABI as Z}from"@swapkit/helpers/contracts";import{BrowserProvider as $t,Contract as ot,Interface as et,getAddress as _}from"ethers";var F=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");function j({chain:t=L.Ethereum,provider:u,signer:n,isEIP1559Compatible:y=!0}){return{getAddress:()=>{return n?n.getAddress():void 0},call:v({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),estimateCall:at({provider:u,signer:n}),EIP1193SendTransaction:P(u),approve:St({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),approvedAmount:lt({provider:u,chain:t}),broadcastTransaction:u.broadcastTransaction,createApprovalTx:Kt({provider:u,signer:n,chain:t}),createContract:Yt({provider:u,chain:t}),createContractTxObject:X({provider:u,chain:t}),createTransferTx:A({provider:u,signer:n,chain:t}),createTransaction:A({provider:u,signer:n,chain:t}),estimateGasLimit:_t({provider:u,signer:n,chain:t}),estimateGasPrices:G({chain:t,provider:u,isEIP1559Compatible:y}),isApproved:Nt({provider:u,chain:t}),sendTransaction:mt({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),signMessage:n?.signMessage,transfer:ht({provider:u,signer:n,isEIP1559Compatible:y,chain:t}),validateAddress:(o)=>Qt({address:o})}}function Qt({address:t}){try{return _(t),!0}catch(u){return!1}}function K(t){return t instanceof $t}function O(t,u,n){return new ot(t,et.from(u),n)}function Yt({provider:t}){return function u(n,y){return new ot(n,et.from(y),t)}}var Zt=["payable","nonpayable"];function Xt({abi:t,funcName:u}){let n=t.find((y)=>y.name===u);if(!n)throw new w("toolbox_evm_no_abi_fragment",{funcName:u});return n.stateMutability&&Zt.includes(n.stateMutability)}function Un(t){return _(t)}function P(t){return function u({value:n,...y}){if(!K(t))throw new w("toolbox_evm_provider_not_eip1193_compatible");return t.send("eth_sendTransaction",[{value:h(BigInt(n||0)),...y}])}}function Ln(t,u){let n=g(t,u);if(n)return _(n.toLowerCase());throw new w("toolbox_evm_invalid_gas_asset_address")}var Vt={[L.Arbitrum]:q.ARB,[L.Avalanche]:q.AVAX,[L.Base]:q.BASE,[L.BinanceSmartChain]:q.BSC,[L.Ethereum]:q.ETH,[L.Optimism]:q.OP,[L.Polygon]:q.MATIC};function g({chain:t,symbol:u,ticker:n},y){try{let o=t===L.BinanceSmartChain&&u==="BNB"&&n==="BNB",e=t===y&&u===y&&n===y,l=[L.Arbitrum,L.Base].includes(t)&&u==="ETH"&&n==="ETH";if(e||o||l)return Vt[y];return _(u.slice(n.length+1).replace(/^0X/,""))}catch(o){return null}}function X({provider:t}){return async({contractAddress:u,abi:n,funcName:y,funcParams:o=[],txOverrides:e})=>O(u,n,t).getFunction(y).populateTransaction(...o.concat(e).filter((l)=>typeof l!=="undefined"))}function G({chain:t,provider:u,isEIP1559Compatible:n=!0}){if(t===L.Arbitrum)return async function y(){try{let{gasPrice:o}=await u.getFeeData();if(!o)throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{gasPrice:o},[T.Fast]:{gasPrice:o},[T.Fastest]:{gasPrice:o}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}};if(t===L.Optimism)return async function y(){try{let{maxFeePerGas:o,maxPriorityFeePerGas:e,gasPrice:l}=await u.getFeeData(),m=d(u)(),a=l;if(!(o&&e))throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{l1GasPrice:m,gasPrice:a,maxFeePerGas:o,maxPriorityFeePerGas:e},[T.Fast]:{l1GasPrice:H(m||0n,T.Fast),gasPrice:H(a,T.Fast),maxFeePerGas:o,maxPriorityFeePerGas:H(e,T.Fast)},[T.Fastest]:{l1GasPrice:H(m||0n,T.Fastest),gasPrice:H(a,T.Fastest),maxFeePerGas:o,maxPriorityFeePerGas:H(e,T.Fastest)}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}};return async function y(){try{let{maxFeePerGas:o,maxPriorityFeePerGas:e,gasPrice:l}=await u.getFeeData();if(n){if(o===null||e===null)throw new w("toolbox_evm_no_fee_data");return{[T.Average]:{maxFeePerGas:o,maxPriorityFeePerGas:e},[T.Fast]:{maxFeePerGas:H(o,T.Fast),maxPriorityFeePerGas:H(e,T.Fast)},[T.Fastest]:{maxFeePerGas:H(o,T.Fastest),maxPriorityFeePerGas:H(e,T.Fastest)}}}if(!l)throw new w("toolbox_evm_no_gas_price");return{[T.Average]:{gasPrice:l},[T.Fast]:{gasPrice:H(l,T.Fast)},[T.Fastest]:{gasPrice:H(l,T.Fastest)}}}catch(o){throw new w("toolbox_evm_gas_estimation_error",{error:o.msg??o.toString()})}}}function v({provider:t,isEIP1559Compatible:u,signer:n,chain:y}){return async function o({callProvider:e,contractAddress:l,abi:m,funcName:a,funcParams:b=[],txOverrides:i={},feeOption:M=T.Fast}){let p=e||t;if(!l)throw new w("toolbox_evm_invalid_params",{error:"contractAddress must be provided"});let s=Xt({abi:m,funcName:a});if(s&&K(p)&&n){let R=X({provider:p,chain:y}),D=i?.from||await n?.getAddress(),U=await R({contractAddress:l,abi:m,funcName:a,funcParams:b,txOverrides:{...i,from:D}});return P(p)(U)}let c=O(l,m,p);if(s){if(!n)throw new w("toolbox_evm_no_signer");let R=i?.from||await n.getAddress();if(!R)throw new w("toolbox_evm_no_signer_address");let D=c.connect(n),U=G({provider:t,isEIP1559Compatible:u,chain:y}),{maxFeePerGas:z,maxPriorityFeePerGas:B,gasPrice:E}=(await U())[M],Y=await c.getFunction(a).estimateGas(...b,i),N=await D[a](...b,{...i,gasLimit:Y,maxFeePerGas:z,maxPriorityFeePerGas:B,gasPrice:E,nonce:i?.nonce||await p.getTransactionCount(R)});return typeof N?.hash==="string"?N?.hash:N}let f=await c[a]?.(...b);return typeof f?.hash==="string"?f?.hash:f}}function lt({provider:t,chain:u}){return function n({assetAddress:y,spenderAddress:o,from:e}){return v({provider:t,isEIP1559Compatible:!0,chain:u})({contractAddress:y,abi:Z,funcName:"allowance",funcParams:[e,o]})}}function Nt({provider:t,chain:u}){return async function n({assetAddress:y,spenderAddress:o,from:e,amount:l=F}){let m=await lt({provider:t,chain:u})({assetAddress:y,spenderAddress:o,from:e});return yt.fromBigInt(m).gte(yt.fromBigInt(BigInt(l)))}}function St({signer:t,isEIP1559Compatible:u=!0,provider:n,chain:y}){return async function o({assetAddress:e,spenderAddress:l,feeOptionKey:m=T.Fast,amount:a,gasLimitFallback:b,from:i,nonce:M}){let p=[l,BigInt(a||F)],s=await t?.getAddress()||i,c={contractAddress:e,abi:Z,funcName:"approve",funcParams:p,signer:t,txOverrides:{from:s}};if(K(n)){let R=X({provider:n,chain:y}),D=P(n),U=await R(c);return D(U)}return v({provider:n,isEIP1559Compatible:u,signer:t,chain:y})({...c,funcParams:p,txOverrides:{from:s,nonce:M,gasLimit:b?BigInt(b.toString()):void 0},feeOption:m})}}function ht({signer:t,isEIP1559Compatible:u=!0,provider:n}){return async function y({assetValue:o,memo:e,recipient:l,feeOptionKey:m=T.Fast,sender:a,...b}){let{hexlify:i,toUtf8Bytes:M}=await import("ethers"),p=o.getBaseValue("bigint"),s=o.chain,c=a||await t?.getAddress(),f=mt({provider:n,signer:t,isEIP1559Compatible:u,chain:s});if(!c)throw new w("toolbox_evm_no_from_address");if(o.isGasAsset){let E={...b,from:c,to:l,value:p,data:i(M(e||"")),feeOptionKey:m};return f(E)}if(!g(o,s))throw new w("toolbox_evm_no_contract_address");let{maxFeePerGas:D,maxPriorityFeePerGas:U,gasPrice:z}=(await G({provider:n,isEIP1559Compatible:u,chain:s})())[m],B=await A({provider:n,signer:t,chain:s})({assetValue:o,memo:e,recipient:l,data:i(M(e||"")),sender:c,maxFeePerGas:D,maxPriorityFeePerGas:U,gasPrice:z});return f(B)}}function at({provider:t,signer:u}){return function n({contractAddress:y,abi:o,funcName:e,funcParams:l=[],txOverrides:m}){if(!y)throw new w("toolbox_evm_no_contract_address");let a=O(y,o,t);return u?a.connect(u).getFunction(e).estimateGas(...l,m):a.getFunction(e).estimateGas(...l,m)}}function _t({provider:t,signer:u}){return async function n({assetValue:y,recipient:o,memo:e,data:l,sender:m,funcName:a,funcParams:b,txOverrides:i}){let M=y.bigIntValue,p=y.isGasAsset?null:g(y,y.chain);if(p&&a)return at({provider:t,signer:u})({contractAddress:p,abi:Z,funcName:a,funcParams:b,txOverrides:i});let{hexlify:s,toUtf8Bytes:c}=await import("ethers");return t.estimateGas({from:m,to:o,value:M,data:l?l:e?s(c(e)):void 0})}}var jt=(t)=>t.type===2||!!t.maxFeePerGas||!!t.maxPriorityFeePerGas;function mt({provider:t,signer:u,isEIP1559Compatible:n=!0,chain:y}){return async function o({feeOptionKey:e=T.Fast,...l}){let{from:m,to:a,data:b,value:i,...M}=l;if(!u)throw new w("toolbox_evm_no_signer");if(!a)throw new w("toolbox_evm_no_to_address");let p={...M,data:b||"0x",to:a,from:m,value:BigInt(i||0)};if(K(t))return P(t)(p);let s=m||await u.getAddress(),c=l.nonce||await t.getTransactionCount(s),f=(await t.getNetwork()).chainId,R=jt(p)||n,D=G({provider:t,isEIP1559Compatible:n,chain:y}),U=R&&!(p.maxFeePerGas&&p.maxPriorityFeePerGas)||!p.gasPrice?Object.entries((await D())[e]).reduce((B,[E,Y])=>({...B,[E]:h(BigInt(Y))}),{}):{},z;try{z=h(p.gasLimit||await t.estimateGas(p)*11n/10n)}catch(B){throw new w("toolbox_evm_error_estimating_gas_limit",{error:B})}try{let B={...p,chainId:f,type:R?2:0,gasLimit:z,nonce:c,...U};try{return(await u.sendTransaction(B)).hash}catch(E){let Y=await u.signTransaction({...B,from:s});return(await t.broadcastTransaction(Y)).hash}}catch(B){throw new w("toolbox_evm_error_sending_transaction",{error:B})}}}function A({provider:t,signer:u}){return async function n({assetValue:y,memo:o,recipient:e,data:l,sender:m,maxFeePerGas:a,maxPriorityFeePerGas:b,gasPrice:i,...M}){let p=y.getBaseValue("bigint"),s=y.chain,c=m||await u?.getAddress();if(!c)throw new w("toolbox_evm_no_from_address");if(Wt(y)){let{hexlify:D,toUtf8Bytes:U}=await import("ethers");return{...M,from:c,to:e,value:p,data:l||D(U(o||""))}}let f=g(y,s);if(!f)throw new w("toolbox_evm_no_contract_address");return X({provider:t,chain:y.chain})({contractAddress:f,abi:Z,funcName:"transfer",funcParams:[e,p],txOverrides:{from:c,maxFeePerGas:a,maxPriorityFeePerGas:b,gasPrice:i}})}}function Kt({provider:t,signer:u,chain:n}){return async function y({assetAddress:o,spenderAddress:e,amount:l,from:m}){let a=await u?.getAddress()||m,b=X({provider:t,chain:n}),i=[e,BigInt(l||F)];return await b({contractAddress:o,abi:Z,funcName:"approve",funcParams:i,txOverrides:{from:a}})}}async function W(t,u){let{JsonRpcProvider:n}=await import("ethers");return new n(u||bt.get("rpcUrls")[t])}var En=async({from:t,memo:u="",feeOptionKey:n=pt.Fastest,assetValue:y,abi:o,funcName:e,funcParams:l,contractAddress:m,txOverrides:a})=>{let{getEvmToolbox:b}=await import("@swapkit/toolboxes/evm"),i=await b(y.chain),p=(await i.getBalance(t)).find(({symbol:B,chain:E})=>y?B===y.symbol:B===I.from({chain:E})?.symbol),s=(await i.estimateGasPrices())[n];if(!p)return I.from({chain:y.chain});if(y&&(p.chain!==y.chain||p.symbol!==y?.symbol))return p;let c=o&&e&&l&&m?await i.estimateCall({contractAddress:m,abi:o,funcName:e,funcParams:l,txOverrides:a}):await i.estimateGasLimit({sender:t,recipient:t,memo:u,assetValue:y}),f="maxFeePerGas"in s,R="gasPrice"in s&&s.gasPrice!==void 0;if(!(s&&(R||f)))throw new tt("toolbox_evm_no_fee_data");let D=f?(s.maxFeePerGas||1n)+(s.maxPriorityFeePerGas||1n):s.gasPrice||1n,U=c*D,z=r.fromBigInt(p.getBaseValue("bigint")).sub(U.toString());return I.from({chain:p.chain,value:z.getValue("string")})};function h(t){return t>0n?`0x${t.toString(16)}`:"0x0"}function Tt({provider:t,isEIP1559Compatible:u=!0}){return async function n({feeOption:y=pt.Fast,chain:o,...e}){let m=await G({provider:t,isEIP1559Compatible:u,chain:o})(),a=await t.estimateGas(e),b=I.from({chain:o}),{gasPrice:i,maxFeePerGas:M,maxPriorityFeePerGas:p}=m[y];if(!u&&i)return b.set(r.fromBigInt(i*a,b.decimal));if(M&&p){let s=(M+p)*a;return b.set(r.fromBigInt(s,b.decimal))}throw new tt("toolbox_evm_no_gas_price")}}function it(t){return()=>x.Ethereum===t?void 0:{...At({chain:t}),chainId:It[t],rpcUrls:[bt.get("rpcUrls")[t]],blockExplorerUrls:[gt[t]]}}function st(t){return![x.Arbitrum,x.BinanceSmartChain].includes(t)}function At({chain:t}){let u=Pt[t];switch(t){case x.Arbitrum:return{chainName:"Arbitrum One",nativeCurrency:{name:"Ethereum",symbol:x.Ethereum,decimals:u}};case x.Avalanche:return{chainName:"Avalanche Network",nativeCurrency:{name:"Avalanche",symbol:t,decimals:u}};case x.Base:return{chainName:"Base Mainnet",nativeCurrency:{name:"Ethereum",symbol:x.Ethereum,decimals:u}};case x.BinanceSmartChain:return{chainName:"BNB Chain",nativeCurrency:{name:"Binance Coin",symbol:"BNB",decimals:u}};case x.Polygon:return{chainName:"Polygon Mainnet",nativeCurrency:{name:"Polygon",symbol:x.Polygon,decimals:u}};default:throw new tt("toolbox_evm_not_supported",{chain:t})}}var Ft;((n)=>{n.Test="goerli";n.Main="homestead"})(Ft||={});import{Chain as J,SwapKitError as Tn}from"@swapkit/helpers";import{Chain as $,FeeOption as Ot,SKConfig as vt}from"@swapkit/helpers";import{HDNodeWallet as dt}from"ethers";import{P as ct,match as rt}from"ts-pattern";var wt=[{inputs:[{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"aggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes[]",name:"returnData",type:"bytes[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"blockAndAggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes32",name:"blockHash",type:"bytes32"},{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"}],name:"getBlockHash",outputs:[{internalType:"bytes32",name:"blockHash",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[],name:"getBlockNumber",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockCoinbase",outputs:[{internalType:"address",name:"coinbase",type:"address"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockDifficulty",outputs:[{internalType:"uint256",name:"difficulty",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockGasLimit",outputs:[{internalType:"uint256",name:"gaslimit",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockTimestamp",outputs:[{internalType:"uint256",name:"timestamp",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"address",name:"addr",type:"address"}],name:"getEthBalance",outputs:[{internalType:"uint256",name:"balance",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"getLastBlockHash",outputs:[{internalType:"bytes32",name:"blockHash",type:"bytes32"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bool",name:"requireSuccess",type:"bool"},{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"tryAggregate",outputs:[{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"bool",name:"requireSuccess",type:"bool"},{components:[{internalType:"address",name:"target",type:"address"},{internalType:"bytes",name:"callData",type:"bytes"}],internalType:"struct Multicall2.Call[]",name:"calls",type:"tuple[]"}],name:"tryBlockAndAggregate",outputs:[{internalType:"uint256",name:"blockNumber",type:"uint256"},{internalType:"bytes32",name:"blockHash",type:"bytes32"},{components:[{internalType:"bool",name:"success",type:"bool"},{internalType:"bytes",name:"returnData",type:"bytes"}],internalType:"struct Multicall2.Result[]",name:"returnData",type:"tuple[]"}],stateMutability:"nonpayable",type:"function"}];async function Mt({provider:t,...u}){let n=await Q($.Ethereum)({provider:t,...u});async function y(o,e="0x5ba1e12693dc8f9c48aad8770482f4739beed696",l="aggregate",m=Ot.Fast){let a=await n.createContractTxObject({contractAddress:e,abi:wt,funcName:l,funcParams:[o]});return n.sendTransaction({...a,feeOptionKey:m})}return{...n,multicall:y}}var ft=Q($.Arbitrum),Bt=Q($.Avalanche),Rt=Q($.Base),Dt=Q($.BinanceSmartChain),Ut=Q($.Polygon);function Q(t){return async function u({provider:n,...y}){let o=vt.get("rpcUrls")[t],e=n||await W(t,o),l=st(t),m=rt(y).with({phrase:ct.string},({phrase:b})=>dt.fromPhrase(b).connect(e)).with({signer:ct.any},({signer:b})=>b).otherwise(()=>{return});return{...j({provider:e,signer:m,isEIP1559Compatible:l,chain:t}),estimateTransactionFee:Tt({provider:e,isEIP1559Compatible:l,chain:t}),getNetworkParams:it(t),getBalance:S(t).getBalance}}}import{BaseDecimal as tn,Chain as V,ChainId as nn,ChainToExplorerUrl as un,SKConfig as Ht,SwapKitError as yn}from"@swapkit/helpers";import{Contract as on,HDNodeWallet as en}from"ethers";import{P as xt}from"ts-pattern";import{match as ln}from"ts-pattern";var Lt=[{inputs:[{internalType:"address",name:"_owner",type:"address"}],stateMutability:"nonpayable",type:"constructor"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"DecimalsUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"GasPriceUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"L1BaseFeeUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"OverheadUpdated",type:"event"},{anonymous:!1,inputs:[{indexed:!0,internalType:"address",name:"previousOwner",type:"address"},{indexed:!0,internalType:"address",name:"newOwner",type:"address"}],name:"OwnershipTransferred",type:"event"},{anonymous:!1,inputs:[{indexed:!1,internalType:"uint256",name:"",type:"uint256"}],name:"ScalarUpdated",type:"event"},{inputs:[],name:"decimals",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"gasPrice",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes",name:"_data",type:"bytes"}],name:"getL1Fee",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"bytes",name:"_data",type:"bytes"}],name:"getL1GasUsed",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"l1BaseFee",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"overhead",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[],name:"owner",outputs:[{internalType:"address",name:"",type:"address"}],stateMutability:"view",type:"function"},{inputs:[],name:"renounceOwnership",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[],name:"scalar",outputs:[{internalType:"uint256",name:"",type:"uint256"}],stateMutability:"view",type:"function"},{inputs:[{internalType:"uint256",name:"_decimals",type:"uint256"}],name:"setDecimals",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_gasPrice",type:"uint256"}],name:"setGasPrice",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_baseFee",type:"uint256"}],name:"setL1BaseFee",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_overhead",type:"uint256"}],name:"setOverhead",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"uint256",name:"_scalar",type:"uint256"}],name:"setScalar",outputs:[],stateMutability:"nonpayable",type:"function"},{inputs:[{internalType:"address",name:"newOwner",type:"address"}],name:"transferOwnership",outputs:[],stateMutability:"nonpayable",type:"function"}];var an="0x420000000000000000000000000000000000000f";function nt(t){return new on(an,Lt,t)}function d(t){return function u(){let n=nt(t);if(n&&"l1BaseFee"in n)return n?.l1BaseFee();return}}function zt(t){return async function u({from:n,to:y,nonce:o,...e}){let{Transaction:l}=await import("ethers");if(!y)throw new yn("toolbox_evm_invalid_transaction",{error:"Missing to address"});return l.from({...e,authorizationList:e.authorizationList,to:y,nonce:o?o:n?await t.getTransactionCount(n):0}).serialized}}function Et(t){return async function u(n){let y=nt(t),o=await zt(t)(n);if(y&&"getL1Fee"in y)return y.getL1Fee(o)}}function qt(t){return async function u(n){let y=await t.send("eth_gasPrice",[]),o=await t.estimateGas(n);return y.mul(o)}}function mn(t){return async function u(n){let y=await Et(t)(n),o=await qt(t)(n);return y.add(o)}}function pn(t){return async function u(n){let y=nt(t),o=await zt(t)(n);if(y&&"getL1GasUsed"in y)return y.getL1GasUsed(o)}}var bn=()=>({chainId:nn.OptimismHex,chainName:"Optimism",nativeCurrency:{name:"Ethereum",symbol:V.Ethereum,decimals:tn.ETH},rpcUrls:[Ht.get("rpcUrls")[V.Optimism]],blockExplorerUrls:[un[V.Optimism]]});async function Jt({provider:t,...u}){let n=V.Optimism,y=Ht.get("rpcUrls")[n],o=t||await W(n,y),e=ln(u).with({phrase:xt.string},({phrase:a})=>en.fromPhrase(a).connect(o)).with({signer:xt.any},({signer:a})=>a).otherwise(()=>{return}),l=j({provider:o,signer:e}),m=d(o);return{...l,estimateL1Gas:pn(o),estimateL1GasCost:Et(o),estimateL2GasCost:qt(o),estimateTotalGasCost:mn(o),getBalance:S(V.Optimism).getBalance,getL1GasPrice:m,getNetworkParams:bn}}async function dn(t,u){let n={...u,provider:u?.provider||await W(t)};switch(t){case J.Avalanche:return Bt(n);case J.Arbitrum:return ft(n);case J.Base:return Rt(n);case J.Optimism:return Jt(n);case J.Polygon:return Ut(n);case J.BinanceSmartChain:return Dt(n);case J.Ethereum:return Mt(n);default:throw new Tn("toolbox_evm_not_supported",{chain:t})}}export{h as toHexString,Un as toChecksumAddress,Xt as isStateChangingCall,K as isBrowserProvider,g as getTokenAddress,W as getProvider,it as getNetworkParams,d as getL1GasPriceFetcher,st as getIsEIP1559Compatible,dn as getEvmToolbox,S as getEvmApi,Tt as getEstimateTransactionFee,G as getEstimateGasPrices,P as getEIP1193SendTransaction,X as getCreateContractTxObject,Yt as getCreateContract,Ln as getChecksumAddressFromAsset,Qt as evmValidateAddress,En as estimateMaxSendableAmount,pn as estimateL1Gas,cn as createCustomEvmApi,O as createContract,Jt as OPToolbox,F as MAX_APPROVAL,Ut as MATICToolbox,Ft as EthNetwork,Mt as ETHToolbox,j as BaseEVMToolbox,Dt as BSCToolbox,Rt as BASEToolbox,Bt as AVAXToolbox,ft as ARBToolbox};
|
|
2
2
|
|
|
3
3
|
//# debugId=4FF5D94E59789B6C64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
package/dist/src/tron/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var Q2={};J2(Q2,{trc20ABI:()=>x,getTronPrivateKeyFromMnemonic:()=>A,getTronAddressValidator:()=>v,createTronToolbox:()=>b});module.exports=z2(Q2);var y=require("@swapkit/helpers"),F=require("ts-pattern");var x=[{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"success",type:"bool"}],type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],type:"function"}];var S=require("@swapkit/helpers"),w=require("tronweb"),a="https://api.trongrid.io";async function p($){try{let G=await fetch(`${a}/v1/accounts/${$}`);if(!G.ok)throw new Error(`TronGrid API error: ${G.status} ${G.statusText}`);let O=await G.json();if(!(O.success&&O.data)||O.data.length===0)throw new Error("Invalid response from TronGrid API");let J;try{J=w.TronWeb.address.toHex($).toLowerCase()}catch{J=$.toLowerCase()}let M=O.data.find((_)=>{return _.address.toLowerCase()===J});if(!M)return;return{balance:M.balance,trc20:M.trc20||[]}}catch(G){throw new S.SwapKitError("toolbox_tron_trongrid_api_error",{message:G instanceof Error?G.message:"Unknown error",address:$})}}var N=require("tronweb"),e=268,y2=13000,f2=345,u="TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t";async function v(){return($)=>{return N.TronWeb.isAddress($)}}async function A({phrase:$,derivationPath:G,index:O}){let J=G||y.derivationPathToString(y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:O||0})),{HDKey:M}=await import("@scure/bip32"),{mnemonicToSeedSync:_}=await import("@scure/bip39"),L=_($),H=M.fromMasterSeed(L).derive(J);if(!H.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");return Buffer.from(H.privateKey).toString("hex")}async function q2({phrase:$,derivationPath:G}){let{HDKey:O}=await import("@scure/bip32"),{mnemonicToSeedSync:J}=await import("@scure/bip39"),M=J($),L=O.fromMasterSeed(M).derive(G);if(!L.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");let I=Buffer.from(L.privateKey).toString("hex"),H=new N.TronWeb({fullHost:y.SKConfig.get("rpcUrls")[y.Chain.Tron],privateKey:I}),T=H.address.fromPrivateKey(I);return{getAddress:()=>Promise.resolve(typeof T==="string"?T:""),signTransaction:async(m)=>{return await H.trx.sign(m,I)}}}var b=async($={})=>{let G=y.SKConfig.get("rpcUrls")[y.Chain.Tron],O=void 0,J=new N.TronWeb({fullHost:G,headers:void 0}),M="index"in $?$.index||0:0,_=y.derivationPathToString("derivationPath"in $&&$.derivationPath?$.derivationPath:y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:M})),L=await F.match($).with({phrase:F.P.string},async({phrase:q})=>q2({phrase:q,derivationPath:_})).with({signer:F.P.any},({signer:q})=>Promise.resolve(q)).otherwise(()=>Promise.resolve(void 0)),I=async()=>{if(!L)throw new y.SwapKitError("toolbox_tron_no_signer");return await L.getAddress()},H=()=>{return 1e8},T=async()=>{try{let q=await J.trx.getChainParameters(),f={};for(let z of q)f[z.key]=z.value;return{energyFee:f.getEnergyFee||420,bandwidthFee:f.getTransactionFee||1000,createAccountFee:f.getCreateAccountFee||1e5}}catch{return{energyFee:420,bandwidthFee:1000,createAccountFee:1e5}}},m=async(q)=>{try{let f=await J.trx.getAccount(q);return f&&Object.keys(f).length>0}catch{return!1}},V=async(q)=>{try{let f=await J.trx.getAccountResources(q);return{bandwidth:{free:f.freeNetLimit-f.freeNetUsed,total:f.NetLimit||0,used:f.NetUsed||0},energy:{total:f.EnergyLimit||0,used:f.EnergyUsed||0}}}catch{return{bandwidth:{free:600,total:0,used:0},energy:{total:0,used:0}}}},l=async(q,f)=>{try{let z=J.contract(x,f);if(!z.methods?.balanceOf)return 0n;let Z=(await z.methods.balanceOf(q).call())[0];return BigInt(Z||0)}catch(z){return console.warn(`balanceOf() failed for ${f}:`,z),0n}},h=async(q,f)=>{try{J.setAddress(f);let z=J.contract(x,q),[Z,Q]=await Promise.all([z.symbol().call().catch(()=>"UNKNOWN"),z.decimals().call().catch(()=>"18")]);return{symbol:Z??"UNKNOWN",decimals:Number(Q??18)}}catch(z){return y.warnOnce(!0,`Failed to get token balance for ${q}: ${z instanceof Error?z.message:z}`),null}},o=async(q,f=!0)=>{let z=[y.AssetValue.from({chain:y.Chain.Tron})];try{let Z=await p(q);if(Z){let Q=[];Q.push(y.AssetValue.from({chain:y.Chain.Tron,value:Z.balance,fromBaseDecimal:6}));for(let j of Z.trc20){let[U,Y]=Object.entries(j)[0]||[];if(!(U&&Y))continue;let X=await h(U,q);if(!X)continue;Q.push(y.AssetValue.from({asset:`TRX.${X.symbol}-${U}`,value:BigInt(Y||0),fromBaseDecimal:X.decimals}))}return Q}return z}catch(Z){y.warnOnce(!0,`Tron API getBalance failed: ${Z instanceof Error?Z.message:Z}`);let Q=[],j=await J.trx.getBalance(q);if(j&&Number(j)>0)Q.push(y.AssetValue.from({chain:y.Chain.Tron,value:j,fromBaseDecimal:6}));let U=await l(q,u);if(U)Q.push(y.AssetValue.from({asset:`TRX.USDT-${u}`,value:U,fromBaseDecimal:6}));return Q}},c=async({recipient:q,assetValue:f,memo:z})=>{if(!L)throw new y.SwapKitError("toolbox_tron_no_signer");let Z=await I();if(f.isGasAsset){let k=await J.transactionBuilder.sendTrx(q,f.getBaseValue("number"),Z);if(z){let D=await J.transactionBuilder.addUpdateData(k,z,"utf8"),P=await L.signTransaction(D),{txid:R}=await J.trx.sendRawTransaction(P);return R}let B=await L.signTransaction(k),{txid:C}=await J.trx.sendRawTransaction(B);return C}let j=f.address;if(!j)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:f.toString()});let U=H(),Y=J.contract(x,j);if(!Y.methods?.transfer)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");let X=await Y.methods.transfer(q,f.getBaseValue("string")).send({from:Z,feeLimit:U,callValue:0});if(!X)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");return X},i=async({assetValue:q,recipient:f,sender:z})=>{let Z=q.isGasAsset;try{let Q=z?z:L?await I():void 0;if(!Q)return Z?y.AssetValue.from({chain:y.Chain.Tron,value:0.1,fromBaseDecimal:0}):y.AssetValue.from({chain:y.Chain.Tron,value:15,fromBaseDecimal:0});let j=await T(),Y=await m(f)?0:j.createAccountFee,X=await V(Q);if(Z){let E=e,g=X.bandwidth.free+(X.bandwidth.total-X.bandwidth.used),W=0;if(E>g)W=(E-g)*j.bandwidthFee;let r=Y+W;return y.AssetValue.from({chain:y.Chain.Tron,value:r,fromBaseDecimal:6})}let k=f2,B=y2,C=X.bandwidth.free+(X.bandwidth.total-X.bandwidth.used),D=X.energy.total-X.energy.used,P=0;if(k>C)P=(k-C)*j.bandwidthFee;let R=0;if(B>D)R=(B-D)*j.energyFee;let s=Y+P+R;return y.AssetValue.from({chain:y.Chain.Tron,value:s,fromBaseDecimal:6})}catch(Q){throw y.warnOnce(!0,`Failed to calculate exact fee, using conservative estimate: ${Q instanceof Error?Q.message:Q}`),new y.SwapKitError("toolbox_tron_fee_estimation_failed",{error:Q})}},n=async(q)=>{let{recipient:f,assetValue:z,memo:Z,sender:Q}=q;if(z.isGasAsset){let Y=await J.transactionBuilder.sendTrx(f,z.getBaseValue("number"),Q);if(Z)return J.transactionBuilder.addUpdateData(Y,Z,"utf8");return Y}let U=z.address;if(!U)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:z.toString()});try{let X=[{type:"address",value:f},{type:"uint256",value:z.getBaseValue("string")}],k={feeLimit:H(),callValue:0};return(await J.transactionBuilder.triggerSmartContract(U,"transfer(address,uint256)",k,X,Q)).transaction}catch(Y){throw new y.SwapKitError("toolbox_tron_transaction_creation_failed",{message:"Failed to create TRC20 transaction. This might be due to TronWeb 6.0.3 bug. Use the transfer method directly instead.",originalError:Y instanceof Error?Y.message:String(Y)})}},d=async(q)=>{if(!L)throw new y.SwapKitError("toolbox_tron_no_signer");return await L.signTransaction(q)},t=async(q)=>{let{txid:f}=await J.trx.sendRawTransaction(q);return f};return{tronWeb:J,getAddress:I,validateAddress:await v(),getBalance:o,transfer:c,estimateTransactionFee:i,createTransaction:n,signTransaction:d,broadcastTransaction:t}};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=8C1B70DA6AF55BEC64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/tron/toolbox.ts", "../src/tron/helpers/trc20.abi.ts"],
|
|
3
|
+
"sources": ["../src/tron/toolbox.ts", "../src/tron/helpers/trc20.abi.ts", "../src/tron/helpers/trongrid.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport type {\n TronCreateTransactionParams,\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nimport { TronWeb } from \"tronweb\";\n\nexport async function getTronAddressValidator() {\n return (address: string) => {\n return TronWeb.isAddress(address);\n };\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], {\n index: index || 0,\n }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}) {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n // Constants for TRON resource calculation\n const TRX_TRANSFER_BANDWIDTH = 268; // Bandwidth consumed by a TRX transfer\n const TRC20_TRANSFER_ENERGY = 13000; // Average energy consumed by TRC20 transfer\n const TRC20_TRANSFER_BANDWIDTH = 345; // Bandwidth consumed by TRC20 transfer\n\n /**\n * Get current chain parameters including resource prices\n */\n const getChainParameters = async () => {\n try {\n const parameters = await tronWeb.trx.getChainParameters();\n const paramMap: Record<string, number> = {};\n\n for (const param of parameters) {\n paramMap[param.key] = param.value;\n }\n\n return {\n energyFee: paramMap.getEnergyFee || 420, // SUN per energy unit\n bandwidthFee: paramMap.getTransactionFee || 1000, // SUN per bandwidth unit\n createAccountFee: paramMap.getCreateAccountFee || 100000, // 0.1 TRX in SUN\n };\n } catch {\n // Return default values if unable to fetch\n return {\n energyFee: 420,\n bandwidthFee: 1000,\n createAccountFee: 100000,\n };\n }\n };\n\n /**\n * Check if an address exists on the blockchain\n */\n const accountExists = async (address: string) => {\n try {\n const account = await tronWeb.trx.getAccount(address);\n return account && Object.keys(account).length > 0;\n } catch {\n return false;\n }\n };\n\n /**\n * Get account resources (bandwidth and energy)\n */\n const getAccountResources = async (address: string) => {\n try {\n const resources = await tronWeb.trx.getAccountResources(address);\n\n return {\n bandwidth: {\n free: resources.freeNetLimit - resources.freeNetUsed,\n total: resources.NetLimit || 0,\n used: resources.NetUsed || 0,\n },\n energy: {\n total: resources.EnergyLimit || 0,\n used: resources.EnergyUsed || 0,\n },\n };\n } catch {\n // Return default structure if unable to fetch\n return {\n bandwidth: { free: 600, total: 0, used: 0 }, // 600 free bandwidth daily\n energy: { total: 0, used: 0 },\n };\n }\n };\n\n const getBalance = async (address: string, scamFilter = true) => {\n const { getBalance: getBalanceFromApi } = await import(\"../utils.js\");\n\n try {\n // Use SwapKit API for comprehensive balance fetching (includes TRX + TRC20 tokens)\n const apiBalances = await getBalanceFromApi(Chain.Tron)(address, scamFilter);\n\n // If API returns balances, use those\n if (apiBalances.length > 0) {\n return apiBalances;\n }\n\n // Fallback to on-chain TRX balance if API fails or returns empty\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6, // TRX has 6 decimals\n }),\n ];\n } catch (error) {\n warnOnce(\n true,\n `Failed to get Tron balance for ${address}: ${error instanceof Error ? error.message : error}`,\n );\n\n // Final fallback: try to get just the native TRX balance\n try {\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n ];\n } catch (fallbackError) {\n warnOnce(\n true,\n `Failed to get native TRX balance for ${address}: ${fallbackError instanceof Error ? fallbackError.message : fallbackError}`,\n );\n return [];\n }\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = async ({\n assetValue,\n recipient,\n sender,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\n }: TronTransferParams & { sender?: string }) => {\n const isNative = assetValue.isGasAsset;\n\n try {\n // Get sender address\n const senderAddress = sender ? sender : signer ? await getAddress() : undefined;\n if (!senderAddress) {\n // If no signer, return conservative estimate\n return isNative\n ? AssetValue.from({ chain: Chain.Tron, value: 0.1, fromBaseDecimal: 0 })\n : AssetValue.from({ chain: Chain.Tron, value: 15, fromBaseDecimal: 0 });\n }\n\n // Get chain parameters for current resource prices\n const chainParams = await getChainParameters();\n\n // Check if recipient account exists (new accounts require activation fee)\n const recipientExists = await accountExists(recipient);\n const activationFee = recipientExists ? 0 : chainParams.createAccountFee;\n\n // Get account resources\n const resources = await getAccountResources(senderAddress);\n\n if (isNative) {\n // Calculate bandwidth needed for TRX transfer\n const bandwidthNeeded = TRX_TRANSFER_BANDWIDTH;\n const availableBandwidth =\n resources.bandwidth.free + (resources.bandwidth.total - resources.bandwidth.used);\n\n let bandwidthFee = 0;\n if (bandwidthNeeded > availableBandwidth) {\n // Need to burn TRX for bandwidth\n const bandwidthToBuy = bandwidthNeeded - availableBandwidth;\n bandwidthFee = bandwidthToBuy * chainParams.bandwidthFee;\n }\n\n // Total fee in SUN\n const totalFeeSun = activationFee + bandwidthFee;\n\n return AssetValue.from({\n chain: Chain.Tron,\n value: totalFeeSun,\n fromBaseDecimal: 6, // SUN to TRX\n });\n }\n\n // TRC20 Transfer - needs both bandwidth and energy\n const bandwidthNeeded = TRC20_TRANSFER_BANDWIDTH;\n const energyNeeded = TRC20_TRANSFER_ENERGY;\n\n const availableBandwidth =\n resources.bandwidth.free + (resources.bandwidth.total - resources.bandwidth.used);\n const availableEnergy = resources.energy.total - resources.energy.used;\n\n let bandwidthFee = 0;\n if (bandwidthNeeded > availableBandwidth) {\n const bandwidthToBuy = bandwidthNeeded - availableBandwidth;\n bandwidthFee = bandwidthToBuy * chainParams.bandwidthFee;\n }\n\n let energyFee = 0;\n if (energyNeeded > availableEnergy) {\n const energyToBuy = energyNeeded - availableEnergy;\n energyFee = energyToBuy * chainParams.energyFee;\n }\n\n // Total fee in SUN\n const totalFeeSun = activationFee + bandwidthFee + energyFee;\n\n return AssetValue.from({\n chain: Chain.Tron,\n value: totalFeeSun,\n fromBaseDecimal: 6, // SUN to TRX\n });\n } catch (error) {\n // Fallback to conservative estimates if calculation fails\n warnOnce(\n true,\n `Failed to calculate exact fee, using conservative estimate: ${error instanceof Error ? error.message : error}`,\n );\n\n throw new SwapKitError(\"toolbox_tron_fee_estimation_failed\", { error });\n }\n };\n\n const createTransaction = async (params: TronCreateTransactionParams) => {\n const { recipient, assetValue, memo, sender } = params;\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n sender,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n // First, try using triggerSmartContract (might work despite the known bug)\n try {\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const options = {\n feeLimit: calculateFeeLimit(),\n callValue: 0,\n };\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n options,\n parameter,\n sender,\n );\n\n return result.transaction;\n } catch (error) {\n // If both methods fail, throw a descriptive error\n throw new SwapKitError(\"toolbox_tron_transaction_creation_failed\", {\n message:\n \"Failed to create TRC20 transaction. This might be due to TronWeb 6.0.3 bug. Use the transfer method directly instead.\",\n originalError: error instanceof Error ? error.message : String(error),\n });\n }\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress: await getTronAddressValidator(),\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
|
|
6
|
-
"export const trc20ABI = [\n {\n constant: true,\n inputs: [{ name: \"_owner\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"balance\", type: \"uint256\" }],\n type: \"function\",\n },\n {\n constant: false,\n inputs: [\n { name: \"_to\", type: \"address\" },\n { name: \"_value\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"success\", type: \"bool\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"decimals\",\n outputs: [{ name: \"\", type: \"uint8\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"symbol\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"name\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n] as const;\n"
|
|
5
|
+
"import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport { fetchAccountFromTronGrid } from \"./helpers/trongrid.js\";\nimport type {\n TronCreateTransactionParams,\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nimport { TronWeb } from \"tronweb\";\n\n// Constants for TRON resource calculation\nconst TRX_TRANSFER_BANDWIDTH = 268; // Bandwidth consumed by a TRX transfer\nconst TRC20_TRANSFER_ENERGY = 13000; // Average energy consumed by TRC20 transfer\nconst TRC20_TRANSFER_BANDWIDTH = 345; // Bandwidth consumed by TRC20 transfer\n\n// Known TRON tokens\nconst TRON_USDT_CONTRACT = \"TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t\";\n\nexport async function getTronAddressValidator() {\n return (address: string) => {\n return TronWeb.isAddress(address);\n };\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], {\n index: index || 0,\n }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}) {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n /**\n * Get current chain parameters including resource prices\n */\n const getChainParameters = async () => {\n try {\n const parameters = await tronWeb.trx.getChainParameters();\n const paramMap: Record<string, number> = {};\n\n for (const param of parameters) {\n paramMap[param.key] = param.value;\n }\n\n return {\n energyFee: paramMap.getEnergyFee || 420, // SUN per energy unit\n bandwidthFee: paramMap.getTransactionFee || 1000, // SUN per bandwidth unit\n createAccountFee: paramMap.getCreateAccountFee || 100000, // 0.1 TRX in SUN\n };\n } catch {\n // Return default values if unable to fetch\n return {\n energyFee: 420,\n bandwidthFee: 1000,\n createAccountFee: 100000,\n };\n }\n };\n\n /**\n * Check if an address exists on the blockchain\n */\n const accountExists = async (address: string) => {\n try {\n const account = await tronWeb.trx.getAccount(address);\n return account && Object.keys(account).length > 0;\n } catch {\n return false;\n }\n };\n\n /**\n * Get account resources (bandwidth and energy)\n */\n const getAccountResources = async (address: string) => {\n try {\n const resources = await tronWeb.trx.getAccountResources(address);\n\n return {\n bandwidth: {\n free: resources.freeNetLimit - resources.freeNetUsed,\n total: resources.NetLimit || 0,\n used: resources.NetUsed || 0,\n },\n energy: {\n total: resources.EnergyLimit || 0,\n used: resources.EnergyUsed || 0,\n },\n };\n } catch {\n // Return default structure if unable to fetch\n return {\n bandwidth: { free: 600, total: 0, used: 0 }, // 600 free bandwidth daily\n energy: { total: 0, used: 0 },\n };\n }\n };\n\n /**\n * Get token balance and info directly from contract\n */\n const fetchTokenBalance = async (address: string, contractAddress: string) => {\n try {\n const contract = tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.balanceOf) {\n return 0n;\n }\n\n const balance = (await contract.methods.balanceOf(address).call())[0] as string;\n\n return BigInt(balance || 0); // Convert to BigInt for consistency\n } catch (err) {\n console.warn(`balanceOf() failed for ${contractAddress}:`, err);\n return 0n;\n }\n };\n\n /**\n * Get token balance and info directly from contract\n */\n const fetchTokenMetadata = async (contractAddress: string, address: string) => {\n try {\n tronWeb.setAddress(address); // Set address for contract calls\n const contract = tronWeb.contract(trc20ABI, contractAddress);\n\n const [symbolRaw, decimalsRaw] = await Promise.all([\n contract\n .symbol()\n .call()\n .catch(() => \"UNKNOWN\"),\n contract\n .decimals()\n .call()\n .catch(() => \"18\"),\n ]);\n\n return {\n symbol: symbolRaw ?? \"UNKNOWN\",\n decimals: Number(decimalsRaw ?? 18),\n };\n } catch (error) {\n warnOnce(\n true,\n `Failed to get token balance for ${contractAddress}: ${error instanceof Error ? error.message : error}`,\n );\n return null;\n }\n };\n\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\n const getBalance = async (address: string, _scamFilter = true) => {\n const fallbackBalance = [\n AssetValue.from({\n chain: Chain.Tron,\n }),\n ];\n // Try primary source (TronGrid)\n try {\n const accountData = await fetchAccountFromTronGrid(address);\n if (accountData) {\n const balances: AssetValue[] = [];\n\n // Add TRX balance\n balances.push(\n AssetValue.from({\n chain: Chain.Tron,\n value: accountData.balance,\n fromBaseDecimal: 6,\n }),\n );\n\n // Add TRC20 balances\n\n for (const token of accountData.trc20) {\n const [contractAddress, balance] = Object.entries(token)[0] || [];\n\n if (!(contractAddress && balance)) continue;\n\n const tokenMetaData = await fetchTokenMetadata(contractAddress, address);\n\n if (!tokenMetaData) continue;\n\n balances.push(\n AssetValue.from({\n asset: `TRX.${tokenMetaData.symbol}-${contractAddress}`,\n value: BigInt(balance || 0),\n fromBaseDecimal: tokenMetaData.decimals,\n }),\n );\n }\n\n return balances;\n }\n return fallbackBalance;\n } catch (error) {\n warnOnce(\n true,\n `Tron API getBalance failed: ${error instanceof Error ? error.message : error}`,\n );\n\n // Fallback: get TRX and USDT directly\n const balances: AssetValue[] = [];\n\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n if (trxBalanceInSun && Number(trxBalanceInSun) > 0) {\n balances.push(\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n );\n }\n\n const usdtBalance = await fetchTokenBalance(address, TRON_USDT_CONTRACT);\n if (usdtBalance) {\n balances.push(\n AssetValue.from({\n asset: `TRX.USDT-${TRON_USDT_CONTRACT}`,\n value: usdtBalance,\n fromBaseDecimal: 6,\n }),\n );\n }\n\n return balances;\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = async ({\n assetValue,\n recipient,\n sender,\n // biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\n }: TronTransferParams & { sender?: string }) => {\n const isNative = assetValue.isGasAsset;\n\n try {\n // Get sender address\n const senderAddress = sender ? sender : signer ? await getAddress() : undefined;\n if (!senderAddress) {\n // If no signer, return conservative estimate\n return isNative\n ? AssetValue.from({ chain: Chain.Tron, value: 0.1, fromBaseDecimal: 0 })\n : AssetValue.from({ chain: Chain.Tron, value: 15, fromBaseDecimal: 0 });\n }\n\n // Get chain parameters for current resource prices\n const chainParams = await getChainParameters();\n\n // Check if recipient account exists (new accounts require activation fee)\n const recipientExists = await accountExists(recipient);\n const activationFee = recipientExists ? 0 : chainParams.createAccountFee;\n\n // Get account resources\n const resources = await getAccountResources(senderAddress);\n\n if (isNative) {\n // Calculate bandwidth needed for TRX transfer\n const bandwidthNeeded = TRX_TRANSFER_BANDWIDTH;\n const availableBandwidth =\n resources.bandwidth.free + (resources.bandwidth.total - resources.bandwidth.used);\n\n let bandwidthFee = 0;\n if (bandwidthNeeded > availableBandwidth) {\n // Need to burn TRX for bandwidth\n const bandwidthToBuy = bandwidthNeeded - availableBandwidth;\n bandwidthFee = bandwidthToBuy * chainParams.bandwidthFee;\n }\n\n // Total fee in SUN\n const totalFeeSun = activationFee + bandwidthFee;\n\n return AssetValue.from({\n chain: Chain.Tron,\n value: totalFeeSun,\n fromBaseDecimal: 6, // SUN to TRX\n });\n }\n\n // TRC20 Transfer - needs both bandwidth and energy\n const bandwidthNeeded = TRC20_TRANSFER_BANDWIDTH;\n const energyNeeded = TRC20_TRANSFER_ENERGY;\n\n const availableBandwidth =\n resources.bandwidth.free + (resources.bandwidth.total - resources.bandwidth.used);\n const availableEnergy = resources.energy.total - resources.energy.used;\n\n let bandwidthFee = 0;\n if (bandwidthNeeded > availableBandwidth) {\n const bandwidthToBuy = bandwidthNeeded - availableBandwidth;\n bandwidthFee = bandwidthToBuy * chainParams.bandwidthFee;\n }\n\n let energyFee = 0;\n if (energyNeeded > availableEnergy) {\n const energyToBuy = energyNeeded - availableEnergy;\n energyFee = energyToBuy * chainParams.energyFee;\n }\n\n // Total fee in SUN\n const totalFeeSun = activationFee + bandwidthFee + energyFee;\n\n return AssetValue.from({\n chain: Chain.Tron,\n value: totalFeeSun,\n fromBaseDecimal: 6, // SUN to TRX\n });\n } catch (error) {\n // Fallback to conservative estimates if calculation fails\n warnOnce(\n true,\n `Failed to calculate exact fee, using conservative estimate: ${error instanceof Error ? error.message : error}`,\n );\n\n throw new SwapKitError(\"toolbox_tron_fee_estimation_failed\", { error });\n }\n };\n\n const createTransaction = async (params: TronCreateTransactionParams) => {\n const { recipient, assetValue, memo, sender } = params;\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n sender,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n // First, try using triggerSmartContract (might work despite the known bug)\n try {\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const options = {\n feeLimit: calculateFeeLimit(),\n callValue: 0,\n };\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n options,\n parameter,\n sender,\n );\n\n return result.transaction;\n } catch (error) {\n // If both methods fail, throw a descriptive error\n throw new SwapKitError(\"toolbox_tron_transaction_creation_failed\", {\n message:\n \"Failed to create TRC20 transaction. This might be due to TronWeb 6.0.3 bug. Use the transfer method directly instead.\",\n originalError: error instanceof Error ? error.message : String(error),\n });\n }\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress: await getTronAddressValidator(),\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
|
|
6
|
+
"export const trc20ABI = [\n {\n constant: true,\n inputs: [{ name: \"_owner\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"balance\", type: \"uint256\" }],\n type: \"function\",\n },\n {\n constant: false,\n inputs: [\n { name: \"_to\", type: \"address\" },\n { name: \"_value\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"success\", type: \"bool\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"decimals\",\n outputs: [{ name: \"\", type: \"uint8\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"symbol\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"name\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n] as const;\n",
|
|
7
|
+
"import { SwapKitError } from \"@swapkit/helpers\";\nimport { TronWeb } from \"tronweb\";\nimport type { TronGridAccountResponse } from \"../types.js\";\n\nconst TRONGRID_API_BASE = \"https://api.trongrid.io\";\n\n/**\n * Fetch account information including TRC20 balances from TronGrid API\n */\nexport async function fetchAccountFromTronGrid(address: string) {\n try {\n const response = await fetch(`${TRONGRID_API_BASE}/v1/accounts/${address}`);\n\n if (!response.ok) {\n throw new Error(`TronGrid API error: ${response.status} ${response.statusText}`);\n }\n\n const data = (await response.json()) as TronGridAccountResponse;\n\n if (!(data.success && data.data) || data.data.length === 0) {\n throw new Error(\"Invalid response from TronGrid API\");\n }\n\n // Convert search address to hex format for comparison\n let searchAddressHex: string;\n try {\n // If address is base58, convert to hex\n searchAddressHex = TronWeb.address.toHex(address).toLowerCase();\n } catch {\n // If conversion fails, assume it's already hex\n searchAddressHex = address.toLowerCase();\n }\n\n // Find the account that matches the requested address\n const account = data.data.find((acc) => {\n return acc.address.toLowerCase() === searchAddressHex;\n });\n\n if (!account) {\n return;\n }\n\n // Return simplified object with balance and trc20 array\n return {\n balance: account.balance,\n trc20: account.trc20 || [],\n };\n } catch (error) {\n throw new SwapKitError(\"toolbox_tron_trongrid_api_error\", {\n message: error instanceof Error ? error.message : \"Unknown error\",\n address,\n });\n }\n}\n"
|
|
7
8
|
],
|
|
8
|
-
"mappings": "
|
|
9
|
-
"debugId": "
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "8C1B70DA6AF55BEC64756E2164756E21",
|
|
10
11
|
"names": []
|
|
11
12
|
}
|