@galacticcouncil/xc-sdk 1.0.0 → 1.1.0-pr297-4f08471
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/build/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var xn=Object.create;var Ft=Object.defineProperty;var Sn=Object.getOwnPropertyDescriptor;var Pn=Object.getOwnPropertyNames;var Tn=Object.getPrototypeOf,Bn=Object.prototype.hasOwnProperty;var En=(u,t)=>{for(var e in t)Ft(u,e,{get:t[e],enumerable:!0})},ve=(u,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Pn(t))!Bn.call(u,n)&&n!==e&&Ft(u,n,{get:()=>t[n],enumerable:!(s=Sn(t,n))||s.enumerable});return u};var In=(u,t,e)=>(e=u!=null?xn(Tn(u)):{},ve(t||!u||!u.__esModule?Ft(e,"default",{value:u,enumerable:!0}):e,u)),Fn=u=>ve(Ft({},"__esModule",{value:!0}),u);var Kn={};En(Kn,{DISPATCH_ADDRESS:()=>oe,EvmClaim:()=>lt,EvmPlatform:()=>dt,EvmSigner:()=>ie,FeeSwap:()=>it,PlatformAdapter:()=>K,SolanaClaim:()=>ht,SolanaLilJit:()=>Q,SolanaPlatform:()=>pt,SolanaSigner:()=>me,SubstrateClaim:()=>yt,SubstrateExec:()=>At,SubstratePlatform:()=>wt,SubstrateService:()=>T,SubstrateSigner:()=>he,SuiClaim:()=>Ce,SuiPlatform:()=>vt,SuiSigner:()=>Ae,TransferBuilder:()=>hn,Wallet:()=>ee,WhStatus:()=>be,WormholeScan:()=>Bt,WormholeTransfer:()=>we,chunkBySize:()=>ce,deserializeV0:()=>Vn,ixToHuman:()=>M,serializeV0:()=>tt});module.exports=Fn(Kn);var Tt=require("@galacticcouncil/common"),ct=require("@galacticcouncil/xc-core"),ne=require("rxjs");var at=require("@galacticcouncil/xc-core");var Dt=require("@galacticcouncil/xc-core"),xe=require("viem"),ae=require("@wormhole-foundation/sdk-base"),lt=class{#t;constructor(t){this.#t=t}redeem(t,e){let s=Dt.Wormhole.fromChain(this.#t),n=ae.encoding.b64.decode(e),a=ae.encoding.hex.encode(n),r=Dt.Abi.TokenBridge,o=(0,xe.encodeFunctionData)({abi:r,functionName:"completeTransfer",args:["0x"+a]});return{abi:JSON.stringify(r),data:o,from:t,to:s.getTokenBridge()}}};var R=require("@galacticcouncil/xc-core"),_=require("rxjs");var Y=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No EVM client found")}validateConfig(t){if(!t.address)throw new Error("Contract address is required")}};var Se=require("@galacticcouncil/xc-core");var Rt=class extends Y{erc20;constructor(t,e){super(t,e),this.erc20=new Se.Erc20Client(t,e.address)}async getBalance(){let{args:t}=this.config,[e]=t;return this.erc20.balanceOf(e)}async getDecimals(){return this.erc20.decimals()}};var kt=class extends Y{async getBalance(){let t=this.client.getProvider(),{address:e}=this.config;return t.getBalance({address:e})}async getDecimals(){return this.client.chain.nativeCurrency.decimals}};var Vt=class{static get(t,e){switch(e.module){case"Erc20":return new Rt(t,e);case"Native":return new kt(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var _t=require("viem"),Ot=class{client;config;constructor(t,e){this.validateClient(t),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No EVM client found")}get abi(){return this.config.abi}get asset(){let t=this.config.args,[e]=t;return e}get calldata(){return this.config.encodeFunctionData()}async estimateGas(t){let{address:e,args:s,value:n,func:a}=this.config;return await this.client.getProvider().estimateContractGas({address:e,abi:this.abi,functionName:a,args:s,value:n,account:t})}async estimateFee(t,e){if(e===0n)return 0n;try{let s=await this.estimateGas(t),n=await this.getGasPrice();return s*n}catch(s){return s instanceof _t.ContractFunctionExecutionError?console.log(`Can't estimate fees!
|
|
2
2
|
`,s.message):console.log(s),0n}}async getGasPrice(){return this.client.getProvider().getGasPrice()}async getNonce(t){return this.client.getProvider().getTransactionCount({address:t})}async simulateCall(t){let{address:e,args:s,value:n,func:a}=this.config,r=this.client.getProvider(),o=await this.getNonce(t);try{let{results:i}=await r.simulateCalls({account:t,calls:[{to:e,abi:this.abi,functionName:a,args:s,value:n}],stateOverrides:[{address:t,nonce:o}]}),[c]=i;return c}catch(i){return console.log(`Can't simulate call!
|
|
3
|
-
`,i.details),{error:i}}}decodeEvents(t){let e=[];return t&&t.forEach(s=>{try{let{eventName:n,args:a}=(0,_t.decodeEventLog)({abi:this.abi,data:s.data,topics:s.topics});e.push({eventName:n,args:a})}catch{}}),e}};var mt=class{static get(t,e){return new Vt(t,e)}};var Se=require("@galacticcouncil/xc-core");function Pe(l){let t=l.module==="Snowbridge"&&l.func==="sendToken"&&l.args[0]==="0x0000000000000000000000000000000000000000";return l.module==="TokenBridge"&&["wrapAndTransferETHWithPayload","wrapAndTransferETH"].includes(l.func)||t}function Te(l){return Object.entries(Se.Precompile).map(([e,s])=>s).includes(l.address)}var dt=class{#t;constructor(t){this.#t=t.evmClient}async buildCall(t,e,s,n){let a=mt.get(this.#t,n),{abi:r,asset:o,calldata:i}=a,c={abi:JSON.stringify(r),data:i,from:t,to:n.address,type:R.CallType.Evm,value:n.value,dryRun:async()=>{let{error:g,logs:p}=await a.simulateCall(t),f=a.decodeEvents(p);return{call:n.module+"."+n.func,error:g?.shortMessage,events:f}}};if(Te(n)||Pe(n))return c;let u=new R.Erc20Client(this.#t,o),m=await u.allowance(t,n.address);if(m>=e)return c;let d=u.approve(n.address,e);return{abi:JSON.stringify(R.Abi.Erc20),allowance:m,data:d,from:t,to:o,type:R.CallType.Evm,dryRun:()=>{}}}async estimateFee(t,e,s,n){let r=await mt.get(this.#t,n).estimateFee(t,e);return s.copyWith({amount:r})}async getBalance(t,e){let s=Ot.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return R.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new _.Subject,n=s.pipe((0,_.shareReplay)(1)),a=this.#t.getProvider(),r=async()=>{let i=async()=>{let u=await this.getBalance(t,e);s.next(u)};await i();let c=a.watchBlocks({onBlock:()=>i()});return()=>c()},o;return r().then(i=>o=i),n.pipe((0,_.finalize)(()=>o?.()),(0,_.distinctUntilChanged)((i,c)=>i.amount===c.amount))}};var Be=require("@galacticcouncil/xc-core"),Ee=require("@galacticcouncil/common"),Ie=require("polkadot-api"),re="0x0000000000000000000000000000000000000401",{H160:En}=Ee.h160,oe=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=t.evmClient,this.#n=e}async signAndSend(t,e){let s=En.fromAny(t.from),n=this.#e.getProvider(),a=!1;if(this.#t instanceof Be.EvmParachain)try{let o=this.#t.client,i=Ie.Binary.fromHex(t.data);await o.getUnsafeApi().txFromCallData(i),a=!0}catch{}let r;if(a){let[o,i]=await Promise.all([n.estimateGas({account:s,data:t.data,to:re}),n.getGasPrice()]),c=i+i/100n*10n;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:t.data,maxPriorityFeePerGas:c,maxFeePerGas:c,gas:o*11n/10n,to:re})}else{let{data:o,to:i,value:c}=t;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:o,to:i,value:c})}e.onTransactionSend(r),n.waitForTransactionReceipt({hash:r}).then(o=>e.onTransactionReceipt(o)).catch(o=>e.onError(o))}};var Kt=require("@galacticcouncil/xc-core"),_e=require("@solana/web3.js"),Me=require("buffer"),N=require("rxjs");var Z=class{connection;config;constructor(t,e){this.validateConnection(t),this.validateConfig(e),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}validateConfig(t){if(!t.address)throw new Error("Solana address is required")}};var Fe=require("@wormhole-foundation/sdk-solana");var In=9,Mt=class extends Z{async getBalance(){let{address:t}=this.config,e=new Fe.SolanaAddress(t).unwrap(),s=await this.connection.getBalance(e);return BigInt(s)}async getDecimals(){return In}};var Nt=require("@wormhole-foundation/sdk-solana");var Wt=class extends Z{constructor(t,e){super(t,e),this.validateToken(e)}async getBalance(){let{address:t,token:e}=this.config,s=new Nt.SolanaAddress(t).unwrap(),n=new Nt.SolanaAddress(e).unwrap();return(await this.connection.getParsedTokenAccountsByOwner(s,{mint:n})).value.reduce((r,{account:o})=>{let i=o.data.parsed.info.tokenAmount;return r+=BigInt(i.amount),r},0n)}async getDecimals(){let{token:t}=this.config,e=new Nt.SolanaAddress(t).unwrap();return(await this.connection.getTokenSupply(e)).value.decimals}validateToken(t){if(!t.token)throw new Error("Token address is required")}};var Ut=class{static get(t,e){switch(e.module){case"Native":return new Mt(t,e);case"Token":return new Wt(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var D=require("@solana/web3.js"),De=.5,Re=2,ke=1,Oe=1e6,Fn=25e4,jt=class{connection;config;constructor(t,e){this.validateConnection(t),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}async getPriorityMessage(t){let{instructions:e}=this.config,s=await this.getV0Message(t,e),n=await this.createPriorityFeeInstructions(s);return this.getV0Message(t,[...e,...n])}async estimateFee(t,e){if(e===0n)return 0n;let{instructions:s}=this.config,n=await this.getV0Message(t,s),a=await this.determineComputeBudget(n);return BigInt(a)}async getV0Message(t,e){let s=new D.PublicKey(t),{blockhash:n}=await this.connection.getLatestBlockhash("finalized");return new D.TransactionMessage({payerKey:s,recentBlockhash:n,instructions:e}).compileToV0Message()}async createPriorityFeeInstructions(t,e=De,s=Re,n=ke,a=Oe){let[r,o]=await Promise.all([this.determineComputeBudget(t),this.determinePriorityFee(t,e,s,n,a)]);return[D.ComputeBudgetProgram.setComputeUnitLimit({units:r}),D.ComputeBudgetProgram.setComputeUnitPrice({microLamports:o})]}async simulateTransaction(t,e){let s=new D.VersionedTransaction(e);return(await this.connection.simulateTransaction(s,{accounts:{encoding:"base64",addresses:[t]}})).value}async determineComputeBudget(t){let e=new D.VersionedTransaction(t),s=await this.connection.simulateTransaction(e),{err:n,unitsConsumed:a}=s.value;return a&&!n?Math.round(a*1.2):Fn}async determinePriorityFee(t,e=De,s=Re,n=ke,a=Oe){let r=n,o=await this.getTxAccounts(t),i=await this.connection.getRecentPrioritizationFees({lockedWritableAccounts:o});if(i){let c=i.map(m=>m.prioritizationFee).filter(m=>m>0).sort((m,d)=>m-d),u=Math.ceil(c.length*e);if(c.length>u){let d=c[u]*s;r=Math.max(r,d)}}return Math.min(Math.max(r,n),a)}async getTxAccounts(t){let e=(await Promise.all(t.addressTableLookups.map(n=>this.connection.getAddressLookupTable(n.accountKey)))).map(n=>n.value).filter(n=>n!==null),s=t.getAccountKeys({addressLookupTableAccounts:e??void 0});return t.compiledInstructions.flatMap(n=>n.accountKeyIndexes).map(n=>t.isAccountWritable(n)?s.get(n):null).filter(n=>n!==null)}};var gt=class{static get(t,e){return new jt(t,e)}};var Ve=require("@solana/web3.js");function M(l){return l.map(t=>({program:t.programId.toBase58(),data:t.data.toString("hex"),keys:t.keys.map(e=>e.pubkey.toBase58())}))}function ie(l,t=1e3){let e=[],s=[],n=0;for(let a of l){let r=a.data?.length??0;s.length&&n+r>t&&(e.push(s),s=[],n=0),s.push(a),n+=r}return s.length&&e.push(s),e}function tt(l){let t=l.serialize();return Buffer.from(t).toString("hex")}function Dn(l){let t=Buffer.from(l,"hex"),e=Uint8Array.from(t);return Ve.MessageV0.deserialize(e)}var pt=class{#t;constructor(t){this.#t=t.connection}async buildCall(t,e,s,n){let a=gt.get(this.#t,n),r=await a.getPriorityMessage(t),o=r.serialize(),i=Me.Buffer.from(o).toString("hex");return{from:t,data:i,ix:M(n.instructions),signers:n.signers,type:Kt.CallType.Solana,dryRun:async()=>{let{err:c,logs:u}=await a.simulateTransaction(t,r);return{call:n.module+"."+n.func,error:c,events:u}}}}async estimateFee(t,e,s,n){let a=gt.get(this.#t,n),r=await a.estimateFee(t,e),o=await a.getPriorityMessage(t),{accounts:i}=await a.simulateTransaction(t,o),u=(i&&i[0])?.lamports;if(u){let m=n.module==="TokenBridge"&&n.func==="TransferNativeWithPayload";return s.copyWith({amount:s.amount-BigInt(u)-(m?e:0n)+n.rentReserve})}return s.copyWith({amount:r+n.rentReserve})}async getBalance(t,e){let s=Ut.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return Kt.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new N.Subject,n=s.pipe((0,N.shareReplay)(1)),a=async()=>{let o=async()=>{let u=await this.getBalance(t,e);s.next(u)};await o();let i=new _e.PublicKey(e.address),c=this.#t.onAccountChange(i,()=>o());return()=>{this.#t.removeAccountChangeListener(c)}},r;return a().then(o=>r=o),n.pipe((0,N.finalize)(()=>r?.()),(0,N.distinctUntilChanged)((o,i)=>o.amount===i.amount))}};var q=require("@galacticcouncil/xc-core"),S=require("@solana/web3.js"),y=require("@solana/spl-token"),Ne=require("@wormhole-foundation/sdk-solana"),ce=require("@wormhole-foundation/sdk-solana-core"),We=require("@wormhole-foundation/sdk-base"),le=require("@wormhole-foundation/sdk-definitions"),ft=require("@wormhole-foundation/sdk-solana-tokenbridge");var Q=class{#t;constructor(t){this.#t=t.connection}async sendBundle(t){let{result:e}=await this.#t._rpcRequest("sendBundle",[t]);return e}async simulateBundle(t){return(await this.#t._rpcRequest("simulateBundle",[[t]])).result}async getInflightBundleStatuses(t){let{result:e}=await this.#t._rpcRequest("getInflightBundleStatuses",[t]);return e}async getRegion(){let{result:t}=await this.#t._rpcRequest("getRegions",[]);return t}async getTipAccount(){let{result:t}=await this.#t._rpcRequest("getTipAccounts",[]);return t}};var ht=class{#t;#e;#n;constructor(t){this.#t=t,this.#e=t.connection,this.#n=new Q(t)}async redeem(t,e,s){let n=q.Wormhole.fromChain(this.#t),a=We.encoding.b64.decode(e),r=(0,le.deserialize)("TokenBridge:Transfer",a),o=(0,le.deserialize)("Uint8Array",a),i=this.derivePostedVaaKey(n.getCoreBridge(),Buffer.from(r.hash)),c=new S.PublicKey(t),u=s?new S.PublicKey(s):c,m=c.equals(u),d=[];if(!await this.#e.getAccountInfo(i)){let h=S.Keypair.generate(),E=await ce.utils.createVerifySignaturesInstructions(this.#t.connection,n.getCoreBridge(),c,o,h.publicKey),k=ie(E,1e3);for(let F=0;F<k.length;F++){let w=k[F],O=await this.getV0Message(c,w),V=tt(O);d.push({from:t,data:V,ix:M(w),signers:[h],type:q.CallType.Solana})}let L=ce.utils.createPostVaaInstruction(this.#e,n.getCoreBridge(),c,o,h.publicKey),lt=await this.getV0Message(c,[L]),b=tt(lt);d.push({from:t,data:b,ix:M([L]),type:q.CallType.Solana})}let p=r.payload.token.chain==="Solana",f=new S.PublicKey(r.payload.token.address.toUint8Array()),C=p&&f.equals(y.NATIVE_MINT),P=await this.#n.getTipAccount(),A=S.SystemProgram.transfer({fromPubkey:c,toPubkey:new S.PublicKey(P[0]),lamports:1e3});if(C&&m){let h=await this.redeemAndUnwrap(n,c,r,A);d.push(h)}else{let h=await this.redeemToken(n,c,u,f,p,r,A);d.push(h)}return d}async redeemToken(t,e,s,n,a,r,o){let c=(a?ft.createCompleteTransferNativeInstruction:ft.createCompleteTransferWrappedInstruction)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,r),u=(0,y.getAssociatedTokenAddressSync)(n,s),m=(0,y.createAssociatedTokenAccountIdempotentInstruction)(e,u,s,n),d=await this.getV0Message(e,[m,c,o]),g=tt(d);return{from:e.toBase58(),data:g,ix:M([m,c]),type:q.CallType.Solana}}async redeemAndUnwrap(t,e,s,n){let a=new S.PublicKey(s.payload.to.address.toUint8Array()),r=await(0,y.getMint)(this.#e,y.NATIVE_MINT),o=s.payload.token.amount*BigInt(Math.pow(10,r.decimals-8)),i=await(0,y.getMinimumBalanceForRentExemptAccount)(this.#e),c=S.Keypair.generate(),u=(0,y.createAssociatedTokenAccountIdempotentInstruction)(e,a,e,y.NATIVE_MINT),m=(0,ft.createCompleteTransferNativeInstruction)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,s),d=S.SystemProgram.createAccount({fromPubkey:e,newAccountPubkey:c.publicKey,lamports:i,space:y.ACCOUNT_SIZE,programId:y.TOKEN_PROGRAM_ID}),g=(0,y.createInitializeAccountInstruction)(c.publicKey,y.NATIVE_MINT,e),p=(0,y.createTransferInstruction)(a,c.publicKey,e,o),f=(0,y.createCloseAccountInstruction)(c.publicKey,e,e),C=[u,m,d,g,p,f,n],P=await this.getV0Message(e,C),A=tt(P);return{from:e.toBase58(),data:A,ix:M(C),signers:[c],type:q.CallType.Solana}}derivePostedVaaKey(t,e){return Ne.utils.deriveAddress([Buffer.from("PostedVAA"),e],t)}async getV0Message(t,e){let{blockhash:s}=await this.#e.getLatestBlockhash("finalized");return new S.TransactionMessage({payerKey:t,recentBlockhash:s,instructions:e}).compileToV0Message()}};var X=require("@solana/web3.js"),zt=require("buffer");var ue=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=e,this.#n=new Q(t)}async signAndSend(t,e){let{data:s,signers:n}=t,a=this.toVersioned(s,n);try{if(this.#e instanceof X.Keypair){a.sign([this.#e]);let c=await this.#t.connection.sendTransaction(a);e.onTransactionSend(c);let u=await this.#t.connection.getSignatureStatus(c);e.onStatus?.(u);return}let r=this.#e;await r.connect(),n&&a.sign(n);let{signature:o}=await r.signAndSendTransaction(a);e.onTransactionSend(o);let i=await this.#t.connection.getSignatureStatus(o);e.onStatus?.(i)}catch(r){e.onError(r)}}async signAndSendAll(t,e){let s=t.map(n=>{let{data:a,signers:r}=n;return this.toVersioned(a,r)});try{let n;if(this.#e instanceof X.Keypair)s.forEach(i=>i.sign([this.#e])),n=s.map(i=>zt.Buffer.from(i.serialize()).toString("base64"));else{let i=this.#e;await i.connect(),n=(await i.signAllTransactions(s)).map(u=>zt.Buffer.from(u.serialize()).toString("base64"))}let a=await this.#n.simulateBundle(n);if(a.value.summary!=="succeeded")throw new Error("Bundle simulation failed! "+JSON.stringify(a,null,2));let r=await this.#n.sendBundle(n);e.onTransactionSend(r);let o=await this.#n.getInflightBundleStatuses([r]);e.onBundleStatus?.(o.value)}catch(n){e.onError(n)}}toVersioned(t,e){let s=zt.Buffer.from(t,"hex"),n=Uint8Array.from(s),a=X.MessageV0.deserialize(n),r=new X.VersionedTransaction(a);return e&&r.sign(e),r}};var W=require("@galacticcouncil/xc-core"),me=require("@wormhole-foundation/sdk-base"),Ue=require("viem"),Ht=require("polkadot-api"),yt=class{#t;constructor(t){this.#t=t,W.Wormhole.fromChain(this.#t)}redeemMrl(t,e){let s=me.encoding.b64.decode(e),n=me.encoding.hex.encode(s),a=W.Abi.Gmp,r=(0,Ue.encodeFunctionData)({abi:a,functionName:"wormholeTransferERC20",args:["0x"+n]});return{abi:JSON.stringify(a),data:r,from:t,to:W.Precompile.Bridge}}async redeemMrlViaXcm(t,e){let n=this.#t.client.getUnsafeApi(),a=this.redeemMrl(t,e),o=await n.tx.EthereumXcm.transact({xcm_transaction:{type:"V2",value:{gas_limit:[5000000n,0n,0n,0n],fee_payment:{type:"Auto",value:void 0},action:{type:"Call",value:Ht.Binary.fromHex(a.to)},value:[0n,0n,0n,0n],input:Ht.Binary.fromHex(a.data),access_list:void 0}}}).getEncodedData();return{data:Ht.Binary.toHex(o),from:t,type:W.CallType.Substrate,dryRun:async()=>{},txOptions:void 0}}};var $t=require("@galacticcouncil/xc-core"),Ct=require("polkadot-api");var je=require("@galacticcouncil/common");async function de(l,t,e){let s=await e.getDecimals(),n=e.chain.getAssetDecimals(t)??s,a=e.chain.usesChainDecimals?s:n;return{amount:je.big.convertDecimals(l,a,n),decimals:n}}var Ke=require("@galacticcouncil/common"),ze=l=>{let t=[];for(let e of l)if(["PolkadotXcm"].includes(e.type)&&e.value.type==="FeesPaid"){let n=e.value.value.fees;for(let a of n)if(a.fun.type==="Fungible"){let r=BigInt(a.fun.value);t.push(r)}}return t.reduce((e,s)=>e+s,0n)},et=l=>{let t=l.value.error;return t.type==="Module"?Ke.enums.enumPath(t.value):JSON.stringify(t.value)};var Lt=require("@galacticcouncil/common");function Rn(l){return{parents:0,interior:{type:"X1",value:l.startsWith("0x")?Lt.xcm.toAccountKey20(l):Lt.xcm.toAccountId32(l)}}}function He(l){return{type:"V4",value:{parents:1,interior:{type:"X1",value:{type:"Parachain",value:l.parachainId}}}}}var kn=(l,t)=>({id:Lt.xcm.transform(l),fun:{type:"Fungible",value:t}}),Le=(l,t,e,s,n,a)=>{console.log(a);let r=Rn(l),o=kn(t,e.amount);return{type:"V4",value:[{type:"WithdrawAsset",value:[o]},{type:"BuyExecution",value:{fees:o,weight_limit:{type:"Unlimited"}}},{type:"Transact",value:{origin_kind:{type:"SovereignAccount"},require_weight_at_most:{ref_time:s,proof_size:n},call:a}},{type:"RefundSurplus",value:void 0},{type:"DepositAsset",value:{assets:{type:"Wild",value:{type:"AllCounted",value:1}},beneficiary:r}}]}};var At=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async remoteExec(t,e,s,n,a={}){let r=this.#t.api,o=await this.#t.getAsset(),i=this.#e.api,c=this.#e.chain,u=await c.getCurrency(),m=u.asset,d=u.decimals,g=c.getAssetXcmLocation(m),p=Ct.Binary.fromHex(s.data),C=await(await i.txFromCallData(p)).getPaymentInfo(e),P=BigInt(C.partial_fee)*120n/100n,A=$t.AssetAmount.fromAsset(m,{amount:P,decimals:d}),h=C.weight.ref_time,E=C.weight.proof_size,k=He(c),L=Le(e,g,A,h,E,p),lt=r.tx.PolkadotXcm.send({dest:k,message:L}),b=[];try{let x=await this.#t.chain.dex.getCalldata(t,a.srcFeeAsset||o,m,A,10),It=Ct.Binary.fromHex(x),$=await r.txFromCallData(It);b.push($)}catch{}let F=await n(A),w=Ct.Binary.fromHex(F.data),O=await r.txFromCallData(w);b.push(O),b.push(lt);let V=b.map(x=>x.decodedCall),Et=r.tx.Utility.batch_all({calls:V}),se=await Et.getEncodedData();return{from:t,data:Ct.Binary.toHex(se),type:$t.CallType.Substrate,dryRun:this.#t.isDryRunSupported()?async()=>{try{let x=await this.#t.dryRun(t,Et);return{call:"polkadotXcm.send",error:x.execution_result&&x.execution_result.success?void 0:et(x.execution_result),events:x.emitted_events||[],xcm:x.forwarded_xcms||[]}}catch(x){return{call:"polkadotXcm.send",error:x instanceof Error?x.message:"unknown"}}}:()=>{}}}};var J=require("@galacticcouncil/xc-core"),Qe=require("polkadot-api"),B=require("rxjs");var U=require("@galacticcouncil/xc-core"),Qt=require("@galacticcouncil/common"),qt=require("@polkadot-api/substrate-bindings"),bt=require("@polkadot-api/utils"),ge=require("polkadot-api");var{Ss58Addr:$e}=U.addr,T=class l{chain;_currency;constructor(t){this.chain=t}static async create(t){return new l(t)}get client(){return this.chain.client}get api(){return this.client.getUnsafeApi()}async getCurrency(){return this._currency||(this._currency=this.chain.getCurrency()),this._currency}async getAsset(){return(await this.getCurrency()).asset}async getDecimals(){return(await this.getCurrency()).decimals}async getExistentialDeposit(){let t;try{let n=await this.api.constants.Balances.ExistentialDeposit();t=typeof n=="bigint"?n:BigInt(String(n))}catch{t=0n}let{asset:e,decimals:s}=await this.getCurrency();return U.AssetAmount.fromAsset(e,{amount:t,decimals:s})}isDryRunSupported(){return this.api.apis?.DryRunApi!==void 0}async buildMessageId(t,e,s,n){let a=await this.client._request("system_accountNextIndex",[t]),r=qt.u32.enc(a),o=u=>new TextEncoder().encode(u),i=new Uint8Array([...o(this.chain.parachainId.toString()),...(0,bt.fromHex)(t.startsWith("0x")?t.slice(2):t),...r,...(0,bt.fromHex)(s.startsWith("0x")?s.slice(2):s),...o(n),...o(e.toString())]),c=(0,qt.Blake2256)(i);return(0,bt.toHex)(c)}async dryRun(t,e){let s=(0,ge.Enum)("Signed",t),n=(0,ge.Enum)("system",s),a=await this.api.apis.DryRunApi.dry_run_call(n,e.decodedCall,4);if(!a.success)throw new Error("DryRun call failed");let r=a.value;if("type"in r&&"value"in r)throw new Error("DryRun call error: "+Qt.enums.enumPath(r.value));return r}async estimateNetworkFee(t,e){let s=e.getTx(this.client);try{let n=await s.getPaymentInfo(t);return BigInt(n.partial_fee)}catch{console.warn("Can't estimate network fee.")}return 0n}async estimateDeliveryFee(t,e){if(this.chain.usesDeliveryFee){let s=await this.estimateDeliveryFeeWith(t,e);try{let n=e.getTx(this.client),a=await this.dryRun(s,n);if(a.execution_result?.success)return ze(a.emitted_events||[]);{let r=et(a.execution_result);console.warn(`Can't estimate delivery fee. Reason:
|
|
4
|
-
${r}`)}}catch{}}return 0n}async estimateDeliveryFeeWith(t,e){if(["PolkadotXcm"].includes(e.module)){let n=e.getTx(this.client).decodedCall.value.value,a="dest"in n?n.dest:void 0;if(!a)return t;let r=U.multiloc.findNestedKey(a,"interior"),o=U.multiloc.findParachain(a);if(U.multiloc.findGlobalConsensus(a))return t;if(o){let c=Qt.acc.getSovereignAccounts(o);return this.chain.parachainId===0?$e.encodePubKey(c.relay):$e.encodePubKey(c.generic)}if(r&&r.interior==="Here")return this.chain.treasury||t}return t}};var wt=class{#t;constructor(t){this.#t=T.create(t)}async useSignerFee(t){let e=await this.#t,s=await e.getAsset();return e.chain.usesSignerFee&&!s.isEqual(t)}async buildCall(t,e,s,n){let a=await this.#t,o=await this.useSignerFee(s)?{asset:new J.Asset(s)}:void 0,i=n.getTx(a.client),c=n.module+"."+n.func,u=await i.getEncodedData();return{from:t,data:Qe.Binary.toHex(u),type:J.CallType.Substrate,txOptions:o,dryRun:a.isDryRunSupported()?async()=>{try{let m=n.getTx(a.client),d=await a.dryRun(t,m),g=d.execution_result&&d.execution_result.success?void 0:et(d.execution_result);return{call:c,error:g,events:d.emitted_events||[],xcm:d.forwarded_xcms||[]}}catch(m){return{call:c,error:m instanceof Error?m.message:"unknown"}}}:()=>{}}}async estimateFee(t,e,s,n){let a=await this.#t,r=await a.estimateNetworkFee(t,n),o=await a.estimateDeliveryFee(t,n),i=await this.exchangeFee(r+o,s),c=await de(i,s,a);return s.copyWith(c)}async getBalance(t,e){let s=await this.subscribeBalance(t,e);return(0,B.firstValueFrom)(s)}async subscribeBalance(t,e){let s=await this.#t,{module:n,func:a,args:r,transform:o}=e;return s.client.getUnsafeApi().query[n][a].watchValue(...r,{at:"best"}).pipe((0,B.map)(({value:u})=>u)).pipe((0,B.concatMap)(u=>o(u)),(0,B.distinctUntilChanged)((u,m)=>u===m),(0,B.concatMap)(async u=>{let m=await de(u,t,s);return J.AssetAmount.fromAsset(t,m)}),(0,B.catchError)(u=>(console.error("subscribe fails for:",t),(0,B.throwError)(()=>u))))}async exchangeFee(t,e){let s=await this.#t,n=await s.getAsset(),a=await s.getDecimals();if(n.isEqual(e))return t;try{let r=s.chain.dex,o=J.AssetAmount.fromAsset(n,{amount:t,decimals:a});return(await r.getQuote(e,n,o,!0)).amount}catch{}return t}};var pe=require("@galacticcouncil/xc-core"),nt=require("polkadot-api"),fe=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}signAndSend(t,e){let n=this.#t.client.getUnsafeApi(),a=nt.Binary.fromHex(t.data),r={};t.txOptions?.asset&&(r={asset:this.getFeeAsset(t.txOptions.asset)}),n.txFromCallData(a).then(o=>{o.signSubmitAndWatch(this.#e,r).subscribe({next:i=>{i.type==="broadcasted"&&e.onTransactionSend(i.txHash),i.type==="finalized"&&e.onFinalized(i)},error:i=>{e.onError(i)}})})}getFeeAsset(t){let e=this.#t.getAssetXcmLocation(t);if(e){let s=pe.multiloc.findPalletInstance(e),n=pe.multiloc.findGeneralIndex(e);return{parents:0,interior:(0,nt.Enum)("X2",[(0,nt.Enum)("PalletInstance",Number(s)),(0,nt.Enum)("GeneralIndex",BigInt(n))])}}throw new Error("Asset location not found")}};var Jt=require("@galacticcouncil/xc-core"),Xe=require("@mysten/sui/transactions"),Je=require("@mysten/sui/utils"),Ge=require("@mysten/bcs"),st=require("@wormhole-foundation/sdk-connect"),Ye=require("@wormhole-foundation/sdk-definitions"),he=require("@wormhole-foundation/sdk-sui"),Ze=require("@wormhole-foundation/sdk-sui-tokenbridge");var qe=require("@mysten/bcs");function Xt(l,t={}){let e=l.inputs??[],s=l.commands??[],n=t.numbers??"string",a=t.decode32As??"address",r=u=>n==="bigint"?u:n==="number"?Number(u):u.toString(),o=u=>{let m=(0,qe.fromBase64)(u),d=g=>{let p=0n;for(let f=0;f<g;f++)p|=BigInt(m[f])<<8n*BigInt(f);return p};return m.length===1?{type:"pure",valueType:"u8",value:Number(m[0])}:m.length===2?{type:"pure",valueType:"u16",value:r(d(2))}:m.length===4?{type:"pure",valueType:"u32",value:Number(d(4))}:m.length===8?{type:"pure",valueType:"u64",value:r(d(8))}:m.length===32&&a==="address"?{type:"pure",valueType:"address",value:"0x"+[...m].map(p=>p.toString(16).padStart(2,"0")).join("")}:{type:"pure",valueType:"vector<u8>",value:Array.from(m)}},i=u=>{let m=e[u];if(!m)return{Input:u};if(m.Pure?.bytes)return o(m.Pure.bytes);let d=m.Object?.SharedObject;if(d)return{type:"object",objectType:"sharedObject",objectId:d.objectId,initialSharedVersion:String(d.initialSharedVersion),mutable:!!d.mutable};let g=m.Object?.ImmOrOwnedObject;return g?{type:"object",objectType:"immOrOwnedObject",objectId:g.objectId,version:String(g.version),digest:g.digest??void 0}:{Input:u}},c=u=>u?.GasCoin?"GasCoin":Array.isArray(u?.NestedResult)?u:typeof u?.Input=="number"?i(u.Input):u;return s.map(u=>{if(u.MoveCall){let m=u.MoveCall;return{MoveCall:{...m,arguments:(m.arguments??[]).map(c)}}}if(u.SplitCoins){let m=u.SplitCoins,d=m.coin?.GasCoin?"GasCoin":c(m.coin),g=(m.amounts??[]).map(c);return{SplitCoins:[d,g]}}if(u.MergeCoins){let m=u.MergeCoins;return{MergeCoins:{...m,destination:c(m.destination),sources:(m.sources??[]).map(c)}}}if(u.TransferObjects){let m=u.TransferObjects;return{TransferObjects:{...m,objects:(m.objects??[]).map(c),address:c(m.address)}}}return u})}var ye=class{#t;constructor(t){this.#t=t}async redeem(t,e){let s=Jt.Wormhole.fromChain(this.#t),n=this.#t.client,a=st.encoding.b64.decode(e),r=(0,Ye.deserialize)("TokenBridge:Transfer",a),o=s.getCoreBridge(),i=s.getTokenBridge(),c=await(0,Ze.getTokenCoinType)(n,i,r.payload.token.address.toUint8Array(),(0,st.toChainId)(r.payload.token.chain));if(!c)throw new Error("Unable to fetch token coinType");let[u,m]=await Promise.all([(0,he.getPackageId)(n,o),(0,he.getPackageId)(n,i)]),d=new Xe.Transaction;d.setSender(t);let[g]=d.moveCall({target:`${u}::vaa::parse_and_verify`,arguments:[d.object(o),d.pure.vector("u8",(0,st.serialize)(r)),d.object(Je.SUI_CLOCK_OBJECT_ID)]}),[p]=d.moveCall({target:`${m}::vaa::verify_only_once`,arguments:[d.object(i),g]}),[f]=d.moveCall({target:`${m}::complete_transfer::authorize_transfer`,arguments:[d.object(i),p],typeArguments:[c]}),[C]=d.moveCall({target:`${m}::complete_transfer::redeem_relayer_payout`,arguments:[f],typeArguments:[c]});d.moveCall({target:`${m}::coin_utils::return_nonzero`,arguments:[C],typeArguments:[c]});let P=await d.build({client:n}),A=await d.toJSON(),h=Xt(JSON.parse(A));return{from:t,commands:h,data:(0,Ge.toBase64)(P),type:Jt.CallType.Sui}}};var te=require("@galacticcouncil/xc-core"),en=require("@mysten/bcs"),j=require("rxjs");var Gt=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No client found")}validateConfig(t){if(!t.address)throw new Error("Sui address is required")}};var tn=require("@mysten/sui/utils");var On=9,Yt=class extends Gt{async getBalance(){let{address:t}=this.config,e=await this.client.getBalance({owner:t,coinType:tn.SUI_TYPE_ARG});return BigInt(e.totalBalance)}async getDecimals(){return On}};var Zt=class{static get(t,e){switch(e.module){case"Native":return new Yt(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var vt=class{#t;constructor(t){this.#t=t.client}async buildCall(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),o=await a.toJSON(),i=Xt(JSON.parse(o));return{from:t,commands:i,data:(0,en.toBase64)(r),type:te.CallType.Sui,dryRun:async()=>{let c=await this.#t.dryRunTransactionBlock({transactionBlock:r});return{call:n.module+"."+n.func,error:c.executionErrorSource}}}}async estimateFee(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),i=(await this.#t.dryRunTransactionBlock({transactionBlock:r})).effects.gasUsed,c=BigInt(i.computationCost),u=BigInt(i.storageCost),m=c+u;return s.copyWith({amount:m})}async getBalance(t,e){let s=Zt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return te.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new j.Subject,n=s.pipe((0,j.shareReplay)(1)),a=async()=>{await(async()=>{let c=await this.getBalance(t,e);s.next(c)})();let i=setInterval(()=>{},3e3);return()=>clearInterval(i)},r;return a().then(o=>r=o),n.pipe((0,j.finalize)(()=>r?.()),(0,j.distinctUntilChanged)((o,i)=>o.amount===i.amount))}};var nn=require("@mysten/sui/keypairs/ed25519"),sn=require("@mysten/sui/transactions"),Ce=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async signAndSend(t,e){let{from:s,data:n}=t,a=this.#t.client;try{if(this.#e instanceof nn.Ed25519Keypair){let i=sn.Transaction.from(n),c=await a.signAndExecuteTransaction({signer:this.#e,transaction:i,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(c.digest);return}let r=await this.#e.signTransaction({transaction:n,address:s,networkID:"sui:mainnet"}),o=await a.executeTransactionBlock({transactionBlock:r.transaction,signature:r.signature,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(o.digest)}catch(r){e.onError(r)}}};var K=class{platform={};constructor(t){switch(t.getType()){case at.ChainType.EvmChain:this.registerEvm(t);break;case at.ChainType.EvmParachain:this.registerEvm(t),this.registerSubstrate(t);break;case at.ChainType.Parachain:this.registerSubstrate(t);break;case at.ChainType.SolanaChain:this.registerSolana(t);break;case at.ChainType.SuiChain:this.registerSui(t);break;default:throw new Error("Unsupported platform: "+t.getType())}}registerEvm(t){let e=t;this.platform.Evm=new dt(e)}registerSolana(t){let e=t;this.platform.Solana=new pt(e)}registerSui(t){let e=t;this.platform.Sui=new vt(e)}registerSubstrate(t){let e=t;this.platform.Substrate=new wt(e)}async buildCall(t,e,s,n){return this.platform[n.type].buildCall(t,e,s,n)}async estimateFee(t,e,s,n){return this.platform[n.type].estimateFee(t,e,s,n)}async getBalance(t,e){return this.platform[e.type].getBalance(t,e)}async subscribeBalance(t,e){return this.platform[e.type].subscribeBalance(t,e)}};var H=require("@galacticcouncil/xc-core"),xt=require("@galacticcouncil/common");var an=require("@galacticcouncil/common"),rt=Tn(require("big.js"),1);function rn(l,t,e,s){let n=l.toBig().minus(e.toBig()).minus(l.isSame(t)?t.toBig():new rt.default(0));return s&&(n=n.minus(l.isSame(s)?s.toBig():new rt.default(0))),l.copyWith({amount:n.lt(0)?0n:BigInt(n.toFixed())})}function on(l,t,e,s){let a=l.copyWith({amount:0n}).toBig().plus(l.isSame(t)?t.toBig():new rt.default(0)).plus(l.toBig().lt(e.toBig())?e.toBig():new rt.default(0));return s&&(a=a.plus(l.isSame(s)&&l.toBig().lt(s.toBig())?s.toBig():new rt.default(0))),l.copyWith({amount:BigInt(a.toFixed())})}async function z(l,t){return t.isEvmParachain()?t.getDerivatedAddress(l):l}function cn(l,t){return t?an.big.toBigInt(t,l):0n}var G=require("@galacticcouncil/xc-core"),ln=require("@galacticcouncil/common");var{EvmAddr:Vn}=G.addr,ot=class{adapter;config;constructor(t,e){this.adapter=t,this.config=e}async getEd(){let{chain:t}=this.config;if(t instanceof G.Parachain)return(await T.create(t)).getExistentialDeposit()}async getBalance(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.asset,r=e.getBalanceAssetId(a),o=Vn.isValid(r.toString())?await z(t,e):t,i=s.source.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=s.min;if(t instanceof G.Parachain&&a){let r=t.getMinAssetId(n),o=a.build({asset:r});return this.adapter.getBalance(n,o)}return this.getAssetMin()}async getAssetMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=t.getAssetMin(n),r=await this.getDecimals(n),o=0n;return a&&(o=ln.big.toBigInt(a,r)),G.AssetAmount.fromAsset(n,{amount:o,decimals:r})}async getDecimals(t){let{chain:e}=this.config,s=e.getAssetDecimals(t);return s||(await e.getCurrency()).decimals}};var{EvmAddr:un}=H.addr,St=class extends ot{constructor(t,e){super(t,e)}async getCall(t){let{amount:e,sender:s,source:n}=t,a=await this.getTransfer(t);return this.adapter.buildCall(s,e,n.feeBalance,a)}async getDestinationFee(){let{chain:t,route:e}=this.config,{source:s,destination:n,transact:a}=e,r=n.fee.amount,o=s.destinationFee.asset||n.fee.asset,i=await this.getDecimals(o);if(Number.isFinite(r))return{fee:H.AssetAmount.fromAsset(o,{amount:xt.big.toBigInt(r,i),decimals:i}),feeBreakdown:{}};let c=r,{amount:u,breakdown:m}=await c.build({feeAsset:o,transferAsset:s.asset,source:a?a.chain:t,destination:n.chain});return{fee:H.AssetAmount.fromAsset(o,{amount:u,decimals:i}),feeBreakdown:m}}async getDestinationFeeBalance(t){let{chain:e,route:s}=this.config,{source:n,destination:a}=s,r=n.asset,o=n.destinationFee.asset||a.fee.asset;if(r.isEqual(o))return this.getBalance(t);let i=e.getBalanceAssetId(o),c=un.isValid(i.toString())?await z(t,e):t,u=n.destinationFee.balance.build({address:c,asset:o,chain:e});return this.adapter.getBalance(o,u)}async getFee(t){let{chain:e,route:s}=this.config,{amount:n,sender:a,source:r}=t,o=await this.getTransfer(t),i=s.contract?await z(a,e):a,c=await this.adapter.estimateFee(i,n,r.feeBalance,o),{fee:u}=s.source,m=u?cn(c.decimals,u.extra):0n,d=c.amount+m;return c.copyWith({amount:d})}async getFeeBalance(t){let{chain:e,route:s}=this.config,{source:n}=s;if(!n.fee)return this.getBalance(t);let a=await this.getFeeAsset(t),r=e.getBalanceAssetId(a),o=un.isValid(r.toString())?await z(t,e):t,i=n.fee.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getFeeAsset(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.fee,r=n.asset;if(!a)return r;let o=a.asset;return e instanceof H.Parachain&&"build"in o?await o.build({chain:e,address:t}):o}async getTransfer(t){let{chain:e,route:s}=this.config,{contract:n,extrinsic:a,program:r,move:o}=s;if(a){let{address:c,amount:u,asset:m,sender:d}=t,p=await(await T.create(e)).buildMessageId(d,u,m.originSymbol,c);return a.build({...t,messageId:p})}let i=n||r||o;if(i)return i.build({...t});throw new Error("AssetRoute transfer config is invalid! Specify contract, extrinsic, move or program instructions.")}async getTransact(t){let{route:e}=this.config,{transact:s}=e;if(s){let n=Object.assign({transact:{chain:s.chain}}),a={...t,...n};return{...await this.getTransactData(s,a),chain:s.chain}}}async getTransactData(t,e){let{chain:s,extrinsic:n}=t,a=await n.build(e),r=await T.create(s),o=a.getTx(r.client),i=e.source.chain,c=e.sender,u=xt.acc.getMultilocationDerivatedAccount(i.parachainId,c,s.parachainId===0?0:1,s.usesH160Acc),m=await o.getPaymentInfo(u),d=await o.getEncodedData(),[g,p]=await Promise.all([this.getTransactFee(t),this.getTransactFeeBalance(t,e)]);return{call:d,chain:s,fee:g,feeBalance:p,weight:{refTime:m.weight.ref_time,proofSize:m.weight.proof_size}}}async getTransactFee(t){let{fee:e}=t,s=await this.getDecimals(e.asset),n=xt.big.toBigInt(e.amount,s);return H.AssetAmount.fromAsset(e.asset,{amount:n,decimals:s})}async getTransactFeeBalance(t,e){let{chain:s}=this.config,{fee:n}=t,a=n.balance.build({address:e.sender,asset:n.asset,chain:s});return this.adapter.getBalance(n.asset,a)}};var Pt=class extends ot{constructor(t,e){super(t,e)}};var mn=require("@galacticcouncil/xc-core"),it=class{ctx;constructor(t){this.ctx=t}get asset(){let{source:t}=this.ctx;return t.balance}get dex(){let{source:t}=this.ctx;return t.chain.dex}get destFee(){let{source:t,transact:e}=this.ctx;return e?e.fee:t.destinationFee}get destFeeBalance(){let{source:t,transact:e}=this.ctx;return e?e.feeBalance:t.destinationFeeBalance}get feeBalance(){let{source:t}=this.ctx;return t.feeBalance}async getSwap(t){let{asset:e,decimals:s}=await this.dex.chain.getCurrency(),{amount:n}=await this.dex.getQuote(e,t,t);return{aIn:t,aOut:mn.AssetAmount.fromAsset(e,{amount:n,decimals:s}),enabled:!0}}isSwapSupported(t){try{this.dex}catch{return!1}return!!(t&&t.swap)}async getDestinationSwap(t){let{amount:e,route:s}=await this.dex.getQuote(t,this.destFee,this.destFee),n=this.destFeeBalance.amount<this.destFee.amount,a=this.feeBalance.amount-t.amount>e*2n;return{aIn:t.copyWith({amount:e}),aOut:this.destFee,enabled:n&&a,route:s}}isDestinationSwapSupported(t){try{this.dex}catch{return!1}let e=!t.isSame(this.destFee),s=this.asset.isSame(this.destFee);return e&&!s}};var{EvmAddr:_n}=ct.addr,ee=class{config;validations;constructor({configService:t,transferValidations:e}){this.config=t,this.validations=e||[]}async transfer(t,e,s,n,a){let r=(0,ct.ConfigBuilder)(this.config).assets().asset(t).source(s).destination(a).build();return this.getTransferData(r,e,n)}async remoteXcm(t,e,s,n,a={}){let r=this.config.getChain(e),o=this.config.getChain(s);if(!(r.isSubstrate()&&o.isSubstrate()))throw Error("RemoteXcm is supported only between parachains");let[c,u]=await Promise.all([T.create(r),T.create(o)]),m=new At(c,u),d=Tt.acc.getMultilocationDerivatedAccount(r.parachainId,t,1,o.usesH160Acc),g=await u.getAsset(),p=await this.transfer(g,t,e,d,s);return m.remoteExec(t,d,n,f=>{let C=f.toDecimal();return p.buildCall(C)},a)}async getTransferData(t,e,s){let n=t.origin,a=t.reverse,r=new K(n.chain),o=new K(a.chain),i=new St(r,n),c=new Pt(o,a),u=new ct.TransferValidator(...this.validations),[m,d,g,p,f,C,P]=await Promise.all([i.getBalance(e),i.getFeeBalance(e),i.getDestinationFee(),i.getDestinationFeeBalance(e),i.getMin(),c.getBalance(s),c.getMin()]),{source:A,destination:h}=n.route,E=g.fee.copyWith(h.fee.asset),k=g.feeBreakdown,lt=A.asset.isEqual(E)&&E.amount>10n?E.amount+1n:10n,b={address:s,amount:lt,asset:A.asset,destination:{balance:C,chain:a.chain,fee:E,feeBreakdown:k},sender:e,source:{balance:m,chain:n.chain,fee:d.copyWith({amount:0n}),feeBalance:d,destinationFee:g.fee,destinationFeeBalance:p}};b.transact=await i.getTransact(b);let F=new it(b),w=await i.getFee(b),O;F.isSwapSupported(A.fee)&&(O=await F.getSwap(w),b.source.feeSwap=O);let V;F.isDestinationSwapSupported(w)&&(V=await F.getDestinationSwap(w),b.source.destinationFeeSwap=V),(O||V)&&(w=await i.getFee(b),w=w.padByPct(5n));let Et=await c.getEd(),se=on(C,E,P,Et),x=await i.getEd(),It=rn(m,w,f,x);return b.amount=0n,b.source.fee=w,{source:{balance:m,destinationFee:g.fee,destinationFeeBalance:p,destinationFeeSwap:V,fee:w,feeBalance:d,feeSwap:O,max:It,min:m.copyWith({amount:se.amount})},destination:{balance:C,fee:E},async buildCall($){let I=Object.assign({},b);return I.amount=Tt.big.toBigInt($,m.decimals),I.transact=await i.getTransact(I),i.getCall(I)},async estimateFee($){let I=Object.assign({},b);return I.amount=Tt.big.toBigInt($,m.decimals),I.transact=await i.getTransact(I),i.getFee(I)},async validate($){let I=Object.assign({},b),An=$||w.amount;return I.source.fee=w.copyWith({amount:An}),u.validate(I)}}}async subscribeBalance(t,e,s){let n=this.config.getChainRoutes(e),a=new K(n.chain),r=n.getUniqueRoutes().map(async({source:c})=>{let{asset:u,balance:m}=c,d=n.chain.getBalanceAssetId(u),g=_n.isValid(d.toString())?await z(t,n.chain):t,p=m.build({address:g,asset:u,chain:n.chain});return a.subscribeBalance(u,p)}),o=await Promise.all(r);return(0,ne.combineLatest)(o).pipe((0,ne.debounceTime)(500)).subscribe(s)}};var dn=require("@galacticcouncil/xc-core");function gn(l){let t=(0,dn.ConfigBuilder)(l.config).assets();return{assets:t,withAsset(e){let s=t.asset(e);return{sources:s,withSource(n){let a=s.source(n);return{destinations:a,withDestination(r){let{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:u,build:m}=a.destination(r);return{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:u,build({srcAddress:d,dstAddress:g,dstAsset:p,tag:f}){let C=m(p,f);return l.getTransferData(C,d,g)}}}}}}}}}var pn=require("@galacticcouncil/xc-core"),Mn="https://api.wormholescan.io",Bt=class{_baseUrl;constructor(t){this._baseUrl=t||Mn}buildApi(t,e){return[this._baseUrl,t,"?"].join("")+new URLSearchParams(e).toString()}async getVaaBytes(t){let e=this.buildApi("/v1/signed_vaa/"+t,{});return await(await fetch(e)).json()}async getVaa(t){let e=this.buildApi("/api/v1/vaas/"+t,{});return(await(await fetch(e)).json()).data}async getVaaByTxHash(t){let e=this.buildApi("/api/v1/vaas/",{txHash:t}),n=await(await fetch(e)).json();if(n.data.length>0)return n.data[0];throw Error("Can't find VAA for given txHash: "+t)}async getOperations(t){let e=this.buildApi("/api/v1/operations/",t);return(await(await fetch(e)).json()).operations}async getOperation(t){let e=this.buildApi("/api/v1/operations/"+t,{});return await(await fetch(e)).json()}isMrlTransfer(t){let{payloadType:e,toAddress:s,toChain:n}=t,a="0x"+s.substring(26);return e===3&&n===16&&a===pn.Precompile.Bridge}};var fn=require("@galacticcouncil/common"),v=require("@galacticcouncil/xc-core"),hn=require("@wormhole-foundation/sdk-base"),yn=require("@wormhole-foundation/sdk-connect"),Cn=require("@wormhole-foundation/sdk-definitions");var Ae=(s=>(s[s.WaitingForVaa=0]="WaitingForVaa",s[s.VaaEmitted=1]="VaaEmitted",s[s.Completed=2]="Completed",s))(Ae||{});var Nn=300*1e3,be=class{parachainId;config;whScan;constructor(t,e){this.config=t,this.parachainId=e,this.whScan=new Bt}get chains(){let t=this.config.chains.values();return Array.from(t)}get filters(){let t=new Date,e=new Date;e.setDate(t.getDate()-6);let s=t.toISOString();return{page:"0",pageSize:"50",includeEndDate:"true",from:e.toISOString(),to:s}}async getWithdraws(t){let e=fn.acc.getMultilocationDerivatedAccount(this.parachainId,t,1,!0),n=(await this.whScan.getOperations({...this.filters,address:e})).map(async a=>{let{content:r}=a,{payload:o,standarizedProperties:i}=r,c=this.getStatus(a),u=this.chains.find(f=>f instanceof v.Parachain&&f.parachainId===this.parachainId),{toAddress:m,tokenAddress:d}=i,g=this.chains.find(f=>v.Wormhole.isKnown(f)&&v.Wormhole.fromChain(f).getWormholeId()===o.tokenChain),p;if(c===1&&a.vaa){let{timestamp:f}=this.getVaaHeader(a.vaa.raw),C=a.vaa.raw;if(this.isStuck(f))switch(g.getType()){case v.ChainType.EvmChain:let P=new ut(g);p=async h=>P.redeem(h,C);break;case v.ChainType.SolanaChain:let A=new ht(g);p=async h=>A.redeem(h,C);break}}return{asset:d,assetSymbol:a.data.symbol,amount:a.data.tokenAmount,from:t,fromChain:u,to:m,toChain:g,status:c,redeem:p,operation:a}});return Promise.all(n)}async getDeposits(t,e="hydration"){let s=await this.whScan.getOperations({...this.filters,address:v.Precompile.Bridge,pageSize:"100"}),n=this.config.chains.get(e);if(!n)return[];let a=n,o=(await v.mrl.createPayload(a,t)).toHex(),i=s.filter(c=>{let{content:u}=c,{payload:m}=u;return m.payloadType===3&&m.toChain===16&&"0x"+m.payload===o}).map(async c=>{let{content:u,sourceChain:m}=c,{payload:d,standarizedProperties:g}=u,p=this.getStatus(c),{tokenAddress:f}=g,C=this.chains.find(h=>v.Wormhole.isKnown(h)&&v.Wormhole.fromChain(h).getWormholeId()===d.tokenChain),P=this.chains.find(h=>v.Wormhole.isKnown(h)&&v.Wormhole.fromChain(h).getWormholeId()===d.toChain),A;if(p===1&&c.vaa){let{timestamp:h}=this.getVaaHeader(c.vaa.raw),E=c.vaa.raw;if(this.isStuck(h)){let k=new yt(P);A=async L=>k.redeemMrlViaXcm(L,E)}}return{asset:f,assetSymbol:c.data.symbol,amount:c.data.tokenAmount,from:m.from,fromChain:C,to:t,toChain:n,status:p,redeem:A,operation:c}});return Promise.all(i)}isStuck(t){return Date.now()>=t*1e3+Nn}getVaaHeader(t){let e=hn.encoding.b64.decode(t),s=(0,Cn.deserialize)("Uint8Array",e);return{timestamp:s.timestamp,emitterChain:s.emitterChain,emitterAddress:s.emitterAddress.toString(),sequence:s.sequence,payload:s.payload,hash:s.hash,id:(0,yn.keccak256)(s.hash)}}getStatus(t){return t.vaa?t.targetChain&&t.targetChain.status==="completed"?2:1:0}};0&&(module.exports={DISPATCH_ADDRESS,EvmClaim,EvmPlatform,EvmSigner,FeeSwap,PlatformAdapter,SolanaClaim,SolanaLilJit,SolanaPlatform,SolanaSigner,SubstrateClaim,SubstrateExec,SubstratePlatform,SubstrateService,SubstrateSigner,SuiClaim,SuiPlatform,SuiSigner,TransferBuilder,Wallet,WhStatus,WormholeScan,WormholeTransfer,chunkBySize,deserializeV0,ixToHuman,serializeV0});
|
|
3
|
+
`,i.details),{error:i}}}decodeEvents(t){let e=[];return t&&t.forEach(s=>{try{let{eventName:n,args:a}=(0,_t.decodeEventLog)({abi:this.abi,data:s.data,topics:s.topics});e.push({eventName:n,args:a})}catch{}}),e}};var mt=class{static get(t,e){return new Ot(t,e)}};var Pe=require("@galacticcouncil/xc-core"),Te=require("viem");function re(u){return u.module==="Snowbridge"&&u.func==="v2_sendMessage"}function Be(u){if(!re(u))return;let t=u.args[1];if(!t||t.length===0)return;let[e,s]=(0,Te.decodeAbiParameters)([{type:"uint8"},{type:"address"},{type:"uint128"}],t[0]);return s}function Ee(u){let t=u.module==="Snowbridge"&&u.func==="v2_sendMessage"&&Array.isArray(u.args[1])&&u.args[1].length===0;return u.module==="TokenBridge"&&["wrapAndTransferETHWithPayload","wrapAndTransferETH"].includes(u.func)||t}function Ie(u){return Object.entries(Pe.Precompile).map(([e,s])=>s).includes(u.address)}var dt=class{#t;constructor(t){this.#t=t.evmClient}async buildCall(t,e,s,n){let a=mt.get(this.#t,n),{abi:r,asset:o,calldata:i}=a,c={abi:JSON.stringify(r),data:i,from:t,to:n.address,type:R.CallType.Evm,value:n.value,dryRun:async()=>{let{error:p,logs:f}=await a.simulateCall(t),h=a.decodeEvents(f);return{call:n.module+"."+n.func,error:p?.shortMessage,events:h}}};if(Ie(n)||Ee(n))return c;let l=re(n)?Be(n):o,m=new R.Erc20Client(this.#t,l),d=await m.allowance(t,n.address);if(d>=e)return c;let g=m.approve(n.address,e);return{abi:JSON.stringify(R.Abi.Erc20),allowance:d,data:g,from:t,to:l,type:R.CallType.Evm,dryRun:()=>{}}}async estimateFee(t,e,s,n){let r=await mt.get(this.#t,n).estimateFee(t,e);return s.copyWith({amount:r})}async getBalance(t,e){let s=Vt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return R.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new _.Subject,n=s.pipe((0,_.shareReplay)(1)),a=this.#t.getProvider(),r=async()=>{let i=async()=>{let l=await this.getBalance(t,e);s.next(l)};await i();let c=a.watchBlocks({onBlock:()=>i()});return()=>c()},o;return r().then(i=>o=i),n.pipe((0,_.finalize)(()=>o?.()),(0,_.distinctUntilChanged)((i,c)=>i.amount===c.amount))}};var Fe=require("@galacticcouncil/xc-core"),De=require("@galacticcouncil/common"),Re=require("polkadot-api"),oe="0x0000000000000000000000000000000000000401",{H160:Dn}=De.h160,ie=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=t.evmClient,this.#n=e}async signAndSend(t,e){let s=Dn.fromAny(t.from),n=this.#e.getProvider(),a=!1;if(this.#t instanceof Fe.EvmParachain)try{let o=this.#t.client,i=Re.Binary.fromHex(t.data);await o.getUnsafeApi().txFromCallData(i),a=!0}catch{}let r;if(a){let[o,i]=await Promise.all([n.estimateGas({account:s,data:t.data,to:oe}),n.getGasPrice()]),c=i+i/100n*10n;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:t.data,maxPriorityFeePerGas:c,maxFeePerGas:c,gas:o*11n/10n,to:oe})}else{let{data:o,to:i,value:c}=t;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:o,to:i,value:c})}e.onTransactionSend(r),n.waitForTransactionReceipt({hash:r}).then(o=>e.onTransactionReceipt(o)).catch(o=>e.onError(o))}};var Kt=require("@galacticcouncil/xc-core"),We=require("@solana/web3.js"),Ue=require("buffer"),N=require("rxjs");var Z=class{connection;config;constructor(t,e){this.validateConnection(t),this.validateConfig(e),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}validateConfig(t){if(!t.address)throw new Error("Solana address is required")}};var ke=require("@wormhole-foundation/sdk-solana");var Rn=9,Mt=class extends Z{async getBalance(){let{address:t}=this.config,e=new ke.SolanaAddress(t).unwrap(),s=await this.connection.getBalance(e);return BigInt(s)}async getDecimals(){return Rn}};var Nt=require("@wormhole-foundation/sdk-solana");var Wt=class extends Z{constructor(t,e){super(t,e),this.validateToken(e)}async getBalance(){let{address:t,token:e}=this.config,s=new Nt.SolanaAddress(t).unwrap(),n=new Nt.SolanaAddress(e).unwrap();return(await this.connection.getParsedTokenAccountsByOwner(s,{mint:n})).value.reduce((r,{account:o})=>{let i=o.data.parsed.info.tokenAmount;return r+=BigInt(i.amount),r},0n)}async getDecimals(){let{token:t}=this.config,e=new Nt.SolanaAddress(t).unwrap();return(await this.connection.getTokenSupply(e)).value.decimals}validateToken(t){if(!t.token)throw new Error("Token address is required")}};var Ut=class{static get(t,e){switch(e.module){case"Native":return new Mt(t,e);case"Token":return new Wt(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var D=require("@solana/web3.js"),Ve=.5,Oe=2,_e=1,Me=1e6,kn=25e4,jt=class{connection;config;constructor(t,e){this.validateConnection(t),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}async getPriorityMessage(t){let{instructions:e}=this.config,s=await this.getV0Message(t,e),n=await this.createPriorityFeeInstructions(s);return this.getV0Message(t,[...e,...n])}async estimateFee(t,e){if(e===0n)return 0n;let{instructions:s}=this.config,n=await this.getV0Message(t,s),a=await this.determineComputeBudget(n);return BigInt(a)}async getV0Message(t,e){let s=new D.PublicKey(t),{blockhash:n}=await this.connection.getLatestBlockhash("finalized");return new D.TransactionMessage({payerKey:s,recentBlockhash:n,instructions:e}).compileToV0Message()}async createPriorityFeeInstructions(t,e=Ve,s=Oe,n=_e,a=Me){let[r,o]=await Promise.all([this.determineComputeBudget(t),this.determinePriorityFee(t,e,s,n,a)]);return[D.ComputeBudgetProgram.setComputeUnitLimit({units:r}),D.ComputeBudgetProgram.setComputeUnitPrice({microLamports:o})]}async simulateTransaction(t,e){let s=new D.VersionedTransaction(e);return(await this.connection.simulateTransaction(s,{accounts:{encoding:"base64",addresses:[t]}})).value}async determineComputeBudget(t){let e=new D.VersionedTransaction(t),s=await this.connection.simulateTransaction(e),{err:n,unitsConsumed:a}=s.value;return a&&!n?Math.round(a*1.2):kn}async determinePriorityFee(t,e=Ve,s=Oe,n=_e,a=Me){let r=n,o=await this.getTxAccounts(t),i=await this.connection.getRecentPrioritizationFees({lockedWritableAccounts:o});if(i){let c=i.map(m=>m.prioritizationFee).filter(m=>m>0).sort((m,d)=>m-d),l=Math.ceil(c.length*e);if(c.length>l){let d=c[l]*s;r=Math.max(r,d)}}return Math.min(Math.max(r,n),a)}async getTxAccounts(t){let e=(await Promise.all(t.addressTableLookups.map(n=>this.connection.getAddressLookupTable(n.accountKey)))).map(n=>n.value).filter(n=>n!==null),s=t.getAccountKeys({addressLookupTableAccounts:e??void 0});return t.compiledInstructions.flatMap(n=>n.accountKeyIndexes).map(n=>t.isAccountWritable(n)?s.get(n):null).filter(n=>n!==null)}};var gt=class{static get(t,e){return new jt(t,e)}};var Ne=require("@solana/web3.js");function M(u){return u.map(t=>({program:t.programId.toBase58(),data:t.data.toString("hex"),keys:t.keys.map(e=>e.pubkey.toBase58())}))}function ce(u,t=1e3){let e=[],s=[],n=0;for(let a of u){let r=a.data?.length??0;s.length&&n+r>t&&(e.push(s),s=[],n=0),s.push(a),n+=r}return s.length&&e.push(s),e}function tt(u){let t=u.serialize();return Buffer.from(t).toString("hex")}function Vn(u){let t=Buffer.from(u,"hex"),e=Uint8Array.from(t);return Ne.MessageV0.deserialize(e)}var pt=class{#t;constructor(t){this.#t=t.connection}async buildCall(t,e,s,n){let a=gt.get(this.#t,n),r=await a.getPriorityMessage(t),o=r.serialize(),i=Ue.Buffer.from(o).toString("hex");return{from:t,data:i,ix:M(n.instructions),signers:n.signers,type:Kt.CallType.Solana,dryRun:async()=>{let{err:c,logs:l}=await a.simulateTransaction(t,r);return{call:n.module+"."+n.func,error:c,events:l}}}}async estimateFee(t,e,s,n){let a=gt.get(this.#t,n),r=await a.estimateFee(t,e),o=await a.getPriorityMessage(t),{accounts:i}=await a.simulateTransaction(t,o),l=(i&&i[0])?.lamports;if(l){let m=n.module==="TokenBridge"&&n.func==="TransferNativeWithPayload";return s.copyWith({amount:s.amount-BigInt(l)-(m?e:0n)+n.rentReserve})}return s.copyWith({amount:r+n.rentReserve})}async getBalance(t,e){let s=Ut.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return Kt.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new N.Subject,n=s.pipe((0,N.shareReplay)(1)),a=async()=>{let o=async()=>{let l=await this.getBalance(t,e);s.next(l)};await o();let i=new We.PublicKey(e.address),c=this.#t.onAccountChange(i,()=>o());return()=>{this.#t.removeAccountChangeListener(c)}},r;return a().then(o=>r=o),n.pipe((0,N.finalize)(()=>r?.()),(0,N.distinctUntilChanged)((o,i)=>o.amount===i.amount))}};var q=require("@galacticcouncil/xc-core"),S=require("@solana/web3.js"),C=require("@solana/spl-token"),je=require("@wormhole-foundation/sdk-solana"),ue=require("@wormhole-foundation/sdk-solana-core"),Ke=require("@wormhole-foundation/sdk-base"),le=require("@wormhole-foundation/sdk-definitions"),ft=require("@wormhole-foundation/sdk-solana-tokenbridge");var Q=class{#t;constructor(t){this.#t=t.connection}async sendBundle(t){let{result:e}=await this.#t._rpcRequest("sendBundle",[t]);return e}async simulateBundle(t){return(await this.#t._rpcRequest("simulateBundle",[[t]])).result}async getInflightBundleStatuses(t){let{result:e}=await this.#t._rpcRequest("getInflightBundleStatuses",[t]);return e}async getRegion(){let{result:t}=await this.#t._rpcRequest("getRegions",[]);return t}async getTipAccount(){let{result:t}=await this.#t._rpcRequest("getTipAccounts",[]);return t}};var ht=class{#t;#e;#n;constructor(t){this.#t=t,this.#e=t.connection,this.#n=new Q(t)}async redeem(t,e,s){let n=q.Wormhole.fromChain(this.#t),a=Ke.encoding.b64.decode(e),r=(0,le.deserialize)("TokenBridge:Transfer",a),o=(0,le.deserialize)("Uint8Array",a),i=this.derivePostedVaaKey(n.getCoreBridge(),Buffer.from(r.hash)),c=new S.PublicKey(t),l=s?new S.PublicKey(s):c,m=c.equals(l),d=[];if(!await this.#e.getAccountInfo(i)){let y=S.Keypair.generate(),E=await ue.utils.createVerifySignaturesInstructions(this.#t.connection,n.getCoreBridge(),c,o,y.publicKey),k=ce(E,1e3);for(let F=0;F<k.length;F++){let w=k[F],V=await this.getV0Message(c,w),O=tt(V);d.push({from:t,data:O,ix:M(w),signers:[y],type:q.CallType.Solana})}let L=ue.utils.createPostVaaInstruction(this.#e,n.getCoreBridge(),c,o,y.publicKey),ut=await this.getV0Message(c,[L]),b=tt(ut);d.push({from:t,data:b,ix:M([L]),type:q.CallType.Solana})}let p=r.payload.token.chain==="Solana",f=new S.PublicKey(r.payload.token.address.toUint8Array()),h=p&&f.equals(C.NATIVE_MINT),P=await this.#n.getTipAccount(),A=S.SystemProgram.transfer({fromPubkey:c,toPubkey:new S.PublicKey(P[0]),lamports:1e3});if(h&&m){let y=await this.redeemAndUnwrap(n,c,r,A);d.push(y)}else{let y=await this.redeemToken(n,c,l,f,p,r,A);d.push(y)}return d}async redeemToken(t,e,s,n,a,r,o){let c=(a?ft.createCompleteTransferNativeInstruction:ft.createCompleteTransferWrappedInstruction)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,r),l=(0,C.getAssociatedTokenAddressSync)(n,s),m=(0,C.createAssociatedTokenAccountIdempotentInstruction)(e,l,s,n),d=await this.getV0Message(e,[m,c,o]),g=tt(d);return{from:e.toBase58(),data:g,ix:M([m,c]),type:q.CallType.Solana}}async redeemAndUnwrap(t,e,s,n){let a=new S.PublicKey(s.payload.to.address.toUint8Array()),r=await(0,C.getMint)(this.#e,C.NATIVE_MINT),o=s.payload.token.amount*BigInt(Math.pow(10,r.decimals-8)),i=await(0,C.getMinimumBalanceForRentExemptAccount)(this.#e),c=S.Keypair.generate(),l=(0,C.createAssociatedTokenAccountIdempotentInstruction)(e,a,e,C.NATIVE_MINT),m=(0,ft.createCompleteTransferNativeInstruction)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,s),d=S.SystemProgram.createAccount({fromPubkey:e,newAccountPubkey:c.publicKey,lamports:i,space:C.ACCOUNT_SIZE,programId:C.TOKEN_PROGRAM_ID}),g=(0,C.createInitializeAccountInstruction)(c.publicKey,C.NATIVE_MINT,e),p=(0,C.createTransferInstruction)(a,c.publicKey,e,o),f=(0,C.createCloseAccountInstruction)(c.publicKey,e,e),h=[l,m,d,g,p,f,n],P=await this.getV0Message(e,h),A=tt(P);return{from:e.toBase58(),data:A,ix:M(h),signers:[c],type:q.CallType.Solana}}derivePostedVaaKey(t,e){return je.utils.deriveAddress([Buffer.from("PostedVAA"),e],t)}async getV0Message(t,e){let{blockhash:s}=await this.#e.getLatestBlockhash("finalized");return new S.TransactionMessage({payerKey:t,recentBlockhash:s,instructions:e}).compileToV0Message()}};var X=require("@solana/web3.js"),zt=require("buffer");var me=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=e,this.#n=new Q(t)}async signAndSend(t,e){let{data:s,signers:n}=t,a=this.toVersioned(s,n);try{if(this.#e instanceof X.Keypair){a.sign([this.#e]);let c=await this.#t.connection.sendTransaction(a);e.onTransactionSend(c);let l=await this.#t.connection.getSignatureStatus(c);e.onStatus?.(l);return}let r=this.#e;await r.connect(),n&&a.sign(n);let{signature:o}=await r.signAndSendTransaction(a);e.onTransactionSend(o);let i=await this.#t.connection.getSignatureStatus(o);e.onStatus?.(i)}catch(r){e.onError(r)}}async signAndSendAll(t,e){let s=t.map(n=>{let{data:a,signers:r}=n;return this.toVersioned(a,r)});try{let n;if(this.#e instanceof X.Keypair)s.forEach(i=>i.sign([this.#e])),n=s.map(i=>zt.Buffer.from(i.serialize()).toString("base64"));else{let i=this.#e;await i.connect(),n=(await i.signAllTransactions(s)).map(l=>zt.Buffer.from(l.serialize()).toString("base64"))}let a=await this.#n.simulateBundle(n);if(a.value.summary!=="succeeded")throw new Error("Bundle simulation failed! "+JSON.stringify(a,null,2));let r=await this.#n.sendBundle(n);e.onTransactionSend(r);let o=await this.#n.getInflightBundleStatuses([r]);e.onBundleStatus?.(o.value)}catch(n){e.onError(n)}}toVersioned(t,e){let s=zt.Buffer.from(t,"hex"),n=Uint8Array.from(s),a=X.MessageV0.deserialize(n),r=new X.VersionedTransaction(a);return e&&r.sign(e),r}};var W=require("@galacticcouncil/xc-core"),de=require("@wormhole-foundation/sdk-base"),ze=require("viem"),Ht=require("polkadot-api"),yt=class{#t;constructor(t){this.#t=t,W.Wormhole.fromChain(this.#t)}redeemMrl(t,e){let s=de.encoding.b64.decode(e),n=de.encoding.hex.encode(s),a=W.Abi.Gmp,r=(0,ze.encodeFunctionData)({abi:a,functionName:"wormholeTransferERC20",args:["0x"+n]});return{abi:JSON.stringify(a),data:r,from:t,to:W.Precompile.Bridge}}async redeemMrlViaXcm(t,e){let n=this.#t.client.getUnsafeApi(),a=this.redeemMrl(t,e),o=await n.tx.EthereumXcm.transact({xcm_transaction:{type:"V2",value:{gas_limit:[5000000n,0n,0n,0n],fee_payment:{type:"Auto",value:void 0},action:{type:"Call",value:Ht.Binary.fromHex(a.to)},value:[0n,0n,0n,0n],input:Ht.Binary.fromHex(a.data),access_list:void 0}}}).getEncodedData();return{data:Ht.Binary.toHex(o),from:t,type:W.CallType.Substrate,dryRun:async()=>{},txOptions:void 0}}};var $t=require("@galacticcouncil/xc-core"),Ct=require("polkadot-api");var He=require("@galacticcouncil/common");async function ge(u,t,e){let s=await e.getDecimals(),n=e.chain.getAssetDecimals(t)??s,a=e.chain.usesChainDecimals?s:n;return{amount:He.big.convertDecimals(u,a,n),decimals:n}}var Le=require("@galacticcouncil/common"),$e=u=>{let t=[];for(let e of u)if(["PolkadotXcm"].includes(e.type)&&e.value.type==="FeesPaid"){let n=e.value.value.fees;for(let a of n)if(a.fun.type==="Fungible"){let r=BigInt(a.fun.value);t.push(r)}}return t.reduce((e,s)=>e+s,0n)},et=u=>{let t=u.value.error;return t.type==="Module"?Le.enums.enumPath(t.value):JSON.stringify(t.value)};var Lt=require("@galacticcouncil/common");function On(u){return{parents:0,interior:{type:"X1",value:u.startsWith("0x")?Lt.xcm.toAccountKey20(u):Lt.xcm.toAccountId32(u)}}}function Qe(u){return{type:"V4",value:{parents:1,interior:{type:"X1",value:{type:"Parachain",value:u.parachainId}}}}}var _n=(u,t)=>({id:Lt.xcm.transform(u),fun:{type:"Fungible",value:t}}),qe=(u,t,e,s,n,a)=>{console.log(a);let r=On(u),o=_n(t,e.amount);return{type:"V4",value:[{type:"WithdrawAsset",value:[o]},{type:"BuyExecution",value:{fees:o,weight_limit:{type:"Unlimited"}}},{type:"Transact",value:{origin_kind:{type:"SovereignAccount"},require_weight_at_most:{ref_time:s,proof_size:n},call:a}},{type:"RefundSurplus",value:void 0},{type:"DepositAsset",value:{assets:{type:"Wild",value:{type:"AllCounted",value:1}},beneficiary:r}}]}};var At=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async remoteExec(t,e,s,n,a={}){let r=this.#t.api,o=await this.#t.getAsset(),i=this.#e.api,c=this.#e.chain,l=await c.getCurrency(),m=l.asset,d=l.decimals,g=c.getAssetXcmLocation(m),p=Ct.Binary.fromHex(s.data),h=await(await i.txFromCallData(p)).getPaymentInfo(e),P=BigInt(h.partial_fee)*120n/100n,A=$t.AssetAmount.fromAsset(m,{amount:P,decimals:d}),y=h.weight.ref_time,E=h.weight.proof_size,k=Qe(c),L=qe(e,g,A,y,E,p),ut=r.tx.PolkadotXcm.send({dest:k,message:L}),b=[];try{let x=await this.#t.chain.dex.getCalldata(t,a.srcFeeAsset||o,m,A,10),It=Ct.Binary.fromHex(x),$=await r.txFromCallData(It);b.push($)}catch{}let F=await n(A),w=Ct.Binary.fromHex(F.data),V=await r.txFromCallData(w);b.push(V),b.push(ut);let O=b.map(x=>x.decodedCall),Et=r.tx.Utility.batch_all({calls:O}),se=await Et.getEncodedData();return{from:t,data:Ct.Binary.toHex(se),type:$t.CallType.Substrate,dryRun:this.#t.isDryRunSupported()?async()=>{try{let x=await this.#t.dryRun(t,Et);return{call:"polkadotXcm.send",error:x.execution_result&&x.execution_result.success?void 0:et(x.execution_result),events:x.emitted_events||[],xcm:x.forwarded_xcms||[]}}catch(x){return{call:"polkadotXcm.send",error:x instanceof Error?x.message:"unknown"}}}:()=>{}}}};var J=require("@galacticcouncil/xc-core"),Je=require("polkadot-api"),B=require("rxjs");var U=require("@galacticcouncil/xc-core"),Qt=require("@galacticcouncil/common"),qt=require("@polkadot-api/substrate-bindings"),bt=require("@polkadot-api/utils"),pe=require("polkadot-api");var{Ss58Addr:Xe}=U.addr,T=class u{chain;_currency;constructor(t){this.chain=t}static async create(t){return new u(t)}get client(){return this.chain.client}get api(){return this.client.getUnsafeApi()}async getCurrency(){return this._currency||(this._currency=this.chain.getCurrency()),this._currency}async getAsset(){return(await this.getCurrency()).asset}async getDecimals(){return(await this.getCurrency()).decimals}async getExistentialDeposit(){let t;try{let n=await this.api.constants.Balances.ExistentialDeposit();t=typeof n=="bigint"?n:BigInt(String(n))}catch{t=0n}let{asset:e,decimals:s}=await this.getCurrency();return U.AssetAmount.fromAsset(e,{amount:t,decimals:s})}isDryRunSupported(){return this.api.apis?.DryRunApi!==void 0}async buildMessageId(t,e,s,n){let a=await this.client._request("system_accountNextIndex",[t]),r=qt.u32.enc(a),o=l=>new TextEncoder().encode(l),i=new Uint8Array([...o(this.chain.parachainId.toString()),...(0,bt.fromHex)(t.startsWith("0x")?t.slice(2):t),...r,...(0,bt.fromHex)(s.startsWith("0x")?s.slice(2):s),...o(n),...o(e.toString())]),c=(0,qt.Blake2256)(i);return(0,bt.toHex)(c)}async dryRun(t,e){let s=(0,pe.Enum)("Signed",t),n=(0,pe.Enum)("system",s),a=await this.api.apis.DryRunApi.dry_run_call(n,e.decodedCall,4);if(!a.success)throw new Error("DryRun call failed");let r=a.value;if("type"in r&&"value"in r)throw new Error("DryRun call error: "+Qt.enums.enumPath(r.value));return r}async estimateNetworkFee(t,e){let s=e.getTx(this.client);try{let n=await s.getPaymentInfo(t);return BigInt(n.partial_fee)}catch{console.warn("Can't estimate network fee.")}return 0n}async estimateDeliveryFee(t,e){if(this.chain.usesDeliveryFee){let s=await this.estimateDeliveryFeeWith(t,e);try{let n=e.getTx(this.client),a=await this.dryRun(s,n);if(a.execution_result?.success)return $e(a.emitted_events||[]);{let r=et(a.execution_result);console.warn(`Can't estimate delivery fee. Reason:
|
|
4
|
+
${r}`)}}catch{}}return 0n}async estimateDeliveryFeeWith(t,e){if(["PolkadotXcm"].includes(e.module)){let n=e.getTx(this.client).decodedCall.value.value,a="dest"in n?n.dest:void 0;if(!a)return t;let r=U.multiloc.findNestedKey(a,"interior"),o=U.multiloc.findParachain(a);if(U.multiloc.findGlobalConsensus(a))return t;if(o){let c=Qt.acc.getSovereignAccounts(o);return this.chain.parachainId===0?Xe.encodePubKey(c.relay):Xe.encodePubKey(c.generic)}if(r&&r.interior==="Here")return this.chain.treasury||t}return t}};var wt=class{#t;constructor(t){this.#t=T.create(t)}async useSignerFee(t){let e=await this.#t,s=await e.getAsset();return e.chain.usesSignerFee&&!s.isEqual(t)}async buildCall(t,e,s,n){let a=await this.#t,o=await this.useSignerFee(s)?{asset:new J.Asset(s)}:void 0,i=n.getTx(a.client),c=n.module+"."+n.func,l=await i.getEncodedData();return{from:t,data:Je.Binary.toHex(l),type:J.CallType.Substrate,txOptions:o,dryRun:a.isDryRunSupported()?async()=>{try{let m=n.getTx(a.client),d=await a.dryRun(t,m),g=d.execution_result&&d.execution_result.success?void 0:et(d.execution_result);return{call:c,error:g,events:d.emitted_events||[],xcm:d.forwarded_xcms||[]}}catch(m){return{call:c,error:m instanceof Error?m.message:"unknown"}}}:()=>{}}}async estimateFee(t,e,s,n){let a=await this.#t,r=await a.estimateNetworkFee(t,n),o=await a.estimateDeliveryFee(t,n),i=await this.exchangeFee(r+o,s),c=await ge(i,s,a);return s.copyWith(c)}async getBalance(t,e){let s=await this.subscribeBalance(t,e);return(0,B.firstValueFrom)(s)}async subscribeBalance(t,e){let s=await this.#t,{module:n,func:a,args:r,transform:o}=e;return s.client.getUnsafeApi().query[n][a].watchValue(...r,{at:"best"}).pipe((0,B.map)(({value:l})=>l)).pipe((0,B.concatMap)(l=>o(l)),(0,B.distinctUntilChanged)((l,m)=>l===m),(0,B.concatMap)(async l=>{let m=await ge(l,t,s);return J.AssetAmount.fromAsset(t,m)}),(0,B.catchError)(l=>(console.error("subscribe fails for:",t),(0,B.throwError)(()=>l))))}async exchangeFee(t,e){let s=await this.#t,n=await s.getAsset(),a=await s.getDecimals();if(n.isEqual(e))return t;try{let r=s.chain.dex,o=J.AssetAmount.fromAsset(n,{amount:t,decimals:a});return(await r.getQuote(e,n,o,!0)).amount}catch{}return t}};var fe=require("@galacticcouncil/xc-core"),nt=require("polkadot-api"),he=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}signAndSend(t,e){let n=this.#t.client.getUnsafeApi(),a=nt.Binary.fromHex(t.data),r={};t.txOptions?.asset&&(r={asset:this.getFeeAsset(t.txOptions.asset)}),n.txFromCallData(a).then(o=>{o.signSubmitAndWatch(this.#e,r).subscribe({next:i=>{i.type==="broadcasted"&&e.onTransactionSend(i.txHash),i.type==="finalized"&&e.onFinalized(i)},error:i=>{e.onError(i)}})})}getFeeAsset(t){let e=this.#t.getAssetXcmLocation(t);if(e){let s=fe.multiloc.findPalletInstance(e),n=fe.multiloc.findGeneralIndex(e);return{parents:0,interior:(0,nt.Enum)("X2",[(0,nt.Enum)("PalletInstance",Number(s)),(0,nt.Enum)("GeneralIndex",BigInt(n))])}}throw new Error("Asset location not found")}};var Jt=require("@galacticcouncil/xc-core"),Ye=require("@mysten/sui/transactions"),Ze=require("@mysten/sui/utils"),tn=require("@mysten/bcs"),st=require("@wormhole-foundation/sdk-connect"),en=require("@wormhole-foundation/sdk-definitions"),ye=require("@wormhole-foundation/sdk-sui"),nn=require("@wormhole-foundation/sdk-sui-tokenbridge");var Ge=require("@mysten/bcs");function Xt(u,t={}){let e=u.inputs??[],s=u.commands??[],n=t.numbers??"string",a=t.decode32As??"address",r=l=>n==="bigint"?l:n==="number"?Number(l):l.toString(),o=l=>{let m=(0,Ge.fromBase64)(l),d=g=>{let p=0n;for(let f=0;f<g;f++)p|=BigInt(m[f])<<8n*BigInt(f);return p};return m.length===1?{type:"pure",valueType:"u8",value:Number(m[0])}:m.length===2?{type:"pure",valueType:"u16",value:r(d(2))}:m.length===4?{type:"pure",valueType:"u32",value:Number(d(4))}:m.length===8?{type:"pure",valueType:"u64",value:r(d(8))}:m.length===32&&a==="address"?{type:"pure",valueType:"address",value:"0x"+[...m].map(p=>p.toString(16).padStart(2,"0")).join("")}:{type:"pure",valueType:"vector<u8>",value:Array.from(m)}},i=l=>{let m=e[l];if(!m)return{Input:l};if(m.Pure?.bytes)return o(m.Pure.bytes);let d=m.Object?.SharedObject;if(d)return{type:"object",objectType:"sharedObject",objectId:d.objectId,initialSharedVersion:String(d.initialSharedVersion),mutable:!!d.mutable};let g=m.Object?.ImmOrOwnedObject;return g?{type:"object",objectType:"immOrOwnedObject",objectId:g.objectId,version:String(g.version),digest:g.digest??void 0}:{Input:l}},c=l=>l?.GasCoin?"GasCoin":Array.isArray(l?.NestedResult)?l:typeof l?.Input=="number"?i(l.Input):l;return s.map(l=>{if(l.MoveCall){let m=l.MoveCall;return{MoveCall:{...m,arguments:(m.arguments??[]).map(c)}}}if(l.SplitCoins){let m=l.SplitCoins,d=m.coin?.GasCoin?"GasCoin":c(m.coin),g=(m.amounts??[]).map(c);return{SplitCoins:[d,g]}}if(l.MergeCoins){let m=l.MergeCoins;return{MergeCoins:{...m,destination:c(m.destination),sources:(m.sources??[]).map(c)}}}if(l.TransferObjects){let m=l.TransferObjects;return{TransferObjects:{...m,objects:(m.objects??[]).map(c),address:c(m.address)}}}return l})}var Ce=class{#t;constructor(t){this.#t=t}async redeem(t,e){let s=Jt.Wormhole.fromChain(this.#t),n=this.#t.client,a=st.encoding.b64.decode(e),r=(0,en.deserialize)("TokenBridge:Transfer",a),o=s.getCoreBridge(),i=s.getTokenBridge(),c=await(0,nn.getTokenCoinType)(n,i,r.payload.token.address.toUint8Array(),(0,st.toChainId)(r.payload.token.chain));if(!c)throw new Error("Unable to fetch token coinType");let[l,m]=await Promise.all([(0,ye.getPackageId)(n,o),(0,ye.getPackageId)(n,i)]),d=new Ye.Transaction;d.setSender(t);let[g]=d.moveCall({target:`${l}::vaa::parse_and_verify`,arguments:[d.object(o),d.pure.vector("u8",(0,st.serialize)(r)),d.object(Ze.SUI_CLOCK_OBJECT_ID)]}),[p]=d.moveCall({target:`${m}::vaa::verify_only_once`,arguments:[d.object(i),g]}),[f]=d.moveCall({target:`${m}::complete_transfer::authorize_transfer`,arguments:[d.object(i),p],typeArguments:[c]}),[h]=d.moveCall({target:`${m}::complete_transfer::redeem_relayer_payout`,arguments:[f],typeArguments:[c]});d.moveCall({target:`${m}::coin_utils::return_nonzero`,arguments:[h],typeArguments:[c]});let P=await d.build({client:n}),A=await d.toJSON(),y=Xt(JSON.parse(A));return{from:t,commands:y,data:(0,tn.toBase64)(P),type:Jt.CallType.Sui}}};var te=require("@galacticcouncil/xc-core"),an=require("@mysten/bcs"),j=require("rxjs");var Gt=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No client found")}validateConfig(t){if(!t.address)throw new Error("Sui address is required")}};var sn=require("@mysten/sui/utils");var Mn=9,Yt=class extends Gt{async getBalance(){let{address:t}=this.config,e=await this.client.getBalance({owner:t,coinType:sn.SUI_TYPE_ARG});return BigInt(e.totalBalance)}async getDecimals(){return Mn}};var Zt=class{static get(t,e){switch(e.module){case"Native":return new Yt(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var vt=class{#t;constructor(t){this.#t=t.client}async buildCall(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),o=await a.toJSON(),i=Xt(JSON.parse(o));return{from:t,commands:i,data:(0,an.toBase64)(r),type:te.CallType.Sui,dryRun:async()=>{let c=await this.#t.dryRunTransactionBlock({transactionBlock:r});return{call:n.module+"."+n.func,error:c.executionErrorSource}}}}async estimateFee(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),i=(await this.#t.dryRunTransactionBlock({transactionBlock:r})).effects.gasUsed,c=BigInt(i.computationCost),l=BigInt(i.storageCost),m=c+l;return s.copyWith({amount:m})}async getBalance(t,e){let s=Zt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return te.AssetAmount.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new j.Subject,n=s.pipe((0,j.shareReplay)(1)),a=async()=>{await(async()=>{let c=await this.getBalance(t,e);s.next(c)})();let i=setInterval(()=>{},3e3);return()=>clearInterval(i)},r;return a().then(o=>r=o),n.pipe((0,j.finalize)(()=>r?.()),(0,j.distinctUntilChanged)((o,i)=>o.amount===i.amount))}};var rn=require("@mysten/sui/keypairs/ed25519"),on=require("@mysten/sui/transactions"),Ae=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async signAndSend(t,e){let{from:s,data:n}=t,a=this.#t.client;try{if(this.#e instanceof rn.Ed25519Keypair){let i=on.Transaction.from(n),c=await a.signAndExecuteTransaction({signer:this.#e,transaction:i,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(c.digest);return}let r=await this.#e.signTransaction({transaction:n,address:s,networkID:"sui:mainnet"}),o=await a.executeTransactionBlock({transactionBlock:r.transaction,signature:r.signature,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(o.digest)}catch(r){e.onError(r)}}};var K=class{platform={};constructor(t){switch(t.getType()){case at.ChainType.EvmChain:this.registerEvm(t);break;case at.ChainType.EvmParachain:this.registerEvm(t),this.registerSubstrate(t);break;case at.ChainType.Parachain:this.registerSubstrate(t);break;case at.ChainType.SolanaChain:this.registerSolana(t);break;case at.ChainType.SuiChain:this.registerSui(t);break;default:throw new Error("Unsupported platform: "+t.getType())}}registerEvm(t){let e=t;this.platform.Evm=new dt(e)}registerSolana(t){let e=t;this.platform.Solana=new pt(e)}registerSui(t){let e=t;this.platform.Sui=new vt(e)}registerSubstrate(t){let e=t;this.platform.Substrate=new wt(e)}async buildCall(t,e,s,n){return this.platform[n.type].buildCall(t,e,s,n)}async estimateFee(t,e,s,n){return this.platform[n.type].estimateFee(t,e,s,n)}async getBalance(t,e){return this.platform[e.type].getBalance(t,e)}async subscribeBalance(t,e){return this.platform[e.type].subscribeBalance(t,e)}};var H=require("@galacticcouncil/xc-core"),xt=require("@galacticcouncil/common");var cn=require("@galacticcouncil/common"),rt=In(require("big.js"),1);function un(u,t,e,s){let n=u.toBig().minus(e.toBig()).minus(u.isSame(t)?t.toBig():new rt.default(0));return s&&(n=n.minus(u.isSame(s)?s.toBig():new rt.default(0))),u.copyWith({amount:n.lt(0)?0n:BigInt(n.toFixed())})}function ln(u,t,e,s){let a=u.copyWith({amount:0n}).toBig().plus(u.isSame(t)?t.toBig():new rt.default(0)).plus(u.toBig().lt(e.toBig())?e.toBig():new rt.default(0));return s&&(a=a.plus(u.isSame(s)&&u.toBig().lt(s.toBig())?s.toBig():new rt.default(0))),u.copyWith({amount:BigInt(a.toFixed())})}async function z(u,t){return t.isEvmParachain()?t.getDerivatedAddress(u):u}function mn(u,t){return t?cn.big.toBigInt(t,u):0n}var G=require("@galacticcouncil/xc-core"),dn=require("@galacticcouncil/common");var{EvmAddr:Nn}=G.addr,ot=class{adapter;config;constructor(t,e){this.adapter=t,this.config=e}async getEd(){let{chain:t}=this.config;if(t instanceof G.Parachain)return(await T.create(t)).getExistentialDeposit()}async getBalance(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.asset,r=e.getBalanceAssetId(a),o=Nn.isValid(r.toString())?await z(t,e):t,i=s.source.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=s.min;if(t instanceof G.Parachain&&a){let r=t.getMinAssetId(n),o=a.build({asset:r});return this.adapter.getBalance(n,o)}return this.getAssetMin()}async getAssetMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=t.getAssetMin(n),r=await this.getDecimals(n),o=0n;return a&&(o=dn.big.toBigInt(a,r)),G.AssetAmount.fromAsset(n,{amount:o,decimals:r})}async getDecimals(t){let{chain:e}=this.config,s=e.getAssetDecimals(t);return s||(await e.getCurrency()).decimals}};var{EvmAddr:gn}=H.addr,St=class extends ot{constructor(t,e){super(t,e)}async getCall(t){let{amount:e,sender:s,source:n}=t,a=await this.getTransfer(t);return this.adapter.buildCall(s,e,n.feeBalance,a)}async getDestinationFee(){let{chain:t,route:e}=this.config,{source:s,destination:n,transact:a}=e,r=n.fee.amount,o=s.destinationFee.asset||n.fee.asset,i=await this.getDecimals(o);if(Number.isFinite(r))return{fee:H.AssetAmount.fromAsset(o,{amount:xt.big.toBigInt(r,i),decimals:i}),feeBreakdown:{}};let c=r,{amount:l,breakdown:m}=await c.build({feeAsset:o,transferAsset:s.asset,source:a?a.chain:t,destination:n.chain});return{fee:H.AssetAmount.fromAsset(o,{amount:l,decimals:i}),feeBreakdown:m}}async getDestinationFeeBalance(t){let{chain:e,route:s}=this.config,{source:n,destination:a}=s,r=n.asset,o=n.destinationFee.asset||a.fee.asset;if(r.isEqual(o))return this.getBalance(t);let i=e.getBalanceAssetId(o),c=gn.isValid(i.toString())?await z(t,e):t,l=n.destinationFee.balance.build({address:c,asset:o,chain:e});return this.adapter.getBalance(o,l)}async getFee(t){let{chain:e,route:s}=this.config,{amount:n,sender:a,source:r}=t,o=await this.getTransfer(t),i=s.contract?await z(a,e):a,c=await this.adapter.estimateFee(i,n,r.feeBalance,o),{fee:l}=s.source,m=l?mn(c.decimals,l.extra):0n,d=c.amount+m;return c.copyWith({amount:d})}async getFeeBalance(t){let{chain:e,route:s}=this.config,{source:n}=s;if(!n.fee)return this.getBalance(t);let a=await this.getFeeAsset(t),r=e.getBalanceAssetId(a),o=gn.isValid(r.toString())?await z(t,e):t,i=n.fee.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getFeeAsset(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.fee,r=n.asset;if(!a)return r;let o=a.asset;return e instanceof H.Parachain&&"build"in o?await o.build({chain:e,address:t}):o}async getTransfer(t){let{chain:e,route:s}=this.config,{contract:n,extrinsic:a,program:r,move:o}=s;if(a){let{address:c,amount:l,asset:m,sender:d}=t,p=await(await T.create(e)).buildMessageId(d,l,m.originSymbol,c);return a.build({...t,messageId:p})}let i=n||r||o;if(i)return i.build({...t});throw new Error("AssetRoute transfer config is invalid! Specify contract, extrinsic, move or program instructions.")}async getTransact(t){let{route:e}=this.config,{transact:s}=e;if(s){let n=Object.assign({transact:{chain:s.chain}}),a={...t,...n};return{...await this.getTransactData(s,a),chain:s.chain}}}async getTransactData(t,e){let{chain:s,extrinsic:n}=t,a=await n.build(e),r=await T.create(s),o=a.getTx(r.client),i=e.source.chain,c=e.sender,l=xt.acc.getMultilocationDerivatedAccount(i.parachainId,c,s.parachainId===0?0:1,s.usesH160Acc),m=await o.getPaymentInfo(l),d=await o.getEncodedData(),[g,p]=await Promise.all([this.getTransactFee(t),this.getTransactFeeBalance(t,e)]);return{call:d,chain:s,fee:g,feeBalance:p,weight:{refTime:m.weight.ref_time,proofSize:m.weight.proof_size}}}async getTransactFee(t){let{fee:e}=t,s=await this.getDecimals(e.asset),n=xt.big.toBigInt(e.amount,s);return H.AssetAmount.fromAsset(e.asset,{amount:n,decimals:s})}async getTransactFeeBalance(t,e){let{chain:s}=this.config,{fee:n}=t,a=n.balance.build({address:e.sender,asset:n.asset,chain:s});return this.adapter.getBalance(n.asset,a)}};var Pt=class extends ot{constructor(t,e){super(t,e)}};var pn=require("@galacticcouncil/xc-core"),it=class{ctx;constructor(t){this.ctx=t}get asset(){let{source:t}=this.ctx;return t.balance}get dex(){let{source:t}=this.ctx;return t.chain.dex}get destFee(){let{source:t,transact:e}=this.ctx;return e?e.fee:t.destinationFee}get destFeeBalance(){let{source:t,transact:e}=this.ctx;return e?e.feeBalance:t.destinationFeeBalance}get feeBalance(){let{source:t}=this.ctx;return t.feeBalance}async getSwap(t){let{asset:e,decimals:s}=await this.dex.chain.getCurrency(),{amount:n}=await this.dex.getQuote(e,t,t);return{aIn:t,aOut:pn.AssetAmount.fromAsset(e,{amount:n,decimals:s}),enabled:!0}}isSwapSupported(t){try{this.dex}catch{return!1}return!!(t&&t.swap)}async getDestinationSwap(t){let{amount:e,route:s}=await this.dex.getQuote(t,this.destFee,this.destFee),n=this.destFeeBalance.amount<this.destFee.amount,a=this.feeBalance.amount-t.amount>e*2n;return{aIn:t.copyWith({amount:e}),aOut:this.destFee,enabled:n&&a,route:s}}isDestinationSwapSupported(t){try{this.dex}catch{return!1}let e=!t.isSame(this.destFee),s=this.asset.isSame(this.destFee);return e&&!s}};var{EvmAddr:Wn}=ct.addr,ee=class{config;validations;constructor({configService:t,transferValidations:e}){this.config=t,this.validations=e||[]}async transfer(t,e,s,n,a){let r=(0,ct.ConfigBuilder)(this.config).assets().asset(t).source(s).destination(a).build();return this.getTransferData(r,e,n)}async remoteXcm(t,e,s,n,a={}){let r=this.config.getChain(e),o=this.config.getChain(s);if(!(r.isSubstrate()&&o.isSubstrate()))throw Error("RemoteXcm is supported only between parachains");let[c,l]=await Promise.all([T.create(r),T.create(o)]),m=new At(c,l),d=Tt.acc.getMultilocationDerivatedAccount(r.parachainId,t,1,o.usesH160Acc),g=await l.getAsset(),p=await this.transfer(g,t,e,d,s);return m.remoteExec(t,d,n,f=>{let h=f.toDecimal();return p.buildCall(h)},a)}async getTransferData(t,e,s){let n=t.origin,a=t.reverse,r=new K(n.chain),o=new K(a.chain),i=new St(r,n),c=new Pt(o,a),l=new ct.TransferValidator(...this.validations),[m,d,g,p,f,h,P]=await Promise.all([i.getBalance(e),i.getFeeBalance(e),i.getDestinationFee(),i.getDestinationFeeBalance(e),i.getMin(),c.getBalance(s),c.getMin()]),{source:A,destination:y}=n.route,E=g.fee.copyWith(y.fee.asset),k=g.feeBreakdown,ut=A.asset.isEqual(E)&&E.amount>10n?E.amount+1n:10n,b={address:s,amount:ut,asset:A.asset,destination:{balance:h,chain:a.chain,fee:E,feeBreakdown:k},sender:e,source:{balance:m,chain:n.chain,fee:d.copyWith({amount:0n}),feeBalance:d,destinationFee:g.fee,destinationFeeBalance:p}};b.transact=await i.getTransact(b);let F=new it(b),w=await i.getFee(b),V;F.isSwapSupported(A.fee)&&(V=await F.getSwap(w),b.source.feeSwap=V);let O;F.isDestinationSwapSupported(w)&&(O=await F.getDestinationSwap(w),b.source.destinationFeeSwap=O),(V||O)&&(w=await i.getFee(b),w=w.padByPct(5n));let Et=await c.getEd(),se=ln(h,E,P,Et),x=await i.getEd(),It=un(m,w,f,x);return b.amount=0n,b.source.fee=w,{source:{balance:m,destinationFee:g.fee,destinationFeeBalance:p,destinationFeeSwap:O,fee:w,feeBalance:d,feeSwap:V,max:It,min:m.copyWith({amount:se.amount})},destination:{balance:h,fee:E},async buildCall($){let I=Object.assign({},b);return I.amount=Tt.big.toBigInt($,m.decimals),I.transact=await i.getTransact(I),i.getCall(I)},async estimateFee($){let I=Object.assign({},b);return I.amount=Tt.big.toBigInt($,m.decimals),I.transact=await i.getTransact(I),i.getFee(I)},async validate($){let I=Object.assign({},b),vn=$||w.amount;return I.source.fee=w.copyWith({amount:vn}),l.validate(I)}}}async subscribeBalance(t,e,s){let n=this.config.getChainRoutes(e),a=new K(n.chain),r=n.getUniqueRoutes().map(async({source:c})=>{let{asset:l,balance:m}=c,d=n.chain.getBalanceAssetId(l),g=Wn.isValid(d.toString())?await z(t,n.chain):t,p=m.build({address:g,asset:l,chain:n.chain});return a.subscribeBalance(l,p)}),o=await Promise.all(r);return(0,ne.combineLatest)(o).pipe((0,ne.debounceTime)(500)).subscribe(s)}};var fn=require("@galacticcouncil/xc-core");function hn(u){let t=(0,fn.ConfigBuilder)(u.config).assets();return{assets:t,withAsset(e){let s=t.asset(e);return{sources:s,withSource(n){let a=s.source(n);return{destinations:a,withDestination(r){let{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:l,build:m}=a.destination(r);return{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:l,build({srcAddress:d,dstAddress:g,dstAsset:p,tag:f}){let h=m(p,f);return u.getTransferData(h,d,g)}}}}}}}}}var yn=require("@galacticcouncil/xc-core"),Un="https://api.wormholescan.io",Bt=class{_baseUrl;constructor(t){this._baseUrl=t||Un}buildApi(t,e){return[this._baseUrl,t,"?"].join("")+new URLSearchParams(e).toString()}async getVaaBytes(t){let e=this.buildApi("/v1/signed_vaa/"+t,{});return await(await fetch(e)).json()}async getVaa(t){let e=this.buildApi("/api/v1/vaas/"+t,{});return(await(await fetch(e)).json()).data}async getVaaByTxHash(t){let e=this.buildApi("/api/v1/vaas/",{txHash:t}),n=await(await fetch(e)).json();if(n.data.length>0)return n.data[0];throw Error("Can't find VAA for given txHash: "+t)}async getOperations(t){let e=this.buildApi("/api/v1/operations/",t);return(await(await fetch(e)).json()).operations}async getOperation(t){let e=this.buildApi("/api/v1/operations/"+t,{});return await(await fetch(e)).json()}isMrlTransfer(t){let{payloadType:e,toAddress:s,toChain:n}=t,a="0x"+s.substring(26);return e===3&&n===16&&a===yn.Precompile.Bridge}};var Cn=require("@galacticcouncil/common"),v=require("@galacticcouncil/xc-core"),An=require("@wormhole-foundation/sdk-base"),bn=require("@wormhole-foundation/sdk-connect"),wn=require("@wormhole-foundation/sdk-definitions");var be=(s=>(s[s.WaitingForVaa=0]="WaitingForVaa",s[s.VaaEmitted=1]="VaaEmitted",s[s.Completed=2]="Completed",s))(be||{});var jn=300*1e3,we=class{parachainId;config;whScan;constructor(t,e){this.config=t,this.parachainId=e,this.whScan=new Bt}get chains(){let t=this.config.chains.values();return Array.from(t)}get filters(){let t=new Date,e=new Date;e.setDate(t.getDate()-6);let s=t.toISOString();return{page:"0",pageSize:"50",includeEndDate:"true",from:e.toISOString(),to:s}}async getWithdraws(t){let e=Cn.acc.getMultilocationDerivatedAccount(this.parachainId,t,1,!0),n=(await this.whScan.getOperations({...this.filters,address:e})).map(async a=>{let{content:r}=a,{payload:o,standarizedProperties:i}=r,c=this.getStatus(a),l=this.chains.find(f=>f instanceof v.Parachain&&f.parachainId===this.parachainId),{toAddress:m,tokenAddress:d}=i,g=this.chains.find(f=>v.Wormhole.isKnown(f)&&v.Wormhole.fromChain(f).getWormholeId()===o.tokenChain),p;if(c===1&&a.vaa){let{timestamp:f}=this.getVaaHeader(a.vaa.raw),h=a.vaa.raw;if(this.isStuck(f))switch(g.getType()){case v.ChainType.EvmChain:let P=new lt(g);p=async y=>P.redeem(y,h);break;case v.ChainType.SolanaChain:let A=new ht(g);p=async y=>A.redeem(y,h);break}}return{asset:d,assetSymbol:a.data.symbol,amount:a.data.tokenAmount,from:t,fromChain:l,to:m,toChain:g,status:c,redeem:p,operation:a}});return Promise.all(n)}async getDeposits(t,e="hydration"){let s=await this.whScan.getOperations({...this.filters,address:v.Precompile.Bridge,pageSize:"100"}),n=this.config.chains.get(e);if(!n)return[];let a=n,o=(await v.mrl.createPayload(a,t)).toHex(),i=s.filter(c=>{let{content:l}=c,{payload:m}=l;return m.payloadType===3&&m.toChain===16&&"0x"+m.payload===o}).map(async c=>{let{content:l,sourceChain:m}=c,{payload:d,standarizedProperties:g}=l,p=this.getStatus(c),{tokenAddress:f}=g,h=this.chains.find(y=>v.Wormhole.isKnown(y)&&v.Wormhole.fromChain(y).getWormholeId()===d.tokenChain),P=this.chains.find(y=>v.Wormhole.isKnown(y)&&v.Wormhole.fromChain(y).getWormholeId()===d.toChain),A;if(p===1&&c.vaa){let{timestamp:y}=this.getVaaHeader(c.vaa.raw),E=c.vaa.raw;if(this.isStuck(y)){let k=new yt(P);A=async L=>k.redeemMrlViaXcm(L,E)}}return{asset:f,assetSymbol:c.data.symbol,amount:c.data.tokenAmount,from:m.from,fromChain:h,to:t,toChain:n,status:p,redeem:A,operation:c}});return Promise.all(i)}isStuck(t){return Date.now()>=t*1e3+jn}getVaaHeader(t){let e=An.encoding.b64.decode(t),s=(0,wn.deserialize)("Uint8Array",e);return{timestamp:s.timestamp,emitterChain:s.emitterChain,emitterAddress:s.emitterAddress.toString(),sequence:s.sequence,payload:s.payload,hash:s.hash,id:(0,bn.keccak256)(s.hash)}}getStatus(t){return t.vaa?t.targetChain&&t.targetChain.status==="completed"?2:1:0}};0&&(module.exports={DISPATCH_ADDRESS,EvmClaim,EvmPlatform,EvmSigner,FeeSwap,PlatformAdapter,SolanaClaim,SolanaLilJit,SolanaPlatform,SolanaSigner,SubstrateClaim,SubstrateExec,SubstratePlatform,SubstrateService,SubstrateSigner,SuiClaim,SuiPlatform,SuiSigner,TransferBuilder,Wallet,WhStatus,WormholeScan,WormholeTransfer,chunkBySize,deserializeV0,ixToHuman,serializeV0});
|
package/build/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{acc as
|
|
1
|
+
import{acc as Ts,big as ve}from"@galacticcouncil/common";import{addr as Bs,ConfigBuilder as Es,TransferValidator as Is}from"@galacticcouncil/xc-core";import{combineLatest as Fs,debounceTime as Ds}from"rxjs";import{ChainType as $}from"@galacticcouncil/xc-core";import{Abi as Be,Wormhole as Ee}from"@galacticcouncil/xc-core";import{encodeFunctionData as Ie}from"viem";import{encoding as Vt}from"@wormhole-foundation/sdk-base";var Z=class{#t;constructor(t){this.#t=t}redeem(t,e){let s=Ee.fromChain(this.#t),n=Vt.b64.decode(e),a=Vt.hex.encode(n),r=Be.TokenBridge,o=Ie({abi:r,functionName:"completeTransfer",args:["0x"+a]});return{abi:JSON.stringify(r),data:o,from:t,to:s.getTokenBridge()}}};import{Abi as Oe,AssetAmount as _e,CallType as Nt,Erc20Client as Me}from"@galacticcouncil/xc-core";import{distinctUntilChanged as Ne,finalize as We,shareReplay as Ue,Subject as je}from"rxjs";var O=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No EVM client found")}validateConfig(t){if(!t.address)throw new Error("Contract address is required")}};import{Erc20Client as Fe}from"@galacticcouncil/xc-core";var tt=class extends O{erc20;constructor(t,e){super(t,e),this.erc20=new Fe(t,e.address)}async getBalance(){let{args:t}=this.config,[e]=t;return this.erc20.balanceOf(e)}async getDecimals(){return this.erc20.decimals()}};var et=class extends O{async getBalance(){let t=this.client.getProvider(),{address:e}=this.config;return t.getBalance({address:e})}async getDecimals(){return this.client.chain.nativeCurrency.decimals}};var nt=class{static get(t,e){switch(e.module){case"Erc20":return new tt(t,e);case"Native":return new et(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};import{ContractFunctionExecutionError as De,decodeEventLog as Re}from"viem";var st=class{client;config;constructor(t,e){this.validateClient(t),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No EVM client found")}get abi(){return this.config.abi}get asset(){let t=this.config.args,[e]=t;return e}get calldata(){return this.config.encodeFunctionData()}async estimateGas(t){let{address:e,args:s,value:n,func:a}=this.config;return await this.client.getProvider().estimateContractGas({address:e,abi:this.abi,functionName:a,args:s,value:n,account:t})}async estimateFee(t,e){if(e===0n)return 0n;try{let s=await this.estimateGas(t),n=await this.getGasPrice();return s*n}catch(s){return s instanceof De?console.log(`Can't estimate fees!
|
|
2
2
|
`,s.message):console.log(s),0n}}async getGasPrice(){return this.client.getProvider().getGasPrice()}async getNonce(t){return this.client.getProvider().getTransactionCount({address:t})}async simulateCall(t){let{address:e,args:s,value:n,func:a}=this.config,r=this.client.getProvider(),o=await this.getNonce(t);try{let{results:i}=await r.simulateCalls({account:t,calls:[{to:e,abi:this.abi,functionName:a,args:s,value:n}],stateOverrides:[{address:t,nonce:o}]}),[c]=i;return c}catch(i){return console.log(`Can't simulate call!
|
|
3
|
-
`,i.details),{error:i}}}decodeEvents(t){let e=[];return t&&t.forEach(s=>{try{let{eventName:n,args:a}=Fe({abi:this.abi,data:s.data,topics:s.topics});e.push({eventName:n,args:a})}catch{}}),e}};var K=class{static get(t,e){return new st(t,e)}};import{Precompile as De}from"@galacticcouncil/xc-core";function Ot(m){let t=m.module==="Snowbridge"&&m.func==="sendToken"&&m.args[0]==="0x0000000000000000000000000000000000000000";return m.module==="TokenBridge"&&["wrapAndTransferETHWithPayload","wrapAndTransferETH"].includes(m.func)||t}function Vt(m){return Object.entries(De).map(([e,s])=>s).includes(m.address)}var at=class{#t;constructor(t){this.#t=t.evmClient}async buildCall(t,e,s,n){let a=K.get(this.#t,n),{abi:r,asset:o,calldata:i}=a,c={abi:JSON.stringify(r),data:i,from:t,to:n.address,type:_t.Evm,value:n.value,dryRun:async()=>{let{error:g,logs:p}=await a.simulateCall(t),f=a.decodeEvents(p);return{call:n.module+"."+n.func,error:g?.shortMessage,events:f}}};if(Vt(n)||Ot(n))return c;let l=new Oe(this.#t,o),u=await l.allowance(t,n.address);if(u>=e)return c;let d=l.approve(n.address,e);return{abi:JSON.stringify(Re.Erc20),allowance:u,data:d,from:t,to:o,type:_t.Evm,dryRun:()=>{}}}async estimateFee(t,e,s,n){let r=await K.get(this.#t,n).estimateFee(t,e);return s.copyWith({amount:r})}async getBalance(t,e){let s=nt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return ke.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new Ne,n=s.pipe(Me(1)),a=this.#t.getProvider(),r=async()=>{let i=async()=>{let l=await this.getBalance(t,e);s.next(l)};await i();let c=a.watchBlocks({onBlock:()=>i()});return()=>c()},o;return r().then(i=>o=i),n.pipe(_e(()=>o?.()),Ve((i,c)=>i.amount===c.amount))}};import{EvmParachain as We}from"@galacticcouncil/xc-core";import{h160 as Ue}from"@galacticcouncil/common";import{Binary as je}from"polkadot-api";var Mt="0x0000000000000000000000000000000000000401",{H160:Ke}=Ue,Nt=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=t.evmClient,this.#n=e}async signAndSend(t,e){let s=Ke.fromAny(t.from),n=this.#e.getProvider(),a=!1;if(this.#t instanceof We)try{let o=this.#t.client,i=je.fromHex(t.data);await o.getUnsafeApi().txFromCallData(i),a=!0}catch{}let r;if(a){let[o,i]=await Promise.all([n.estimateGas({account:s,data:t.data,to:Mt}),n.getGasPrice()]),c=i+i/100n*10n;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:t.data,maxPriorityFeePerGas:c,maxFeePerGas:c,gas:o*11n/10n,to:Mt})}else{let{data:o,to:i,value:c}=t;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:o,to:i,value:c})}e.onTransactionSend(r),n.waitForTransactionReceipt({hash:r}).then(o=>e.onTransactionReceipt(o)).catch(o=>e.onError(o))}};import{AssetAmount as Xe,CallType as Je}from"@galacticcouncil/xc-core";import{PublicKey as Ge}from"@solana/web3.js";import{Buffer as Ye}from"buffer";import{distinctUntilChanged as Ze,finalize as tn,shareReplay as en,Subject as nn}from"rxjs";var _=class{connection;config;constructor(t,e){this.validateConnection(t),this.validateConfig(e),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}validateConfig(t){if(!t.address)throw new Error("Solana address is required")}};import{SolanaAddress as ze}from"@wormhole-foundation/sdk-solana";var He=9,rt=class extends _{async getBalance(){let{address:t}=this.config,e=new ze(t).unwrap(),s=await this.connection.getBalance(e);return BigInt(s)}async getDecimals(){return He}};import{SolanaAddress as St}from"@wormhole-foundation/sdk-solana";var ot=class extends _{constructor(t,e){super(t,e),this.validateToken(e)}async getBalance(){let{address:t,token:e}=this.config,s=new St(t).unwrap(),n=new St(e).unwrap();return(await this.connection.getParsedTokenAccountsByOwner(s,{mint:n})).value.reduce((r,{account:o})=>{let i=o.data.parsed.info.tokenAmount;return r+=BigInt(i.amount),r},0n)}async getDecimals(){let{token:t}=this.config,e=new St(t).unwrap();return(await this.connection.getTokenSupply(e)).value.decimals}validateToken(t){if(!t.token)throw new Error("Token address is required")}};var it=class{static get(t,e){switch(e.module){case"Native":return new rt(t,e);case"Token":return new ot(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};import{ComputeBudgetProgram as Wt,PublicKey as Le,TransactionMessage as $e,VersionedTransaction as Ut}from"@solana/web3.js";var jt=.5,Kt=2,zt=1,Ht=1e6,Qe=25e4,ct=class{connection;config;constructor(t,e){this.validateConnection(t),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}async getPriorityMessage(t){let{instructions:e}=this.config,s=await this.getV0Message(t,e),n=await this.createPriorityFeeInstructions(s);return this.getV0Message(t,[...e,...n])}async estimateFee(t,e){if(e===0n)return 0n;let{instructions:s}=this.config,n=await this.getV0Message(t,s),a=await this.determineComputeBudget(n);return BigInt(a)}async getV0Message(t,e){let s=new Le(t),{blockhash:n}=await this.connection.getLatestBlockhash("finalized");return new $e({payerKey:s,recentBlockhash:n,instructions:e}).compileToV0Message()}async createPriorityFeeInstructions(t,e=jt,s=Kt,n=zt,a=Ht){let[r,o]=await Promise.all([this.determineComputeBudget(t),this.determinePriorityFee(t,e,s,n,a)]);return[Wt.setComputeUnitLimit({units:r}),Wt.setComputeUnitPrice({microLamports:o})]}async simulateTransaction(t,e){let s=new Ut(e);return(await this.connection.simulateTransaction(s,{accounts:{encoding:"base64",addresses:[t]}})).value}async determineComputeBudget(t){let e=new Ut(t),s=await this.connection.simulateTransaction(e),{err:n,unitsConsumed:a}=s.value;return a&&!n?Math.round(a*1.2):Qe}async determinePriorityFee(t,e=jt,s=Kt,n=zt,a=Ht){let r=n,o=await this.getTxAccounts(t),i=await this.connection.getRecentPrioritizationFees({lockedWritableAccounts:o});if(i){let c=i.map(u=>u.prioritizationFee).filter(u=>u>0).sort((u,d)=>u-d),l=Math.ceil(c.length*e);if(c.length>l){let d=c[l]*s;r=Math.max(r,d)}}return Math.min(Math.max(r,n),a)}async getTxAccounts(t){let e=(await Promise.all(t.addressTableLookups.map(n=>this.connection.getAddressLookupTable(n.accountKey)))).map(n=>n.value).filter(n=>n!==null),s=t.getAccountKeys({addressLookupTableAccounts:e??void 0});return t.compiledInstructions.flatMap(n=>n.accountKeyIndexes).map(n=>t.isAccountWritable(n)?s.get(n):null).filter(n=>n!==null)}};var z=class{static get(t,e){return new ct(t,e)}};import{MessageV0 as qe}from"@solana/web3.js";function k(m){return m.map(t=>({program:t.programId.toBase58(),data:t.data.toString("hex"),keys:t.keys.map(e=>e.pubkey.toBase58())}))}function Lt(m,t=1e3){let e=[],s=[],n=0;for(let a of m){let r=a.data?.length??0;s.length&&n+r>t&&(e.push(s),s=[],n=0),s.push(a),n+=r}return s.length&&e.push(s),e}function H(m){let t=m.serialize();return Buffer.from(t).toString("hex")}function fr(m){let t=Buffer.from(m,"hex"),e=Uint8Array.from(t);return qe.deserialize(e)}var lt=class{#t;constructor(t){this.#t=t.connection}async buildCall(t,e,s,n){let a=z.get(this.#t,n),r=await a.getPriorityMessage(t),o=r.serialize(),i=Ye.from(o).toString("hex");return{from:t,data:i,ix:k(n.instructions),signers:n.signers,type:Je.Solana,dryRun:async()=>{let{err:c,logs:l}=await a.simulateTransaction(t,r);return{call:n.module+"."+n.func,error:c,events:l}}}}async estimateFee(t,e,s,n){let a=z.get(this.#t,n),r=await a.estimateFee(t,e),o=await a.getPriorityMessage(t),{accounts:i}=await a.simulateTransaction(t,o),l=(i&&i[0])?.lamports;if(l){let u=n.module==="TokenBridge"&&n.func==="TransferNativeWithPayload";return s.copyWith({amount:s.amount-BigInt(l)-(u?e:0n)+n.rentReserve})}return s.copyWith({amount:r+n.rentReserve})}async getBalance(t,e){let s=it.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return Xe.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new nn,n=s.pipe(en(1)),a=async()=>{let o=async()=>{let l=await this.getBalance(t,e);s.next(l)};await o();let i=new Ge(e.address),c=this.#t.onAccountChange(i,()=>o());return()=>{this.#t.removeAccountChangeListener(c)}},r;return a().then(o=>r=o),n.pipe(tn(()=>r?.()),Ze((o,i)=>o.amount===i.amount))}};import{CallType as ut,Wormhole as sn}from"@galacticcouncil/xc-core";import{Keypair as $t,PublicKey as L,SystemProgram as Qt,TransactionMessage as an}from"@solana/web3.js";import{ACCOUNT_SIZE as rn,NATIVE_MINT as mt,TOKEN_PROGRAM_ID as on,createAssociatedTokenAccountIdempotentInstruction as qt,createCloseAccountInstruction as cn,createInitializeAccountInstruction as ln,createTransferInstruction as un,getAssociatedTokenAddressSync as mn,getMinimumBalanceForRentExemptAccount as dn,getMint as gn}from"@solana/spl-token";import{utils as pn}from"@wormhole-foundation/sdk-solana";import{utils as Xt}from"@wormhole-foundation/sdk-solana-core";import{encoding as fn}from"@wormhole-foundation/sdk-base";import{deserialize as Jt}from"@wormhole-foundation/sdk-definitions";import{createCompleteTransferNativeInstruction as Gt,createCompleteTransferWrappedInstruction as hn}from"@wormhole-foundation/sdk-solana-tokenbridge";var M=class{#t;constructor(t){this.#t=t.connection}async sendBundle(t){let{result:e}=await this.#t._rpcRequest("sendBundle",[t]);return e}async simulateBundle(t){return(await this.#t._rpcRequest("simulateBundle",[[t]])).result}async getInflightBundleStatuses(t){let{result:e}=await this.#t._rpcRequest("getInflightBundleStatuses",[t]);return e}async getRegion(){let{result:t}=await this.#t._rpcRequest("getRegions",[]);return t}async getTipAccount(){let{result:t}=await this.#t._rpcRequest("getTipAccounts",[]);return t}};var dt=class{#t;#e;#n;constructor(t){this.#t=t,this.#e=t.connection,this.#n=new M(t)}async redeem(t,e,s){let n=sn.fromChain(this.#t),a=fn.b64.decode(e),r=Jt("TokenBridge:Transfer",a),o=Jt("Uint8Array",a),i=this.derivePostedVaaKey(n.getCoreBridge(),Buffer.from(r.hash)),c=new L(t),l=s?new L(s):c,u=c.equals(l),d=[];if(!await this.#e.getAccountInfo(i)){let h=$t.generate(),x=await Xt.createVerifySignaturesInstructions(this.#t.connection,n.getCoreBridge(),c,o,h.publicKey),B=Lt(x,1e3);for(let T=0;T<B.length;T++){let b=B[T],E=await this.getV0Message(c,b),I=H(E);d.push({from:t,data:I,ix:k(b),signers:[h],type:ut.Solana})}let D=Xt.createPostVaaInstruction(this.#e,n.getCoreBridge(),c,o,h.publicKey),j=await this.getV0Message(c,[D]),A=H(j);d.push({from:t,data:A,ix:k([D]),type:ut.Solana})}let p=r.payload.token.chain==="Solana",f=new L(r.payload.token.address.toUint8Array()),y=p&&f.equals(mt),v=await this.#n.getTipAccount(),C=Qt.transfer({fromPubkey:c,toPubkey:new L(v[0]),lamports:1e3});if(y&&u){let h=await this.redeemAndUnwrap(n,c,r,C);d.push(h)}else{let h=await this.redeemToken(n,c,l,f,p,r,C);d.push(h)}return d}async redeemToken(t,e,s,n,a,r,o){let c=(a?Gt:hn)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,r),l=mn(n,s),u=qt(e,l,s,n),d=await this.getV0Message(e,[u,c,o]),g=H(d);return{from:e.toBase58(),data:g,ix:k([u,c]),type:ut.Solana}}async redeemAndUnwrap(t,e,s,n){let a=new L(s.payload.to.address.toUint8Array()),r=await gn(this.#e,mt),o=s.payload.token.amount*BigInt(Math.pow(10,r.decimals-8)),i=await dn(this.#e),c=$t.generate(),l=qt(e,a,e,mt),u=Gt(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,s),d=Qt.createAccount({fromPubkey:e,newAccountPubkey:c.publicKey,lamports:i,space:rn,programId:on}),g=ln(c.publicKey,mt,e),p=un(a,c.publicKey,e,o),f=cn(c.publicKey,e,e),y=[l,u,d,g,p,f,n],v=await this.getV0Message(e,y),C=H(v);return{from:e.toBase58(),data:C,ix:k(y),signers:[c],type:ut.Solana}}derivePostedVaaKey(t,e){return pn.deriveAddress([Buffer.from("PostedVAA"),e],t)}async getV0Message(t,e){let{blockhash:s}=await this.#e.getLatestBlockhash("finalized");return new an({payerKey:t,recentBlockhash:s,instructions:e}).compileToV0Message()}};import{Keypair as Yt,MessageV0 as yn,VersionedTransaction as Cn}from"@solana/web3.js";import{Buffer as Pt}from"buffer";var Zt=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=e,this.#n=new M(t)}async signAndSend(t,e){let{data:s,signers:n}=t,a=this.toVersioned(s,n);try{if(this.#e instanceof Yt){a.sign([this.#e]);let c=await this.#t.connection.sendTransaction(a);e.onTransactionSend(c);let l=await this.#t.connection.getSignatureStatus(c);e.onStatus?.(l);return}let r=this.#e;await r.connect(),n&&a.sign(n);let{signature:o}=await r.signAndSendTransaction(a);e.onTransactionSend(o);let i=await this.#t.connection.getSignatureStatus(o);e.onStatus?.(i)}catch(r){e.onError(r)}}async signAndSendAll(t,e){let s=t.map(n=>{let{data:a,signers:r}=n;return this.toVersioned(a,r)});try{let n;if(this.#e instanceof Yt)s.forEach(i=>i.sign([this.#e])),n=s.map(i=>Pt.from(i.serialize()).toString("base64"));else{let i=this.#e;await i.connect(),n=(await i.signAllTransactions(s)).map(l=>Pt.from(l.serialize()).toString("base64"))}let a=await this.#n.simulateBundle(n);if(a.value.summary!=="succeeded")throw new Error("Bundle simulation failed! "+JSON.stringify(a,null,2));let r=await this.#n.sendBundle(n);e.onTransactionSend(r);let o=await this.#n.getInflightBundleStatuses([r]);e.onBundleStatus?.(o.value)}catch(n){e.onError(n)}}toVersioned(t,e){let s=Pt.from(t,"hex"),n=Uint8Array.from(s),a=yn.deserialize(n),r=new Cn(a);return e&&r.sign(e),r}};import{Abi as An,CallType as bn,Precompile as wn,Wormhole as vn}from"@galacticcouncil/xc-core";import{encoding as te}from"@wormhole-foundation/sdk-base";import{encodeFunctionData as xn}from"viem";import{Binary as Tt}from"polkadot-api";var gt=class{#t;constructor(t){this.#t=t,vn.fromChain(this.#t)}redeemMrl(t,e){let s=te.b64.decode(e),n=te.hex.encode(s),a=An.Gmp,r=xn({abi:a,functionName:"wormholeTransferERC20",args:["0x"+n]});return{abi:JSON.stringify(a),data:r,from:t,to:wn.Bridge}}async redeemMrlViaXcm(t,e){let n=this.#t.client.getUnsafeApi(),a=this.redeemMrl(t,e),o=await n.tx.EthereumXcm.transact({xcm_transaction:{type:"V2",value:{gas_limit:[5000000n,0n,0n,0n],fee_payment:{type:"Auto",value:void 0},action:{type:"Call",value:Tt.fromHex(a.to)},value:[0n,0n,0n,0n],input:Tt.fromHex(a.data),access_list:void 0}}}).getEncodedData();return{data:Tt.toHex(o),from:t,type:bn.Substrate,dryRun:async()=>{},txOptions:void 0}}};import{AssetAmount as En,CallType as In}from"@galacticcouncil/xc-core";import{Binary as pt}from"polkadot-api";import{big as Sn}from"@galacticcouncil/common";async function Bt(m,t,e){let s=await e.getDecimals(),n=e.chain.getAssetDecimals(t)??s,a=e.chain.usesChainDecimals?s:n;return{amount:Sn.convertDecimals(m,a,n),decimals:n}}import{enums as Pn}from"@galacticcouncil/common";var ee=m=>{let t=[];for(let e of m)if(["PolkadotXcm"].includes(e.type)&&e.value.type==="FeesPaid"){let n=e.value.value.fees;for(let a of n)if(a.fun.type==="Fungible"){let r=BigInt(a.fun.value);t.push(r)}}return t.reduce((e,s)=>e+s,0n)},N=m=>{let t=m.value.error;return t.type==="Module"?Pn.enumPath(t.value):JSON.stringify(t.value)};import{xcm as Et}from"@galacticcouncil/common";function Tn(m){return{parents:0,interior:{type:"X1",value:m.startsWith("0x")?Et.toAccountKey20(m):Et.toAccountId32(m)}}}function ne(m){return{type:"V4",value:{parents:1,interior:{type:"X1",value:{type:"Parachain",value:m.parachainId}}}}}var Bn=(m,t)=>({id:Et.transform(m),fun:{type:"Fungible",value:t}}),se=(m,t,e,s,n,a)=>{console.log(a);let r=Tn(m),o=Bn(t,e.amount);return{type:"V4",value:[{type:"WithdrawAsset",value:[o]},{type:"BuyExecution",value:{fees:o,weight_limit:{type:"Unlimited"}}},{type:"Transact",value:{origin_kind:{type:"SovereignAccount"},require_weight_at_most:{ref_time:s,proof_size:n},call:a}},{type:"RefundSurplus",value:void 0},{type:"DepositAsset",value:{assets:{type:"Wild",value:{type:"AllCounted",value:1}},beneficiary:r}}]}};var ft=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async remoteExec(t,e,s,n,a={}){let r=this.#t.api,o=await this.#t.getAsset(),i=this.#e.api,c=this.#e.chain,l=await c.getCurrency(),u=l.asset,d=l.decimals,g=c.getAssetXcmLocation(u),p=pt.fromHex(s.data),y=await(await i.txFromCallData(p)).getPaymentInfo(e),v=BigInt(y.partial_fee)*120n/100n,C=En.fromAsset(u,{amount:v,decimals:d}),h=y.weight.ref_time,x=y.weight.proof_size,B=ne(c),D=se(e,g,C,h,x,p),j=r.tx.PolkadotXcm.send({dest:B,message:D}),A=[];try{let w=await this.#t.chain.dex.getCalldata(t,a.srcFeeAsset||o,u,C,10),Y=pt.fromHex(w),R=await r.txFromCallData(Y);A.push(R)}catch{}let T=await n(C),b=pt.fromHex(T.data),E=await r.txFromCallData(b);A.push(E),A.push(j);let I=A.map(w=>w.decodedCall),G=r.tx.Utility.batch_all({calls:I}),xt=await G.getEncodedData();return{from:t,data:pt.toHex(xt),type:In.Substrate,dryRun:this.#t.isDryRunSupported()?async()=>{try{let w=await this.#t.dryRun(t,G);return{call:"polkadotXcm.send",error:w.execution_result&&w.execution_result.success?void 0:N(w.execution_result),events:w.emitted_events||[],xcm:w.forwarded_xcms||[]}}catch(w){return{call:"polkadotXcm.send",error:w instanceof Error?w.message:"unknown"}}}:()=>{}}}};import{Asset as Mn,AssetAmount as ie,CallType as Nn}from"@galacticcouncil/xc-core";import{Binary as Wn}from"polkadot-api";import{concatMap as ce,catchError as Un,distinctUntilChanged as jn,firstValueFrom as Kn,map as zn,throwError as Hn}from"rxjs";import{addr as Fn,multiloc as It,AssetAmount as Dn}from"@galacticcouncil/xc-core";import{acc as Rn,enums as kn}from"@galacticcouncil/common";import{Blake2256 as On,u32 as Vn}from"@polkadot-api/substrate-bindings";import{toHex as _n,fromHex as ae}from"@polkadot-api/utils";import{Enum as re}from"polkadot-api";var{Ss58Addr:oe}=Fn,P=class m{chain;_currency;constructor(t){this.chain=t}static async create(t){return new m(t)}get client(){return this.chain.client}get api(){return this.client.getUnsafeApi()}async getCurrency(){return this._currency||(this._currency=this.chain.getCurrency()),this._currency}async getAsset(){return(await this.getCurrency()).asset}async getDecimals(){return(await this.getCurrency()).decimals}async getExistentialDeposit(){let t;try{let n=await this.api.constants.Balances.ExistentialDeposit();t=typeof n=="bigint"?n:BigInt(String(n))}catch{t=0n}let{asset:e,decimals:s}=await this.getCurrency();return Dn.fromAsset(e,{amount:t,decimals:s})}isDryRunSupported(){return this.api.apis?.DryRunApi!==void 0}async buildMessageId(t,e,s,n){let a=await this.client._request("system_accountNextIndex",[t]),r=Vn.enc(a),o=l=>new TextEncoder().encode(l),i=new Uint8Array([...o(this.chain.parachainId.toString()),...ae(t.startsWith("0x")?t.slice(2):t),...r,...ae(s.startsWith("0x")?s.slice(2):s),...o(n),...o(e.toString())]),c=On(i);return _n(c)}async dryRun(t,e){let s=re("Signed",t),n=re("system",s),a=await this.api.apis.DryRunApi.dry_run_call(n,e.decodedCall,4);if(!a.success)throw new Error("DryRun call failed");let r=a.value;if("type"in r&&"value"in r)throw new Error("DryRun call error: "+kn.enumPath(r.value));return r}async estimateNetworkFee(t,e){let s=e.getTx(this.client);try{let n=await s.getPaymentInfo(t);return BigInt(n.partial_fee)}catch{console.warn("Can't estimate network fee.")}return 0n}async estimateDeliveryFee(t,e){if(this.chain.usesDeliveryFee){let s=await this.estimateDeliveryFeeWith(t,e);try{let n=e.getTx(this.client),a=await this.dryRun(s,n);if(a.execution_result?.success)return ee(a.emitted_events||[]);{let r=N(a.execution_result);console.warn(`Can't estimate delivery fee. Reason:
|
|
4
|
-
${r}`)}}catch{}}return 0n}async estimateDeliveryFeeWith(t,e){if(["PolkadotXcm"].includes(e.module)){let n=e.getTx(this.client).decodedCall.value.value,a="dest"in n?n.dest:void 0;if(!a)return t;let r=It.findNestedKey(a,"interior"),o=It.findParachain(a);if(It.findGlobalConsensus(a))return t;if(o){let c=Rn.getSovereignAccounts(o);return this.chain.parachainId===0?oe.encodePubKey(c.relay):oe.encodePubKey(c.generic)}if(r&&r.interior==="Here")return this.chain.treasury||t}return t}};var ht=class{#t;constructor(t){this.#t=P.create(t)}async useSignerFee(t){let e=await this.#t,s=await e.getAsset();return e.chain.usesSignerFee&&!s.isEqual(t)}async buildCall(t,e,s,n){let a=await this.#t,o=await this.useSignerFee(s)?{asset:new Mn(s)}:void 0,i=n.getTx(a.client),c=n.module+"."+n.func,l=await i.getEncodedData();return{from:t,data:Wn.toHex(l),type:Nn.Substrate,txOptions:o,dryRun:a.isDryRunSupported()?async()=>{try{let u=n.getTx(a.client),d=await a.dryRun(t,u),g=d.execution_result&&d.execution_result.success?void 0:N(d.execution_result);return{call:c,error:g,events:d.emitted_events||[],xcm:d.forwarded_xcms||[]}}catch(u){return{call:c,error:u instanceof Error?u.message:"unknown"}}}:()=>{}}}async estimateFee(t,e,s,n){let a=await this.#t,r=await a.estimateNetworkFee(t,n),o=await a.estimateDeliveryFee(t,n),i=await this.exchangeFee(r+o,s),c=await Bt(i,s,a);return s.copyWith(c)}async getBalance(t,e){let s=await this.subscribeBalance(t,e);return Kn(s)}async subscribeBalance(t,e){let s=await this.#t,{module:n,func:a,args:r,transform:o}=e;return s.client.getUnsafeApi().query[n][a].watchValue(...r,{at:"best"}).pipe(zn(({value:l})=>l)).pipe(ce(l=>o(l)),jn((l,u)=>l===u),ce(async l=>{let u=await Bt(l,t,s);return ie.fromAsset(t,u)}),Un(l=>(console.error("subscribe fails for:",t),Hn(()=>l))))}async exchangeFee(t,e){let s=await this.#t,n=await s.getAsset(),a=await s.getDecimals();if(n.isEqual(e))return t;try{let r=s.chain.dex,o=ie.fromAsset(n,{amount:t,decimals:a});return(await r.getQuote(e,n,o,!0)).amount}catch{}return t}};import{multiloc as le}from"@galacticcouncil/xc-core";import{Binary as Ln,Enum as Ft}from"polkadot-api";var ue=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}signAndSend(t,e){let n=this.#t.client.getUnsafeApi(),a=Ln.fromHex(t.data),r={};t.txOptions?.asset&&(r={asset:this.getFeeAsset(t.txOptions.asset)}),n.txFromCallData(a).then(o=>{o.signSubmitAndWatch(this.#e,r).subscribe({next:i=>{i.type==="broadcasted"&&e.onTransactionSend(i.txHash),i.type==="finalized"&&e.onFinalized(i)},error:i=>{e.onError(i)}})})}getFeeAsset(t){let e=this.#t.getAssetXcmLocation(t);if(e){let s=le.findPalletInstance(e),n=le.findGeneralIndex(e);return{parents:0,interior:Ft("X2",[Ft("PalletInstance",Number(s)),Ft("GeneralIndex",BigInt(n))])}}throw new Error("Asset location not found")}};import{CallType as Qn,Wormhole as qn}from"@galacticcouncil/xc-core";import{Transaction as Xn}from"@mysten/sui/transactions";import{SUI_CLOCK_OBJECT_ID as Jn}from"@mysten/sui/utils";import{toBase64 as Gn}from"@mysten/bcs";import{encoding as Yn,serialize as Zn,toChainId as ts}from"@wormhole-foundation/sdk-connect";import{deserialize as es}from"@wormhole-foundation/sdk-definitions";import{getPackageId as me}from"@wormhole-foundation/sdk-sui";import{getTokenCoinType as ns}from"@wormhole-foundation/sdk-sui-tokenbridge";import{fromBase64 as $n}from"@mysten/bcs";function yt(m,t={}){let e=m.inputs??[],s=m.commands??[],n=t.numbers??"string",a=t.decode32As??"address",r=l=>n==="bigint"?l:n==="number"?Number(l):l.toString(),o=l=>{let u=$n(l),d=g=>{let p=0n;for(let f=0;f<g;f++)p|=BigInt(u[f])<<8n*BigInt(f);return p};return u.length===1?{type:"pure",valueType:"u8",value:Number(u[0])}:u.length===2?{type:"pure",valueType:"u16",value:r(d(2))}:u.length===4?{type:"pure",valueType:"u32",value:Number(d(4))}:u.length===8?{type:"pure",valueType:"u64",value:r(d(8))}:u.length===32&&a==="address"?{type:"pure",valueType:"address",value:"0x"+[...u].map(p=>p.toString(16).padStart(2,"0")).join("")}:{type:"pure",valueType:"vector<u8>",value:Array.from(u)}},i=l=>{let u=e[l];if(!u)return{Input:l};if(u.Pure?.bytes)return o(u.Pure.bytes);let d=u.Object?.SharedObject;if(d)return{type:"object",objectType:"sharedObject",objectId:d.objectId,initialSharedVersion:String(d.initialSharedVersion),mutable:!!d.mutable};let g=u.Object?.ImmOrOwnedObject;return g?{type:"object",objectType:"immOrOwnedObject",objectId:g.objectId,version:String(g.version),digest:g.digest??void 0}:{Input:l}},c=l=>l?.GasCoin?"GasCoin":Array.isArray(l?.NestedResult)?l:typeof l?.Input=="number"?i(l.Input):l;return s.map(l=>{if(l.MoveCall){let u=l.MoveCall;return{MoveCall:{...u,arguments:(u.arguments??[]).map(c)}}}if(l.SplitCoins){let u=l.SplitCoins,d=u.coin?.GasCoin?"GasCoin":c(u.coin),g=(u.amounts??[]).map(c);return{SplitCoins:[d,g]}}if(l.MergeCoins){let u=l.MergeCoins;return{MergeCoins:{...u,destination:c(u.destination),sources:(u.sources??[]).map(c)}}}if(l.TransferObjects){let u=l.TransferObjects;return{TransferObjects:{...u,objects:(u.objects??[]).map(c),address:c(u.address)}}}return l})}var de=class{#t;constructor(t){this.#t=t}async redeem(t,e){let s=qn.fromChain(this.#t),n=this.#t.client,a=Yn.b64.decode(e),r=es("TokenBridge:Transfer",a),o=s.getCoreBridge(),i=s.getTokenBridge(),c=await ns(n,i,r.payload.token.address.toUint8Array(),ts(r.payload.token.chain));if(!c)throw new Error("Unable to fetch token coinType");let[l,u]=await Promise.all([me(n,o),me(n,i)]),d=new Xn;d.setSender(t);let[g]=d.moveCall({target:`${l}::vaa::parse_and_verify`,arguments:[d.object(o),d.pure.vector("u8",Zn(r)),d.object(Jn)]}),[p]=d.moveCall({target:`${u}::vaa::verify_only_once`,arguments:[d.object(i),g]}),[f]=d.moveCall({target:`${u}::complete_transfer::authorize_transfer`,arguments:[d.object(i),p],typeArguments:[c]}),[y]=d.moveCall({target:`${u}::complete_transfer::redeem_relayer_payout`,arguments:[f],typeArguments:[c]});d.moveCall({target:`${u}::coin_utils::return_nonzero`,arguments:[y],typeArguments:[c]});let v=await d.build({client:n}),C=await d.toJSON(),h=yt(JSON.parse(C));return{from:t,commands:h,data:Gn(v),type:Qn.Sui}}};import{AssetAmount as rs,CallType as os}from"@galacticcouncil/xc-core";import{toBase64 as is}from"@mysten/bcs";import{distinctUntilChanged as cs,finalize as ls,shareReplay as us,Subject as ms}from"rxjs";var Ct=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No client found")}validateConfig(t){if(!t.address)throw new Error("Sui address is required")}};import{SUI_TYPE_ARG as ss}from"@mysten/sui/utils";var as=9,At=class extends Ct{async getBalance(){let{address:t}=this.config,e=await this.client.getBalance({owner:t,coinType:ss});return BigInt(e.totalBalance)}async getDecimals(){return as}};var bt=class{static get(t,e){switch(e.module){case"Native":return new At(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var wt=class{#t;constructor(t){this.#t=t.client}async buildCall(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),o=await a.toJSON(),i=yt(JSON.parse(o));return{from:t,commands:i,data:is(r),type:os.Sui,dryRun:async()=>{let c=await this.#t.dryRunTransactionBlock({transactionBlock:r});return{call:n.module+"."+n.func,error:c.executionErrorSource}}}}async estimateFee(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),i=(await this.#t.dryRunTransactionBlock({transactionBlock:r})).effects.gasUsed,c=BigInt(i.computationCost),l=BigInt(i.storageCost),u=c+l;return s.copyWith({amount:u})}async getBalance(t,e){let s=bt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return rs.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new ms,n=s.pipe(us(1)),a=async()=>{await(async()=>{let c=await this.getBalance(t,e);s.next(c)})();let i=setInterval(()=>{},3e3);return()=>clearInterval(i)},r;return a().then(o=>r=o),n.pipe(ls(()=>r?.()),cs((o,i)=>o.amount===i.amount))}};import{Ed25519Keypair as ds}from"@mysten/sui/keypairs/ed25519";import{Transaction as gs}from"@mysten/sui/transactions";var ge=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async signAndSend(t,e){let{from:s,data:n}=t,a=this.#t.client;try{if(this.#e instanceof ds){let i=gs.from(n),c=await a.signAndExecuteTransaction({signer:this.#e,transaction:i,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(c.digest);return}let r=await this.#e.signTransaction({transaction:n,address:s,networkID:"sui:mainnet"}),o=await a.executeTransactionBlock({transactionBlock:r.transaction,signature:r.signature,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(o.digest)}catch(r){e.onError(r)}}};var O=class{platform={};constructor(t){switch(t.getType()){case $.EvmChain:this.registerEvm(t);break;case $.EvmParachain:this.registerEvm(t),this.registerSubstrate(t);break;case $.Parachain:this.registerSubstrate(t);break;case $.SolanaChain:this.registerSolana(t);break;case $.SuiChain:this.registerSui(t);break;default:throw new Error("Unsupported platform: "+t.getType())}}registerEvm(t){let e=t;this.platform.Evm=new at(e)}registerSolana(t){let e=t;this.platform.Solana=new lt(e)}registerSui(t){let e=t;this.platform.Sui=new wt(e)}registerSubstrate(t){let e=t;this.platform.Substrate=new ht(e)}async buildCall(t,e,s,n){return this.platform[n.type].buildCall(t,e,s,n)}async estimateFee(t,e,s,n){return this.platform[n.type].estimateFee(t,e,s,n)}async getBalance(t,e){return this.platform[e.type].getBalance(t,e)}async subscribeBalance(t,e){return this.platform[e.type].subscribeBalance(t,e)}};import{addr as As,AssetAmount as Dt,Parachain as bs}from"@galacticcouncil/xc-core";import{acc as ws,big as Ce}from"@galacticcouncil/common";import{big as ps}from"@galacticcouncil/common";import Q from"big.js";function pe(m,t,e,s){let n=m.toBig().minus(e.toBig()).minus(m.isSame(t)?t.toBig():new Q(0));return s&&(n=n.minus(m.isSame(s)?s.toBig():new Q(0))),m.copyWith({amount:n.lt(0)?0n:BigInt(n.toFixed())})}function fe(m,t,e,s){let a=m.copyWith({amount:0n}).toBig().plus(m.isSame(t)?t.toBig():new Q(0)).plus(m.toBig().lt(e.toBig())?e.toBig():new Q(0));return s&&(a=a.plus(m.isSame(s)&&m.toBig().lt(s.toBig())?s.toBig():new Q(0))),m.copyWith({amount:BigInt(a.toFixed())})}async function F(m,t){return t.isEvmParachain()?t.getDerivatedAddress(m):m}function he(m,t){return t?ps.toBigInt(t,m):0n}import{addr as fs,AssetAmount as hs,Parachain as ye}from"@galacticcouncil/xc-core";import{big as ys}from"@galacticcouncil/common";var{EvmAddr:Cs}=fs,W=class{adapter;config;constructor(t,e){this.adapter=t,this.config=e}async getEd(){let{chain:t}=this.config;if(t instanceof ye)return(await P.create(t)).getExistentialDeposit()}async getBalance(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.asset,r=e.getBalanceAssetId(a),o=Cs.isValid(r.toString())?await F(t,e):t,i=s.source.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=s.min;if(t instanceof ye&&a){let r=t.getMinAssetId(n),o=a.build({asset:r});return this.adapter.getBalance(n,o)}return this.getAssetMin()}async getAssetMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=t.getAssetMin(n),r=await this.getDecimals(n),o=0n;return a&&(o=ys.toBigInt(a,r)),hs.fromAsset(n,{amount:o,decimals:r})}async getDecimals(t){let{chain:e}=this.config,s=e.getAssetDecimals(t);return s||(await e.getCurrency()).decimals}};var{EvmAddr:Ae}=As,q=class extends W{constructor(t,e){super(t,e)}async getCall(t){let{amount:e,sender:s,source:n}=t,a=await this.getTransfer(t);return this.adapter.buildCall(s,e,n.feeBalance,a)}async getDestinationFee(){let{chain:t,route:e}=this.config,{source:s,destination:n,transact:a}=e,r=n.fee.amount,o=s.destinationFee.asset||n.fee.asset,i=await this.getDecimals(o);if(Number.isFinite(r))return{fee:Dt.fromAsset(o,{amount:Ce.toBigInt(r,i),decimals:i}),feeBreakdown:{}};let c=r,{amount:l,breakdown:u}=await c.build({feeAsset:o,transferAsset:s.asset,source:a?a.chain:t,destination:n.chain});return{fee:Dt.fromAsset(o,{amount:l,decimals:i}),feeBreakdown:u}}async getDestinationFeeBalance(t){let{chain:e,route:s}=this.config,{source:n,destination:a}=s,r=n.asset,o=n.destinationFee.asset||a.fee.asset;if(r.isEqual(o))return this.getBalance(t);let i=e.getBalanceAssetId(o),c=Ae.isValid(i.toString())?await F(t,e):t,l=n.destinationFee.balance.build({address:c,asset:o,chain:e});return this.adapter.getBalance(o,l)}async getFee(t){let{chain:e,route:s}=this.config,{amount:n,sender:a,source:r}=t,o=await this.getTransfer(t),i=s.contract?await F(a,e):a,c=await this.adapter.estimateFee(i,n,r.feeBalance,o),{fee:l}=s.source,u=l?he(c.decimals,l.extra):0n,d=c.amount+u;return c.copyWith({amount:d})}async getFeeBalance(t){let{chain:e,route:s}=this.config,{source:n}=s;if(!n.fee)return this.getBalance(t);let a=await this.getFeeAsset(t),r=e.getBalanceAssetId(a),o=Ae.isValid(r.toString())?await F(t,e):t,i=n.fee.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getFeeAsset(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.fee,r=n.asset;if(!a)return r;let o=a.asset;return e instanceof bs&&"build"in o?await o.build({chain:e,address:t}):o}async getTransfer(t){let{chain:e,route:s}=this.config,{contract:n,extrinsic:a,program:r,move:o}=s;if(a){let{address:c,amount:l,asset:u,sender:d}=t,p=await(await P.create(e)).buildMessageId(d,l,u.originSymbol,c);return a.build({...t,messageId:p})}let i=n||r||o;if(i)return i.build({...t});throw new Error("AssetRoute transfer config is invalid! Specify contract, extrinsic, move or program instructions.")}async getTransact(t){let{route:e}=this.config,{transact:s}=e;if(s){let n=Object.assign({transact:{chain:s.chain}}),a={...t,...n};return{...await this.getTransactData(s,a),chain:s.chain}}}async getTransactData(t,e){let{chain:s,extrinsic:n}=t,a=await n.build(e),r=await P.create(s),o=a.getTx(r.client),i=e.source.chain,c=e.sender,l=ws.getMultilocationDerivatedAccount(i.parachainId,c,s.parachainId===0?0:1,s.usesH160Acc),u=await o.getPaymentInfo(l),d=await o.getEncodedData(),[g,p]=await Promise.all([this.getTransactFee(t),this.getTransactFeeBalance(t,e)]);return{call:d,chain:s,fee:g,feeBalance:p,weight:{refTime:u.weight.ref_time,proofSize:u.weight.proof_size}}}async getTransactFee(t){let{fee:e}=t,s=await this.getDecimals(e.asset),n=Ce.toBigInt(e.amount,s);return Dt.fromAsset(e.asset,{amount:n,decimals:s})}async getTransactFeeBalance(t,e){let{chain:s}=this.config,{fee:n}=t,a=n.balance.build({address:e.sender,asset:n.asset,chain:s});return this.adapter.getBalance(n.asset,a)}};var X=class extends W{constructor(t,e){super(t,e)}};import{AssetAmount as vs}from"@galacticcouncil/xc-core";var J=class{ctx;constructor(t){this.ctx=t}get asset(){let{source:t}=this.ctx;return t.balance}get dex(){let{source:t}=this.ctx;return t.chain.dex}get destFee(){let{source:t,transact:e}=this.ctx;return e?e.fee:t.destinationFee}get destFeeBalance(){let{source:t,transact:e}=this.ctx;return e?e.feeBalance:t.destinationFeeBalance}get feeBalance(){let{source:t}=this.ctx;return t.feeBalance}async getSwap(t){let{asset:e,decimals:s}=await this.dex.chain.getCurrency(),{amount:n}=await this.dex.getQuote(e,t,t);return{aIn:t,aOut:vs.fromAsset(e,{amount:n,decimals:s}),enabled:!0}}isSwapSupported(t){try{this.dex}catch{return!1}return!!(t&&t.swap)}async getDestinationSwap(t){let{amount:e,route:s}=await this.dex.getQuote(t,this.destFee,this.destFee),n=this.destFeeBalance.amount<this.destFee.amount,a=this.feeBalance.amount-t.amount>e*2n;return{aIn:t.copyWith({amount:e}),aOut:this.destFee,enabled:n&&a,route:s}}isDestinationSwapSupported(t){try{this.dex}catch{return!1}let e=!t.isSame(this.destFee),s=this.asset.isSame(this.destFee);return e&&!s}};var{EvmAddr:Is}=Ss,Rt=class{config;validations;constructor({configService:t,transferValidations:e}){this.config=t,this.validations=e||[]}async transfer(t,e,s,n,a){let r=Ps(this.config).assets().asset(t).source(s).destination(a).build();return this.getTransferData(r,e,n)}async remoteXcm(t,e,s,n,a={}){let r=this.config.getChain(e),o=this.config.getChain(s);if(!(r.isSubstrate()&&o.isSubstrate()))throw Error("RemoteXcm is supported only between parachains");let[c,l]=await Promise.all([P.create(r),P.create(o)]),u=new ft(c,l),d=xs.getMultilocationDerivatedAccount(r.parachainId,t,1,o.usesH160Acc),g=await l.getAsset(),p=await this.transfer(g,t,e,d,s);return u.remoteExec(t,d,n,f=>{let y=f.toDecimal();return p.buildCall(y)},a)}async getTransferData(t,e,s){let n=t.origin,a=t.reverse,r=new O(n.chain),o=new O(a.chain),i=new q(r,n),c=new X(o,a),l=new Ts(...this.validations),[u,d,g,p,f,y,v]=await Promise.all([i.getBalance(e),i.getFeeBalance(e),i.getDestinationFee(),i.getDestinationFeeBalance(e),i.getMin(),c.getBalance(s),c.getMin()]),{source:C,destination:h}=n.route,x=g.fee.copyWith(h.fee.asset),B=g.feeBreakdown,j=C.asset.isEqual(x)&&x.amount>10n?x.amount+1n:10n,A={address:s,amount:j,asset:C.asset,destination:{balance:y,chain:a.chain,fee:x,feeBreakdown:B},sender:e,source:{balance:u,chain:n.chain,fee:d.copyWith({amount:0n}),feeBalance:d,destinationFee:g.fee,destinationFeeBalance:p}};A.transact=await i.getTransact(A);let T=new J(A),b=await i.getFee(A),E;T.isSwapSupported(C.fee)&&(E=await T.getSwap(b),A.source.feeSwap=E);let I;T.isDestinationSwapSupported(b)&&(I=await T.getDestinationSwap(b),A.source.destinationFeeSwap=I),(E||I)&&(b=await i.getFee(A),b=b.padByPct(5n));let G=await c.getEd(),xt=fe(y,x,v,G),w=await i.getEd(),Y=pe(u,b,f,w);return A.amount=0n,A.source.fee=b,{source:{balance:u,destinationFee:g.fee,destinationFeeBalance:p,destinationFeeSwap:I,fee:b,feeBalance:d,feeSwap:E,max:Y,min:u.copyWith({amount:xt.amount})},destination:{balance:y,fee:x},async buildCall(R){let S=Object.assign({},A);return S.amount=be.toBigInt(R,u.decimals),S.transact=await i.getTransact(S),i.getCall(S)},async estimateFee(R){let S=Object.assign({},A);return S.amount=be.toBigInt(R,u.decimals),S.transact=await i.getTransact(S),i.getFee(S)},async validate(R){let S=Object.assign({},A),Se=R||b.amount;return S.source.fee=b.copyWith({amount:Se}),l.validate(S)}}}async subscribeBalance(t,e,s){let n=this.config.getChainRoutes(e),a=new O(n.chain),r=n.getUniqueRoutes().map(async({source:c})=>{let{asset:l,balance:u}=c,d=n.chain.getBalanceAssetId(l),g=Is.isValid(d.toString())?await F(t,n.chain):t,p=u.build({address:g,asset:l,chain:n.chain});return a.subscribeBalance(l,p)}),o=await Promise.all(r);return Bs(o).pipe(Es(500)).subscribe(s)}};import{ConfigBuilder as Fs}from"@galacticcouncil/xc-core";function Ds(m){let t=Fs(m.config).assets();return{assets:t,withAsset(e){let s=t.asset(e);return{sources:s,withSource(n){let a=s.source(n);return{destinations:a,withDestination(r){let{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:l,build:u}=a.destination(r);return{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:l,build({srcAddress:d,dstAddress:g,dstAsset:p,tag:f}){let y=u(p,f);return m.getTransferData(y,d,g)}}}}}}}}}import{Precompile as Rs}from"@galacticcouncil/xc-core";var ks="https://api.wormholescan.io",vt=class{_baseUrl;constructor(t){this._baseUrl=t||ks}buildApi(t,e){return[this._baseUrl,t,"?"].join("")+new URLSearchParams(e).toString()}async getVaaBytes(t){let e=this.buildApi("/v1/signed_vaa/"+t,{});return await(await fetch(e)).json()}async getVaa(t){let e=this.buildApi("/api/v1/vaas/"+t,{});return(await(await fetch(e)).json()).data}async getVaaByTxHash(t){let e=this.buildApi("/api/v1/vaas/",{txHash:t}),n=await(await fetch(e)).json();if(n.data.length>0)return n.data[0];throw Error("Can't find VAA for given txHash: "+t)}async getOperations(t){let e=this.buildApi("/api/v1/operations/",t);return(await(await fetch(e)).json()).operations}async getOperation(t){let e=this.buildApi("/api/v1/operations/"+t,{});return await(await fetch(e)).json()}isMrlTransfer(t){let{payloadType:e,toAddress:s,toChain:n}=t,a="0x"+s.substring(26);return e===3&&n===16&&a===Rs.Bridge}};import{acc as Os}from"@galacticcouncil/common";import{mrl as Vs,ChainType as ve,Parachain as _s,Precompile as Ms,Wormhole as U}from"@galacticcouncil/xc-core";import{encoding as Ns}from"@wormhole-foundation/sdk-base";import{keccak256 as Ws}from"@wormhole-foundation/sdk-connect";import{deserialize as Us}from"@wormhole-foundation/sdk-definitions";var we=(s=>(s[s.WaitingForVaa=0]="WaitingForVaa",s[s.VaaEmitted=1]="VaaEmitted",s[s.Completed=2]="Completed",s))(we||{});var js=300*1e3,xe=class{parachainId;config;whScan;constructor(t,e){this.config=t,this.parachainId=e,this.whScan=new vt}get chains(){let t=this.config.chains.values();return Array.from(t)}get filters(){let t=new Date,e=new Date;e.setDate(t.getDate()-6);let s=t.toISOString();return{page:"0",pageSize:"50",includeEndDate:"true",from:e.toISOString(),to:s}}async getWithdraws(t){let e=Os.getMultilocationDerivatedAccount(this.parachainId,t,1,!0),n=(await this.whScan.getOperations({...this.filters,address:e})).map(async a=>{let{content:r}=a,{payload:o,standarizedProperties:i}=r,c=this.getStatus(a),l=this.chains.find(f=>f instanceof _s&&f.parachainId===this.parachainId),{toAddress:u,tokenAddress:d}=i,g=this.chains.find(f=>U.isKnown(f)&&U.fromChain(f).getWormholeId()===o.tokenChain),p;if(c===1&&a.vaa){let{timestamp:f}=this.getVaaHeader(a.vaa.raw),y=a.vaa.raw;if(this.isStuck(f))switch(g.getType()){case ve.EvmChain:let v=new Z(g);p=async h=>v.redeem(h,y);break;case ve.SolanaChain:let C=new dt(g);p=async h=>C.redeem(h,y);break}}return{asset:d,assetSymbol:a.data.symbol,amount:a.data.tokenAmount,from:t,fromChain:l,to:u,toChain:g,status:c,redeem:p,operation:a}});return Promise.all(n)}async getDeposits(t,e="hydration"){let s=await this.whScan.getOperations({...this.filters,address:Ms.Bridge,pageSize:"100"}),n=this.config.chains.get(e);if(!n)return[];let a=n,o=(await Vs.createPayload(a,t)).toHex(),i=s.filter(c=>{let{content:l}=c,{payload:u}=l;return u.payloadType===3&&u.toChain===16&&"0x"+u.payload===o}).map(async c=>{let{content:l,sourceChain:u}=c,{payload:d,standarizedProperties:g}=l,p=this.getStatus(c),{tokenAddress:f}=g,y=this.chains.find(h=>U.isKnown(h)&&U.fromChain(h).getWormholeId()===d.tokenChain),v=this.chains.find(h=>U.isKnown(h)&&U.fromChain(h).getWormholeId()===d.toChain),C;if(p===1&&c.vaa){let{timestamp:h}=this.getVaaHeader(c.vaa.raw),x=c.vaa.raw;if(this.isStuck(h)){let B=new gt(v);C=async D=>B.redeemMrlViaXcm(D,x)}}return{asset:f,assetSymbol:c.data.symbol,amount:c.data.tokenAmount,from:u.from,fromChain:y,to:t,toChain:n,status:p,redeem:C,operation:c}});return Promise.all(i)}isStuck(t){return Date.now()>=t*1e3+js}getVaaHeader(t){let e=Ns.b64.decode(t),s=Us("Uint8Array",e);return{timestamp:s.timestamp,emitterChain:s.emitterChain,emitterAddress:s.emitterAddress.toString(),sequence:s.sequence,payload:s.payload,hash:s.hash,id:Ws(s.hash)}}getStatus(t){return t.vaa?t.targetChain&&t.targetChain.status==="completed"?2:1:0}};export{Mt as DISPATCH_ADDRESS,Z as EvmClaim,at as EvmPlatform,Nt as EvmSigner,J as FeeSwap,O as PlatformAdapter,dt as SolanaClaim,M as SolanaLilJit,lt as SolanaPlatform,Zt as SolanaSigner,gt as SubstrateClaim,ft as SubstrateExec,ht as SubstratePlatform,P as SubstrateService,ue as SubstrateSigner,de as SuiClaim,wt as SuiPlatform,ge as SuiSigner,Ds as TransferBuilder,Rt as Wallet,we as WhStatus,vt as WormholeScan,xe as WormholeTransfer,Lt as chunkBySize,fr as deserializeV0,k as ixToHuman,H as serializeV0};
|
|
3
|
+
`,i.details),{error:i}}}decodeEvents(t){let e=[];return t&&t.forEach(s=>{try{let{eventName:n,args:a}=Re({abi:this.abi,data:s.data,topics:s.topics});e.push({eventName:n,args:a})}catch{}}),e}};var K=class{static get(t,e){return new st(t,e)}};import{Precompile as ke}from"@galacticcouncil/xc-core";import{decodeAbiParameters as Ve}from"viem";function St(l){return l.module==="Snowbridge"&&l.func==="v2_sendMessage"}function Ot(l){if(!St(l))return;let t=l.args[1];if(!t||t.length===0)return;let[e,s]=Ve([{type:"uint8"},{type:"address"},{type:"uint128"}],t[0]);return s}function _t(l){let t=l.module==="Snowbridge"&&l.func==="v2_sendMessage"&&Array.isArray(l.args[1])&&l.args[1].length===0;return l.module==="TokenBridge"&&["wrapAndTransferETHWithPayload","wrapAndTransferETH"].includes(l.func)||t}function Mt(l){return Object.entries(ke).map(([e,s])=>s).includes(l.address)}var at=class{#t;constructor(t){this.#t=t.evmClient}async buildCall(t,e,s,n){let a=K.get(this.#t,n),{abi:r,asset:o,calldata:i}=a,c={abi:JSON.stringify(r),data:i,from:t,to:n.address,type:Nt.Evm,value:n.value,dryRun:async()=>{let{error:p,logs:f}=await a.simulateCall(t),h=a.decodeEvents(f);return{call:n.module+"."+n.func,error:p?.shortMessage,events:h}}};if(Mt(n)||_t(n))return c;let u=St(n)?Ot(n):o,m=new Me(this.#t,u),d=await m.allowance(t,n.address);if(d>=e)return c;let g=m.approve(n.address,e);return{abi:JSON.stringify(Oe.Erc20),allowance:d,data:g,from:t,to:u,type:Nt.Evm,dryRun:()=>{}}}async estimateFee(t,e,s,n){let r=await K.get(this.#t,n).estimateFee(t,e);return s.copyWith({amount:r})}async getBalance(t,e){let s=nt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return _e.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new je,n=s.pipe(Ue(1)),a=this.#t.getProvider(),r=async()=>{let i=async()=>{let u=await this.getBalance(t,e);s.next(u)};await i();let c=a.watchBlocks({onBlock:()=>i()});return()=>c()},o;return r().then(i=>o=i),n.pipe(We(()=>o?.()),Ne((i,c)=>i.amount===c.amount))}};import{EvmParachain as Ke}from"@galacticcouncil/xc-core";import{h160 as ze}from"@galacticcouncil/common";import{Binary as He}from"polkadot-api";var Wt="0x0000000000000000000000000000000000000401",{H160:Le}=ze,Ut=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=t.evmClient,this.#n=e}async signAndSend(t,e){let s=Le.fromAny(t.from),n=this.#e.getProvider(),a=!1;if(this.#t instanceof Ke)try{let o=this.#t.client,i=He.fromHex(t.data);await o.getUnsafeApi().txFromCallData(i),a=!0}catch{}let r;if(a){let[o,i]=await Promise.all([n.estimateGas({account:s,data:t.data,to:Wt}),n.getGasPrice()]),c=i+i/100n*10n;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:t.data,maxPriorityFeePerGas:c,maxFeePerGas:c,gas:o*11n/10n,to:Wt})}else{let{data:o,to:i,value:c}=t;r=await this.#n.sendTransaction({account:s,chain:this.#e.chain,data:o,to:i,value:c})}e.onTransactionSend(r),n.waitForTransactionReceipt({hash:r}).then(o=>e.onTransactionReceipt(o)).catch(o=>e.onError(o))}};import{AssetAmount as Ye,CallType as Ze}from"@galacticcouncil/xc-core";import{PublicKey as tn}from"@solana/web3.js";import{Buffer as en}from"buffer";import{distinctUntilChanged as nn,finalize as sn,shareReplay as an,Subject as rn}from"rxjs";var _=class{connection;config;constructor(t,e){this.validateConnection(t),this.validateConfig(e),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}validateConfig(t){if(!t.address)throw new Error("Solana address is required")}};import{SolanaAddress as $e}from"@wormhole-foundation/sdk-solana";var Qe=9,rt=class extends _{async getBalance(){let{address:t}=this.config,e=new $e(t).unwrap(),s=await this.connection.getBalance(e);return BigInt(s)}async getDecimals(){return Qe}};import{SolanaAddress as Pt}from"@wormhole-foundation/sdk-solana";var ot=class extends _{constructor(t,e){super(t,e),this.validateToken(e)}async getBalance(){let{address:t,token:e}=this.config,s=new Pt(t).unwrap(),n=new Pt(e).unwrap();return(await this.connection.getParsedTokenAccountsByOwner(s,{mint:n})).value.reduce((r,{account:o})=>{let i=o.data.parsed.info.tokenAmount;return r+=BigInt(i.amount),r},0n)}async getDecimals(){let{token:t}=this.config,e=new Pt(t).unwrap();return(await this.connection.getTokenSupply(e)).value.decimals}validateToken(t){if(!t.token)throw new Error("Token address is required")}};var it=class{static get(t,e){switch(e.module){case"Native":return new rt(t,e);case"Token":return new ot(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};import{ComputeBudgetProgram as jt,PublicKey as qe,TransactionMessage as Xe,VersionedTransaction as Kt}from"@solana/web3.js";var zt=.5,Ht=2,Lt=1,$t=1e6,Je=25e4,ct=class{connection;config;constructor(t,e){this.validateConnection(t),this.connection=t,this.config=e}validateConnection(t){if(!t)throw new Error("No connection found")}async getPriorityMessage(t){let{instructions:e}=this.config,s=await this.getV0Message(t,e),n=await this.createPriorityFeeInstructions(s);return this.getV0Message(t,[...e,...n])}async estimateFee(t,e){if(e===0n)return 0n;let{instructions:s}=this.config,n=await this.getV0Message(t,s),a=await this.determineComputeBudget(n);return BigInt(a)}async getV0Message(t,e){let s=new qe(t),{blockhash:n}=await this.connection.getLatestBlockhash("finalized");return new Xe({payerKey:s,recentBlockhash:n,instructions:e}).compileToV0Message()}async createPriorityFeeInstructions(t,e=zt,s=Ht,n=Lt,a=$t){let[r,o]=await Promise.all([this.determineComputeBudget(t),this.determinePriorityFee(t,e,s,n,a)]);return[jt.setComputeUnitLimit({units:r}),jt.setComputeUnitPrice({microLamports:o})]}async simulateTransaction(t,e){let s=new Kt(e);return(await this.connection.simulateTransaction(s,{accounts:{encoding:"base64",addresses:[t]}})).value}async determineComputeBudget(t){let e=new Kt(t),s=await this.connection.simulateTransaction(e),{err:n,unitsConsumed:a}=s.value;return a&&!n?Math.round(a*1.2):Je}async determinePriorityFee(t,e=zt,s=Ht,n=Lt,a=$t){let r=n,o=await this.getTxAccounts(t),i=await this.connection.getRecentPrioritizationFees({lockedWritableAccounts:o});if(i){let c=i.map(m=>m.prioritizationFee).filter(m=>m>0).sort((m,d)=>m-d),u=Math.ceil(c.length*e);if(c.length>u){let d=c[u]*s;r=Math.max(r,d)}}return Math.min(Math.max(r,n),a)}async getTxAccounts(t){let e=(await Promise.all(t.addressTableLookups.map(n=>this.connection.getAddressLookupTable(n.accountKey)))).map(n=>n.value).filter(n=>n!==null),s=t.getAccountKeys({addressLookupTableAccounts:e??void 0});return t.compiledInstructions.flatMap(n=>n.accountKeyIndexes).map(n=>t.isAccountWritable(n)?s.get(n):null).filter(n=>n!==null)}};var z=class{static get(t,e){return new ct(t,e)}};import{MessageV0 as Ge}from"@solana/web3.js";function k(l){return l.map(t=>({program:t.programId.toBase58(),data:t.data.toString("hex"),keys:t.keys.map(e=>e.pubkey.toBase58())}))}function Qt(l,t=1e3){let e=[],s=[],n=0;for(let a of l){let r=a.data?.length??0;s.length&&n+r>t&&(e.push(s),s=[],n=0),s.push(a),n+=r}return s.length&&e.push(s),e}function H(l){let t=l.serialize();return Buffer.from(t).toString("hex")}function Ar(l){let t=Buffer.from(l,"hex"),e=Uint8Array.from(t);return Ge.deserialize(e)}var ut=class{#t;constructor(t){this.#t=t.connection}async buildCall(t,e,s,n){let a=z.get(this.#t,n),r=await a.getPriorityMessage(t),o=r.serialize(),i=en.from(o).toString("hex");return{from:t,data:i,ix:k(n.instructions),signers:n.signers,type:Ze.Solana,dryRun:async()=>{let{err:c,logs:u}=await a.simulateTransaction(t,r);return{call:n.module+"."+n.func,error:c,events:u}}}}async estimateFee(t,e,s,n){let a=z.get(this.#t,n),r=await a.estimateFee(t,e),o=await a.getPriorityMessage(t),{accounts:i}=await a.simulateTransaction(t,o),u=(i&&i[0])?.lamports;if(u){let m=n.module==="TokenBridge"&&n.func==="TransferNativeWithPayload";return s.copyWith({amount:s.amount-BigInt(u)-(m?e:0n)+n.rentReserve})}return s.copyWith({amount:r+n.rentReserve})}async getBalance(t,e){let s=it.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return Ye.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new rn,n=s.pipe(an(1)),a=async()=>{let o=async()=>{let u=await this.getBalance(t,e);s.next(u)};await o();let i=new tn(e.address),c=this.#t.onAccountChange(i,()=>o());return()=>{this.#t.removeAccountChangeListener(c)}},r;return a().then(o=>r=o),n.pipe(sn(()=>r?.()),nn((o,i)=>o.amount===i.amount))}};import{CallType as lt,Wormhole as on}from"@galacticcouncil/xc-core";import{Keypair as qt,PublicKey as L,SystemProgram as Xt,TransactionMessage as cn}from"@solana/web3.js";import{ACCOUNT_SIZE as un,NATIVE_MINT as mt,TOKEN_PROGRAM_ID as ln,createAssociatedTokenAccountIdempotentInstruction as Jt,createCloseAccountInstruction as mn,createInitializeAccountInstruction as dn,createTransferInstruction as gn,getAssociatedTokenAddressSync as pn,getMinimumBalanceForRentExemptAccount as fn,getMint as hn}from"@solana/spl-token";import{utils as yn}from"@wormhole-foundation/sdk-solana";import{utils as Gt}from"@wormhole-foundation/sdk-solana-core";import{encoding as Cn}from"@wormhole-foundation/sdk-base";import{deserialize as Yt}from"@wormhole-foundation/sdk-definitions";import{createCompleteTransferNativeInstruction as Zt,createCompleteTransferWrappedInstruction as An}from"@wormhole-foundation/sdk-solana-tokenbridge";var M=class{#t;constructor(t){this.#t=t.connection}async sendBundle(t){let{result:e}=await this.#t._rpcRequest("sendBundle",[t]);return e}async simulateBundle(t){return(await this.#t._rpcRequest("simulateBundle",[[t]])).result}async getInflightBundleStatuses(t){let{result:e}=await this.#t._rpcRequest("getInflightBundleStatuses",[t]);return e}async getRegion(){let{result:t}=await this.#t._rpcRequest("getRegions",[]);return t}async getTipAccount(){let{result:t}=await this.#t._rpcRequest("getTipAccounts",[]);return t}};var dt=class{#t;#e;#n;constructor(t){this.#t=t,this.#e=t.connection,this.#n=new M(t)}async redeem(t,e,s){let n=on.fromChain(this.#t),a=Cn.b64.decode(e),r=Yt("TokenBridge:Transfer",a),o=Yt("Uint8Array",a),i=this.derivePostedVaaKey(n.getCoreBridge(),Buffer.from(r.hash)),c=new L(t),u=s?new L(s):c,m=c.equals(u),d=[];if(!await this.#e.getAccountInfo(i)){let y=qt.generate(),x=await Gt.createVerifySignaturesInstructions(this.#t.connection,n.getCoreBridge(),c,o,y.publicKey),B=Qt(x,1e3);for(let T=0;T<B.length;T++){let b=B[T],E=await this.getV0Message(c,b),I=H(E);d.push({from:t,data:I,ix:k(b),signers:[y],type:lt.Solana})}let D=Gt.createPostVaaInstruction(this.#e,n.getCoreBridge(),c,o,y.publicKey),j=await this.getV0Message(c,[D]),A=H(j);d.push({from:t,data:A,ix:k([D]),type:lt.Solana})}let p=r.payload.token.chain==="Solana",f=new L(r.payload.token.address.toUint8Array()),h=p&&f.equals(mt),v=await this.#n.getTipAccount(),C=Xt.transfer({fromPubkey:c,toPubkey:new L(v[0]),lamports:1e3});if(h&&m){let y=await this.redeemAndUnwrap(n,c,r,C);d.push(y)}else{let y=await this.redeemToken(n,c,u,f,p,r,C);d.push(y)}return d}async redeemToken(t,e,s,n,a,r,o){let c=(a?Zt:An)(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,r),u=pn(n,s),m=Jt(e,u,s,n),d=await this.getV0Message(e,[m,c,o]),g=H(d);return{from:e.toBase58(),data:g,ix:k([m,c]),type:lt.Solana}}async redeemAndUnwrap(t,e,s,n){let a=new L(s.payload.to.address.toUint8Array()),r=await hn(this.#e,mt),o=s.payload.token.amount*BigInt(Math.pow(10,r.decimals-8)),i=await fn(this.#e),c=qt.generate(),u=Jt(e,a,e,mt),m=Zt(this.#e,t.getTokenBridge(),t.getCoreBridge(),e,s),d=Xt.createAccount({fromPubkey:e,newAccountPubkey:c.publicKey,lamports:i,space:un,programId:ln}),g=dn(c.publicKey,mt,e),p=gn(a,c.publicKey,e,o),f=mn(c.publicKey,e,e),h=[u,m,d,g,p,f,n],v=await this.getV0Message(e,h),C=H(v);return{from:e.toBase58(),data:C,ix:k(h),signers:[c],type:lt.Solana}}derivePostedVaaKey(t,e){return yn.deriveAddress([Buffer.from("PostedVAA"),e],t)}async getV0Message(t,e){let{blockhash:s}=await this.#e.getLatestBlockhash("finalized");return new cn({payerKey:t,recentBlockhash:s,instructions:e}).compileToV0Message()}};import{Keypair as te,MessageV0 as bn,VersionedTransaction as wn}from"@solana/web3.js";import{Buffer as Tt}from"buffer";var ee=class{#t;#e;#n;constructor(t,e){this.#t=t,this.#e=e,this.#n=new M(t)}async signAndSend(t,e){let{data:s,signers:n}=t,a=this.toVersioned(s,n);try{if(this.#e instanceof te){a.sign([this.#e]);let c=await this.#t.connection.sendTransaction(a);e.onTransactionSend(c);let u=await this.#t.connection.getSignatureStatus(c);e.onStatus?.(u);return}let r=this.#e;await r.connect(),n&&a.sign(n);let{signature:o}=await r.signAndSendTransaction(a);e.onTransactionSend(o);let i=await this.#t.connection.getSignatureStatus(o);e.onStatus?.(i)}catch(r){e.onError(r)}}async signAndSendAll(t,e){let s=t.map(n=>{let{data:a,signers:r}=n;return this.toVersioned(a,r)});try{let n;if(this.#e instanceof te)s.forEach(i=>i.sign([this.#e])),n=s.map(i=>Tt.from(i.serialize()).toString("base64"));else{let i=this.#e;await i.connect(),n=(await i.signAllTransactions(s)).map(u=>Tt.from(u.serialize()).toString("base64"))}let a=await this.#n.simulateBundle(n);if(a.value.summary!=="succeeded")throw new Error("Bundle simulation failed! "+JSON.stringify(a,null,2));let r=await this.#n.sendBundle(n);e.onTransactionSend(r);let o=await this.#n.getInflightBundleStatuses([r]);e.onBundleStatus?.(o.value)}catch(n){e.onError(n)}}toVersioned(t,e){let s=Tt.from(t,"hex"),n=Uint8Array.from(s),a=bn.deserialize(n),r=new wn(a);return e&&r.sign(e),r}};import{Abi as vn,CallType as xn,Precompile as Sn,Wormhole as Pn}from"@galacticcouncil/xc-core";import{encoding as ne}from"@wormhole-foundation/sdk-base";import{encodeFunctionData as Tn}from"viem";import{Binary as Bt}from"polkadot-api";var gt=class{#t;constructor(t){this.#t=t,Pn.fromChain(this.#t)}redeemMrl(t,e){let s=ne.b64.decode(e),n=ne.hex.encode(s),a=vn.Gmp,r=Tn({abi:a,functionName:"wormholeTransferERC20",args:["0x"+n]});return{abi:JSON.stringify(a),data:r,from:t,to:Sn.Bridge}}async redeemMrlViaXcm(t,e){let n=this.#t.client.getUnsafeApi(),a=this.redeemMrl(t,e),o=await n.tx.EthereumXcm.transact({xcm_transaction:{type:"V2",value:{gas_limit:[5000000n,0n,0n,0n],fee_payment:{type:"Auto",value:void 0},action:{type:"Call",value:Bt.fromHex(a.to)},value:[0n,0n,0n,0n],input:Bt.fromHex(a.data),access_list:void 0}}}).getEncodedData();return{data:Bt.toHex(o),from:t,type:xn.Substrate,dryRun:async()=>{},txOptions:void 0}}};import{AssetAmount as Dn,CallType as Rn}from"@galacticcouncil/xc-core";import{Binary as pt}from"polkadot-api";import{big as Bn}from"@galacticcouncil/common";async function Et(l,t,e){let s=await e.getDecimals(),n=e.chain.getAssetDecimals(t)??s,a=e.chain.usesChainDecimals?s:n;return{amount:Bn.convertDecimals(l,a,n),decimals:n}}import{enums as En}from"@galacticcouncil/common";var se=l=>{let t=[];for(let e of l)if(["PolkadotXcm"].includes(e.type)&&e.value.type==="FeesPaid"){let n=e.value.value.fees;for(let a of n)if(a.fun.type==="Fungible"){let r=BigInt(a.fun.value);t.push(r)}}return t.reduce((e,s)=>e+s,0n)},N=l=>{let t=l.value.error;return t.type==="Module"?En.enumPath(t.value):JSON.stringify(t.value)};import{xcm as It}from"@galacticcouncil/common";function In(l){return{parents:0,interior:{type:"X1",value:l.startsWith("0x")?It.toAccountKey20(l):It.toAccountId32(l)}}}function ae(l){return{type:"V4",value:{parents:1,interior:{type:"X1",value:{type:"Parachain",value:l.parachainId}}}}}var Fn=(l,t)=>({id:It.transform(l),fun:{type:"Fungible",value:t}}),re=(l,t,e,s,n,a)=>{console.log(a);let r=In(l),o=Fn(t,e.amount);return{type:"V4",value:[{type:"WithdrawAsset",value:[o]},{type:"BuyExecution",value:{fees:o,weight_limit:{type:"Unlimited"}}},{type:"Transact",value:{origin_kind:{type:"SovereignAccount"},require_weight_at_most:{ref_time:s,proof_size:n},call:a}},{type:"RefundSurplus",value:void 0},{type:"DepositAsset",value:{assets:{type:"Wild",value:{type:"AllCounted",value:1}},beneficiary:r}}]}};var ft=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async remoteExec(t,e,s,n,a={}){let r=this.#t.api,o=await this.#t.getAsset(),i=this.#e.api,c=this.#e.chain,u=await c.getCurrency(),m=u.asset,d=u.decimals,g=c.getAssetXcmLocation(m),p=pt.fromHex(s.data),h=await(await i.txFromCallData(p)).getPaymentInfo(e),v=BigInt(h.partial_fee)*120n/100n,C=Dn.fromAsset(m,{amount:v,decimals:d}),y=h.weight.ref_time,x=h.weight.proof_size,B=ae(c),D=re(e,g,C,y,x,p),j=r.tx.PolkadotXcm.send({dest:B,message:D}),A=[];try{let w=await this.#t.chain.dex.getCalldata(t,a.srcFeeAsset||o,m,C,10),Y=pt.fromHex(w),R=await r.txFromCallData(Y);A.push(R)}catch{}let T=await n(C),b=pt.fromHex(T.data),E=await r.txFromCallData(b);A.push(E),A.push(j);let I=A.map(w=>w.decodedCall),G=r.tx.Utility.batch_all({calls:I}),xt=await G.getEncodedData();return{from:t,data:pt.toHex(xt),type:Rn.Substrate,dryRun:this.#t.isDryRunSupported()?async()=>{try{let w=await this.#t.dryRun(t,G);return{call:"polkadotXcm.send",error:w.execution_result&&w.execution_result.success?void 0:N(w.execution_result),events:w.emitted_events||[],xcm:w.forwarded_xcms||[]}}catch(w){return{call:"polkadotXcm.send",error:w instanceof Error?w.message:"unknown"}}}:()=>{}}}};import{Asset as Un,AssetAmount as ue,CallType as jn}from"@galacticcouncil/xc-core";import{Binary as Kn}from"polkadot-api";import{concatMap as le,catchError as zn,distinctUntilChanged as Hn,firstValueFrom as Ln,map as $n,throwError as Qn}from"rxjs";import{addr as kn,multiloc as Ft,AssetAmount as Vn}from"@galacticcouncil/xc-core";import{acc as On,enums as _n}from"@galacticcouncil/common";import{Blake2256 as Mn,u32 as Nn}from"@polkadot-api/substrate-bindings";import{toHex as Wn,fromHex as oe}from"@polkadot-api/utils";import{Enum as ie}from"polkadot-api";var{Ss58Addr:ce}=kn,P=class l{chain;_currency;constructor(t){this.chain=t}static async create(t){return new l(t)}get client(){return this.chain.client}get api(){return this.client.getUnsafeApi()}async getCurrency(){return this._currency||(this._currency=this.chain.getCurrency()),this._currency}async getAsset(){return(await this.getCurrency()).asset}async getDecimals(){return(await this.getCurrency()).decimals}async getExistentialDeposit(){let t;try{let n=await this.api.constants.Balances.ExistentialDeposit();t=typeof n=="bigint"?n:BigInt(String(n))}catch{t=0n}let{asset:e,decimals:s}=await this.getCurrency();return Vn.fromAsset(e,{amount:t,decimals:s})}isDryRunSupported(){return this.api.apis?.DryRunApi!==void 0}async buildMessageId(t,e,s,n){let a=await this.client._request("system_accountNextIndex",[t]),r=Nn.enc(a),o=u=>new TextEncoder().encode(u),i=new Uint8Array([...o(this.chain.parachainId.toString()),...oe(t.startsWith("0x")?t.slice(2):t),...r,...oe(s.startsWith("0x")?s.slice(2):s),...o(n),...o(e.toString())]),c=Mn(i);return Wn(c)}async dryRun(t,e){let s=ie("Signed",t),n=ie("system",s),a=await this.api.apis.DryRunApi.dry_run_call(n,e.decodedCall,4);if(!a.success)throw new Error("DryRun call failed");let r=a.value;if("type"in r&&"value"in r)throw new Error("DryRun call error: "+_n.enumPath(r.value));return r}async estimateNetworkFee(t,e){let s=e.getTx(this.client);try{let n=await s.getPaymentInfo(t);return BigInt(n.partial_fee)}catch{console.warn("Can't estimate network fee.")}return 0n}async estimateDeliveryFee(t,e){if(this.chain.usesDeliveryFee){let s=await this.estimateDeliveryFeeWith(t,e);try{let n=e.getTx(this.client),a=await this.dryRun(s,n);if(a.execution_result?.success)return se(a.emitted_events||[]);{let r=N(a.execution_result);console.warn(`Can't estimate delivery fee. Reason:
|
|
4
|
+
${r}`)}}catch{}}return 0n}async estimateDeliveryFeeWith(t,e){if(["PolkadotXcm"].includes(e.module)){let n=e.getTx(this.client).decodedCall.value.value,a="dest"in n?n.dest:void 0;if(!a)return t;let r=Ft.findNestedKey(a,"interior"),o=Ft.findParachain(a);if(Ft.findGlobalConsensus(a))return t;if(o){let c=On.getSovereignAccounts(o);return this.chain.parachainId===0?ce.encodePubKey(c.relay):ce.encodePubKey(c.generic)}if(r&&r.interior==="Here")return this.chain.treasury||t}return t}};var ht=class{#t;constructor(t){this.#t=P.create(t)}async useSignerFee(t){let e=await this.#t,s=await e.getAsset();return e.chain.usesSignerFee&&!s.isEqual(t)}async buildCall(t,e,s,n){let a=await this.#t,o=await this.useSignerFee(s)?{asset:new Un(s)}:void 0,i=n.getTx(a.client),c=n.module+"."+n.func,u=await i.getEncodedData();return{from:t,data:Kn.toHex(u),type:jn.Substrate,txOptions:o,dryRun:a.isDryRunSupported()?async()=>{try{let m=n.getTx(a.client),d=await a.dryRun(t,m),g=d.execution_result&&d.execution_result.success?void 0:N(d.execution_result);return{call:c,error:g,events:d.emitted_events||[],xcm:d.forwarded_xcms||[]}}catch(m){return{call:c,error:m instanceof Error?m.message:"unknown"}}}:()=>{}}}async estimateFee(t,e,s,n){let a=await this.#t,r=await a.estimateNetworkFee(t,n),o=await a.estimateDeliveryFee(t,n),i=await this.exchangeFee(r+o,s),c=await Et(i,s,a);return s.copyWith(c)}async getBalance(t,e){let s=await this.subscribeBalance(t,e);return Ln(s)}async subscribeBalance(t,e){let s=await this.#t,{module:n,func:a,args:r,transform:o}=e;return s.client.getUnsafeApi().query[n][a].watchValue(...r,{at:"best"}).pipe($n(({value:u})=>u)).pipe(le(u=>o(u)),Hn((u,m)=>u===m),le(async u=>{let m=await Et(u,t,s);return ue.fromAsset(t,m)}),zn(u=>(console.error("subscribe fails for:",t),Qn(()=>u))))}async exchangeFee(t,e){let s=await this.#t,n=await s.getAsset(),a=await s.getDecimals();if(n.isEqual(e))return t;try{let r=s.chain.dex,o=ue.fromAsset(n,{amount:t,decimals:a});return(await r.getQuote(e,n,o,!0)).amount}catch{}return t}};import{multiloc as me}from"@galacticcouncil/xc-core";import{Binary as qn,Enum as Dt}from"polkadot-api";var de=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}signAndSend(t,e){let n=this.#t.client.getUnsafeApi(),a=qn.fromHex(t.data),r={};t.txOptions?.asset&&(r={asset:this.getFeeAsset(t.txOptions.asset)}),n.txFromCallData(a).then(o=>{o.signSubmitAndWatch(this.#e,r).subscribe({next:i=>{i.type==="broadcasted"&&e.onTransactionSend(i.txHash),i.type==="finalized"&&e.onFinalized(i)},error:i=>{e.onError(i)}})})}getFeeAsset(t){let e=this.#t.getAssetXcmLocation(t);if(e){let s=me.findPalletInstance(e),n=me.findGeneralIndex(e);return{parents:0,interior:Dt("X2",[Dt("PalletInstance",Number(s)),Dt("GeneralIndex",BigInt(n))])}}throw new Error("Asset location not found")}};import{CallType as Jn,Wormhole as Gn}from"@galacticcouncil/xc-core";import{Transaction as Yn}from"@mysten/sui/transactions";import{SUI_CLOCK_OBJECT_ID as Zn}from"@mysten/sui/utils";import{toBase64 as ts}from"@mysten/bcs";import{encoding as es,serialize as ns,toChainId as ss}from"@wormhole-foundation/sdk-connect";import{deserialize as as}from"@wormhole-foundation/sdk-definitions";import{getPackageId as ge}from"@wormhole-foundation/sdk-sui";import{getTokenCoinType as rs}from"@wormhole-foundation/sdk-sui-tokenbridge";import{fromBase64 as Xn}from"@mysten/bcs";function yt(l,t={}){let e=l.inputs??[],s=l.commands??[],n=t.numbers??"string",a=t.decode32As??"address",r=u=>n==="bigint"?u:n==="number"?Number(u):u.toString(),o=u=>{let m=Xn(u),d=g=>{let p=0n;for(let f=0;f<g;f++)p|=BigInt(m[f])<<8n*BigInt(f);return p};return m.length===1?{type:"pure",valueType:"u8",value:Number(m[0])}:m.length===2?{type:"pure",valueType:"u16",value:r(d(2))}:m.length===4?{type:"pure",valueType:"u32",value:Number(d(4))}:m.length===8?{type:"pure",valueType:"u64",value:r(d(8))}:m.length===32&&a==="address"?{type:"pure",valueType:"address",value:"0x"+[...m].map(p=>p.toString(16).padStart(2,"0")).join("")}:{type:"pure",valueType:"vector<u8>",value:Array.from(m)}},i=u=>{let m=e[u];if(!m)return{Input:u};if(m.Pure?.bytes)return o(m.Pure.bytes);let d=m.Object?.SharedObject;if(d)return{type:"object",objectType:"sharedObject",objectId:d.objectId,initialSharedVersion:String(d.initialSharedVersion),mutable:!!d.mutable};let g=m.Object?.ImmOrOwnedObject;return g?{type:"object",objectType:"immOrOwnedObject",objectId:g.objectId,version:String(g.version),digest:g.digest??void 0}:{Input:u}},c=u=>u?.GasCoin?"GasCoin":Array.isArray(u?.NestedResult)?u:typeof u?.Input=="number"?i(u.Input):u;return s.map(u=>{if(u.MoveCall){let m=u.MoveCall;return{MoveCall:{...m,arguments:(m.arguments??[]).map(c)}}}if(u.SplitCoins){let m=u.SplitCoins,d=m.coin?.GasCoin?"GasCoin":c(m.coin),g=(m.amounts??[]).map(c);return{SplitCoins:[d,g]}}if(u.MergeCoins){let m=u.MergeCoins;return{MergeCoins:{...m,destination:c(m.destination),sources:(m.sources??[]).map(c)}}}if(u.TransferObjects){let m=u.TransferObjects;return{TransferObjects:{...m,objects:(m.objects??[]).map(c),address:c(m.address)}}}return u})}var pe=class{#t;constructor(t){this.#t=t}async redeem(t,e){let s=Gn.fromChain(this.#t),n=this.#t.client,a=es.b64.decode(e),r=as("TokenBridge:Transfer",a),o=s.getCoreBridge(),i=s.getTokenBridge(),c=await rs(n,i,r.payload.token.address.toUint8Array(),ss(r.payload.token.chain));if(!c)throw new Error("Unable to fetch token coinType");let[u,m]=await Promise.all([ge(n,o),ge(n,i)]),d=new Yn;d.setSender(t);let[g]=d.moveCall({target:`${u}::vaa::parse_and_verify`,arguments:[d.object(o),d.pure.vector("u8",ns(r)),d.object(Zn)]}),[p]=d.moveCall({target:`${m}::vaa::verify_only_once`,arguments:[d.object(i),g]}),[f]=d.moveCall({target:`${m}::complete_transfer::authorize_transfer`,arguments:[d.object(i),p],typeArguments:[c]}),[h]=d.moveCall({target:`${m}::complete_transfer::redeem_relayer_payout`,arguments:[f],typeArguments:[c]});d.moveCall({target:`${m}::coin_utils::return_nonzero`,arguments:[h],typeArguments:[c]});let v=await d.build({client:n}),C=await d.toJSON(),y=yt(JSON.parse(C));return{from:t,commands:y,data:ts(v),type:Jn.Sui}}};import{AssetAmount as cs,CallType as us}from"@galacticcouncil/xc-core";import{toBase64 as ls}from"@mysten/bcs";import{distinctUntilChanged as ms,finalize as ds,shareReplay as gs,Subject as ps}from"rxjs";var Ct=class{client;config;constructor(t,e){this.validateClient(t),this.validateConfig(e),this.client=t,this.config=e}validateClient(t){if(!t)throw new Error("No client found")}validateConfig(t){if(!t.address)throw new Error("Sui address is required")}};import{SUI_TYPE_ARG as os}from"@mysten/sui/utils";var is=9,At=class extends Ct{async getBalance(){let{address:t}=this.config,e=await this.client.getBalance({owner:t,coinType:os});return BigInt(e.totalBalance)}async getDecimals(){return is}};var bt=class{static get(t,e){switch(e.module){case"Native":return new At(t,e);default:throw new Error("Module "+e.module+" is not supported")}}};var wt=class{#t;constructor(t){this.#t=t.client}async buildCall(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),o=await a.toJSON(),i=yt(JSON.parse(o));return{from:t,commands:i,data:ls(r),type:us.Sui,dryRun:async()=>{let c=await this.#t.dryRunTransactionBlock({transactionBlock:r});return{call:n.module+"."+n.func,error:c.executionErrorSource}}}}async estimateFee(t,e,s,n){let{transaction:a}=n;a.setSender(t);let r=await a.build({client:this.#t}),i=(await this.#t.dryRunTransactionBlock({transactionBlock:r})).effects.gasUsed,c=BigInt(i.computationCost),u=BigInt(i.storageCost),m=c+u;return s.copyWith({amount:m})}async getBalance(t,e){let s=bt.get(this.#t,e),[n,a]=await Promise.all([s.getBalance(),s.getDecimals()]);return cs.fromAsset(t,{amount:n,decimals:a})}async subscribeBalance(t,e){let s=new ps,n=s.pipe(gs(1)),a=async()=>{await(async()=>{let c=await this.getBalance(t,e);s.next(c)})();let i=setInterval(()=>{},3e3);return()=>clearInterval(i)},r;return a().then(o=>r=o),n.pipe(ds(()=>r?.()),ms((o,i)=>o.amount===i.amount))}};import{Ed25519Keypair as fs}from"@mysten/sui/keypairs/ed25519";import{Transaction as hs}from"@mysten/sui/transactions";var fe=class{#t;#e;constructor(t,e){this.#t=t,this.#e=e}async signAndSend(t,e){let{from:s,data:n}=t,a=this.#t.client;try{if(this.#e instanceof fs){let i=hs.from(n),c=await a.signAndExecuteTransaction({signer:this.#e,transaction:i,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(c.digest);return}let r=await this.#e.signTransaction({transaction:n,address:s,networkID:"sui:mainnet"}),o=await a.executeTransactionBlock({transactionBlock:r.transaction,signature:r.signature,options:{showEffects:!0,showEvents:!0,showObjectChanges:!0,showBalanceChanges:!0}});e.onTransactionSend(o.digest)}catch(r){e.onError(r)}}};var V=class{platform={};constructor(t){switch(t.getType()){case $.EvmChain:this.registerEvm(t);break;case $.EvmParachain:this.registerEvm(t),this.registerSubstrate(t);break;case $.Parachain:this.registerSubstrate(t);break;case $.SolanaChain:this.registerSolana(t);break;case $.SuiChain:this.registerSui(t);break;default:throw new Error("Unsupported platform: "+t.getType())}}registerEvm(t){let e=t;this.platform.Evm=new at(e)}registerSolana(t){let e=t;this.platform.Solana=new ut(e)}registerSui(t){let e=t;this.platform.Sui=new wt(e)}registerSubstrate(t){let e=t;this.platform.Substrate=new ht(e)}async buildCall(t,e,s,n){return this.platform[n.type].buildCall(t,e,s,n)}async estimateFee(t,e,s,n){return this.platform[n.type].estimateFee(t,e,s,n)}async getBalance(t,e){return this.platform[e.type].getBalance(t,e)}async subscribeBalance(t,e){return this.platform[e.type].subscribeBalance(t,e)}};import{addr as vs,AssetAmount as Rt,Parachain as xs}from"@galacticcouncil/xc-core";import{acc as Ss,big as be}from"@galacticcouncil/common";import{big as ys}from"@galacticcouncil/common";import Q from"big.js";function he(l,t,e,s){let n=l.toBig().minus(e.toBig()).minus(l.isSame(t)?t.toBig():new Q(0));return s&&(n=n.minus(l.isSame(s)?s.toBig():new Q(0))),l.copyWith({amount:n.lt(0)?0n:BigInt(n.toFixed())})}function ye(l,t,e,s){let a=l.copyWith({amount:0n}).toBig().plus(l.isSame(t)?t.toBig():new Q(0)).plus(l.toBig().lt(e.toBig())?e.toBig():new Q(0));return s&&(a=a.plus(l.isSame(s)&&l.toBig().lt(s.toBig())?s.toBig():new Q(0))),l.copyWith({amount:BigInt(a.toFixed())})}async function F(l,t){return t.isEvmParachain()?t.getDerivatedAddress(l):l}function Ce(l,t){return t?ys.toBigInt(t,l):0n}import{addr as Cs,AssetAmount as As,Parachain as Ae}from"@galacticcouncil/xc-core";import{big as bs}from"@galacticcouncil/common";var{EvmAddr:ws}=Cs,W=class{adapter;config;constructor(t,e){this.adapter=t,this.config=e}async getEd(){let{chain:t}=this.config;if(t instanceof Ae)return(await P.create(t)).getExistentialDeposit()}async getBalance(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.asset,r=e.getBalanceAssetId(a),o=ws.isValid(r.toString())?await F(t,e):t,i=s.source.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=s.min;if(t instanceof Ae&&a){let r=t.getMinAssetId(n),o=a.build({asset:r});return this.adapter.getBalance(n,o)}return this.getAssetMin()}async getAssetMin(){let{chain:t,route:e}=this.config,{source:s}=e,n=s.asset,a=t.getAssetMin(n),r=await this.getDecimals(n),o=0n;return a&&(o=bs.toBigInt(a,r)),As.fromAsset(n,{amount:o,decimals:r})}async getDecimals(t){let{chain:e}=this.config,s=e.getAssetDecimals(t);return s||(await e.getCurrency()).decimals}};var{EvmAddr:we}=vs,q=class extends W{constructor(t,e){super(t,e)}async getCall(t){let{amount:e,sender:s,source:n}=t,a=await this.getTransfer(t);return this.adapter.buildCall(s,e,n.feeBalance,a)}async getDestinationFee(){let{chain:t,route:e}=this.config,{source:s,destination:n,transact:a}=e,r=n.fee.amount,o=s.destinationFee.asset||n.fee.asset,i=await this.getDecimals(o);if(Number.isFinite(r))return{fee:Rt.fromAsset(o,{amount:be.toBigInt(r,i),decimals:i}),feeBreakdown:{}};let c=r,{amount:u,breakdown:m}=await c.build({feeAsset:o,transferAsset:s.asset,source:a?a.chain:t,destination:n.chain});return{fee:Rt.fromAsset(o,{amount:u,decimals:i}),feeBreakdown:m}}async getDestinationFeeBalance(t){let{chain:e,route:s}=this.config,{source:n,destination:a}=s,r=n.asset,o=n.destinationFee.asset||a.fee.asset;if(r.isEqual(o))return this.getBalance(t);let i=e.getBalanceAssetId(o),c=we.isValid(i.toString())?await F(t,e):t,u=n.destinationFee.balance.build({address:c,asset:o,chain:e});return this.adapter.getBalance(o,u)}async getFee(t){let{chain:e,route:s}=this.config,{amount:n,sender:a,source:r}=t,o=await this.getTransfer(t),i=s.contract?await F(a,e):a,c=await this.adapter.estimateFee(i,n,r.feeBalance,o),{fee:u}=s.source,m=u?Ce(c.decimals,u.extra):0n,d=c.amount+m;return c.copyWith({amount:d})}async getFeeBalance(t){let{chain:e,route:s}=this.config,{source:n}=s;if(!n.fee)return this.getBalance(t);let a=await this.getFeeAsset(t),r=e.getBalanceAssetId(a),o=we.isValid(r.toString())?await F(t,e):t,i=n.fee.balance.build({address:o,asset:a,chain:e});return this.adapter.getBalance(a,i)}async getFeeAsset(t){let{chain:e,route:s}=this.config,{source:n}=s,a=n.fee,r=n.asset;if(!a)return r;let o=a.asset;return e instanceof xs&&"build"in o?await o.build({chain:e,address:t}):o}async getTransfer(t){let{chain:e,route:s}=this.config,{contract:n,extrinsic:a,program:r,move:o}=s;if(a){let{address:c,amount:u,asset:m,sender:d}=t,p=await(await P.create(e)).buildMessageId(d,u,m.originSymbol,c);return a.build({...t,messageId:p})}let i=n||r||o;if(i)return i.build({...t});throw new Error("AssetRoute transfer config is invalid! Specify contract, extrinsic, move or program instructions.")}async getTransact(t){let{route:e}=this.config,{transact:s}=e;if(s){let n=Object.assign({transact:{chain:s.chain}}),a={...t,...n};return{...await this.getTransactData(s,a),chain:s.chain}}}async getTransactData(t,e){let{chain:s,extrinsic:n}=t,a=await n.build(e),r=await P.create(s),o=a.getTx(r.client),i=e.source.chain,c=e.sender,u=Ss.getMultilocationDerivatedAccount(i.parachainId,c,s.parachainId===0?0:1,s.usesH160Acc),m=await o.getPaymentInfo(u),d=await o.getEncodedData(),[g,p]=await Promise.all([this.getTransactFee(t),this.getTransactFeeBalance(t,e)]);return{call:d,chain:s,fee:g,feeBalance:p,weight:{refTime:m.weight.ref_time,proofSize:m.weight.proof_size}}}async getTransactFee(t){let{fee:e}=t,s=await this.getDecimals(e.asset),n=be.toBigInt(e.amount,s);return Rt.fromAsset(e.asset,{amount:n,decimals:s})}async getTransactFeeBalance(t,e){let{chain:s}=this.config,{fee:n}=t,a=n.balance.build({address:e.sender,asset:n.asset,chain:s});return this.adapter.getBalance(n.asset,a)}};var X=class extends W{constructor(t,e){super(t,e)}};import{AssetAmount as Ps}from"@galacticcouncil/xc-core";var J=class{ctx;constructor(t){this.ctx=t}get asset(){let{source:t}=this.ctx;return t.balance}get dex(){let{source:t}=this.ctx;return t.chain.dex}get destFee(){let{source:t,transact:e}=this.ctx;return e?e.fee:t.destinationFee}get destFeeBalance(){let{source:t,transact:e}=this.ctx;return e?e.feeBalance:t.destinationFeeBalance}get feeBalance(){let{source:t}=this.ctx;return t.feeBalance}async getSwap(t){let{asset:e,decimals:s}=await this.dex.chain.getCurrency(),{amount:n}=await this.dex.getQuote(e,t,t);return{aIn:t,aOut:Ps.fromAsset(e,{amount:n,decimals:s}),enabled:!0}}isSwapSupported(t){try{this.dex}catch{return!1}return!!(t&&t.swap)}async getDestinationSwap(t){let{amount:e,route:s}=await this.dex.getQuote(t,this.destFee,this.destFee),n=this.destFeeBalance.amount<this.destFee.amount,a=this.feeBalance.amount-t.amount>e*2n;return{aIn:t.copyWith({amount:e}),aOut:this.destFee,enabled:n&&a,route:s}}isDestinationSwapSupported(t){try{this.dex}catch{return!1}let e=!t.isSame(this.destFee),s=this.asset.isSame(this.destFee);return e&&!s}};var{EvmAddr:Rs}=Bs,kt=class{config;validations;constructor({configService:t,transferValidations:e}){this.config=t,this.validations=e||[]}async transfer(t,e,s,n,a){let r=Es(this.config).assets().asset(t).source(s).destination(a).build();return this.getTransferData(r,e,n)}async remoteXcm(t,e,s,n,a={}){let r=this.config.getChain(e),o=this.config.getChain(s);if(!(r.isSubstrate()&&o.isSubstrate()))throw Error("RemoteXcm is supported only between parachains");let[c,u]=await Promise.all([P.create(r),P.create(o)]),m=new ft(c,u),d=Ts.getMultilocationDerivatedAccount(r.parachainId,t,1,o.usesH160Acc),g=await u.getAsset(),p=await this.transfer(g,t,e,d,s);return m.remoteExec(t,d,n,f=>{let h=f.toDecimal();return p.buildCall(h)},a)}async getTransferData(t,e,s){let n=t.origin,a=t.reverse,r=new V(n.chain),o=new V(a.chain),i=new q(r,n),c=new X(o,a),u=new Is(...this.validations),[m,d,g,p,f,h,v]=await Promise.all([i.getBalance(e),i.getFeeBalance(e),i.getDestinationFee(),i.getDestinationFeeBalance(e),i.getMin(),c.getBalance(s),c.getMin()]),{source:C,destination:y}=n.route,x=g.fee.copyWith(y.fee.asset),B=g.feeBreakdown,j=C.asset.isEqual(x)&&x.amount>10n?x.amount+1n:10n,A={address:s,amount:j,asset:C.asset,destination:{balance:h,chain:a.chain,fee:x,feeBreakdown:B},sender:e,source:{balance:m,chain:n.chain,fee:d.copyWith({amount:0n}),feeBalance:d,destinationFee:g.fee,destinationFeeBalance:p}};A.transact=await i.getTransact(A);let T=new J(A),b=await i.getFee(A),E;T.isSwapSupported(C.fee)&&(E=await T.getSwap(b),A.source.feeSwap=E);let I;T.isDestinationSwapSupported(b)&&(I=await T.getDestinationSwap(b),A.source.destinationFeeSwap=I),(E||I)&&(b=await i.getFee(A),b=b.padByPct(5n));let G=await c.getEd(),xt=ye(h,x,v,G),w=await i.getEd(),Y=he(m,b,f,w);return A.amount=0n,A.source.fee=b,{source:{balance:m,destinationFee:g.fee,destinationFeeBalance:p,destinationFeeSwap:I,fee:b,feeBalance:d,feeSwap:E,max:Y,min:m.copyWith({amount:xt.amount})},destination:{balance:h,fee:x},async buildCall(R){let S=Object.assign({},A);return S.amount=ve.toBigInt(R,m.decimals),S.transact=await i.getTransact(S),i.getCall(S)},async estimateFee(R){let S=Object.assign({},A);return S.amount=ve.toBigInt(R,m.decimals),S.transact=await i.getTransact(S),i.getFee(S)},async validate(R){let S=Object.assign({},A),Te=R||b.amount;return S.source.fee=b.copyWith({amount:Te}),u.validate(S)}}}async subscribeBalance(t,e,s){let n=this.config.getChainRoutes(e),a=new V(n.chain),r=n.getUniqueRoutes().map(async({source:c})=>{let{asset:u,balance:m}=c,d=n.chain.getBalanceAssetId(u),g=Rs.isValid(d.toString())?await F(t,n.chain):t,p=m.build({address:g,asset:u,chain:n.chain});return a.subscribeBalance(u,p)}),o=await Promise.all(r);return Fs(o).pipe(Ds(500)).subscribe(s)}};import{ConfigBuilder as ks}from"@galacticcouncil/xc-core";function Vs(l){let t=ks(l.config).assets();return{assets:t,withAsset(e){let s=t.asset(e);return{sources:s,withSource(n){let a=s.source(n);return{destinations:a,withDestination(r){let{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:u,build:m}=a.destination(r);return{routes:o,destinationAssets:i,isAssetSelect:c,isTagSelect:u,build({srcAddress:d,dstAddress:g,dstAsset:p,tag:f}){let h=m(p,f);return l.getTransferData(h,d,g)}}}}}}}}}import{Precompile as Os}from"@galacticcouncil/xc-core";var _s="https://api.wormholescan.io",vt=class{_baseUrl;constructor(t){this._baseUrl=t||_s}buildApi(t,e){return[this._baseUrl,t,"?"].join("")+new URLSearchParams(e).toString()}async getVaaBytes(t){let e=this.buildApi("/v1/signed_vaa/"+t,{});return await(await fetch(e)).json()}async getVaa(t){let e=this.buildApi("/api/v1/vaas/"+t,{});return(await(await fetch(e)).json()).data}async getVaaByTxHash(t){let e=this.buildApi("/api/v1/vaas/",{txHash:t}),n=await(await fetch(e)).json();if(n.data.length>0)return n.data[0];throw Error("Can't find VAA for given txHash: "+t)}async getOperations(t){let e=this.buildApi("/api/v1/operations/",t);return(await(await fetch(e)).json()).operations}async getOperation(t){let e=this.buildApi("/api/v1/operations/"+t,{});return await(await fetch(e)).json()}isMrlTransfer(t){let{payloadType:e,toAddress:s,toChain:n}=t,a="0x"+s.substring(26);return e===3&&n===16&&a===Os.Bridge}};import{acc as Ms}from"@galacticcouncil/common";import{mrl as Ns,ChainType as Se,Parachain as Ws,Precompile as Us,Wormhole as U}from"@galacticcouncil/xc-core";import{encoding as js}from"@wormhole-foundation/sdk-base";import{keccak256 as Ks}from"@wormhole-foundation/sdk-connect";import{deserialize as zs}from"@wormhole-foundation/sdk-definitions";var xe=(s=>(s[s.WaitingForVaa=0]="WaitingForVaa",s[s.VaaEmitted=1]="VaaEmitted",s[s.Completed=2]="Completed",s))(xe||{});var Hs=300*1e3,Pe=class{parachainId;config;whScan;constructor(t,e){this.config=t,this.parachainId=e,this.whScan=new vt}get chains(){let t=this.config.chains.values();return Array.from(t)}get filters(){let t=new Date,e=new Date;e.setDate(t.getDate()-6);let s=t.toISOString();return{page:"0",pageSize:"50",includeEndDate:"true",from:e.toISOString(),to:s}}async getWithdraws(t){let e=Ms.getMultilocationDerivatedAccount(this.parachainId,t,1,!0),n=(await this.whScan.getOperations({...this.filters,address:e})).map(async a=>{let{content:r}=a,{payload:o,standarizedProperties:i}=r,c=this.getStatus(a),u=this.chains.find(f=>f instanceof Ws&&f.parachainId===this.parachainId),{toAddress:m,tokenAddress:d}=i,g=this.chains.find(f=>U.isKnown(f)&&U.fromChain(f).getWormholeId()===o.tokenChain),p;if(c===1&&a.vaa){let{timestamp:f}=this.getVaaHeader(a.vaa.raw),h=a.vaa.raw;if(this.isStuck(f))switch(g.getType()){case Se.EvmChain:let v=new Z(g);p=async y=>v.redeem(y,h);break;case Se.SolanaChain:let C=new dt(g);p=async y=>C.redeem(y,h);break}}return{asset:d,assetSymbol:a.data.symbol,amount:a.data.tokenAmount,from:t,fromChain:u,to:m,toChain:g,status:c,redeem:p,operation:a}});return Promise.all(n)}async getDeposits(t,e="hydration"){let s=await this.whScan.getOperations({...this.filters,address:Us.Bridge,pageSize:"100"}),n=this.config.chains.get(e);if(!n)return[];let a=n,o=(await Ns.createPayload(a,t)).toHex(),i=s.filter(c=>{let{content:u}=c,{payload:m}=u;return m.payloadType===3&&m.toChain===16&&"0x"+m.payload===o}).map(async c=>{let{content:u,sourceChain:m}=c,{payload:d,standarizedProperties:g}=u,p=this.getStatus(c),{tokenAddress:f}=g,h=this.chains.find(y=>U.isKnown(y)&&U.fromChain(y).getWormholeId()===d.tokenChain),v=this.chains.find(y=>U.isKnown(y)&&U.fromChain(y).getWormholeId()===d.toChain),C;if(p===1&&c.vaa){let{timestamp:y}=this.getVaaHeader(c.vaa.raw),x=c.vaa.raw;if(this.isStuck(y)){let B=new gt(v);C=async D=>B.redeemMrlViaXcm(D,x)}}return{asset:f,assetSymbol:c.data.symbol,amount:c.data.tokenAmount,from:m.from,fromChain:h,to:t,toChain:n,status:p,redeem:C,operation:c}});return Promise.all(i)}isStuck(t){return Date.now()>=t*1e3+Hs}getVaaHeader(t){let e=js.b64.decode(t),s=zs("Uint8Array",e);return{timestamp:s.timestamp,emitterChain:s.emitterChain,emitterAddress:s.emitterAddress.toString(),sequence:s.sequence,payload:s.payload,hash:s.hash,id:Ks(s.hash)}}getStatus(t){return t.vaa?t.targetChain&&t.targetChain.status==="completed"?2:1:0}};export{Wt as DISPATCH_ADDRESS,Z as EvmClaim,at as EvmPlatform,Ut as EvmSigner,J as FeeSwap,V as PlatformAdapter,dt as SolanaClaim,M as SolanaLilJit,ut as SolanaPlatform,ee as SolanaSigner,gt as SubstrateClaim,ft as SubstrateExec,ht as SubstratePlatform,P as SubstrateService,de as SubstrateSigner,pe as SuiClaim,wt as SuiPlatform,fe as SuiSigner,Vs as TransferBuilder,kt as Wallet,xe as WhStatus,vt as WormholeScan,Pe as WormholeTransfer,Qt as chunkBySize,Ar as deserializeV0,k as ixToHuman,H as serializeV0};
|
|
@@ -1,3 +1,8 @@
|
|
|
1
1
|
import { ContractConfig } from '@galacticcouncil/xc-core';
|
|
2
|
+
export declare function isSnowbridgeV2(config: ContractConfig): boolean;
|
|
3
|
+
/**
|
|
4
|
+
* Extract the ERC20 token address from Snowbridge V2 assets arg.
|
|
5
|
+
s */
|
|
6
|
+
export declare function getSnowbridgeV2TokenAddress(config: ContractConfig): string | undefined;
|
|
2
7
|
export declare function isNativeEthBridge(config: ContractConfig): boolean;
|
|
3
8
|
export declare function isPrecompile(config: ContractConfig): boolean;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@galacticcouncil/xc-sdk",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.0-pr297-4f08471",
|
|
4
4
|
"description": "Cross-chain sdk",
|
|
5
5
|
"author": "GalacticCouncil",
|
|
6
6
|
"type": "module",
|
|
@@ -33,6 +33,6 @@
|
|
|
33
33
|
"link": "npm ln"
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
|
-
"@galacticcouncil/xc-core": "
|
|
36
|
+
"@galacticcouncil/xc-core": "1.1.0-pr297-4f08471"
|
|
37
37
|
}
|
|
38
38
|
}
|