@swapkit/toolboxes 4.0.27 → 4.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/cardano/index.cjs +4 -0
- package/dist/src/cardano/index.cjs.map +11 -0
- package/dist/src/cardano/index.js +4 -0
- package/dist/src/cardano/index.js.map +11 -0
- package/dist/src/cosmos/index.cjs +2 -2
- package/dist/src/cosmos/index.cjs.map +5 -5
- package/dist/src/cosmos/index.js +2 -2
- package/dist/src/cosmos/index.js.map +5 -5
- package/dist/src/evm/index.cjs +2 -2
- package/dist/src/evm/index.cjs.map +6 -6
- package/dist/src/evm/index.js +2 -2
- package/dist/src/evm/index.js.map +6 -6
- package/dist/src/index.cjs +3 -3
- package/dist/src/index.cjs.map +40 -34
- package/dist/src/index.js +3 -3
- package/dist/src/index.js.map +40 -34
- package/dist/src/near/index.cjs +2 -2
- package/dist/src/near/index.cjs.map +4 -4
- package/dist/src/near/index.js +2 -2
- package/dist/src/near/index.js.map +4 -4
- package/dist/src/solana/index.cjs +2 -2
- package/dist/src/solana/index.cjs.map +3 -3
- package/dist/src/solana/index.js +2 -2
- package/dist/src/solana/index.js.map +3 -3
- package/dist/src/substrate/index.cjs +2 -2
- package/dist/src/substrate/index.cjs.map +3 -3
- package/dist/src/substrate/index.js +2 -2
- package/dist/src/substrate/index.js.map +3 -3
- package/dist/src/sui/index.cjs +4 -0
- package/dist/src/sui/index.cjs.map +11 -0
- package/dist/src/sui/index.js +4 -0
- package/dist/src/sui/index.js.map +11 -0
- package/dist/src/ton/index.cjs +4 -0
- package/dist/src/ton/index.cjs.map +11 -0
- package/dist/src/ton/index.js +4 -0
- package/dist/src/ton/index.js.map +11 -0
- package/dist/src/tron/index.cjs +2 -2
- package/dist/src/tron/index.cjs.map +3 -3
- package/dist/src/tron/index.js +2 -2
- package/dist/src/tron/index.js.map +3 -3
- package/dist/src/utxo/index.cjs +2 -2
- package/dist/src/utxo/index.cjs.map +5 -5
- package/dist/src/utxo/index.js +2 -2
- package/dist/src/utxo/index.js.map +5 -5
- package/dist/types/cardano/index.d.ts +3 -0
- package/dist/types/cardano/index.d.ts.map +1 -0
- package/dist/types/cardano/toolbox.d.ts +34 -0
- package/dist/types/cardano/toolbox.d.ts.map +1 -0
- package/dist/types/cardano/types.d.ts +11 -0
- package/dist/types/cardano/types.d.ts.map +1 -0
- package/dist/types/cosmos/toolbox/cosmos.d.ts +2 -14
- package/dist/types/cosmos/toolbox/cosmos.d.ts.map +1 -1
- package/dist/types/evm/toolbox/baseEVMToolbox.d.ts +1 -0
- package/dist/types/evm/toolbox/baseEVMToolbox.d.ts.map +1 -1
- package/dist/types/evm/toolbox/evm.d.ts.map +1 -1
- package/dist/types/evm/toolbox/index.d.ts +2 -2
- package/dist/types/evm/toolbox/index.d.ts.map +1 -1
- package/dist/types/evm/toolbox/op.d.ts +2 -2
- package/dist/types/evm/toolbox/op.d.ts.map +1 -1
- package/dist/types/index.d.ts +12 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/solana/toolbox.d.ts.map +1 -1
- package/dist/types/sui/index.d.ts +3 -0
- package/dist/types/sui/index.d.ts.map +1 -0
- package/dist/types/sui/toolbox.d.ts +19 -0
- package/dist/types/sui/toolbox.d.ts.map +1 -0
- package/dist/types/sui/types.d.ts +16 -0
- package/dist/types/sui/types.d.ts.map +1 -0
- package/dist/types/ton/index.d.ts +3 -0
- package/dist/types/ton/index.d.ts.map +1 -0
- package/dist/types/ton/toolbox.d.ts +14 -0
- package/dist/types/ton/toolbox.d.ts.map +1 -0
- package/dist/types/ton/types.d.ts +22 -0
- package/dist/types/ton/types.d.ts.map +1 -0
- package/dist/types/tron/toolbox.d.ts.map +1 -1
- package/dist/types/types.d.ts +10 -2
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/utxo/toolbox/bitcoinCash.d.ts.map +1 -1
- package/dist/types/utxo/toolbox/zcash.d.ts.map +1 -1
- package/package.json +31 -4
package/dist/src/near/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var Lt=Object.create;var{getPrototypeOf:Gt,defineProperty:D,getOwnPropertyNames:tt,getOwnPropertyDescriptor:pt}=Object,rt=Object.prototype.hasOwnProperty;var N=(t,r,i)=>{i=t!=null?Lt(Gt(t)):{};let e=r||!t||!t.__esModule?D(i,"default",{value:t,enumerable:!0}):i;for(let m of tt(t))if(!rt.call(e,m))D(e,m,{get:()=>t[m],enumerable:!0});return e},c=new WeakMap,bt=(t)=>{var r=c.get(t),i;if(r)return r;if(r=D({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")tt(t).map((e)=>!rt.call(r,e)&&D(r,e,{get:()=>t[e],enumerable:!(i=pt(t,e))||i.enumerable}));return c.set(t,r),r};var Ut=(t,r)=>{for(var i in r)D(t,i,{get:r[i],enumerable:!0,configurable:!0,set:(e)=>r[i]=()=>e})};var R=(t,r)=>()=>(t&&(r=t(t=0)),r);async function G(){let{validateAccountId:t}=await import("near-sdk-js");return(r)=>{try{return t(r)}catch{let i=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return r.length>=2&&r.length<=64&&i.test(r)}}}async function p(t){let{parseSeedPhrase:r}=await import("near-seed-phrase"),{KeyPair:i}=await import("near-api-js"),e=t.index||0,m=t.derivationPath?L.derivationPathToString(t.derivationPath.slice(0,3)):`m/44'/397'/${e}'`,{secretKey:f}=r(t.phrase,m),P=i.fromString(f);return et(P)}async function B(t){let{KeyPair:r}=await import("near-api-js/lib/utils"),i=r.fromString(t);return et(i)}function et(t){return new it(t)}async function b(t,r){let e=(await t.query({account_id:r,finality:"final",request_type:"view_access_key_list"})).keys.find((E)=>E.access_key.permission==="FullAccess");if(!e)throw new L.SwapKitError("toolbox_near_invalid_address");let{utils:m}=await import("near-api-js"),f=m.PublicKey.fromString(e.public_key);return{nonce:e.access_key.nonce||0,publicKey:f}}var L,nt,it;var M=R(()=>{L=require("@swapkit/helpers"),nt=require("near-api-js");it=class it extends nt.KeyPairSigner{#t;constructor(t){super(t);this.#t=t}getAddress(){let t=this.#t.getPublicKey(),r=Buffer.from(t.data).toString("hex");return Promise.resolve(r)}}});function Q(t){return"recipient"in t&&"amount"in t&&!("contractId"in t)}function Z(t){return"contractId"in t&&"methodName"in t}function $(t){return"actions"in t}function z(t){return"newAccountId"in t}function X(t){return"contractCode"in t}function H(t){return"customEstimator"in t}function V(t){let r=0;for(let i of t)switch(i.enum){case"transfer":r+=Number(C.SIMPLE_TRANSFER);break;case"functionCall":r+=Number(C.CONTRACT_CALL);break;case"createAccount":r+=Number(C.ACCOUNT_CREATION);break;case"deployContract":r+=Number(C.CONTRACT_DEPLOYMENT);break;case"addKey":r+=Number(C.ACCESS_KEY_ADDITION);break;case"deleteKey":r+=Number(C.ACCESS_KEY_DELETION);break;case"stake":r+=Number(C.STAKE);break;default:r+=Number(C.CONTRACT_CALL)}return r.toString()}function k(t){if(t==="ft_transfer"||t==="ft_transfer_call")return C.TOKEN_TRANSFER;if(t==="storage_deposit")return C.STORAGE_DEPOSIT;return C.CONTRACT_CALL}function Yt(t){return(BigInt(t)*BigInt(1000000000000)).toString()}function Ft(t){return(BigInt(t)/BigInt(1000000000000)).toString()}var C;var w=R(()=>{C={ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",ACCOUNT_CREATION:"30",CONTRACT_CALL:"150",CONTRACT_DEPLOYMENT:"200",SIMPLE_TRANSFER:"1",STAKE:"10",STORAGE_DEPOSIT:"150",TOKEN_TRANSFER:"150"}});async function U({account:t,contractId:r,viewMethods:i,changeMethods:e}){let{Contract:m}=await import("near-api-js");return new m(t,r,{changeMethods:e,useLocalViewExecution:!0,viewMethods:i})}async function j({contractId:t,account:r}){let i=(await import("bn.js")).default,e=await U({account:r,changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"],contractId:t,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"]}),m=async(f)=>{if(!await e.storage_balance_of({account_id:f})){let A=(await e.storage_balance_bounds())?.min||"1250000000000000000000";await e.storage_deposit({account_id:f},new i("100000000000000"),new i(A))}};return{balanceOf:(f)=>e.ft_balance_of({account_id:f}),contract:e,ensureStorage:m,metadata:()=>e.ft_metadata(),storageBalanceOf:(f)=>e.storage_balance_of({account_id:f}),storageDeposit:(f,P)=>e.storage_deposit({account_id:f},new i("100000000000000"),new i(P||"1250000000000000000000")),totalSupply:()=>e.ft_total_supply(),transfer:async(f,P,E)=>{return await m(f),e.ft_transfer({amount:P,memo:E,receiver_id:f},new i("100000000000000"),new i("1"))},transferCall:async(f,P,E,A)=>{return await m(f),e.ft_transfer_call({amount:P,memo:A,msg:E,receiver_id:f},new i("100000000000000"),new i("1"))}}}function zt(){function t(){let r=Date.now(),i=l||r;return l=i,r>l?r:i+1}return qt+t().toString(36)}function Tt(t){return async function(i,e=!0){let m=await ot.SwapKitApi.getChainBalance({address:i,chain:t,scamFilter:e}),{baseDecimal:f}=Y.getChainConfig(t);return m.map(({identifier:P,value:E,decimal:A})=>{return new Y.AssetValue({decimal:A||f,identifier:P,value:E})})}}var Y,ot,qt,l=0;var mt=R(()=>{Y=require("@swapkit/helpers"),ot=require("@swapkit/helpers/api"),qt=typeof process<"u"&&process.pid?process.pid.toString(36):""});async function Jt(t){let{P:r,match:i}=await import("ts-pattern"),{providers:e}=await import("near-api-js"),m=await i(t).with({phrase:r.string},async(n)=>{return await p(n)}).with({signer:r.any},({signer:n})=>n).otherwise(()=>{return}),f=await T.getRPCUrl(T.Chain.Near),P=new e.JsonRpcProvider({url:f});async function E(n){let{Account:o}=await import("near-api-js"),g=n||await A();return new o(g,P,m)}async function A(){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");return await m.getAddress()}async function gt(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let o=await h({...n,sender:await A()});return I(await v(o))}async function h(n){let{recipient:o,assetValue:g,memo:s,attachedDeposit:O,sender:x,functionCall:_}=n,a=await G();if(!a(o))throw new T.SwapKitError("toolbox_near_invalid_address",{recipient:o});if(!a(x))throw new T.SwapKitError("toolbox_near_invalid_address",{signerId:x});if(_)return F({..._,sender:x});if(!g.isGasAsset){let d=g.address;if(!d)throw new T.SwapKitError("toolbox_near_missing_contract_address");return F({args:{amount:g.getBaseValue("string"),memo:s||null,receiver_id:o},attachedDeposit:O||"1",contractId:d,gas:"250000000000000",methodName:"ft_transfer",sender:x})}let{publicKey:S,nonce:J}=await b(P,x),yt=g.getBaseValue("bigint"),{transactions:W,utils:Rt}=await import("near-api-js"),K=[W.transfer(yt)];if(s&&O)K.push(W.functionCall("memo",{memo:s},BigInt("250000000000000"),BigInt(O)));let St=await P.block({finality:"final"}),Dt=Rt.serialize.base_decode(St.header.hash);return W.createTransaction(x,S,o,J+1,K,Dt)}async function Pt(n){let{SCHEMA:o}=await import("near-api-js/lib/transaction"),{utils:g}=await import("near-api-js"),s=g.serialize.serialize(o.Transaction,n);return Buffer.from(s).toString("base64")}async function F(n){let{sender:o}=n,{publicKey:g,nonce:s}=await b(P,o),{transactions:O,utils:x}=await import("near-api-js"),_=await P.block({finality:"final"}),a=x.serialize.base_decode(_.header.hash),S=[O.functionCall(n.methodName,Buffer.from(JSON.stringify(n.args)),BigInt(n.gas),BigInt(n.attachedDeposit))];return O.createTransaction(o,g,n.contractId,s+1,S,a)}async function Nt(n){let{transactions:o}=await import("near-api-js");return o.functionCall(n.methodName,Buffer.from(JSON.stringify(n.args)),BigInt(n.gas),BigInt(n.attachedDeposit))}async function v(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let[o,g]=await m.signTransaction(n);return g}async function I(n){return(await P.sendTransaction(n)).transaction.hash}async function st(n){if("assetValue"in n){let O=BigInt("115123062500")+BigInt("108059500000"),x=await xt(),_=O*BigInt(x.toString()),{baseDecimal:a}=T.getChainConfig(T.Chain.Near);return T.AssetValue.from({chain:T.Chain.Near,fromBaseDecimal:a,value:_.toString()})}let o=m?await E():void 0;return q(n,o)}async function xt(){try{return await P.query({account_id:"system",args_base64:"",finality:"final",method_name:"gas_price",request_type:"call_function"})}catch{return"100000000"}}async function Ct(n,o,g){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let s=await E(),{utils:O}=await import("near-api-js"),x=O.format.parseNearAmount(g)||"0";return(await s.createAccount(n,O.PublicKey.fromString(o),BigInt(x))).transaction.hash}async function Et(n){try{if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let{transactions:o}=await import("near-api-js"),{contractId:g,methodName:s,args:O,deposit:x}=n,_=await E(),a=await q({args:O||{},contractId:g,methodName:s}),S=o.functionCall(s,O||{},a.getBaseValue("bigint"),BigInt(x||"1"));return(await _.signAndSendTransaction({actions:[S],receiverId:g})).transaction_outcome.id}catch(o){throw new T.SwapKitError("toolbox_near_transfer_failed",{error:o})}}async function Ot(n){let o=await E();return U({account:o,changeMethods:n.changeMethods,contractId:n.contractId,viewMethods:n.viewMethods})}async function _t(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");if(n.actions.length===0)throw new T.SwapKitError("toolbox_near_empty_batch");return(await(await E()).signAndSendTransaction({actions:n.actions,receiverId:n.receiverId})).transaction.hash}async function At(n){let o=await E();return j({account:o,contractId:n})}async function q(n,o){let{baseDecimal:g}=T.getChainConfig(T.Chain.Near),s=await i(n).when(Q,()=>C.SIMPLE_TRANSFER).when(Z,(_)=>k(_.methodName)).when($,(_)=>V(_.actions)).when(z,()=>C.ACCOUNT_CREATION).when(X,()=>C.CONTRACT_DEPLOYMENT).when(H,(_)=>{if(!o)throw new T.SwapKitError("toolbox_near_no_account");return _.customEstimator(o)}).otherwise(()=>{throw new T.SwapKitError("toolbox_near_invalid_gas_params")}),x=BigInt(s)*BigInt(1000000000000);return T.AssetValue.from({chain:T.Chain.Near,fromBaseDecimal:g,value:x})}async function at(){try{return(await P.gasPrice(null)).gas_price||"100000000"}catch(n){return"100000000"}}return{broadcastTransaction:I,callFunction:Et,createAction:Nt,createContract:Ot,createContractFunctionCall:F,createSubAccount:Ct,createTransaction:h,estimateGas:q,estimateTransactionFee:st,executeBatchTransaction:_t,getAddress:A,getBalance:Tt(T.Chain.Near),getGasPrice:at,getPublicKey:async()=>m?(await m.getPublicKey()).toString():"",getSignerFromPhrase:(n)=>p(n),getSignerFromPrivateKey:B,nep141:At,provider:P,serializeTransaction:Pt,signTransaction:v,transfer:gt,validateAddress:await G()}}var T;var u=R(()=>{mt();M();w();T=require("@swapkit/helpers")});var ft=R(()=>{u()});var Wt={};Ut(Wt,{tgasToGas:()=>Yt,isSimpleTransfer:()=>Q,isCustomEstimator:()=>H,isContractDeployment:()=>X,isContractCall:()=>Z,isBatchTransaction:()=>$,isAccountCreation:()=>z,getValidateNearAddress:()=>G,getNearToolbox:()=>Jt,getNearSignerFromPrivateKey:()=>B,getNearSignerFromPhrase:()=>p,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>k,gasToTGas:()=>Ft,estimateBatchGas:()=>V,createNearContract:()=>U,createNEP141Token:()=>j,GAS_COSTS:()=>C});module.exports=bt(Wt);var Bt=R(()=>{M();w();u();ft()});Bt();
|
|
1
|
+
var Lt=Object.create;var{getPrototypeOf:Gt,defineProperty:D,getOwnPropertyNames:tt,getOwnPropertyDescriptor:pt}=Object,rt=Object.prototype.hasOwnProperty;var N=(t,r,i)=>{i=t!=null?Lt(Gt(t)):{};let e=r||!t||!t.__esModule?D(i,"default",{value:t,enumerable:!0}):i;for(let m of tt(t))if(!rt.call(e,m))D(e,m,{get:()=>t[m],enumerable:!0});return e},c=new WeakMap,bt=(t)=>{var r=c.get(t),i;if(r)return r;if(r=D({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")tt(t).map((e)=>!rt.call(r,e)&&D(r,e,{get:()=>t[e],enumerable:!(i=pt(t,e))||i.enumerable}));return c.set(t,r),r};var Ut=(t,r)=>{for(var i in r)D(t,i,{get:r[i],enumerable:!0,configurable:!0,set:(e)=>r[i]=()=>e})};var R=(t,r)=>()=>(t&&(r=t(t=0)),r);async function G(){let{validateAccountId:t}=await import("near-sdk-js");return(r)=>{try{return t(r)}catch{let i=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return r.length>=2&&r.length<=64&&i.test(r)}}}async function p(t){let{parseSeedPhrase:r}=await import("near-seed-phrase"),{KeyPair:i}=await import("near-api-js"),e=t.index||0,m=t.derivationPath?L.derivationPathToString(t.derivationPath.slice(0,3)):`m/44'/397'/${e}'`,{secretKey:f}=r(t.phrase,m),P=i.fromString(f);return et(P)}async function B(t){let{KeyPair:r}=await import("near-api-js/lib/utils"),i=r.fromString(t);return et(i)}function et(t){return new it(t)}async function b(t,r){let e=(await t.query({account_id:r,finality:"final",request_type:"view_access_key_list"})).keys.find((E)=>E.access_key.permission==="FullAccess");if(!e)throw new L.SwapKitError("toolbox_near_no_public_key_found");let{utils:m}=await import("near-api-js"),f=m.PublicKey.fromString(e.public_key);return{nonce:e.access_key.nonce||0,publicKey:f}}var L,nt,it;var M=R(()=>{L=require("@swapkit/helpers"),nt=require("near-api-js");it=class it extends nt.KeyPairSigner{#t;constructor(t){super(t);this.#t=t}getAddress(){let t=this.#t.getPublicKey(),r=Buffer.from(t.data).toString("hex");return Promise.resolve(r)}}});function Q(t){return"recipient"in t&&"amount"in t&&!("contractId"in t)}function Z(t){return"contractId"in t&&"methodName"in t}function $(t){return"actions"in t}function z(t){return"newAccountId"in t}function X(t){return"contractCode"in t}function H(t){return"customEstimator"in t}function V(t){let r=0;for(let i of t)switch(i.enum){case"transfer":r+=Number(C.SIMPLE_TRANSFER);break;case"functionCall":r+=Number(C.CONTRACT_CALL);break;case"createAccount":r+=Number(C.ACCOUNT_CREATION);break;case"deployContract":r+=Number(C.CONTRACT_DEPLOYMENT);break;case"addKey":r+=Number(C.ACCESS_KEY_ADDITION);break;case"deleteKey":r+=Number(C.ACCESS_KEY_DELETION);break;case"stake":r+=Number(C.STAKE);break;default:r+=Number(C.CONTRACT_CALL)}return r.toString()}function k(t){if(t==="ft_transfer"||t==="ft_transfer_call")return C.TOKEN_TRANSFER;if(t==="storage_deposit")return C.STORAGE_DEPOSIT;return C.CONTRACT_CALL}function Yt(t){return(BigInt(t)*BigInt(1000000000000)).toString()}function Ft(t){return(BigInt(t)/BigInt(1000000000000)).toString()}var C;var w=R(()=>{C={ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",ACCOUNT_CREATION:"30",CONTRACT_CALL:"150",CONTRACT_DEPLOYMENT:"200",SIMPLE_TRANSFER:"1",STAKE:"10",STORAGE_DEPOSIT:"150",TOKEN_TRANSFER:"150"}});async function U({account:t,contractId:r,viewMethods:i,changeMethods:e}){let{Contract:m}=await import("near-api-js");return new m(t,r,{changeMethods:e,useLocalViewExecution:!0,viewMethods:i})}async function j({contractId:t,account:r}){let i=(await import("bn.js")).default,e=await U({account:r,changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"],contractId:t,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"]}),m=async(f)=>{if(!await e.storage_balance_of({account_id:f})){let A=(await e.storage_balance_bounds())?.min||"1250000000000000000000";await e.storage_deposit({account_id:f},new i("100000000000000"),new i(A))}};return{balanceOf:(f)=>e.ft_balance_of({account_id:f}),contract:e,ensureStorage:m,metadata:()=>e.ft_metadata(),storageBalanceOf:(f)=>e.storage_balance_of({account_id:f}),storageDeposit:(f,P)=>e.storage_deposit({account_id:f},new i("100000000000000"),new i(P||"1250000000000000000000")),totalSupply:()=>e.ft_total_supply(),transfer:async(f,P,E)=>{return await m(f),e.ft_transfer({amount:P,memo:E,receiver_id:f},new i("100000000000000"),new i("1"))},transferCall:async(f,P,E,A)=>{return await m(f),e.ft_transfer_call({amount:P,memo:A,msg:E,receiver_id:f},new i("100000000000000"),new i("1"))}}}function zt(){function t(){let r=Date.now(),i=l||r;return l=i,r>l?r:i+1}return qt+t().toString(36)}function Tt(t){return async function(i,e=!0){let m=await ot.SwapKitApi.getChainBalance({address:i,chain:t,scamFilter:e}),{baseDecimal:f}=Y.getChainConfig(t);return m.map(({identifier:P,value:E,decimal:A})=>{return new Y.AssetValue({decimal:A||f,identifier:P,value:E})})}}var Y,ot,qt,l=0;var mt=R(()=>{Y=require("@swapkit/helpers"),ot=require("@swapkit/helpers/api"),qt=typeof process<"u"&&process.pid?process.pid.toString(36):""});async function Jt(t){let{P:r,match:i}=await import("ts-pattern"),{providers:e}=await import("near-api-js"),m=await i(t).with({phrase:r.string},async(n)=>{return await p(n)}).with({signer:r.any},({signer:n})=>n).otherwise(()=>{return}),f=await T.getRPCUrl(T.Chain.Near),P=new e.JsonRpcProvider({url:f});async function E(n){let{Account:o}=await import("near-api-js"),g=n||await A();return new o(g,P,m)}async function A(){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");return await m.getAddress()}async function gt(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let o=await h({...n,sender:await A()});return I(await v(o))}async function h(n){let{recipient:o,assetValue:g,memo:s,attachedDeposit:O,sender:x,functionCall:_}=n,a=await G();if(!a(o))throw new T.SwapKitError("toolbox_near_invalid_address",{recipient:o});if(!a(x))throw new T.SwapKitError("toolbox_near_invalid_address",{signerId:x});if(_)return F({..._,sender:x});if(!g.isGasAsset){let d=g.address;if(!d)throw new T.SwapKitError("toolbox_near_missing_contract_address");return F({args:{amount:g.getBaseValue("string"),memo:s||null,receiver_id:o},attachedDeposit:O||"1",contractId:d,gas:"250000000000000",methodName:"ft_transfer",sender:x})}let{publicKey:S,nonce:J}=await b(P,x),yt=g.getBaseValue("bigint"),{transactions:W,utils:Rt}=await import("near-api-js"),K=[W.transfer(yt)];if(s&&O)K.push(W.functionCall("memo",{memo:s},BigInt("250000000000000"),BigInt(O)));let St=await P.block({finality:"final"}),Dt=Rt.serialize.base_decode(St.header.hash);return W.createTransaction(x,S,o,J+1,K,Dt)}async function Pt(n){let{SCHEMA:o}=await import("near-api-js/lib/transaction"),{utils:g}=await import("near-api-js"),s=g.serialize.serialize(o.Transaction,n);return Buffer.from(s).toString("base64")}async function F(n){let{sender:o}=n,{publicKey:g,nonce:s}=await b(P,o),{transactions:O,utils:x}=await import("near-api-js"),_=await P.block({finality:"final"}),a=x.serialize.base_decode(_.header.hash),S=[O.functionCall(n.methodName,Buffer.from(JSON.stringify(n.args)),BigInt(n.gas),BigInt(n.attachedDeposit))];return O.createTransaction(o,g,n.contractId,s+1,S,a)}async function Nt(n){let{transactions:o}=await import("near-api-js");return o.functionCall(n.methodName,Buffer.from(JSON.stringify(n.args)),BigInt(n.gas),BigInt(n.attachedDeposit))}async function v(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let[o,g]=await m.signTransaction(n);return g}async function I(n){return(await P.sendTransaction(n)).transaction.hash}async function st(n){if("assetValue"in n){let O=BigInt("115123062500")+BigInt("108059500000"),x=await xt(),_=O*BigInt(x.toString()),{baseDecimal:a}=T.getChainConfig(T.Chain.Near);return T.AssetValue.from({chain:T.Chain.Near,fromBaseDecimal:a,value:_.toString()})}let o=m?await E():void 0;return q(n,o)}async function xt(){try{return await P.query({account_id:"system",args_base64:"",finality:"final",method_name:"gas_price",request_type:"call_function"})}catch{return"100000000"}}async function Ct(n,o,g){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let s=await E(),{utils:O}=await import("near-api-js"),x=O.format.parseNearAmount(g)||"0";return(await s.createAccount(n,O.PublicKey.fromString(o),BigInt(x))).transaction.hash}async function Et(n){try{if(!m)throw new T.SwapKitError("toolbox_near_no_signer");let{transactions:o}=await import("near-api-js"),{contractId:g,methodName:s,args:O,deposit:x}=n,_=await E(),a=await q({args:O||{},contractId:g,methodName:s}),S=o.functionCall(s,O||{},a.getBaseValue("bigint"),BigInt(x||"1"));return(await _.signAndSendTransaction({actions:[S],receiverId:g})).transaction_outcome.id}catch(o){throw new T.SwapKitError("toolbox_near_transfer_failed",{error:o})}}async function Ot(n){let o=await E();return U({account:o,changeMethods:n.changeMethods,contractId:n.contractId,viewMethods:n.viewMethods})}async function _t(n){if(!m)throw new T.SwapKitError("toolbox_near_no_signer");if(n.actions.length===0)throw new T.SwapKitError("toolbox_near_empty_batch");return(await(await E()).signAndSendTransaction({actions:n.actions,receiverId:n.receiverId})).transaction.hash}async function At(n){let o=await E();return j({account:o,contractId:n})}async function q(n,o){let{baseDecimal:g}=T.getChainConfig(T.Chain.Near),s=await i(n).when(Q,()=>C.SIMPLE_TRANSFER).when(Z,(_)=>k(_.methodName)).when($,(_)=>V(_.actions)).when(z,()=>C.ACCOUNT_CREATION).when(X,()=>C.CONTRACT_DEPLOYMENT).when(H,(_)=>{if(!o)throw new T.SwapKitError("toolbox_near_no_account");return _.customEstimator(o)}).otherwise(()=>{throw new T.SwapKitError("toolbox_near_invalid_gas_params")}),x=BigInt(s)*BigInt(1000000000000);return T.AssetValue.from({chain:T.Chain.Near,fromBaseDecimal:g,value:x})}async function at(){try{return(await P.gasPrice(null)).gas_price||"100000000"}catch{return"100000000"}}return{broadcastTransaction:I,callFunction:Et,createAction:Nt,createContract:Ot,createContractFunctionCall:F,createSubAccount:Ct,createTransaction:h,estimateGas:q,estimateTransactionFee:st,executeBatchTransaction:_t,getAddress:A,getBalance:Tt(T.Chain.Near),getGasPrice:at,getPublicKey:async()=>m?(await m.getPublicKey()).toString():"",getSignerFromPhrase:(n)=>p(n),getSignerFromPrivateKey:B,nep141:At,provider:P,serializeTransaction:Pt,signTransaction:v,transfer:gt,validateAddress:await G()}}var T;var u=R(()=>{mt();M();w();T=require("@swapkit/helpers")});var ft=R(()=>{u()});var Wt={};Ut(Wt,{tgasToGas:()=>Yt,isSimpleTransfer:()=>Q,isCustomEstimator:()=>H,isContractDeployment:()=>X,isContractCall:()=>Z,isBatchTransaction:()=>$,isAccountCreation:()=>z,getValidateNearAddress:()=>G,getNearToolbox:()=>Jt,getNearSignerFromPrivateKey:()=>B,getNearSignerFromPhrase:()=>p,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>k,gasToTGas:()=>Ft,estimateBatchGas:()=>V,createNearContract:()=>U,createNEP141Token:()=>j,GAS_COSTS:()=>C});module.exports=bt(Wt);var Bt=R(()=>{M();w();u();ft()});Bt();
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=8C3E92F25946136B64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,15 +2,15 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/near/helpers/core.ts", "../src/near/helpers/gasEstimation.ts", "../src/near/helpers/nep141.ts", "../src/utils.ts", "../src/near/toolbox.ts", "../src/near/types.ts", "../src/near/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, derivationPathToString, SwapKitError } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function getValidateNearAddress() {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return (address: string) => {\n // Use the official NEAR SDK validation function if available\n try {\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}\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 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 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 const response = await provider.query({\n account_id: accountId,\n finality: \"final\",\n request_type: \"view_access_key_list\",\n });\n\n const fullAccessKey = (response as any).keys.find((key: any) => key.access_key.permission === \"FullAccess\");\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"
|
|
5
|
+
"import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, derivationPathToString, SwapKitError } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function getValidateNearAddress() {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return (address: string) => {\n // Use the official NEAR SDK validation function if available\n try {\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}\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 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 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 const response = await provider.query({\n account_id: accountId,\n finality: \"final\",\n request_type: \"view_access_key_list\",\n });\n\n const fullAccessKey = (response as any).keys.find((key: any) => key.access_key.permission === \"FullAccess\");\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_no_public_key_found\");\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 { nonce, publicKey };\n}\n",
|
|
6
6
|
"import type { Account } from \"near-api-js\";\nimport type { NearGasEstimateParams } from \"../types/contract\";\n\nexport const GAS_COSTS = {\n ACCESS_KEY_ADDITION: \"5\",\n ACCESS_KEY_DELETION: \"5\",\n ACCOUNT_CREATION: \"30\",\n CONTRACT_CALL: \"150\",\n CONTRACT_DEPLOYMENT: \"200\",\n SIMPLE_TRANSFER: \"1\",\n STAKE: \"10\",\n STORAGE_DEPOSIT: \"150\",\n TOKEN_TRANSFER: \"150\",\n} as const;\n\nexport function isSimpleTransfer(params: NearGasEstimateParams): params is { recipient: string; amount: string } {\n return \"recipient\" in params && \"amount\" in params && !(\"contractId\" in params);\n}\n\nexport function isContractCall(\n params: NearGasEstimateParams,\n): params is { contractId: string; methodName: string; args?: Record<string, any>; attachedDeposit?: string } {\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(\n params: NearGasEstimateParams,\n): params is { newAccountId: string; publicKey?: string } {\n return \"newAccountId\" in params;\n}\n\nexport function isContractDeployment(params: NearGasEstimateParams): params is { contractCode: Uint8Array } {\n return \"contractCode\" in params;\n}\n\nexport function isCustomEstimator(\n params: NearGasEstimateParams,\n): params is { customEstimator: (account: Account) => Promise<string> } {\n return \"customEstimator\" in params;\n}\n\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\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\nexport function tgasToGas(tgas: string): string {\n return (BigInt(tgas) * BigInt(10 ** 12)).toString();\n}\n\nexport function gasToTGas(gas: string): string {\n return (BigInt(gas) / BigInt(10 ** 12)).toString();\n}\n",
|
|
7
7
|
"import type { Account, Contract } from \"near-api-js\";\n\nconst DEFAULT_STORAGE_DEPOSIT = \"1250000000000000000000\"; // 0.00125 NEAR\n\n// NEP-141 metadata interface\nexport interface NEP141Metadata {\n spec: string;\n name: string;\n symbol: string;\n icon?: string;\n reference?: string;\n reference_hash?: string;\n decimals: number;\n}\n\n// Storage balance response\nexport interface StorageBalance {\n total: string;\n available: string;\n}\n\n// Storage balance bounds\nexport interface StorageBalanceBounds {\n min: string;\n max?: string;\n}\n\n// BN.js is dynamically imported, but we need the type\n// Using any here is acceptable as BN.js doesn't export proper TypeScript types\ntype BN = any; // BN.js instance\n\n// Define NEP-141 contract interface\nexport interface 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<NEP141Metadata>;\n storage_balance_of(args: { account_id: string }): Promise<StorageBalance | null>;\n storage_balance_bounds(): Promise<StorageBalanceBounds>;\n\n // Change methods\n ft_transfer(args: { receiver_id: string; amount: string; memo?: string }, gas: BN, deposit: BN): Promise<void>;\n ft_transfer_call(\n args: { receiver_id: string; amount: string; msg: string; memo?: string },\n gas: BN,\n deposit: BN,\n ): Promise<void>;\n storage_deposit(\n args: { account_id?: string; registration_only?: boolean },\n gas: BN,\n deposit: BN,\n ): Promise<StorageBalance>;\n storage_withdraw(args: { amount?: string }, gas: BN, deposit?: BN): Promise<StorageBalance>;\n storage_unregister(force?: boolean, gas?: BN): Promise<boolean>;\n}\n\nexport type NEP141Token = {\n transfer: (receiverId: string, amount: string, memo?: string) => Promise<void>;\n transferCall: (receiverId: string, amount: string, msg: string, memo?: string) => Promise<void>;\n balanceOf: (accountId: string) => Promise<string>;\n totalSupply: () => Promise<string>;\n metadata: () => Promise<NEP141Metadata>;\n storageBalanceOf: (accountId: string) => Promise<StorageBalance | null>;\n storageDeposit: (accountId?: string, amount?: string) => Promise<StorageBalance>;\n ensureStorage: (accountId: string) => Promise<void>;\n contract: NEP141Contract;\n};\n\n// Create a Near contract instance\nexport async function createNearContract<T extends Contract>({\n account,\n contractId,\n viewMethods,\n changeMethods,\n}: {\n account: Account;\n contractId: string;\n viewMethods: string[];\n changeMethods: string[];\n}): Promise<T> {\n const { Contract } = await import(\"near-api-js\");\n\n return new Contract(account, contractId, {\n changeMethods,\n useLocalViewExecution: true, // Enable local view execution for efficiency\n viewMethods,\n }) as T;\n}\n\nexport async function createNEP141Token({\n contractId,\n account,\n}: {\n contractId: string;\n account: Account;\n}): Promise<NEP141Token> {\n const BN = (await import(\"bn.js\")).default;\n\n const contract = await createNearContract<NEP141Contract>({\n account,\n changeMethods: [\"ft_transfer\", \"ft_transfer_call\", \"storage_deposit\", \"storage_withdraw\", \"storage_unregister\"],\n contractId,\n viewMethods: [\"ft_balance_of\", \"ft_total_supply\", \"ft_metadata\", \"storage_balance_of\", \"storage_balance_bounds\"],\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 balanceOf: (accountId: string) => contract.ft_balance_of({ account_id: accountId }),\n\n // Raw contract access for advanced use cases\n contract,\n\n ensureStorage: ensureStorageFor,\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 totalSupply: () => contract.ft_total_supply(),\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 { amount, memo, receiver_id: receiverId },\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 { amount, memo, msg, receiver_id: receiverId },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n };\n}\n",
|
|
8
8
|
"import { AssetValue, type Chain, getChainConfig } from \"@swapkit/helpers\";\nimport { SwapKitApi } from \"@swapkit/helpers/api\";\n\nconst pid = typeof process !== \"undefined\" && process.pid ? process.pid.toString(36) : \"\";\n\nlet last = 0;\nexport function uniqid() {\n function now() {\n const time = Date.now();\n const lastTime = last || time;\n last = lastTime;\n\n return time > last ? time : lastTime + 1;\n }\n\n return pid + now().toString(36);\n}\n\nexport function getBalance<T extends Chain>(chain: T) {\n return async function getBalance(address: string, scamFilter = true) {\n const balances = await SwapKitApi.getChainBalance({ address, chain, scamFilter });\n const { baseDecimal } = getChainConfig(chain);\n return balances.map(({ identifier, value, decimal }) => {\n return new AssetValue({ decimal: decimal || baseDecimal, identifier, value });\n });\n };\n}\n",
|
|
9
|
-
"import { AssetValue, Chain, getChainConfig, getRPCUrl, SwapKitError } from \"@swapkit/helpers\";\nimport type { Account, Contract } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport { getBalance } from \"../utils\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n getValidateNearAddress,\n} from \"./helpers/core\";\nimport {\n estimateBatchGas,\n GAS_COSTS,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token, createNearContract } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\nimport type {\n BatchTransaction,\n ContractFunctionCallParams,\n CreateActionParams,\n GetSignerFromPhraseParams,\n NearToolbox,\n} from \"./types/toolbox\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams): Promise<NearToolbox> {\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 = await getRPCUrl(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 transaction = await createTransaction({ ...params, sender: await getAddress() });\n\n return broadcastTransaction(await signTransaction(transaction));\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, attachedDeposit, sender: signerId, functionCall } = params;\n const validateNearAddress = await getValidateNearAddress();\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { recipient: recipient });\n }\n\n if (!validateNearAddress(signerId)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { signerId: signerId });\n }\n\n if (functionCall) {\n return createContractFunctionCall({ ...functionCall, sender: signerId });\n }\n\n if (!assetValue.isGasAsset) {\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n return createContractFunctionCall({\n args: { amount: assetValue.getBaseValue(\"string\"), memo: memo || null, receiver_id: recipient },\n attachedDeposit: attachedDeposit || \"1\",\n contractId,\n gas: \"250000000000000\",\n methodName: \"ft_transfer\",\n sender: signerId,\n });\n }\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(transactions.functionCall(\"memo\", { memo }, BigInt(\"250000000000000\"), BigInt(attachedDeposit)));\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n return transactions.createTransaction(signerId, publicKey, recipient, nonce + 1, txActions, blockHash);\n }\n\n async function serializeTransaction(transaction: Transaction) {\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { utils } = await import(\"near-api-js\");\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n return Buffer.from(serializedTx).toString(\"base64\");\n }\n\n async function createContractFunctionCall(params: ContractFunctionCallParams) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\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 + 1,\n actions,\n blockHash,\n );\n\n return transaction;\n }\n\n async function createAction(params: CreateActionParams) {\n const { transactions } = await import(\"near-api-js\");\n\n const action = transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n );\n\n return action;\n }\n\n async function signTransaction(transaction: Transaction): Promise<SignedTransaction> {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\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\";\n const receiptCreationCost = \"108059500000\";\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n const { baseDecimal } = getChainConfig(Chain.Near);\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: totalCostYocto.toString() });\n }\n\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 account_id: \"system\",\n args_base64: \"\",\n finality: \"final\",\n method_name: \"gas_price\",\n request_type: \"call_function\",\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): Promise<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): Promise<string> {\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({ args: args || {}, contractId, methodName });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"1\"),\n );\n\n const result = await account.signAndSendTransaction({ actions: [functionAction], receiverId: contractId });\n\n return result.transaction_outcome.id;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract<T extends Contract = Contract>(contractInterface: NearContractInterface): Promise<T> {\n const account = await getAccount();\n\n return createNearContract<T>({\n account,\n changeMethods: contractInterface.changeMethods,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n });\n }\n\n async function executeBatchTransaction(batch: BatchTransaction): Promise<string> {\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({ actions: batch.actions, receiverId: batch.receiverId });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ account, contractId });\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const { baseDecimal } = getChainConfig(Chain.Near);\n\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 const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12);\n const costInYoctoNear = gasInUnits;\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: costInYoctoNear });\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 broadcastTransaction,\n callFunction,\n createAction,\n createContract,\n createContractFunctionCall,\n createSubAccount,\n createTransaction,\n estimateGas,\n estimateTransactionFee,\n executeBatchTransaction,\n getAddress,\n getBalance: getBalance(Chain.Near),\n getGasPrice,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n getSignerFromPhrase: (params: GetSignerFromPhraseParams) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n nep141,\n provider,\n serializeTransaction,\n signTransaction,\n transfer,\n validateAddress: await getValidateNearAddress(),\n };\n}\n",
|
|
9
|
+
"import { AssetValue, Chain, getChainConfig, getRPCUrl, SwapKitError } from \"@swapkit/helpers\";\nimport type { Account, Contract } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport { getBalance } from \"../utils\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n getValidateNearAddress,\n} from \"./helpers/core\";\nimport {\n estimateBatchGas,\n GAS_COSTS,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token, createNearContract } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\nimport type {\n BatchTransaction,\n ContractFunctionCallParams,\n CreateActionParams,\n GetSignerFromPhraseParams,\n NearToolbox,\n} from \"./types/toolbox\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams): Promise<NearToolbox> {\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 = await getRPCUrl(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 transaction = await createTransaction({ ...params, sender: await getAddress() });\n\n return broadcastTransaction(await signTransaction(transaction));\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, attachedDeposit, sender: signerId, functionCall } = params;\n const validateNearAddress = await getValidateNearAddress();\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { recipient: recipient });\n }\n\n if (!validateNearAddress(signerId)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { signerId: signerId });\n }\n\n if (functionCall) {\n return createContractFunctionCall({ ...functionCall, sender: signerId });\n }\n\n if (!assetValue.isGasAsset) {\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n return createContractFunctionCall({\n args: { amount: assetValue.getBaseValue(\"string\"), memo: memo || null, receiver_id: recipient },\n attachedDeposit: attachedDeposit || \"1\",\n contractId,\n gas: \"250000000000000\",\n methodName: \"ft_transfer\",\n sender: signerId,\n });\n }\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(transactions.functionCall(\"memo\", { memo }, BigInt(\"250000000000000\"), BigInt(attachedDeposit)));\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n return transactions.createTransaction(signerId, publicKey, recipient, nonce + 1, txActions, blockHash);\n }\n\n async function serializeTransaction(transaction: Transaction) {\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { utils } = await import(\"near-api-js\");\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n return Buffer.from(serializedTx).toString(\"base64\");\n }\n\n async function createContractFunctionCall(params: ContractFunctionCallParams) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\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 + 1,\n actions,\n blockHash,\n );\n\n return transaction;\n }\n\n async function createAction(params: CreateActionParams) {\n const { transactions } = await import(\"near-api-js\");\n\n const action = transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n );\n\n return action;\n }\n\n async function signTransaction(transaction: Transaction): Promise<SignedTransaction> {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\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\";\n const receiptCreationCost = \"108059500000\";\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n const { baseDecimal } = getChainConfig(Chain.Near);\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: totalCostYocto.toString() });\n }\n\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 account_id: \"system\",\n args_base64: \"\",\n finality: \"final\",\n method_name: \"gas_price\",\n request_type: \"call_function\",\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): Promise<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): Promise<string> {\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({ args: args || {}, contractId, methodName });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"1\"),\n );\n\n const result = await account.signAndSendTransaction({ actions: [functionAction], receiverId: contractId });\n\n return result.transaction_outcome.id;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract<T extends Contract = Contract>(contractInterface: NearContractInterface): Promise<T> {\n const account = await getAccount();\n\n return createNearContract<T>({\n account,\n changeMethods: contractInterface.changeMethods,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n });\n }\n\n async function executeBatchTransaction(batch: BatchTransaction): Promise<string> {\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({ actions: batch.actions, receiverId: batch.receiverId });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ account, contractId });\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const { baseDecimal } = getChainConfig(Chain.Near);\n\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 const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12);\n const costInYoctoNear = gasInUnits;\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: costInYoctoNear });\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 {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n broadcastTransaction,\n callFunction,\n createAction,\n createContract,\n createContractFunctionCall,\n createSubAccount,\n createTransaction,\n estimateGas,\n estimateTransactionFee,\n executeBatchTransaction,\n getAddress,\n getBalance: getBalance(Chain.Near),\n getGasPrice,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n getSignerFromPhrase: (params: GetSignerFromPhraseParams) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n nep141,\n provider,\n serializeTransaction,\n signTransaction,\n transfer,\n validateAddress: await getValidateNearAddress(),\n };\n}\n",
|
|
10
10
|
"import type {\n ChainSigner,\n DerivationPathArray,\n GenericCreateTransactionParams,\n GenericTransferParams,\n} from \"@swapkit/helpers\";\nimport type { KeyPairSigner, Signer, transactions } from \"near-api-js\";\n\ninterface NearKeyPairSigner\n extends KeyPairSigner,\n Omit<ChainSigner<typeof transactions.Transaction, typeof transactions.SignedTransaction>, \"signTransaction\"> {}\n\ninterface NearGeneralSigner\n extends Signer,\n Omit<ChainSigner<typeof transactions.Transaction, typeof transactions.SignedTransaction>, \"signTransaction\"> {}\n\nexport type NearSigner = NearKeyPairSigner | NearGeneralSigner;\n\nexport type NearToolboxParams =\n | { signer?: NearSigner; accountId?: string }\n | { phrase?: string; index?: number; derivationPath?: DerivationPathArray };\n\nexport interface NearTransferParams extends GenericTransferParams {}\n\nexport interface NearConfig {\n networkId: \"mainnet\" | \"testnet\" | \"betanet\";\n nodeUrl: string;\n walletUrl?: string;\n helperUrl?: string;\n keyStore?: any;\n}\n\nexport interface NearFunctionCallParams {\n contractId: string;\n methodName: string;\n args: Uint8Array | Record<string, any>;\n deposit?: bigint | string | number;\n gas?: bigint | string | number;\n}\n\nexport interface NearCreateTransactionParams extends Omit<GenericCreateTransactionParams, \"feeRate\"> {\n attachedDeposit?: string;\n functionCall?: { methodName: string; args: object; attachedDeposit: string; gas: string; contractId: string };\n}\n\nexport * from \"./toolbox\";\nexport * from \"./types/contract\";\nexport * from \"./types/nep141\";\nexport * from \"./types/toolbox\";\n",
|
|
11
11
|
"import type { getNearToolbox } from \"./toolbox\";\n\nexport * from \"./helpers/core\";\nexport * from \"./helpers/gasEstimation\";\nexport * from \"./helpers/nep141\";\nexport * from \"./toolbox\";\nexport * from \"./types\";\n\nexport type NearWallet = Awaited<ReturnType<typeof getNearToolbox>>;\n\nexport type {\n NearCallParams,\n NearContractInterface,\n NearGasEstimateParams,\n} from \"./types/contract\";\nexport type {\n FungibleTokenMetadata,\n NEP141Contract,\n StorageBalance,\n StorageBalanceBounds,\n TokenTransferParams,\n} from \"./types/nep141\";\n"
|
|
12
12
|
],
|
|
13
|
-
"mappings": "otBAKA,eAAsB,CAAsB,EAAG,CAC7C,IAAQ,qBAAsB,KAAa,uBAC3C,MAAO,CAAC,IAAoB,CAE1B,GAAI,CACF,OAAO,EAAkB,CAAO,EAChC,KAAM,CACN,IAAM,EAAmB,wDAEzB,OAAO,EAAQ,QAAU,GAAK,EAAQ,QAAU,IAAM,EAAiB,KAAK,CAAO,IAKzF,eAAsB,CAAuB,CAAC,EAI3C,CACD,IAAQ,mBAAoB,KAAa,6BACjC,WAAY,KAAa,uBAE3B,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,GAA4B,CAAO,EAG5C,eAAsB,CAA2B,CAAC,EAAoB,CACpE,IAAQ,WAAY,KAAa,iCAC3B,EAAU,EAAQ,WAAW,CAAiB,EACpD,OAAO,GAA4B,CAAO,EAkB5C,SAAS,EAA2B,CAAC,EAA8B,CAGjE,OAFsB,IAAI,GAAgB,CAAO,EAKnD,eAAsB,CAAsB,CAAC,EAAoB,EAAmB,CAOlF,IAAM,GANW,MAAM,EAAS,MAAM,CACpC,WAAY,EACZ,SAAU,QACV,aAAc,sBAChB,CAAC,GAEuC,KAAK,KAAK,CAAC,IAAa,EAAI,WAAW,aAAe,YAAY,EAE1G,GAAI,CAAC,EACH,MAAM,IAAI,eAAa,
|
|
14
|
-
"debugId": "
|
|
13
|
+
"mappings": "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",
|
|
14
|
+
"debugId": "8C3E92F25946136B64756E2164756E21",
|
|
15
15
|
"names": []
|
|
16
16
|
}
|
package/dist/src/near/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var Rt=Object.create;var{getPrototypeOf:St,defineProperty:W,getOwnPropertyNames:Dt}=Object;var Lt=Object.prototype.hasOwnProperty;var P=(t,n,i)=>{i=t!=null?Rt(St(t)):{};let o=n||!t||!t.__esModule?W(i,"default",{value:t,enumerable:!0}):i;for(let T of Dt(t))if(!Lt.call(o,T))W(o,T,{get:()=>t[T],enumerable:!0});return o};var Gt=(t,n)=>{for(var i in n)W(t,i,{get:n[i],enumerable:!0,configurable:!0,set:(o)=>n[i]=()=>o})};var S=(t,n)=>()=>(t&&(n=t(t=0)),n);var N=((t)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(n,i)=>(typeof require<"u"?require:n)[i]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});import{derivationPathToString as pt,SwapKitError as bt}from"@swapkit/helpers";import{KeyPairSigner as Ut}from"near-api-js";async function G(){let{validateAccountId:t}=await import("near-sdk-js");return(n)=>{try{return t(n)}catch{let i=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return n.length>=2&&n.length<=64&&i.test(n)}}}async function p(t){let{parseSeedPhrase:n}=await import("near-seed-phrase"),{KeyPair:i}=await import("near-api-js"),o=t.index||0,T=t.derivationPath?pt(t.derivationPath.slice(0,3)):`m/44'/397'/${o}'`,{secretKey:m}=n(t.phrase,T),g=i.fromString(m);return tt(g)}async function B(t){let{KeyPair:n}=await import("near-api-js/lib/utils"),i=n.fromString(t);return tt(i)}function tt(t){return new c(t)}async function b(t,n){let o=(await t.query({account_id:n,finality:"final",request_type:"view_access_key_list"})).keys.find((E)=>E.access_key.permission==="FullAccess");if(!o)throw new bt("toolbox_near_invalid_address");let{utils:T}=await import("near-api-js"),m=T.PublicKey.fromString(o.public_key);return{nonce:o.access_key.nonce||0,publicKey:m}}var c;var M=S(()=>{c=class c extends Ut{#t;constructor(t){super(t);this.#t=t}getAddress(){let t=this.#t.getPublicKey(),n=Buffer.from(t.data).toString("hex");return Promise.resolve(n)}}});function Q(t){return"recipient"in t&&"amount"in t&&!("contractId"in t)}function Z(t){return"contractId"in t&&"methodName"in t}function $(t){return"actions"in t}function z(t){return"newAccountId"in t}function X(t){return"contractCode"in t}function H(t){return"customEstimator"in t}function V(t){let n=0;for(let i of t)switch(i.enum){case"transfer":n+=Number(C.SIMPLE_TRANSFER);break;case"functionCall":n+=Number(C.CONTRACT_CALL);break;case"createAccount":n+=Number(C.ACCOUNT_CREATION);break;case"deployContract":n+=Number(C.CONTRACT_DEPLOYMENT);break;case"addKey":n+=Number(C.ACCESS_KEY_ADDITION);break;case"deleteKey":n+=Number(C.ACCESS_KEY_DELETION);break;case"stake":n+=Number(C.STAKE);break;default:n+=Number(C.CONTRACT_CALL)}return n.toString()}function k(t){if(t==="ft_transfer"||t==="ft_transfer_call")return C.TOKEN_TRANSFER;if(t==="storage_deposit")return C.STORAGE_DEPOSIT;return C.CONTRACT_CALL}function Yt(t){return(BigInt(t)*BigInt(1000000000000)).toString()}function Ft(t){return(BigInt(t)/BigInt(1000000000000)).toString()}var C;var w=S(()=>{C={ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",ACCOUNT_CREATION:"30",CONTRACT_CALL:"150",CONTRACT_DEPLOYMENT:"200",SIMPLE_TRANSFER:"1",STAKE:"10",STORAGE_DEPOSIT:"150",TOKEN_TRANSFER:"150"}});async function U({account:t,contractId:n,viewMethods:i,changeMethods:o}){let{Contract:T}=await import("near-api-js");return new T(t,n,{changeMethods:o,useLocalViewExecution:!0,viewMethods:i})}async function j({contractId:t,account:n}){let i=(await import("bn.js")).default,o=await U({account:n,changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"],contractId:t,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"]}),T=async(m)=>{if(!await o.storage_balance_of({account_id:m})){let a=(await o.storage_balance_bounds())?.min||"1250000000000000000000";await o.storage_deposit({account_id:m},new i("100000000000000"),new i(a))}};return{balanceOf:(m)=>o.ft_balance_of({account_id:m}),contract:o,ensureStorage:T,metadata:()=>o.ft_metadata(),storageBalanceOf:(m)=>o.storage_balance_of({account_id:m}),storageDeposit:(m,g)=>o.storage_deposit({account_id:m},new i("100000000000000"),new i(g||"1250000000000000000000")),totalSupply:()=>o.ft_total_supply(),transfer:async(m,g,E)=>{return await T(m),o.ft_transfer({amount:g,memo:E,receiver_id:m},new i("100000000000000"),new i("1"))},transferCall:async(m,g,E,a)=>{return await T(m),o.ft_transfer_call({amount:g,memo:a,msg:E,receiver_id:m},new i("100000000000000"),new i("1"))}}}import{AssetValue as qt,getChainConfig as Jt}from"@swapkit/helpers";import{SwapKitApi as Wt}from"@swapkit/helpers/api";function ut(){function t(){let n=Date.now(),i=l||n;return l=i,n>l?n:i+1}return Bt+t().toString(36)}function rt(t){return async function(i,o=!0){let T=await Wt.getChainBalance({address:i,chain:t,scamFilter:o}),{baseDecimal:m}=Jt(t);return T.map(({identifier:g,value:E,decimal:a})=>{return new qt({decimal:a||m,identifier:g,value:E})})}}var Bt,l=0;var nt=S(()=>{Bt=typeof process<"u"&&process.pid?process.pid.toString(36):""});import{AssetValue as it,Chain as D,getChainConfig as et,getRPCUrl as Mt,SwapKitError as A}from"@swapkit/helpers";async function Qt(t){let{P:n,match:i}=await import("ts-pattern"),{providers:o}=await import("near-api-js"),T=await i(t).with({phrase:n.string},async(r)=>{return await p(r)}).with({signer:n.any},({signer:r})=>r).otherwise(()=>{return}),m=await Mt(D.Near),g=new o.JsonRpcProvider({url:m});async function E(r){let{Account:e}=await import("near-api-js"),f=r||await a();return new e(f,g,T)}async function a(){if(!T)throw new A("toolbox_near_no_signer");return await T.getAddress()}async function Tt(r){if(!T)throw new A("toolbox_near_no_signer");let e=await h({...r,sender:await a()});return I(await v(e))}async function h(r){let{recipient:e,assetValue:f,memo:s,attachedDeposit:O,sender:x,functionCall:_}=r,y=await G();if(!y(e))throw new A("toolbox_near_invalid_address",{recipient:e});if(!y(x))throw new A("toolbox_near_invalid_address",{signerId:x});if(_)return Y({..._,sender:x});if(!f.isGasAsset){let d=f.address;if(!d)throw new A("toolbox_near_missing_contract_address");return Y({args:{amount:f.getBaseValue("string"),memo:s||null,receiver_id:e},attachedDeposit:O||"1",contractId:d,gas:"250000000000000",methodName:"ft_transfer",sender:x})}let{publicKey:L,nonce:q}=await b(g,x),_t=f.getBaseValue("bigint"),{transactions:J,utils:At}=await import("near-api-js"),K=[J.transfer(_t)];if(s&&O)K.push(J.functionCall("memo",{memo:s},BigInt("250000000000000"),BigInt(O)));let at=await g.block({finality:"final"}),yt=At.serialize.base_decode(at.header.hash);return J.createTransaction(x,L,e,q+1,K,yt)}async function mt(r){let{SCHEMA:e}=await import("near-api-js/lib/transaction"),{utils:f}=await import("near-api-js"),s=f.serialize.serialize(e.Transaction,r);return Buffer.from(s).toString("base64")}async function Y(r){let{sender:e}=r,{publicKey:f,nonce:s}=await b(g,e),{transactions:O,utils:x}=await import("near-api-js"),_=await g.block({finality:"final"}),y=x.serialize.base_decode(_.header.hash),L=[O.functionCall(r.methodName,Buffer.from(JSON.stringify(r.args)),BigInt(r.gas),BigInt(r.attachedDeposit))];return O.createTransaction(e,f,r.contractId,s+1,L,y)}async function ft(r){let{transactions:e}=await import("near-api-js");return e.functionCall(r.methodName,Buffer.from(JSON.stringify(r.args)),BigInt(r.gas),BigInt(r.attachedDeposit))}async function v(r){if(!T)throw new A("toolbox_near_no_signer");let[e,f]=await T.signTransaction(r);return f}async function I(r){return(await g.sendTransaction(r)).transaction.hash}async function gt(r){if("assetValue"in r){let O=BigInt("115123062500")+BigInt("108059500000"),x=await Pt(),_=O*BigInt(x.toString()),{baseDecimal:y}=et(D.Near);return it.from({chain:D.Near,fromBaseDecimal:y,value:_.toString()})}let e=T?await E():void 0;return F(r,e)}async function Pt(){try{return await g.query({account_id:"system",args_base64:"",finality:"final",method_name:"gas_price",request_type:"call_function"})}catch{return"100000000"}}async function Nt(r,e,f){if(!T)throw new A("toolbox_near_no_signer");let s=await E(),{utils:O}=await import("near-api-js"),x=O.format.parseNearAmount(f)||"0";return(await s.createAccount(r,O.PublicKey.fromString(e),BigInt(x))).transaction.hash}async function st(r){try{if(!T)throw new A("toolbox_near_no_signer");let{transactions:e}=await import("near-api-js"),{contractId:f,methodName:s,args:O,deposit:x}=r,_=await E(),y=await F({args:O||{},contractId:f,methodName:s}),L=e.functionCall(s,O||{},y.getBaseValue("bigint"),BigInt(x||"1"));return(await _.signAndSendTransaction({actions:[L],receiverId:f})).transaction_outcome.id}catch(e){throw new A("toolbox_near_transfer_failed",{error:e})}}async function xt(r){let e=await E();return U({account:e,changeMethods:r.changeMethods,contractId:r.contractId,viewMethods:r.viewMethods})}async function Ct(r){if(!T)throw new A("toolbox_near_no_signer");if(r.actions.length===0)throw new A("toolbox_near_empty_batch");return(await(await E()).signAndSendTransaction({actions:r.actions,receiverId:r.receiverId})).transaction.hash}async function Et(r){let e=await E();return j({account:e,contractId:r})}async function F(r,e){let{baseDecimal:f}=et(D.Near),s=await i(r).when(Q,()=>C.SIMPLE_TRANSFER).when(Z,(_)=>k(_.methodName)).when($,(_)=>V(_.actions)).when(z,()=>C.ACCOUNT_CREATION).when(X,()=>C.CONTRACT_DEPLOYMENT).when(H,(_)=>{if(!e)throw new A("toolbox_near_no_account");return _.customEstimator(e)}).otherwise(()=>{throw new A("toolbox_near_invalid_gas_params")}),x=BigInt(s)*BigInt(1000000000000);return it.from({chain:D.Near,fromBaseDecimal:f,value:x})}async function Ot(){try{return(await g.gasPrice(null)).gas_price||"100000000"}catch(r){return"100000000"}}return{broadcastTransaction:I,callFunction:st,createAction:ft,createContract:xt,createContractFunctionCall:Y,createSubAccount:Nt,createTransaction:h,estimateGas:F,estimateTransactionFee:gt,executeBatchTransaction:Ct,getAddress:a,getBalance:rt(D.Near),getGasPrice:Ot,getPublicKey:async()=>T?(await T.getPublicKey()).toString():"",getSignerFromPhrase:(r)=>p(r),getSignerFromPrivateKey:B,nep141:Et,provider:g,serializeTransaction:mt,signTransaction:v,transfer:Tt,validateAddress:await G()}}var u=S(()=>{nt();M();w()});var ot=S(()=>{u()});var Zt={};Gt(Zt,{tgasToGas:()=>Yt,isSimpleTransfer:()=>Q,isCustomEstimator:()=>H,isContractDeployment:()=>X,isContractCall:()=>Z,isBatchTransaction:()=>$,isAccountCreation:()=>z,getValidateNearAddress:()=>G,getNearToolbox:()=>Qt,getNearSignerFromPrivateKey:()=>B,getNearSignerFromPhrase:()=>p,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>k,gasToTGas:()=>Ft,estimateBatchGas:()=>V,createNearContract:()=>U,createNEP141Token:()=>j,GAS_COSTS:()=>C});var $t=S(()=>{M();w();u();ot()});$t();export{Yt as tgasToGas,Q as isSimpleTransfer,H as isCustomEstimator,X as isContractDeployment,Z as isContractCall,$ as isBatchTransaction,z as isAccountCreation,G as getValidateNearAddress,Qt as getNearToolbox,B as getNearSignerFromPrivateKey,p as getNearSignerFromPhrase,b as getFullAccessPublicKey,k as getContractMethodGas,Ft as gasToTGas,V as estimateBatchGas,U as createNearContract,j as createNEP141Token,C as GAS_COSTS};
|
|
1
|
+
var Rt=Object.create;var{getPrototypeOf:St,defineProperty:W,getOwnPropertyNames:Dt}=Object;var Lt=Object.prototype.hasOwnProperty;var P=(t,n,i)=>{i=t!=null?Rt(St(t)):{};let o=n||!t||!t.__esModule?W(i,"default",{value:t,enumerable:!0}):i;for(let T of Dt(t))if(!Lt.call(o,T))W(o,T,{get:()=>t[T],enumerable:!0});return o};var Gt=(t,n)=>{for(var i in n)W(t,i,{get:n[i],enumerable:!0,configurable:!0,set:(o)=>n[i]=()=>o})};var S=(t,n)=>()=>(t&&(n=t(t=0)),n);var N=((t)=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(n,i)=>(typeof require<"u"?require:n)[i]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});import{derivationPathToString as pt,SwapKitError as bt}from"@swapkit/helpers";import{KeyPairSigner as Ut}from"near-api-js";async function G(){let{validateAccountId:t}=await import("near-sdk-js");return(n)=>{try{return t(n)}catch{let i=/^(([a-z\d]+[-_])*[a-z\d]+\.)*([a-z\d]+[-_])*[a-z\d]+$/;return n.length>=2&&n.length<=64&&i.test(n)}}}async function p(t){let{parseSeedPhrase:n}=await import("near-seed-phrase"),{KeyPair:i}=await import("near-api-js"),o=t.index||0,T=t.derivationPath?pt(t.derivationPath.slice(0,3)):`m/44'/397'/${o}'`,{secretKey:m}=n(t.phrase,T),g=i.fromString(m);return tt(g)}async function B(t){let{KeyPair:n}=await import("near-api-js/lib/utils"),i=n.fromString(t);return tt(i)}function tt(t){return new c(t)}async function b(t,n){let o=(await t.query({account_id:n,finality:"final",request_type:"view_access_key_list"})).keys.find((E)=>E.access_key.permission==="FullAccess");if(!o)throw new bt("toolbox_near_no_public_key_found");let{utils:T}=await import("near-api-js"),m=T.PublicKey.fromString(o.public_key);return{nonce:o.access_key.nonce||0,publicKey:m}}var c;var M=S(()=>{c=class c extends Ut{#t;constructor(t){super(t);this.#t=t}getAddress(){let t=this.#t.getPublicKey(),n=Buffer.from(t.data).toString("hex");return Promise.resolve(n)}}});function Q(t){return"recipient"in t&&"amount"in t&&!("contractId"in t)}function Z(t){return"contractId"in t&&"methodName"in t}function $(t){return"actions"in t}function z(t){return"newAccountId"in t}function X(t){return"contractCode"in t}function H(t){return"customEstimator"in t}function V(t){let n=0;for(let i of t)switch(i.enum){case"transfer":n+=Number(C.SIMPLE_TRANSFER);break;case"functionCall":n+=Number(C.CONTRACT_CALL);break;case"createAccount":n+=Number(C.ACCOUNT_CREATION);break;case"deployContract":n+=Number(C.CONTRACT_DEPLOYMENT);break;case"addKey":n+=Number(C.ACCESS_KEY_ADDITION);break;case"deleteKey":n+=Number(C.ACCESS_KEY_DELETION);break;case"stake":n+=Number(C.STAKE);break;default:n+=Number(C.CONTRACT_CALL)}return n.toString()}function k(t){if(t==="ft_transfer"||t==="ft_transfer_call")return C.TOKEN_TRANSFER;if(t==="storage_deposit")return C.STORAGE_DEPOSIT;return C.CONTRACT_CALL}function Yt(t){return(BigInt(t)*BigInt(1000000000000)).toString()}function Ft(t){return(BigInt(t)/BigInt(1000000000000)).toString()}var C;var w=S(()=>{C={ACCESS_KEY_ADDITION:"5",ACCESS_KEY_DELETION:"5",ACCOUNT_CREATION:"30",CONTRACT_CALL:"150",CONTRACT_DEPLOYMENT:"200",SIMPLE_TRANSFER:"1",STAKE:"10",STORAGE_DEPOSIT:"150",TOKEN_TRANSFER:"150"}});async function U({account:t,contractId:n,viewMethods:i,changeMethods:o}){let{Contract:T}=await import("near-api-js");return new T(t,n,{changeMethods:o,useLocalViewExecution:!0,viewMethods:i})}async function j({contractId:t,account:n}){let i=(await import("bn.js")).default,o=await U({account:n,changeMethods:["ft_transfer","ft_transfer_call","storage_deposit","storage_withdraw","storage_unregister"],contractId:t,viewMethods:["ft_balance_of","ft_total_supply","ft_metadata","storage_balance_of","storage_balance_bounds"]}),T=async(m)=>{if(!await o.storage_balance_of({account_id:m})){let a=(await o.storage_balance_bounds())?.min||"1250000000000000000000";await o.storage_deposit({account_id:m},new i("100000000000000"),new i(a))}};return{balanceOf:(m)=>o.ft_balance_of({account_id:m}),contract:o,ensureStorage:T,metadata:()=>o.ft_metadata(),storageBalanceOf:(m)=>o.storage_balance_of({account_id:m}),storageDeposit:(m,g)=>o.storage_deposit({account_id:m},new i("100000000000000"),new i(g||"1250000000000000000000")),totalSupply:()=>o.ft_total_supply(),transfer:async(m,g,E)=>{return await T(m),o.ft_transfer({amount:g,memo:E,receiver_id:m},new i("100000000000000"),new i("1"))},transferCall:async(m,g,E,a)=>{return await T(m),o.ft_transfer_call({amount:g,memo:a,msg:E,receiver_id:m},new i("100000000000000"),new i("1"))}}}import{AssetValue as qt,getChainConfig as Jt}from"@swapkit/helpers";import{SwapKitApi as Wt}from"@swapkit/helpers/api";function ut(){function t(){let n=Date.now(),i=l||n;return l=i,n>l?n:i+1}return Bt+t().toString(36)}function rt(t){return async function(i,o=!0){let T=await Wt.getChainBalance({address:i,chain:t,scamFilter:o}),{baseDecimal:m}=Jt(t);return T.map(({identifier:g,value:E,decimal:a})=>{return new qt({decimal:a||m,identifier:g,value:E})})}}var Bt,l=0;var nt=S(()=>{Bt=typeof process<"u"&&process.pid?process.pid.toString(36):""});import{AssetValue as it,Chain as D,getChainConfig as et,getRPCUrl as Mt,SwapKitError as A}from"@swapkit/helpers";async function Qt(t){let{P:n,match:i}=await import("ts-pattern"),{providers:o}=await import("near-api-js"),T=await i(t).with({phrase:n.string},async(r)=>{return await p(r)}).with({signer:n.any},({signer:r})=>r).otherwise(()=>{return}),m=await Mt(D.Near),g=new o.JsonRpcProvider({url:m});async function E(r){let{Account:e}=await import("near-api-js"),f=r||await a();return new e(f,g,T)}async function a(){if(!T)throw new A("toolbox_near_no_signer");return await T.getAddress()}async function Tt(r){if(!T)throw new A("toolbox_near_no_signer");let e=await h({...r,sender:await a()});return I(await v(e))}async function h(r){let{recipient:e,assetValue:f,memo:s,attachedDeposit:O,sender:x,functionCall:_}=r,y=await G();if(!y(e))throw new A("toolbox_near_invalid_address",{recipient:e});if(!y(x))throw new A("toolbox_near_invalid_address",{signerId:x});if(_)return Y({..._,sender:x});if(!f.isGasAsset){let d=f.address;if(!d)throw new A("toolbox_near_missing_contract_address");return Y({args:{amount:f.getBaseValue("string"),memo:s||null,receiver_id:e},attachedDeposit:O||"1",contractId:d,gas:"250000000000000",methodName:"ft_transfer",sender:x})}let{publicKey:L,nonce:q}=await b(g,x),_t=f.getBaseValue("bigint"),{transactions:J,utils:At}=await import("near-api-js"),K=[J.transfer(_t)];if(s&&O)K.push(J.functionCall("memo",{memo:s},BigInt("250000000000000"),BigInt(O)));let at=await g.block({finality:"final"}),yt=At.serialize.base_decode(at.header.hash);return J.createTransaction(x,L,e,q+1,K,yt)}async function mt(r){let{SCHEMA:e}=await import("near-api-js/lib/transaction"),{utils:f}=await import("near-api-js"),s=f.serialize.serialize(e.Transaction,r);return Buffer.from(s).toString("base64")}async function Y(r){let{sender:e}=r,{publicKey:f,nonce:s}=await b(g,e),{transactions:O,utils:x}=await import("near-api-js"),_=await g.block({finality:"final"}),y=x.serialize.base_decode(_.header.hash),L=[O.functionCall(r.methodName,Buffer.from(JSON.stringify(r.args)),BigInt(r.gas),BigInt(r.attachedDeposit))];return O.createTransaction(e,f,r.contractId,s+1,L,y)}async function ft(r){let{transactions:e}=await import("near-api-js");return e.functionCall(r.methodName,Buffer.from(JSON.stringify(r.args)),BigInt(r.gas),BigInt(r.attachedDeposit))}async function v(r){if(!T)throw new A("toolbox_near_no_signer");let[e,f]=await T.signTransaction(r);return f}async function I(r){return(await g.sendTransaction(r)).transaction.hash}async function gt(r){if("assetValue"in r){let O=BigInt("115123062500")+BigInt("108059500000"),x=await Pt(),_=O*BigInt(x.toString()),{baseDecimal:y}=et(D.Near);return it.from({chain:D.Near,fromBaseDecimal:y,value:_.toString()})}let e=T?await E():void 0;return F(r,e)}async function Pt(){try{return await g.query({account_id:"system",args_base64:"",finality:"final",method_name:"gas_price",request_type:"call_function"})}catch{return"100000000"}}async function Nt(r,e,f){if(!T)throw new A("toolbox_near_no_signer");let s=await E(),{utils:O}=await import("near-api-js"),x=O.format.parseNearAmount(f)||"0";return(await s.createAccount(r,O.PublicKey.fromString(e),BigInt(x))).transaction.hash}async function st(r){try{if(!T)throw new A("toolbox_near_no_signer");let{transactions:e}=await import("near-api-js"),{contractId:f,methodName:s,args:O,deposit:x}=r,_=await E(),y=await F({args:O||{},contractId:f,methodName:s}),L=e.functionCall(s,O||{},y.getBaseValue("bigint"),BigInt(x||"1"));return(await _.signAndSendTransaction({actions:[L],receiverId:f})).transaction_outcome.id}catch(e){throw new A("toolbox_near_transfer_failed",{error:e})}}async function xt(r){let e=await E();return U({account:e,changeMethods:r.changeMethods,contractId:r.contractId,viewMethods:r.viewMethods})}async function Ct(r){if(!T)throw new A("toolbox_near_no_signer");if(r.actions.length===0)throw new A("toolbox_near_empty_batch");return(await(await E()).signAndSendTransaction({actions:r.actions,receiverId:r.receiverId})).transaction.hash}async function Et(r){let e=await E();return j({account:e,contractId:r})}async function F(r,e){let{baseDecimal:f}=et(D.Near),s=await i(r).when(Q,()=>C.SIMPLE_TRANSFER).when(Z,(_)=>k(_.methodName)).when($,(_)=>V(_.actions)).when(z,()=>C.ACCOUNT_CREATION).when(X,()=>C.CONTRACT_DEPLOYMENT).when(H,(_)=>{if(!e)throw new A("toolbox_near_no_account");return _.customEstimator(e)}).otherwise(()=>{throw new A("toolbox_near_invalid_gas_params")}),x=BigInt(s)*BigInt(1000000000000);return it.from({chain:D.Near,fromBaseDecimal:f,value:x})}async function Ot(){try{return(await g.gasPrice(null)).gas_price||"100000000"}catch{return"100000000"}}return{broadcastTransaction:I,callFunction:st,createAction:ft,createContract:xt,createContractFunctionCall:Y,createSubAccount:Nt,createTransaction:h,estimateGas:F,estimateTransactionFee:gt,executeBatchTransaction:Ct,getAddress:a,getBalance:rt(D.Near),getGasPrice:Ot,getPublicKey:async()=>T?(await T.getPublicKey()).toString():"",getSignerFromPhrase:(r)=>p(r),getSignerFromPrivateKey:B,nep141:Et,provider:g,serializeTransaction:mt,signTransaction:v,transfer:Tt,validateAddress:await G()}}var u=S(()=>{nt();M();w()});var ot=S(()=>{u()});var Zt={};Gt(Zt,{tgasToGas:()=>Yt,isSimpleTransfer:()=>Q,isCustomEstimator:()=>H,isContractDeployment:()=>X,isContractCall:()=>Z,isBatchTransaction:()=>$,isAccountCreation:()=>z,getValidateNearAddress:()=>G,getNearToolbox:()=>Qt,getNearSignerFromPrivateKey:()=>B,getNearSignerFromPhrase:()=>p,getFullAccessPublicKey:()=>b,getContractMethodGas:()=>k,gasToTGas:()=>Ft,estimateBatchGas:()=>V,createNearContract:()=>U,createNEP141Token:()=>j,GAS_COSTS:()=>C});var $t=S(()=>{M();w();u();ot()});$t();export{Yt as tgasToGas,Q as isSimpleTransfer,H as isCustomEstimator,X as isContractDeployment,Z as isContractCall,$ as isBatchTransaction,z as isAccountCreation,G as getValidateNearAddress,Qt as getNearToolbox,B as getNearSignerFromPrivateKey,p as getNearSignerFromPhrase,b as getFullAccessPublicKey,k as getContractMethodGas,Ft as gasToTGas,V as estimateBatchGas,U as createNearContract,j as createNEP141Token,C as GAS_COSTS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=E37C0557C8965FF464756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -2,15 +2,15 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/near/helpers/core.ts", "../src/near/helpers/gasEstimation.ts", "../src/near/helpers/nep141.ts", "../src/utils.ts", "../src/near/toolbox.ts", "../src/near/types.ts", "../src/near/index.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, derivationPathToString, SwapKitError } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function getValidateNearAddress() {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return (address: string) => {\n // Use the official NEAR SDK validation function if available\n try {\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}\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 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 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 const response = await provider.query({\n account_id: accountId,\n finality: \"final\",\n request_type: \"view_access_key_list\",\n });\n\n const fullAccessKey = (response as any).keys.find((key: any) => key.access_key.permission === \"FullAccess\");\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"
|
|
5
|
+
"import type { Provider } from \"@near-js/providers\";\nimport { type DerivationPathArray, derivationPathToString, SwapKitError } from \"@swapkit/helpers\";\nimport { type KeyPair, KeyPairSigner } from \"near-api-js\";\nimport type { NearSigner } from \"../types\";\n\nexport async function getValidateNearAddress() {\n const { validateAccountId } = await import(\"near-sdk-js\");\n return (address: string) => {\n // Use the official NEAR SDK validation function if available\n try {\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}\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 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 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 const response = await provider.query({\n account_id: accountId,\n finality: \"final\",\n request_type: \"view_access_key_list\",\n });\n\n const fullAccessKey = (response as any).keys.find((key: any) => key.access_key.permission === \"FullAccess\");\n\n if (!fullAccessKey) {\n throw new SwapKitError(\"toolbox_near_no_public_key_found\");\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 { nonce, publicKey };\n}\n",
|
|
6
6
|
"import type { Account } from \"near-api-js\";\nimport type { NearGasEstimateParams } from \"../types/contract\";\n\nexport const GAS_COSTS = {\n ACCESS_KEY_ADDITION: \"5\",\n ACCESS_KEY_DELETION: \"5\",\n ACCOUNT_CREATION: \"30\",\n CONTRACT_CALL: \"150\",\n CONTRACT_DEPLOYMENT: \"200\",\n SIMPLE_TRANSFER: \"1\",\n STAKE: \"10\",\n STORAGE_DEPOSIT: \"150\",\n TOKEN_TRANSFER: \"150\",\n} as const;\n\nexport function isSimpleTransfer(params: NearGasEstimateParams): params is { recipient: string; amount: string } {\n return \"recipient\" in params && \"amount\" in params && !(\"contractId\" in params);\n}\n\nexport function isContractCall(\n params: NearGasEstimateParams,\n): params is { contractId: string; methodName: string; args?: Record<string, any>; attachedDeposit?: string } {\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(\n params: NearGasEstimateParams,\n): params is { newAccountId: string; publicKey?: string } {\n return \"newAccountId\" in params;\n}\n\nexport function isContractDeployment(params: NearGasEstimateParams): params is { contractCode: Uint8Array } {\n return \"contractCode\" in params;\n}\n\nexport function isCustomEstimator(\n params: NearGasEstimateParams,\n): params is { customEstimator: (account: Account) => Promise<string> } {\n return \"customEstimator\" in params;\n}\n\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\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\nexport function tgasToGas(tgas: string): string {\n return (BigInt(tgas) * BigInt(10 ** 12)).toString();\n}\n\nexport function gasToTGas(gas: string): string {\n return (BigInt(gas) / BigInt(10 ** 12)).toString();\n}\n",
|
|
7
7
|
"import type { Account, Contract } from \"near-api-js\";\n\nconst DEFAULT_STORAGE_DEPOSIT = \"1250000000000000000000\"; // 0.00125 NEAR\n\n// NEP-141 metadata interface\nexport interface NEP141Metadata {\n spec: string;\n name: string;\n symbol: string;\n icon?: string;\n reference?: string;\n reference_hash?: string;\n decimals: number;\n}\n\n// Storage balance response\nexport interface StorageBalance {\n total: string;\n available: string;\n}\n\n// Storage balance bounds\nexport interface StorageBalanceBounds {\n min: string;\n max?: string;\n}\n\n// BN.js is dynamically imported, but we need the type\n// Using any here is acceptable as BN.js doesn't export proper TypeScript types\ntype BN = any; // BN.js instance\n\n// Define NEP-141 contract interface\nexport interface 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<NEP141Metadata>;\n storage_balance_of(args: { account_id: string }): Promise<StorageBalance | null>;\n storage_balance_bounds(): Promise<StorageBalanceBounds>;\n\n // Change methods\n ft_transfer(args: { receiver_id: string; amount: string; memo?: string }, gas: BN, deposit: BN): Promise<void>;\n ft_transfer_call(\n args: { receiver_id: string; amount: string; msg: string; memo?: string },\n gas: BN,\n deposit: BN,\n ): Promise<void>;\n storage_deposit(\n args: { account_id?: string; registration_only?: boolean },\n gas: BN,\n deposit: BN,\n ): Promise<StorageBalance>;\n storage_withdraw(args: { amount?: string }, gas: BN, deposit?: BN): Promise<StorageBalance>;\n storage_unregister(force?: boolean, gas?: BN): Promise<boolean>;\n}\n\nexport type NEP141Token = {\n transfer: (receiverId: string, amount: string, memo?: string) => Promise<void>;\n transferCall: (receiverId: string, amount: string, msg: string, memo?: string) => Promise<void>;\n balanceOf: (accountId: string) => Promise<string>;\n totalSupply: () => Promise<string>;\n metadata: () => Promise<NEP141Metadata>;\n storageBalanceOf: (accountId: string) => Promise<StorageBalance | null>;\n storageDeposit: (accountId?: string, amount?: string) => Promise<StorageBalance>;\n ensureStorage: (accountId: string) => Promise<void>;\n contract: NEP141Contract;\n};\n\n// Create a Near contract instance\nexport async function createNearContract<T extends Contract>({\n account,\n contractId,\n viewMethods,\n changeMethods,\n}: {\n account: Account;\n contractId: string;\n viewMethods: string[];\n changeMethods: string[];\n}): Promise<T> {\n const { Contract } = await import(\"near-api-js\");\n\n return new Contract(account, contractId, {\n changeMethods,\n useLocalViewExecution: true, // Enable local view execution for efficiency\n viewMethods,\n }) as T;\n}\n\nexport async function createNEP141Token({\n contractId,\n account,\n}: {\n contractId: string;\n account: Account;\n}): Promise<NEP141Token> {\n const BN = (await import(\"bn.js\")).default;\n\n const contract = await createNearContract<NEP141Contract>({\n account,\n changeMethods: [\"ft_transfer\", \"ft_transfer_call\", \"storage_deposit\", \"storage_withdraw\", \"storage_unregister\"],\n contractId,\n viewMethods: [\"ft_balance_of\", \"ft_total_supply\", \"ft_metadata\", \"storage_balance_of\", \"storage_balance_bounds\"],\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 balanceOf: (accountId: string) => contract.ft_balance_of({ account_id: accountId }),\n\n // Raw contract access for advanced use cases\n contract,\n\n ensureStorage: ensureStorageFor,\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 totalSupply: () => contract.ft_total_supply(),\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 { amount, memo, receiver_id: receiverId },\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 { amount, memo, msg, receiver_id: receiverId },\n new BN(\"100000000000000\"), // 100 TGas\n new BN(\"1\"), // 1 yoctoNEAR for security\n );\n },\n };\n}\n",
|
|
8
8
|
"import { AssetValue, type Chain, getChainConfig } from \"@swapkit/helpers\";\nimport { SwapKitApi } from \"@swapkit/helpers/api\";\n\nconst pid = typeof process !== \"undefined\" && process.pid ? process.pid.toString(36) : \"\";\n\nlet last = 0;\nexport function uniqid() {\n function now() {\n const time = Date.now();\n const lastTime = last || time;\n last = lastTime;\n\n return time > last ? time : lastTime + 1;\n }\n\n return pid + now().toString(36);\n}\n\nexport function getBalance<T extends Chain>(chain: T) {\n return async function getBalance(address: string, scamFilter = true) {\n const balances = await SwapKitApi.getChainBalance({ address, chain, scamFilter });\n const { baseDecimal } = getChainConfig(chain);\n return balances.map(({ identifier, value, decimal }) => {\n return new AssetValue({ decimal: decimal || baseDecimal, identifier, value });\n });\n };\n}\n",
|
|
9
|
-
"import { AssetValue, Chain, getChainConfig, getRPCUrl, SwapKitError } from \"@swapkit/helpers\";\nimport type { Account, Contract } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport { getBalance } from \"../utils\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n getValidateNearAddress,\n} from \"./helpers/core\";\nimport {\n estimateBatchGas,\n GAS_COSTS,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token, createNearContract } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\nimport type {\n BatchTransaction,\n ContractFunctionCallParams,\n CreateActionParams,\n GetSignerFromPhraseParams,\n NearToolbox,\n} from \"./types/toolbox\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams): Promise<NearToolbox> {\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 = await getRPCUrl(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 transaction = await createTransaction({ ...params, sender: await getAddress() });\n\n return broadcastTransaction(await signTransaction(transaction));\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, attachedDeposit, sender: signerId, functionCall } = params;\n const validateNearAddress = await getValidateNearAddress();\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { recipient: recipient });\n }\n\n if (!validateNearAddress(signerId)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { signerId: signerId });\n }\n\n if (functionCall) {\n return createContractFunctionCall({ ...functionCall, sender: signerId });\n }\n\n if (!assetValue.isGasAsset) {\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n return createContractFunctionCall({\n args: { amount: assetValue.getBaseValue(\"string\"), memo: memo || null, receiver_id: recipient },\n attachedDeposit: attachedDeposit || \"1\",\n contractId,\n gas: \"250000000000000\",\n methodName: \"ft_transfer\",\n sender: signerId,\n });\n }\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(transactions.functionCall(\"memo\", { memo }, BigInt(\"250000000000000\"), BigInt(attachedDeposit)));\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n return transactions.createTransaction(signerId, publicKey, recipient, nonce + 1, txActions, blockHash);\n }\n\n async function serializeTransaction(transaction: Transaction) {\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { utils } = await import(\"near-api-js\");\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n return Buffer.from(serializedTx).toString(\"base64\");\n }\n\n async function createContractFunctionCall(params: ContractFunctionCallParams) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\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 + 1,\n actions,\n blockHash,\n );\n\n return transaction;\n }\n\n async function createAction(params: CreateActionParams) {\n const { transactions } = await import(\"near-api-js\");\n\n const action = transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n );\n\n return action;\n }\n\n async function signTransaction(transaction: Transaction): Promise<SignedTransaction> {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\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\";\n const receiptCreationCost = \"108059500000\";\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n const { baseDecimal } = getChainConfig(Chain.Near);\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: totalCostYocto.toString() });\n }\n\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 account_id: \"system\",\n args_base64: \"\",\n finality: \"final\",\n method_name: \"gas_price\",\n request_type: \"call_function\",\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): Promise<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): Promise<string> {\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({ args: args || {}, contractId, methodName });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"1\"),\n );\n\n const result = await account.signAndSendTransaction({ actions: [functionAction], receiverId: contractId });\n\n return result.transaction_outcome.id;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract<T extends Contract = Contract>(contractInterface: NearContractInterface): Promise<T> {\n const account = await getAccount();\n\n return createNearContract<T>({\n account,\n changeMethods: contractInterface.changeMethods,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n });\n }\n\n async function executeBatchTransaction(batch: BatchTransaction): Promise<string> {\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({ actions: batch.actions, receiverId: batch.receiverId });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ account, contractId });\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const { baseDecimal } = getChainConfig(Chain.Near);\n\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 const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12);\n const costInYoctoNear = gasInUnits;\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: costInYoctoNear });\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 broadcastTransaction,\n callFunction,\n createAction,\n createContract,\n createContractFunctionCall,\n createSubAccount,\n createTransaction,\n estimateGas,\n estimateTransactionFee,\n executeBatchTransaction,\n getAddress,\n getBalance: getBalance(Chain.Near),\n getGasPrice,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n getSignerFromPhrase: (params: GetSignerFromPhraseParams) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n nep141,\n provider,\n serializeTransaction,\n signTransaction,\n transfer,\n validateAddress: await getValidateNearAddress(),\n };\n}\n",
|
|
9
|
+
"import { AssetValue, Chain, getChainConfig, getRPCUrl, SwapKitError } from \"@swapkit/helpers\";\nimport type { Account, Contract } from \"near-api-js\";\nimport type { SignedTransaction, Transaction } from \"near-api-js/lib/transaction\";\nimport { getBalance } from \"../utils\";\nimport {\n getFullAccessPublicKey,\n getNearSignerFromPhrase,\n getNearSignerFromPrivateKey,\n getValidateNearAddress,\n} from \"./helpers/core\";\nimport {\n estimateBatchGas,\n GAS_COSTS,\n getContractMethodGas,\n isAccountCreation,\n isBatchTransaction,\n isContractCall,\n isContractDeployment,\n isCustomEstimator,\n isSimpleTransfer,\n} from \"./helpers/gasEstimation\";\nimport { createNEP141Token, createNearContract } from \"./helpers/nep141\";\nimport type {\n NearCreateTransactionParams,\n NearFunctionCallParams,\n NearToolboxParams,\n NearTransferParams,\n} from \"./types\";\nimport type { NearContractInterface, NearGasEstimateParams } from \"./types/contract\";\nimport type {\n BatchTransaction,\n ContractFunctionCallParams,\n CreateActionParams,\n GetSignerFromPhraseParams,\n NearToolbox,\n} from \"./types/toolbox\";\n\nexport async function getNearToolbox(toolboxParams?: NearToolboxParams): Promise<NearToolbox> {\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 = await getRPCUrl(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 transaction = await createTransaction({ ...params, sender: await getAddress() });\n\n return broadcastTransaction(await signTransaction(transaction));\n }\n\n async function createTransaction(params: NearCreateTransactionParams) {\n const { recipient, assetValue, memo, attachedDeposit, sender: signerId, functionCall } = params;\n const validateNearAddress = await getValidateNearAddress();\n\n if (!validateNearAddress(recipient)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { recipient: recipient });\n }\n\n if (!validateNearAddress(signerId)) {\n throw new SwapKitError(\"toolbox_near_invalid_address\", { signerId: signerId });\n }\n\n if (functionCall) {\n return createContractFunctionCall({ ...functionCall, sender: signerId });\n }\n\n if (!assetValue.isGasAsset) {\n const contractId = assetValue.address;\n if (!contractId) {\n throw new SwapKitError(\"toolbox_near_missing_contract_address\");\n }\n\n return createContractFunctionCall({\n args: { amount: assetValue.getBaseValue(\"string\"), memo: memo || null, receiver_id: recipient },\n attachedDeposit: attachedDeposit || \"1\",\n contractId,\n gas: \"250000000000000\",\n methodName: \"ft_transfer\",\n sender: signerId,\n });\n }\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, signerId);\n const baseAmount = assetValue.getBaseValue(\"bigint\");\n\n const { transactions, utils } = await import(\"near-api-js\");\n\n const txActions = [transactions.transfer(baseAmount)];\n\n if (memo && attachedDeposit) {\n txActions.push(transactions.functionCall(\"memo\", { memo }, BigInt(\"250000000000000\"), BigInt(attachedDeposit)));\n }\n\n const block = await provider.block({ finality: \"final\" });\n const blockHash = utils.serialize.base_decode(block.header.hash);\n\n return transactions.createTransaction(signerId, publicKey, recipient, nonce + 1, txActions, blockHash);\n }\n\n async function serializeTransaction(transaction: Transaction) {\n const { SCHEMA } = await import(\"near-api-js/lib/transaction\");\n const { utils } = await import(\"near-api-js\");\n\n const serializedTx = utils.serialize.serialize(SCHEMA.Transaction, transaction);\n return Buffer.from(serializedTx).toString(\"base64\");\n }\n\n async function createContractFunctionCall(params: ContractFunctionCallParams) {\n const { sender: accountId } = params;\n\n const { publicKey, nonce } = await getFullAccessPublicKey(provider, accountId);\n\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 + 1,\n actions,\n blockHash,\n );\n\n return transaction;\n }\n\n async function createAction(params: CreateActionParams) {\n const { transactions } = await import(\"near-api-js\");\n\n const action = transactions.functionCall(\n params.methodName,\n Buffer.from(JSON.stringify(params.args)),\n BigInt(params.gas),\n BigInt(params.attachedDeposit),\n );\n\n return action;\n }\n\n async function signTransaction(transaction: Transaction): Promise<SignedTransaction> {\n if (!signer) {\n throw new SwapKitError(\"toolbox_near_no_signer\");\n }\n\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\";\n const receiptCreationCost = \"108059500000\";\n\n const totalGasUnits = BigInt(baseTransferCost) + BigInt(receiptCreationCost);\n\n const gasPrice = await getCurrentGasPrice();\n\n const totalCostYocto = totalGasUnits * BigInt(gasPrice.toString());\n const { baseDecimal } = getChainConfig(Chain.Near);\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: totalCostYocto.toString() });\n }\n\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 account_id: \"system\",\n args_base64: \"\",\n finality: \"final\",\n method_name: \"gas_price\",\n request_type: \"call_function\",\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): Promise<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): Promise<string> {\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({ args: args || {}, contractId, methodName });\n\n const functionAction = transactions.functionCall(\n methodName,\n args || {},\n estimatedGas.getBaseValue(\"bigint\"),\n BigInt(deposit || \"1\"),\n );\n\n const result = await account.signAndSendTransaction({ actions: [functionAction], receiverId: contractId });\n\n return result.transaction_outcome.id;\n } catch (error) {\n throw new SwapKitError(\"toolbox_near_transfer_failed\", { error });\n }\n }\n\n // Create typed contract interface\n async function createContract<T extends Contract = Contract>(contractInterface: NearContractInterface): Promise<T> {\n const account = await getAccount();\n\n return createNearContract<T>({\n account,\n changeMethods: contractInterface.changeMethods,\n contractId: contractInterface.contractId,\n viewMethods: contractInterface.viewMethods,\n });\n }\n\n async function executeBatchTransaction(batch: BatchTransaction): Promise<string> {\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({ actions: batch.actions, receiverId: batch.receiverId });\n\n return result.transaction.hash;\n }\n\n async function nep141(contractId: string) {\n const account = await getAccount();\n return createNEP141Token({ account, contractId });\n }\n\n async function estimateGas(params: NearGasEstimateParams, account?: Account) {\n const { baseDecimal } = getChainConfig(Chain.Near);\n\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 const gasInUnits = BigInt(gasInTGas) * BigInt(10 ** 12);\n const costInYoctoNear = gasInUnits;\n\n return AssetValue.from({ chain: Chain.Near, fromBaseDecimal: baseDecimal, value: costInYoctoNear });\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 {\n // Fallback to default\n return \"100000000\";\n }\n }\n\n return {\n broadcastTransaction,\n callFunction,\n createAction,\n createContract,\n createContractFunctionCall,\n createSubAccount,\n createTransaction,\n estimateGas,\n estimateTransactionFee,\n executeBatchTransaction,\n getAddress,\n getBalance: getBalance(Chain.Near),\n getGasPrice,\n getPublicKey: async () => (signer ? (await signer.getPublicKey()).toString() : \"\"),\n getSignerFromPhrase: (params: GetSignerFromPhraseParams) => getNearSignerFromPhrase(params),\n getSignerFromPrivateKey: getNearSignerFromPrivateKey,\n nep141,\n provider,\n serializeTransaction,\n signTransaction,\n transfer,\n validateAddress: await getValidateNearAddress(),\n };\n}\n",
|
|
10
10
|
"import type {\n ChainSigner,\n DerivationPathArray,\n GenericCreateTransactionParams,\n GenericTransferParams,\n} from \"@swapkit/helpers\";\nimport type { KeyPairSigner, Signer, transactions } from \"near-api-js\";\n\ninterface NearKeyPairSigner\n extends KeyPairSigner,\n Omit<ChainSigner<typeof transactions.Transaction, typeof transactions.SignedTransaction>, \"signTransaction\"> {}\n\ninterface NearGeneralSigner\n extends Signer,\n Omit<ChainSigner<typeof transactions.Transaction, typeof transactions.SignedTransaction>, \"signTransaction\"> {}\n\nexport type NearSigner = NearKeyPairSigner | NearGeneralSigner;\n\nexport type NearToolboxParams =\n | { signer?: NearSigner; accountId?: string }\n | { phrase?: string; index?: number; derivationPath?: DerivationPathArray };\n\nexport interface NearTransferParams extends GenericTransferParams {}\n\nexport interface NearConfig {\n networkId: \"mainnet\" | \"testnet\" | \"betanet\";\n nodeUrl: string;\n walletUrl?: string;\n helperUrl?: string;\n keyStore?: any;\n}\n\nexport interface NearFunctionCallParams {\n contractId: string;\n methodName: string;\n args: Uint8Array | Record<string, any>;\n deposit?: bigint | string | number;\n gas?: bigint | string | number;\n}\n\nexport interface NearCreateTransactionParams extends Omit<GenericCreateTransactionParams, \"feeRate\"> {\n attachedDeposit?: string;\n functionCall?: { methodName: string; args: object; attachedDeposit: string; gas: string; contractId: string };\n}\n\nexport * from \"./toolbox\";\nexport * from \"./types/contract\";\nexport * from \"./types/nep141\";\nexport * from \"./types/toolbox\";\n",
|
|
11
11
|
"import type { getNearToolbox } from \"./toolbox\";\n\nexport * from \"./helpers/core\";\nexport * from \"./helpers/gasEstimation\";\nexport * from \"./helpers/nep141\";\nexport * from \"./toolbox\";\nexport * from \"./types\";\n\nexport type NearWallet = Awaited<ReturnType<typeof getNearToolbox>>;\n\nexport type {\n NearCallParams,\n NearContractInterface,\n NearGasEstimateParams,\n} from \"./types/contract\";\nexport type {\n FungibleTokenMetadata,\n NEP141Contract,\n StorageBalance,\n StorageBalanceBounds,\n TokenTransferParams,\n} from \"./types/nep141\";\n"
|
|
12
12
|
],
|
|
13
|
-
"mappings": "gsBACA,iCAAmC,mBAAwB,0BAC3D,wBAAuB,qBAGvB,eAAsB,CAAsB,EAAG,CAC7C,IAAQ,qBAAsB,KAAa,uBAC3C,MAAO,CAAC,IAAoB,CAE1B,GAAI,CACF,OAAO,EAAkB,CAAO,EAChC,KAAM,CACN,IAAM,EAAmB,wDAEzB,OAAO,EAAQ,QAAU,GAAK,EAAQ,QAAU,IAAM,EAAiB,KAAK,CAAO,IAKzF,eAAsB,CAAuB,CAAC,EAI3C,CACD,IAAQ,mBAAoB,KAAa,6BACjC,WAAY,KAAa,uBAE3B,EAAQ,EAAO,OAAS,EACxB,EAAiB,EAAO,eAC1B,GAAuB,EAAO,eAAe,MAAM,EAAG,CAAC,CAA6B,EACpF,cAAc,MAEV,aAAc,EAAgB,EAAO,OAAQ,CAAc,EAC7D,EAAU,EAAQ,WAAW,CAAgB,EAEnD,OAAO,GAA4B,CAAO,EAG5C,eAAsB,CAA2B,CAAC,EAAoB,CACpE,IAAQ,WAAY,KAAa,iCAC3B,EAAU,EAAQ,WAAW,CAAiB,EACpD,OAAO,GAA4B,CAAO,EAkB5C,SAAS,EAA2B,CAAC,EAA8B,CAGjE,OAFsB,IAAI,EAAgB,CAAO,EAKnD,eAAsB,CAAsB,CAAC,EAAoB,EAAmB,CAOlF,IAAM,GANW,MAAM,EAAS,MAAM,CACpC,WAAY,EACZ,SAAU,QACV,aAAc,sBAChB,CAAC,GAEuC,KAAK,KAAK,CAAC,IAAa,EAAI,WAAW,aAAe,YAAY,EAE1G,GAAI,CAAC,EACH,MAAM,IAAI,GAAa,
|
|
14
|
-
"debugId": "
|
|
13
|
+
"mappings": "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",
|
|
14
|
+
"debugId": "E37C0557C8965FF464756E2164756E21",
|
|
15
15
|
"names": []
|
|
16
16
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var y=Object.create;var{getPrototypeOf:A,defineProperty:L,getOwnPropertyNames:h,getOwnPropertyDescriptor:p}=Object,k=Object.prototype.hasOwnProperty;var
|
|
1
|
+
var y=Object.create;var{getPrototypeOf:A,defineProperty:L,getOwnPropertyNames:h,getOwnPropertyDescriptor:p}=Object,k=Object.prototype.hasOwnProperty;var O=(j,q,w)=>{w=j!=null?y(A(j)):{};let B=q||!j||!j.__esModule?L(w,"default",{value:j,enumerable:!0}):w;for(let F of h(j))if(!k.call(B,F))L(B,F,{get:()=>j[F],enumerable:!0});return B},D=new WeakMap,C=(j)=>{var q=D.get(j),w;if(q)return q;if(q=L({},"__esModule",{value:!0}),j&&typeof j==="object"||typeof j==="function")h(j).map((B)=>!k.call(q,B)&&L(q,B,{get:()=>j[B],enumerable:!(w=p(j,B))||w.enumerable}));return D.set(j,q),q};var P=(j,q)=>{for(var w in q)L(j,w,{get:q[w],enumerable:!0,configurable:!0,set:(B)=>q[w]=()=>B})};var T=(j,q)=>()=>(j&&(q=j(j=0)),q);async function l(j){try{let q=await fetch(`https://lite-api.jup.ag/tokens/v1/token/${j}`);if(!q.ok)return null;return await q.json()}catch{return null}}async function u(j){let q=await X(),{PublicKey:w}=await import("@solana/web3.js"),{TOKEN_PROGRAM_ID:B}=await import("@solana/spl-token"),F=new w(j),J=[],G=await q.getBalance(F);if(G>0){let{baseDecimal:Q}=z.getChainConfig(z.Chain.Solana);J.push(z.AssetValue.from({chain:z.Chain.Solana,fromBaseDecimal:Q,value:G}))}let N=await q.getParsedTokenAccountsByOwner(F,{programId:B});for(let{account:Q}of N.value){let R=Q.data.parsed.info,U=R.mint,Y=R.tokenAmount.amount;if(Number(Y)===0)continue;let _=await l(U),$=_?.symbol||"UNKNOWN",Z=_?.decimals||R.tokenAmount.decimals;J.push(z.AssetValue.from({asset:`${z.Chain.Solana}.${$}-${U}`,fromBaseDecimal:Z,value:Y}))}return J}async function x(){let{PublicKey:j}=await import("@solana/web3.js");return(q)=>{try{let w=new j(q);return j.isOnCurve(w.toBytes())}catch{return!1}}}async function m(j){let q=j&&"index"in j?j.index||0:0,w=z.derivationPathToString(j&&"derivationPath"in j&&j.derivationPath?j.derivationPath:z.updateDerivationPath(z.NetworkDerivationPath[z.Chain.Solana],{index:q})),B=await W.match(j).with({phrase:W.P.string},({phrase:G})=>M({derivationPath:w,phrase:G})).with({signer:W.P.any},({signer:G})=>G).otherwise(()=>{return});function F(){return B?.publicKey?v(B.publicKey):""}function J(G){let N=G||F();if(!N)throw new z.SwapKitError("core_wallet_connection_not_found");return u(N)}return{broadcastTransaction:I(X),createKeysForPath:M,createTransaction:H(X),createTransactionFromInstructions:a,estimateTransactionFee:d(X),getAddress:F,getAddressFromPubKey:v,getAddressValidator:x,getBalance:J,getConnection:X,getPubkeyFromAddress:S,signTransaction:r(X,B),transfer:o(X,B)}}function d(j){return async({recipient:q,assetValue:w,memo:B,isProgramDerivedAddress:F,sender:J})=>{let G=await j(),Q=(await H(j)({assetValue:w,isProgramDerivedAddress:F,memo:B,recipient:q,sender:J})).compileMessage(),R=await G.getFeeForMessage(Q);if(R.value===null)throw new z.SwapKitError("toolbox_solana_fee_estimation_failed","Could not estimate Solana fee.");let{baseDecimal:U}=z.getChainConfig(z.Chain.Solana);return z.AssetValue.from({chain:z.Chain.Solana,fromBaseDecimal:U,value:R.value})}}async function X(){let{Connection:j}=await import("@solana/web3.js"),q=await z.getRPCUrl(z.Chain.Solana);return new j(q,"confirmed")}function g(j){return async({assetValue:q,recipient:w,sender:B,isProgramDerivedAddress:F})=>{let J=await j(),G=await S(B);if(q.isGasAsset){let{Transaction:N,SystemProgram:Q,PublicKey:R}=await import("@solana/web3.js");return new N().add(Q.transfer({fromPubkey:G,lamports:q.getBaseValue("number"),toPubkey:new R(w)}))}if(q.address)return c({amount:q.getBaseValue("number"),connection:J,decimals:q.decimal,from:G,isProgramDerivedAddress:F,recipient:w,tokenAddress:q.address});return}}async function c({tokenAddress:j,recipient:q,from:w,connection:B,amount:F,decimals:J,isProgramDerivedAddress:G}){let{getAssociatedTokenAddress:N,getAccount:Q,createAssociatedTokenAccountInstruction:R,createTransferCheckedInstruction:U}=await import("@solana/spl-token"),{Transaction:Y,PublicKey:_}=await import("@solana/web3.js"),$=new Y,Z=new _(j),b=await N(Z,w),f=new _(q),E=await N(Z,f,G),V=!1;try{await Q(B,E),V=!0}catch{}if(!V)$.add(R(w,E,f,Z));return $.add(U(b,Z,E,w,F,J)),$}function H(j){return async({recipient:q,assetValue:w,memo:B,isProgramDerivedAddress:F,sender:J})=>{let{createMemoInstruction:G}=await import("@solana/spl-memo"),N=await S(J),Q=await x();if(!(F||Q(q)))throw new z.SwapKitError("core_transaction_invalid_recipient_address");let R=await j(),U=await g(j)({assetValue:w,isProgramDerivedAddress:F,recipient:q,sender:J});if(!U)throw new z.SwapKitError("core_transaction_invalid_sender_address");if(B)U.add(G(B));let Y=await R.getLatestBlockhash();return U.recentBlockhash=Y.blockhash,U.feePayer=N,U}}async function a({instructions:j}){let{Transaction:q}=await import("@solana/web3.js"),w=new q().add(...j);if(!w)throw new z.SwapKitError("core_transaction_invalid_sender_address");return w}function o(j,q){return async({recipient:w,assetValue:B,memo:F,isProgramDerivedAddress:J})=>{if(!q)throw new z.SwapKitError("core_transaction_invalid_sender_address");let G=q.publicKey?.toString()??(await q.connect()).publicKey.toString(),N=await H(j)({assetValue:B,isProgramDerivedAddress:J,memo:F,recipient:w,sender:G});if("signTransaction"in q){let Q=await q.signTransaction(N);return I(j)(Q)}return N.sign(q),I(j)(N)}}function I(j){return async(q)=>{return(await j()).sendRawTransaction(q.serialize())}}function r(j,q){return async(w)=>{let{VersionedTransaction:B}=await import("@solana/web3.js");if(!q)throw new z.SwapKitError("toolbox_solana_no_signer");if(!(w instanceof B)){let J=await(await j()).getLatestBlockhash();w.recentBlockhash=J.blockhash,w.feePayer=q.publicKey||void 0}if("connect"in q)return await q.signTransaction(w);return await w.sign([q]),w}}async function M({phrase:j,derivationPath:q=z.DerivationPath.SOL}){let{HDKey:w}=await import("micro-key-producer/slip10.js"),{mnemonicToSeedSync:B}=await import("@scure/bip39"),{Keypair:F}=await import("@solana/web3.js"),J=B(j),G=w.fromMasterSeed(J);return F.fromSeed(G.derive(q,!0).privateKey)}function v(j){return j.toString()}async function S(j){let{PublicKey:q}=await import("@solana/web3.js");return new q(j)}var z,W;var K=T(()=>{z=require("@swapkit/helpers"),W=require("ts-pattern")});var s={};P(s,{getSolanaToolbox:()=>m,getSolanaAddressValidator:()=>x,createKeysForPath:()=>M});module.exports=C(s);var t=T(()=>{K()});t();
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=94732C88A2A5B1DC64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|