@swapkit/toolboxes 4.3.6 → 4.3.8

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.
Files changed (61) hide show
  1. package/dist/src/evm/index.cjs +2 -2
  2. package/dist/src/evm/index.cjs.map +7 -7
  3. package/dist/src/evm/index.js +2 -2
  4. package/dist/src/evm/index.js.map +7 -7
  5. package/dist/src/index.cjs +3 -3
  6. package/dist/src/index.cjs.map +13 -13
  7. package/dist/src/index.js +3 -3
  8. package/dist/src/index.js.map +13 -13
  9. package/dist/src/near/index.cjs +2 -2
  10. package/dist/src/near/index.cjs.map +3 -3
  11. package/dist/src/near/index.js +2 -2
  12. package/dist/src/near/index.js.map +3 -3
  13. package/dist/src/radix/index.cjs +2 -2
  14. package/dist/src/radix/index.cjs.map +3 -3
  15. package/dist/src/radix/index.js +2 -2
  16. package/dist/src/radix/index.js.map +3 -3
  17. package/dist/src/solana/index.cjs +2 -2
  18. package/dist/src/solana/index.cjs.map +3 -3
  19. package/dist/src/solana/index.js +2 -2
  20. package/dist/src/solana/index.js.map +3 -3
  21. package/dist/src/substrate/index.cjs +2 -2
  22. package/dist/src/substrate/index.cjs.map +3 -3
  23. package/dist/src/substrate/index.js +2 -2
  24. package/dist/src/substrate/index.js.map +3 -3
  25. package/dist/src/sui/index.cjs +2 -2
  26. package/dist/src/sui/index.cjs.map +3 -3
  27. package/dist/src/sui/index.js +2 -2
  28. package/dist/src/sui/index.js.map +3 -3
  29. package/dist/src/ton/index.cjs +2 -2
  30. package/dist/src/ton/index.cjs.map +3 -3
  31. package/dist/src/ton/index.js +2 -2
  32. package/dist/src/ton/index.js.map +3 -3
  33. package/dist/src/utxo/index.cjs +3 -3
  34. package/dist/src/utxo/index.cjs.map +4 -4
  35. package/dist/src/utxo/index.js +3 -3
  36. package/dist/src/utxo/index.js.map +4 -4
  37. package/dist/types/evm/helpers.d.ts +1 -1
  38. package/dist/types/evm/helpers.d.ts.map +1 -1
  39. package/dist/types/evm/toolbox/baseEVMToolbox.d.ts +2 -0
  40. package/dist/types/evm/toolbox/baseEVMToolbox.d.ts.map +1 -1
  41. package/dist/types/evm/toolbox/evm.d.ts +38 -38
  42. package/dist/types/evm/toolbox/evm.d.ts.map +1 -1
  43. package/dist/types/evm/toolbox/op.d.ts +2 -14
  44. package/dist/types/evm/toolbox/op.d.ts.map +1 -1
  45. package/dist/types/radix/index.d.ts.map +1 -1
  46. package/dist/types/solana/toolbox.d.ts.map +1 -1
  47. package/dist/types/sui/toolbox.d.ts.map +1 -1
  48. package/dist/types/utils.d.ts.map +1 -1
  49. package/dist/types/utxo/toolbox/zcash.d.ts.map +1 -1
  50. package/package.json +2 -2
  51. package/src/evm/helpers.ts +7 -9
  52. package/src/evm/toolbox/baseEVMToolbox.ts +4 -1
  53. package/src/evm/toolbox/evm.ts +2 -3
  54. package/src/evm/toolbox/op.ts +1 -21
  55. package/src/radix/index.ts +7 -1
  56. package/src/solana/toolbox.ts +2 -8
  57. package/src/substrate/balance.ts +2 -2
  58. package/src/sui/toolbox.ts +4 -3
  59. package/src/ton/toolbox.ts +2 -2
  60. package/src/utils.ts +8 -1
  61. package/src/utxo/toolbox/zcash.ts +1 -4
@@ -1,4 +1,4 @@
1
- var S=Object.create;var{getPrototypeOf:h,defineProperty:v,getOwnPropertyNames:o}=Object;var m=Object.prototype.hasOwnProperty;var Y=(b,f,P)=>{P=b!=null?S(h(b)):{};let W=f||!b||!b.__esModule?v(P,"default",{value:b,enumerable:!0}):P;for(let q of o(b))if(!m.call(W,q))v(W,q,{get:()=>b[q],enumerable:!0});return W};var p=(b,f)=>{for(var P in f)v(b,P,{get:f[P],enumerable:!0,configurable:!0,set:(W)=>f[P]=()=>W})};var _=(b,f)=>()=>(b&&(f=b(b=0)),f);var Z=((b)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(b,{get:(f,P)=>(typeof require<"u"?require:f)[P]}):b)(function(b){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+b+'" is not supported')});import{AssetValue as $,Chain as x,getChainConfig as C,SwapKitError as J}from"@swapkit/helpers";import{match as A,P as D}from"ts-pattern";async function Q(){let{isValidSuiAddress:b}=await import("@mysten/sui/utils");return function(P){try{return b(P)}catch{return!1}}}async function V({provider:b,...f}={}){let P=await Q(),W=await A(f).with({phrase:D.string},async({phrase:G})=>{let{Ed25519Keypair:R}=await import("@mysten/sui/keypairs/ed25519");return R.deriveKeypair(G)}).with({signer:D.any},({signer:G})=>G).otherwise(()=>{return});async function q(G=b){let{SuiClient:R,getFullnodeUrl:j}=await import("@mysten/sui/client");return new R({url:G||j("mainnet")})}function M(){return W?.toSuiAddress()||""}async function y(G){let R=G||M();if(!R)throw new J("toolbox_sui_address_required");try{let j=await q(),{totalBalance:z}=await j.getBalance({owner:R}),{baseDecimal:I,chain:k}=C(x.Sui),O=[$.from({chain:k,fromBaseDecimal:I,value:z})],H=await j.getAllBalances({owner:R});for(let{coinType:L,totalBalance:X}of H){if(L==="0x2::sui::SUI")continue;if(Number(X)>0){let E=L.split("::").pop()?.toUpperCase()||"UNKNOWN",K=`${k}.${E}-${L}`;O.push($.from({asset:K,fromBaseDecimal:I,value:X}))}}return O}catch(j){throw new J("toolbox_sui_balance_error",{error:j})}}async function U(G){let R=$.from({chain:x.Sui,value:"0.01"});if(!G)return R;try{let j=await q(),{txBytes:z}=await N(G),{effects:{status:I,gasUsed:k}}=await j.dryRunTransactionBlock({transactionBlock:z});if(I.status!=="success")return R;let O=Number(k.computationCost)+Number(k.storageCost)-Number(k.storageRebate);return $.from({chain:x.Sui,value:O.toString()})}catch{return R}}async function N({recipient:G,assetValue:R,gasBudget:j,sender:z}){let{Transaction:I}=await import("@mysten/sui/transactions"),k=z||M();if(!k)throw new J("toolbox_sui_no_sender");try{let O=new I;if(O.setSender(k),R.isGasAsset||R.symbol==="SUI"){let[X]=O.splitCoins(O.gas,[R.getBaseValue("string")]);O.transferObjects([X],G)}else throw new J("toolbox_sui_custom_token_transfer_not_implemented");if(j)O.setGasBudget(j);let H=await q(),L=await O.build({client:H});return{tx:O,txBytes:L}}catch(O){throw new J("toolbox_sui_transaction_creation_error",{error:O})}}async function F(G){if(!W)throw new J("toolbox_sui_no_signer");if(G instanceof Uint8Array)return W.signTransaction(G);let{txBytes:R}="tx"in G?G:await N(G);return W.signTransaction(R)}async function w({assetValue:G,gasBudget:R,recipient:j}){if(!W)throw new J("toolbox_sui_no_signer");let z=W.toSuiAddress()||M();if(!z)throw new J("toolbox_sui_no_sender");let{txBytes:I}=await N({assetValue:G,gasBudget:R,recipient:j,sender:z}),k=await q(),{digest:O}=await k.signAndExecuteTransaction({signer:W,transaction:I});return O}return{createTransaction:N,estimateTransactionFee:U,getAddress:M,getBalance:y,signTransaction:F,transfer:w,validateAddress:P}}var T=()=>{};var c={};p(c,{getSuiToolbox:()=>V,getSuiAddressValidator:()=>Q});var g=_(()=>{T()});g();export{V as getSuiToolbox,Q as getSuiAddressValidator};
1
+ var S=Object.create;var{getPrototypeOf:o,defineProperty:v,getOwnPropertyNames:h}=Object;var m=Object.prototype.hasOwnProperty;var Z=(b,f,P)=>{P=b!=null?S(o(b)):{};let W=f||!b||!b.__esModule?v(P,"default",{value:b,enumerable:!0}):P;for(let z of h(b))if(!m.call(W,z))v(W,z,{get:()=>b[z],enumerable:!0});return W};var p=(b,f)=>{for(var P in f)v(b,P,{get:f[P],enumerable:!0,configurable:!0,set:(W)=>f[P]=()=>W})};var _=(b,f)=>()=>(b&&(f=b(b=0)),f);var $=((b)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(b,{get:(f,P)=>(typeof require<"u"?require:f)[P]}):b)(function(b){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+b+'" is not supported')});import{AssetValue as M,Chain as x,getChainConfig as C,SwapKitError as J}from"@swapkit/helpers";import{match as A,P as D}from"ts-pattern";async function Q(){let{isValidSuiAddress:b}=await import("@mysten/sui/utils");return function(P){try{return b(P)}catch{return!1}}}async function V({provider:b,...f}={}){let P=await Q(),W=await A(f).with({phrase:D.string},async({phrase:G})=>{let{Ed25519Keypair:R}=await import("@mysten/sui/keypairs/ed25519");return R.deriveKeypair(G)}).with({signer:D.any},({signer:G})=>G).otherwise(()=>{return});async function z(G=b){let{SuiClient:R,getFullnodeUrl:j}=await import("@mysten/sui/client");return new R({url:G||j("mainnet")})}function N(){return W?.toSuiAddress()||""}async function y(G){let R=G||N();if(!R)throw new J("toolbox_sui_address_required");let{baseDecimal:j,chain:k}=C(x.Sui);try{let I=await z(),{totalBalance:q}=await I.getBalance({owner:R}),O=[M.from({chain:k,fromBaseDecimal:j,value:q})],H=await I.getAllBalances({owner:R});for(let{coinType:L,totalBalance:Y}of H){if(L==="0x2::sui::SUI")continue;if(Number(Y)>0){let E=L.split("::").pop()?.toUpperCase()||"UNKNOWN",K=`${k}.${E}-${L}`;O.push(M.from({asset:K,fromBaseDecimal:j,value:Y}))}}return O}catch{return[M.from({chain:k})]}}async function U(G){let R=M.from({chain:x.Sui,value:"0.01"});if(!G)return R;try{let j=await z(),{txBytes:k}=await X(G),{effects:{status:I,gasUsed:q}}=await j.dryRunTransactionBlock({transactionBlock:k});if(I.status!=="success")return R;let O=Number(q.computationCost)+Number(q.storageCost)-Number(q.storageRebate);return M.from({chain:x.Sui,value:O.toString()})}catch{return R}}async function X({recipient:G,assetValue:R,gasBudget:j,sender:k}){let{Transaction:I}=await import("@mysten/sui/transactions"),q=k||N();if(!q)throw new J("toolbox_sui_no_sender");try{let O=new I;if(O.setSender(q),R.isGasAsset||R.symbol==="SUI"){let[Y]=O.splitCoins(O.gas,[R.getBaseValue("string")]);O.transferObjects([Y],G)}else throw new J("toolbox_sui_custom_token_transfer_not_implemented");if(j)O.setGasBudget(j);let H=await z(),L=await O.build({client:H});return{tx:O,txBytes:L}}catch(O){throw new J("toolbox_sui_transaction_creation_error",{error:O})}}async function F(G){if(!W)throw new J("toolbox_sui_no_signer");if(G instanceof Uint8Array)return W.signTransaction(G);let{txBytes:R}="tx"in G?G:await X(G);return W.signTransaction(R)}async function w({assetValue:G,gasBudget:R,recipient:j}){if(!W)throw new J("toolbox_sui_no_signer");let k=W.toSuiAddress()||N();if(!k)throw new J("toolbox_sui_no_sender");let{txBytes:I}=await X({assetValue:G,gasBudget:R,recipient:j,sender:k}),q=await z(),{digest:O}=await q.signAndExecuteTransaction({signer:W,transaction:I});return O}return{createTransaction:X,estimateTransactionFee:U,getAddress:N,getBalance:y,signTransaction:F,transfer:w,validateAddress:P}}var T=()=>{};var c={};p(c,{getSuiToolbox:()=>V,getSuiAddressValidator:()=>Q});var g=_(()=>{T()});g();export{V as getSuiToolbox,Q as getSuiAddressValidator};
2
2
 
3
- //# debugId=20A44EBE57FF7A1064756E2164756E21
3
+ //# debugId=141CEF8B139E797464756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/sui/toolbox.ts", "../src/sui/index.ts"],
4
4
  "sourcesContent": [
5
- "import { AssetValue, Chain, getChainConfig, SwapKitError } from \"@swapkit/helpers\";\nimport { match, P } from \"ts-pattern\";\nimport type { SuiCreateTransactionParams, SuiToolboxParams, SuiTransferParams } from \"./types\";\n\nexport async function getSuiAddressValidator() {\n const { isValidSuiAddress } = await import(\"@mysten/sui/utils\");\n\n return function validateAddress(address: string) {\n try {\n return isValidSuiAddress(address);\n } catch {\n return false;\n }\n };\n}\n\nexport async function getSuiToolbox({ provider: providerParam, ...signerParams }: SuiToolboxParams = {}) {\n const validateAddress = await getSuiAddressValidator();\n\n const signer = await match(signerParams)\n .with({ phrase: P.string }, async ({ phrase }) => {\n const { Ed25519Keypair } = await import(\"@mysten/sui/keypairs/ed25519\");\n return Ed25519Keypair.deriveKeypair(phrase);\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n async function getSuiClient(url = providerParam) {\n const { SuiClient, getFullnodeUrl } = await import(\"@mysten/sui/client\");\n return new SuiClient({ url: url || getFullnodeUrl(\"mainnet\") });\n }\n\n function getAddress() {\n return signer?.toSuiAddress() || \"\";\n }\n\n async function getBalance(targetAddress?: string) {\n const addressToQuery = targetAddress || getAddress();\n if (!addressToQuery) {\n throw new SwapKitError(\"toolbox_sui_address_required\" as any);\n }\n\n try {\n const suiClient = await getSuiClient();\n const { totalBalance } = await suiClient.getBalance({ owner: addressToQuery });\n const { baseDecimal: fromBaseDecimal, chain } = getChainConfig(Chain.Sui);\n\n const suiBalances = [AssetValue.from({ chain, fromBaseDecimal, value: totalBalance })];\n\n const coinBalances = await suiClient.getAllBalances({ owner: addressToQuery });\n for (const { coinType, totalBalance } of coinBalances) {\n if (coinType === \"0x2::sui::SUI\") continue; // Skip SUI as we already added it\n\n if (Number(totalBalance) > 0) {\n const symbol = coinType.split(\"::\").pop()?.toUpperCase() || \"UNKNOWN\";\n const asset = `${chain}.${symbol}-${coinType}`;\n // Default to 9 decimals, should be fetched from coin metadata\n suiBalances.push(AssetValue.from({ asset, fromBaseDecimal, value: totalBalance }));\n }\n }\n\n return suiBalances;\n } catch (error) {\n throw new SwapKitError(\"toolbox_sui_balance_error\" as any, { error });\n }\n }\n\n async function estimateTransactionFee(params?: SuiCreateTransactionParams) {\n const defaultFee = AssetValue.from({ chain: Chain.Sui, value: \"0.01\" });\n\n if (!params) return defaultFee;\n\n try {\n const suiClient = await getSuiClient();\n const { txBytes } = await createTransaction(params);\n const {\n effects: { status, gasUsed },\n } = await suiClient.dryRunTransactionBlock({ transactionBlock: txBytes });\n\n if (status.status !== \"success\") return defaultFee;\n\n const totalGas = Number(gasUsed.computationCost) + Number(gasUsed.storageCost) - Number(gasUsed.storageRebate);\n\n return AssetValue.from({ chain: Chain.Sui, value: totalGas.toString() });\n } catch {\n return defaultFee;\n }\n }\n\n async function createTransaction({ recipient, assetValue, gasBudget, sender }: SuiCreateTransactionParams) {\n const { Transaction } = await import(\"@mysten/sui/transactions\");\n\n const senderAddress = sender || getAddress();\n\n if (!senderAddress) {\n throw new SwapKitError(\"toolbox_sui_no_sender\");\n }\n\n try {\n const tx = new Transaction();\n tx.setSender(senderAddress);\n\n if (assetValue.isGasAsset || assetValue.symbol === \"SUI\") {\n const [suiCoin] = tx.splitCoins(tx.gas, [assetValue.getBaseValue(\"string\")]);\n tx.transferObjects([suiCoin], recipient);\n } else {\n throw new SwapKitError(\"toolbox_sui_custom_token_transfer_not_implemented\" as any);\n }\n\n if (gasBudget) {\n tx.setGasBudget(gasBudget);\n }\n\n const suiClient = await getSuiClient();\n const txBytes = await tx.build({ client: suiClient });\n\n return { tx, txBytes };\n } catch (error) {\n throw new SwapKitError(\"toolbox_sui_transaction_creation_error\" as any, { error });\n }\n }\n\n async function signTransaction(\n params: Uint8Array<ArrayBuffer> | SuiCreateTransactionParams | Awaited<ReturnType<typeof createTransaction>>,\n ) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_sui_no_signer\");\n }\n\n if (params instanceof Uint8Array) {\n return signer.signTransaction(params);\n }\n\n const { txBytes } = \"tx\" in params ? params : await createTransaction(params);\n\n return signer.signTransaction(txBytes);\n }\n\n async function transfer({ assetValue, gasBudget, recipient }: SuiTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_sui_no_signer\" as any);\n }\n\n const sender = signer.toSuiAddress() || getAddress();\n if (!sender) {\n throw new SwapKitError(\"toolbox_sui_no_sender\");\n }\n\n const { txBytes } = await createTransaction({ assetValue, gasBudget, recipient, sender });\n const suiClient = await getSuiClient();\n const { digest: txHash } = await suiClient.signAndExecuteTransaction({ signer, transaction: txBytes });\n\n return txHash;\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n signTransaction,\n transfer,\n validateAddress,\n };\n}\n",
5
+ "import { AssetValue, Chain, getChainConfig, SwapKitError } from \"@swapkit/helpers\";\nimport { match, P } from \"ts-pattern\";\nimport type { SuiCreateTransactionParams, SuiToolboxParams, SuiTransferParams } from \"./types\";\n\nexport async function getSuiAddressValidator() {\n const { isValidSuiAddress } = await import(\"@mysten/sui/utils\");\n\n return function validateAddress(address: string) {\n try {\n return isValidSuiAddress(address);\n } catch {\n return false;\n }\n };\n}\n\nexport async function getSuiToolbox({ provider: providerParam, ...signerParams }: SuiToolboxParams = {}) {\n const validateAddress = await getSuiAddressValidator();\n\n const signer = await match(signerParams)\n .with({ phrase: P.string }, async ({ phrase }) => {\n const { Ed25519Keypair } = await import(\"@mysten/sui/keypairs/ed25519\");\n return Ed25519Keypair.deriveKeypair(phrase);\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n async function getSuiClient(url = providerParam) {\n const { SuiClient, getFullnodeUrl } = await import(\"@mysten/sui/client\");\n return new SuiClient({ url: url || getFullnodeUrl(\"mainnet\") });\n }\n\n function getAddress() {\n return signer?.toSuiAddress() || \"\";\n }\n\n async function getBalance(targetAddress?: string) {\n const addressToQuery = targetAddress || getAddress();\n if (!addressToQuery) {\n throw new SwapKitError(\"toolbox_sui_address_required\" as any);\n }\n\n const { baseDecimal: fromBaseDecimal, chain } = getChainConfig(Chain.Sui);\n\n try {\n const suiClient = await getSuiClient();\n const { totalBalance } = await suiClient.getBalance({ owner: addressToQuery });\n\n const suiBalances = [AssetValue.from({ chain, fromBaseDecimal, value: totalBalance })];\n\n const coinBalances = await suiClient.getAllBalances({ owner: addressToQuery });\n for (const { coinType, totalBalance } of coinBalances) {\n if (coinType === \"0x2::sui::SUI\") continue; // Skip SUI as we already added it\n\n if (Number(totalBalance) > 0) {\n const symbol = coinType.split(\"::\").pop()?.toUpperCase() || \"UNKNOWN\";\n const asset = `${chain}.${symbol}-${coinType}`;\n // Default to 9 decimals, should be fetched from coin metadata\n suiBalances.push(AssetValue.from({ asset, fromBaseDecimal, value: totalBalance }));\n }\n }\n\n return suiBalances;\n } catch {\n return [AssetValue.from({ chain })];\n }\n }\n\n async function estimateTransactionFee(params?: SuiCreateTransactionParams) {\n const defaultFee = AssetValue.from({ chain: Chain.Sui, value: \"0.01\" });\n\n if (!params) return defaultFee;\n\n try {\n const suiClient = await getSuiClient();\n const { txBytes } = await createTransaction(params);\n const {\n effects: { status, gasUsed },\n } = await suiClient.dryRunTransactionBlock({ transactionBlock: txBytes });\n\n if (status.status !== \"success\") return defaultFee;\n\n const totalGas = Number(gasUsed.computationCost) + Number(gasUsed.storageCost) - Number(gasUsed.storageRebate);\n\n return AssetValue.from({ chain: Chain.Sui, value: totalGas.toString() });\n } catch {\n return defaultFee;\n }\n }\n\n async function createTransaction({ recipient, assetValue, gasBudget, sender }: SuiCreateTransactionParams) {\n const { Transaction } = await import(\"@mysten/sui/transactions\");\n\n const senderAddress = sender || getAddress();\n\n if (!senderAddress) {\n throw new SwapKitError(\"toolbox_sui_no_sender\");\n }\n\n try {\n const tx = new Transaction();\n tx.setSender(senderAddress);\n\n if (assetValue.isGasAsset || assetValue.symbol === \"SUI\") {\n const [suiCoin] = tx.splitCoins(tx.gas, [assetValue.getBaseValue(\"string\")]);\n tx.transferObjects([suiCoin], recipient);\n } else {\n throw new SwapKitError(\"toolbox_sui_custom_token_transfer_not_implemented\" as any);\n }\n\n if (gasBudget) {\n tx.setGasBudget(gasBudget);\n }\n\n const suiClient = await getSuiClient();\n const txBytes = await tx.build({ client: suiClient });\n\n return { tx, txBytes };\n } catch (error) {\n throw new SwapKitError(\"toolbox_sui_transaction_creation_error\" as any, { error });\n }\n }\n\n async function signTransaction(\n params: Uint8Array<ArrayBuffer> | SuiCreateTransactionParams | Awaited<ReturnType<typeof createTransaction>>,\n ) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_sui_no_signer\");\n }\n\n if (params instanceof Uint8Array) {\n return signer.signTransaction(params);\n }\n\n const { txBytes } = \"tx\" in params ? params : await createTransaction(params);\n\n return signer.signTransaction(txBytes);\n }\n\n async function transfer({ assetValue, gasBudget, recipient }: SuiTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_sui_no_signer\" as any);\n }\n\n const sender = signer.toSuiAddress() || getAddress();\n if (!sender) {\n throw new SwapKitError(\"toolbox_sui_no_sender\");\n }\n\n const { txBytes } = await createTransaction({ assetValue, gasBudget, recipient, sender });\n const suiClient = await getSuiClient();\n const { digest: txHash } = await suiClient.signAndExecuteTransaction({ signer, transaction: txBytes });\n\n return txHash;\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n signTransaction,\n transfer,\n validateAddress,\n };\n}\n",
6
6
  "export * from \"./toolbox\";\nexport * from \"./types\";\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "20A44EBE57FF7A1064756E2164756E21",
8
+ "mappings": "urBAAA,qBAAS,WAAY,oBAAO,kBAAgB,yBAC5C,gBAAS,OAAO,mBAGhB,eAAsB,CAAsB,EAAG,CAC7C,IAAQ,qBAAsB,KAAa,6BAE3C,OAAO,QAAwB,CAAC,EAAiB,CAC/C,GAAI,CACF,OAAO,EAAkB,CAAO,EAChC,KAAM,CACN,MAAO,KAKb,eAAsB,CAAa,EAAG,SAAU,KAAkB,GAAmC,CAAC,EAAG,CACvG,IAAM,EAAkB,MAAM,EAAuB,EAE/C,EAAS,MAAM,EAAM,CAAY,EACpC,KAAK,CAAE,OAAQ,EAAE,MAAO,EAAG,OAAS,YAAa,CAChD,IAAQ,kBAAmB,KAAa,wCACxC,OAAO,EAAe,cAAc,CAAM,EAC3C,EACA,KAAK,CAAE,OAAQ,EAAE,GAAI,EAAG,EAAG,YAAa,CAAM,EAC9C,UAAU,IAAG,CAAG,OAAS,EAE5B,eAAe,CAAY,CAAC,EAAM,EAAe,CAC/C,IAAQ,YAAW,kBAAmB,KAAa,8BACnD,OAAO,IAAI,EAAU,CAAE,IAAK,GAAO,EAAe,SAAS,CAAE,CAAC,EAGhE,SAAS,CAAU,EAAG,CACpB,OAAO,GAAQ,aAAa,GAAK,GAGnC,eAAe,CAAU,CAAC,EAAwB,CAChD,IAAM,EAAiB,GAAiB,EAAW,EACnD,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,8BAAqC,EAG9D,IAAQ,YAAa,EAAiB,SAAU,EAAe,EAAM,GAAG,EAExE,GAAI,CACF,IAAM,EAAY,MAAM,EAAa,GAC7B,gBAAiB,MAAM,EAAU,WAAW,CAAE,MAAO,CAAe,CAAC,EAEvE,EAAc,CAAC,EAAW,KAAK,CAAE,QAAO,kBAAiB,MAAO,CAAa,CAAC,CAAC,EAE/E,EAAe,MAAM,EAAU,eAAe,CAAE,MAAO,CAAe,CAAC,EAC7E,QAAa,WAAU,kBAAkB,EAAc,CACrD,GAAI,IAAa,gBAAiB,SAElC,GAAI,OAAO,CAAY,EAAI,EAAG,CAC5B,IAAM,EAAS,EAAS,MAAM,IAAI,EAAE,IAAI,GAAG,YAAY,GAAK,UACtD,EAAQ,GAAG,KAAS,KAAU,IAEpC,EAAY,KAAK,EAAW,KAAK,CAAE,QAAO,kBAAiB,MAAO,CAAa,CAAC,CAAC,GAIrF,OAAO,EACP,KAAM,CACN,MAAO,CAAC,EAAW,KAAK,CAAE,OAAM,CAAC,CAAC,GAItC,eAAe,CAAsB,CAAC,EAAqC,CACzE,IAAM,EAAa,EAAW,KAAK,CAAE,MAAO,EAAM,IAAK,MAAO,MAAO,CAAC,EAEtE,GAAI,CAAC,EAAQ,OAAO,EAEpB,GAAI,CACF,IAAM,EAAY,MAAM,EAAa,GAC7B,WAAY,MAAM,EAAkB,CAAM,GAEhD,SAAW,SAAQ,YACjB,MAAM,EAAU,uBAAuB,CAAE,iBAAkB,CAAQ,CAAC,EAExE,GAAI,EAAO,SAAW,UAAW,OAAO,EAExC,IAAM,EAAW,OAAO,EAAQ,eAAe,EAAI,OAAO,EAAQ,WAAW,EAAI,OAAO,EAAQ,aAAa,EAE7G,OAAO,EAAW,KAAK,CAAE,MAAO,EAAM,IAAK,MAAO,EAAS,SAAS,CAAE,CAAC,EACvE,KAAM,CACN,OAAO,GAIX,eAAe,CAAiB,EAAG,YAAW,aAAY,YAAW,UAAsC,CACzG,IAAQ,eAAgB,KAAa,oCAE/B,EAAgB,GAAU,EAAW,EAE3C,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,uBAAuB,EAGhD,GAAI,CACF,IAAM,EAAK,IAAI,EAGf,GAFA,EAAG,UAAU,CAAa,EAEtB,EAAW,YAAc,EAAW,SAAW,MAAO,CACxD,IAAO,GAAW,EAAG,WAAW,EAAG,IAAK,CAAC,EAAW,aAAa,QAAQ,CAAC,CAAC,EAC3E,EAAG,gBAAgB,CAAC,CAAO,EAAG,CAAS,EAEvC,WAAM,IAAI,EAAa,mDAA0D,EAGnF,GAAI,EACF,EAAG,aAAa,CAAS,EAG3B,IAAM,EAAY,MAAM,EAAa,EAC/B,EAAU,MAAM,EAAG,MAAM,CAAE,OAAQ,CAAU,CAAC,EAEpD,MAAO,CAAE,KAAI,SAAQ,EACrB,MAAO,EAAO,CACd,MAAM,IAAI,EAAa,yCAAiD,CAAE,OAAM,CAAC,GAIrF,eAAe,CAAe,CAC5B,EACA,CACA,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,uBAAuB,EAGhD,GAAI,aAAkB,WACpB,OAAO,EAAO,gBAAgB,CAAM,EAGtC,IAAQ,WAAY,OAAQ,EAAS,EAAS,MAAM,EAAkB,CAAM,EAE5E,OAAO,EAAO,gBAAgB,CAAO,EAGvC,eAAe,CAAQ,EAAG,aAAY,YAAW,aAAgC,CAC/E,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,uBAA8B,EAGvD,IAAM,EAAS,EAAO,aAAa,GAAK,EAAW,EACnD,GAAI,CAAC,EACH,MAAM,IAAI,EAAa,uBAAuB,EAGhD,IAAQ,WAAY,MAAM,EAAkB,CAAE,aAAY,YAAW,YAAW,QAAO,CAAC,EAClF,EAAY,MAAM,EAAa,GAC7B,OAAQ,GAAW,MAAM,EAAU,0BAA0B,CAAE,SAAQ,YAAa,CAAQ,CAAC,EAErG,OAAO,EAGT,MAAO,CACL,oBACA,yBACA,aACA,aACA,kBACA,WACA,iBACF,6FCpKF",
9
+ "debugId": "141CEF8B139E797464756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var G=Object.create;var{getPrototypeOf:E,defineProperty:p,getOwnPropertyNames:N,getOwnPropertyDescriptor:F}=Object,O=Object.prototype.hasOwnProperty;var d=(t,n,o)=>{o=t!=null?G(E(t)):{};let s=n||!t||!t.__esModule?p(o,"default",{value:t,enumerable:!0}):o;for(let l of N(t))if(!O.call(s,l))p(s,l,{get:()=>t[l],enumerable:!0});return s},_=new WeakMap,I=(t)=>{var n=_.get(t),o;if(n)return n;if(n=p({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")N(t).map((s)=>!O.call(n,s)&&p(n,s,{get:()=>t[s],enumerable:!(o=F(t,s))||o.enumerable}));return _.set(t,n),n};var R=(t,n)=>{for(var o in n)p(t,o,{get:n[o],enumerable:!0,configurable:!0,set:(s)=>n[o]=()=>s})};var x=(t,n)=>()=>(t&&(n=t(t=0)),n);async function U(t={}){let{mnemonicToWalletKey:n}=await import("@ton/crypto"),{Address:o,TonClient:s,WalletContractV4:l}=await import("@ton/ton"),P=await b(),w,g,m=await u.match(t).with({phrase:u.P.string},async({phrase:r})=>n(r.split(" "))).with({signer:u.P.any},({signer:r})=>r).otherwise(()=>{return});function y(){let{rpcUrls:r}=e.getChainConfig(e.Chain.Ton),[a]=r;if(!w||w.parameters.endpoint!==a)w=new s({endpoint:a});return w}function T(r){if(!g||r){let a=y(),c=r||m;if(!c)throw new e.SwapKitError("core_wallet_connection_not_found");let i=l.create({publicKey:c.publicKey,workchain:0});g=a.open(i)}return g}async function A(r){let a=y(),{baseDecimal:c}=e.getChainConfig(e.Chain.Ton);try{let i=await a.getBalance(o.parse(r));return[e.AssetValue.from({chain:e.Chain.Ton,value:e.SwapKitNumber.fromBigInt(i,c)})]}catch(i){throw new e.SwapKitError("core_wallet_connection_not_found",{error:i})}}async function h({assetValue:r,recipient:a,memo:c}){let i=T();if(!i||!m)throw new e.SwapKitError("core_wallet_connection_not_found");let{toNano:f,comment:W,internal:B}=await import("@ton/ton"),D=await i.getSeqno(),k=f(r.getValue("string")),q=c?W(c):void 0;return i.createTransfer({messages:[B({body:q,to:a,value:k})],secretKey:m.secretKey,seqno:D})}async function S({assetValue:r,recipient:a,memo:c}){let i=T();if(!i||!m)throw new e.SwapKitError("core_wallet_connection_not_found");let f=await h({assetValue:r,memo:c,recipient:a});return await i.send(f),f.hash().toString()}async function v(r){let a=T();if(!a)throw new e.SwapKitError("core_wallet_connection_not_found");try{return await a.send(r),r.hash().toString("hex")}catch(c){throw new e.SwapKitError("core_wallet_connection_not_found",{error:c})}}function K(){return T().address.toString()}function V(){return Promise.resolve(e.AssetValue.from({chain:e.Chain.Ton,value:"0.0001"}))}return{createTransaction:h,estimateTransactionFee:V,getAddress:K,getBalance:A,sendTransaction:v,transfer:S,validateAddress:P}}async function b(){let{Address:t}=await import("@ton/ton");return function(o){try{return t.parse(o),!0}catch{return!1}}}var e,u;var C=x(()=>{e=require("@swapkit/helpers"),u=require("ts-pattern")});var z={};R(z,{getTONToolbox:()=>U,getTONAddressValidator:()=>b});module.exports=I(z);var H=x(()=>{C()});H();
1
+ var G=Object.create;var{getPrototypeOf:E,defineProperty:p,getOwnPropertyNames:N,getOwnPropertyDescriptor:F}=Object,O=Object.prototype.hasOwnProperty;var d=(t,n,o)=>{o=t!=null?G(E(t)):{};let s=n||!t||!t.__esModule?p(o,"default",{value:t,enumerable:!0}):o;for(let l of N(t))if(!O.call(s,l))p(s,l,{get:()=>t[l],enumerable:!0});return s},_=new WeakMap,I=(t)=>{var n=_.get(t),o;if(n)return n;if(n=p({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")N(t).map((s)=>!O.call(n,s)&&p(n,s,{get:()=>t[s],enumerable:!(o=F(t,s))||o.enumerable}));return _.set(t,n),n};var R=(t,n)=>{for(var o in n)p(t,o,{get:n[o],enumerable:!0,configurable:!0,set:(s)=>n[o]=()=>s})};var x=(t,n)=>()=>(t&&(n=t(t=0)),n);async function U(t={}){let{mnemonicToWalletKey:n}=await import("@ton/crypto"),{Address:o,TonClient:s,WalletContractV4:l}=await import("@ton/ton"),P=await b(),m,g,w=await u.match(t).with({phrase:u.P.string},async({phrase:r})=>n(r.split(" "))).with({signer:u.P.any},({signer:r})=>r).otherwise(()=>{return});function y(){let{rpcUrls:r}=e.getChainConfig(e.Chain.Ton),[a]=r;if(!m||m.parameters.endpoint!==a)m=new s({endpoint:a});return m}function T(r){if(!g||r){let a=y(),i=r||w;if(!i)throw new e.SwapKitError("core_wallet_connection_not_found");let c=l.create({publicKey:i.publicKey,workchain:0});g=a.open(c)}return g}async function A(r){let a=y(),{baseDecimal:i}=e.getChainConfig(e.Chain.Ton);try{let c=await a.getBalance(o.parse(r));return[e.AssetValue.from({chain:e.Chain.Ton,value:e.SwapKitNumber.fromBigInt(c,i)})]}catch{return[e.AssetValue.from({chain:e.Chain.Ton})]}}async function h({assetValue:r,recipient:a,memo:i}){let c=T();if(!c||!w)throw new e.SwapKitError("core_wallet_connection_not_found");let{toNano:f,comment:W,internal:B}=await import("@ton/ton"),D=await c.getSeqno(),k=f(r.getValue("string")),q=i?W(i):void 0;return c.createTransfer({messages:[B({body:q,to:a,value:k})],secretKey:w.secretKey,seqno:D})}async function S({assetValue:r,recipient:a,memo:i}){let c=T();if(!c||!w)throw new e.SwapKitError("core_wallet_connection_not_found");let f=await h({assetValue:r,memo:i,recipient:a});return await c.send(f),f.hash().toString()}async function v(r){let a=T();if(!a)throw new e.SwapKitError("core_wallet_connection_not_found");try{return await a.send(r),r.hash().toString("hex")}catch(i){throw new e.SwapKitError("core_wallet_connection_not_found",{error:i})}}function K(){return T().address.toString()}function V(){return Promise.resolve(e.AssetValue.from({chain:e.Chain.Ton,value:"0.0001"}))}return{createTransaction:h,estimateTransactionFee:V,getAddress:K,getBalance:A,sendTransaction:v,transfer:S,validateAddress:P}}async function b(){let{Address:t}=await import("@ton/ton");return function(o){try{return t.parse(o),!0}catch{return!1}}}var e,u;var C=x(()=>{e=require("@swapkit/helpers"),u=require("ts-pattern")});var z={};R(z,{getTONToolbox:()=>U,getTONAddressValidator:()=>b});module.exports=I(z);var H=x(()=>{C()});H();
2
2
 
3
- //# debugId=AA27057591517A5C64756E2164756E21
3
+ //# debugId=278D59F10A1344C764756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/ton/toolbox.ts", "../src/ton/index.ts"],
4
4
  "sourcesContent": [
5
- "import { AssetValue, Chain, getChainConfig, SwapKitError, SwapKitNumber } from \"@swapkit/helpers\";\nimport type { Cell, OpenedContract, TonClient, WalletContractV4 } from \"@ton/ton\";\nimport { match, P } from \"ts-pattern\";\n\nimport type { TONSigner, TONToolboxParams, TONTransferParams } from \"./types\";\n\nexport async function getTONToolbox(toolboxParams: TONToolboxParams = {}) {\n const { mnemonicToWalletKey } = await import(\"@ton/crypto\");\n const { Address, TonClient, WalletContractV4 } = await import(\"@ton/ton\");\n const validateAddress = await getTONAddressValidator();\n let client: TonClient;\n let wallet: OpenedContract<WalletContractV4>;\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async ({ phrase }) => mnemonicToWalletKey(phrase.split(\" \")))\n .with({ signer: P.any }, ({ signer }) => signer as TONSigner)\n .otherwise(() => undefined);\n\n function getClient() {\n const { rpcUrls } = getChainConfig(Chain.Ton);\n const [endpoint] = rpcUrls;\n\n if (!client || client.parameters.endpoint !== endpoint) {\n client = new TonClient({ endpoint });\n }\n\n return client;\n }\n\n function getWallet(paramSigner?: TONSigner) {\n if (!wallet || paramSigner) {\n const client = getClient();\n const walletSigner = paramSigner || signer;\n\n if (!walletSigner) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const walletContract = WalletContractV4.create({ publicKey: walletSigner.publicKey, workchain: 0 });\n const contract = client.open(walletContract);\n\n wallet = contract;\n }\n\n return wallet;\n }\n\n async function getBalance(address: string) {\n const client = getClient();\n const { baseDecimal } = getChainConfig(Chain.Ton);\n\n try {\n const balance = await client.getBalance(Address.parse(address));\n return [AssetValue.from({ chain: Chain.Ton, value: SwapKitNumber.fromBigInt(balance, baseDecimal) })];\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n async function createTransaction({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const { toNano, comment, internal } = await import(\"@ton/ton\");\n const seqno = await wallet.getSeqno();\n const amount = toNano(assetValue.getValue(\"string\"));\n const messageBody = memo ? comment(memo) : undefined;\n\n const transfer = wallet.createTransfer({\n messages: [internal({ body: messageBody, to: recipient, value: amount })],\n secretKey: signer.secretKey,\n seqno,\n });\n\n return transfer;\n }\n\n async function transfer({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const transfer = await createTransaction({ assetValue, memo, recipient });\n await wallet.send(transfer);\n\n return transfer.hash().toString();\n }\n\n async function sendTransaction(transferCell: Cell) {\n const wallet = getWallet();\n if (!wallet) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n try {\n await wallet.send(transferCell);\n return transferCell.hash().toString(\"hex\");\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n function getAddress() {\n const wallet = getWallet();\n return wallet.address.toString();\n }\n\n function estimateTransactionFee() {\n return Promise.resolve(AssetValue.from({ chain: Chain.Ton, value: \"0.0001\" }));\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n sendTransaction,\n transfer,\n validateAddress,\n };\n}\n\nexport async function getTONAddressValidator() {\n const { Address } = await import(\"@ton/ton\");\n return function validateAddress(address: string) {\n try {\n Address.parse(address);\n return true;\n } catch {\n return false;\n }\n };\n}\n",
5
+ "import { AssetValue, Chain, getChainConfig, SwapKitError, SwapKitNumber } from \"@swapkit/helpers\";\nimport type { Cell, OpenedContract, TonClient, WalletContractV4 } from \"@ton/ton\";\nimport { match, P } from \"ts-pattern\";\n\nimport type { TONSigner, TONToolboxParams, TONTransferParams } from \"./types\";\n\nexport async function getTONToolbox(toolboxParams: TONToolboxParams = {}) {\n const { mnemonicToWalletKey } = await import(\"@ton/crypto\");\n const { Address, TonClient, WalletContractV4 } = await import(\"@ton/ton\");\n const validateAddress = await getTONAddressValidator();\n let client: TonClient;\n let wallet: OpenedContract<WalletContractV4>;\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async ({ phrase }) => mnemonicToWalletKey(phrase.split(\" \")))\n .with({ signer: P.any }, ({ signer }) => signer as TONSigner)\n .otherwise(() => undefined);\n\n function getClient() {\n const { rpcUrls } = getChainConfig(Chain.Ton);\n const [endpoint] = rpcUrls;\n\n if (!client || client.parameters.endpoint !== endpoint) {\n client = new TonClient({ endpoint });\n }\n\n return client;\n }\n\n function getWallet(paramSigner?: TONSigner) {\n if (!wallet || paramSigner) {\n const client = getClient();\n const walletSigner = paramSigner || signer;\n\n if (!walletSigner) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const walletContract = WalletContractV4.create({ publicKey: walletSigner.publicKey, workchain: 0 });\n const contract = client.open(walletContract);\n\n wallet = contract;\n }\n\n return wallet;\n }\n\n async function getBalance(address: string) {\n const client = getClient();\n const { baseDecimal } = getChainConfig(Chain.Ton);\n\n try {\n const balance = await client.getBalance(Address.parse(address));\n return [AssetValue.from({ chain: Chain.Ton, value: SwapKitNumber.fromBigInt(balance, baseDecimal) })];\n } catch {\n return [AssetValue.from({ chain: Chain.Ton })];\n }\n }\n\n async function createTransaction({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const { toNano, comment, internal } = await import(\"@ton/ton\");\n const seqno = await wallet.getSeqno();\n const amount = toNano(assetValue.getValue(\"string\"));\n const messageBody = memo ? comment(memo) : undefined;\n\n const transfer = wallet.createTransfer({\n messages: [internal({ body: messageBody, to: recipient, value: amount })],\n secretKey: signer.secretKey,\n seqno,\n });\n\n return transfer;\n }\n\n async function transfer({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const transfer = await createTransaction({ assetValue, memo, recipient });\n await wallet.send(transfer);\n\n return transfer.hash().toString();\n }\n\n async function sendTransaction(transferCell: Cell) {\n const wallet = getWallet();\n if (!wallet) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n try {\n await wallet.send(transferCell);\n return transferCell.hash().toString(\"hex\");\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n function getAddress() {\n const wallet = getWallet();\n return wallet.address.toString();\n }\n\n function estimateTransactionFee() {\n return Promise.resolve(AssetValue.from({ chain: Chain.Ton, value: \"0.0001\" }));\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n sendTransaction,\n transfer,\n validateAddress,\n };\n}\n\nexport async function getTONAddressValidator() {\n const { Address } = await import(\"@ton/ton\");\n return function validateAddress(address: string) {\n try {\n Address.parse(address);\n return true;\n } catch {\n return false;\n }\n };\n}\n",
6
6
  "export * from \"./toolbox\";\nexport * from \"./types\";\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "AA27057591517A5C64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "278D59F10A1344C764756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var E=Object.create;var{getPrototypeOf:F,defineProperty:y,getOwnPropertyNames:I}=Object;var R=Object.prototype.hasOwnProperty;var m=(t,n,r)=>{r=t!=null?E(F(t)):{};let i=n||!t||!t.__esModule?y(r,"default",{value:t,enumerable:!0}):r;for(let l of I(t))if(!R.call(i,l))y(i,l,{get:()=>t[l],enumerable:!0});return i};var U=(t,n)=>{for(var r in n)y(t,r,{get:n[r],enumerable:!0,configurable:!0,set:(i)=>n[r]=()=>i})};var N=(t,n)=>()=>(t&&(n=t(t=0)),n);var T=((t)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(n,r)=>(typeof require<"u"?require:n)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});import{AssetValue as O,Chain as d,getChainConfig as x,SwapKitError as c,SwapKitNumber as j}from"@swapkit/helpers";import{match as z,P as b}from"ts-pattern";async function H(t={}){let{mnemonicToWalletKey:n}=await import("@ton/crypto"),{Address:r,TonClient:i,WalletContractV4:l}=await import("@ton/ton"),A=await C(),p,g,u=await z(t).with({phrase:b.string},async({phrase:e})=>n(e.split(" "))).with({signer:b.any},({signer:e})=>e).otherwise(()=>{return});function h(){let{rpcUrls:e}=x(d.Ton),[o]=e;if(!p||p.parameters.endpoint!==o)p=new i({endpoint:o});return p}function w(e){if(!g||e){let o=h(),s=e||u;if(!s)throw new c("core_wallet_connection_not_found");let a=l.create({publicKey:s.publicKey,workchain:0});g=o.open(a)}return g}async function S(e){let o=h(),{baseDecimal:s}=x(d.Ton);try{let a=await o.getBalance(r.parse(e));return[O.from({chain:d.Ton,value:j.fromBigInt(a,s)})]}catch(a){throw new c("core_wallet_connection_not_found",{error:a})}}async function _({assetValue:e,recipient:o,memo:s}){let a=w();if(!a||!u)throw new c("core_wallet_connection_not_found");let{toNano:f,comment:B,internal:D}=await import("@ton/ton"),k=await a.getSeqno(),q=f(e.getValue("string")),G=s?B(s):void 0;return a.createTransfer({messages:[D({body:G,to:o,value:q})],secretKey:u.secretKey,seqno:k})}async function v({assetValue:e,recipient:o,memo:s}){let a=w();if(!a||!u)throw new c("core_wallet_connection_not_found");let f=await _({assetValue:e,memo:s,recipient:o});return await a.send(f),f.hash().toString()}async function K(e){let o=w();if(!o)throw new c("core_wallet_connection_not_found");try{return await o.send(e),e.hash().toString("hex")}catch(s){throw new c("core_wallet_connection_not_found",{error:s})}}function V(){return w().address.toString()}function W(){return Promise.resolve(O.from({chain:d.Ton,value:"0.0001"}))}return{createTransaction:_,estimateTransactionFee:W,getAddress:V,getBalance:S,sendTransaction:K,transfer:v,validateAddress:A}}async function C(){let{Address:t}=await import("@ton/ton");return function(r){try{return t.parse(r),!0}catch{return!1}}}var P=()=>{};var L={};U(L,{getTONToolbox:()=>H,getTONAddressValidator:()=>C});var M=N(()=>{P()});M();export{H as getTONToolbox,C as getTONAddressValidator};
1
+ var E=Object.create;var{getPrototypeOf:F,defineProperty:y,getOwnPropertyNames:I}=Object;var R=Object.prototype.hasOwnProperty;var T=(t,n,r)=>{r=t!=null?E(F(t)):{};let i=n||!t||!t.__esModule?y(r,"default",{value:t,enumerable:!0}):r;for(let c of I(t))if(!R.call(i,c))y(i,c,{get:()=>t[c],enumerable:!0});return i};var U=(t,n)=>{for(var r in n)y(t,r,{get:n[r],enumerable:!0,configurable:!0,set:(i)=>n[r]=()=>i})};var O=(t,n)=>()=>(t&&(n=t(t=0)),n);var d=((t)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(n,r)=>(typeof require<"u"?require:n)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});import{AssetValue as h,Chain as f,getChainConfig as x,SwapKitError as p,SwapKitNumber as j}from"@swapkit/helpers";import{match as z,P as b}from"ts-pattern";async function H(t={}){let{mnemonicToWalletKey:n}=await import("@ton/crypto"),{Address:r,TonClient:i,WalletContractV4:c}=await import("@ton/ton"),A=await C(),u,g,m=await z(t).with({phrase:b.string},async({phrase:e})=>n(e.split(" "))).with({signer:b.any},({signer:e})=>e).otherwise(()=>{return});function _(){let{rpcUrls:e}=x(f.Ton),[o]=e;if(!u||u.parameters.endpoint!==o)u=new i({endpoint:o});return u}function w(e){if(!g||e){let o=_(),a=e||m;if(!a)throw new p("core_wallet_connection_not_found");let s=c.create({publicKey:a.publicKey,workchain:0});g=o.open(s)}return g}async function S(e){let o=_(),{baseDecimal:a}=x(f.Ton);try{let s=await o.getBalance(r.parse(e));return[h.from({chain:f.Ton,value:j.fromBigInt(s,a)})]}catch{return[h.from({chain:f.Ton})]}}async function N({assetValue:e,recipient:o,memo:a}){let s=w();if(!s||!m)throw new p("core_wallet_connection_not_found");let{toNano:l,comment:B,internal:D}=await import("@ton/ton"),k=await s.getSeqno(),q=l(e.getValue("string")),G=a?B(a):void 0;return s.createTransfer({messages:[D({body:G,to:o,value:q})],secretKey:m.secretKey,seqno:k})}async function v({assetValue:e,recipient:o,memo:a}){let s=w();if(!s||!m)throw new p("core_wallet_connection_not_found");let l=await N({assetValue:e,memo:a,recipient:o});return await s.send(l),l.hash().toString()}async function K(e){let o=w();if(!o)throw new p("core_wallet_connection_not_found");try{return await o.send(e),e.hash().toString("hex")}catch(a){throw new p("core_wallet_connection_not_found",{error:a})}}function V(){return w().address.toString()}function W(){return Promise.resolve(h.from({chain:f.Ton,value:"0.0001"}))}return{createTransaction:N,estimateTransactionFee:W,getAddress:V,getBalance:S,sendTransaction:K,transfer:v,validateAddress:A}}async function C(){let{Address:t}=await import("@ton/ton");return function(r){try{return t.parse(r),!0}catch{return!1}}}var P=()=>{};var L={};U(L,{getTONToolbox:()=>H,getTONAddressValidator:()=>C});var M=O(()=>{P()});M();export{H as getTONToolbox,C as getTONAddressValidator};
2
2
 
3
- //# debugId=D4A92008ECC5F99F64756E2164756E21
3
+ //# debugId=C1523C849ED6973D64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/ton/toolbox.ts", "../src/ton/index.ts"],
4
4
  "sourcesContent": [
5
- "import { AssetValue, Chain, getChainConfig, SwapKitError, SwapKitNumber } from \"@swapkit/helpers\";\nimport type { Cell, OpenedContract, TonClient, WalletContractV4 } from \"@ton/ton\";\nimport { match, P } from \"ts-pattern\";\n\nimport type { TONSigner, TONToolboxParams, TONTransferParams } from \"./types\";\n\nexport async function getTONToolbox(toolboxParams: TONToolboxParams = {}) {\n const { mnemonicToWalletKey } = await import(\"@ton/crypto\");\n const { Address, TonClient, WalletContractV4 } = await import(\"@ton/ton\");\n const validateAddress = await getTONAddressValidator();\n let client: TonClient;\n let wallet: OpenedContract<WalletContractV4>;\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async ({ phrase }) => mnemonicToWalletKey(phrase.split(\" \")))\n .with({ signer: P.any }, ({ signer }) => signer as TONSigner)\n .otherwise(() => undefined);\n\n function getClient() {\n const { rpcUrls } = getChainConfig(Chain.Ton);\n const [endpoint] = rpcUrls;\n\n if (!client || client.parameters.endpoint !== endpoint) {\n client = new TonClient({ endpoint });\n }\n\n return client;\n }\n\n function getWallet(paramSigner?: TONSigner) {\n if (!wallet || paramSigner) {\n const client = getClient();\n const walletSigner = paramSigner || signer;\n\n if (!walletSigner) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const walletContract = WalletContractV4.create({ publicKey: walletSigner.publicKey, workchain: 0 });\n const contract = client.open(walletContract);\n\n wallet = contract;\n }\n\n return wallet;\n }\n\n async function getBalance(address: string) {\n const client = getClient();\n const { baseDecimal } = getChainConfig(Chain.Ton);\n\n try {\n const balance = await client.getBalance(Address.parse(address));\n return [AssetValue.from({ chain: Chain.Ton, value: SwapKitNumber.fromBigInt(balance, baseDecimal) })];\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n async function createTransaction({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const { toNano, comment, internal } = await import(\"@ton/ton\");\n const seqno = await wallet.getSeqno();\n const amount = toNano(assetValue.getValue(\"string\"));\n const messageBody = memo ? comment(memo) : undefined;\n\n const transfer = wallet.createTransfer({\n messages: [internal({ body: messageBody, to: recipient, value: amount })],\n secretKey: signer.secretKey,\n seqno,\n });\n\n return transfer;\n }\n\n async function transfer({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const transfer = await createTransaction({ assetValue, memo, recipient });\n await wallet.send(transfer);\n\n return transfer.hash().toString();\n }\n\n async function sendTransaction(transferCell: Cell) {\n const wallet = getWallet();\n if (!wallet) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n try {\n await wallet.send(transferCell);\n return transferCell.hash().toString(\"hex\");\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n function getAddress() {\n const wallet = getWallet();\n return wallet.address.toString();\n }\n\n function estimateTransactionFee() {\n return Promise.resolve(AssetValue.from({ chain: Chain.Ton, value: \"0.0001\" }));\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n sendTransaction,\n transfer,\n validateAddress,\n };\n}\n\nexport async function getTONAddressValidator() {\n const { Address } = await import(\"@ton/ton\");\n return function validateAddress(address: string) {\n try {\n Address.parse(address);\n return true;\n } catch {\n return false;\n }\n };\n}\n",
5
+ "import { AssetValue, Chain, getChainConfig, SwapKitError, SwapKitNumber } from \"@swapkit/helpers\";\nimport type { Cell, OpenedContract, TonClient, WalletContractV4 } from \"@ton/ton\";\nimport { match, P } from \"ts-pattern\";\n\nimport type { TONSigner, TONToolboxParams, TONTransferParams } from \"./types\";\n\nexport async function getTONToolbox(toolboxParams: TONToolboxParams = {}) {\n const { mnemonicToWalletKey } = await import(\"@ton/crypto\");\n const { Address, TonClient, WalletContractV4 } = await import(\"@ton/ton\");\n const validateAddress = await getTONAddressValidator();\n let client: TonClient;\n let wallet: OpenedContract<WalletContractV4>;\n\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async ({ phrase }) => mnemonicToWalletKey(phrase.split(\" \")))\n .with({ signer: P.any }, ({ signer }) => signer as TONSigner)\n .otherwise(() => undefined);\n\n function getClient() {\n const { rpcUrls } = getChainConfig(Chain.Ton);\n const [endpoint] = rpcUrls;\n\n if (!client || client.parameters.endpoint !== endpoint) {\n client = new TonClient({ endpoint });\n }\n\n return client;\n }\n\n function getWallet(paramSigner?: TONSigner) {\n if (!wallet || paramSigner) {\n const client = getClient();\n const walletSigner = paramSigner || signer;\n\n if (!walletSigner) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const walletContract = WalletContractV4.create({ publicKey: walletSigner.publicKey, workchain: 0 });\n const contract = client.open(walletContract);\n\n wallet = contract;\n }\n\n return wallet;\n }\n\n async function getBalance(address: string) {\n const client = getClient();\n const { baseDecimal } = getChainConfig(Chain.Ton);\n\n try {\n const balance = await client.getBalance(Address.parse(address));\n return [AssetValue.from({ chain: Chain.Ton, value: SwapKitNumber.fromBigInt(balance, baseDecimal) })];\n } catch {\n return [AssetValue.from({ chain: Chain.Ton })];\n }\n }\n\n async function createTransaction({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const { toNano, comment, internal } = await import(\"@ton/ton\");\n const seqno = await wallet.getSeqno();\n const amount = toNano(assetValue.getValue(\"string\"));\n const messageBody = memo ? comment(memo) : undefined;\n\n const transfer = wallet.createTransfer({\n messages: [internal({ body: messageBody, to: recipient, value: amount })],\n secretKey: signer.secretKey,\n seqno,\n });\n\n return transfer;\n }\n\n async function transfer({ assetValue, recipient, memo }: TONTransferParams) {\n const wallet = getWallet();\n if (!wallet || !signer) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n const transfer = await createTransaction({ assetValue, memo, recipient });\n await wallet.send(transfer);\n\n return transfer.hash().toString();\n }\n\n async function sendTransaction(transferCell: Cell) {\n const wallet = getWallet();\n if (!wallet) {\n throw new SwapKitError(\"core_wallet_connection_not_found\");\n }\n\n try {\n await wallet.send(transferCell);\n return transferCell.hash().toString(\"hex\");\n } catch (error) {\n throw new SwapKitError(\"core_wallet_connection_not_found\", { error });\n }\n }\n\n function getAddress() {\n const wallet = getWallet();\n return wallet.address.toString();\n }\n\n function estimateTransactionFee() {\n return Promise.resolve(AssetValue.from({ chain: Chain.Ton, value: \"0.0001\" }));\n }\n\n return {\n createTransaction,\n estimateTransactionFee,\n getAddress,\n getBalance,\n sendTransaction,\n transfer,\n validateAddress,\n };\n}\n\nexport async function getTONAddressValidator() {\n const { Address } = await import(\"@ton/ton\");\n return function validateAddress(address: string) {\n try {\n Address.parse(address);\n return true;\n } catch {\n return false;\n }\n };\n}\n",
6
6
  "export * from \"./toolbox\";\nexport * from \"./types\";\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "D4A92008ECC5F99F64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "C1523C849ED6973D64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,5 +1,5 @@
1
- var zZ=Object.create;var{getPrototypeOf:CZ,defineProperty:r,getOwnPropertyNames:SX,getOwnPropertyDescriptor:IZ}=Object,xX=Object.prototype.hasOwnProperty;var m=(X,Z,B)=>{B=X!=null?zZ(CZ(X)):{};let G=Z||!X||!X.__esModule?r(B,"default",{value:X,enumerable:!0}):B;for(let $ of SX(X))if(!xX.call(G,$))r(G,$,{get:()=>X[$],enumerable:!0});return G},KX=new WeakMap,MZ=(X)=>{var Z=KX.get(X),B;if(Z)return Z;if(Z=r({},"__esModule",{value:!0}),X&&typeof X==="object"||typeof X==="function")SX(X).map((G)=>!xX.call(Z,G)&&r(Z,G,{get:()=>X[G],enumerable:!(B=IZ(X,G))||B.enumerable}));return KX.set(X,Z),Z};var _Z=(X,Z)=>{for(var B in Z)r(X,B,{get:Z[B],enumerable:!0,configurable:!0,set:(G)=>Z[B]=()=>G})};var N=(X,Z)=>()=>(X&&(Z=X(X=0)),Z);function mX(){function X(){let Z=Date.now(),B=zX||Z;return zX=B,Z>zX?Z:B+1}return HZ+X().toString(36)}function lX(X){return async function(B,G=!0){let $=await gX.SwapKitApi.getChainBalance({address:B,chain:X,scamFilter:G}),{baseDecimal:Q}=BX.getChainConfig(X);return $.map(({identifier:J,value:j,decimal:q})=>{return new BX.AssetValue({decimal:q||Q,identifier:J,value:j})})}}var BX,gX,HZ,zX=0;var CX=N(()=>{BX=require("@swapkit/helpers"),gX=require("@swapkit/helpers/api"),HZ=typeof process<"u"&&process.pid?process.pid.toString(36):""});async function vZ({chain:X,txHash:Z}){let B=`${GX(X)}/push/transaction`,G=JSON.stringify({data:Z});try{let $=await U.RequestClient.post(B,{body:G,headers:{"Content-Type":"application/json"}});if($.context.code!==200)throw new U.SwapKitError("toolbox_utxo_broadcast_failed",{error:$.context.error||"Transaction broadcast failed"});return $.data?.transaction_hash||Z}catch($){let Q=await U.getRPCUrl(X);if(Q){let J=JSON.stringify({id:mX(),jsonrpc:"2.0",method:"sendrawtransaction",params:[Z]}),j=await U.RequestClient.post(Q,{body:J,headers:{"Content-Type":"application/json"}});if(j.error)throw new U.SwapKitError("toolbox_utxo_broadcast_failed",{error:j.error?.message});if(j.result.includes('"code":-26'))throw new U.SwapKitError("toolbox_utxo_invalid_transaction",{error:"Transaction amount was too low"});return j.result}throw $}}function GX(X){return`https://api.blockchair.com/${NZ(X)}`}function hX(X){switch(X){case U.Chain.Bitcoin:return 5;case U.Chain.Dogecoin:return 1e4;case U.Chain.Litecoin:return 1;case U.Chain.Zcash:return 1;default:return 2}}function NZ(X){switch(X){case U.Chain.BitcoinCash:return"bitcoin-cash";case U.Chain.Litecoin:return"litecoin";case U.Chain.Dash:return"dash";case U.Chain.Dogecoin:return"dogecoin";case U.Chain.Zcash:return"zcash";case U.Chain.Polkadot:return"polkadot";default:return"bitcoin"}}async function OZ(X){try{let{feePerKb:Z}=await U.RequestClient.get(`https://app.bitgo.com/api/v2/${X.toLowerCase()}/tx/fee`),B=Z/1000;return Math.max(B,hX(X))}catch{return hX(X)}}async function IX(X,Z){let B=await U.RequestClient.get(`${X}${Z?`${X.includes("?")?"&":"?"}key=${Z}`:""}`);if(!B||B.context.code!==200)throw new U.SwapKitError("toolbox_utxo_api_error",{error:`Failed to query ${X}`});return B.data}async function nX({address:X,chain:Z,apiKey:B}){if(!X)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"Address is required"});try{return(await IX(`${GX(Z)}/dashboards/address/${X}?transaction_details=true`,B))[X]}catch{return{address:{balance:0,transaction_count:0},utxo:[]}}}async function yZ({address:X,chain:Z,apiKey:B}){return(await nX({address:X,apiKey:B,chain:Z}))?.address.balance||0}async function uX({chain:X,apiKey:Z,txHash:B}){if(!B)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"TxHash is required"});try{return(await IX(`${GX(X)}/raw/transaction/${B}`,Z))?.[B]?.raw_transaction||""}catch(G){let $=G instanceof Error?G.message:String(G);return console.error(`Failed to fetch raw transaction: ${$}`),""}}async function FZ({chain:X,address:Z,apiKey:B,offset:G=0,limit:$=30}){return(await IX(`${GX(X)}/outputs?q=recipient(${Z}),is_spent(false),value(..2000000000000000)&s=value(desc)&fields=is_spent,transaction_hash,index,value,script_hex,block_id,spending_signature_hex&limit=${$}&offset=${G}`,B)).map(({is_spent:q,script_hex:W,block_id:T,transaction_hash:Y,index:z,value:D,spending_signature_hex:C})=>({hash:Y,index:z,is_confirmed:T!==-1,is_spent:q,script_hex:W,txHex:C,value:D}))}function AZ(X){return X.reduce((Z,B)=>Z+B.value,0)}function cX(X,Z){let B=[...X].sort((G,$)=>$.value-G.value);if(Z){let G=[],$=0;for(let Q of B)if(G.push(Q),$+=Q.value,$>=Z)break;return G}return B}async function rX({chain:X,address:Z,apiKey:B,targetValue:G,accumulativeValue:$=0,offset:Q=0,limit:J=30}){if(!Z)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"Address is required"});try{let j=await FZ({address:Z,apiKey:B,chain:X,limit:J,offset:Q,targetValue:G}),W=j.length<J,T=j.filter(({is_spent:M})=>!M),Y=AZ(T),z=$+Y,D=G&&z>=G;if(W||D)return cX(T,G);let C=await rX({accumulativeValue:z,address:Z,apiKey:B,chain:X,limit:J,offset:Q+J,targetValue:G}),H=[...T,...C];return cX(H,G)}catch(j){let q=j instanceof Error?j.message:String(j);return console.error(`Failed to fetch unspent UTXOs: ${q}`),[]}}async function kZ({address:X,chain:Z,apiKey:B,fetchTxHex:G=!0,targetValue:$}){let Q=await rX({address:X,apiKey:B,chain:Z,targetValue:$}),J=[];for(let{hash:j,index:q,script_hex:W,value:T}of Q){let Y;if(G)Y=await uX({apiKey:B,chain:Z,txHash:j});J.push({address:X,hash:j,index:q,txHex:Y,value:T,witnessUtxo:{script:Buffer.from(W,"hex"),value:T}})}return J}function v(X){let Z=U.SKConfig.get("apiKeys").blockchair||"";return U.warnOnce({condition:!Z,id:"no_blockchair_api_key_warning",warning:"No Blockchair API key found. Functionality will be limited."}),{broadcastTx:(B)=>vZ({chain:X,txHash:B}),getAddressData:(B)=>nX({address:B,apiKey:Z,chain:X}),getBalance:(B)=>yZ({address:B,apiKey:Z,chain:X}),getRawTx:(B)=>uX({apiKey:Z,chain:X,txHash:B}),getSuggestedTxFee:()=>OZ(X),getUtxos:(B)=>kZ({...B,apiKey:Z,chain:X})}}function EZ(X){return X}function F(){return function(Z){switch(Z){case U.Chain.Bitcoin:return oX.networks.bitcoin;case U.Chain.BitcoinCash:return l.default.bitcoincash.main.toBitcoinJS();case U.Chain.Dash:return l.default.dash.main.toBitcoinJS();case U.Chain.Litecoin:return l.default.litecoin.main.toBitcoinJS();case U.Chain.Dogecoin:{let B={private:70615956,public:70617039},G=l.default.dogecoin.test;return G.versions.bip32=B,l.default.dogecoin.main.toBitcoinJS()}case U.Chain.Zcash:return pX.networks.zcash;default:throw new U.SwapKitError("toolbox_utxo_not_supported",{chain:Z})}}}var pX,U,oX,l;var dX=N(()=>{CX();pX=require("@bitgo/utxo-lib"),U=require("@swapkit/helpers"),oX=require("bitcoinjs-lib"),l=m(require("coininfo"))});function NX(X){try{return JX(X),!0}catch{return!1}}function OX(X){return JX(X)?.network}function h(X){let Z=JX(X);if(Z?.format==="legacy")return X;return wZ(Z)}function d(X){let Z=JX(X);return PZ(Z)}function JX(X){try{let Z=fZ(X);if(Z)return Z}catch{}try{let Z=RZ(X);if(Z)return Z}catch{}throw new MX.SwapKitError("toolbox_utxo_invalid_address",{address:X})}function fZ(X){try{let Z=_X.default.decode(X);if(Z.length!==21)throw new MX.SwapKitError("toolbox_utxo_invalid_address",{address:X});let B=Z[0],G=Array.prototype.slice.call(Z,1);switch(B){case K.legacy.mainnet.p2pkh:return{format:"legacy",hash:G,network:"mainnet",type:"p2pkh"};case K.legacy.mainnet.p2sh:return{format:"legacy",hash:G,network:"mainnet",type:"p2sh"};case K.legacy.testnet.p2pkh:return{format:"legacy",hash:G,network:"testnet",type:"p2pkh"};case K.legacy.testnet.p2sh:return{format:"legacy",hash:G,network:"testnet",type:"p2sh"};case K.bitpay.mainnet.p2pkh:return{format:"bitpay",hash:G,network:"mainnet",type:"p2pkh"};case K.bitpay.mainnet.p2sh:return{format:"bitpay",hash:G,network:"mainnet",type:"p2sh"};default:return}}catch{return}}function RZ(X){if(X.indexOf(":")!==-1)try{return iX(X)}catch{}else{let Z=["bitcoincash","bchtest","bchreg"];for(let B of Z)try{return iX(`${B}:${X}`)}catch{}}return}function iX(X){try{let{hash:Z,prefix:B,type:G}=HX.default.decode(X);return{format:"cashaddr",hash:Array.prototype.slice.call(Z,0),network:B==="bitcoincash"?"mainnet":"testnet",type:G==="P2PKH"?"p2pkh":"p2sh"}}catch{return}}function wZ(X){let Z=K.legacy[X.network][X.type],B=Buffer.alloc(1+X.hash.length);return B[0]=Z,B.set(X.hash,1),_X.default.encode(B)}function PZ(X){let Z=X.network==="mainnet"?"bitcoincash":"bchtest",B=X.type==="p2pkh"?"P2PKH":"P2SH",G=new Uint8Array(X.hash);return HX.default.encode(Z,B,G)}var MX,_X,HX,vX,K;var sX=N(()=>{MX=require("@swapkit/helpers"),_X=m(require("bs58check")),HX=m(require("cashaddrjs"));((B)=>{B.Mainnet="mainnet";B.Testnet="testnet"})(vX||={});K={["legacy"]:{["mainnet"]:{["p2pkh"]:0,["p2sh"]:5},["testnet"]:{["p2pkh"]:111,["p2sh"]:196}},["bitpay"]:{["mainnet"]:{["p2pkh"]:28,["p2sh"]:40},["testnet"]:{["p2pkh"]:111,["p2sh"]:196}}}});function A(X){let Z=Buffer.from(X,"utf8");return jX.script.compile([jX.opcodes.OP_RETURN,Z])}var aX,jX,VZ=1000,qX=10,tX=10,bZ=41,KZ=107,WX,QX,$X,i=(X)=>{if(X.startsWith("bc1")||X.startsWith("tb1")||X.startsWith("ltc1")||X.startsWith("tltc1"))return"P2WPKH";if(X.startsWith("1")||X.startsWith("m")||X.startsWith("n")||X.startsWith("bitcoincash:q")||X.startsWith("bitcoincash:p")||X.startsWith("q")||X.startsWith("p")||X.startsWith("L")||X.startsWith("M")||X.startsWith("3")||X.startsWith("D")||X.startsWith("A")||X.startsWith("9")||X.startsWith("X")||X.startsWith("7")||X.startsWith("y")||X.startsWith("t1")||X.startsWith("t3")||X.startsWith("tm"))return"P2PKH";throw new aX.SwapKitError("toolbox_utxo_invalid_address",{address:X})},c=({inputs:X,outputs:Z,feeRate:B})=>{let G=X[0]&&"address"in X[0]&&X[0].address?i(X[0].address):"P2PKH",$=X.filter((J)=>J.value>=QX["type"in J?J.type:"P2PKH"]*Math.ceil(B)).reduce((J,j)=>J+P(j),0),Q=Z?.reduce((J,j)=>J+s(j),0)||$X[G];return qX+$+Q},P=(X)=>{if("type"in X)return QX[X.type];if("address"in X&&X.address)return QX[i(X.address)];return bZ+KZ},s=(X,Z)=>{if(X?.script)return tX+X.script.length+(X.script.length>=74?2:1);if(Z)return $X[Z];return $X.P2PKH};var yX=N(()=>{aX=require("@swapkit/helpers"),jX=require("bitcoinjs-lib");((B)=>{B.P2PKH="P2PKH";B.P2WPKH="P2WPKH"})(WX||={});QX={["P2PKH"]:148,["P2WPKH"]:68},$X={["P2PKH"]:34,["P2WPKH"]:31}});function LX(X){switch(X){case k.Chain.Bitcoin:case k.Chain.BitcoinCash:return 550;case k.Chain.Dash:case k.Chain.Litecoin:return 5500;case k.Chain.Dogecoin:return 1e5;case k.Chain.Zcash:return 546;default:throw new k.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}function E({inputs:X,outputs:Z,feeRate:B=1,chain:G=k.Chain.Bitcoin,changeAddress:$=""}){let Q=Math.ceil(B),J=X[0]&&"address"in X[0]&&X[0].address?i(X[0].address):"P2PKH",j=X.filter((D)=>P(D)*Q<=D.value),q=qX+Z.reduce((D,C)=>D+s(C,J),0),W=Z.reduce((D,C)=>D+C.value,0),T=q*Q,Y=0,z=[];for(let D of j){let C=P(D),H=Q*C;T+=H,Y+=D.value,z.push(D);let M=T+W;if(Y<M)continue;let b=Y-M,R=Q*s({address:"",value:0},J);if(b>R){let VX=R+T,bX=Y-(W+VX);if(bX>Math.max(P({})*Q,LX(G)))return{fee:VX,inputs:z,outputs:Z.concat({address:$,value:bX})}}return{fee:T,inputs:z,outputs:Z}}return{fee:Q*c({feeRate:Q,inputs:X,outputs:Z})}}var k;var eX=N(()=>{yX();k=require("@swapkit/helpers")});var p=N(()=>{dX();sX();eX();yX()});function S(X){return X.replace(/(bchtest:|bitcoincash:)/,"")}function V(X){let Z=S(X);return NX(Z)&&OX(Z)==="mainnet"}function o(X){try{if(X.startsWith("z"))return console.warn("Shielded Zcash addresses (z-addresses) are not supported. Use transparent addresses (t1/t3) only."),!1;let Z=TX.networks.zcash;try{return TX.address.toOutputScript(X,Z),!0}catch{let B=XZ.default.decode(X);if(B.length<21)return!1;let G=B[0];return G===Z.pubKeyHash||G===Z.scriptHash}}catch{return!1}}var TX,XZ;var a=N(()=>{p();TX=require("@bitgo/utxo-lib"),XZ=m(require("bs58check"))});function GZ({inputs:X,outputs:Z,chain:B,psbt:G,sender:$,compiledMemo:Q}){for(let J of X){let j=!!J.witnessUtxo&&!t.includes(B)&&{witnessUtxo:J.witnessUtxo},q=t.includes(B)&&{nonWitnessUtxo:J.txHex?Buffer.from(J.txHex,"hex"):void 0};G.addInput({hash:J.hash,index:J.index,...j,...q})}for(let J of Z){let j="address"in J&&J.address?J.address:$,q=J.script;if(q&&!Q)continue;let W=q?{script:Q,value:0}:{address:j,value:J.value};f.initEccLib(YX.default),G.addOutput(W)}return{inputs:X,psbt:G}}async function JZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$,fetchTxHex:Q=!1}){let J=X.chain,j=B?await A(B):null,q=await jZ({assetValue:X,fetchTxHex:Q,memo:B,recipient:Z,sender:$}),{inputs:W,outputs:T}=E({...q,chain:J,feeRate:G});if(!(W&&T))throw new L.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let Y=await F(),z=new f.Psbt({network:Y(J)});if(J===L.Chain.Dogecoin)z.setMaximumFeeRate(650000000);let{psbt:D,inputs:C}=await GZ({chain:J,compiledMemo:j,inputs:W,outputs:T,psbt:z,sender:$});return{inputs:C,psbt:D,utxos:q.inputs}}async function QZ(){let X=await F();return function({address:B,chain:G}){if(G===L.Chain.BitcoinCash)return V(B);if(G===L.Chain.Zcash)return o(B);try{return f.initEccLib(YX.default),f.address.toOutputScript(B,X(G)),!0}catch{return!1}}}async function SZ({chain:X,phrase:Z,derivationPath:B}){let G=(await e(X))({derivationPath:B,phrase:Z});async function $(J){return await J.signAllInputs(G),J}function Q(){return AX(X)(G)}return{getAddress:Q,signTransaction:$}}async function x({chain:X,...Z}){let B="phrase"in Z?Z.phrase:void 0,G="index"in Z?Z.index||0:0,$=L.derivationPathToString("derivationPath"in Z&&Z.derivationPath?Z.derivationPath:L.updateDerivationPath(L.NetworkDerivationPath[X],{index:G})),Q=B?await SZ({chain:X,derivationPath:$,phrase:B}):("signer"in Z)?Z.signer:void 0;function J(){return Promise.resolve(Q?.getAddress())}let j=await QZ(),q=await e(X);return{accumulative:E,broadcastTx:(W)=>v(X).broadcastTx(W),calculateTxSize:c,createKeysForPath:q,createTransaction:JZ,estimateMaxSendableAmount:xZ(X),estimateTransactionFee:gZ(X),getAddress:J,getAddressFromKeys:AX(X),getBalance:lX(X),getFeeRates:()=>XX(X),getInputsOutputsFee:$Z,getPrivateKeyFromMnemonic:(W)=>{return q(W).toWIF()},transfer:mZ(Q),validateAddress:(W)=>j({address:W,chain:X})}}async function $Z({assetValue:X,feeOptionKey:Z=L.FeeOption.Fast,feeRate:B,memo:G,sender:$,recipient:Q}){let J=X.chain,j=await jZ({assetValue:X,memo:G,recipient:Q,sender:$}),q=B?Math.floor(B):(await XX(J))[Z];return E({...j,chain:J,feeRate:q})}function xZ(X){return async function({from:B,memo:G,feeRate:$,feeOptionKey:Q=L.FeeOption.Fast,recipients:J=1}){let j=await v(X).getAddressData(B),q=$?Math.ceil($):(await XX(X))[Q],W=j?.utxo.map((C)=>({...C,hash:"",type:"P2PKH"})).filter((C)=>C.value>Math.max(LX(X),P(C)*q));if(!W?.length)return L.AssetValue.from({chain:X});let T=L.AssetValue.from({chain:X,value:W.reduce((C,H)=>C+H.value,0)}),Y=typeof J==="number"?Array.from({length:J},()=>({address:B,value:0})):J;if(G){let C=await A(G);Y.push({address:B,script:C,value:0})}let D=c({feeRate:q,inputs:W,outputs:Y})*q;return T.sub(D)}}function gZ(X){return async(Z)=>{let B=await $Z(Z);return L.AssetValue.from({chain:X,value:L.SwapKitNumber.fromBigInt(BigInt(B.fee),8).getValue("string")})}}async function e(X){let Z=await F();switch(X){case L.Chain.BitcoinCash:return function({phrase:G,derivationPath:$=`${L.DerivationPath.BCH}/0`,wif:Q}){let J=Z(X);if(Q)return DX.ECPair.fromWIF(Q,J);if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"No phrase provided"});return DX.HDNode.fromSeedBuffer(Buffer.from(FX.mnemonicToSeedSync(G)),J).derivePath($).keyPair};case L.Chain.Bitcoin:case L.Chain.Dogecoin:case L.Chain.Litecoin:case L.Chain.Zcash:case L.Chain.Dash:return function({phrase:G,wif:$,derivationPath:Q}){if(!($||G))throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Either phrase or wif must be provided"});let J=BZ.ECPairFactory(YX.default),j=Z(X);if($)return J.fromWIF($,j);let q=FX.mnemonicToSeedSync(G),W=ZZ.HDKey.fromMasterSeed(q,j).derive(Q);if(!W.privateKey)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Could not get private key from phrase"});return J.fromPrivateKey(Buffer.from(W.privateKey),{network:j})};default:throw new L.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}function AX(X){let Z=F();return function(G){if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Keys must be provided"});let $=t.includes(X)?f.payments.p2pkh:f.payments.p2wpkh,{address:Q}=$({network:Z(X),pubkey:G.publicKey});if(!Q)throw new L.SwapKitError("toolbox_utxo_invalid_address",{error:"Address not defined"});return Q}}function mZ(X){return async function({memo:B,recipient:G,feeOptionKey:$,feeRate:Q,assetValue:J}){let j=await X?.getAddress(),q=J.chain;if(!(X&&j))throw new L.SwapKitError("toolbox_utxo_no_signer");if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Recipient address must be provided"});let W=Q||(await XX(q))[$||L.FeeOption.Fast],{psbt:T}=await JZ({assetValue:J,feeRate:W,memo:B,recipient:G,sender:j}),Y=await X.signTransaction(T);return Y.finalizeAllInputs(),v(q).broadcastTx(Y.extractTransaction().toHex())}}async function XX(X){let Z=await v(X).getSuggestedTxFee();return{[L.FeeOption.Average]:Z,[L.FeeOption.Fast]:L.applyFeeMultiplier(Z,L.FeeOption.Fast),[L.FeeOption.Fastest]:L.applyFeeMultiplier(Z,L.FeeOption.Fastest)}}async function jZ({assetValue:X,recipient:Z,memo:B,sender:G,fetchTxHex:$=!1}){let Q=X.chain,J=(await XX(Q))[L.FeeOption.Fastest],j=$||t.includes(Q),q=X.getBaseValue("number"),W=Math.ceil(q+J*5000);return{inputs:await v(Q).getUtxos({address:G,fetchTxHex:j,targetValue:W}),outputs:[{address:Z,value:q},...B?[{address:"",script:await A(B),value:0}]:[]]}}var YX,DX,ZZ,FX,L,f,BZ,t;var ZX=N(()=>{CX();p();a();YX=m(require("@bitcoinerlab/secp256k1")),DX=require("@psf/bitcoincashjs-lib"),ZZ=require("@scure/bip32"),FX=require("@scure/bip39"),L=require("@swapkit/helpers"),f=require("bitcoinjs-lib"),BZ=require("ecpair"),t=[L.Chain.Dash,L.Chain.Dogecoin,L.Chain.Zcash,L.Chain.BitcoinCash]});function g(X){return S(d(X))}function lZ(X){function Z({builder:G,utxos:$}){return $.forEach((Q,J)=>{G.sign(J,X,void 0,65,Q.witnessUtxo?.value)}),G.build()}return{getAddress:()=>{let G=X.getAddress(0);return Promise.resolve(g(G))},signTransaction:Z}}async function kX(X){let Z="phrase"in X?X.phrase:void 0,B="index"in X?X.index||0:0,G=_.derivationPathToString("derivationPath"in X&&X.derivationPath?X.derivationPath:_.updateDerivationPath(_.NetworkDerivationPath[O],{index:B})),$=Z?(await e(O))({derivationPath:G,phrase:Z}):void 0,Q=$?lZ($):("signer"in X)?X.signer:void 0;function J(){return Promise.resolve(Q?.getAddress())}let{getBalance:j,getFeeRates:q,broadcastTx:W,...T}=await x({chain:O});function Y(z,D=!0){return j(S(d(z)))}return{...T,broadcastTx:W,buildTx:cZ,createTransaction:WZ,getAddress:J,getAddressFromKeys:pZ,getBalance:Y,getFeeRates:q,stripPrefix:S,stripToCashAddress:g,transfer:hZ({broadcastTx:W,getFeeRates:q,signer:Q}),validateAddress:V}}async function WZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$}){if(!V(Z))throw new _.SwapKitError("toolbox_utxo_invalid_address",{address:Z});let Q=Math.ceil(X.getBaseValue("number")+G*7500),J=await v(O).getUtxos({address:g($),fetchTxHex:!0,targetValue:Q}),j=B?await A(B):null,q=[];q.push({address:Z,value:X.getBaseValue("number")});let{inputs:W,outputs:T}=E({chain:O,feeRate:G,inputs:J,outputs:q});if(!(W&&T))throw new _.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let Y=await F(),z=new n.TransactionBuilder(Y(O));await Promise.all(W.map(async(D)=>{let C=await v(O).getRawTx(D.hash);z.addInput(n.Transaction.fromBuffer(Buffer.from(C,"hex")),D.index)}));for(let D of T){let C="address"in D&&D.address?D.address:h($),H=await F(),M=n.address.toOutputScript(h(C),H(O));z.addOutput(M,D.value)}if(j)z.addOutput(j,0);return{builder:z,utxos:W}}function hZ({broadcastTx:X,getFeeRates:Z,signer:B}){return async function({recipient:$,assetValue:Q,feeOptionKey:J=_.FeeOption.Fast,...j}){let q=await B?.getAddress();if(!(B&&q))throw new _.SwapKitError("toolbox_utxo_no_signer");if(!$)throw new _.SwapKitError("toolbox_utxo_invalid_params",{error:"Recipient address must be provided"});let W=j.feeRate||(await Z())[J],{builder:T,utxos:Y}=await WZ({...j,assetValue:Q,feeRate:W,recipient:$,sender:q}),D=(await B.signTransaction({builder:T,utxos:Y})).toHex();return X(D)}}async function cZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$,setSigHashType:Q}){let J=d(Z);if(!V(J))throw new _.SwapKitError("toolbox_utxo_invalid_address",{address:J});let j=Math.ceil(X.getBaseValue("number")+G*7500),q=await v(O).getUtxos({address:g($),fetchTxHex:!1,targetValue:j}),W=Number(G.toFixed(0)),T=B?await A(B):null,Y=[];if(Y.push({address:h(Z),value:X.getBaseValue("number")}),T)Y.push({script:T,value:0});let{inputs:z,outputs:D}=E({chain:O,feeRate:W,inputs:q,outputs:Y});if(!(z&&D))throw new _.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let C=await F(),H=new qZ.Psbt({network:C(O)});for(let{hash:M,index:b,witnessUtxo:R}of z)H.addInput({hash:M,index:b,sighashType:Q?65:void 0,witnessUtxo:R});for(let M of D){let b="address"in M&&M.address?M.address:h($),R=M.script?T?{script:T,value:0}:void 0:{address:b,value:M.value};if(R)H.addOutput(R)}return{inputs:z,psbt:H,utxos:q}}function pZ(X){let Z=X.getAddress(0);return g(Z)}var n,_,qZ,O;var UX=N(()=>{p();ZX();a();n=require("@psf/bitcoincashjs-lib"),_=require("@swapkit/helpers"),qZ=require("bitcoinjs-lib"),O=_.Chain.BitcoinCash});function YZ(){return y.networks.zcash}function DZ(){return{bech32:void 0,bip32:{private:76066276,public:76067358},messagePrefix:`\x18ZCash Signed Message:
2
- `,pubKeyHash:28,scriptHash:28,wif:128}}function oZ({phrase:X,derivationPath:Z}){let B=fX.mnemonicToSeedSync(X),$=EX.HDKey.fromMasterSeed(B).derive(Z);if(!$.privateKey)throw new I.SwapKitError("toolbox_utxo_invalid_params");let Q=DZ(),J=y.ECPair.fromPrivateKey(Buffer.from($.privateKey),{network:Q}),j=y.crypto.hash160(J.publicKey),{isStagenet:q}=I.SKConfig.get("envs"),W=q?Buffer.from([29,37]):Buffer.from([28,184]),T=Buffer.concat([W,j]),Y=TZ.default.encode(T);return{getAddress:()=>Promise.resolve(Y),signTransaction:(z)=>{let D=z.signAllInputs(J);return Promise.resolve(D)}}}function nZ({inputs:X,outputs:Z,psbt:B,sender:G,compiledMemo:$}){for(let Q of X){let J=!!Q.witnessUtxo&&{witnessUtxo:{...Q.witnessUtxo,value:BigInt(Q.value)}},j=!Q.witnessUtxo&&{nonWitnessUtxo:Q.txHex?Buffer.from(Q.txHex,"hex"):void 0};B.addInput({hash:Q.hash,index:Q.index,...J,...j})}for(let Q of Z){let J="address"in Q&&Q.address?Q.address:G,j=Q.script;if(j&&!$)continue;let q=j?{script:$,value:0n}:{script:y.address.toOutputScript(J,YZ()),value:BigInt(Q.value)};B.addOutput(q)}return{inputs:X,psbt:B}}async function LZ(X){let{assetValue:Z,recipient:B,memo:G,feeRate:$,sender:Q,fetchTxHex:J}=X,j=G?A(G):null,q=await v(I.Chain.Zcash).getUtxos({address:Q,fetchTxHex:J!==!1}),W=[{address:B,value:Number(Z.getBaseValue("string"))},...j?[{script:j,value:0}]:[]],{inputs:T,outputs:Y}=E({chain:I.Chain.Zcash,changeAddress:Q,feeRate:$,inputs:q,outputs:W});if(!(T&&Y))throw new I.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:Z,sender:Q});let z=y.bitgo.createPsbtForNetwork({network:YZ()},{version:455}),C=3268858036,H=Buffer.concat([Buffer.of(252),Buffer.of(5),Buffer.from("BITGO"),Buffer.of(0)]),M=Buffer.allocUnsafe(4);M.writeUInt32LE(C>>>0,0),z.addUnknownKeyValToGlobal({key:H,value:M});let{psbt:b,inputs:R}=await nZ({compiledMemo:j,inputs:T,outputs:Y,psbt:z,sender:Q});return{inputs:R,outputs:Y,psbt:b}}async function RX(X){let Z=await u.match(X).with({signer:u.P.not(u.P.nullish)},({signer:J})=>Promise.resolve(J)).with({phrase:u.P.string},({phrase:J,derivationPath:j,index:q=0})=>{let W=j||I.NetworkDerivationPath[I.Chain.Zcash]||[44,133,0,0,0],T=I.updateDerivationPath(W,{index:q}),Y=I.derivationPathToString(T);return oZ({derivationPath:Y,phrase:J})}).otherwise(()=>Promise.resolve(void 0)),B=await x({chain:I.Chain.Zcash,signer:Z});async function G({recipient:J,assetValue:j,feeOptionKey:q=I.FeeOption.Fast,...W}){let T=await Z?.getAddress();if(!(Z&&T))throw new I.SwapKitError("toolbox_utxo_no_signer");let Y=W.feeRate||(await B.getFeeRates())[q],{psbt:z}=await LZ({...W,assetValue:j,feeRate:Y,recipient:J,sender:T}),D=await Z.signTransaction(z);return D.finalizeAllInputs(),B.broadcastTx(D.extractTransaction().toHex())}function $({phrase:J,derivationPath:j="m/44'/133'/0'/0/0"}){let q=fX.mnemonicToSeedSync(J),T=EX.HDKey.fromMasterSeed(q).derive(j);if(!T.privateKey)throw new I.SwapKitError("toolbox_utxo_invalid_params");let Y=DZ();return y.ECPair.fromPrivateKey(Buffer.from(T.privateKey),{network:Y})}function Q({phrase:J,derivationPath:j="m/44'/133'/0'/0/0"}){return $({derivationPath:j,phrase:J}).toWIF()}return{...B,createKeysForPath:$,createTransaction:LZ,getPrivateKeyFromMnemonic:Q,transfer:G,validateAddress:o}}var y,EX,fX,I,TZ,u;var wX=N(()=>{p();ZX();a();y=require("@bitgo/utxo-lib"),EX=require("@scure/bip32"),fX=require("@scure/bip39"),I=require("@swapkit/helpers"),TZ=m(require("bs58check")),u=require("ts-pattern")});async function uZ(X,Z){switch(X){case w.Chain.BitcoinCash:return await kX(Z||{});case w.Chain.Zcash:return await RX(Z);case w.Chain.Bitcoin:case w.Chain.Dogecoin:case w.Chain.Litecoin:case w.Chain.Dash:return await x({chain:X,...Z});default:throw new w.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}var w;var UZ=N(()=>{UX();ZX();wX();UX();a();w=require("@swapkit/helpers")});var rZ={};_Z(rZ,{validateZcashAddress:()=>o,toLegacyAddress:()=>h,toCashAddress:()=>d,stripToCashAddress:()=>g,stripPrefix:()=>S,nonSegwitChains:()=>t,isValidAddress:()=>NX,getUtxoToolbox:()=>uZ,getUtxoNetwork:()=>F,getUtxoApi:()=>v,getUTXOAddressValidator:()=>QZ,getScriptTypeForAddress:()=>i,getOutputSize:()=>s,getInputSize:()=>P,getDustThreshold:()=>LX,getCreateKeysForPath:()=>e,detectAddressNetwork:()=>OX,createZcashToolbox:()=>RX,createUTXOToolbox:()=>x,createCustomUtxoApi:()=>EZ,createBCHToolbox:()=>kX,compileMemo:()=>A,calculateTxSize:()=>c,bchValidateAddress:()=>V,addressFromKeysGetter:()=>AX,addInputsAndOutputs:()=>GZ,accumulative:()=>E,UtxoNetwork:()=>vX,UTXOScriptType:()=>WX,TX_OVERHEAD:()=>qX,OutputSizes:()=>$X,OP_RETURN_OVERHEAD:()=>tX,MIN_TX_FEE:()=>VZ,InputSizes:()=>QX});module.exports=MZ(rZ);var dZ=N(()=>{p();UZ();UX();ZX();wX()});dZ();
1
+ var zZ=Object.create;var{getPrototypeOf:CZ,defineProperty:r,getOwnPropertyNames:SX,getOwnPropertyDescriptor:IZ}=Object,xX=Object.prototype.hasOwnProperty;var m=(X,Z,B)=>{B=X!=null?zZ(CZ(X)):{};let G=Z||!X||!X.__esModule?r(B,"default",{value:X,enumerable:!0}):B;for(let $ of SX(X))if(!xX.call(G,$))r(G,$,{get:()=>X[$],enumerable:!0});return G},KX=new WeakMap,MZ=(X)=>{var Z=KX.get(X),B;if(Z)return Z;if(Z=r({},"__esModule",{value:!0}),X&&typeof X==="object"||typeof X==="function")SX(X).map((G)=>!xX.call(Z,G)&&r(Z,G,{get:()=>X[G],enumerable:!(B=IZ(X,G))||B.enumerable}));return KX.set(X,Z),Z};var _Z=(X,Z)=>{for(var B in Z)r(X,B,{get:Z[B],enumerable:!0,configurable:!0,set:(G)=>Z[B]=()=>G})};var N=(X,Z)=>()=>(X&&(Z=X(X=0)),Z);function mX(){function X(){let Z=Date.now(),B=zX||Z;return zX=B,Z>zX?Z:B+1}return HZ+X().toString(36)}function lX(X){return async function(B,G=!0){let $=await gX.SwapKitApi.getChainBalance({address:B,chain:X,scamFilter:G}),{baseDecimal:Q}=d.getChainConfig(X),J=$.map(({identifier:q,value:W,decimal:T})=>{return new d.AssetValue({decimal:T||Q,identifier:q,value:W})});if(!J.some((q)=>q.isGasAsset))return[d.AssetValue.from({chain:X}),...J];return J}}var d,gX,HZ,zX=0;var CX=N(()=>{d=require("@swapkit/helpers"),gX=require("@swapkit/helpers/api"),HZ=typeof process<"u"&&process.pid?process.pid.toString(36):""});async function vZ({chain:X,txHash:Z}){let B=`${GX(X)}/push/transaction`,G=JSON.stringify({data:Z});try{let $=await U.RequestClient.post(B,{body:G,headers:{"Content-Type":"application/json"}});if($.context.code!==200)throw new U.SwapKitError("toolbox_utxo_broadcast_failed",{error:$.context.error||"Transaction broadcast failed"});return $.data?.transaction_hash||Z}catch($){let Q=await U.getRPCUrl(X);if(Q){let J=JSON.stringify({id:mX(),jsonrpc:"2.0",method:"sendrawtransaction",params:[Z]}),j=await U.RequestClient.post(Q,{body:J,headers:{"Content-Type":"application/json"}});if(j.error)throw new U.SwapKitError("toolbox_utxo_broadcast_failed",{error:j.error?.message});if(j.result.includes('"code":-26'))throw new U.SwapKitError("toolbox_utxo_invalid_transaction",{error:"Transaction amount was too low"});return j.result}throw $}}function GX(X){return`https://api.blockchair.com/${NZ(X)}`}function hX(X){switch(X){case U.Chain.Bitcoin:return 5;case U.Chain.Dogecoin:return 1e4;case U.Chain.Litecoin:return 1;case U.Chain.Zcash:return 1;default:return 2}}function NZ(X){switch(X){case U.Chain.BitcoinCash:return"bitcoin-cash";case U.Chain.Litecoin:return"litecoin";case U.Chain.Dash:return"dash";case U.Chain.Dogecoin:return"dogecoin";case U.Chain.Zcash:return"zcash";case U.Chain.Polkadot:return"polkadot";default:return"bitcoin"}}async function OZ(X){try{let{feePerKb:Z}=await U.RequestClient.get(`https://app.bitgo.com/api/v2/${X.toLowerCase()}/tx/fee`),B=Z/1000;return Math.max(B,hX(X))}catch{return hX(X)}}async function IX(X,Z){let B=await U.RequestClient.get(`${X}${Z?`${X.includes("?")?"&":"?"}key=${Z}`:""}`);if(!B||B.context.code!==200)throw new U.SwapKitError("toolbox_utxo_api_error",{error:`Failed to query ${X}`});return B.data}async function nX({address:X,chain:Z,apiKey:B}){if(!X)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"Address is required"});try{return(await IX(`${GX(Z)}/dashboards/address/${X}?transaction_details=true`,B))[X]}catch{return{address:{balance:0,transaction_count:0},utxo:[]}}}async function yZ({address:X,chain:Z,apiKey:B}){return(await nX({address:X,apiKey:B,chain:Z}))?.address.balance||0}async function uX({chain:X,apiKey:Z,txHash:B}){if(!B)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"TxHash is required"});try{return(await IX(`${GX(X)}/raw/transaction/${B}`,Z))?.[B]?.raw_transaction||""}catch(G){let $=G instanceof Error?G.message:String(G);return console.error(`Failed to fetch raw transaction: ${$}`),""}}async function FZ({chain:X,address:Z,apiKey:B,offset:G=0,limit:$=30}){return(await IX(`${GX(X)}/outputs?q=recipient(${Z}),is_spent(false),value(..2000000000000000)&s=value(desc)&fields=is_spent,transaction_hash,index,value,script_hex,block_id,spending_signature_hex&limit=${$}&offset=${G}`,B)).map(({is_spent:q,script_hex:W,block_id:T,transaction_hash:Y,index:z,value:D,spending_signature_hex:C})=>({hash:Y,index:z,is_confirmed:T!==-1,is_spent:q,script_hex:W,txHex:C,value:D}))}function AZ(X){return X.reduce((Z,B)=>Z+B.value,0)}function cX(X,Z){let B=[...X].sort((G,$)=>$.value-G.value);if(Z){let G=[],$=0;for(let Q of B)if(G.push(Q),$+=Q.value,$>=Z)break;return G}return B}async function rX({chain:X,address:Z,apiKey:B,targetValue:G,accumulativeValue:$=0,offset:Q=0,limit:J=30}){if(!Z)throw new U.SwapKitError("toolbox_utxo_invalid_params",{error:"Address is required"});try{let j=await FZ({address:Z,apiKey:B,chain:X,limit:J,offset:Q,targetValue:G}),W=j.length<J,T=j.filter(({is_spent:_})=>!_),Y=AZ(T),z=$+Y,D=G&&z>=G;if(W||D)return cX(T,G);let C=await rX({accumulativeValue:z,address:Z,apiKey:B,chain:X,limit:J,offset:Q+J,targetValue:G}),H=[...T,...C];return cX(H,G)}catch(j){let q=j instanceof Error?j.message:String(j);return console.error(`Failed to fetch unspent UTXOs: ${q}`),[]}}async function kZ({address:X,chain:Z,apiKey:B,fetchTxHex:G=!0,targetValue:$}){let Q=await rX({address:X,apiKey:B,chain:Z,targetValue:$}),J=[];for(let{hash:j,index:q,script_hex:W,value:T}of Q){let Y;if(G)Y=await uX({apiKey:B,chain:Z,txHash:j});J.push({address:X,hash:j,index:q,txHex:Y,value:T,witnessUtxo:{script:Buffer.from(W,"hex"),value:T}})}return J}function v(X){let Z=U.SKConfig.get("apiKeys").blockchair||"";return U.warnOnce({condition:!Z,id:"no_blockchair_api_key_warning",warning:"No Blockchair API key found. Functionality will be limited."}),{broadcastTx:(B)=>vZ({chain:X,txHash:B}),getAddressData:(B)=>nX({address:B,apiKey:Z,chain:X}),getBalance:(B)=>yZ({address:B,apiKey:Z,chain:X}),getRawTx:(B)=>uX({apiKey:Z,chain:X,txHash:B}),getSuggestedTxFee:()=>OZ(X),getUtxos:(B)=>kZ({...B,apiKey:Z,chain:X})}}function EZ(X){return X}function F(){return function(Z){switch(Z){case U.Chain.Bitcoin:return oX.networks.bitcoin;case U.Chain.BitcoinCash:return l.default.bitcoincash.main.toBitcoinJS();case U.Chain.Dash:return l.default.dash.main.toBitcoinJS();case U.Chain.Litecoin:return l.default.litecoin.main.toBitcoinJS();case U.Chain.Dogecoin:{let B={private:70615956,public:70617039},G=l.default.dogecoin.test;return G.versions.bip32=B,l.default.dogecoin.main.toBitcoinJS()}case U.Chain.Zcash:return pX.networks.zcash;default:throw new U.SwapKitError("toolbox_utxo_not_supported",{chain:Z})}}}var pX,U,oX,l;var dX=N(()=>{CX();pX=require("@bitgo/utxo-lib"),U=require("@swapkit/helpers"),oX=require("bitcoinjs-lib"),l=m(require("coininfo"))});function NX(X){try{return JX(X),!0}catch{return!1}}function OX(X){return JX(X)?.network}function h(X){let Z=JX(X);if(Z?.format==="legacy")return X;return wZ(Z)}function i(X){let Z=JX(X);return PZ(Z)}function JX(X){try{let Z=fZ(X);if(Z)return Z}catch{}try{let Z=RZ(X);if(Z)return Z}catch{}throw new MX.SwapKitError("toolbox_utxo_invalid_address",{address:X})}function fZ(X){try{let Z=_X.default.decode(X);if(Z.length!==21)throw new MX.SwapKitError("toolbox_utxo_invalid_address",{address:X});let B=Z[0],G=Array.prototype.slice.call(Z,1);switch(B){case K.legacy.mainnet.p2pkh:return{format:"legacy",hash:G,network:"mainnet",type:"p2pkh"};case K.legacy.mainnet.p2sh:return{format:"legacy",hash:G,network:"mainnet",type:"p2sh"};case K.legacy.testnet.p2pkh:return{format:"legacy",hash:G,network:"testnet",type:"p2pkh"};case K.legacy.testnet.p2sh:return{format:"legacy",hash:G,network:"testnet",type:"p2sh"};case K.bitpay.mainnet.p2pkh:return{format:"bitpay",hash:G,network:"mainnet",type:"p2pkh"};case K.bitpay.mainnet.p2sh:return{format:"bitpay",hash:G,network:"mainnet",type:"p2sh"};default:return}}catch{return}}function RZ(X){if(X.indexOf(":")!==-1)try{return iX(X)}catch{}else{let Z=["bitcoincash","bchtest","bchreg"];for(let B of Z)try{return iX(`${B}:${X}`)}catch{}}return}function iX(X){try{let{hash:Z,prefix:B,type:G}=HX.default.decode(X);return{format:"cashaddr",hash:Array.prototype.slice.call(Z,0),network:B==="bitcoincash"?"mainnet":"testnet",type:G==="P2PKH"?"p2pkh":"p2sh"}}catch{return}}function wZ(X){let Z=K.legacy[X.network][X.type],B=Buffer.alloc(1+X.hash.length);return B[0]=Z,B.set(X.hash,1),_X.default.encode(B)}function PZ(X){let Z=X.network==="mainnet"?"bitcoincash":"bchtest",B=X.type==="p2pkh"?"P2PKH":"P2SH",G=new Uint8Array(X.hash);return HX.default.encode(Z,B,G)}var MX,_X,HX,vX,K;var sX=N(()=>{MX=require("@swapkit/helpers"),_X=m(require("bs58check")),HX=m(require("cashaddrjs"));((B)=>{B.Mainnet="mainnet";B.Testnet="testnet"})(vX||={});K={["legacy"]:{["mainnet"]:{["p2pkh"]:0,["p2sh"]:5},["testnet"]:{["p2pkh"]:111,["p2sh"]:196}},["bitpay"]:{["mainnet"]:{["p2pkh"]:28,["p2sh"]:40},["testnet"]:{["p2pkh"]:111,["p2sh"]:196}}}});function A(X){let Z=Buffer.from(X,"utf8");return jX.script.compile([jX.opcodes.OP_RETURN,Z])}var aX,jX,VZ=1000,qX=10,tX=10,bZ=41,KZ=107,WX,QX,$X,s=(X)=>{if(X.startsWith("bc1")||X.startsWith("tb1")||X.startsWith("ltc1")||X.startsWith("tltc1"))return"P2WPKH";if(X.startsWith("1")||X.startsWith("m")||X.startsWith("n")||X.startsWith("bitcoincash:q")||X.startsWith("bitcoincash:p")||X.startsWith("q")||X.startsWith("p")||X.startsWith("L")||X.startsWith("M")||X.startsWith("3")||X.startsWith("D")||X.startsWith("A")||X.startsWith("9")||X.startsWith("X")||X.startsWith("7")||X.startsWith("y")||X.startsWith("t1")||X.startsWith("t3")||X.startsWith("tm"))return"P2PKH";throw new aX.SwapKitError("toolbox_utxo_invalid_address",{address:X})},c=({inputs:X,outputs:Z,feeRate:B})=>{let G=X[0]&&"address"in X[0]&&X[0].address?s(X[0].address):"P2PKH",$=X.filter((J)=>J.value>=QX["type"in J?J.type:"P2PKH"]*Math.ceil(B)).reduce((J,j)=>J+w(j),0),Q=Z?.reduce((J,j)=>J+a(j),0)||$X[G];return qX+$+Q},w=(X)=>{if("type"in X)return QX[X.type];if("address"in X&&X.address)return QX[s(X.address)];return bZ+KZ},a=(X,Z)=>{if(X?.script)return tX+X.script.length+(X.script.length>=74?2:1);if(Z)return $X[Z];return $X.P2PKH};var yX=N(()=>{aX=require("@swapkit/helpers"),jX=require("bitcoinjs-lib");((B)=>{B.P2PKH="P2PKH";B.P2WPKH="P2WPKH"})(WX||={});QX={["P2PKH"]:148,["P2WPKH"]:68},$X={["P2PKH"]:34,["P2WPKH"]:31}});function LX(X){switch(X){case k.Chain.Bitcoin:case k.Chain.BitcoinCash:return 550;case k.Chain.Dash:case k.Chain.Litecoin:return 5500;case k.Chain.Dogecoin:return 1e5;case k.Chain.Zcash:return 546;default:throw new k.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}function E({inputs:X,outputs:Z,feeRate:B=1,chain:G=k.Chain.Bitcoin,changeAddress:$=""}){let Q=Math.ceil(B),J=X[0]&&"address"in X[0]&&X[0].address?s(X[0].address):"P2PKH",j=X.filter((D)=>w(D)*Q<=D.value),q=qX+Z.reduce((D,C)=>D+a(C,J),0),W=Z.reduce((D,C)=>D+C.value,0),T=q*Q,Y=0,z=[];for(let D of j){let C=w(D),H=Q*C;T+=H,Y+=D.value,z.push(D);let _=T+W;if(Y<_)continue;let V=Y-_,b=Q*a({address:"",value:0},J);if(V>b){let VX=b+T,bX=Y-(W+VX);if(bX>Math.max(w({})*Q,LX(G)))return{fee:VX,inputs:z,outputs:Z.concat({address:$,value:bX})}}return{fee:T,inputs:z,outputs:Z}}return{fee:Q*c({feeRate:Q,inputs:X,outputs:Z})}}var k;var eX=N(()=>{yX();k=require("@swapkit/helpers")});var p=N(()=>{dX();sX();eX();yX()});function S(X){return X.replace(/(bchtest:|bitcoincash:)/,"")}function P(X){let Z=S(X);return NX(Z)&&OX(Z)==="mainnet"}function o(X){try{if(X.startsWith("z"))return console.warn("Shielded Zcash addresses (z-addresses) are not supported. Use transparent addresses (t1/t3) only."),!1;let Z=TX.networks.zcash;try{return TX.address.toOutputScript(X,Z),!0}catch{let B=XZ.default.decode(X);if(B.length<21)return!1;let G=B[0];return G===Z.pubKeyHash||G===Z.scriptHash}}catch{return!1}}var TX,XZ;var t=N(()=>{p();TX=require("@bitgo/utxo-lib"),XZ=m(require("bs58check"))});function GZ({inputs:X,outputs:Z,chain:B,psbt:G,sender:$,compiledMemo:Q}){for(let J of X){let j=!!J.witnessUtxo&&!e.includes(B)&&{witnessUtxo:J.witnessUtxo},q=e.includes(B)&&{nonWitnessUtxo:J.txHex?Buffer.from(J.txHex,"hex"):void 0};G.addInput({hash:J.hash,index:J.index,...j,...q})}for(let J of Z){let j="address"in J&&J.address?J.address:$,q=J.script;if(q&&!Q)continue;let W=q?{script:Q,value:0}:{address:j,value:J.value};f.initEccLib(YX.default),G.addOutput(W)}return{inputs:X,psbt:G}}async function JZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$,fetchTxHex:Q=!1}){let J=X.chain,j=B?await A(B):null,q=await jZ({assetValue:X,fetchTxHex:Q,memo:B,recipient:Z,sender:$}),{inputs:W,outputs:T}=E({...q,chain:J,feeRate:G});if(!(W&&T))throw new L.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let Y=await F(),z=new f.Psbt({network:Y(J)});if(J===L.Chain.Dogecoin)z.setMaximumFeeRate(650000000);let{psbt:D,inputs:C}=await GZ({chain:J,compiledMemo:j,inputs:W,outputs:T,psbt:z,sender:$});return{inputs:C,psbt:D,utxos:q.inputs}}async function QZ(){let X=await F();return function({address:B,chain:G}){if(G===L.Chain.BitcoinCash)return P(B);if(G===L.Chain.Zcash)return o(B);try{return f.initEccLib(YX.default),f.address.toOutputScript(B,X(G)),!0}catch{return!1}}}async function SZ({chain:X,phrase:Z,derivationPath:B}){let G=(await XX(X))({derivationPath:B,phrase:Z});async function $(J){return await J.signAllInputs(G),J}function Q(){return AX(X)(G)}return{getAddress:Q,signTransaction:$}}async function x({chain:X,...Z}){let B="phrase"in Z?Z.phrase:void 0,G="index"in Z?Z.index||0:0,$=L.derivationPathToString("derivationPath"in Z&&Z.derivationPath?Z.derivationPath:L.updateDerivationPath(L.NetworkDerivationPath[X],{index:G})),Q=B?await SZ({chain:X,derivationPath:$,phrase:B}):("signer"in Z)?Z.signer:void 0;function J(){return Promise.resolve(Q?.getAddress())}let j=await QZ(),q=await XX(X);return{accumulative:E,broadcastTx:(W)=>v(X).broadcastTx(W),calculateTxSize:c,createKeysForPath:q,createTransaction:JZ,estimateMaxSendableAmount:xZ(X),estimateTransactionFee:gZ(X),getAddress:J,getAddressFromKeys:AX(X),getBalance:lX(X),getFeeRates:()=>ZX(X),getInputsOutputsFee:$Z,getPrivateKeyFromMnemonic:(W)=>{return q(W).toWIF()},transfer:mZ(Q),validateAddress:(W)=>j({address:W,chain:X})}}async function $Z({assetValue:X,feeOptionKey:Z=L.FeeOption.Fast,feeRate:B,memo:G,sender:$,recipient:Q}){let J=X.chain,j=await jZ({assetValue:X,memo:G,recipient:Q,sender:$}),q=B?Math.floor(B):(await ZX(J))[Z];return E({...j,chain:J,feeRate:q})}function xZ(X){return async function({from:B,memo:G,feeRate:$,feeOptionKey:Q=L.FeeOption.Fast,recipients:J=1}){let j=await v(X).getAddressData(B),q=$?Math.ceil($):(await ZX(X))[Q],W=j?.utxo.map((C)=>({...C,hash:"",type:"P2PKH"})).filter((C)=>C.value>Math.max(LX(X),w(C)*q));if(!W?.length)return L.AssetValue.from({chain:X});let T=L.AssetValue.from({chain:X,value:W.reduce((C,H)=>C+H.value,0)}),Y=typeof J==="number"?Array.from({length:J},()=>({address:B,value:0})):J;if(G){let C=await A(G);Y.push({address:B,script:C,value:0})}let D=c({feeRate:q,inputs:W,outputs:Y})*q;return T.sub(D)}}function gZ(X){return async(Z)=>{let B=await $Z(Z);return L.AssetValue.from({chain:X,value:L.SwapKitNumber.fromBigInt(BigInt(B.fee),8).getValue("string")})}}async function XX(X){let Z=await F();switch(X){case L.Chain.BitcoinCash:return function({phrase:G,derivationPath:$=`${L.DerivationPath.BCH}/0`,wif:Q}){let J=Z(X);if(Q)return DX.ECPair.fromWIF(Q,J);if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"No phrase provided"});return DX.HDNode.fromSeedBuffer(Buffer.from(FX.mnemonicToSeedSync(G)),J).derivePath($).keyPair};case L.Chain.Bitcoin:case L.Chain.Dogecoin:case L.Chain.Litecoin:case L.Chain.Zcash:case L.Chain.Dash:return function({phrase:G,wif:$,derivationPath:Q}){if(!($||G))throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Either phrase or wif must be provided"});let J=BZ.ECPairFactory(YX.default),j=Z(X);if($)return J.fromWIF($,j);let q=FX.mnemonicToSeedSync(G),W=ZZ.HDKey.fromMasterSeed(q,j).derive(Q);if(!W.privateKey)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Could not get private key from phrase"});return J.fromPrivateKey(Buffer.from(W.privateKey),{network:j})};default:throw new L.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}function AX(X){let Z=F();return function(G){if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Keys must be provided"});let $=e.includes(X)?f.payments.p2pkh:f.payments.p2wpkh,{address:Q}=$({network:Z(X),pubkey:G.publicKey});if(!Q)throw new L.SwapKitError("toolbox_utxo_invalid_address",{error:"Address not defined"});return Q}}function mZ(X){return async function({memo:B,recipient:G,feeOptionKey:$,feeRate:Q,assetValue:J}){let j=await X?.getAddress(),q=J.chain;if(!(X&&j))throw new L.SwapKitError("toolbox_utxo_no_signer");if(!G)throw new L.SwapKitError("toolbox_utxo_invalid_params",{error:"Recipient address must be provided"});let W=Q||(await ZX(q))[$||L.FeeOption.Fast],{psbt:T}=await JZ({assetValue:J,feeRate:W,memo:B,recipient:G,sender:j}),Y=await X.signTransaction(T);return Y.finalizeAllInputs(),v(q).broadcastTx(Y.extractTransaction().toHex())}}async function ZX(X){let Z=await v(X).getSuggestedTxFee();return{[L.FeeOption.Average]:Z,[L.FeeOption.Fast]:L.applyFeeMultiplier(Z,L.FeeOption.Fast),[L.FeeOption.Fastest]:L.applyFeeMultiplier(Z,L.FeeOption.Fastest)}}async function jZ({assetValue:X,recipient:Z,memo:B,sender:G,fetchTxHex:$=!1}){let Q=X.chain,J=(await ZX(Q))[L.FeeOption.Fastest],j=$||e.includes(Q),q=X.getBaseValue("number"),W=Math.ceil(q+J*5000);return{inputs:await v(Q).getUtxos({address:G,fetchTxHex:j,targetValue:W}),outputs:[{address:Z,value:q},...B?[{address:"",script:await A(B),value:0}]:[]]}}var YX,DX,ZZ,FX,L,f,BZ,e;var BX=N(()=>{CX();p();t();YX=m(require("@bitcoinerlab/secp256k1")),DX=require("@psf/bitcoincashjs-lib"),ZZ=require("@scure/bip32"),FX=require("@scure/bip39"),L=require("@swapkit/helpers"),f=require("bitcoinjs-lib"),BZ=require("ecpair"),e=[L.Chain.Dash,L.Chain.Dogecoin,L.Chain.Zcash,L.Chain.BitcoinCash]});function g(X){return S(i(X))}function lZ(X){function Z({builder:G,utxos:$}){return $.forEach((Q,J)=>{G.sign(J,X,void 0,65,Q.witnessUtxo?.value)}),G.build()}return{getAddress:()=>{let G=X.getAddress(0);return Promise.resolve(g(G))},signTransaction:Z}}async function kX(X){let Z="phrase"in X?X.phrase:void 0,B="index"in X?X.index||0:0,G=M.derivationPathToString("derivationPath"in X&&X.derivationPath?X.derivationPath:M.updateDerivationPath(M.NetworkDerivationPath[O],{index:B})),$=Z?(await XX(O))({derivationPath:G,phrase:Z}):void 0,Q=$?lZ($):("signer"in X)?X.signer:void 0;function J(){return Promise.resolve(Q?.getAddress())}let{getBalance:j,getFeeRates:q,broadcastTx:W,...T}=await x({chain:O});function Y(z,D=!0){return j(S(i(z)))}return{...T,broadcastTx:W,buildTx:cZ,createTransaction:WZ,getAddress:J,getAddressFromKeys:pZ,getBalance:Y,getFeeRates:q,stripPrefix:S,stripToCashAddress:g,transfer:hZ({broadcastTx:W,getFeeRates:q,signer:Q}),validateAddress:P}}async function WZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$}){if(!P(Z))throw new M.SwapKitError("toolbox_utxo_invalid_address",{address:Z});let Q=Math.ceil(X.getBaseValue("number")+G*7500),J=await v(O).getUtxos({address:g($),fetchTxHex:!0,targetValue:Q}),j=B?await A(B):null,q=[];q.push({address:Z,value:X.getBaseValue("number")});let{inputs:W,outputs:T}=E({chain:O,feeRate:G,inputs:J,outputs:q});if(!(W&&T))throw new M.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let Y=await F(),z=new n.TransactionBuilder(Y(O));await Promise.all(W.map(async(D)=>{let C=await v(O).getRawTx(D.hash);z.addInput(n.Transaction.fromBuffer(Buffer.from(C,"hex")),D.index)}));for(let D of T){let C="address"in D&&D.address?D.address:h($),H=await F(),_=n.address.toOutputScript(h(C),H(O));z.addOutput(_,D.value)}if(j)z.addOutput(j,0);return{builder:z,utxos:W}}function hZ({broadcastTx:X,getFeeRates:Z,signer:B}){return async function({recipient:$,assetValue:Q,feeOptionKey:J=M.FeeOption.Fast,...j}){let q=await B?.getAddress();if(!(B&&q))throw new M.SwapKitError("toolbox_utxo_no_signer");if(!$)throw new M.SwapKitError("toolbox_utxo_invalid_params",{error:"Recipient address must be provided"});let W=j.feeRate||(await Z())[J],{builder:T,utxos:Y}=await WZ({...j,assetValue:Q,feeRate:W,recipient:$,sender:q}),D=(await B.signTransaction({builder:T,utxos:Y})).toHex();return X(D)}}async function cZ({assetValue:X,recipient:Z,memo:B,feeRate:G,sender:$,setSigHashType:Q}){let J=i(Z);if(!P(J))throw new M.SwapKitError("toolbox_utxo_invalid_address",{address:J});let j=Math.ceil(X.getBaseValue("number")+G*7500),q=await v(O).getUtxos({address:g($),fetchTxHex:!1,targetValue:j}),W=Number(G.toFixed(0)),T=B?await A(B):null,Y=[];if(Y.push({address:h(Z),value:X.getBaseValue("number")}),T)Y.push({script:T,value:0});let{inputs:z,outputs:D}=E({chain:O,feeRate:W,inputs:q,outputs:Y});if(!(z&&D))throw new M.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:X,sender:$});let C=await F(),H=new qZ.Psbt({network:C(O)});for(let{hash:_,index:V,witnessUtxo:b}of z)H.addInput({hash:_,index:V,sighashType:Q?65:void 0,witnessUtxo:b});for(let _ of D){let V="address"in _&&_.address?_.address:h($),b=_.script?T?{script:T,value:0}:void 0:{address:V,value:_.value};if(b)H.addOutput(b)}return{inputs:z,psbt:H,utxos:q}}function pZ(X){let Z=X.getAddress(0);return g(Z)}var n,M,qZ,O;var UX=N(()=>{p();BX();t();n=require("@psf/bitcoincashjs-lib"),M=require("@swapkit/helpers"),qZ=require("bitcoinjs-lib"),O=M.Chain.BitcoinCash});function YZ(){return y.networks.zcash}function DZ(){return{bech32:void 0,bip32:{private:76066276,public:76067358},messagePrefix:`\x18ZCash Signed Message:
2
+ `,pubKeyHash:28,scriptHash:28,wif:128}}function oZ({phrase:X,derivationPath:Z}){let B=fX.mnemonicToSeedSync(X),$=EX.HDKey.fromMasterSeed(B).derive(Z);if(!$.privateKey)throw new I.SwapKitError("toolbox_utxo_invalid_params");let Q=DZ(),J=y.ECPair.fromPrivateKey(Buffer.from($.privateKey),{network:Q}),j=y.crypto.hash160(J.publicKey),{isStagenet:q}=I.SKConfig.get("envs"),W=q?Buffer.from([29,37]):Buffer.from([28,184]),T=Buffer.concat([W,j]),Y=TZ.default.encode(T);return{getAddress:()=>Promise.resolve(Y),signTransaction:(z)=>{let D=z.signAllInputs(J);return Promise.resolve(D)}}}function nZ({inputs:X,outputs:Z,psbt:B,sender:G,compiledMemo:$}){for(let Q of X){let J=!!Q.witnessUtxo&&{witnessUtxo:{...Q.witnessUtxo,value:BigInt(Q.value)}},j=!Q.witnessUtxo&&{nonWitnessUtxo:Q.txHex?Buffer.from(Q.txHex,"hex"):void 0};B.addInput({hash:Q.hash,index:Q.index,...J,...j})}for(let Q of Z){let J="address"in Q&&Q.address?Q.address:G,j=Q.script;if(j&&!$)continue;let q=j?{script:$,value:0n}:{script:y.address.toOutputScript(J,YZ()),value:BigInt(Q.value)};B.addOutput(q)}return{inputs:X,psbt:B}}async function LZ(X){let{assetValue:Z,recipient:B,memo:G,feeRate:$,sender:Q,fetchTxHex:J}=X,j=G?A(G):null,q=await v(I.Chain.Zcash).getUtxos({address:Q,fetchTxHex:J!==!1}),W=[{address:B,value:Number(Z.getBaseValue("string"))},...j?[{script:j,value:0}]:[]],{inputs:T,outputs:Y}=E({chain:I.Chain.Zcash,changeAddress:Q,feeRate:$,inputs:q,outputs:W});if(!(T&&Y))throw new I.SwapKitError("toolbox_utxo_insufficient_balance",{assetValue:Z,sender:Q});let z=y.bitgo.createPsbtForNetwork({network:YZ()},{version:455}),D=1307332080,C=Buffer.concat([Buffer.of(252),Buffer.of(5),Buffer.from("BITGO"),Buffer.of(0)]),H=Buffer.allocUnsafe(4);H.writeUInt32LE(D>>>0,0),z.addUnknownKeyValToGlobal({key:C,value:H});let{psbt:_,inputs:V}=await nZ({compiledMemo:j,inputs:T,outputs:Y,psbt:z,sender:Q});return{inputs:V,outputs:Y,psbt:_}}async function RX(X){let Z=await u.match(X).with({signer:u.P.not(u.P.nullish)},({signer:J})=>Promise.resolve(J)).with({phrase:u.P.string},({phrase:J,derivationPath:j,index:q=0})=>{let W=j||I.NetworkDerivationPath[I.Chain.Zcash]||[44,133,0,0,0],T=I.updateDerivationPath(W,{index:q}),Y=I.derivationPathToString(T);return oZ({derivationPath:Y,phrase:J})}).otherwise(()=>Promise.resolve(void 0)),B=await x({chain:I.Chain.Zcash,signer:Z});async function G({recipient:J,assetValue:j,feeOptionKey:q=I.FeeOption.Fast,...W}){let T=await Z?.getAddress();if(!(Z&&T))throw new I.SwapKitError("toolbox_utxo_no_signer");let Y=W.feeRate||(await B.getFeeRates())[q],{psbt:z}=await LZ({...W,assetValue:j,feeRate:Y,recipient:J,sender:T}),D=await Z.signTransaction(z);return D.finalizeAllInputs(),B.broadcastTx(D.extractTransaction().toHex())}function $({phrase:J,derivationPath:j="m/44'/133'/0'/0/0"}){let q=fX.mnemonicToSeedSync(J),T=EX.HDKey.fromMasterSeed(q).derive(j);if(!T.privateKey)throw new I.SwapKitError("toolbox_utxo_invalid_params");let Y=DZ();return y.ECPair.fromPrivateKey(Buffer.from(T.privateKey),{network:Y})}function Q({phrase:J,derivationPath:j="m/44'/133'/0'/0/0"}){return $({derivationPath:j,phrase:J}).toWIF()}return{...B,createKeysForPath:$,createTransaction:LZ,getPrivateKeyFromMnemonic:Q,transfer:G,validateAddress:o}}var y,EX,fX,I,TZ,u;var wX=N(()=>{p();BX();t();y=require("@bitgo/utxo-lib"),EX=require("@scure/bip32"),fX=require("@scure/bip39"),I=require("@swapkit/helpers"),TZ=m(require("bs58check")),u=require("ts-pattern")});async function uZ(X,Z){switch(X){case R.Chain.BitcoinCash:return await kX(Z||{});case R.Chain.Zcash:return await RX(Z);case R.Chain.Bitcoin:case R.Chain.Dogecoin:case R.Chain.Litecoin:case R.Chain.Dash:return await x({chain:X,...Z});default:throw new R.SwapKitError("toolbox_utxo_not_supported",{chain:X})}}var R;var UZ=N(()=>{UX();BX();wX();UX();t();R=require("@swapkit/helpers")});var rZ={};_Z(rZ,{validateZcashAddress:()=>o,toLegacyAddress:()=>h,toCashAddress:()=>i,stripToCashAddress:()=>g,stripPrefix:()=>S,nonSegwitChains:()=>e,isValidAddress:()=>NX,getUtxoToolbox:()=>uZ,getUtxoNetwork:()=>F,getUtxoApi:()=>v,getUTXOAddressValidator:()=>QZ,getScriptTypeForAddress:()=>s,getOutputSize:()=>a,getInputSize:()=>w,getDustThreshold:()=>LX,getCreateKeysForPath:()=>XX,detectAddressNetwork:()=>OX,createZcashToolbox:()=>RX,createUTXOToolbox:()=>x,createCustomUtxoApi:()=>EZ,createBCHToolbox:()=>kX,compileMemo:()=>A,calculateTxSize:()=>c,bchValidateAddress:()=>P,addressFromKeysGetter:()=>AX,addInputsAndOutputs:()=>GZ,accumulative:()=>E,UtxoNetwork:()=>vX,UTXOScriptType:()=>WX,TX_OVERHEAD:()=>qX,OutputSizes:()=>$X,OP_RETURN_OVERHEAD:()=>tX,MIN_TX_FEE:()=>VZ,InputSizes:()=>QX});module.exports=MZ(rZ);var dZ=N(()=>{p();UZ();UX();BX();wX()});dZ();
3
3
 
4
- //# debugId=DFE52EAF21FD217E64756E2164756E21
4
+ //# debugId=C66AE75E301E956F64756E2164756E21
5
5
  //# sourceMappingURL=index.cjs.map