@swapkit/toolboxes 1.0.0-beta.21 → 1.0.0-beta.23

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.
@@ -1,3 +1,3 @@
1
- var D1={};V1(D1,{validateNearAddress:()=>T,tgasToGas:()=>t,isSimpleTransfer:()=>I,isCustomEstimator:()=>l,isContractDeployment:()=>S,isContractCall:()=>h,isBatchTransaction:()=>A,isAccountCreation:()=>g,getNearToolbox:()=>R1,getNearSignerFromPrivateKey:()=>K,getNearSignerFromPhrase:()=>y,getFullAccessPublicKey:()=>P,getContractMethodGas:()=>m,gasToTGas:()=>e,estimateBatchGas:()=>u,createNearContract:()=>F,createNEP141Token:()=>N,GAS_COSTS:()=>R});module.exports=H1(D1);var q=require("@swapkit/helpers");var E=require("@swapkit/helpers"),n=require("near-api-js");async function T(W){try{let{validateAccountId:Z}=await import("near-sdk-js");return Z(W)}catch{let Z=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return W.length>=2&&W.length<=64&&Z.test(W)}}async function y(W){let{parseSeedPhrase:Z}=await import("near-seed-phrase"),{KeyPair:M}=await import("near-api-js"),Y=W.index||0,$=W.derivationPath?E.derivationPathToString(W.derivationPath.slice(0,3)):`m/44'/397'/${Y}'`,{secretKey:X}=Z(W.phrase,$),z=M.fromString(X);return s(z)}async function K(W){let{KeyPair:Z}=await import("near-api-js/lib/utils"),M=Z.fromString(W);return s(M)}class c extends n.KeyPairSigner{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Z=Buffer.from(W.data).toString("hex");return Promise.resolve(Z)}}function s(W){return new c(W)}async function P(W,Z){let Y=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Z})).keys.find((X)=>X.access_key.permission==="FullAccess");if(!Y)throw new E.SwapKitError("toolbox_near_invalid_address");let{utils:$}=await import("near-api-js");return $.PublicKey.fromString(Y.public_key)}var R={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function I(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function h(W){return"contractId"in W&&"methodName"in W}function A(W){return"actions"in W}function g(W){return"newAccountId"in W}function S(W){return"contractCode"in W}function l(W){return"customEstimator"in W}function u(W){let Z=0;for(let M of W)switch(M.enum){case"transfer":Z+=Number(R.SIMPLE_TRANSFER);break;case"functionCall":Z+=Number(R.CONTRACT_CALL);break;case"createAccount":Z+=Number(R.ACCOUNT_CREATION);break;case"deployContract":Z+=Number(R.CONTRACT_DEPLOYMENT);break;case"addKey":Z+=Number(R.ACCESS_KEY_ADDITION);break;case"deleteKey":Z+=Number(R.ACCESS_KEY_DELETION);break;case"stake":Z+=Number(R.STAKE);break;default:Z+=Number(R.CONTRACT_CALL)}return Z.toString()}function m(W){if(W==="ft_transfer"||W==="ft_transfer_call")return R.TOKEN_TRANSFER;if(W==="storage_deposit")return R.STORAGE_DEPOSIT;return R.CONTRACT_CALL}function t(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function e(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var r="1250000000000000000000";async function N({contractId:W,account:Z}){let M=(await import("bn.js")).default,Y=await F({account:Z,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),$=async(X)=>{if(!await Y.storage_balance_of({account_id:X})){let B=(await Y.storage_balance_bounds())?.min||r;await Y.storage_deposit({account_id:X},new M("100000000000000"),new M(B))}};return{transfer:async(X,z,D)=>{return await $(X),Y.ft_transfer({receiver_id:X,amount:z,memo:D},new M("100000000000000"),new M("1"))},transferCall:async(X,z,D,B)=>{return await $(X),Y.ft_transfer_call({receiver_id:X,amount:z,memo:B,msg:D},new M("100000000000000"),new M("1"))},balanceOf:(X)=>Y.ft_balance_of({account_id:X}),totalSupply:()=>Y.ft_total_supply(),metadata:()=>Y.ft_metadata(),storageBalanceOf:(X)=>Y.storage_balance_of({account_id:X}),storageDeposit:(X,z)=>Y.storage_deposit({account_id:X},new M("100000000000000"),new M(z||r)),ensureStorage:$,contract:Y}}async function R1(W){let{P:Z,match:M}=await import("ts-pattern"),{providers:Y}=await import("near-api-js"),$=await M(W).with({phrase:Z.string},async(x)=>{return await y(x)}).with({signer:Z.any},({signer:x})=>x).otherwise(()=>{return}),X=q.SKConfig.get("rpcUrls")[q.Chain.Near],z=new Y.JsonRpcProvider({url:X});async function D(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{Account:J}=await import("near-api-js"),Q=x||await B();return new J(Q,z,$)}async function B(){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");return await $.getAddress()}async function a(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{recipient:J,assetValue:Q}=x;if(!T(J))throw new q.SwapKitError("toolbox_near_invalid_address");let f=await D();if(Q.isGasAsset===!1){let L=Q.address;if(!L)throw new q.SwapKitError("toolbox_near_missing_contract_address");let H=Q.getBaseValue("string");return p({contractId:L,methodName:"ft_transfer",args:{receiver_id:J,amount:H,memo:x.memo}})}try{let L=Q.getBaseValue("string");return(await f.transfer({receiverId:J,amount:L})).transaction.hash}catch(L){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:L})}}async function x1(x){let{recipient:J,assetValue:Q,memo:f,feeRate:L,attachedDeposit:H,sender:V}=x,j=V||await B(),w=await P(z,j),k=(await z.query({request_type:"view_access_key",finality:"final",account_id:j})).nonce+1,v=Q.getBaseValue("bigint"),{SCHEMA:G}=await import("near-api-js/lib/transaction"),{transactions:_,utils:C}=await import("near-api-js"),o=[_.transfer(v)];if(f&&H)o.push(_.functionCall("memo",{memo:f},BigInt(L),BigInt(H)));let Y1=await z.block({finality:"final"}),i=C.serialize.base_decode(Y1.header.hash),f1=_.createTransaction(j,w,J,k,o,i),U1=C.serialize.serialize(G.Transaction,f1);return{serialized:Buffer.from(U1).toString("base64"),publicKey:w.toString(),details:{signerId:await B(),nonce:k,blockHash:C.serialize.base_encode(i)}}}async function W1(x){let{accountId:J}=x,Q=await P(z,J),L=(await z.query({request_type:"view_access_key",finality:"final",account_id:J,public_key:Q.toString()})).nonce+1,{SCHEMA:H}=await import("near-api-js/lib/transaction"),{transactions:V,utils:j}=await import("near-api-js"),w=await z.block({finality:"final"}),O=j.serialize.base_decode(w.header.hash),k=[V.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],v=V.createTransaction(J,Q,x.contractId,L,k,O),G=j.serialize.serialize(H.Transaction,v);return{serialized:Buffer.from(G).toString("base64"),publicKey:Q.toString(),details:{signerId:J,receiverId:x.contractId,methodName:x.methodName,nonce:L,blockHash:j.serialize.base_encode(O)}}}async function q1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let[J,Q]=await $.signTransaction(x);return Q}async function J1(x){return(await z.sendTransaction(x)).transaction.hash}async function Q1(x){if("assetValue"in x){let L=BigInt("115123062500")+BigInt("108059500000"),H=await Z1(),V=L*BigInt(H.toString());return q.AssetValue.from({chain:q.Chain.Near,value:V.toString(),fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}let J=$?await D():void 0;return b(x,J)}async function Z1(){try{return await z.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function $1(x,J,Q){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let f=await D(),{utils:L}=await import("near-api-js"),H=L.format.parseNearAmount(Q)||"0";return(await f.createAccount(x,L.PublicKey.fromString(J),BigInt(H))).transaction.hash}async function p(x){try{if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{transactions:J}=await import("near-api-js"),{contractId:Q,methodName:f,args:L,deposit:H}=x,V=await D(),j=await b({methodName:f,args:L||{},contractId:Q}),w=J.functionCall(f,L||{},j.getBaseValue("bigint"),BigInt(H||"0"));return(await V.signAndSendTransaction({receiverId:Q,actions:[w]})).transaction.hash}catch(J){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:J})}}async function X1(x){let{createNearContract:J}=await import("../../chunk-vtd17cje.js"),Q=await D();return J({account:Q,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function z1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");if(x.actions.length===0)throw new q.SwapKitError("toolbox_near_empty_batch");return(await(await D()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function L1(x){let J=await D();return N({contractId:x,account:J})}async function M1(x){try{let J=await D(x),Q;try{let f=await J.getBalance();Q=q.AssetValue.from({chain:q.Chain.Near,value:f,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}catch{Q=q.AssetValue.from({chain:q.Chain.Near,value:"0",fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}return[Q]}catch(J){throw new q.SwapKitError("toolbox_near_balance_failed",{error:J})}}async function b(x,J){let Q=await M(x).when(I,()=>R.SIMPLE_TRANSFER).when(h,(V)=>m(V.methodName)).when(A,(V)=>u(V.actions)).when(g,()=>R.ACCOUNT_CREATION).when(S,()=>R.CONTRACT_DEPLOYMENT).when(l,(V)=>{if(!J)throw new q.SwapKitError("toolbox_near_no_account");return V.customEstimator(J)}).otherwise(()=>{throw new q.SwapKitError("toolbox_near_invalid_gas_params")}),f=await d(),H=BigInt(Q)*BigInt(1000000000000)*BigInt(f);return q.AssetValue.from({chain:q.Chain.Near,value:H,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}async function d(){try{return(await z.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:B,getPublicKey:async()=>$?(await $.getPublicKey()).toString():"",provider:z,transfer:a,createTransaction:x1,createContractFunctionCall:W1,estimateTransactionFee:Q1,broadcastTransaction:J1,signTransaction:q1,getBalance:M1,validateAddress:T,getSignerFromPhrase:(x)=>y(x),getSignerFromPrivateKey:K,callFunction:p,createSubAccount:$1,createContract:X1,executeBatchTransaction:z1,nep141:L1,getGasPrice:d,estimateGas:b}}
1
+ var H1={};R1(H1,{validateNearAddress:()=>T,tgasToGas:()=>c,isSimpleTransfer:()=>C,isCustomEstimator:()=>g,isContractDeployment:()=>A,isContractCall:()=>K,isBatchTransaction:()=>I,isAccountCreation:()=>h,getNearToolbox:()=>U1,getNearSignerFromPrivateKey:()=>G,getNearSignerFromPhrase:()=>P,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>l,gasToTGas:()=>s,estimateBatchGas:()=>S,createNearContract:()=>N,createNEP141Token:()=>O,GAS_COSTS:()=>V});module.exports=f1(H1);var q=require("@swapkit/helpers");var E=require("@swapkit/helpers"),o=require("near-api-js");async function T(W){try{let{validateAccountId:Z}=await import("near-sdk-js");return Z(W)}catch{let Z=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return W.length>=2&&W.length<=64&&Z.test(W)}}async function P(W){let{parseSeedPhrase:Z}=await import("near-seed-phrase"),{KeyPair:Y}=await import("near-api-js"),L=W.index||0,$=W.derivationPath?E.derivationPathToString(W.derivationPath.slice(0,3)):`m/44'/397'/${L}'`,{secretKey:X}=Z(W.phrase,$),z=Y.fromString(X);return n(z)}async function G(W){let{KeyPair:Z}=await import("near-api-js/lib/utils"),Y=Z.fromString(W);return n(Y)}class i extends o.KeyPairSigner{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Z=Buffer.from(W.data).toString("hex");return Promise.resolve(Z)}}function n(W){return new i(W)}async function b(W,Z){let L=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Z})).keys.find((D)=>D.access_key.permission==="FullAccess");if(!L)throw new E.SwapKitError("toolbox_near_invalid_address");let{utils:$}=await import("near-api-js"),X=$.PublicKey.fromString(L.public_key),z=L.access_key.nonce||0;return{publicKey:X,nonce:z}}var V={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function C(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function K(W){return"contractId"in W&&"methodName"in W}function I(W){return"actions"in W}function h(W){return"newAccountId"in W}function A(W){return"contractCode"in W}function g(W){return"customEstimator"in W}function S(W){let Z=0;for(let Y of W)switch(Y.enum){case"transfer":Z+=Number(V.SIMPLE_TRANSFER);break;case"functionCall":Z+=Number(V.CONTRACT_CALL);break;case"createAccount":Z+=Number(V.ACCOUNT_CREATION);break;case"deployContract":Z+=Number(V.CONTRACT_DEPLOYMENT);break;case"addKey":Z+=Number(V.ACCESS_KEY_ADDITION);break;case"deleteKey":Z+=Number(V.ACCESS_KEY_DELETION);break;case"stake":Z+=Number(V.STAKE);break;default:Z+=Number(V.CONTRACT_CALL)}return Z.toString()}function l(W){if(W==="ft_transfer"||W==="ft_transfer_call")return V.TOKEN_TRANSFER;if(W==="storage_deposit")return V.STORAGE_DEPOSIT;return V.CONTRACT_CALL}function c(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function s(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var e="1250000000000000000000";async function O({contractId:W,account:Z}){let Y=(await import("bn.js")).default,L=await N({account:Z,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),$=async(X)=>{if(!await L.storage_balance_of({account_id:X})){let w=(await L.storage_balance_bounds())?.min||e;await L.storage_deposit({account_id:X},new Y("100000000000000"),new Y(w))}};return{transfer:async(X,z,D)=>{return await $(X),L.ft_transfer({receiver_id:X,amount:z,memo:D},new Y("100000000000000"),new Y("1"))},transferCall:async(X,z,D,w)=>{return await $(X),L.ft_transfer_call({receiver_id:X,amount:z,memo:w,msg:D},new Y("100000000000000"),new Y("1"))},balanceOf:(X)=>L.ft_balance_of({account_id:X}),totalSupply:()=>L.ft_total_supply(),metadata:()=>L.ft_metadata(),storageBalanceOf:(X)=>L.storage_balance_of({account_id:X}),storageDeposit:(X,z)=>L.storage_deposit({account_id:X},new Y("100000000000000"),new Y(z||e)),ensureStorage:$,contract:L}}async function U1(W){let{P:Z,match:Y}=await import("ts-pattern"),{providers:L}=await import("near-api-js"),$=await Y(W).with({phrase:Z.string},async(x)=>{return await P(x)}).with({signer:Z.any},({signer:x})=>x).otherwise(()=>{return}),X=q.SKConfig.get("rpcUrls")[q.Chain.Near],z=new L.JsonRpcProvider({url:X});async function D(x){let{Account:J}=await import("near-api-js"),Q=x||await w();return new J(Q,z,$)}async function w(){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");return await $.getAddress()}async function t(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{recipient:J,assetValue:Q}=x;if(!T(J))throw new q.SwapKitError("toolbox_near_invalid_address");let U=await D();if(Q.isGasAsset===!1){let M=Q.address;if(!M)throw new q.SwapKitError("toolbox_near_missing_contract_address");let R=Q.getBaseValue("string");return u({contractId:M,methodName:"ft_transfer",args:{receiver_id:J,amount:R,memo:x.memo}})}try{let M=Q.getBaseValue("string");return(await U.transfer({receiverId:J,amount:M})).transaction.hash}catch(M){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:M})}}async function r(x){let{recipient:J,assetValue:Q,memo:U,feeRate:M,attachedDeposit:R,sender:f}=x,{publicKey:B,nonce:j}=await b(z,f),k=Q.getBaseValue("bigint"),{SCHEMA:v}=await import("near-api-js/lib/transaction"),{transactions:F,utils:_}=await import("near-api-js"),d=[F.transfer(k)];if(U&&R)d.push(F.functionCall("memo",{memo:U},BigInt(M),BigInt(R)));let L1=await z.block({finality:"final"}),p=_.serialize.base_decode(L1.header.hash),M1=F.createTransaction(f,B,J,j,d,p),Y1=_.serialize.serialize(v.Transaction,M1);return{serialized:Buffer.from(Y1).toString("base64"),publicKey:B.toString(),details:{signerId:f,nonce:j,blockHash:_.serialize.base_encode(p)}}}async function a(x){let{sender:J}=x,{publicKey:Q,nonce:U}=await b(z,J),{SCHEMA:M}=await import("near-api-js/lib/transaction"),{transactions:R,utils:f}=await import("near-api-js"),B=await z.block({finality:"final"}),j=f.serialize.base_decode(B.header.hash),k=[R.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],v=R.createTransaction(J,Q,x.contractId,U,k,j),F=f.serialize.serialize(M.Transaction,v);return{serialized:Buffer.from(F).toString("base64"),publicKey:Q.toString(),details:{signerId:J,receiverId:x.contractId,methodName:x.methodName,nonce:U,blockHash:f.serialize.base_encode(j)}}}async function x1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let[J,Q]=await $.signTransaction(x);return Q}async function W1(x){return(await z.sendTransaction(x)).transaction.hash}async function q1(x){if("assetValue"in x){let M=BigInt("115123062500")+BigInt("108059500000"),R=await J1(),f=M*BigInt(R.toString());return q.AssetValue.from({chain:q.Chain.Near,value:f.toString(),fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}let J=$?await D():void 0;return y(x,J)}async function J1(){try{return await z.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function Q1(x,J,Q){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let U=await D(),{utils:M}=await import("near-api-js"),R=M.format.parseNearAmount(Q)||"0";return(await U.createAccount(x,M.PublicKey.fromString(J),BigInt(R))).transaction.hash}async function u(x){try{if(!$)throw new q.SwapKitError("toolbox_near_no_signer");let{transactions:J}=await import("near-api-js"),{contractId:Q,methodName:U,args:M,deposit:R}=x,f=await D(),B=await y({methodName:U,args:M||{},contractId:Q}),j=J.functionCall(U,M||{},B.getBaseValue("bigint"),BigInt(R||"0"));return(await f.signAndSendTransaction({receiverId:Q,actions:[j]})).transaction.hash}catch(J){throw new q.SwapKitError("toolbox_near_transfer_failed",{error:J})}}async function Z1(x){let{createNearContract:J}=await import("../../chunk-vtd17cje.js"),Q=await D();return J({account:Q,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function $1(x){if(!$)throw new q.SwapKitError("toolbox_near_no_signer");if(x.actions.length===0)throw new q.SwapKitError("toolbox_near_empty_batch");return(await(await D()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function X1(x){let J=await D();return O({contractId:x,account:J})}async function z1(x){try{let J=await D(x),Q;try{let U=await J.getBalance();Q=q.AssetValue.from({chain:q.Chain.Near,value:U,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}catch{Q=q.AssetValue.from({chain:q.Chain.Near,value:"0",fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}return[Q]}catch(J){throw new q.SwapKitError("toolbox_near_balance_failed",{error:J})}}async function y(x,J){let Q=await Y(x).when(C,()=>V.SIMPLE_TRANSFER).when(K,(f)=>l(f.methodName)).when(I,(f)=>S(f.actions)).when(h,()=>V.ACCOUNT_CREATION).when(A,()=>V.CONTRACT_DEPLOYMENT).when(g,(f)=>{if(!J)throw new q.SwapKitError("toolbox_near_no_account");return f.customEstimator(J)}).otherwise(()=>{throw new q.SwapKitError("toolbox_near_invalid_gas_params")}),U=await m(),R=BigInt(Q)*BigInt(1000000000000)*BigInt(U);return q.AssetValue.from({chain:q.Chain.Near,value:R,fromBaseDecimal:q.BaseDecimal[q.Chain.Near]})}async function m(){try{return(await z.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:w,getPublicKey:async()=>$?(await $.getPublicKey()).toString():"",provider:z,transfer:t,createTransaction:r,createContractFunctionCall:a,estimateTransactionFee:q1,broadcastTransaction:W1,signTransaction:x1,getBalance:z1,validateAddress:T,getSignerFromPhrase:(x)=>P(x),getSignerFromPrivateKey:G,callFunction:u,createSubAccount:Q1,createContract:Z1,executeBatchTransaction:$1,nep141:X1,getGasPrice:m,estimateGas:y}}
2
2
 
3
- //# debugId=95CBB72A2AA595E364756E2164756E21
3
+ //# debugId=FC6BDAE142BFC3F564756E2164756E21
@@ -2,12 +2,12 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/near/toolbox.ts", "../src/near/helpers/core.ts", "../src/near/helpers/gasEstimation.ts", "../src/near/helpers/nep141.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n BaseDecimal,\n Chain,\n type DerivationPathArray,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\nimport type { Account } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n validateNearAddress,\n} from \"./helpers\";\nimport {\n GAS_COSTS,\n estimateBatchGas,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams) {\n const { P, match } = await import(\"ts-pattern\");\n const { providers } = await import(\"near-api-js\");\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async (params) => {\n const signer = await getNearSignerFromPhrase(params);\n return signer;\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n const url = SKConfig.get(\"rpcUrls\")[Chain.Near];\n\n const provider = new providers.JsonRpcProvider({ url });\n\n async function getAccount(address?: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const { Account } = await import(\"near-api-js\");\n\n const _address = address || (await getAddress());\n\n const account = new Account(_address, provider, signer);\n\n return account;\n }\n\n async function getAddress() {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const address = await signer.getAddress();\n return address;\n }\n\n async function transfer(params: NearTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { recipient, assetValue } = params;\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const account = await getAccount();\n\n if (assetValue.isGasAsset === false) {\n // NEP-141 token transfer\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n const amount = assetValue.getBaseValue(\"string\");\n\n return callFunction({\n contractId,\n methodName: \"ft_transfer\",\n args: {\n receiver_id: recipient,\n amount,\n memo: params.memo,\n },\n });\n }\n\n try {\n const transferAmount = assetValue.getBaseValue(\"string\");\n\n const result = await account.transfer({\n receiverId: recipient,\n amount: transferAmount,\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender } = params;\n\n const signerId = sender || (await getAddress());\n const publicKey = await getFullAccessPublicKey(provider, signerId);\n\n const accessKey = await provider.query({\n request_type: \"view_access_key\",\n finality: \"final\",\n account_id: signerId,\n });\n\n const nonce = (accessKey as any).nonce + 1;\n\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(\n transactions.functionCall(\"memo\", { memo }, BigInt(gas), BigInt(attachedDeposit)),\n );\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const transaction = transactions.createTransaction(\n signerId,\n publicKey,\n recipient,\n nonce,\n txActions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: await getAddress(),\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function createContractFunctionCall(params: {\n accountId: string;\n contractId: string;\n methodName: string;\n args: any;\n gas: string;\n attachedDeposit: string;\n }) {\n const { accountId } = params;\n\n const publicKey = await getFullAccessPublicKey(provider, accountId);\n\n const accessKey = await provider.query({\n request_type: \"view_access_key\",\n finality: \"final\",\n account_id: accountId,\n public_key: publicKey.toString(),\n });\n const nonce = (accessKey as any).nonce + 1;\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const actions = [\n transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n ),\n ];\n\n const transaction = transactions.createTransaction(\n accountId,\n publicKey,\n params.contractId,\n nonce,\n actions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: accountId,\n receiverId: params.contractId,\n methodName: params.methodName,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function signTransaction(transaction: Transaction) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n // Use the new signer interface method\n const [_hash, signedTx] = await signer.signTransaction(transaction);\n return signedTx;\n }\n\n async function broadcastTransaction(signedTransaction: SignedTransaction) {\n const result = await provider.sendTransaction(signedTransaction);\n return result.transaction.hash;\n }\n\n async function estimateTransactionFee(params: NearTransferParams | NearGasEstimateParams) {\n if (\"assetValue\" in params) {\n const baseTransferCost = \"115123062500\"; // gas units for transfer\n const receiptCreationCost = \"108059500000\"; // gas units for receipt\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n // NEAR doesn't support fee multipliers - gas price is fixed by the network\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n\n return AssetValue.from({\n chain: Chain.Near,\n value: totalCostYocto.toString(),\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Handle new gas estimation params\n const account = signer ? await getAccount() : undefined;\n return estimateGas(params, account);\n }\n\n async function getCurrentGasPrice() {\n try {\n const result = await provider.query({\n request_type: \"call_function\",\n finality: \"final\",\n account_id: \"system\",\n method_name: \"gas_price\",\n args_base64: \"\",\n });\n\n return result;\n } catch {\n return \"100000000\"; // 0.0001 NEAR per Tgas\n }\n }\n\n async function createSubAccount(subAccountId: string, publicKey: string, initialBalance: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const account = await getAccount();\n const { utils } = await import(\"near-api-js\");\n\n const balanceInYocto = utils.format.parseNearAmount(initialBalance) || \"0\";\n\n const result = await account.createAccount(\n subAccountId,\n utils.PublicKey.fromString(publicKey),\n BigInt(balanceInYocto),\n );\n\n return result.transaction.hash;\n }\n\n async function callFunction(params: NearFunctionCallParams) {\n try {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { transactions } = await import(\"near-api-js\");\n\n const { contractId, methodName, args, deposit } = params;\n const account = await getAccount();\n\n const estimatedGas = await estimateGas({\n methodName,\n args: args || {},\n contractId,\n });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"0\"),\n );\n\n const result = await account.signAndSendTransaction({\n receiverId: contractId,\n actions: [functionAction],\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract(contractInterface: NearContractInterface) {\n const { createNearContract } = await import(\"./helpers/contractFactory\");\n const account = await getAccount();\n\n return createNearContract({\n account,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n changeMethods: contractInterface.changeMethods,\n });\n }\n\n async function executeBatchTransaction(batch: { receiverId: string; actions: any[] }) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n if (batch.actions.length === 0) {\n throw new SwapKitError(\"toolbox_near_empty_batch\");\n }\n\n const account = await getAccount();\n\n // Use account.signAndSendTransaction for batch operations\n const result = await account.signAndSendTransaction({\n receiverId: batch.receiverId,\n actions: batch.actions,\n });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ contractId, account });\n }\n\n async function getBalance(address: string) {\n try {\n const account = await getAccount(address);\n\n let nativeBalance: AssetValue;\n try {\n const value = await account.getBalance();\n\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n } catch {\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value: \"0\",\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // // Then, fetch token balances from API\n // let tokenBalances: AssetValue[] = [];\n // try {\n // const apiBalances = await SwapKitApi.getChainBalance({\n // chain: Chain.Near,\n // address,\n // scamFilter,\n // });\n\n // tokenBalances = apiBalances\n // .filter(({ identifier }) => identifier !== Chain.Near) // Filter out native NEAR\n // .map(({ identifier, value, decimal }) => {\n // return new AssetValue({\n // decimal: decimal || BaseDecimal[Chain.Near],\n // value,\n // identifier,\n // });\n // });\n // } catch (error) {\n // // If API fails, just return on-chain balance\n // console.warn(\"Failed to fetch token balances from API:\", error);\n // }\n\n // Merge native balance with token balances\n // return [nativeBalance, ...tokenBalances];\n return [nativeBalance];\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_balance_failed\", { error });\n }\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const gasInTGas = await match(params)\n .when(isSimpleTransfer, () => GAS_COSTS.SIMPLE_TRANSFER)\n .when(isContractCall, (p) => getContractMethodGas(p.methodName))\n .when(isBatchTransaction, (p) => estimateBatchGas(p.actions))\n .when(isAccountCreation, () => GAS_COSTS.ACCOUNT_CREATION)\n .when(isContractDeployment, () => GAS_COSTS.CONTRACT_DEPLOYMENT)\n .when(isCustomEstimator, (p) => {\n if (!account) {\n throw new SwapKitError(\"toolbox_near_no_account\");\n }\n return p.customEstimator(account);\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_near_invalid_gas_params\");\n });\n\n // Convert TGas to gas price in NEAR\n const gasPrice = await getGasPrice();\n const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12); // Convert TGas to gas units\n const costInYoctoNear = gasInUnits * BigInt(gasPrice);\n\n return AssetValue.from({\n chain: Chain.Near,\n value: costInYoctoNear,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Get current gas price from network\n async function getGasPrice() {\n try {\n const result = await provider.gasPrice(null);\n return result.gas_price || \"100000000\";\n } catch (_error) {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n getAddress,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n provider,\n transfer,\n createTransaction,\n createContractFunctionCall,\n estimateTransactionFee,\n broadcastTransaction,\n signTransaction,\n getBalance,\n validateAddress: validateNearAddress,\n getSignerFromPhrase: (params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n }) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n callFunction,\n createSubAccount,\n createContract,\n executeBatchTransaction,\n nep141,\n getGasPrice,\n estimateGas,\n };\n}\n",
6
- "import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, SwapKitError, derivationPathToString } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function validateNearAddress(address: string) {\n // Use the official NEAR SDK validation function if available\n try {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return validateAccountId(address);\n } catch {\n const ACCOUNT_ID_REGEX = /^(([a-z\\d]+[-_])*[a-z\\d]+\\.)*([a-z\\d]+[-_])*[a-z\\d]+$/;\n\n return address.length >= 2 && address.length <= 64 && ACCOUNT_ID_REGEX.test(address);\n }\n}\n\nexport async function getNearSignerFromPhrase(params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n}) {\n const { parseSeedPhrase } = await import(\"near-seed-phrase\");\n const { KeyPair } = await import(\"near-api-js\");\n\n // Handle derivation path logic here\n // NEAR uses a 3-level derivation path: m/44'/397'/index'\n const index = params.index || 0;\n const derivationPath = params.derivationPath\n ? derivationPathToString(params.derivationPath.slice(0, 3) as [number, number, number])\n : `m/44'/397'/${index}'`;\n\n const { secretKey } = parseSeedPhrase(params.phrase, derivationPath);\n const keyPair = KeyPair.fromString(secretKey as any);\n\n return createNearSignerFromKeyPair(keyPair);\n}\n\nexport async function getNearSignerFromPrivateKey(privateKey: string) {\n const { KeyPair } = await import(\"near-api-js/lib/utils\");\n const keyPair = KeyPair.fromString(privateKey as any);\n return createNearSignerFromKeyPair(keyPair);\n}\n\nclass SKKeyPairSigner extends KeyPairSigner {\n #keyPair: KeyPair;\n\n constructor(keyPair: KeyPair) {\n super(keyPair);\n this.#keyPair = keyPair;\n }\n\n getAddress(): Promise<string> {\n // For implicit accounts, derive account ID from public key\n // NEAR implicit accounts use hex representation of the public key\n const publicKey = this.#keyPair.getPublicKey();\n const hexAddress = Buffer.from(publicKey.data).toString(\"hex\");\n return Promise.resolve(hexAddress);\n }\n}\n\nfunction createNearSignerFromKeyPair(keyPair: KeyPair): NearSigner {\n const keyPairSigner = new SKKeyPairSigner(keyPair);\n\n return keyPairSigner;\n}\n\nexport async function getFullAccessPublicKey(provider: Provider, accountId: string) {\n // Get the first full access key for the account\n const response = await provider.query({\n request_type: \"view_access_key_list\",\n finality: \"final\",\n account_id: accountId,\n });\n\n const fullAccessKey = (response as any).keys.find(\n (key: any) => key.access_key.permission === \"FullAccess\",\n );\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const { utils } = await import(\"near-api-js\");\n return utils.PublicKey.fromString(fullAccessKey.public_key);\n}\n",
5
+ "import {\n AssetValue,\n BaseDecimal,\n Chain,\n type DerivationPathArray,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\nimport type { Account } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n validateNearAddress,\n} from \"./helpers\";\nimport {\n GAS_COSTS,\n estimateBatchGas,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams) {\n const { P, match } = await import(\"ts-pattern\");\n const { providers } = await import(\"near-api-js\");\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async (params) => {\n const signer = await getNearSignerFromPhrase(params);\n return signer;\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n const url = SKConfig.get(\"rpcUrls\")[Chain.Near];\n\n const provider = new providers.JsonRpcProvider({ url });\n\n async function getAccount(address?: string) {\n const { Account } = await import(\"near-api-js\");\n\n const _address = address || (await getAddress());\n\n const account = new Account(_address, provider, signer);\n\n return account;\n }\n\n async function getAddress() {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const address = await signer.getAddress();\n return address;\n }\n\n async function transfer(params: NearTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { recipient, assetValue } = params;\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const account = await getAccount();\n\n if (assetValue.isGasAsset === false) {\n // NEP-141 token transfer\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n const amount = assetValue.getBaseValue(\"string\");\n\n return callFunction({\n contractId,\n methodName: \"ft_transfer\",\n args: {\n receiver_id: recipient,\n amount,\n memo: params.memo,\n },\n });\n }\n\n try {\n const transferAmount = assetValue.getBaseValue(\"string\");\n\n const result = await account.transfer({\n receiverId: recipient,\n amount: transferAmount,\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender: signerId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(\n transactions.functionCall(\"memo\", { memo }, BigInt(gas), BigInt(attachedDeposit)),\n );\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const transaction = transactions.createTransaction(\n signerId,\n publicKey,\n recipient,\n nonce,\n txActions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function createContractFunctionCall(params: {\n sender: string;\n contractId: string;\n methodName: string;\n args: any;\n gas: string;\n attachedDeposit: string;\n }) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const actions = [\n transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n ),\n ];\n\n const transaction = transactions.createTransaction(\n accountId,\n publicKey,\n params.contractId,\n nonce,\n actions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: accountId,\n receiverId: params.contractId,\n methodName: params.methodName,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function signTransaction(transaction: Transaction) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n // Use the new signer interface method\n const [_hash, signedTx] = await signer.signTransaction(transaction);\n return signedTx;\n }\n\n async function broadcastTransaction(signedTransaction: SignedTransaction) {\n const result = await provider.sendTransaction(signedTransaction);\n return result.transaction.hash;\n }\n\n async function estimateTransactionFee(params: NearTransferParams | NearGasEstimateParams) {\n if (\"assetValue\" in params) {\n const baseTransferCost = \"115123062500\"; // gas units for transfer\n const receiptCreationCost = \"108059500000\"; // gas units for receipt\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n // NEAR doesn't support fee multipliers - gas price is fixed by the network\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n\n return AssetValue.from({\n chain: Chain.Near,\n value: totalCostYocto.toString(),\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Handle new gas estimation params\n const account = signer ? await getAccount() : undefined;\n return estimateGas(params, account);\n }\n\n async function getCurrentGasPrice() {\n try {\n const result = await provider.query({\n request_type: \"call_function\",\n finality: \"final\",\n account_id: \"system\",\n method_name: \"gas_price\",\n args_base64: \"\",\n });\n\n return result;\n } catch {\n return \"100000000\"; // 0.0001 NEAR per Tgas\n }\n }\n\n async function createSubAccount(subAccountId: string, publicKey: string, initialBalance: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const account = await getAccount();\n const { utils } = await import(\"near-api-js\");\n\n const balanceInYocto = utils.format.parseNearAmount(initialBalance) || \"0\";\n\n const result = await account.createAccount(\n subAccountId,\n utils.PublicKey.fromString(publicKey),\n BigInt(balanceInYocto),\n );\n\n return result.transaction.hash;\n }\n\n async function callFunction(params: NearFunctionCallParams) {\n try {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { transactions } = await import(\"near-api-js\");\n\n const { contractId, methodName, args, deposit } = params;\n const account = await getAccount();\n\n const estimatedGas = await estimateGas({\n methodName,\n args: args || {},\n contractId,\n });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"0\"),\n );\n\n const result = await account.signAndSendTransaction({\n receiverId: contractId,\n actions: [functionAction],\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract(contractInterface: NearContractInterface) {\n const { createNearContract } = await import(\"./helpers/contractFactory\");\n const account = await getAccount();\n\n return createNearContract({\n account,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n changeMethods: contractInterface.changeMethods,\n });\n }\n\n async function executeBatchTransaction(batch: { receiverId: string; actions: any[] }) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n if (batch.actions.length === 0) {\n throw new SwapKitError(\"toolbox_near_empty_batch\");\n }\n\n const account = await getAccount();\n\n // Use account.signAndSendTransaction for batch operations\n const result = await account.signAndSendTransaction({\n receiverId: batch.receiverId,\n actions: batch.actions,\n });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ contractId, account });\n }\n\n async function getBalance(address: string) {\n try {\n const account = await getAccount(address);\n\n let nativeBalance: AssetValue;\n try {\n const value = await account.getBalance();\n\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n } catch {\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value: \"0\",\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // // Then, fetch token balances from API\n // let tokenBalances: AssetValue[] = [];\n // try {\n // const apiBalances = await SwapKitApi.getChainBalance({\n // chain: Chain.Near,\n // address,\n // scamFilter,\n // });\n\n // tokenBalances = apiBalances\n // .filter(({ identifier }) => identifier !== Chain.Near) // Filter out native NEAR\n // .map(({ identifier, value, decimal }) => {\n // return new AssetValue({\n // decimal: decimal || BaseDecimal[Chain.Near],\n // value,\n // identifier,\n // });\n // });\n // } catch (error) {\n // // If API fails, just return on-chain balance\n // console.warn(\"Failed to fetch token balances from API:\", error);\n // }\n\n // Merge native balance with token balances\n // return [nativeBalance, ...tokenBalances];\n return [nativeBalance];\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_balance_failed\", { error });\n }\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const gasInTGas = await match(params)\n .when(isSimpleTransfer, () => GAS_COSTS.SIMPLE_TRANSFER)\n .when(isContractCall, (p) => getContractMethodGas(p.methodName))\n .when(isBatchTransaction, (p) => estimateBatchGas(p.actions))\n .when(isAccountCreation, () => GAS_COSTS.ACCOUNT_CREATION)\n .when(isContractDeployment, () => GAS_COSTS.CONTRACT_DEPLOYMENT)\n .when(isCustomEstimator, (p) => {\n if (!account) {\n throw new SwapKitError(\"toolbox_near_no_account\");\n }\n return p.customEstimator(account);\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_near_invalid_gas_params\");\n });\n\n // Convert TGas to gas price in NEAR\n const gasPrice = await getGasPrice();\n const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12); // Convert TGas to gas units\n const costInYoctoNear = gasInUnits * BigInt(gasPrice);\n\n return AssetValue.from({\n chain: Chain.Near,\n value: costInYoctoNear,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Get current gas price from network\n async function getGasPrice() {\n try {\n const result = await provider.gasPrice(null);\n return result.gas_price || \"100000000\";\n } catch (_error) {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n getAddress,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n provider,\n transfer,\n createTransaction,\n createContractFunctionCall,\n estimateTransactionFee,\n broadcastTransaction,\n signTransaction,\n getBalance,\n validateAddress: validateNearAddress,\n getSignerFromPhrase: (params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n }) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n callFunction,\n createSubAccount,\n createContract,\n executeBatchTransaction,\n nep141,\n getGasPrice,\n estimateGas,\n };\n}\n",
6
+ "import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, SwapKitError, derivationPathToString } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function validateNearAddress(address: string) {\n // Use the official NEAR SDK validation function if available\n try {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return validateAccountId(address);\n } catch {\n const ACCOUNT_ID_REGEX = /^(([a-z\\d]+[-_])*[a-z\\d]+\\.)*([a-z\\d]+[-_])*[a-z\\d]+$/;\n\n return address.length >= 2 && address.length <= 64 && ACCOUNT_ID_REGEX.test(address);\n }\n}\n\nexport async function getNearSignerFromPhrase(params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n}) {\n const { parseSeedPhrase } = await import(\"near-seed-phrase\");\n const { KeyPair } = await import(\"near-api-js\");\n\n // Handle derivation path logic here\n // NEAR uses a 3-level derivation path: m/44'/397'/index'\n const index = params.index || 0;\n const derivationPath = params.derivationPath\n ? derivationPathToString(params.derivationPath.slice(0, 3) as [number, number, number])\n : `m/44'/397'/${index}'`;\n\n const { secretKey } = parseSeedPhrase(params.phrase, derivationPath);\n const keyPair = KeyPair.fromString(secretKey as any);\n\n return createNearSignerFromKeyPair(keyPair);\n}\n\nexport async function getNearSignerFromPrivateKey(privateKey: string) {\n const { KeyPair } = await import(\"near-api-js/lib/utils\");\n const keyPair = KeyPair.fromString(privateKey as any);\n return createNearSignerFromKeyPair(keyPair);\n}\n\nclass SKKeyPairSigner extends KeyPairSigner {\n #keyPair: KeyPair;\n\n constructor(keyPair: KeyPair) {\n super(keyPair);\n this.#keyPair = keyPair;\n }\n\n getAddress(): Promise<string> {\n // For implicit accounts, derive account ID from public key\n // NEAR implicit accounts use hex representation of the public key\n const publicKey = this.#keyPair.getPublicKey();\n const hexAddress = Buffer.from(publicKey.data).toString(\"hex\");\n return Promise.resolve(hexAddress);\n }\n}\n\nfunction createNearSignerFromKeyPair(keyPair: KeyPair): NearSigner {\n const keyPairSigner = new SKKeyPairSigner(keyPair);\n\n return keyPairSigner;\n}\n\nexport async function getFullAccessPublicKey(provider: Provider, accountId: string) {\n // Get the first full access key for the account\n const response = await provider.query({\n request_type: \"view_access_key_list\",\n finality: \"final\",\n account_id: accountId,\n });\n\n const fullAccessKey = (response as any).keys.find(\n (key: any) => key.access_key.permission === \"FullAccess\",\n );\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const { utils } = await import(\"near-api-js\");\n const publicKey = utils.PublicKey.fromString(fullAccessKey.public_key);\n const nonce = (fullAccessKey.access_key.nonce as number) || 0;\n\n return { publicKey, nonce };\n}\n",
7
7
  "import type { Account } from \"near-api-js\";\nimport type { NearGasEstimateParams } from \"../types/contract\";\n\n// Gas constants (in TGas - 10^12 gas units)\nexport const GAS_COSTS = {\n SIMPLE_TRANSFER: \"1\", // 1 TGas\n TOKEN_TRANSFER: \"100\", // 100 TGas\n CONTRACT_CALL: \"100\", // 100 TGas base\n ACCOUNT_CREATION: \"30\", // 30 TGas\n CONTRACT_DEPLOYMENT: \"200\", // 200 TGas\n ACCESS_KEY_ADDITION: \"5\", // 5 TGas\n ACCESS_KEY_DELETION: \"5\", // 5 TGas\n STAKE: \"10\", // 10 TGas\n STORAGE_DEPOSIT: \"100\", // 100 TGas\n} as const;\n\n// Type guards for discriminated union\nexport function isSimpleTransfer(\n params: NearGasEstimateParams,\n): params is { recipient: string; amount: string } {\n return \"recipient\" in params && \"amount\" in params && !(\"contractId\" in params);\n}\n\nexport function isContractCall(params: NearGasEstimateParams): params is {\n contractId: string;\n methodName: string;\n args?: Record<string, any>;\n attachedDeposit?: string;\n} {\n return \"contractId\" in params && \"methodName\" in params;\n}\n\nexport function isBatchTransaction(params: NearGasEstimateParams): params is { actions: any[] } {\n return \"actions\" in params;\n}\n\nexport function isAccountCreation(params: NearGasEstimateParams): params is {\n newAccountId: string;\n publicKey?: string;\n} {\n return \"newAccountId\" in params;\n}\n\nexport function isContractDeployment(\n params: NearGasEstimateParams,\n): params is { contractCode: Uint8Array } {\n return \"contractCode\" in params;\n}\n\nexport function isCustomEstimator(params: NearGasEstimateParams): params is {\n customEstimator: (account: Account) => Promise<string>;\n} {\n return \"customEstimator\" in params;\n}\n\n// Helper function to estimate gas for batch actions\nexport function estimateBatchGas(actions: any[]) {\n let totalGas = 0;\n\n for (const action of actions) {\n switch (action.enum) {\n case \"transfer\":\n totalGas += Number(GAS_COSTS.SIMPLE_TRANSFER);\n break;\n case \"functionCall\":\n totalGas += Number(GAS_COSTS.CONTRACT_CALL);\n break;\n case \"createAccount\":\n totalGas += Number(GAS_COSTS.ACCOUNT_CREATION);\n break;\n case \"deployContract\":\n totalGas += Number(GAS_COSTS.CONTRACT_DEPLOYMENT);\n break;\n case \"addKey\":\n totalGas += Number(GAS_COSTS.ACCESS_KEY_ADDITION);\n break;\n case \"deleteKey\":\n totalGas += Number(GAS_COSTS.ACCESS_KEY_DELETION);\n break;\n case \"stake\":\n totalGas += Number(GAS_COSTS.STAKE);\n break;\n default:\n totalGas += Number(GAS_COSTS.CONTRACT_CALL);\n }\n }\n\n return totalGas.toString();\n}\n\n// Helper function to get gas cost for contract methods\nexport function getContractMethodGas(methodName: string) {\n if (methodName === \"ft_transfer\" || methodName === \"ft_transfer_call\") {\n return GAS_COSTS.TOKEN_TRANSFER;\n }\n if (methodName === \"storage_deposit\") {\n return GAS_COSTS.STORAGE_DEPOSIT;\n }\n return GAS_COSTS.CONTRACT_CALL;\n}\n\n// Convert TGas string to gas units\nexport function tgasToGas(tgas: string): string {\n return (BigInt(tgas) * BigInt(10 ** 12)).toString();\n}\n\n// Convert gas units to TGas\nexport function gasToTGas(gas: string): string {\n return (BigInt(gas) / BigInt(10 ** 12)).toString();\n}\n",
8
8
  "import type { Account, Contract } from \"near-api-js\";\nimport { createNearContract } from \"./contractFactory\";\n\nconst DEFAULT_STORAGE_DEPOSIT = \"1250000000000000000000\"; // 0.00125 NEAR\n\n// Define NEP-141 contract interface\ninterface NEP141Contract extends Contract {\n // View methods\n ft_balance_of(args: { account_id: string }): Promise<string>;\n ft_total_supply(): Promise<string>;\n ft_metadata(): Promise<any>;\n storage_balance_of(args: { account_id: string }): Promise<any>;\n storage_balance_bounds(): Promise<any>;\n\n // Change methods\n ft_transfer(args: any, gas: any, deposit: any): Promise<any>;\n ft_transfer_call(args: any, gas: any, deposit: any): Promise<any>;\n storage_deposit(args: any, gas: any, deposit: any): Promise<any>;\n storage_withdraw(args: any, gas: any, deposit: any): Promise<any>;\n storage_unregister(force?: boolean, gas?: any): Promise<any>;\n}\n\nexport async function createNEP141Token({\n contractId,\n account,\n}: {\n contractId: string;\n account: Account;\n}) {\n const BN = (await import(\"bn.js\")).default;\n\n const contract = await createNearContract<NEP141Contract>({\n account,\n contractId,\n viewMethods: [\n \"ft_balance_of\",\n \"ft_total_supply\",\n \"ft_metadata\",\n \"storage_balance_of\",\n \"storage_balance_bounds\",\n ],\n changeMethods: [\n \"ft_transfer\",\n \"ft_transfer_call\",\n \"storage_deposit\",\n \"storage_withdraw\",\n \"storage_unregister\",\n ],\n });\n\n // Helper to ensure storage before transfers\n const ensureStorageFor = async (accountId: string) => {\n const balance = await contract.storage_balance_of({ account_id: accountId });\n if (!balance) {\n // Get minimum storage requirement\n const bounds = await contract.storage_balance_bounds();\n const deposit = bounds?.min || DEFAULT_STORAGE_DEPOSIT;\n\n await contract.storage_deposit(\n { account_id: accountId },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(deposit),\n );\n }\n };\n\n return {\n transfer: async (receiverId: string, amount: string, memo?: string) => {\n // Ensure recipient has storage before transfer\n await ensureStorageFor(receiverId);\n\n return contract.ft_transfer(\n { receiver_id: receiverId, amount, memo },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n\n transferCall: async (receiverId: string, amount: string, msg: string, memo?: string) => {\n // Ensure recipient has storage before transfer\n await ensureStorageFor(receiverId);\n\n return contract.ft_transfer_call(\n { receiver_id: receiverId, amount, memo, msg },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n\n balanceOf: (accountId: string) => contract.ft_balance_of({ account_id: accountId }),\n\n totalSupply: () => contract.ft_total_supply(),\n\n metadata: () => contract.ft_metadata(),\n\n storageBalanceOf: (accountId: string) => contract.storage_balance_of({ account_id: accountId }),\n\n storageDeposit: (accountId?: string, amount?: string) =>\n contract.storage_deposit(\n { account_id: accountId },\n new BN(\"100000000000000\"),\n new BN(amount || DEFAULT_STORAGE_DEPOSIT),\n ),\n\n ensureStorage: ensureStorageFor,\n\n // Raw contract access for advanced use cases\n contract,\n };\n}\n"
9
9
  ],
10
- "mappings": "ydAOO,IAPP,8BCC+E,IAA/E,8BACA,yBAGA,eAAsB,CAAmB,CAAC,EAAiB,CAEzD,GAAI,CACF,IAAQ,qBAAsB,KAAa,uBAC3C,OAAO,EAAkB,CAAO,EAChC,KAAM,CACN,IAAM,EAAmB,wDAEzB,OAAO,EAAQ,QAAU,GAAK,EAAQ,QAAU,IAAM,EAAiB,KAAK,CAAO,GAIvF,eAAsB,CAAuB,CAAC,EAI3C,CACD,IAAQ,mBAAoB,KAAa,6BACjC,WAAY,KAAa,uBAI3B,EAAQ,EAAO,OAAS,EACxB,EAAiB,EAAO,eAC1B,yBAAuB,EAAO,eAAe,MAAM,EAAG,CAAC,CAA6B,EACpF,cAAc,MAEV,aAAc,EAAgB,EAAO,OAAQ,CAAc,EAC7D,EAAU,EAAQ,WAAW,CAAgB,EAEnD,OAAO,EAA4B,CAAO,EAG5C,eAAsB,CAA2B,CAAC,EAAoB,CACpE,IAAQ,WAAY,KAAa,iCAC3B,EAAU,EAAQ,WAAW,CAAiB,EACpD,OAAO,EAA4B,CAAO,EAG5C,MAAM,UAAwB,eAAc,CAC1C,GAEA,WAAW,CAAC,EAAkB,CAC5B,MAAM,CAAO,EACb,KAAK,GAAW,EAGlB,UAAU,EAAoB,CAG5B,IAAM,EAAY,KAAK,GAAS,aAAa,EACvC,EAAa,OAAO,KAAK,EAAU,IAAI,EAAE,SAAS,KAAK,EAC7D,OAAO,QAAQ,QAAQ,CAAU,EAErC,CAEA,SAAS,CAA2B,CAAC,EAA8B,CAGjE,OAFsB,IAAI,EAAgB,CAAO,EAKnD,eAAsB,CAAsB,CAAC,EAAoB,EAAmB,CAQlF,IAAM,GANW,MAAM,EAAS,MAAM,CACpC,aAAc,uBACd,SAAU,QACV,WAAY,CACd,CAAC,GAEuC,KAAK,KAC3C,CAAC,IAAa,EAAI,WAAW,aAAe,YAC9C,EAEA,IAAK,EACH,MAAM,IAAI,eAAa,8BAA8B,EAGvD,IAAQ,SAAU,KAAa,uBAC/B,OAAO,EAAM,UAAU,WAAW,EAAc,UAAU,EChFrD,IAAM,EAAY,CACvB,gBAAiB,IACjB,eAAgB,MAChB,cAAe,MACf,iBAAkB,KAClB,oBAAqB,MACrB,oBAAqB,IACrB,oBAAqB,IACrB,MAAO,KACP,gBAAiB,KACnB,EAGO,SAAS,CAAgB,CAC9B,EACiD,CACjD,MAAO,cAAe,GAAU,WAAY,KAAY,eAAgB,GAGnE,SAAS,CAAc,CAAC,EAK7B,CACA,MAAO,eAAgB,GAAU,eAAgB,EAG5C,SAAS,CAAkB,CAAC,EAA6D,CAC9F,MAAO,YAAa,EAGf,SAAS,CAAiB,CAAC,EAGhC,CACA,MAAO,iBAAkB,EAGpB,SAAS,CAAoB,CAClC,EACwC,CACxC,MAAO,iBAAkB,EAGpB,SAAS,CAAiB,CAAC,EAEhC,CACA,MAAO,oBAAqB,EAIvB,SAAS,CAAgB,CAAC,EAAgB,CAC/C,IAAI,EAAW,EAEf,QAAW,KAAU,EACnB,OAAQ,EAAO,UACR,WACH,GAAY,OAAO,EAAU,eAAe,EAC5C,UACG,eACH,GAAY,OAAO,EAAU,aAAa,EAC1C,UACG,gBACH,GAAY,OAAO,EAAU,gBAAgB,EAC7C,UACG,iBACH,GAAY,OAAO,EAAU,mBAAmB,EAChD,UACG,SACH,GAAY,OAAO,EAAU,mBAAmB,EAChD,UACG,YACH,GAAY,OAAO,EAAU,mBAAmB,EAChD,UACG,QACH,GAAY,OAAO,EAAU,KAAK,EAClC,cAEA,GAAY,OAAO,EAAU,aAAa,EAIhD,OAAO,EAAS,SAAS,EAIpB,SAAS,CAAoB,CAAC,EAAoB,CACvD,GAAI,IAAe,eAAiB,IAAe,mBACjD,OAAO,EAAU,eAEnB,GAAI,IAAe,kBACjB,OAAO,EAAU,gBAEnB,OAAO,EAAU,cAIZ,SAAS,CAAS,CAAC,EAAsB,CAC9C,OAAQ,OAAO,CAAI,EAAI,OAAO,aAAQ,GAAG,SAAS,EAI7C,SAAS,CAAS,CAAC,EAAqB,CAC7C,OAAQ,OAAO,CAAG,EAAI,OAAO,aAAQ,GAAG,SAAS,ECzGnD,IAAM,EAA0B,yBAmBhC,eAAsB,CAAiB,EACrC,aACA,WAIC,CACD,IAAM,GAAM,KAAa,kBAAU,QAE7B,EAAW,MAAM,EAAmC,CACxD,UACA,aACA,YAAa,CACX,gBACA,kBACA,cACA,qBACA,wBACF,EACA,cAAe,CACb,cACA,mBACA,kBACA,mBACA,oBACF,CACF,CAAC,EAGK,EAAmB,MAAO,IAAsB,CAEpD,IADgB,MAAM,EAAS,mBAAmB,CAAE,WAAY,CAAU,CAAC,EAC7D,CAGZ,IAAM,GADS,MAAM,EAAS,uBAAuB,IAC7B,KAAO,EAE/B,MAAM,EAAS,gBACb,CAAE,WAAY,CAAU,EACxB,IAAI,EAAG,iBAAiB,EACxB,IAAI,EAAG,CAAO,CAChB,IAIJ,MAAO,CACL,SAAU,MAAO,EAAoB,EAAgB,IAAkB,CAIrE,OAFA,MAAM,EAAiB,CAAU,EAE1B,EAAS,YACd,CAAE,YAAa,EAAY,SAAQ,MAAK,EACxC,IAAI,EAAG,iBAAiB,EACxB,IAAI,EAAG,GAAG,CACZ,GAGF,aAAc,MAAO,EAAoB,EAAgB,EAAa,IAAkB,CAItF,OAFA,MAAM,EAAiB,CAAU,EAE1B,EAAS,iBACd,CAAE,YAAa,EAAY,SAAQ,OAAM,KAAI,EAC7C,IAAI,EAAG,iBAAiB,EACxB,IAAI,EAAG,GAAG,CACZ,GAGF,UAAW,CAAC,IAAsB,EAAS,cAAc,CAAE,WAAY,CAAU,CAAC,EAElF,YAAa,IAAM,EAAS,gBAAgB,EAE5C,SAAU,IAAM,EAAS,YAAY,EAErC,iBAAkB,CAAC,IAAsB,EAAS,mBAAmB,CAAE,WAAY,CAAU,CAAC,EAE9F,eAAgB,CAAC,EAAoB,IACnC,EAAS,gBACP,CAAE,WAAY,CAAU,EACxB,IAAI,EAAG,iBAAiB,EACxB,IAAI,EAAG,GAAU,CAAuB,CAC1C,EAEF,cAAe,EAGf,UACF,EHxEF,eAAsB,EAAc,CAAC,EAAmC,CACtE,IAAQ,IAAG,SAAU,KAAa,uBAC1B,aAAc,KAAa,uBAC7B,EAAS,MAAM,EAAM,CAAa,EACrC,KAAK,CAAE,OAAQ,EAAE,MAAO,EAAG,MAAO,IAAW,CAE5C,OADe,MAAM,EAAwB,CAAM,EAEpD,EACA,KAAK,CAAE,OAAQ,EAAE,GAAI,EAAG,EAAG,YAAa,CAAM,EAC9C,UAAU,IAAG,CAAG,OAAS,EAEtB,EAAM,WAAS,IAAI,SAAS,EAAE,QAAM,MAEpC,EAAW,IAAI,EAAU,gBAAgB,CAAE,KAAI,CAAC,EAEtD,eAAe,CAAU,CAAC,EAAkB,CAC1C,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAEjD,IAAQ,WAAY,KAAa,uBAE3B,EAAW,GAAY,MAAM,EAAW,EAI9C,OAFgB,IAAI,EAAQ,EAAU,EAAU,CAAM,EAKxD,eAAe,CAAU,EAAG,CAC1B,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAGjD,OADgB,MAAM,EAAO,WAAW,EAI1C,eAAe,CAAQ,CAAC,EAA4B,CAClD,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAGjD,IAAQ,YAAW,cAAe,EAElC,IAAK,EAAoB,CAAS,EAChC,MAAM,IAAI,eAAa,8BAA8B,EAGvD,IAAM,EAAU,MAAM,EAAW,EAEjC,GAAI,EAAW,aAAe,GAAO,CAEnC,IAAM,EAAa,EAAW,QAC9B,IAAK,EACH,MAAM,IAAI,eAAa,uCAAuC,EAGhE,IAAM,EAAS,EAAW,aAAa,QAAQ,EAE/C,OAAO,EAAa,CAClB,aACA,WAAY,cACZ,KAAM,CACJ,YAAa,EACb,SACA,KAAM,EAAO,IACf,CACF,CAAC,EAGH,GAAI,CACF,IAAM,EAAiB,EAAW,aAAa,QAAQ,EAOvD,OALe,MAAM,EAAQ,SAAS,CACpC,WAAY,EACZ,OAAQ,CACV,CAAC,GAEa,YAAY,KAC1B,MAAO,EAAO,CACd,MAAM,IAAI,eAAa,+BAAgC,CAAE,OAAM,CAAC,GAIpE,eAAe,EAAiB,CAAC,EAAqC,CACpE,IAAQ,YAAW,aAAY,OAAM,QAAS,EAAK,kBAAiB,UAAW,EAEzE,EAAW,GAAW,MAAM,EAAW,EACvC,EAAY,MAAM,EAAuB,EAAU,CAAQ,EAQ3D,GANY,MAAM,EAAS,MAAM,CACrC,aAAc,kBACd,SAAU,QACV,WAAY,CACd,CAAC,GAEgC,MAAQ,EAEnC,EAAa,EAAW,aAAa,QAAQ,GAE3C,UAAW,KAAa,wCACxB,eAAc,SAAU,KAAa,uBAEvC,EAAY,CAAC,EAAa,SAAS,CAAU,CAAC,EAEpD,GAAI,GAAQ,EACV,EAAU,KACR,EAAa,aAAa,OAAQ,CAAE,MAAK,EAAG,OAAO,CAAG,EAAG,OAAO,CAAe,CAAC,CAClF,EAGF,IAAM,GAAQ,MAAM,EAAS,MAAM,CAAE,SAAU,OAAQ,CAAC,EAClD,EAAY,EAAM,UAAU,YAAY,GAAM,OAAO,IAAI,EAEzD,GAAc,EAAa,kBAC/B,EACA,EACA,EACA,EACA,EACA,CACF,EAEM,GAAe,EAAM,UAAU,UAAU,EAAO,YAAa,EAAW,EAG9E,MAAO,CACL,WAHuB,OAAO,KAAK,EAAY,EAAE,SAAS,QAAQ,EAIlE,UAAW,EAAU,SAAS,EAC9B,QAAS,CACP,SAAU,MAAM,EAAW,EAC3B,MAAO,EACP,UAAW,EAAM,UAAU,YAAY,CAAS,CAClD,CACF,EAGF,eAAe,EAA0B,CAAC,EAOvC,CACD,IAAQ,aAAc,EAEhB,EAAY,MAAM,EAAuB,EAAU,CAAS,EAQ5D,GANY,MAAM,EAAS,MAAM,CACrC,aAAc,kBACd,SAAU,QACV,WAAY,EACZ,WAAY,EAAU,SAAS,CACjC,CAAC,GACgC,MAAQ,GAEjC,UAAW,KAAa,wCACxB,eAAc,SAAU,KAAa,uBACvC,EAAQ,MAAM,EAAS,MAAM,CAAE,SAAU,OAAQ,CAAC,EAClD,EAAY,EAAM,UAAU,YAAY,EAAM,OAAO,IAAI,EAEzD,EAAU,CACd,EAAa,aACX,EAAO,WACP,OAAO,KAAK,KAAK,UAAU,EAAO,IAAI,CAAC,EACvC,OAAO,EAAO,GAAG,EACjB,OAAO,EAAO,eAAe,CAC/B,CACF,EAEM,EAAc,EAAa,kBAC/B,EACA,EACA,EAAO,WACP,EACA,EACA,CACF,EAEM,EAAe,EAAM,UAAU,UAAU,EAAO,YAAa,CAAW,EAG9E,MAAO,CACL,WAHuB,OAAO,KAAK,CAAY,EAAE,SAAS,QAAQ,EAIlE,UAAW,EAAU,SAAS,EAC9B,QAAS,CACP,SAAU,EACV,WAAY,EAAO,WACnB,WAAY,EAAO,WACnB,MAAO,EACP,UAAW,EAAM,UAAU,YAAY,CAAS,CAClD,CACF,EAGF,eAAe,EAAe,CAAC,EAA0B,CACvD,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAIjD,IAAO,EAAO,GAAY,MAAM,EAAO,gBAAgB,CAAW,EAClE,OAAO,EAGT,eAAe,EAAoB,CAAC,EAAsC,CAExE,OADe,MAAM,EAAS,gBAAgB,CAAiB,GACjD,YAAY,KAG5B,eAAe,EAAsB,CAAC,EAAoD,CACxF,GAAI,eAAgB,EAAQ,CAI1B,IAAM,EAAgB,OAHG,cAGoB,EAAI,OAFrB,cAE+C,EAErE,EAAW,MAAM,GAAmB,EAGpC,EAAiB,EAAgB,OAAO,EAAS,SAAS,CAAC,EAEjE,OAAO,aAAW,KAAK,CACrB,MAAO,QAAM,KACb,MAAO,EAAe,SAAS,EAC/B,gBAAiB,cAAY,QAAM,KACrC,CAAC,EAIH,IAAM,EAAU,EAAS,MAAM,EAAW,EAAI,OAC9C,OAAO,EAAY,EAAQ,CAAO,EAGpC,eAAe,EAAkB,EAAG,CAClC,GAAI,CASF,OARe,MAAM,EAAS,MAAM,CAClC,aAAc,gBACd,SAAU,QACV,WAAY,SACZ,YAAa,YACb,YAAa,EACf,CAAC,EAGD,KAAM,CACN,MAAO,aAIX,eAAe,EAAgB,CAAC,EAAsB,EAAmB,EAAwB,CAC/F,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAGjD,IAAM,EAAU,MAAM,EAAW,GACzB,SAAU,KAAa,uBAEzB,EAAiB,EAAM,OAAO,gBAAgB,CAAc,GAAK,IAQvE,OANe,MAAM,EAAQ,cAC3B,EACA,EAAM,UAAU,WAAW,CAAS,EACpC,OAAO,CAAc,CACvB,GAEc,YAAY,KAG5B,eAAe,CAAY,CAAC,EAAgC,CAC1D,GAAI,CACF,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAGjD,IAAQ,gBAAiB,KAAa,wBAE9B,aAAY,aAAY,OAAM,WAAY,EAC5C,EAAU,MAAM,EAAW,EAE3B,EAAe,MAAM,EAAY,CACrC,aACA,KAAM,GAAQ,CAAC,EACf,YACF,CAAC,EAEK,EAAiB,EAAa,aAClC,EACA,GAAQ,CAAC,EACT,EAAa,aAAa,QAAQ,EAClC,OAAO,GAAW,GAAG,CACvB,EAOA,OALe,MAAM,EAAQ,uBAAuB,CAClD,WAAY,EACZ,QAAS,CAAC,CAAc,CAC1B,CAAC,GAEa,YAAY,KAC1B,MAAO,EAAO,CACd,MAAM,IAAI,eAAa,+BAAgC,CAAE,OAAM,CAAC,GAKpE,eAAe,EAAc,CAAC,EAA0C,CACtE,IAAQ,sBAAuB,KAAa,mCACtC,EAAU,MAAM,EAAW,EAEjC,OAAO,EAAmB,CACxB,UACA,WAAY,EAAkB,WAC9B,YAAa,EAAkB,YAC/B,cAAe,EAAkB,aACnC,CAAC,EAGH,eAAe,EAAuB,CAAC,EAA+C,CACpF,IAAK,EACH,MAAM,IAAI,eAAa,wBAAwB,EAGjD,GAAI,EAAM,QAAQ,SAAW,EAC3B,MAAM,IAAI,eAAa,0BAA0B,EAWnD,OALe,MAHC,MAAM,EAAW,GAGJ,uBAAuB,CAClD,WAAY,EAAM,WAClB,QAAS,EAAM,OACjB,CAAC,GAEa,YAAY,KAG5B,eAAe,EAAM,CAAC,EAAoB,CACxC,IAAM,EAAU,MAAM,EAAW,EACjC,OAAO,EAAkB,CAAE,aAAY,SAAQ,CAAC,EAGlD,eAAe,EAAU,CAAC,EAAiB,CACzC,GAAI,CACF,IAAM,EAAU,MAAM,EAAW,CAAO,EAEpC,EACJ,GAAI,CACF,IAAM,EAAQ,MAAM,EAAQ,WAAW,EAEvC,EAAgB,aAAW,KAAK,CAC9B,MAAO,QAAM,KACb,QACA,gBAAiB,cAAY,QAAM,KACrC,CAAC,EACD,KAAM,CACN,EAAgB,aAAW,KAAK,CAC9B,MAAO,QAAM,KACb,MAAO,IACP,gBAAiB,cAAY,QAAM,KACrC,CAAC,EA4BH,MAAO,CAAC,CAAa,EACrB,MAAO,EAAO,CACd,MAAM,IAAI,eAAa,8BAA+B,CAAE,OAAM,CAAC,GAInE,eAAe,CAAW,CAAC,EAA+B,EAAmB,CAC3E,IAAM,EAAY,MAAM,EAAM,CAAM,EACjC,KAAK,EAAkB,IAAM,EAAU,eAAe,EACtD,KAAK,EAAgB,CAAC,IAAM,EAAqB,EAAE,UAAU,CAAC,EAC9D,KAAK,EAAoB,CAAC,IAAM,EAAiB,EAAE,OAAO,CAAC,EAC3D,KAAK,EAAmB,IAAM,EAAU,gBAAgB,EACxD,KAAK,EAAsB,IAAM,EAAU,mBAAmB,EAC9D,KAAK,EAAmB,CAAC,IAAM,CAC9B,IAAK,EACH,MAAM,IAAI,eAAa,yBAAyB,EAElD,OAAO,EAAE,gBAAgB,CAAO,EACjC,EACA,UAAU,IAAM,CACf,MAAM,IAAI,eAAa,iCAAiC,EACzD,EAGG,EAAW,MAAM,EAAY,EAE7B,EADa,OAAO,CAAS,EAAI,OAAO,aAAQ,EACjB,OAAO,CAAQ,EAEpD,OAAO,aAAW,KAAK,CACrB,MAAO,QAAM,KACb,MAAO,EACP,gBAAiB,cAAY,QAAM,KACrC,CAAC,EAIH,eAAe,CAAW,EAAG,CAC3B,GAAI,CAEF,OADe,MAAM,EAAS,SAAS,IAAI,GAC7B,WAAa,YAC3B,MAAO,EAAQ,CAEf,MAAO,aAIX,MAAO,CACL,aACA,aAAc,SAAa,GAAU,MAAM,EAAO,aAAa,GAAG,SAAS,EAAI,GAC/E,WACA,WACA,qBACA,8BACA,0BACA,wBACA,mBACA,cACA,gBAAiB,EACjB,oBAAqB,CAAC,IAIhB,EAAwB,CAAM,EACpC,wBAAyB,EACzB,eACA,oBACA,kBACA,2BACA,UACA,cACA,aACF",
11
- "debugId": "95CBB72A2AA595E364756E2164756E21",
10
+ "mappings": "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",
11
+ "debugId": "FC6BDAE142BFC3F564756E2164756E21",
12
12
  "names": []
13
13
  }
@@ -1,3 +1,3 @@
1
- import{a as E}from"../../chunk-kbnwrc5b.js";import{d as f,e as U}from"../../chunk-s47y8512.js";import{AssetValue as y,BaseDecimal as P,Chain as w,SKConfig as B1,SwapKitError as D}from"@swapkit/helpers";import{SwapKitError as R1,derivationPathToString as H1}from"@swapkit/helpers";import{KeyPairSigner as V1}from"near-api-js";async function K(W){try{let{validateAccountId:Q}=await import("near-sdk-js");return Q(W)}catch{let Q=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return W.length>=2&&W.length<=64&&Q.test(W)}}async function I(W){let{parseSeedPhrase:Q}=await import("near-seed-phrase"),{KeyPair:L}=await import("near-api-js"),M=W.index||0,Z=W.derivationPath?H1(W.derivationPath.slice(0,3)):`m/44'/397'/${M}'`,{secretKey:$}=Q(W.phrase,Z),X=L.fromString($);return p(X)}async function u(W){let{KeyPair:Q}=await import("near-api-js/lib/utils"),L=Q.fromString(W);return p(L)}class m extends V1{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Q=Buffer.from(W.data).toString("hex");return Promise.resolve(Q)}}function p(W){return new m(W)}async function h(W,Q){let M=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Q})).keys.find(($)=>$.access_key.permission==="FullAccess");if(!M)throw new R1("toolbox_near_invalid_address");let{utils:Z}=await import("near-api-js");return Z.PublicKey.fromString(M.public_key)}var V={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function d(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function o(W){return"contractId"in W&&"methodName"in W}function i(W){return"actions"in W}function n(W){return"newAccountId"in W}function c(W){return"contractCode"in W}function s(W){return"customEstimator"in W}function t(W){let Q=0;for(let L of W)switch(L.enum){case"transfer":Q+=Number(V.SIMPLE_TRANSFER);break;case"functionCall":Q+=Number(V.CONTRACT_CALL);break;case"createAccount":Q+=Number(V.ACCOUNT_CREATION);break;case"deployContract":Q+=Number(V.CONTRACT_DEPLOYMENT);break;case"addKey":Q+=Number(V.ACCESS_KEY_ADDITION);break;case"deleteKey":Q+=Number(V.ACCESS_KEY_DELETION);break;case"stake":Q+=Number(V.STAKE);break;default:Q+=Number(V.CONTRACT_CALL)}return Q.toString()}function e(W){if(W==="ft_transfer"||W==="ft_transfer_call")return V.TOKEN_TRANSFER;if(W==="storage_deposit")return V.STORAGE_DEPOSIT;return V.CONTRACT_CALL}function D1(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function j1(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var r="1250000000000000000000";async function T({contractId:W,account:Q}){let L=(await import("bn.js")).default,M=await E({account:Q,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),Z=async($)=>{if(!await M.storage_balance_of({account_id:$})){let F=(await M.storage_balance_bounds())?.min||r;await M.storage_deposit({account_id:$},new L("100000000000000"),new L(F))}};return{transfer:async($,X,j)=>{return await Z($),M.ft_transfer({receiver_id:$,amount:X,memo:j},new L("100000000000000"),new L("1"))},transferCall:async($,X,j,F)=>{return await Z($),M.ft_transfer_call({receiver_id:$,amount:X,memo:F,msg:j},new L("100000000000000"),new L("1"))},balanceOf:($)=>M.ft_balance_of({account_id:$}),totalSupply:()=>M.ft_total_supply(),metadata:()=>M.ft_metadata(),storageBalanceOf:($)=>M.storage_balance_of({account_id:$}),storageDeposit:($,X)=>M.storage_deposit({account_id:$},new L("100000000000000"),new L(X||r)),ensureStorage:Z,contract:M}}async function h1(W){let{P:Q,match:L}=await import("ts-pattern"),{providers:M}=await import("near-api-js"),Z=await L(W).with({phrase:Q.string},async(x)=>{return await I(x)}).with({signer:Q.any},({signer:x})=>x).otherwise(()=>{return}),$=B1.get("rpcUrls")[w.Near],X=new M.JsonRpcProvider({url:$});async function j(x){if(!Z)throw new D("toolbox_near_no_signer");let{Account:q}=await import("near-api-js"),J=x||await F();return new q(J,X,Z)}async function F(){if(!Z)throw new D("toolbox_near_no_signer");return await Z.getAddress()}async function a(x){if(!Z)throw new D("toolbox_near_no_signer");let{recipient:q,assetValue:J}=x;if(!K(q))throw new D("toolbox_near_invalid_address");let Y=await j();if(J.isGasAsset===!1){let z=J.address;if(!z)throw new D("toolbox_near_missing_contract_address");let R=J.getBaseValue("string");return A({contractId:z,methodName:"ft_transfer",args:{receiver_id:q,amount:R,memo:x.memo}})}try{let z=J.getBaseValue("string");return(await Y.transfer({receiverId:q,amount:z})).transaction.hash}catch(z){throw new D("toolbox_near_transfer_failed",{error:z})}}async function x1(x){let{recipient:q,assetValue:J,memo:Y,feeRate:z,attachedDeposit:R,sender:H}=x,B=H||await F(),N=await h(X,B),k=(await X.query({request_type:"view_access_key",finality:"final",account_id:B})).nonce+1,v=J.getBaseValue("bigint"),{SCHEMA:G}=await import("near-api-js/lib/transaction"),{transactions:_,utils:C}=await import("near-api-js"),S=[_.transfer(v)];if(Y&&R)S.push(_.functionCall("memo",{memo:Y},BigInt(z),BigInt(R)));let Y1=await X.block({finality:"final"}),l=C.serialize.base_decode(Y1.header.hash),f1=_.createTransaction(B,N,q,k,S,l),U1=C.serialize.serialize(G.Transaction,f1);return{serialized:Buffer.from(U1).toString("base64"),publicKey:N.toString(),details:{signerId:await F(),nonce:k,blockHash:C.serialize.base_encode(l)}}}async function W1(x){let{accountId:q}=x,J=await h(X,q),z=(await X.query({request_type:"view_access_key",finality:"final",account_id:q,public_key:J.toString()})).nonce+1,{SCHEMA:R}=await import("near-api-js/lib/transaction"),{transactions:H,utils:B}=await import("near-api-js"),N=await X.block({finality:"final"}),O=B.serialize.base_decode(N.header.hash),k=[H.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],v=H.createTransaction(q,J,x.contractId,z,k,O),G=B.serialize.serialize(R.Transaction,v);return{serialized:Buffer.from(G).toString("base64"),publicKey:J.toString(),details:{signerId:q,receiverId:x.contractId,methodName:x.methodName,nonce:z,blockHash:B.serialize.base_encode(O)}}}async function q1(x){if(!Z)throw new D("toolbox_near_no_signer");let[q,J]=await Z.signTransaction(x);return J}async function J1(x){return(await X.sendTransaction(x)).transaction.hash}async function Q1(x){if("assetValue"in x){let z=BigInt("115123062500")+BigInt("108059500000"),R=await Z1(),H=z*BigInt(R.toString());return y.from({chain:w.Near,value:H.toString(),fromBaseDecimal:P[w.Near]})}let q=Z?await j():void 0;return b(x,q)}async function Z1(){try{return await X.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function $1(x,q,J){if(!Z)throw new D("toolbox_near_no_signer");let Y=await j(),{utils:z}=await import("near-api-js"),R=z.format.parseNearAmount(J)||"0";return(await Y.createAccount(x,z.PublicKey.fromString(q),BigInt(R))).transaction.hash}async function A(x){try{if(!Z)throw new D("toolbox_near_no_signer");let{transactions:q}=await import("near-api-js"),{contractId:J,methodName:Y,args:z,deposit:R}=x,H=await j(),B=await b({methodName:Y,args:z||{},contractId:J}),N=q.functionCall(Y,z||{},B.getBaseValue("bigint"),BigInt(R||"0"));return(await H.signAndSendTransaction({receiverId:J,actions:[N]})).transaction.hash}catch(q){throw new D("toolbox_near_transfer_failed",{error:q})}}async function X1(x){let{createNearContract:q}=await import("../../chunk-kbnwrc5b.js"),J=await j();return q({account:J,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function z1(x){if(!Z)throw new D("toolbox_near_no_signer");if(x.actions.length===0)throw new D("toolbox_near_empty_batch");return(await(await j()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function L1(x){let q=await j();return T({contractId:x,account:q})}async function M1(x){try{let q=await j(x),J;try{let Y=await q.getBalance();J=y.from({chain:w.Near,value:Y,fromBaseDecimal:P[w.Near]})}catch{J=y.from({chain:w.Near,value:"0",fromBaseDecimal:P[w.Near]})}return[J]}catch(q){throw new D("toolbox_near_balance_failed",{error:q})}}async function b(x,q){let J=await L(x).when(d,()=>V.SIMPLE_TRANSFER).when(o,(H)=>e(H.methodName)).when(i,(H)=>t(H.actions)).when(n,()=>V.ACCOUNT_CREATION).when(c,()=>V.CONTRACT_DEPLOYMENT).when(s,(H)=>{if(!q)throw new D("toolbox_near_no_account");return H.customEstimator(q)}).otherwise(()=>{throw new D("toolbox_near_invalid_gas_params")}),Y=await g(),R=BigInt(J)*BigInt(1000000000000)*BigInt(Y);return y.from({chain:w.Near,value:R,fromBaseDecimal:P[w.Near]})}async function g(){try{return(await X.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:F,getPublicKey:async()=>Z?(await Z.getPublicKey()).toString():"",provider:X,transfer:a,createTransaction:x1,createContractFunctionCall:W1,estimateTransactionFee:Q1,broadcastTransaction:J1,signTransaction:q1,getBalance:M1,validateAddress:K,getSignerFromPhrase:(x)=>I(x),getSignerFromPrivateKey:u,callFunction:A,createSubAccount:$1,createContract:X1,executeBatchTransaction:z1,nep141:L1,getGasPrice:g,estimateGas:b}}export{K as validateNearAddress,D1 as tgasToGas,d as isSimpleTransfer,s as isCustomEstimator,c as isContractDeployment,o as isContractCall,i as isBatchTransaction,n as isAccountCreation,h1 as getNearToolbox,u as getNearSignerFromPrivateKey,I as getNearSignerFromPhrase,h as getFullAccessPublicKey,e as getContractMethodGas,j1 as gasToTGas,t as estimateBatchGas,E as createNearContract,T as createNEP141Token,V as GAS_COSTS};
1
+ import{a as E}from"../../chunk-kbnwrc5b.js";import{d as R,e as H}from"../../chunk-s47y8512.js";import{AssetValue as P,BaseDecimal as b,Chain as w,SKConfig as D1,SwapKitError as j}from"@swapkit/helpers";import{SwapKitError as U1,derivationPathToString as f1}from"@swapkit/helpers";import{KeyPairSigner as R1}from"near-api-js";async function G(W){try{let{validateAccountId:Q}=await import("near-sdk-js");return Q(W)}catch{let Q=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return W.length>=2&&W.length<=64&&Q.test(W)}}async function C(W){let{parseSeedPhrase:Q}=await import("near-seed-phrase"),{KeyPair:M}=await import("near-api-js"),z=W.index||0,Z=W.derivationPath?f1(W.derivationPath.slice(0,3)):`m/44'/397'/${z}'`,{secretKey:$}=Q(W.phrase,Z),X=M.fromString($);return u(X)}async function S(W){let{KeyPair:Q}=await import("near-api-js/lib/utils"),M=Q.fromString(W);return u(M)}class l extends R1{#x;constructor(W){super(W);this.#x=W}getAddress(){let W=this.#x.getPublicKey(),Q=Buffer.from(W.data).toString("hex");return Promise.resolve(Q)}}function u(W){return new l(W)}async function K(W,Q){let z=(await W.query({request_type:"view_access_key_list",finality:"final",account_id:Q})).keys.find((V)=>V.access_key.permission==="FullAccess");if(!z)throw new U1("toolbox_near_invalid_address");let{utils:Z}=await import("near-api-js"),$=Z.PublicKey.fromString(z.public_key),X=z.access_key.nonce||0;return{publicKey:$,nonce:X}}var D={SIMPLE_TRANSFER:"1",TOKEN_TRANSFER:"100",CONTRACT_CALL:"100",ACCOUNT_CREATION:"30",CONTRACT_DEPLOYMENT:"200",ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",STAKE:"10",STORAGE_DEPOSIT:"100"};function m(W){return"recipient"in W&&"amount"in W&&!("contractId"in W)}function d(W){return"contractId"in W&&"methodName"in W}function p(W){return"actions"in W}function o(W){return"newAccountId"in W}function i(W){return"contractCode"in W}function n(W){return"customEstimator"in W}function c(W){let Q=0;for(let M of W)switch(M.enum){case"transfer":Q+=Number(D.SIMPLE_TRANSFER);break;case"functionCall":Q+=Number(D.CONTRACT_CALL);break;case"createAccount":Q+=Number(D.ACCOUNT_CREATION);break;case"deployContract":Q+=Number(D.CONTRACT_DEPLOYMENT);break;case"addKey":Q+=Number(D.ACCESS_KEY_ADDITION);break;case"deleteKey":Q+=Number(D.ACCESS_KEY_DELETION);break;case"stake":Q+=Number(D.STAKE);break;default:Q+=Number(D.CONTRACT_CALL)}return Q.toString()}function s(W){if(W==="ft_transfer"||W==="ft_transfer_call")return D.TOKEN_TRANSFER;if(W==="storage_deposit")return D.STORAGE_DEPOSIT;return D.CONTRACT_CALL}function H1(W){return(BigInt(W)*BigInt(1000000000000)).toString()}function V1(W){return(BigInt(W)/BigInt(1000000000000)).toString()}var e="1250000000000000000000";async function T({contractId:W,account:Q}){let M=(await import("bn.js")).default,z=await E({account:Q,contractId:W,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"],changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"]}),Z=async($)=>{if(!await z.storage_balance_of({account_id:$})){let F=(await z.storage_balance_bounds())?.min||e;await z.storage_deposit({account_id:$},new M("100000000000000"),new M(F))}};return{transfer:async($,X,V)=>{return await Z($),z.ft_transfer({receiver_id:$,amount:X,memo:V},new M("100000000000000"),new M("1"))},transferCall:async($,X,V,F)=>{return await Z($),z.ft_transfer_call({receiver_id:$,amount:X,memo:F,msg:V},new M("100000000000000"),new M("1"))},balanceOf:($)=>z.ft_balance_of({account_id:$}),totalSupply:()=>z.ft_total_supply(),metadata:()=>z.ft_metadata(),storageBalanceOf:($)=>z.storage_balance_of({account_id:$}),storageDeposit:($,X)=>z.storage_deposit({account_id:$},new M("100000000000000"),new M(X||e)),ensureStorage:Z,contract:z}}async function K1(W){let{P:Q,match:M}=await import("ts-pattern"),{providers:z}=await import("near-api-js"),Z=await M(W).with({phrase:Q.string},async(x)=>{return await C(x)}).with({signer:Q.any},({signer:x})=>x).otherwise(()=>{return}),$=D1.get("rpcUrls")[w.Near],X=new z.JsonRpcProvider({url:$});async function V(x){let{Account:q}=await import("near-api-js"),J=x||await F();return new q(J,X,Z)}async function F(){if(!Z)throw new j("toolbox_near_no_signer");return await Z.getAddress()}async function t(x){if(!Z)throw new j("toolbox_near_no_signer");let{recipient:q,assetValue:J}=x;if(!G(q))throw new j("toolbox_near_invalid_address");let Y=await V();if(J.isGasAsset===!1){let L=J.address;if(!L)throw new j("toolbox_near_missing_contract_address");let f=J.getBaseValue("string");return I({contractId:L,methodName:"ft_transfer",args:{receiver_id:q,amount:f,memo:x.memo}})}try{let L=J.getBaseValue("string");return(await Y.transfer({receiverId:q,amount:L})).transaction.hash}catch(L){throw new j("toolbox_near_transfer_failed",{error:L})}}async function r(x){let{recipient:q,assetValue:J,memo:Y,feeRate:L,attachedDeposit:f,sender:U}=x,{publicKey:N,nonce:B}=await K(X,U),k=J.getBaseValue("bigint"),{SCHEMA:v}=await import("near-api-js/lib/transaction"),{transactions:O,utils:_}=await import("near-api-js"),A=[O.transfer(k)];if(Y&&f)A.push(O.functionCall("memo",{memo:Y},BigInt(L),BigInt(f)));let L1=await X.block({finality:"final"}),g=_.serialize.base_decode(L1.header.hash),M1=O.createTransaction(U,N,q,B,A,g),Y1=_.serialize.serialize(v.Transaction,M1);return{serialized:Buffer.from(Y1).toString("base64"),publicKey:N.toString(),details:{signerId:U,nonce:B,blockHash:_.serialize.base_encode(g)}}}async function a(x){let{sender:q}=x,{publicKey:J,nonce:Y}=await K(X,q),{SCHEMA:L}=await import("near-api-js/lib/transaction"),{transactions:f,utils:U}=await import("near-api-js"),N=await X.block({finality:"final"}),B=U.serialize.base_decode(N.header.hash),k=[f.functionCall(x.methodName,Buffer.from(JSON.stringify(x.args)),BigInt(x.gas),BigInt(x.attachedDeposit))],v=f.createTransaction(q,J,x.contractId,Y,k,B),O=U.serialize.serialize(L.Transaction,v);return{serialized:Buffer.from(O).toString("base64"),publicKey:J.toString(),details:{signerId:q,receiverId:x.contractId,methodName:x.methodName,nonce:Y,blockHash:U.serialize.base_encode(B)}}}async function x1(x){if(!Z)throw new j("toolbox_near_no_signer");let[q,J]=await Z.signTransaction(x);return J}async function W1(x){return(await X.sendTransaction(x)).transaction.hash}async function q1(x){if("assetValue"in x){let L=BigInt("115123062500")+BigInt("108059500000"),f=await J1(),U=L*BigInt(f.toString());return P.from({chain:w.Near,value:U.toString(),fromBaseDecimal:b[w.Near]})}let q=Z?await V():void 0;return y(x,q)}async function J1(){try{return await X.query({request_type:"call_function",finality:"final",account_id:"system",method_name:"gas_price",args_base64:""})}catch{return"100000000"}}async function Q1(x,q,J){if(!Z)throw new j("toolbox_near_no_signer");let Y=await V(),{utils:L}=await import("near-api-js"),f=L.format.parseNearAmount(J)||"0";return(await Y.createAccount(x,L.PublicKey.fromString(q),BigInt(f))).transaction.hash}async function I(x){try{if(!Z)throw new j("toolbox_near_no_signer");let{transactions:q}=await import("near-api-js"),{contractId:J,methodName:Y,args:L,deposit:f}=x,U=await V(),N=await y({methodName:Y,args:L||{},contractId:J}),B=q.functionCall(Y,L||{},N.getBaseValue("bigint"),BigInt(f||"0"));return(await U.signAndSendTransaction({receiverId:J,actions:[B]})).transaction.hash}catch(q){throw new j("toolbox_near_transfer_failed",{error:q})}}async function Z1(x){let{createNearContract:q}=await import("../../chunk-kbnwrc5b.js"),J=await V();return q({account:J,contractId:x.contractId,viewMethods:x.viewMethods,changeMethods:x.changeMethods})}async function $1(x){if(!Z)throw new j("toolbox_near_no_signer");if(x.actions.length===0)throw new j("toolbox_near_empty_batch");return(await(await V()).signAndSendTransaction({receiverId:x.receiverId,actions:x.actions})).transaction.hash}async function X1(x){let q=await V();return T({contractId:x,account:q})}async function z1(x){try{let q=await V(x),J;try{let Y=await q.getBalance();J=P.from({chain:w.Near,value:Y,fromBaseDecimal:b[w.Near]})}catch{J=P.from({chain:w.Near,value:"0",fromBaseDecimal:b[w.Near]})}return[J]}catch(q){throw new j("toolbox_near_balance_failed",{error:q})}}async function y(x,q){let J=await M(x).when(m,()=>D.SIMPLE_TRANSFER).when(d,(U)=>s(U.methodName)).when(p,(U)=>c(U.actions)).when(o,()=>D.ACCOUNT_CREATION).when(i,()=>D.CONTRACT_DEPLOYMENT).when(n,(U)=>{if(!q)throw new j("toolbox_near_no_account");return U.customEstimator(q)}).otherwise(()=>{throw new j("toolbox_near_invalid_gas_params")}),Y=await h(),f=BigInt(J)*BigInt(1000000000000)*BigInt(Y);return P.from({chain:w.Near,value:f,fromBaseDecimal:b[w.Near]})}async function h(){try{return(await X.gasPrice(null)).gas_price||"100000000"}catch(x){return"100000000"}}return{getAddress:F,getPublicKey:async()=>Z?(await Z.getPublicKey()).toString():"",provider:X,transfer:t,createTransaction:r,createContractFunctionCall:a,estimateTransactionFee:q1,broadcastTransaction:W1,signTransaction:x1,getBalance:z1,validateAddress:G,getSignerFromPhrase:(x)=>C(x),getSignerFromPrivateKey:S,callFunction:I,createSubAccount:Q1,createContract:Z1,executeBatchTransaction:$1,nep141:X1,getGasPrice:h,estimateGas:y}}export{G as validateNearAddress,H1 as tgasToGas,m as isSimpleTransfer,n as isCustomEstimator,i as isContractDeployment,d as isContractCall,p as isBatchTransaction,o as isAccountCreation,K1 as getNearToolbox,S as getNearSignerFromPrivateKey,C as getNearSignerFromPhrase,K as getFullAccessPublicKey,s as getContractMethodGas,V1 as gasToTGas,c as estimateBatchGas,E as createNearContract,T as createNEP141Token,D as GAS_COSTS};
2
2
 
3
- //# debugId=4D0E2F7A8548072664756E2164756E21
3
+ //# debugId=65F52263B10375B264756E2164756E21
@@ -2,12 +2,12 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/near/toolbox.ts", "../src/near/helpers/core.ts", "../src/near/helpers/gasEstimation.ts", "../src/near/helpers/nep141.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n BaseDecimal,\n Chain,\n type DerivationPathArray,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\nimport type { Account } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n validateNearAddress,\n} from \"./helpers\";\nimport {\n GAS_COSTS,\n estimateBatchGas,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams) {\n const { P, match } = await import(\"ts-pattern\");\n const { providers } = await import(\"near-api-js\");\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async (params) => {\n const signer = await getNearSignerFromPhrase(params);\n return signer;\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n const url = SKConfig.get(\"rpcUrls\")[Chain.Near];\n\n const provider = new providers.JsonRpcProvider({ url });\n\n async function getAccount(address?: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const { Account } = await import(\"near-api-js\");\n\n const _address = address || (await getAddress());\n\n const account = new Account(_address, provider, signer);\n\n return account;\n }\n\n async function getAddress() {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const address = await signer.getAddress();\n return address;\n }\n\n async function transfer(params: NearTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { recipient, assetValue } = params;\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const account = await getAccount();\n\n if (assetValue.isGasAsset === false) {\n // NEP-141 token transfer\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n const amount = assetValue.getBaseValue(\"string\");\n\n return callFunction({\n contractId,\n methodName: \"ft_transfer\",\n args: {\n receiver_id: recipient,\n amount,\n memo: params.memo,\n },\n });\n }\n\n try {\n const transferAmount = assetValue.getBaseValue(\"string\");\n\n const result = await account.transfer({\n receiverId: recipient,\n amount: transferAmount,\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender } = params;\n\n const signerId = sender || (await getAddress());\n const publicKey = await getFullAccessPublicKey(provider, signerId);\n\n const accessKey = await provider.query({\n request_type: \"view_access_key\",\n finality: \"final\",\n account_id: signerId,\n });\n\n const nonce = (accessKey as any).nonce + 1;\n\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(\n transactions.functionCall(\"memo\", { memo }, BigInt(gas), BigInt(attachedDeposit)),\n );\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const transaction = transactions.createTransaction(\n signerId,\n publicKey,\n recipient,\n nonce,\n txActions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: await getAddress(),\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function createContractFunctionCall(params: {\n accountId: string;\n contractId: string;\n methodName: string;\n args: any;\n gas: string;\n attachedDeposit: string;\n }) {\n const { accountId } = params;\n\n const publicKey = await getFullAccessPublicKey(provider, accountId);\n\n const accessKey = await provider.query({\n request_type: \"view_access_key\",\n finality: \"final\",\n account_id: accountId,\n public_key: publicKey.toString(),\n });\n const nonce = (accessKey as any).nonce + 1;\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const actions = [\n transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n ),\n ];\n\n const transaction = transactions.createTransaction(\n accountId,\n publicKey,\n params.contractId,\n nonce,\n actions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: accountId,\n receiverId: params.contractId,\n methodName: params.methodName,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function signTransaction(transaction: Transaction) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n // Use the new signer interface method\n const [_hash, signedTx] = await signer.signTransaction(transaction);\n return signedTx;\n }\n\n async function broadcastTransaction(signedTransaction: SignedTransaction) {\n const result = await provider.sendTransaction(signedTransaction);\n return result.transaction.hash;\n }\n\n async function estimateTransactionFee(params: NearTransferParams | NearGasEstimateParams) {\n if (\"assetValue\" in params) {\n const baseTransferCost = \"115123062500\"; // gas units for transfer\n const receiptCreationCost = \"108059500000\"; // gas units for receipt\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n // NEAR doesn't support fee multipliers - gas price is fixed by the network\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n\n return AssetValue.from({\n chain: Chain.Near,\n value: totalCostYocto.toString(),\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Handle new gas estimation params\n const account = signer ? await getAccount() : undefined;\n return estimateGas(params, account);\n }\n\n async function getCurrentGasPrice() {\n try {\n const result = await provider.query({\n request_type: \"call_function\",\n finality: \"final\",\n account_id: \"system\",\n method_name: \"gas_price\",\n args_base64: \"\",\n });\n\n return result;\n } catch {\n return \"100000000\"; // 0.0001 NEAR per Tgas\n }\n }\n\n async function createSubAccount(subAccountId: string, publicKey: string, initialBalance: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const account = await getAccount();\n const { utils } = await import(\"near-api-js\");\n\n const balanceInYocto = utils.format.parseNearAmount(initialBalance) || \"0\";\n\n const result = await account.createAccount(\n subAccountId,\n utils.PublicKey.fromString(publicKey),\n BigInt(balanceInYocto),\n );\n\n return result.transaction.hash;\n }\n\n async function callFunction(params: NearFunctionCallParams) {\n try {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { transactions } = await import(\"near-api-js\");\n\n const { contractId, methodName, args, deposit } = params;\n const account = await getAccount();\n\n const estimatedGas = await estimateGas({\n methodName,\n args: args || {},\n contractId,\n });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"0\"),\n );\n\n const result = await account.signAndSendTransaction({\n receiverId: contractId,\n actions: [functionAction],\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract(contractInterface: NearContractInterface) {\n const { createNearContract } = await import(\"./helpers/contractFactory\");\n const account = await getAccount();\n\n return createNearContract({\n account,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n changeMethods: contractInterface.changeMethods,\n });\n }\n\n async function executeBatchTransaction(batch: { receiverId: string; actions: any[] }) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n if (batch.actions.length === 0) {\n throw new SwapKitError(\"toolbox_near_empty_batch\");\n }\n\n const account = await getAccount();\n\n // Use account.signAndSendTransaction for batch operations\n const result = await account.signAndSendTransaction({\n receiverId: batch.receiverId,\n actions: batch.actions,\n });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ contractId, account });\n }\n\n async function getBalance(address: string) {\n try {\n const account = await getAccount(address);\n\n let nativeBalance: AssetValue;\n try {\n const value = await account.getBalance();\n\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n } catch {\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value: \"0\",\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // // Then, fetch token balances from API\n // let tokenBalances: AssetValue[] = [];\n // try {\n // const apiBalances = await SwapKitApi.getChainBalance({\n // chain: Chain.Near,\n // address,\n // scamFilter,\n // });\n\n // tokenBalances = apiBalances\n // .filter(({ identifier }) => identifier !== Chain.Near) // Filter out native NEAR\n // .map(({ identifier, value, decimal }) => {\n // return new AssetValue({\n // decimal: decimal || BaseDecimal[Chain.Near],\n // value,\n // identifier,\n // });\n // });\n // } catch (error) {\n // // If API fails, just return on-chain balance\n // console.warn(\"Failed to fetch token balances from API:\", error);\n // }\n\n // Merge native balance with token balances\n // return [nativeBalance, ...tokenBalances];\n return [nativeBalance];\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_balance_failed\", { error });\n }\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const gasInTGas = await match(params)\n .when(isSimpleTransfer, () => GAS_COSTS.SIMPLE_TRANSFER)\n .when(isContractCall, (p) => getContractMethodGas(p.methodName))\n .when(isBatchTransaction, (p) => estimateBatchGas(p.actions))\n .when(isAccountCreation, () => GAS_COSTS.ACCOUNT_CREATION)\n .when(isContractDeployment, () => GAS_COSTS.CONTRACT_DEPLOYMENT)\n .when(isCustomEstimator, (p) => {\n if (!account) {\n throw new SwapKitError(\"toolbox_near_no_account\");\n }\n return p.customEstimator(account);\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_near_invalid_gas_params\");\n });\n\n // Convert TGas to gas price in NEAR\n const gasPrice = await getGasPrice();\n const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12); // Convert TGas to gas units\n const costInYoctoNear = gasInUnits * BigInt(gasPrice);\n\n return AssetValue.from({\n chain: Chain.Near,\n value: costInYoctoNear,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Get current gas price from network\n async function getGasPrice() {\n try {\n const result = await provider.gasPrice(null);\n return result.gas_price || \"100000000\";\n } catch (_error) {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n getAddress,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n provider,\n transfer,\n createTransaction,\n createContractFunctionCall,\n estimateTransactionFee,\n broadcastTransaction,\n signTransaction,\n getBalance,\n validateAddress: validateNearAddress,\n getSignerFromPhrase: (params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n }) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n callFunction,\n createSubAccount,\n createContract,\n executeBatchTransaction,\n nep141,\n getGasPrice,\n estimateGas,\n };\n}\n",
6
- "import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, SwapKitError, derivationPathToString } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function validateNearAddress(address: string) {\n // Use the official NEAR SDK validation function if available\n try {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return validateAccountId(address);\n } catch {\n const ACCOUNT_ID_REGEX = /^(([a-z\\d]+[-_])*[a-z\\d]+\\.)*([a-z\\d]+[-_])*[a-z\\d]+$/;\n\n return address.length >= 2 && address.length <= 64 && ACCOUNT_ID_REGEX.test(address);\n }\n}\n\nexport async function getNearSignerFromPhrase(params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n}) {\n const { parseSeedPhrase } = await import(\"near-seed-phrase\");\n const { KeyPair } = await import(\"near-api-js\");\n\n // Handle derivation path logic here\n // NEAR uses a 3-level derivation path: m/44'/397'/index'\n const index = params.index || 0;\n const derivationPath = params.derivationPath\n ? derivationPathToString(params.derivationPath.slice(0, 3) as [number, number, number])\n : `m/44'/397'/${index}'`;\n\n const { secretKey } = parseSeedPhrase(params.phrase, derivationPath);\n const keyPair = KeyPair.fromString(secretKey as any);\n\n return createNearSignerFromKeyPair(keyPair);\n}\n\nexport async function getNearSignerFromPrivateKey(privateKey: string) {\n const { KeyPair } = await import(\"near-api-js/lib/utils\");\n const keyPair = KeyPair.fromString(privateKey as any);\n return createNearSignerFromKeyPair(keyPair);\n}\n\nclass SKKeyPairSigner extends KeyPairSigner {\n #keyPair: KeyPair;\n\n constructor(keyPair: KeyPair) {\n super(keyPair);\n this.#keyPair = keyPair;\n }\n\n getAddress(): Promise<string> {\n // For implicit accounts, derive account ID from public key\n // NEAR implicit accounts use hex representation of the public key\n const publicKey = this.#keyPair.getPublicKey();\n const hexAddress = Buffer.from(publicKey.data).toString(\"hex\");\n return Promise.resolve(hexAddress);\n }\n}\n\nfunction createNearSignerFromKeyPair(keyPair: KeyPair): NearSigner {\n const keyPairSigner = new SKKeyPairSigner(keyPair);\n\n return keyPairSigner;\n}\n\nexport async function getFullAccessPublicKey(provider: Provider, accountId: string) {\n // Get the first full access key for the account\n const response = await provider.query({\n request_type: \"view_access_key_list\",\n finality: \"final\",\n account_id: accountId,\n });\n\n const fullAccessKey = (response as any).keys.find(\n (key: any) => key.access_key.permission === \"FullAccess\",\n );\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const { utils } = await import(\"near-api-js\");\n return utils.PublicKey.fromString(fullAccessKey.public_key);\n}\n",
5
+ "import {\n AssetValue,\n BaseDecimal,\n Chain,\n type DerivationPathArray,\n SKConfig,\n SwapKitError,\n} from \"@swapkit/helpers\";\nimport type { Account } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n validateNearAddress,\n} from \"./helpers\";\nimport {\n GAS_COSTS,\n estimateBatchGas,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams) {\n const { P, match } = await import(\"ts-pattern\");\n const { providers } = await import(\"near-api-js\");\n const signer = await match(toolboxParams)\n .with({ phrase: P.string }, async (params) => {\n const signer = await getNearSignerFromPhrase(params);\n return signer;\n })\n .with({ signer: P.any }, ({ signer }) => signer)\n .otherwise(() => undefined);\n\n const url = SKConfig.get(\"rpcUrls\")[Chain.Near];\n\n const provider = new providers.JsonRpcProvider({ url });\n\n async function getAccount(address?: string) {\n const { Account } = await import(\"near-api-js\");\n\n const _address = address || (await getAddress());\n\n const account = new Account(_address, provider, signer);\n\n return account;\n }\n\n async function getAddress() {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n const address = await signer.getAddress();\n return address;\n }\n\n async function transfer(params: NearTransferParams) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { recipient, assetValue } = params;\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const account = await getAccount();\n\n if (assetValue.isGasAsset === false) {\n // NEP-141 token transfer\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n const amount = assetValue.getBaseValue(\"string\");\n\n return callFunction({\n contractId,\n methodName: \"ft_transfer\",\n args: {\n receiver_id: recipient,\n amount,\n memo: params.memo,\n },\n });\n }\n\n try {\n const transferAmount = assetValue.getBaseValue(\"string\");\n\n const result = await account.transfer({\n receiverId: recipient,\n amount: transferAmount,\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender: signerId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(\n transactions.functionCall(\"memo\", { memo }, BigInt(gas), BigInt(attachedDeposit)),\n );\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const transaction = transactions.createTransaction(\n signerId,\n publicKey,\n recipient,\n nonce,\n txActions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function createContractFunctionCall(params: {\n sender: string;\n contractId: string;\n methodName: string;\n args: any;\n gas: string;\n attachedDeposit: string;\n }) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { transactions, utils } = await import(\"near-api-js\");\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n const actions = [\n transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n ),\n ];\n\n const transaction = transactions.createTransaction(\n accountId,\n publicKey,\n params.contractId,\n nonce,\n actions,\n blockHash,\n );\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n const serializedBase64 = Buffer.from(serializedTx).toString(\"base64\");\n\n return {\n serialized: serializedBase64,\n publicKey: publicKey.toString(),\n details: {\n signerId: accountId,\n receiverId: params.contractId,\n methodName: params.methodName,\n nonce: nonce,\n blockHash: utils.serialize.base_encode(blockHash),\n },\n };\n }\n\n async function signTransaction(transaction: Transaction) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n // Use the new signer interface method\n const [_hash, signedTx] = await signer.signTransaction(transaction);\n return signedTx;\n }\n\n async function broadcastTransaction(signedTransaction: SignedTransaction) {\n const result = await provider.sendTransaction(signedTransaction);\n return result.transaction.hash;\n }\n\n async function estimateTransactionFee(params: NearTransferParams | NearGasEstimateParams) {\n if (\"assetValue\" in params) {\n const baseTransferCost = \"115123062500\"; // gas units for transfer\n const receiptCreationCost = \"108059500000\"; // gas units for receipt\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n // NEAR doesn't support fee multipliers - gas price is fixed by the network\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n\n return AssetValue.from({\n chain: Chain.Near,\n value: totalCostYocto.toString(),\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Handle new gas estimation params\n const account = signer ? await getAccount() : undefined;\n return estimateGas(params, account);\n }\n\n async function getCurrentGasPrice() {\n try {\n const result = await provider.query({\n request_type: \"call_function\",\n finality: \"final\",\n account_id: \"system\",\n method_name: \"gas_price\",\n args_base64: \"\",\n });\n\n return result;\n } catch {\n return \"100000000\"; // 0.0001 NEAR per Tgas\n }\n }\n\n async function createSubAccount(subAccountId: string, publicKey: string, initialBalance: string) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const account = await getAccount();\n const { utils } = await import(\"near-api-js\");\n\n const balanceInYocto = utils.format.parseNearAmount(initialBalance) || \"0\";\n\n const result = await account.createAccount(\n subAccountId,\n utils.PublicKey.fromString(publicKey),\n BigInt(balanceInYocto),\n );\n\n return result.transaction.hash;\n }\n\n async function callFunction(params: NearFunctionCallParams) {\n try {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n const { transactions } = await import(\"near-api-js\");\n\n const { contractId, methodName, args, deposit } = params;\n const account = await getAccount();\n\n const estimatedGas = await estimateGas({\n methodName,\n args: args || {},\n contractId,\n });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"0\"),\n );\n\n const result = await account.signAndSendTransaction({\n receiverId: contractId,\n actions: [functionAction],\n });\n\n return result.transaction.hash;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract(contractInterface: NearContractInterface) {\n const { createNearContract } = await import(\"./helpers/contractFactory\");\n const account = await getAccount();\n\n return createNearContract({\n account,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n changeMethods: contractInterface.changeMethods,\n });\n }\n\n async function executeBatchTransaction(batch: { receiverId: string; actions: any[] }) {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\n if (batch.actions.length === 0) {\n throw new SwapKitError(\"toolbox_near_empty_batch\");\n }\n\n const account = await getAccount();\n\n // Use account.signAndSendTransaction for batch operations\n const result = await account.signAndSendTransaction({\n receiverId: batch.receiverId,\n actions: batch.actions,\n });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ contractId, account });\n }\n\n async function getBalance(address: string) {\n try {\n const account = await getAccount(address);\n\n let nativeBalance: AssetValue;\n try {\n const value = await account.getBalance();\n\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n } catch {\n nativeBalance = AssetValue.from({\n chain: Chain.Near,\n value: \"0\",\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // // Then, fetch token balances from API\n // let tokenBalances: AssetValue[] = [];\n // try {\n // const apiBalances = await SwapKitApi.getChainBalance({\n // chain: Chain.Near,\n // address,\n // scamFilter,\n // });\n\n // tokenBalances = apiBalances\n // .filter(({ identifier }) => identifier !== Chain.Near) // Filter out native NEAR\n // .map(({ identifier, value, decimal }) => {\n // return new AssetValue({\n // decimal: decimal || BaseDecimal[Chain.Near],\n // value,\n // identifier,\n // });\n // });\n // } catch (error) {\n // // If API fails, just return on-chain balance\n // console.warn(\"Failed to fetch token balances from API:\", error);\n // }\n\n // Merge native balance with token balances\n // return [nativeBalance, ...tokenBalances];\n return [nativeBalance];\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_balance_failed\", { error });\n }\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const gasInTGas = await match(params)\n .when(isSimpleTransfer, () => GAS_COSTS.SIMPLE_TRANSFER)\n .when(isContractCall, (p) => getContractMethodGas(p.methodName))\n .when(isBatchTransaction, (p) => estimateBatchGas(p.actions))\n .when(isAccountCreation, () => GAS_COSTS.ACCOUNT_CREATION)\n .when(isContractDeployment, () => GAS_COSTS.CONTRACT_DEPLOYMENT)\n .when(isCustomEstimator, (p) => {\n if (!account) {\n throw new SwapKitError(\"toolbox_near_no_account\");\n }\n return p.customEstimator(account);\n })\n .otherwise(() => {\n throw new SwapKitError(\"toolbox_near_invalid_gas_params\");\n });\n\n // Convert TGas to gas price in NEAR\n const gasPrice = await getGasPrice();\n const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12); // Convert TGas to gas units\n const costInYoctoNear = gasInUnits * BigInt(gasPrice);\n\n return AssetValue.from({\n chain: Chain.Near,\n value: costInYoctoNear,\n fromBaseDecimal: BaseDecimal[Chain.Near],\n });\n }\n\n // Get current gas price from network\n async function getGasPrice() {\n try {\n const result = await provider.gasPrice(null);\n return result.gas_price || \"100000000\";\n } catch (_error) {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n getAddress,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n provider,\n transfer,\n createTransaction,\n createContractFunctionCall,\n estimateTransactionFee,\n broadcastTransaction,\n signTransaction,\n getBalance,\n validateAddress: validateNearAddress,\n getSignerFromPhrase: (params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n }) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n callFunction,\n createSubAccount,\n createContract,\n executeBatchTransaction,\n nep141,\n getGasPrice,\n estimateGas,\n };\n}\n",
6
+ "import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, SwapKitError, derivationPathToString } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function validateNearAddress(address: string) {\n // Use the official NEAR SDK validation function if available\n try {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return validateAccountId(address);\n } catch {\n const ACCOUNT_ID_REGEX = /^(([a-z\\d]+[-_])*[a-z\\d]+\\.)*([a-z\\d]+[-_])*[a-z\\d]+$/;\n\n return address.length >= 2 && address.length <= 64 && ACCOUNT_ID_REGEX.test(address);\n }\n}\n\nexport async function getNearSignerFromPhrase(params: {\n phrase: string;\n derivationPath?: DerivationPathArray;\n index?: number;\n}) {\n const { parseSeedPhrase } = await import(\"near-seed-phrase\");\n const { KeyPair } = await import(\"near-api-js\");\n\n // Handle derivation path logic here\n // NEAR uses a 3-level derivation path: m/44'/397'/index'\n const index = params.index || 0;\n const derivationPath = params.derivationPath\n ? derivationPathToString(params.derivationPath.slice(0, 3) as [number, number, number])\n : `m/44'/397'/${index}'`;\n\n const { secretKey } = parseSeedPhrase(params.phrase, derivationPath);\n const keyPair = KeyPair.fromString(secretKey as any);\n\n return createNearSignerFromKeyPair(keyPair);\n}\n\nexport async function getNearSignerFromPrivateKey(privateKey: string) {\n const { KeyPair } = await import(\"near-api-js/lib/utils\");\n const keyPair = KeyPair.fromString(privateKey as any);\n return createNearSignerFromKeyPair(keyPair);\n}\n\nclass SKKeyPairSigner extends KeyPairSigner {\n #keyPair: KeyPair;\n\n constructor(keyPair: KeyPair) {\n super(keyPair);\n this.#keyPair = keyPair;\n }\n\n getAddress(): Promise<string> {\n // For implicit accounts, derive account ID from public key\n // NEAR implicit accounts use hex representation of the public key\n const publicKey = this.#keyPair.getPublicKey();\n const hexAddress = Buffer.from(publicKey.data).toString(\"hex\");\n return Promise.resolve(hexAddress);\n }\n}\n\nfunction createNearSignerFromKeyPair(keyPair: KeyPair): NearSigner {\n const keyPairSigner = new SKKeyPairSigner(keyPair);\n\n return keyPairSigner;\n}\n\nexport async function getFullAccessPublicKey(provider: Provider, accountId: string) {\n // Get the first full access key for the account\n const response = await provider.query({\n request_type: \"view_access_key_list\",\n finality: \"final\",\n account_id: accountId,\n });\n\n const fullAccessKey = (response as any).keys.find(\n (key: any) => key.access_key.permission === \"FullAccess\",\n );\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_invalid_address\");\n }\n\n const { utils } = await import(\"near-api-js\");\n const publicKey = utils.PublicKey.fromString(fullAccessKey.public_key);\n const nonce = (fullAccessKey.access_key.nonce as number) || 0;\n\n return { publicKey, nonce };\n}\n",
7
7
  "import type { Account } from \"near-api-js\";\nimport type { NearGasEstimateParams } from \"../types/contract\";\n\n// Gas constants (in TGas - 10^12 gas units)\nexport const GAS_COSTS = {\n SIMPLE_TRANSFER: \"1\", // 1 TGas\n TOKEN_TRANSFER: \"100\", // 100 TGas\n CONTRACT_CALL: \"100\", // 100 TGas base\n ACCOUNT_CREATION: \"30\", // 30 TGas\n CONTRACT_DEPLOYMENT: \"200\", // 200 TGas\n ACCESS_KEY_ADDITION: \"5\", // 5 TGas\n ACCESS_KEY_DELETION: \"5\", // 5 TGas\n STAKE: \"10\", // 10 TGas\n STORAGE_DEPOSIT: \"100\", // 100 TGas\n} as const;\n\n// Type guards for discriminated union\nexport function isSimpleTransfer(\n params: NearGasEstimateParams,\n): params is { recipient: string; amount: string } {\n return \"recipient\" in params && \"amount\" in params && !(\"contractId\" in params);\n}\n\nexport function isContractCall(params: NearGasEstimateParams): params is {\n contractId: string;\n methodName: string;\n args?: Record<string, any>;\n attachedDeposit?: string;\n} {\n return \"contractId\" in params && \"methodName\" in params;\n}\n\nexport function isBatchTransaction(params: NearGasEstimateParams): params is { actions: any[] } {\n return \"actions\" in params;\n}\n\nexport function isAccountCreation(params: NearGasEstimateParams): params is {\n newAccountId: string;\n publicKey?: string;\n} {\n return \"newAccountId\" in params;\n}\n\nexport function isContractDeployment(\n params: NearGasEstimateParams,\n): params is { contractCode: Uint8Array } {\n return \"contractCode\" in params;\n}\n\nexport function isCustomEstimator(params: NearGasEstimateParams): params is {\n customEstimator: (account: Account) => Promise<string>;\n} {\n return \"customEstimator\" in params;\n}\n\n// Helper function to estimate gas for batch actions\nexport function estimateBatchGas(actions: any[]) {\n let totalGas = 0;\n\n for (const action of actions) {\n switch (action.enum) {\n case \"transfer\":\n totalGas += Number(GAS_COSTS.SIMPLE_TRANSFER);\n break;\n case \"functionCall\":\n totalGas += Number(GAS_COSTS.CONTRACT_CALL);\n break;\n case \"createAccount\":\n totalGas += Number(GAS_COSTS.ACCOUNT_CREATION);\n break;\n case \"deployContract\":\n totalGas += Number(GAS_COSTS.CONTRACT_DEPLOYMENT);\n break;\n case \"addKey\":\n totalGas += Number(GAS_COSTS.ACCESS_KEY_ADDITION);\n break;\n case \"deleteKey\":\n totalGas += Number(GAS_COSTS.ACCESS_KEY_DELETION);\n break;\n case \"stake\":\n totalGas += Number(GAS_COSTS.STAKE);\n break;\n default:\n totalGas += Number(GAS_COSTS.CONTRACT_CALL);\n }\n }\n\n return totalGas.toString();\n}\n\n// Helper function to get gas cost for contract methods\nexport function getContractMethodGas(methodName: string) {\n if (methodName === \"ft_transfer\" || methodName === \"ft_transfer_call\") {\n return GAS_COSTS.TOKEN_TRANSFER;\n }\n if (methodName === \"storage_deposit\") {\n return GAS_COSTS.STORAGE_DEPOSIT;\n }\n return GAS_COSTS.CONTRACT_CALL;\n}\n\n// Convert TGas string to gas units\nexport function tgasToGas(tgas: string): string {\n return (BigInt(tgas) * BigInt(10 ** 12)).toString();\n}\n\n// Convert gas units to TGas\nexport function gasToTGas(gas: string): string {\n return (BigInt(gas) / BigInt(10 ** 12)).toString();\n}\n",
8
8
  "import type { Account, Contract } from \"near-api-js\";\nimport { createNearContract } from \"./contractFactory\";\n\nconst DEFAULT_STORAGE_DEPOSIT = \"1250000000000000000000\"; // 0.00125 NEAR\n\n// Define NEP-141 contract interface\ninterface NEP141Contract extends Contract {\n // View methods\n ft_balance_of(args: { account_id: string }): Promise<string>;\n ft_total_supply(): Promise<string>;\n ft_metadata(): Promise<any>;\n storage_balance_of(args: { account_id: string }): Promise<any>;\n storage_balance_bounds(): Promise<any>;\n\n // Change methods\n ft_transfer(args: any, gas: any, deposit: any): Promise<any>;\n ft_transfer_call(args: any, gas: any, deposit: any): Promise<any>;\n storage_deposit(args: any, gas: any, deposit: any): Promise<any>;\n storage_withdraw(args: any, gas: any, deposit: any): Promise<any>;\n storage_unregister(force?: boolean, gas?: any): Promise<any>;\n}\n\nexport async function createNEP141Token({\n contractId,\n account,\n}: {\n contractId: string;\n account: Account;\n}) {\n const BN = (await import(\"bn.js\")).default;\n\n const contract = await createNearContract<NEP141Contract>({\n account,\n contractId,\n viewMethods: [\n \"ft_balance_of\",\n \"ft_total_supply\",\n \"ft_metadata\",\n \"storage_balance_of\",\n \"storage_balance_bounds\",\n ],\n changeMethods: [\n \"ft_transfer\",\n \"ft_transfer_call\",\n \"storage_deposit\",\n \"storage_withdraw\",\n \"storage_unregister\",\n ],\n });\n\n // Helper to ensure storage before transfers\n const ensureStorageFor = async (accountId: string) => {\n const balance = await contract.storage_balance_of({ account_id: accountId });\n if (!balance) {\n // Get minimum storage requirement\n const bounds = await contract.storage_balance_bounds();\n const deposit = bounds?.min || DEFAULT_STORAGE_DEPOSIT;\n\n await contract.storage_deposit(\n { account_id: accountId },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(deposit),\n );\n }\n };\n\n return {\n transfer: async (receiverId: string, amount: string, memo?: string) => {\n // Ensure recipient has storage before transfer\n await ensureStorageFor(receiverId);\n\n return contract.ft_transfer(\n { receiver_id: receiverId, amount, memo },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n\n transferCall: async (receiverId: string, amount: string, msg: string, memo?: string) => {\n // Ensure recipient has storage before transfer\n await ensureStorageFor(receiverId);\n\n return contract.ft_transfer_call(\n { receiver_id: receiverId, amount, memo, msg },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n\n balanceOf: (accountId: string) => contract.ft_balance_of({ account_id: accountId }),\n\n totalSupply: () => contract.ft_total_supply(),\n\n metadata: () => contract.ft_metadata(),\n\n storageBalanceOf: (accountId: string) => contract.storage_balance_of({ account_id: accountId }),\n\n storageDeposit: (accountId?: string, amount?: string) =>\n contract.storage_deposit(\n { account_id: accountId },\n new BN(\"100000000000000\"),\n new BN(amount || DEFAULT_STORAGE_DEPOSIT),\n ),\n\n ensureStorage: ensureStorageFor,\n\n // Raw contract access for advanced use cases\n contract,\n };\n}\n"
9
9
  ],
10
- "mappings": "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",
11
- "debugId": "4D0E2F7A8548072664756E2164756E21",
10
+ "mappings": "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",
11
+ "debugId": "65F52263B10375B264756E2164756E21",
12
12
  "names": []
13
13
  }
@@ -1,3 +1,3 @@
1
- var K={};g(K,{trc20ABI:()=>B,getTronPrivateKeyFromMnemonic:()=>m,getTronAddressValidator:()=>x,createTronToolbox:()=>A});module.exports=b(K);var y=require("@swapkit/helpers"),u=require("tronweb"),$=require("ts-pattern");var B=[{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"success",type:"bool"}],type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],type:"function"}];async function x(){let{TronWeb:z}=await import("tronweb");return(Q)=>z.isAddress(Q)}async function m({phrase:z,derivationPath:Q,index:j}){let f=Q||y.derivationPathToString(y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:j||0})),{HDKey:Y}=await import("@scure/bip32"),{mnemonicToSeedSync:I}=await import("@scure/bip39"),_=I(z),R=Y.fromMasterSeed(_).derive(f);if(!R.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");return Buffer.from(R.privateKey).toString("hex")}async function p({phrase:z,derivationPath:Q}){let{HDKey:j}=await import("@scure/bip32"),{mnemonicToSeedSync:f}=await import("@scure/bip39"),Y=f(z),_=j.fromMasterSeed(Y).derive(Q);if(!_.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");let O=Buffer.from(_.privateKey).toString("hex"),R=new u.TronWeb({fullHost:y.SKConfig.get("rpcUrls")[y.Chain.Tron],privateKey:O}),Z=R.address.fromPrivateKey(O);return{getAddress:()=>Promise.resolve(typeof Z==="string"?Z:""),signTransaction:async(H)=>{return await R.trx.sign(H,O)}}}var A=async(z={})=>{let Q=y.SKConfig.get("rpcUrls")[y.Chain.Tron],j=void 0,f=new u.TronWeb({fullHost:Q,headers:void 0}),Y="index"in z?z.index||0:0,I=y.derivationPathToString("derivationPath"in z&&z.derivationPath?z.derivationPath:y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:Y})),_=await $.match(z).with({phrase:$.P.string},async({phrase:T})=>p({phrase:T,derivationPath:I})).with({signer:$.P.any},({signer:T})=>Promise.resolve(T)).otherwise(()=>Promise.resolve(void 0)),O=async()=>{if(!_)throw new y.SwapKitError("toolbox_tron_no_signer");return await _.getAddress()},R=(T)=>{return f.isAddress(T)},Z=(T)=>{return T.address},H=()=>{return 1e8};return{tronWeb:f,getAddress:O,validateAddress:R,getBalance:async(T,q=!0)=>{let{getBalance:M}=await import("../../chunk-5yxc1e69.js");try{let G=await M(y.Chain.Tron)(T,q);if(G.length>0)return G;let J=await f.trx.getBalance(T);return[y.AssetValue.from({chain:y.Chain.Tron,value:J,fromBaseDecimal:6})]}catch(G){y.warnOnce(!0,`Failed to get Tron balance for ${T}: ${G instanceof Error?G.message:G}`);try{let J=await f.trx.getBalance(T);return[y.AssetValue.from({chain:y.Chain.Tron,value:J,fromBaseDecimal:6})]}catch(J){return y.warnOnce(!0,`Failed to get native TRX balance for ${T}: ${J instanceof Error?J.message:J}`),[]}}},transfer:async({recipient:T,assetValue:q,memo:M})=>{if(!_)throw new y.SwapKitError("toolbox_tron_no_signer");let G=await O();if(q.isGasAsset){let D=await f.transactionBuilder.sendTrx(T,q.getBaseValue("number"),G);if(M){let P=await f.transactionBuilder.addUpdateData(D,M,"utf8"),w=await _.signTransaction(P),{txid:v}=await f.trx.sendRawTransaction(w);return v}let F=await _.signTransaction(D),{txid:E}=await f.trx.sendRawTransaction(F);return E}let k=Z(q);if(!k)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:q.toString()});let L=H(),N=await f.contract(B,k);if(!N.methods?.transfer)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");let U=await N.methods.transfer(T,q.getBaseValue("string")).send({from:G,feeLimit:L,callValue:0});if(!U)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");return U},estimateTransactionFee:({assetValue:T})=>{if(T.isGasAsset)return y.AssetValue.from({chain:y.Chain.Tron,value:1});return y.AssetValue.from({chain:y.Chain.Tron,value:10})},createTransaction:async(T)=>{if(!_)throw new y.SwapKitError("toolbox_tron_no_signer");let{recipient:q,assetValue:M,memo:G}=T,J=await O();if(M.isGasAsset){let F=await f.transactionBuilder.sendTrx(q,M.getBaseValue("number"),J);if(G)return f.transactionBuilder.addUpdateData(F,G,"utf8");return F}let L=Z(M);if(!L)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:M.toString()});let N="transfer(address,uint256)",U=[{type:"address",value:q},{type:"uint256",value:M.getBaseValue("string")}];return(await f.transactionBuilder.triggerSmartContract(L,N,{},U,J)).transaction},signTransaction:async(T)=>{if(!_)throw new y.SwapKitError("toolbox_tron_no_signer");return await _.signTransaction(T)},broadcastTransaction:async(T)=>{let{txid:q}=await f.trx.sendRawTransaction(T);return q}}};
1
+ var V={};b(V,{trc20ABI:()=>H,getTronPrivateKeyFromMnemonic:()=>A,getTronAddressValidator:()=>x,createTronToolbox:()=>C});module.exports=W(V);var y=require("@swapkit/helpers"),Z=require("ts-pattern");var H=[{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"success",type:"bool"}],type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],type:"function"}];async function x(){let{TronWeb:z}=require("tronweb");return(R)=>{return z.isAddress(R)}}async function A({phrase:z,derivationPath:R,index:T}){let $=R||y.derivationPathToString(y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:T||0})),{HDKey:_}=await import("@scure/bip32"),{mnemonicToSeedSync:X}=await import("@scure/bip39"),j=X(z),O=_.fromMasterSeed(j).derive($);if(!O.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");return Buffer.from(O.privateKey).toString("hex")}async function S({phrase:z,derivationPath:R}){let{HDKey:T}=await import("@scure/bip32"),{mnemonicToSeedSync:$}=await import("@scure/bip39"),{TronWeb:_}=require("tronweb"),X=$(z),J=T.fromMasterSeed(X).derive(R);if(!J.privateKey)throw new y.SwapKitError("toolbox_tron_no_signer");let O=Buffer.from(J.privateKey).toString("hex"),I=new _({fullHost:y.SKConfig.get("rpcUrls")[y.Chain.Tron],privateKey:O}),L=I.address.fromPrivateKey(O);return{getAddress:()=>Promise.resolve(typeof L==="string"?L:""),signTransaction:async(k)=>{return await I.trx.sign(k,O)}}}var C=async(z={})=>{let{TronWeb:R}=require("tronweb"),T=y.SKConfig.get("rpcUrls")[y.Chain.Tron],$=void 0,_=new R({fullHost:T,headers:void 0}),X="index"in z?z.index||0:0,j=y.derivationPathToString("derivationPath"in z&&z.derivationPath?z.derivationPath:y.updateDerivationPath(y.NetworkDerivationPath[y.Chain.Tron],{index:X})),J=await Z.match(z).with({phrase:Z.P.string},async({phrase:f})=>S({phrase:f,derivationPath:j})).with({signer:Z.P.any},({signer:f})=>Promise.resolve(f)).otherwise(()=>Promise.resolve(void 0)),O=async()=>{if(!J)throw new y.SwapKitError("toolbox_tron_no_signer");return await J.getAddress()},I=()=>{return 1e8},L=async(f,q=!0)=>{let{getBalance:Q}=await import("../../chunk-5yxc1e69.js");try{let G=await Q(y.Chain.Tron)(f,q);if(G.length>0)return G;let M=await _.trx.getBalance(f);return[y.AssetValue.from({chain:y.Chain.Tron,value:M,fromBaseDecimal:6})]}catch(G){y.warnOnce(!0,`Failed to get Tron balance for ${f}: ${G instanceof Error?G.message:G}`);try{let M=await _.trx.getBalance(f);return[y.AssetValue.from({chain:y.Chain.Tron,value:M,fromBaseDecimal:6})]}catch(M){return y.warnOnce(!0,`Failed to get native TRX balance for ${f}: ${M instanceof Error?M.message:M}`),[]}}},k=async({recipient:f,assetValue:q,memo:Q})=>{if(!J)throw new y.SwapKitError("toolbox_tron_no_signer");let G=await O();if(q.isGasAsset){let D=await _.transactionBuilder.sendTrx(f,q.getBaseValue("number"),G);if(Q){let p=await _.transactionBuilder.addUpdateData(D,Q,"utf8"),K=await J.signTransaction(p),{txid:g}=await _.trx.sendRawTransaction(K);return g}let F=await J.signTransaction(D),{txid:w}=await _.trx.sendRawTransaction(F);return w}let B=q.address;if(!B)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:q.toString()});let N=I(),U=await _.contract(H,B);if(!U.methods?.transfer)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");let u=await U.methods.transfer(f,q.getBaseValue("string")).send({from:G,feeLimit:N,callValue:0});if(!u)throw new y.SwapKitError("toolbox_tron_token_transfer_failed");return u},m=({assetValue:f})=>{if(f.isGasAsset)return y.AssetValue.from({chain:y.Chain.Tron,value:1});return y.AssetValue.from({chain:y.Chain.Tron,value:10})},E=async(f)=>{let{recipient:q,assetValue:Q,memo:G}=f,M=await O();if(Q.isGasAsset){let F=await _.transactionBuilder.sendTrx(q,Q.getBaseValue("number"),M);if(G)return _.transactionBuilder.addUpdateData(F,G,"utf8");return F}let N=Q.address;if(!N)throw new y.SwapKitError("toolbox_tron_invalid_token_identifier",{identifier:Q.toString()});let U="transfer(address,uint256)",u=[{type:"address",value:q},{type:"uint256",value:Q.getBaseValue("string")}];return(await _.transactionBuilder.triggerSmartContract(N,U,{},u,M)).transaction},P=async(f)=>{if(!J)throw new y.SwapKitError("toolbox_tron_no_signer");return await J.signTransaction(f)},v=async(f)=>{let{txid:q}=await _.trx.sendRawTransaction(f);return q};return{tronWeb:_,getAddress:O,validateAddress:await x(),getBalance:L,transfer:k,estimateTransactionFee:m,createTransaction:E,signTransaction:P,broadcastTransaction:v}};
2
2
 
3
- //# debugId=DB39FF97B3BDD00964756E2164756E21
3
+ //# debugId=DA4D4F666437324964756E2164756E21
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/tron/toolbox.ts", "../src/tron/helpers/trc20.abi.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { TronWeb } from \"tronweb\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport type {\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nexport async function getTronAddressValidator() {\n const { TronWeb } = await import(\"tronweb\");\n return (address: string) => TronWeb.isAddress(address);\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index: index || 0 }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}): Promise<TronSigner> {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const validateAddress = (address: string) => {\n return tronWeb.isAddress(address);\n };\n\n const getContractAddress = (assetValue: AssetValue) => {\n // Use asset.address for TRC20 contracts instead of parsing string\n return assetValue.address;\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n const getBalance = async (address: string, scamFilter = true) => {\n const { getBalance: getBalanceFromApi } = await import(\"../utils.js\");\n\n try {\n // Use SwapKit API for comprehensive balance fetching (includes TRX + TRC20 tokens)\n const apiBalances = await getBalanceFromApi(Chain.Tron)(address, scamFilter);\n\n // If API returns balances, use those\n if (apiBalances.length > 0) {\n return apiBalances;\n }\n\n // Fallback to on-chain TRX balance if API fails or returns empty\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6, // TRX has 6 decimals\n }),\n ];\n } catch (error) {\n warnOnce(\n true,\n `Failed to get Tron balance for ${address}: ${error instanceof Error ? error.message : error}`,\n );\n\n // Final fallback: try to get just the native TRX balance\n try {\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n ];\n } catch (fallbackError) {\n warnOnce(\n true,\n `Failed to get native TRX balance for ${address}: ${fallbackError instanceof Error ? fallbackError.message : fallbackError}`,\n );\n return [];\n }\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = getContractAddress(assetValue);\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = await tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = ({ assetValue }: TronTransferParams) => {\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX transfers typically consume bandwidth, which is free up to daily limit\n // Return a minimal fee estimation for bandwidth cost\n return AssetValue.from({ chain: Chain.Tron, value: 1 }); // 1 TRX\n }\n\n // TRC20 transfers consume energy, estimate higher fee\n return AssetValue.from({ chain: Chain.Tron, value: 10 }); // 10 TRX\n };\n\n const createTransaction = async (params: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const { recipient, assetValue, memo } = params;\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = getContractAddress(assetValue);\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n {},\n parameter,\n from,\n );\n\n return result.transaction;\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress,\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
5
+ "import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport type {\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nexport async function getTronAddressValidator() {\n const { TronWeb } = require(\"tronweb\");\n\n return (address: string) => {\n return TronWeb.isAddress(address);\n };\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index: index || 0 }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}) {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n const { TronWeb } = require(\"tronweb\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n const { TronWeb } = require(\"tronweb\");\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n const getBalance = async (address: string, scamFilter = true) => {\n const { getBalance: getBalanceFromApi } = await import(\"../utils.js\");\n\n try {\n // Use SwapKit API for comprehensive balance fetching (includes TRX + TRC20 tokens)\n const apiBalances = await getBalanceFromApi(Chain.Tron)(address, scamFilter);\n\n // If API returns balances, use those\n if (apiBalances.length > 0) {\n return apiBalances;\n }\n\n // Fallback to on-chain TRX balance if API fails or returns empty\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6, // TRX has 6 decimals\n }),\n ];\n } catch (error) {\n warnOnce(\n true,\n `Failed to get Tron balance for ${address}: ${error instanceof Error ? error.message : error}`,\n );\n\n // Final fallback: try to get just the native TRX balance\n try {\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n ];\n } catch (fallbackError) {\n warnOnce(\n true,\n `Failed to get native TRX balance for ${address}: ${fallbackError instanceof Error ? fallbackError.message : fallbackError}`,\n );\n return [];\n }\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = await tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = ({ assetValue }: TronTransferParams) => {\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX transfers typically consume bandwidth, which is free up to daily limit\n // Return a minimal fee estimation for bandwidth cost\n return AssetValue.from({ chain: Chain.Tron, value: 1 }); // 1 TRX\n }\n\n // TRC20 transfers consume energy, estimate higher fee\n return AssetValue.from({ chain: Chain.Tron, value: 10 }); // 10 TRX\n };\n\n const createTransaction = async (params: TronTransferParams) => {\n const { recipient, assetValue, memo } = params;\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n {},\n parameter,\n from,\n );\n\n return result.transaction;\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress: await getTronAddressValidator(),\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
6
6
  "export const trc20ABI = [\n {\n constant: true,\n inputs: [{ name: \"_owner\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"balance\", type: \"uint256\" }],\n type: \"function\",\n },\n {\n constant: false,\n inputs: [\n { name: \"_to\", type: \"address\" },\n { name: \"_value\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"success\", type: \"bool\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"decimals\",\n outputs: [{ name: \"\", type: \"uint8\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"symbol\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"name\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n] as const;\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "DB39FF97B3BDD00964756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "DA4D4F666437324964756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,3 +1,3 @@
1
- import{d as Y,e as Z}from"../../chunk-s47y8512.js";import{AssetValue as H,Chain as O,NetworkDerivationPath as C,SKConfig as E,SwapKitError as M,derivationPathToString as P,updateDerivationPath as w,warnOnce as m}from"@swapkit/helpers";import{TronWeb as v}from"tronweb";import{P as A,match as W}from"ts-pattern";var x=[{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"success",type:"bool"}],type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],type:"function"}];async function V(){let{TronWeb:q}=await import("tronweb");return(R)=>q.isAddress(R)}async function l({phrase:q,derivationPath:R,index:I}){let T=R||P(w(C[O.Tron],{index:I||0})),{HDKey:$}=await import("@scure/bip32"),{mnemonicToSeedSync:L}=await import("@scure/bip39"),f=L(q),X=$.fromMasterSeed(f).derive(T);if(!X.privateKey)throw new M("toolbox_tron_no_signer");return Buffer.from(X.privateKey).toString("hex")}async function h({phrase:q,derivationPath:R}){let{HDKey:I}=await import("@scure/bip32"),{mnemonicToSeedSync:T}=await import("@scure/bip39"),$=T(q),f=I.fromMasterSeed($).derive(R);if(!f.privateKey)throw new M("toolbox_tron_no_signer");let Q=Buffer.from(f.privateKey).toString("hex"),X=new v({fullHost:E.get("rpcUrls")[O.Tron],privateKey:Q}),j=X.address.fromPrivateKey(Q);return{getAddress:()=>Promise.resolve(typeof j==="string"?j:""),signTransaction:async(k)=>{return await X.trx.sign(k,Q)}}}var c=async(q={})=>{let R=E.get("rpcUrls")[O.Tron],I=void 0,T=new v({fullHost:R,headers:void 0}),$="index"in q?q.index||0:0,L=P("derivationPath"in q&&q.derivationPath?q.derivationPath:w(C[O.Tron],{index:$})),f=await W(q).with({phrase:A.string},async({phrase:y})=>h({phrase:y,derivationPath:L})).with({signer:A.any},({signer:y})=>Promise.resolve(y)).otherwise(()=>Promise.resolve(void 0)),Q=async()=>{if(!f)throw new M("toolbox_tron_no_signer");return await f.getAddress()},X=(y)=>{return T.isAddress(y)},j=(y)=>{return y.address},k=()=>{return 1e8};return{tronWeb:T,getAddress:Q,validateAddress:X,getBalance:async(y,_=!0)=>{let{getBalance:J}=await import("../../chunk-12xtvbsp.js");try{let z=await J(O.Tron)(y,_);if(z.length>0)return z;let G=await T.trx.getBalance(y);return[H.from({chain:O.Tron,value:G,fromBaseDecimal:6})]}catch(z){m(!0,`Failed to get Tron balance for ${y}: ${z instanceof Error?z.message:z}`);try{let G=await T.trx.getBalance(y);return[H.from({chain:O.Tron,value:G,fromBaseDecimal:6})]}catch(G){return m(!0,`Failed to get native TRX balance for ${y}: ${G instanceof Error?G.message:G}`),[]}}},transfer:async({recipient:y,assetValue:_,memo:J})=>{if(!f)throw new M("toolbox_tron_no_signer");let z=await Q();if(_.isGasAsset){let u=await T.transactionBuilder.sendTrx(y,_.getBaseValue("number"),z);if(J){let g=await T.transactionBuilder.addUpdateData(u,J,"utf8"),K=await f.signTransaction(g),{txid:S}=await T.trx.sendRawTransaction(K);return S}let B=await f.signTransaction(u),{txid:b}=await T.trx.sendRawTransaction(B);return b}let D=j(_);if(!D)throw new M("toolbox_tron_invalid_token_identifier",{identifier:_.toString()});let N=k(),U=await T.contract(x,D);if(!U.methods?.transfer)throw new M("toolbox_tron_token_transfer_failed");let F=await U.methods.transfer(y,_.getBaseValue("string")).send({from:z,feeLimit:N,callValue:0});if(!F)throw new M("toolbox_tron_token_transfer_failed");return F},estimateTransactionFee:({assetValue:y})=>{if(y.isGasAsset)return H.from({chain:O.Tron,value:1});return H.from({chain:O.Tron,value:10})},createTransaction:async(y)=>{if(!f)throw new M("toolbox_tron_no_signer");let{recipient:_,assetValue:J,memo:z}=y,G=await Q();if(J.isGasAsset){let B=await T.transactionBuilder.sendTrx(_,J.getBaseValue("number"),G);if(z)return T.transactionBuilder.addUpdateData(B,z,"utf8");return B}let N=j(J);if(!N)throw new M("toolbox_tron_invalid_token_identifier",{identifier:J.toString()});let U="transfer(address,uint256)",F=[{type:"address",value:_},{type:"uint256",value:J.getBaseValue("string")}];return(await T.transactionBuilder.triggerSmartContract(N,U,{},F,G)).transaction},signTransaction:async(y)=>{if(!f)throw new M("toolbox_tron_no_signer");return await f.signTransaction(y)},broadcastTransaction:async(y)=>{let{txid:_}=await T.trx.sendRawTransaction(y);return _}}};export{x as trc20ABI,l as getTronPrivateKeyFromMnemonic,V as getTronAddressValidator,c as createTronToolbox};
1
+ import{d as $,e as T}from"../../chunk-s47y8512.js";import{AssetValue as k,Chain as Q,NetworkDerivationPath as P,SKConfig as v,SwapKitError as R,derivationPathToString as w,updateDerivationPath as p,warnOnce as C}from"@swapkit/helpers";import{P as E,match as c}from"ts-pattern";var m=[{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"success",type:"bool"}],type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],type:"function"},{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],type:"function"}];async function K(){let{TronWeb:q}=T("tronweb");return(X)=>{return q.isAddress(X)}}async function o({phrase:q,derivationPath:X,index:Y}){let j=X||w(p(P[Q.Tron],{index:Y||0})),{HDKey:f}=await import("@scure/bip32"),{mnemonicToSeedSync:Z}=await import("@scure/bip39"),I=Z(q),M=f.fromMasterSeed(I).derive(j);if(!M.privateKey)throw new R("toolbox_tron_no_signer");return Buffer.from(M.privateKey).toString("hex")}async function n({phrase:q,derivationPath:X}){let{HDKey:Y}=await import("@scure/bip32"),{mnemonicToSeedSync:j}=await import("@scure/bip39"),{TronWeb:f}=T("tronweb"),Z=j(q),G=Y.fromMasterSeed(Z).derive(X);if(!G.privateKey)throw new R("toolbox_tron_no_signer");let M=Buffer.from(G.privateKey).toString("hex"),L=new f({fullHost:v.get("rpcUrls")[Q.Tron],privateKey:M}),N=L.address.fromPrivateKey(M);return{getAddress:()=>Promise.resolve(typeof N==="string"?N:""),signTransaction:async(B)=>{return await L.trx.sign(B,M)}}}var d=async(q={})=>{let{TronWeb:X}=T("tronweb"),Y=v.get("rpcUrls")[Q.Tron],j=void 0,f=new X({fullHost:Y,headers:void 0}),Z="index"in q?q.index||0:0,I=w("derivationPath"in q&&q.derivationPath?q.derivationPath:p(P[Q.Tron],{index:Z})),G=await c(q).with({phrase:E.string},async({phrase:y})=>n({phrase:y,derivationPath:I})).with({signer:E.any},({signer:y})=>Promise.resolve(y)).otherwise(()=>Promise.resolve(void 0)),M=async()=>{if(!G)throw new R("toolbox_tron_no_signer");return await G.getAddress()},L=()=>{return 1e8},N=async(y,_=!0)=>{let{getBalance:O}=await import("../../chunk-12xtvbsp.js");try{let z=await O(Q.Tron)(y,_);if(z.length>0)return z;let J=await f.trx.getBalance(y);return[k.from({chain:Q.Tron,value:J,fromBaseDecimal:6})]}catch(z){C(!0,`Failed to get Tron balance for ${y}: ${z instanceof Error?z.message:z}`);try{let J=await f.trx.getBalance(y);return[k.from({chain:Q.Tron,value:J,fromBaseDecimal:6})]}catch(J){return C(!0,`Failed to get native TRX balance for ${y}: ${J instanceof Error?J.message:J}`),[]}}},B=async({recipient:y,assetValue:_,memo:O})=>{if(!G)throw new R("toolbox_tron_no_signer");let z=await M();if(_.isGasAsset){let x=await f.transactionBuilder.sendTrx(y,_.getBaseValue("number"),z);if(O){let V=await f.transactionBuilder.addUpdateData(x,O,"utf8"),l=await G.signTransaction(V),{txid:h}=await f.trx.sendRawTransaction(l);return h}let H=await G.signTransaction(x),{txid:b}=await f.trx.sendRawTransaction(H);return b}let D=_.address;if(!D)throw new R("toolbox_tron_invalid_token_identifier",{identifier:_.toString()});let U=L(),u=await f.contract(m,D);if(!u.methods?.transfer)throw new R("toolbox_tron_token_transfer_failed");let F=await u.methods.transfer(y,_.getBaseValue("string")).send({from:z,feeLimit:U,callValue:0});if(!F)throw new R("toolbox_tron_token_transfer_failed");return F},A=({assetValue:y})=>{if(y.isGasAsset)return k.from({chain:Q.Tron,value:1});return k.from({chain:Q.Tron,value:10})},g=async(y)=>{let{recipient:_,assetValue:O,memo:z}=y,J=await M();if(O.isGasAsset){let H=await f.transactionBuilder.sendTrx(_,O.getBaseValue("number"),J);if(z)return f.transactionBuilder.addUpdateData(H,z,"utf8");return H}let U=O.address;if(!U)throw new R("toolbox_tron_invalid_token_identifier",{identifier:O.toString()});let u="transfer(address,uint256)",F=[{type:"address",value:_},{type:"uint256",value:O.getBaseValue("string")}];return(await f.transactionBuilder.triggerSmartContract(U,u,{},F,J)).transaction},S=async(y)=>{if(!G)throw new R("toolbox_tron_no_signer");return await G.signTransaction(y)},W=async(y)=>{let{txid:_}=await f.trx.sendRawTransaction(y);return _};return{tronWeb:f,getAddress:M,validateAddress:await K(),getBalance:N,transfer:B,estimateTransactionFee:A,createTransaction:g,signTransaction:S,broadcastTransaction:W}};export{m as trc20ABI,o as getTronPrivateKeyFromMnemonic,K as getTronAddressValidator,d as createTronToolbox};
2
2
 
3
- //# debugId=34A485FEEB375E5464756E2164756E21
3
+ //# debugId=CB578B3E08023A8564756E2164756E21
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/tron/toolbox.ts", "../src/tron/helpers/trc20.abi.ts"],
4
4
  "sourcesContent": [
5
- "import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { TronWeb } from \"tronweb\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport type {\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nexport async function getTronAddressValidator() {\n const { TronWeb } = await import(\"tronweb\");\n return (address: string) => TronWeb.isAddress(address);\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index: index || 0 }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}): Promise<TronSigner> {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const validateAddress = (address: string) => {\n return tronWeb.isAddress(address);\n };\n\n const getContractAddress = (assetValue: AssetValue) => {\n // Use asset.address for TRC20 contracts instead of parsing string\n return assetValue.address;\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n const getBalance = async (address: string, scamFilter = true) => {\n const { getBalance: getBalanceFromApi } = await import(\"../utils.js\");\n\n try {\n // Use SwapKit API for comprehensive balance fetching (includes TRX + TRC20 tokens)\n const apiBalances = await getBalanceFromApi(Chain.Tron)(address, scamFilter);\n\n // If API returns balances, use those\n if (apiBalances.length > 0) {\n return apiBalances;\n }\n\n // Fallback to on-chain TRX balance if API fails or returns empty\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6, // TRX has 6 decimals\n }),\n ];\n } catch (error) {\n warnOnce(\n true,\n `Failed to get Tron balance for ${address}: ${error instanceof Error ? error.message : error}`,\n );\n\n // Final fallback: try to get just the native TRX balance\n try {\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n ];\n } catch (fallbackError) {\n warnOnce(\n true,\n `Failed to get native TRX balance for ${address}: ${fallbackError instanceof Error ? fallbackError.message : fallbackError}`,\n );\n return [];\n }\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = getContractAddress(assetValue);\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = await tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = ({ assetValue }: TronTransferParams) => {\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX transfers typically consume bandwidth, which is free up to daily limit\n // Return a minimal fee estimation for bandwidth cost\n return AssetValue.from({ chain: Chain.Tron, value: 1 }); // 1 TRX\n }\n\n // TRC20 transfers consume energy, estimate higher fee\n return AssetValue.from({ chain: Chain.Tron, value: 10 }); // 10 TRX\n };\n\n const createTransaction = async (params: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const { recipient, assetValue, memo } = params;\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = getContractAddress(assetValue);\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n {},\n parameter,\n from,\n );\n\n return result.transaction;\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress,\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
5
+ "import {\n AssetValue,\n Chain,\n NetworkDerivationPath,\n SKConfig,\n SwapKitError,\n derivationPathToString,\n updateDerivationPath,\n warnOnce,\n} from \"@swapkit/helpers\";\nimport { P, match } from \"ts-pattern\";\n\nimport { trc20ABI } from \"./helpers/trc20.abi.js\";\nimport type {\n TronSignedTransaction,\n TronSigner,\n TronToolboxOptions,\n TronTransaction,\n TronTransferParams,\n} from \"./types.js\";\n\nexport async function getTronAddressValidator() {\n const { TronWeb } = require(\"tronweb\");\n\n return (address: string) => {\n return TronWeb.isAddress(address);\n };\n}\n\nexport async function getTronPrivateKeyFromMnemonic({\n phrase,\n derivationPath: customPath,\n index,\n}: {\n phrase: string;\n derivationPath?: string;\n index?: number;\n}) {\n const derivationPathToUse =\n customPath ||\n derivationPathToString(\n updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index: index || 0 }),\n );\n\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPathToUse);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n return Buffer.from(derived.privateKey).toString(\"hex\");\n}\n\nasync function createKeysForPath({\n phrase,\n derivationPath,\n}: {\n phrase: string;\n derivationPath: string;\n}) {\n const { HDKey } = await import(\"@scure/bip32\");\n const { mnemonicToSeedSync } = await import(\"@scure/bip39\");\n const { TronWeb } = require(\"tronweb\");\n\n const seed = mnemonicToSeedSync(phrase);\n const hdKey = HDKey.fromMasterSeed(seed);\n const derived = hdKey.derive(derivationPath);\n\n if (!derived.privateKey) {\n throw new SwapKitError(\"toolbox_tron_no_signer\");\n }\n\n // Convert private key to hex string for TronWeb\n const privateKeyHex = Buffer.from(derived.privateKey).toString(\"hex\");\n\n // Create TronWeb instance with the derived private key\n const tronWebWithKey = new TronWeb({\n fullHost: SKConfig.get(\"rpcUrls\")[Chain.Tron],\n privateKey: privateKeyHex,\n });\n\n const address = tronWebWithKey.address.fromPrivateKey(privateKeyHex);\n\n return {\n getAddress: () => Promise.resolve(typeof address === \"string\" ? address : \"\"),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWebWithKey.trx.sign(transaction, privateKeyHex);\n return signedTx;\n },\n };\n}\n\nexport const createTronToolbox = async (options: TronToolboxOptions = {}) => {\n const { TronWeb } = require(\"tronweb\");\n // Always get configuration from SKConfig\n const rpcUrl = SKConfig.get(\"rpcUrls\")[Chain.Tron];\n // Note: TRON API key support can be added to SKConfig apiKeys when needed\n const headers = undefined; // No API key needed for basic TronGrid access\n\n const tronWeb = new TronWeb({\n fullHost: rpcUrl,\n headers,\n });\n\n // Handle derivation path and index\n const index = \"index\" in options ? options.index || 0 : 0;\n const derivationPath = derivationPathToString(\n \"derivationPath\" in options && options.derivationPath\n ? options.derivationPath\n : updateDerivationPath(NetworkDerivationPath[Chain.Tron], { index }),\n );\n\n // Create signer based on options using pattern matching\n const signer: TronSigner | undefined = await match(options)\n .with({ phrase: P.string }, async ({ phrase }) => createKeysForPath({ phrase, derivationPath }))\n .with({ signer: P.any }, ({ signer }) => Promise.resolve(signer as TronSigner))\n .otherwise(() => Promise.resolve(undefined));\n\n const getAddress = async () => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.getAddress();\n };\n\n const calculateFeeLimit = () => {\n return 100_000_000; // 100 TRX in SUN\n };\n\n const getBalance = async (address: string, scamFilter = true) => {\n const { getBalance: getBalanceFromApi } = await import(\"../utils.js\");\n\n try {\n // Use SwapKit API for comprehensive balance fetching (includes TRX + TRC20 tokens)\n const apiBalances = await getBalanceFromApi(Chain.Tron)(address, scamFilter);\n\n // If API returns balances, use those\n if (apiBalances.length > 0) {\n return apiBalances;\n }\n\n // Fallback to on-chain TRX balance if API fails or returns empty\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6, // TRX has 6 decimals\n }),\n ];\n } catch (error) {\n warnOnce(\n true,\n `Failed to get Tron balance for ${address}: ${error instanceof Error ? error.message : error}`,\n );\n\n // Final fallback: try to get just the native TRX balance\n try {\n const trxBalanceInSun = await tronWeb.trx.getBalance(address);\n return [\n AssetValue.from({\n chain: Chain.Tron,\n value: trxBalanceInSun,\n fromBaseDecimal: 6,\n }),\n ];\n } catch (fallbackError) {\n warnOnce(\n true,\n `Failed to get native TRX balance for ${address}: ${fallbackError instanceof Error ? fallbackError.message : fallbackError}`,\n );\n return [];\n }\n }\n };\n\n const transfer = async ({ recipient, assetValue, memo }: TronTransferParams) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX Transfer (amount in SUN - base units)\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n // Add memo if provided\n if (memo) {\n const transactionWithMemo = await tronWeb.transactionBuilder.addUpdateData(\n transaction,\n memo,\n \"utf8\",\n );\n const signedTx = await signer.signTransaction(transactionWithMemo);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n const signedTx = await signer.signTransaction(transaction);\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n }\n\n // TRC20 Token Transfer\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n const feeLimit = calculateFeeLimit();\n const contract = await tronWeb.contract(trc20ABI, contractAddress);\n\n if (!contract.methods?.transfer) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n const txid = await contract.methods\n .transfer(recipient, assetValue.getBaseValue(\"string\"))\n .send({\n from,\n feeLimit,\n callValue: 0,\n });\n\n if (!txid) {\n throw new SwapKitError(\"toolbox_tron_token_transfer_failed\");\n }\n\n return txid;\n };\n\n const estimateTransactionFee = ({ assetValue }: TronTransferParams) => {\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n // Native TRX transfers typically consume bandwidth, which is free up to daily limit\n // Return a minimal fee estimation for bandwidth cost\n return AssetValue.from({ chain: Chain.Tron, value: 1 }); // 1 TRX\n }\n\n // TRC20 transfers consume energy, estimate higher fee\n return AssetValue.from({ chain: Chain.Tron, value: 10 }); // 10 TRX\n };\n\n const createTransaction = async (params: TronTransferParams) => {\n const { recipient, assetValue, memo } = params;\n const from = await getAddress();\n const isNative = assetValue.isGasAsset;\n\n if (isNative) {\n const transaction = await tronWeb.transactionBuilder.sendTrx(\n recipient,\n assetValue.getBaseValue(\"number\"),\n from,\n );\n\n if (memo) {\n return tronWeb.transactionBuilder.addUpdateData(transaction, memo, \"utf8\");\n }\n\n return transaction;\n }\n\n // For TRC20, we would need to build the transaction manually\n // This is a simplified version - in practice, you'd build the contract call transaction\n const contractAddress = assetValue.address;\n if (!contractAddress) {\n throw new SwapKitError(\"toolbox_tron_invalid_token_identifier\", {\n identifier: assetValue.toString(),\n });\n }\n\n // Build TRC20 transfer transaction\n const functionSelector = \"transfer(address,uint256)\";\n const parameter = [\n { type: \"address\", value: recipient },\n { type: \"uint256\", value: assetValue.getBaseValue(\"string\") },\n ];\n\n const result = await tronWeb.transactionBuilder.triggerSmartContract(\n contractAddress,\n functionSelector,\n {},\n parameter,\n from,\n );\n\n return result.transaction;\n };\n\n const signTransaction = async (transaction: TronTransaction) => {\n if (!signer) throw new SwapKitError(\"toolbox_tron_no_signer\");\n return await signer.signTransaction(transaction);\n };\n\n const broadcastTransaction = async (signedTx: TronSignedTransaction) => {\n const { txid } = await tronWeb.trx.sendRawTransaction(signedTx);\n return txid;\n };\n\n return {\n tronWeb,\n getAddress,\n validateAddress: await getTronAddressValidator(),\n getBalance,\n transfer,\n estimateTransactionFee,\n createTransaction,\n signTransaction,\n broadcastTransaction,\n };\n};\n",
6
6
  "export const trc20ABI = [\n {\n constant: true,\n inputs: [{ name: \"_owner\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"balance\", type: \"uint256\" }],\n type: \"function\",\n },\n {\n constant: false,\n inputs: [\n { name: \"_to\", type: \"address\" },\n { name: \"_value\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"success\", type: \"bool\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"decimals\",\n outputs: [{ name: \"\", type: \"uint8\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"symbol\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n {\n constant: true,\n inputs: [],\n name: \"name\",\n outputs: [{ name: \"\", type: \"string\" }],\n type: \"function\",\n },\n] as const;\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "34A485FEEB375E5464756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "CB578B3E08023A8564756E2164756E21",
10
10
  "names": []
11
11
  }
package/package.json CHANGED
@@ -23,7 +23,7 @@
23
23
  "@solana/spl-memo": "0.2.5",
24
24
  "@solana/spl-token": "0.4.13",
25
25
  "@solana/web3.js": "1.98.2",
26
- "@swapkit/helpers": "3.0.0-beta.15",
26
+ "@swapkit/helpers": "3.0.0-beta.16",
27
27
  "base64-js": "1.5.1",
28
28
  "bitcoinjs-lib": "6.1.7",
29
29
  "bs58check": "4.0.0",
@@ -119,5 +119,5 @@
119
119
  "type-check:go": "tsgo"
120
120
  },
121
121
  "type": "module",
122
- "version": "1.0.0-beta.21"
122
+ "version": "1.0.0-beta.23"
123
123
  }
@@ -0,0 +1,80 @@
1
+ import { beforeAll, beforeEach, describe, expect, test } from "bun:test";
2
+ import { AssetValue, Chain, SKConfig } from "@swapkit/helpers";
3
+ import { providers } from "near-api-js";
4
+ import { getFullAccessPublicKey } from "../helpers/core";
5
+ import { getNearToolbox } from "../toolbox";
6
+
7
+ const accountId = "ea03292d08136cca439513a33c76af083e5204eceb4ce720320fff84071a447f";
8
+
9
+ const context: {
10
+ provider: providers.JsonRpcProvider;
11
+ toolbox: Awaited<ReturnType<typeof getNearToolbox>>;
12
+ } = {} as any;
13
+
14
+ beforeAll(() => {
15
+ context.provider = new providers.JsonRpcProvider({
16
+ url: SKConfig.get("rpcUrls")[Chain.Near],
17
+ });
18
+ });
19
+
20
+ beforeEach(async () => {
21
+ context.toolbox = await getNearToolbox();
22
+ });
23
+
24
+ describe("NEAR createTransaction", () => {
25
+ test("should retrieve full access public key for valid account", async () => {
26
+ const toolbox = context.toolbox;
27
+
28
+ const transaction = await toolbox.createTransaction({
29
+ recipient: accountId, // Self transfer
30
+ assetValue: AssetValue.from({
31
+ chain: Chain.Near,
32
+ value: "0.001", // Small amount
33
+ }),
34
+ sender: accountId,
35
+ feeRate: 300000000000000, // 300 TGas
36
+ });
37
+
38
+ expect(transaction).toBeDefined();
39
+ expect(transaction.publicKey).toBeDefined();
40
+ expect(transaction.serialized).toBeDefined();
41
+ }, 30000);
42
+
43
+ test("should throw error for invalid account", async () => {
44
+ const provider = context.provider;
45
+ const invalidAccountId = "non-existent-account-12345.testnet";
46
+
47
+ await expect(async () => {
48
+ await getFullAccessPublicKey(provider, invalidAccountId);
49
+ }).toThrow();
50
+ }, 10000);
51
+
52
+ test("should handle network errors gracefully", async () => {
53
+ const invalidProvider = new providers.JsonRpcProvider({ url: "https://invalid-rpc-url.test" });
54
+
55
+ await expect(async () => {
56
+ await getFullAccessPublicKey(invalidProvider, "any-account.testnet");
57
+ }).toThrow();
58
+ }, 10000);
59
+
60
+ test("should work with contract function call transaction", async () => {
61
+ const toolbox = context.toolbox;
62
+ const provider = context.provider;
63
+
64
+ const contractTransaction = await toolbox.createContractFunctionCall({
65
+ sender: accountId,
66
+ contractId: "wrap.testnet", // Known testnet contract
67
+ methodName: "storage_deposit",
68
+ args: { account_id: accountId },
69
+ gas: "300000000000000", // 300 TGas
70
+ attachedDeposit: "1250000000000000000000", // 0.00125 NEAR for storage
71
+ });
72
+
73
+ expect(contractTransaction).toBeDefined();
74
+ expect(contractTransaction.publicKey).toBeDefined();
75
+
76
+ // Verify the public key can be retrieved directly
77
+ const { publicKey } = await getFullAccessPublicKey(provider, accountId);
78
+ expect(publicKey.toString()).toBe(contractTransaction.publicKey);
79
+ }, 30000);
80
+ });
@@ -82,5 +82,8 @@ export async function getFullAccessPublicKey(provider: Provider, accountId: stri
82
82
  }
83
83
 
84
84
  const { utils } = await import("near-api-js");
85
- return utils.PublicKey.fromString(fullAccessKey.public_key);
85
+ const publicKey = utils.PublicKey.fromString(fullAccessKey.public_key);
86
+ const nonce = (fullAccessKey.access_key.nonce as number) || 0;
87
+
88
+ return { publicKey, nonce };
86
89
  }
@@ -50,9 +50,6 @@ export async function getNearToolbox(toolboxParams?: NearToolboxParams) {
50
50
  const provider = new providers.JsonRpcProvider({ url });
51
51
 
52
52
  async function getAccount(address?: string) {
53
- if (!signer) {
54
- throw new SwapKitError("toolbox_near_no_signer");
55
- }
56
53
  const { Account } = await import("near-api-js");
57
54
 
58
55
  const _address = address || (await getAddress());
@@ -118,18 +115,9 @@ export async function getNearToolbox(toolboxParams?: NearToolboxParams) {
118
115
  }
119
116
 
120
117
  async function createTransaction(params: NearCreateTransactionParams) {
121
- const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender } = params;
122
-
123
- const signerId = sender || (await getAddress());
124
- const publicKey = await getFullAccessPublicKey(provider, signerId);
118
+ const { recipient, assetValue, memo, feeRate: gas, attachedDeposit, sender: signerId } = params;
125
119
 
126
- const accessKey = await provider.query({
127
- request_type: "view_access_key",
128
- finality: "final",
129
- account_id: signerId,
130
- });
131
-
132
- const nonce = (accessKey as any).nonce + 1;
120
+ const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);
133
121
 
134
122
  const baseAmount = assetValue.getBaseValue("bigint");
135
123
 
@@ -163,7 +151,7 @@ export async function getNearToolbox(toolboxParams?: NearToolboxParams) {
163
151
  serialized: serializedBase64,
164
152
  publicKey: publicKey.toString(),
165
153
  details: {
166
- signerId: await getAddress(),
154
+ signerId,
167
155
  nonce: nonce,
168
156
  blockHash: utils.serialize.base_encode(blockHash),
169
157
  },
@@ -171,24 +159,16 @@ export async function getNearToolbox(toolboxParams?: NearToolboxParams) {
171
159
  }
172
160
 
173
161
  async function createContractFunctionCall(params: {
174
- accountId: string;
162
+ sender: string;
175
163
  contractId: string;
176
164
  methodName: string;
177
165
  args: any;
178
166
  gas: string;
179
167
  attachedDeposit: string;
180
168
  }) {
181
- const { accountId } = params;
169
+ const { sender: accountId } = params;
182
170
 
183
- const publicKey = await getFullAccessPublicKey(provider, accountId);
184
-
185
- const accessKey = await provider.query({
186
- request_type: "view_access_key",
187
- finality: "final",
188
- account_id: accountId,
189
- public_key: publicKey.toString(),
190
- });
191
- const nonce = (accessKey as any).nonce + 1;
171
+ const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);
192
172
 
193
173
  const { SCHEMA } = await import("near-api-js/lib/transaction");
194
174
  const { transactions, utils } = await import("near-api-js");
@@ -0,0 +1,123 @@
1
+ import { beforeAll, beforeEach, describe, expect, test } from "bun:test";
2
+ import { AssetValue, Chain, SKConfig } from "@swapkit/helpers";
3
+ import { createTronToolbox, getTronAddressValidator } from "../toolbox";
4
+
5
+ // Test mnemonic for consistent testing
6
+ const TEST_PHRASE =
7
+ "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about";
8
+
9
+ const context: {
10
+ toolbox: Awaited<ReturnType<typeof createTronToolbox>>;
11
+ validateAddress: (address: string) => boolean;
12
+ } = {} as any;
13
+
14
+ beforeAll(async () => {
15
+ // Set up TRON mainnet configuration
16
+ SKConfig.set({
17
+ rpcUrls: {
18
+ [Chain.Tron]: "https://api.trongrid.io",
19
+ },
20
+ });
21
+
22
+ // Get the address validator
23
+ context.validateAddress = await getTronAddressValidator();
24
+ });
25
+
26
+ beforeEach(async () => {
27
+ context.toolbox = await createTronToolbox({ phrase: TEST_PHRASE });
28
+ });
29
+
30
+ describe("TRON Address Validation", () => {
31
+ test("should validate valid TRON addresses", () => {
32
+ const validAddresses = [
33
+ "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t", // USDT contract
34
+ "TLa2f6VPqDgRE67v1736s7bJ8Ray5wYjU7", // Mainnet address
35
+ "TQn9Y2khEsLJW1ChVWFMSMeRDow5KcbLSE", // Another valid address
36
+ ];
37
+
38
+ for (const address of validAddresses) {
39
+ expect(context.validateAddress(address)).toBe(true);
40
+ expect(context.toolbox.validateAddress(address)).toBe(true);
41
+ }
42
+ });
43
+
44
+ test("should reject invalid TRON addresses", () => {
45
+ const invalidAddresses = [
46
+ "", // Empty string
47
+ "invalid", // Random string
48
+ "0x742d35Cc6648C532F5e7c3d2a7a8E1e1e5b7c8D3", // Ethereum address
49
+ "1A1zP1eP5QGefi2DMPTfTL5SLmv7DivfNa", // Bitcoin address
50
+ "cosmos1abc123", // Cosmos address
51
+ "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6", // Too short
52
+ "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6tt", // Too long
53
+ "XR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t", // Wrong prefix
54
+ "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6O", // Invalid checksum
55
+ ];
56
+
57
+ for (const address of invalidAddresses) {
58
+ expect(context.validateAddress(address)).toBe(false);
59
+ expect(context.toolbox.validateAddress(address)).toBe(false);
60
+ }
61
+ });
62
+
63
+ test("should validate address from generated account", async () => {
64
+ const toolbox = context.toolbox;
65
+
66
+ // Get address from the toolbox
67
+ const address = await toolbox.getAddress();
68
+
69
+ expect(address).toBeDefined();
70
+ expect(typeof address).toBe("string");
71
+ expect(address.length).toBeGreaterThan(0);
72
+
73
+ // The generated address should be valid
74
+ expect(context.validateAddress(address)).toBe(true);
75
+ expect(toolbox.validateAddress(address)).toBe(true);
76
+
77
+ // Address should start with 'T'
78
+ expect(address.startsWith("T")).toBe(true);
79
+ });
80
+
81
+ test("should create transaction with valid addresses", async () => {
82
+ const toolbox = context.toolbox;
83
+ const fromAddress = await toolbox.getAddress();
84
+ const toAddress = "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t"; // Valid TRON address
85
+
86
+ // Both addresses should be valid
87
+ expect(toolbox.validateAddress(fromAddress)).toBe(true);
88
+ expect(toolbox.validateAddress(toAddress)).toBe(true);
89
+
90
+ // Create a transaction
91
+ const transaction = await toolbox.createTransaction({
92
+ recipient: toAddress,
93
+ assetValue: AssetValue.from({
94
+ chain: Chain.Tron,
95
+ value: "1", // 1 TRX
96
+ }),
97
+ });
98
+
99
+ expect(transaction).toBeDefined();
100
+ expect(transaction.raw_data_hex).toBeDefined();
101
+ });
102
+
103
+ test("should handle case sensitivity in addresses", () => {
104
+ const address = "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t";
105
+ const lowerCase = address.toLowerCase();
106
+ const upperCase = address.toUpperCase();
107
+
108
+ // TRON addresses are case sensitive - only the original should be valid
109
+ expect(context.validateAddress(address)).toBe(true);
110
+ expect(context.validateAddress(lowerCase)).toBe(false);
111
+ expect(context.validateAddress(upperCase)).toBe(false);
112
+ });
113
+
114
+ test("should handle edge cases", () => {
115
+ const edgeCases = [null, undefined, 123, {}, [], true, false];
116
+
117
+ for (const testCase of edgeCases) {
118
+ // Should not throw but return false for invalid inputs
119
+ expect(context.validateAddress(testCase as any)).toBe(false);
120
+ expect(context.toolbox.validateAddress(testCase as any)).toBe(false);
121
+ }
122
+ });
123
+ });
@@ -8,7 +8,6 @@ import {
8
8
  updateDerivationPath,
9
9
  warnOnce,
10
10
  } from "@swapkit/helpers";
11
- import { TronWeb } from "tronweb";
12
11
  import { P, match } from "ts-pattern";
13
12
 
14
13
  import { trc20ABI } from "./helpers/trc20.abi.js";
@@ -21,8 +20,11 @@ import type {
21
20
  } from "./types.js";
22
21
 
23
22
  export async function getTronAddressValidator() {
24
- const { TronWeb } = await import("tronweb");
25
- return (address: string) => TronWeb.isAddress(address);
23
+ const { TronWeb } = require("tronweb");
24
+
25
+ return (address: string) => {
26
+ return TronWeb.isAddress(address);
27
+ };
26
28
  }
27
29
 
28
30
  export async function getTronPrivateKeyFromMnemonic({
@@ -60,9 +62,10 @@ async function createKeysForPath({
60
62
  }: {
61
63
  phrase: string;
62
64
  derivationPath: string;
63
- }): Promise<TronSigner> {
65
+ }) {
64
66
  const { HDKey } = await import("@scure/bip32");
65
67
  const { mnemonicToSeedSync } = await import("@scure/bip39");
68
+ const { TronWeb } = require("tronweb");
66
69
 
67
70
  const seed = mnemonicToSeedSync(phrase);
68
71
  const hdKey = HDKey.fromMasterSeed(seed);
@@ -93,6 +96,7 @@ async function createKeysForPath({
93
96
  }
94
97
 
95
98
  export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
99
+ const { TronWeb } = require("tronweb");
96
100
  // Always get configuration from SKConfig
97
101
  const rpcUrl = SKConfig.get("rpcUrls")[Chain.Tron];
98
102
  // Note: TRON API key support can be added to SKConfig apiKeys when needed
@@ -122,15 +126,6 @@ export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
122
126
  return await signer.getAddress();
123
127
  };
124
128
 
125
- const validateAddress = (address: string) => {
126
- return tronWeb.isAddress(address);
127
- };
128
-
129
- const getContractAddress = (assetValue: AssetValue) => {
130
- // Use asset.address for TRC20 contracts instead of parsing string
131
- return assetValue.address;
132
- };
133
-
134
129
  const calculateFeeLimit = () => {
135
130
  return 100_000_000; // 100 TRX in SUN
136
131
  };
@@ -214,7 +209,7 @@ export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
214
209
  }
215
210
 
216
211
  // TRC20 Token Transfer
217
- const contractAddress = getContractAddress(assetValue);
212
+ const contractAddress = assetValue.address;
218
213
  if (!contractAddress) {
219
214
  throw new SwapKitError("toolbox_tron_invalid_token_identifier", {
220
215
  identifier: assetValue.toString(),
@@ -257,8 +252,6 @@ export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
257
252
  };
258
253
 
259
254
  const createTransaction = async (params: TronTransferParams) => {
260
- if (!signer) throw new SwapKitError("toolbox_tron_no_signer");
261
-
262
255
  const { recipient, assetValue, memo } = params;
263
256
  const from = await getAddress();
264
257
  const isNative = assetValue.isGasAsset;
@@ -279,7 +272,7 @@ export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
279
272
 
280
273
  // For TRC20, we would need to build the transaction manually
281
274
  // This is a simplified version - in practice, you'd build the contract call transaction
282
- const contractAddress = getContractAddress(assetValue);
275
+ const contractAddress = assetValue.address;
283
276
  if (!contractAddress) {
284
277
  throw new SwapKitError("toolbox_tron_invalid_token_identifier", {
285
278
  identifier: assetValue.toString(),
@@ -317,7 +310,7 @@ export const createTronToolbox = async (options: TronToolboxOptions = {}) => {
317
310
  return {
318
311
  tronWeb,
319
312
  getAddress,
320
- validateAddress,
313
+ validateAddress: await getTronAddressValidator(),
321
314
  getBalance,
322
315
  transfer,
323
316
  estimateTransactionFee,