@wormhole-foundation/wormhole-connect 2.4.0-beta.3-development → 2.4.0-beta.4-development
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{aptos-BaxuZv2A.js → aptos-C2a0dQjT.js} +2 -2
- package/dist/assets/{ccip-Br2IvhSW.js → ccip-OC0Vc4gm.js} +1 -1
- package/dist/assets/events-7fnqQH7x.js +1 -0
- package/dist/assets/{evm-CEkHuuN5.js → evm-BqmuByVY.js} +3 -3
- package/dist/assets/{evm-DajrgWJp.js → evm-DVLSeRFU.js} +2 -2
- package/dist/assets/{index-D1RqQWR4.js → index-BIdhtTCf.js} +1 -1
- package/dist/assets/{index-DVzhMXXA.js → index-BVlgnsQb.js} +1 -1
- package/dist/assets/{index-ndTMsj-g.js → index-BZDxvV4g.js} +1 -1
- package/dist/assets/{index-B8SSPOGN.js → index-BeEE7MyN.js} +1 -1
- package/dist/assets/{index-z2SBICrL.js → index-C-kVvSEJ.js} +1 -1
- package/dist/assets/{index-Zgbd9ue1.js → index-C1Dta-NJ.js} +1 -1
- package/dist/assets/{index-BWKZaYh0.js → index-CB3XpWtg.js} +1 -1
- package/dist/assets/{index-ylKZk0sO.js → index-CBMmMx3W.js} +1 -1
- package/dist/assets/{index-BGgxsbk4.js → index-CODUkWzQ.js} +1 -1
- package/dist/assets/{index-DnDUIJZk.js → index-COKaKwn8.js} +1 -1
- package/dist/assets/{index-BxMnYxyf.js → index-CvqWMPrS.js} +1 -1
- package/dist/assets/{index-DwbsyLxo.js → index-Dcsj5S2N.js} +1 -1
- package/dist/assets/{index-ICy6eYwP.js → index-M4NDMEge.js} +1 -1
- package/dist/assets/{index-CIIbEJG8.js → index-PnI0Le4b.js} +1 -1
- package/dist/assets/{index-BIKKjy76.js → index-iO-U9jSW.js} +2 -2
- package/dist/assets/index-n50xdA-U.js +1 -0
- package/dist/assets/{index.es-AACkekVm.js → index.es-j8vEfzbO.js} +6 -6
- package/dist/assets/solana-D-pftkkJ.js +2 -0
- package/dist/assets/{solana-Cli5bij_.js → solana-pOvS3swt.js} +2 -2
- package/dist/assets/solanaEmbed.esm-DPIgn-PE.js +37 -0
- package/dist/assets/{sui-76yNbUUP.js → sui-DZhbOaP_.js} +2 -2
- package/dist/main.js +106 -106
- package/dist/src/views/v2/Redeem/index.d.ts.map +1 -1
- package/lib/{aptos-cEXzuL5b.mjs → aptos-CkWuq_27.mjs} +2 -2
- package/lib/{aptos-CSvcKEJm.js → aptos-DU1D2bsY.js} +1 -1
- package/lib/{aptos-WpCc6eOD.js → aptos-TTV2w234.js} +2 -2
- package/lib/{aptos-D3RPZgif.mjs → aptos-qwmh1AJp.mjs} +5 -5
- package/lib/{base64-C73YLbqA.js → base64-CkebPGW0.js} +1 -1
- package/lib/{base64-D3sIs-fw.mjs → base64-r6lIUfD-.mjs} +1 -1
- package/lib/{ccip-BJTawxQ_.mjs → ccip-D869mIiq.mjs} +1 -1
- package/lib/{ccip-CaksatNz.js → ccip-DdUs_h_I.js} +1 -1
- package/lib/{chunk-IMTC3J2M-Dsnj4Vih.mjs → chunk-IMTC3J2M-CSrenBj8.mjs} +3 -3
- package/lib/{chunk-IMTC3J2M-DKXvnM6O.js → chunk-IMTC3J2M-rihZh7hM.js} +1 -1
- package/lib/{evm-D_aPV3AL.mjs → evm-BCvj1OtP.mjs} +6 -6
- package/lib/{evm-Wv2nh7z1.js → evm-Bj5TkyBv.js} +3 -3
- package/lib/{evm-Bs0OjXvE.mjs → evm-BtEIk2Ro.mjs} +5 -5
- package/lib/{evm-DNBYBo_p.js → evm-Df4WZQgF.js} +1 -1
- package/lib/{index-DCRe22Ms.js → index-20yIH7p6.js} +1 -1
- package/lib/{index-D0NbpzAg.mjs → index-B3Lgw0sO.mjs} +1 -1
- package/lib/{index-Bx5QNYj7.mjs → index-BL_uPuTy.mjs} +1 -1
- package/lib/{index-BCrWCNUq.js → index-BOtebTDA.js} +1 -1
- package/lib/{index-Ci0LEPmE.mjs → index-BXHY_Wc_.mjs} +2 -2
- package/lib/{index-q570DLLo.mjs → index-BfQHVxEi.mjs} +2 -2
- package/lib/{index-DLeUCqIq.js → index-BnQbapb-.js} +1 -1
- package/lib/{index-BZpnoMd1.js → index-BnvAiffX.js} +1 -1
- package/lib/{index-CUSJAO56.js → index-C-9QGhXS.js} +1 -1
- package/lib/{index-CjgM-0OC.js → index-C0UDZaND.js} +1 -1
- package/lib/{index-DGGMUOzp.mjs → index-C2w2yYzm.mjs} +3 -3
- package/lib/{index-BpKxYGa-.mjs → index-C54QUs8N.mjs} +2 -2
- package/lib/{index-BvdMRpl6.js → index-C6Oecme5.js} +1 -1
- package/lib/{index-BtA_-iXv.mjs → index-CBM9cmhA.mjs} +2 -2
- package/lib/{index-DYrT7_2n.mjs → index-CCJUXjWs.mjs} +1 -1
- package/lib/{index-DS_rORqD.mjs → index-CIWjtrm4.mjs} +1 -1
- package/lib/{index-D7f2-3wk.js → index-CZi3G6c5.js} +1 -1
- package/lib/{index-9pPnVz73.mjs → index-Cf6wneHs.mjs} +2 -2
- package/lib/{index-C6Hp_1yF.js → index-ChLwWlxD.js} +1 -1
- package/lib/{index-ZK1P1tUH.js → index-Cn5RoB2l.js} +1 -1
- package/lib/{index-v-_ti7Rn.js → index-CskmLcFl.js} +1 -1
- package/lib/{index-BeGnKztN.js → index-Cv_SfKSZ.js} +1 -1
- package/lib/{index-BH-EfOl1.js → index-CxOOdI6c.js} +1 -1
- package/lib/{index-DfPjBy3w.mjs → index-CxnykIim.mjs} +1 -1
- package/lib/{index-DRYbBPuh.mjs → index-D5jQOGNt.mjs} +2 -2
- package/lib/{index-CMw2Uill.js → index-D8mnxtTR.js} +1 -1
- package/lib/{index-BrFIzqtL.js → index-DG9DA23c.js} +1 -1
- package/lib/{index-e3oHdOB4.mjs → index-DIdfi9U5.mjs} +1 -1
- package/lib/{index--95bwciz.js → index-DNGByy1S.js} +1 -1
- package/lib/{index-B2VBT3u7.mjs → index-DOLtniOC.mjs} +2 -2
- package/lib/{index-DqRhhSXa.mjs → index-DS1lD1iG.mjs} +2 -2
- package/lib/{index-Cvtp4dgE.js → index-DU1he9Nx.js} +5 -5
- package/lib/{index-D19OP8Mu.mjs → index-Dfo3bBnl.mjs} +2 -2
- package/lib/{index-ctEY-xjJ.mjs → index-Dgohn547.mjs} +3 -3
- package/lib/{index-DwhWt2Jt.mjs → index-DjHz-TGq.mjs} +1 -1
- package/lib/{index-Cb51fnZM.js → index-DnIR5ghZ.js} +1 -1
- package/lib/{index-COqO8I1C.mjs → index-DqfeHeDN.mjs} +1 -1
- package/lib/{index-Bzn58Yhp.js → index-JY_vmjxX.js} +1 -1
- package/lib/{index-CcEA2K6Q.mjs → index-LaHWWgzV.mjs} +1 -1
- package/lib/{index-CUMRJ8yy.mjs → index-ObRYlj1l.mjs} +48 -16
- package/lib/{index-DRMwoM8a.mjs → index-ZuBMF5ZM.mjs} +4 -4
- package/lib/{index-DIqG9W_r.js → index-l0_fPapQ.js} +1 -1
- package/lib/{index-KpBoUsX2.mjs → index-tsZGjIYB.mjs} +1 -1
- package/lib/{index-DNBuc7tl.js → index-v9fEg88t.js} +1 -1
- package/lib/{index-tzTI5R9c.js → index-vPc_VIRu.js} +1 -1
- package/lib/{index-C5rfYL4K.js → index-yU0Hsqz_.js} +1 -1
- package/lib/{index.es-Czhf3Th8.js → index.es-Bqw6r4nv.js} +2 -2
- package/lib/{index.es-By1LsNow.mjs → index.es-DFa1opYl.mjs} +5 -5
- package/lib/index.js +1 -1
- package/lib/index.mjs +1 -1
- package/lib/{signer-jV9Ixq8U.js → signer-DEoUkKh3.js} +1 -1
- package/lib/{signer-CcpDR9mm.mjs → signer-_KpSCeJr.mjs} +1 -1
- package/lib/{solana-Bo2aMvX4.mjs → solana-CeI-x62u.mjs} +4 -4
- package/lib/solana-CzIZTTUh.js +1 -0
- package/lib/{solana-4YAkIi-J.js → solana-Dbf-kAb8.js} +1 -1
- package/lib/solana-UZrOCesE.mjs +17 -0
- package/lib/{solanaEmbed.esm-B-rprhcd.js → solanaEmbed.esm-CM69eDrj.js} +1 -1
- package/lib/{solanaEmbed.esm-4CS_00aM.mjs → solanaEmbed.esm-rMe_voKF.mjs} +1 -1
- package/lib/src/views/v2/Redeem/index.d.ts.map +1 -1
- package/lib/{sui-MorjdPyy.js → sui-1KKOjsyu.js} +1 -1
- package/lib/{sui-BgD7gx67.js → sui-BRucFXyI.js} +1 -1
- package/lib/{sui-BGaWik82.mjs → sui-CtQtzdVy.mjs} +1 -1
- package/lib/{sui-DLOfqNsy.mjs → sui-DMYKKmcs.mjs} +5 -5
- package/package.json +21 -21
- package/dist/assets/index-GDpnrg5w.js +0 -1
- package/dist/assets/solana-DlYSFsGk.js +0 -2
- package/dist/assets/solanaEmbed.esm-P5uPPwsm.js +0 -37
- package/lib/solana-DA02fWu7.mjs +0 -17
- package/lib/solana-DVFk6Z5q.js +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
var S=Object.defineProperty;var v=(a,e,t)=>e in a?S(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t;var i=(a,e,t)=>v(a,typeof e!="symbol"?e+"":e,t);import{
|
|
1
|
+
var S=Object.defineProperty;var v=(a,e,t)=>e in a?S(a,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):a[e]=t;var i=(a,e,t)=>v(a,typeof e!="symbol"?e+"":e,t);import{cV as I,cW as f,cX as x,cT as b,cY as p,bI as w,c9 as U,bP as $,ca as m,af as o,Q as k,ap as c,an as h,cZ as E,cf as T,i as F,cc as C,al as _,bQ as u,c_ as Q,bV as W}from"../main.js";import{A as N}from"./unsignedTransaction-DsxtoHjl.js";import{A as O}from"./aptos-C2a0dQjT.js";import"./chunk-IMTC3J2M-DIjpRZZk.js";import"./index-WlpSU6Q6.js";import"./base64-IWuz5NCL.js";const R=[{name:"tokenBridgeAddress",...f},{name:"chain",...x()},{name:"domainSeparator",binary:"bytes",custom:b.encode(p),omit:!0},{name:"tokenId",...f},{name:"domainSeparator",binary:"bytes",custom:new Uint8Array([255]),omit:!0}],P=a=>I(R,a);class d{constructor(e,t,s,r){i(this,"network");i(this,"chain");i(this,"connection");i(this,"contracts");i(this,"chainId");i(this,"tokenBridgeAddress");this.network=e,this.chain=t,this.connection=s,this.contracts=r,this.chainId=w(t);const n=r.tokenBridge;if(!n)throw new Error(`TokenBridge contract Address for chain ${t} not found`);this.tokenBridgeAddress=n}static async fromRpc(e,t){const[s,r]=await O.chainFromRpc(e),n=t[r];if(n.network!==s)throw new Error("Network mismatch "+n.network+" !== "+s);return new d(s,r,e,n.contracts)}async isWrappedAsset(e){try{return await this.getOriginalAsset(e),!0}catch{return!1}}async getOriginalAsset(e){const t=e.toString().split(p),s=await this.connection.getAccountResource({accountAddress:t[0],resourceType:`${this.tokenBridgeAddress}::state::OriginInfo`});if(!s)throw U(e.toString());const r=$(parseInt(s.token_chain.number)),n=new m(s.token_address.external_address);return{chain:r,address:n}}async getTokenUniversalAddress(e){return new m(o.encode(k(e.toString()),!0))}async getTokenNativeAddress(e,t){const s=e===this.chain?await this.getTypeFromExternalAddress(t.toString()):await this.getAssetFullyQualifiedType({chain:e,address:t});if(!s)throw new Error("Invalid asset address.");return new c(s)}async hasWrappedAsset(e){try{return await this.getWrappedAsset(e),!0}catch{}return!1}async getWrappedAsset(e){if(h(e.address))throw new Error("native asset cannot be a wrapped asset");const t=await this.getAssetFullyQualifiedType(e);if(!t)throw new Error("Invalid asset address.");return await this.connection.getAccountResource({accountAddress:E(t),resourceType:`${this.tokenBridgeAddress}::state::OriginInfo`}),T(this.chain,t)}async isTransferCompleted(e){const s=(await this.connection.getAccountResource({accountAddress:this.tokenBridgeAddress,resourceType:`${this.tokenBridgeAddress}::state::State`})).consumed_vaas.elems.handle;try{return await this.connection.getTableItem({handle:s,data:{key_type:"vector<u8>",value_type:"u8",key:`0x${F.Buffer.from(C(e.hash)).toString("hex")}`}}),!0}catch{return!1}}async getWrappedNative(){return T(this.chain,_)}async*createAttestation(e,t){const s={chain:this.chain,address:new c(e)},r=await this.getAssetFullyQualifiedType(s);if(!r)throw new Error("Invalid asset address.");yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::attest_token::attest_token_entry`,typeArguments:[r],functionArguments:[]},"Aptos.AttestToken")}async*submitAttestation(e,t){yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::wrapped::create_wrapped_coin_type`,typeArguments:[],functionArguments:[u(e)]},"Aptos.CreateWrappedCoinType");const s=await this.getAssetFullyQualifiedType(e.payload.token);if(!s)throw new Error("Invalid asset address.");yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::wrapped::create_wrapped_coin`,typeArguments:[s],functionArguments:[u(e)]},"Aptos.CreateWrappedCoin")}async*transfer(e,t,s,r,n){const B=0n,A=0n,y=h(s)?_:s.toString(),l=t.address.toUniversalAddress().toUint8Array(),g=w(t.chain);n?yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::transfer_tokens::transfer_tokens_with_payload_entry`,typeArguments:[y],functionArguments:[r,g,l,A,n]},"Aptos.TransferTokensWithPayload"):yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::transfer_tokens::transfer_tokens_entry`,typeArguments:[y],functionArguments:[r,g,l,B,A]},"Aptos.TransferTokens")}async*redeem(e,t,s=!0){const r=t.payload.token.chain===this.chain?await this.getTypeFromExternalAddress(t.payload.token.address.toString()):await this.getAssetFullyQualifiedType(t.payload.token);if(!r)throw new Error("Invalid asset address.");yield this.createUnsignedTx({function:`${this.tokenBridgeAddress}::complete_transfer::submit_vaa_and_register_entry`,typeArguments:[r],functionArguments:[u(t)]},"Aptos.CompleteTransfer")}async getAssetFullyQualifiedType(e){return e.chain===this.chain?Q(e.address.toString())?e.address.toString():null:`${d.getForeignAssetAddress(this.chain,this.tokenBridgeAddress,e)}::coin::T`}async getTypeFromExternalAddress(e){try{const t=await this.connection.getAccountResource({accountAddress:this.tokenBridgeAddress,resourceType:`${this.tokenBridgeAddress}::state::State`}),{handle:s}=t.native_infos,r=await this.connection.getTableItem({handle:s,data:{key_type:`${this.tokenBridgeAddress}::token_hash::TokenHash`,value_type:"0x1::type_info::TypeInfo",key:{hash:e}}});return r?[r.account_address,String.fromCharCode(...o.decode(r.module_name)),String.fromCharCode(...o.decode(r.struct_name))].join(p):null}catch{return null}}static getForeignAssetAddress(e,t,s){if(h(s.address))throw new Error("Invalid token address");const r=P({chain:s.chain,tokenBridgeAddress:new c(t).toUniversalAddress(),tokenId:s.address.toUniversalAddress()});return o.encode(k(r),!0)}createUnsignedTx(e,t,s=!1){return new N(e,this.network,this.chain,t,s)}}W("Aptos","TokenBridge",d);export{d as AptosTokenBridge};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var oe=Object.defineProperty;var se=(m,t,e)=>t in m?oe(m,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):m[t]=e;var h=(m,t,e)=>se(m,typeof t!="symbol"?t+"":t,e);import{g as F,a as N,i as $,S as I,b,T as _,c as C,p as ae,d as ie,e as R,f as M,h as G,j as ce,k as x,l as de,m as le}from"./sui-76yNbUUP.js";import{d1 as W,aZ as ge,d2 as Z,d3 as S,bL as ue,ca as D,cb as q,bQ as fe,bJ as j,a$ as O,an as v,bN as pe,cg as H,cd as he,d4 as we,bR as V,aY as ye,af as U,aQ as me,cU as ke,cH as L,d5 as be,d6 as Ie,a_ as Q,bW as X}from"../main.js";import"./index-DVzhMXXA.js";import{S as ee}from"./unsignedTransaction-arVvzoJx.js";import"./blake2b-C_UGgjrB.js";import"./index-WlpSU6Q6.js";const Y=async(m,t,e)=>{var d,r,n;if(!W(e))throw new Error(`Invalid Sui type: ${e}`);const i=await F(m,t);if(!i)throw new Error(`Unable to fetch object fields from token bridge state. Object ID: ${t}`);const o=(r=(d=i.token_registry.fields)==null?void 0:d.id)==null?void 0:r.id;if(!o)throw new Error("Unable to fetch token registry object ID");const a=ge((n=i.token_registry)==null?void 0:n.type);if(!a)throw new Error("Unable to fetch token registry package ID");return m.getDynamicFieldObject({parentId:o,name:{type:`${a}::token_registry::Key<${e}>`,value:{dummy_field:!1}}})},P=async(m,t,e,i)=>{var s,u,f,w;const o=await F(m,t);if(!o)throw new Error("Unable to fetch object fields from token bridge state");const a=(u=(s=o.token_registry)==null?void 0:s.fields)==null?void 0:u.coin_types,d=(w=(f=a==null?void 0:a.fields)==null?void 0:f.id)==null?void 0:w.id;if(!d)throw new Error("Unable to fetch coin types");const r=Z(a==null?void 0:a.type);if(!r)throw new Error("Unable to get key type");const n=await m.getDynamicFieldObject({parentId:d,name:{type:r,value:{addr:[...e],chain:i}}});if(n.error){if(n.error.code==="dynamicFieldNotFound")return null;throw new Error(`Unexpected getDynamicFieldObject response ${n.error}`)}const l=N(n);if(!l)return null;if(!$(l))throw new Error("What?");return"value"in l?S(l.value):null};class z{constructor(t,e,i,o){h(this,"network");h(this,"chain");h(this,"provider");h(this,"contracts");h(this,"coreBridgeObjectId");h(this,"tokenBridgeObjectId");h(this,"chainId");this.network=t,this.chain=e,this.provider=i,this.contracts=o,this.chainId=ue.get(t,e);const a=this.contracts.tokenBridge;if(!a)throw new Error(`Wormhole Token Bridge contract for domain ${e} not found`);const d=this.contracts.coreBridge;if(!d)throw new Error(`Wormhole Token Bridge contract for domain ${e} not found`);this.tokenBridgeObjectId=a,this.coreBridgeObjectId=d}static async fromRpc(t,e){const[i,o]=await I.chainFromRpc(t),a=e[o];if(a.network!==i)throw new Error(`Network mismatch: ${a.network} != ${i}`);return new z(i,o,t,a.contracts)}async isWrappedAsset(t){try{return await this.getOriginalAsset(t),!0}catch{return!1}}async getOriginalAsset(t){let e=t.getCoinType();if(!W(e))throw new Error(`Invalid Sui type: ${e}`);const i=await Y(this.provider,this.tokenBridgeObjectId,e),o=N(i);if(!o)throw D(e);if(!$(o))throw new Error("Expected fields to be a MoveStruct");if(!("value"in o))throw new Error("Expected a `value` key in fields of MoveStruct");const a=o.value;if(!b(a))throw new Error("Expected fields to be a MoveStruct");const d=S(a.type);if(e=S(e),d.includes(`wrapped_asset::WrappedAsset<${e}>`)){const r=a.fields.info;if(!b(r))throw new Error("Expected fields to be a MoveStruct");const n=r.fields.token_address;if(!b(n))throw new Error("Expected fields to be a MoveStruct");if(!$(n.fields))throw new Error("Expected address data to be a MoveObject");if(!("value"in n.fields))throw new Error("Expected a `value` key in fields of MoveStruct");const l=n.fields.value;if(!b(l))throw new Error("Expected fields to be a MoveStruct");const s=new Uint8Array(l.fields.data);return{chain:fe(Number(r.fields.token_chain)),address:new q(s)}}throw D(e)}async getTokenUniversalAddress(t){let e=t.getCoinType();if(!W(e))throw new Error(`Invalid Sui type: ${e}`);const i=await Y(this.provider,this.tokenBridgeObjectId,e),o=N(i);if(!o)throw new Error(`Token of type ${e} has not been registered with the token bridge. Has it been attested?`);if(!$(o))throw new Error("Expected fields to be a MoveStruct");if(!("value"in o))throw new Error("Expected a `value` key in fields of MoveStruct");const a=o.value;if(!b(a))throw new Error("Expected fields to be a MoveStruct");const d=S(a.type);if(e=S(e),d.includes(`native_asset::NativeAsset<${e}>`)){const r=a.fields.token_address;if(!b(r))throw new Error("Expected fields to be a MoveStruct");if(!("value"in r.fields))throw new Error("Expected a `value` key in fields of MoveStruct");const n=r.fields.value;if(!b(n))throw new Error("Expected fields to be a MoveStruct");const l=new Uint8Array(n.fields.data);return new q(l)}throw new Error(`Token of type ${e} is not a native asset`)}async getTokenNativeAddress(t,e){const i=await P(this.provider,this.tokenBridgeObjectId,e.toUint8Array(),j(t));if(!i)throw new Error(`Token ${e.toString()} not found in token registry`);return new O(i)}async hasWrappedAsset(t){try{return await this.getWrappedAsset(t),!0}catch{}return!1}async getWrappedAsset(t){if(v(t.address))throw new Error("Token Address required, 'native' literal not supported");const e=await P(this.provider,this.tokenBridgeObjectId,t.address.toUniversalAddress().toUint8Array(),j(t.chain));if(!e)throw D(pe(t));return H(this.chain,e)}async isTransferCompleted(t){var r,n,l,s,u,f,w,y;const e=await F(this.provider,this.tokenBridgeObjectId);if(!e)throw new Error("Unable to fetch object fields from token bridge state");const i=(n=(r=e.consumed_vaas)==null?void 0:r.fields)==null?void 0:n.hashes,o=Z((s=(l=i==null?void 0:i.fields)==null?void 0:l.items)==null?void 0:s.type);if(!o)throw new Error("Unable to get key type");const a=(y=(w=(f=(u=i==null?void 0:i.fields)==null?void 0:u.items)==null?void 0:f.fields)==null?void 0:w.id)==null?void 0:y.id;if(!a)throw new Error("Unable to fetch consumed VAAs table");const d=await this.provider.getDynamicFieldObject({parentId:a,name:{type:o,value:{data:[...he(t.hash)]}}});if(!d.error)return!0;if(d.error.code==="dynamicFieldNotFound")return!1;throw new Error(`Unexpected getDynamicFieldObject response ${d.error}`)}async*createAttestation(t){const e=0n,o=t.toString(),a=await this.provider.getCoinMetadata({coinType:o});if(a===null||a.id===null)throw new Error(`Coin metadata ID for type ${o} not found`);const[d,r]=await this.getPackageIds(),n=new _,[l]=n.splitCoins(n.gas,[n.pure.u64(e)]),[s]=n.moveCall({target:`${r}::attest_token::attest_token`,arguments:[n.object(this.tokenBridgeObjectId),n.object(a.id),n.pure.u32(0)],typeArguments:[o]});n.moveCall({target:`${d}::publish_message::publish_message`,arguments:[n.object(this.coreBridgeObjectId),l,s,n.object(C)]}),yield this.createUnsignedTx(n,"Sui.TokenBridge.CreateAttestation")}async*submitAttestation(t,e){const[i,o]=await this.getPackageIds(),a=e.toString(),d=Math.min(t.payload.decimals,8),r=await this.getCoinBuildOutput(i,o,d),n=await ae(r,a);yield this.createUnsignedTx(n,"Sui.TokenBridge.PrepareCreateWrapped");let l="",s="",u="",f="",w="",y=!1;for(;!y;){await new Promise(p=>setTimeout(p,500));const B=await this.provider.queryTransactionBlocks({filter:{FromAddress:a},options:{showObjectChanges:!0},limit:3});for(const p of B.data)if("objectChanges"in p){for(const g of p.objectChanges)ie(g)&&g.packageId!==void 0?l=g.packageId:R(g)&&g.objectType.includes("WrappedAssetSetup")?(s=g.objectId,w=g.objectType.split(", ")[1].replace(">","")):R(g)&&g.objectType.includes("UpgradeCap")?u=g.objectId:R(g)&&g.objectType.includes("CoinMetadata")&&(f=g.objectId);if(l!==""&&s!==""&&u!==""&&f!==""){y=!0;break}else l="",s="",u="",f=""}}const k=we(l),c=new _,[A]=c.moveCall({target:`${i}::vaa::parse_and_verify`,arguments:[c.object(this.coreBridgeObjectId),c.pure.vector("u8",V(t)),c.object(C)]}),[E]=c.moveCall({target:`${o}::vaa::verify_only_once`,arguments:[c.object(this.tokenBridgeObjectId),A]});c.moveCall({target:`${o}::create_wrapped::complete_registration`,arguments:[c.object(this.tokenBridgeObjectId),c.object(f),c.object(s),c.object(u),E],typeArguments:[k,w]}),yield this.createUnsignedTx(c,"Sui.TokenBridge.SubmitAttestation")}async*transfer(t,e,i,o,a){const d=0n,r=0n,l=t.toString(),s=(v(i)?M:i).toString(),u=await I.getCoins(this.provider,t,s),[f,...w]=u.filter(p=>G(p.coinType,s));if(f===void 0)throw new Error(`Coins array doesn't contain any coins of type ${s}`);const[y,k]=await this.getPackageIds(),c=new _,[A]=(()=>{if(s===M)return c.splitCoins(c.gas,[c.pure.u64(o)]);{const p=c.object(f.coinObjectId);return w.length&&c.mergeCoins(p,w.map(g=>c.object(g.coinObjectId))),c.splitCoins(p,[c.pure.u64(o)])}})(),[E]=c.splitCoins(c.gas,[c.pure.u64(d)]),[B]=c.moveCall({target:`${k}::state::verified_asset`,arguments:[c.object(this.tokenBridgeObjectId)],typeArguments:[s]});if(a){if(!l)throw new Error("senderAddress is required for transfer with payload");let p=!1;const g=await(async()=>{const K=await ce(this.provider,y,l);if(K!==null)return c.object(K);{const[ne]=c.moveCall({target:`${y}::emitter::new`,arguments:[c.object(this.coreBridgeObjectId)]});return p=!0,ne}})(),[T,te]=c.moveCall({target:`${k}::transfer_tokens_with_payload::prepare_transfer`,arguments:[g,B,A,c.pure.u16(j(e.chain)),c.pure.vector("u8",e.address.toUint8Array()),c.pure.vector("u8",a),c.pure.u32(0)],typeArguments:[s]});c.moveCall({target:`${k}::coin_utils::return_nonzero`,arguments:[te],typeArguments:[s]});const[re]=c.moveCall({target:`${k}::transfer_tokens_with_payload::transfer_tokens_with_payload`,arguments:[c.object(this.tokenBridgeObjectId),T],typeArguments:[s]});c.moveCall({target:`${y}::publish_message::publish_message`,arguments:[c.object(this.coreBridgeObjectId),E,re,c.object(C)]}),p&&c.transferObjects([g],c.pure.address(l)),yield this.createUnsignedTx(c,"Sui.TokenBridge.TransferWithPayload")}else{const[p,g]=c.moveCall({target:`${k}::transfer_tokens::prepare_transfer`,arguments:[B,A,c.pure.u16(j(e.chain)),c.pure.vector("u8",e.address.toUint8Array()),c.pure.u64(r),c.pure.u32(0)],typeArguments:[s]});c.moveCall({target:`${k}::coin_utils::return_nonzero`,arguments:[g],typeArguments:[s]});const[T]=c.moveCall({target:`${k}::transfer_tokens::transfer_tokens`,arguments:[c.object(this.tokenBridgeObjectId),p],typeArguments:[s]});c.moveCall({target:`${y}::publish_message::publish_message`,arguments:[c.object(this.coreBridgeObjectId),E,T,c.object(C)]}),yield this.createUnsignedTx(c,"Sui.TokenBridge.Transfer")}}async*redeem(t,e,i=!0){const o=await P(this.provider,this.tokenBridgeObjectId,e.payload.token.address.toUint8Array(),j(e.payload.token.chain));if(!o)throw new Error("Unable to fetch token coinType");const[a,d]=await this.getPackageIds(),r=new _,[n]=r.moveCall({target:`${a}::vaa::parse_and_verify`,arguments:[r.object(this.coreBridgeObjectId),r.pure.vector("u8",V(e)),r.object(C)]}),[l]=r.moveCall({target:`${d}::vaa::verify_only_once`,arguments:[r.object(this.tokenBridgeObjectId),n]}),[s]=r.moveCall({target:`${d}::complete_transfer::authorize_transfer`,arguments:[r.object(this.tokenBridgeObjectId),l],typeArguments:[o]}),[u]=r.moveCall({target:`${d}::complete_transfer::redeem_relayer_payout`,arguments:[s],typeArguments:[o]});r.moveCall({target:`${d}::coin_utils::return_nonzero`,arguments:[u],typeArguments:[o]}),yield this.createUnsignedTx(r,"Sui.TokenBridge.Redeem")}async getWrappedNative(){return H(this.chain,M)}async getPackageIds(){return Promise.all([x(this.provider,this.coreBridgeObjectId),x(this.provider,this.tokenBridgeObjectId)])}async getCoinBuildOutput(t,e,i){var r;if(i>8)throw new Error("Decimals is capped at 8");const o=(r=await de(this.provider,this.tokenBridgeObjectId))==null?void 0:r.replace("0x","");if(!o)throw new Error(`Original token bridge package ID not found for object ID ${this.tokenBridgeObjectId}`);const a="a11ceb0b060000000901000a020a14031e1704350405392d07669f01088502600ae502050cea02160004010b010c0205020d000002000201020003030c020001000104020700000700010001090801010c020a050600030803040202000302010702080007080100020800080303090002070801010b020209000901010608010105010b0202080008030209000504434f494e095478436f6e7465787408565f5f305f325f3011577261707065644173736574536574757004636f696e0e6372656174655f777261707065640b64756d6d795f6669656c6404696e697414707265706172655f726567697374726174696f6e0f7075626c69635f7472616e736665720673656e646572087472616e736665720a74785f636f6e746578740f76657273696f6e5f636f6e74726f6c00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002"+o+"00020106010000000001090b0031"+i.toString(16).padStart(2,"0")+"0a0138000b012e110238010200";return{modules:[ye.encode(U.decode(a))],dependencies:["0x1","0x2",e,t].map(n=>me(n))}}createUnsignedTx(t,e,i=!1){return new ee(t,this.network,this.chain,e,i)}}class J{constructor(t,e,i,o){h(this,"network");h(this,"chain");h(this,"connection");h(this,"contracts");h(this,"tokenBridgeRelayerObjectId");h(this,"coreBridgeObjectId");h(this,"tokenBridgeObjectId");h(this,"fields");this.network=t,this.chain=e,this.connection=i,this.contracts=o;const{tokenBridge:a,tokenBridgeRelayer:d,coreBridge:r}=o;if(!a||!d||!r)throw new Error(`Some object IDs for ${e} Automatic Token Bridge not found`);this.tokenBridgeRelayerObjectId=d,this.tokenBridgeObjectId=a,this.coreBridgeObjectId=r}static async fromRpc(t,e){const[i,o]=await I.chainFromRpc(t),a=e[o];if(a.network!==i)throw new Error(`Network mismatch for chain ${o}: ${a.network} != ${i}`);return new J(i,o,t,a.contracts)}async*transfer(t,e,i,o,a){const r=new O(v(i)?I.nativeTokenId(this.network,this.chain).address:i).getCoinType(),{coreBridge:n,tokenBridge:l}=await this.getPackageIds(),s=new _,u=BigInt(0),[f]=s.splitCoins(s.gas,[s.pure.u64(u)]),[w]=await(async()=>{if(v(i))return s.splitCoins(s.gas,[s.pure.u64(o)]);{const E=await I.getCoins(this.connection,t,r),[B,...p]=E.filter(T=>T.coinType===r);if(B===void 0)throw new Error(`Coins array doesn't contain any coins of type ${r}`);const g=s.object(B.coinObjectId);return p.length&&s.mergeCoins(g,p.map(T=>s.object(T.coinObjectId))),s.splitCoins(g,[s.pure.u64(o)])}})(),[y]=s.moveCall({target:`${l}::state::verified_asset`,arguments:[s.object(this.tokenBridgeObjectId)],typeArguments:[r]}),k=await this.getPackageId(),[c]=s.moveCall({target:`${k}::transfer::transfer_tokens_with_relay`,arguments:[s.object(this.tokenBridgeRelayerObjectId),w,y,s.pure.u64(a??0n),s.pure.u16(j(e.chain)),s.pure.address(U.encode(e.address.toUint8Array(),!0)),s.pure.u32(123)],typeArguments:[r]}),[A]=s.moveCall({target:`${l}::transfer_tokens_with_payload::transfer_tokens_with_payload`,arguments:[s.object(this.tokenBridgeObjectId),c],typeArguments:[r]});s.moveCall({target:`${n}::publish_message::publish_message`,arguments:[s.object(this.coreBridgeObjectId),f,A,s.object(C)]}),yield this.createUnsignedTx(s,"AutomaticTokenBridge.transfer")}async*redeem(t,e){const{coreBridge:i,tokenBridge:o}=await this.getPackageIds(),{address:a,chain:d}=e.payload.token,r=await P(this.connection,this.tokenBridgeObjectId,a.toUniversalAddress().toUint8Array(),j(d));if(!r)throw new Error("Unable to fetch token coinType");const n=new _,[l]=n.moveCall({target:`${i}::vaa::parse_and_verify`,arguments:[n.object(this.coreBridgeObjectId),n.pure.vector("u8",V(e)),n.object(C)]}),[s]=n.moveCall({target:`${o}::vaa::verify_only_once`,arguments:[n.object(this.tokenBridgeObjectId),l]}),[u]=n.moveCall({target:`${o}::complete_transfer_with_payload::authorize_transfer`,arguments:[n.object(this.tokenBridgeObjectId),s],typeArguments:[r]}),f=await this.getPackageId();n.moveCall({target:`${f}::redeem::complete_transfer`,arguments:[n.object(this.tokenBridgeRelayerObjectId),u],typeArguments:[r]}),yield this.createUnsignedTx(n,"AutomaticTokenBridge.redeem")}async getRelayerFee(t,e){const i=v(e)?I.nativeTokenId(this.network,this.chain):e,o=await this.getTokenInfo(i.toString());if(o===null)throw new Error("Unsupported token for relay");const a=await this.getFields(),d=await this.connection.getDynamicFieldObject({parentId:this.tokenBridgeRelayerObjectId,name:{type:"vector<u8>",value:Array.from(ke.encode("relayer_fees"))}});if(!d.data||!d.data.content)throw d.error?new Error("Failed to get relayer fees: "+JSON.stringify(d.error)):new Error("Unable to compute relayer fee");const{content:r}=d.data;if(!b(r)||!le(r.fields.id))throw new Error("Unable to compute relayer fee");const n=await this.connection.getDynamicFieldObject({parentId:r.fields.id.id,name:{type:"u16",value:j(t)}});if(!n.data||!n.data.content)throw n.error?new Error("Failed to get relayer fees: "+JSON.stringify(d.error)):new Error("Unable to compute relayer fee");const{content:l}=n.data;if(!b(l))throw new Error("Unable to compute relayer fee");const s=await I.getDecimals(this.chain,this.connection,e.toString()),u=o.swap_rate,f=a.relayer_fee_precision,w=a.swap_rate_precision,y=l.fields.value;return 10n**BigInt(s)*BigInt(y)*BigInt(w)/(BigInt(u)*BigInt(f))}async maxSwapAmount(t){var n,l;const i=(v(t)?I.nativeTokenId(this.network,this.chain):t).toString(),o=await this.connection.getCoinMetadata({coinType:i});if(!o)throw new Error("metadata is null");const a=await this.getPackageId(),d=new _;d.moveCall({target:`${a}::redeem::calculate_max_swap_amount_in`,arguments:[d.object(this.tokenBridgeRelayerObjectId),d.pure.u8(o.decimals)],typeArguments:[i]});const r=await this.connection.devInspectTransactionBlock({transactionBlock:d,sender:U.encode(new Uint8Array(32))});if(!r.results||r.results.length==0||!((n=r.results[0])!=null&&n.returnValues)||((l=r.results[0])==null?void 0:l.returnValues.length)!==1)throw Error("swap rate not set");return L.decode(new Uint8Array(r.results[0].returnValues[0][0].toReversed()))}async nativeTokenAmount(t,e){var l,s;const o=(v(t)?I.nativeTokenId(this.network,this.chain):t).toString(),a=await this.connection.getCoinMetadata({coinType:o});if(!a)throw new Error("metadata is null");const d=await this.getPackageId(),r=new _;r.moveCall({target:`${d}::redeem::calculate_native_swap_amount_out`,arguments:[r.object(this.tokenBridgeRelayerObjectId),r.pure.u64(e),r.pure.u8(a.decimals)],typeArguments:[o]});const n=await this.connection.devInspectTransactionBlock({transactionBlock:r,sender:U.encode(new Uint8Array(32))});if(!n.results||n.results.length==0||!((l=n.results[0])!=null&&l.returnValues)||((s=n.results[0])==null?void 0:s.returnValues.length)!==1)throw Error("swap rate not set");return L.decode(new Uint8Array(n.results[0].returnValues[0][0].toReversed()))}async getRegisteredTokens(){const e=(await this.getFields()).registered_tokens.fields.id.id;return(await this.connection.getDynamicFields({parentId:e})).data.map(a=>{const{address:d,module:r,name:n}=be(a.objectType);return new O([d,r,n].join(Ie))})}async isRegisteredToken(t){const e=new O(v(t)?I.nativeTokenId(this.network,this.chain).address:t).unwrap();try{return await this.getTokenInfo(e)!==null}catch(i){console.error(i)}return!1}async getTokenInfo(t){var n;const e=await this.getFields(),o=new O(e.registered_tokens.type).getPackageId(),a=e.registered_tokens.fields.id.id,d=new O(t),r=G(Q,d.unwrap())?Q:d.getCoinType();try{const l=await this.connection.getDynamicFieldObject({parentId:a,name:{type:`${o}::registered_tokens::Key<${r}>`,value:{dummy_field:!1}}});if(l.error)throw new Error("Failed to get token info: "+JSON.stringify(l.error));if(!l.data||!l.data.content)throw new Error("Failed to get token info: "+JSON.stringify(l));const{content:s}=l.data;return b(s)&&b(s.fields.value)?s.fields.value.fields:null}catch(l){if((l==null?void 0:l.code)===-32e3&&((n=l.message)!=null&&n.includes("RPC Error")))return console.error(l),null;throw l}}async getFields(){if(!this.fields){const t=await F(this.connection,this.tokenBridgeRelayerObjectId);if(t===null)throw new Error("Failed to get fields from token bridge relayer state");this.fields=t}return this.fields}async getPackageId(){const t=await this.getFields();return new O(t.registered_tokens.type).getPackageId()}async getPackageIds(){const[t,e]=await Promise.all([x(this.connection,this.coreBridgeObjectId),x(this.connection,this.tokenBridgeObjectId)]);return{coreBridge:t,tokenBridge:e}}createUnsignedTx(t,e,i=!1){return new ee(t,this.network,this.chain,e,i)}}X("Sui","TokenBridge",z);X("Sui","AutomaticTokenBridge",J);export{J as SuiAutomaticTokenBridge,z as SuiTokenBridge,P as getTokenCoinType,Y as getTokenFromTokenRegistry};
|
|
1
|
+
var oe=Object.defineProperty;var se=(m,t,e)=>t in m?oe(m,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):m[t]=e;var h=(m,t,e)=>se(m,typeof t!="symbol"?t+"":t,e);import{g as F,a as N,i as $,S as I,b,T as _,c as C,p as ae,d as ie,e as R,f as M,h as L,j as ce,k as x,l as de,m as le}from"./sui-DZhbOaP_.js";import{d0 as V,aZ as ge,d1 as Z,d2 as S,bK as ue,c9 as D,ca as q,bP as fe,bI as j,a$ as O,an as v,bM as pe,cf as G,cc as he,d3 as we,bQ as W,aY as ye,af as U,aQ as me,cT as ke,cG as H,d4 as be,d5 as Ie,a_ as Q,bV as X}from"../main.js";import"./index-BVlgnsQb.js";import{S as ee}from"./unsignedTransaction-arVvzoJx.js";import"./blake2b-C_UGgjrB.js";import"./index-WlpSU6Q6.js";const Y=async(m,t,e)=>{var d,r,n;if(!V(e))throw new Error(`Invalid Sui type: ${e}`);const i=await F(m,t);if(!i)throw new Error(`Unable to fetch object fields from token bridge state. Object ID: ${t}`);const o=(r=(d=i.token_registry.fields)==null?void 0:d.id)==null?void 0:r.id;if(!o)throw new Error("Unable to fetch token registry object ID");const a=ge((n=i.token_registry)==null?void 0:n.type);if(!a)throw new Error("Unable to fetch token registry package ID");return m.getDynamicFieldObject({parentId:o,name:{type:`${a}::token_registry::Key<${e}>`,value:{dummy_field:!1}}})},P=async(m,t,e,i)=>{var s,u,f,w;const o=await F(m,t);if(!o)throw new Error("Unable to fetch object fields from token bridge state");const a=(u=(s=o.token_registry)==null?void 0:s.fields)==null?void 0:u.coin_types,d=(w=(f=a==null?void 0:a.fields)==null?void 0:f.id)==null?void 0:w.id;if(!d)throw new Error("Unable to fetch coin types");const r=Z(a==null?void 0:a.type);if(!r)throw new Error("Unable to get key type");const n=await m.getDynamicFieldObject({parentId:d,name:{type:r,value:{addr:[...e],chain:i}}});if(n.error){if(n.error.code==="dynamicFieldNotFound")return null;throw new Error(`Unexpected getDynamicFieldObject response ${n.error}`)}const l=N(n);if(!l)return null;if(!$(l))throw new Error("What?");return"value"in l?S(l.value):null};class z{constructor(t,e,i,o){h(this,"network");h(this,"chain");h(this,"provider");h(this,"contracts");h(this,"coreBridgeObjectId");h(this,"tokenBridgeObjectId");h(this,"chainId");this.network=t,this.chain=e,this.provider=i,this.contracts=o,this.chainId=ue.get(t,e);const a=this.contracts.tokenBridge;if(!a)throw new Error(`Wormhole Token Bridge contract for domain ${e} not found`);const d=this.contracts.coreBridge;if(!d)throw new Error(`Wormhole Token Bridge contract for domain ${e} not found`);this.tokenBridgeObjectId=a,this.coreBridgeObjectId=d}static async fromRpc(t,e){const[i,o]=await I.chainFromRpc(t),a=e[o];if(a.network!==i)throw new Error(`Network mismatch: ${a.network} != ${i}`);return new z(i,o,t,a.contracts)}async isWrappedAsset(t){try{return await this.getOriginalAsset(t),!0}catch{return!1}}async getOriginalAsset(t){let e=t.getCoinType();if(!V(e))throw new Error(`Invalid Sui type: ${e}`);const i=await Y(this.provider,this.tokenBridgeObjectId,e),o=N(i);if(!o)throw D(e);if(!$(o))throw new Error("Expected fields to be a MoveStruct");if(!("value"in o))throw new Error("Expected a `value` key in fields of MoveStruct");const a=o.value;if(!b(a))throw new Error("Expected fields to be a MoveStruct");const d=S(a.type);if(e=S(e),d.includes(`wrapped_asset::WrappedAsset<${e}>`)){const r=a.fields.info;if(!b(r))throw new Error("Expected fields to be a MoveStruct");const n=r.fields.token_address;if(!b(n))throw new Error("Expected fields to be a MoveStruct");if(!$(n.fields))throw new Error("Expected address data to be a MoveObject");if(!("value"in n.fields))throw new Error("Expected a `value` key in fields of MoveStruct");const l=n.fields.value;if(!b(l))throw new Error("Expected fields to be a MoveStruct");const s=new Uint8Array(l.fields.data);return{chain:fe(Number(r.fields.token_chain)),address:new q(s)}}throw D(e)}async getTokenUniversalAddress(t){let e=t.getCoinType();if(!V(e))throw new Error(`Invalid Sui type: ${e}`);const i=await Y(this.provider,this.tokenBridgeObjectId,e),o=N(i);if(!o)throw new Error(`Token of type ${e} has not been registered with the token bridge. Has it been attested?`);if(!$(o))throw new Error("Expected fields to be a MoveStruct");if(!("value"in o))throw new Error("Expected a `value` key in fields of MoveStruct");const a=o.value;if(!b(a))throw new Error("Expected fields to be a MoveStruct");const d=S(a.type);if(e=S(e),d.includes(`native_asset::NativeAsset<${e}>`)){const r=a.fields.token_address;if(!b(r))throw new Error("Expected fields to be a MoveStruct");if(!("value"in r.fields))throw new Error("Expected a `value` key in fields of MoveStruct");const n=r.fields.value;if(!b(n))throw new Error("Expected fields to be a MoveStruct");const l=new Uint8Array(n.fields.data);return new q(l)}throw new Error(`Token of type ${e} is not a native asset`)}async getTokenNativeAddress(t,e){const i=await P(this.provider,this.tokenBridgeObjectId,e.toUint8Array(),j(t));if(!i)throw new Error(`Token ${e.toString()} not found in token registry`);return new O(i)}async hasWrappedAsset(t){try{return await this.getWrappedAsset(t),!0}catch{}return!1}async getWrappedAsset(t){if(v(t.address))throw new Error("Token Address required, 'native' literal not supported");const e=await P(this.provider,this.tokenBridgeObjectId,t.address.toUniversalAddress().toUint8Array(),j(t.chain));if(!e)throw D(pe(t));return G(this.chain,e)}async isTransferCompleted(t){var r,n,l,s,u,f,w,y;const e=await F(this.provider,this.tokenBridgeObjectId);if(!e)throw new Error("Unable to fetch object fields from token bridge state");const i=(n=(r=e.consumed_vaas)==null?void 0:r.fields)==null?void 0:n.hashes,o=Z((s=(l=i==null?void 0:i.fields)==null?void 0:l.items)==null?void 0:s.type);if(!o)throw new Error("Unable to get key type");const a=(y=(w=(f=(u=i==null?void 0:i.fields)==null?void 0:u.items)==null?void 0:f.fields)==null?void 0:w.id)==null?void 0:y.id;if(!a)throw new Error("Unable to fetch consumed VAAs table");const d=await this.provider.getDynamicFieldObject({parentId:a,name:{type:o,value:{data:[...he(t.hash)]}}});if(!d.error)return!0;if(d.error.code==="dynamicFieldNotFound")return!1;throw new Error(`Unexpected getDynamicFieldObject response ${d.error}`)}async*createAttestation(t){const e=0n,o=t.toString(),a=await this.provider.getCoinMetadata({coinType:o});if(a===null||a.id===null)throw new Error(`Coin metadata ID for type ${o} not found`);const[d,r]=await this.getPackageIds(),n=new _,[l]=n.splitCoins(n.gas,[n.pure.u64(e)]),[s]=n.moveCall({target:`${r}::attest_token::attest_token`,arguments:[n.object(this.tokenBridgeObjectId),n.object(a.id),n.pure.u32(0)],typeArguments:[o]});n.moveCall({target:`${d}::publish_message::publish_message`,arguments:[n.object(this.coreBridgeObjectId),l,s,n.object(C)]}),yield this.createUnsignedTx(n,"Sui.TokenBridge.CreateAttestation")}async*submitAttestation(t,e){const[i,o]=await this.getPackageIds(),a=e.toString(),d=Math.min(t.payload.decimals,8),r=await this.getCoinBuildOutput(i,o,d),n=await ae(r,a);yield this.createUnsignedTx(n,"Sui.TokenBridge.PrepareCreateWrapped");let l="",s="",u="",f="",w="",y=!1;for(;!y;){await new Promise(p=>setTimeout(p,500));const B=await this.provider.queryTransactionBlocks({filter:{FromAddress:a},options:{showObjectChanges:!0},limit:3});for(const p of B.data)if("objectChanges"in p){for(const g of p.objectChanges)ie(g)&&g.packageId!==void 0?l=g.packageId:R(g)&&g.objectType.includes("WrappedAssetSetup")?(s=g.objectId,w=g.objectType.split(", ")[1].replace(">","")):R(g)&&g.objectType.includes("UpgradeCap")?u=g.objectId:R(g)&&g.objectType.includes("CoinMetadata")&&(f=g.objectId);if(l!==""&&s!==""&&u!==""&&f!==""){y=!0;break}else l="",s="",u="",f=""}}const k=we(l),c=new _,[A]=c.moveCall({target:`${i}::vaa::parse_and_verify`,arguments:[c.object(this.coreBridgeObjectId),c.pure.vector("u8",W(t)),c.object(C)]}),[E]=c.moveCall({target:`${o}::vaa::verify_only_once`,arguments:[c.object(this.tokenBridgeObjectId),A]});c.moveCall({target:`${o}::create_wrapped::complete_registration`,arguments:[c.object(this.tokenBridgeObjectId),c.object(f),c.object(s),c.object(u),E],typeArguments:[k,w]}),yield this.createUnsignedTx(c,"Sui.TokenBridge.SubmitAttestation")}async*transfer(t,e,i,o,a){const d=0n,r=0n,l=t.toString(),s=(v(i)?M:i).toString(),u=await I.getCoins(this.provider,t,s),[f,...w]=u.filter(p=>L(p.coinType,s));if(f===void 0)throw new Error(`Coins array doesn't contain any coins of type ${s}`);const[y,k]=await this.getPackageIds(),c=new _,[A]=(()=>{if(s===M)return c.splitCoins(c.gas,[c.pure.u64(o)]);{const p=c.object(f.coinObjectId);return w.length&&c.mergeCoins(p,w.map(g=>c.object(g.coinObjectId))),c.splitCoins(p,[c.pure.u64(o)])}})(),[E]=c.splitCoins(c.gas,[c.pure.u64(d)]),[B]=c.moveCall({target:`${k}::state::verified_asset`,arguments:[c.object(this.tokenBridgeObjectId)],typeArguments:[s]});if(a){if(!l)throw new Error("senderAddress is required for transfer with payload");let p=!1;const g=await(async()=>{const K=await ce(this.provider,y,l);if(K!==null)return c.object(K);{const[ne]=c.moveCall({target:`${y}::emitter::new`,arguments:[c.object(this.coreBridgeObjectId)]});return p=!0,ne}})(),[T,te]=c.moveCall({target:`${k}::transfer_tokens_with_payload::prepare_transfer`,arguments:[g,B,A,c.pure.u16(j(e.chain)),c.pure.vector("u8",e.address.toUint8Array()),c.pure.vector("u8",a),c.pure.u32(0)],typeArguments:[s]});c.moveCall({target:`${k}::coin_utils::return_nonzero`,arguments:[te],typeArguments:[s]});const[re]=c.moveCall({target:`${k}::transfer_tokens_with_payload::transfer_tokens_with_payload`,arguments:[c.object(this.tokenBridgeObjectId),T],typeArguments:[s]});c.moveCall({target:`${y}::publish_message::publish_message`,arguments:[c.object(this.coreBridgeObjectId),E,re,c.object(C)]}),p&&c.transferObjects([g],c.pure.address(l)),yield this.createUnsignedTx(c,"Sui.TokenBridge.TransferWithPayload")}else{const[p,g]=c.moveCall({target:`${k}::transfer_tokens::prepare_transfer`,arguments:[B,A,c.pure.u16(j(e.chain)),c.pure.vector("u8",e.address.toUint8Array()),c.pure.u64(r),c.pure.u32(0)],typeArguments:[s]});c.moveCall({target:`${k}::coin_utils::return_nonzero`,arguments:[g],typeArguments:[s]});const[T]=c.moveCall({target:`${k}::transfer_tokens::transfer_tokens`,arguments:[c.object(this.tokenBridgeObjectId),p],typeArguments:[s]});c.moveCall({target:`${y}::publish_message::publish_message`,arguments:[c.object(this.coreBridgeObjectId),E,T,c.object(C)]}),yield this.createUnsignedTx(c,"Sui.TokenBridge.Transfer")}}async*redeem(t,e,i=!0){const o=await P(this.provider,this.tokenBridgeObjectId,e.payload.token.address.toUint8Array(),j(e.payload.token.chain));if(!o)throw new Error("Unable to fetch token coinType");const[a,d]=await this.getPackageIds(),r=new _,[n]=r.moveCall({target:`${a}::vaa::parse_and_verify`,arguments:[r.object(this.coreBridgeObjectId),r.pure.vector("u8",W(e)),r.object(C)]}),[l]=r.moveCall({target:`${d}::vaa::verify_only_once`,arguments:[r.object(this.tokenBridgeObjectId),n]}),[s]=r.moveCall({target:`${d}::complete_transfer::authorize_transfer`,arguments:[r.object(this.tokenBridgeObjectId),l],typeArguments:[o]}),[u]=r.moveCall({target:`${d}::complete_transfer::redeem_relayer_payout`,arguments:[s],typeArguments:[o]});r.moveCall({target:`${d}::coin_utils::return_nonzero`,arguments:[u],typeArguments:[o]}),yield this.createUnsignedTx(r,"Sui.TokenBridge.Redeem")}async getWrappedNative(){return G(this.chain,M)}async getPackageIds(){return Promise.all([x(this.provider,this.coreBridgeObjectId),x(this.provider,this.tokenBridgeObjectId)])}async getCoinBuildOutput(t,e,i){var r;if(i>8)throw new Error("Decimals is capped at 8");const o=(r=await de(this.provider,this.tokenBridgeObjectId))==null?void 0:r.replace("0x","");if(!o)throw new Error(`Original token bridge package ID not found for object ID ${this.tokenBridgeObjectId}`);const a="a11ceb0b060000000901000a020a14031e1704350405392d07669f01088502600ae502050cea02160004010b010c0205020d000002000201020003030c020001000104020700000700010001090801010c020a050600030803040202000302010702080007080100020800080303090002070801010b020209000901010608010105010b0202080008030209000504434f494e095478436f6e7465787408565f5f305f325f3011577261707065644173736574536574757004636f696e0e6372656174655f777261707065640b64756d6d795f6669656c6404696e697414707265706172655f726567697374726174696f6e0f7075626c69635f7472616e736665720673656e646572087472616e736665720a74785f636f6e746578740f76657273696f6e5f636f6e74726f6c00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002"+o+"00020106010000000001090b0031"+i.toString(16).padStart(2,"0")+"0a0138000b012e110238010200";return{modules:[ye.encode(U.decode(a))],dependencies:["0x1","0x2",e,t].map(n=>me(n))}}createUnsignedTx(t,e,i=!1){return new ee(t,this.network,this.chain,e,i)}}class J{constructor(t,e,i,o){h(this,"network");h(this,"chain");h(this,"connection");h(this,"contracts");h(this,"tokenBridgeRelayerObjectId");h(this,"coreBridgeObjectId");h(this,"tokenBridgeObjectId");h(this,"fields");this.network=t,this.chain=e,this.connection=i,this.contracts=o;const{tokenBridge:a,tokenBridgeRelayer:d,coreBridge:r}=o;if(!a||!d||!r)throw new Error(`Some object IDs for ${e} Automatic Token Bridge not found`);this.tokenBridgeRelayerObjectId=d,this.tokenBridgeObjectId=a,this.coreBridgeObjectId=r}static async fromRpc(t,e){const[i,o]=await I.chainFromRpc(t),a=e[o];if(a.network!==i)throw new Error(`Network mismatch for chain ${o}: ${a.network} != ${i}`);return new J(i,o,t,a.contracts)}async*transfer(t,e,i,o,a){const r=new O(v(i)?I.nativeTokenId(this.network,this.chain).address:i).getCoinType(),{coreBridge:n,tokenBridge:l}=await this.getPackageIds(),s=new _,u=BigInt(0),[f]=s.splitCoins(s.gas,[s.pure.u64(u)]),[w]=await(async()=>{if(v(i))return s.splitCoins(s.gas,[s.pure.u64(o)]);{const E=await I.getCoins(this.connection,t,r),[B,...p]=E.filter(T=>T.coinType===r);if(B===void 0)throw new Error(`Coins array doesn't contain any coins of type ${r}`);const g=s.object(B.coinObjectId);return p.length&&s.mergeCoins(g,p.map(T=>s.object(T.coinObjectId))),s.splitCoins(g,[s.pure.u64(o)])}})(),[y]=s.moveCall({target:`${l}::state::verified_asset`,arguments:[s.object(this.tokenBridgeObjectId)],typeArguments:[r]}),k=await this.getPackageId(),[c]=s.moveCall({target:`${k}::transfer::transfer_tokens_with_relay`,arguments:[s.object(this.tokenBridgeRelayerObjectId),w,y,s.pure.u64(a??0n),s.pure.u16(j(e.chain)),s.pure.address(U.encode(e.address.toUint8Array(),!0)),s.pure.u32(123)],typeArguments:[r]}),[A]=s.moveCall({target:`${l}::transfer_tokens_with_payload::transfer_tokens_with_payload`,arguments:[s.object(this.tokenBridgeObjectId),c],typeArguments:[r]});s.moveCall({target:`${n}::publish_message::publish_message`,arguments:[s.object(this.coreBridgeObjectId),f,A,s.object(C)]}),yield this.createUnsignedTx(s,"AutomaticTokenBridge.transfer")}async*redeem(t,e){const{coreBridge:i,tokenBridge:o}=await this.getPackageIds(),{address:a,chain:d}=e.payload.token,r=await P(this.connection,this.tokenBridgeObjectId,a.toUniversalAddress().toUint8Array(),j(d));if(!r)throw new Error("Unable to fetch token coinType");const n=new _,[l]=n.moveCall({target:`${i}::vaa::parse_and_verify`,arguments:[n.object(this.coreBridgeObjectId),n.pure.vector("u8",W(e)),n.object(C)]}),[s]=n.moveCall({target:`${o}::vaa::verify_only_once`,arguments:[n.object(this.tokenBridgeObjectId),l]}),[u]=n.moveCall({target:`${o}::complete_transfer_with_payload::authorize_transfer`,arguments:[n.object(this.tokenBridgeObjectId),s],typeArguments:[r]}),f=await this.getPackageId();n.moveCall({target:`${f}::redeem::complete_transfer`,arguments:[n.object(this.tokenBridgeRelayerObjectId),u],typeArguments:[r]}),yield this.createUnsignedTx(n,"AutomaticTokenBridge.redeem")}async getRelayerFee(t,e){const i=v(e)?I.nativeTokenId(this.network,this.chain):e,o=await this.getTokenInfo(i.toString());if(o===null)throw new Error("Unsupported token for relay");const a=await this.getFields(),d=await this.connection.getDynamicFieldObject({parentId:this.tokenBridgeRelayerObjectId,name:{type:"vector<u8>",value:Array.from(ke.encode("relayer_fees"))}});if(!d.data||!d.data.content)throw d.error?new Error("Failed to get relayer fees: "+JSON.stringify(d.error)):new Error("Unable to compute relayer fee");const{content:r}=d.data;if(!b(r)||!le(r.fields.id))throw new Error("Unable to compute relayer fee");const n=await this.connection.getDynamicFieldObject({parentId:r.fields.id.id,name:{type:"u16",value:j(t)}});if(!n.data||!n.data.content)throw n.error?new Error("Failed to get relayer fees: "+JSON.stringify(d.error)):new Error("Unable to compute relayer fee");const{content:l}=n.data;if(!b(l))throw new Error("Unable to compute relayer fee");const s=await I.getDecimals(this.chain,this.connection,e.toString()),u=o.swap_rate,f=a.relayer_fee_precision,w=a.swap_rate_precision,y=l.fields.value;return 10n**BigInt(s)*BigInt(y)*BigInt(w)/(BigInt(u)*BigInt(f))}async maxSwapAmount(t){var n,l;const i=(v(t)?I.nativeTokenId(this.network,this.chain):t).toString(),o=await this.connection.getCoinMetadata({coinType:i});if(!o)throw new Error("metadata is null");const a=await this.getPackageId(),d=new _;d.moveCall({target:`${a}::redeem::calculate_max_swap_amount_in`,arguments:[d.object(this.tokenBridgeRelayerObjectId),d.pure.u8(o.decimals)],typeArguments:[i]});const r=await this.connection.devInspectTransactionBlock({transactionBlock:d,sender:U.encode(new Uint8Array(32))});if(!r.results||r.results.length==0||!((n=r.results[0])!=null&&n.returnValues)||((l=r.results[0])==null?void 0:l.returnValues.length)!==1)throw Error("swap rate not set");return H.decode(new Uint8Array(r.results[0].returnValues[0][0].toReversed()))}async nativeTokenAmount(t,e){var l,s;const o=(v(t)?I.nativeTokenId(this.network,this.chain):t).toString(),a=await this.connection.getCoinMetadata({coinType:o});if(!a)throw new Error("metadata is null");const d=await this.getPackageId(),r=new _;r.moveCall({target:`${d}::redeem::calculate_native_swap_amount_out`,arguments:[r.object(this.tokenBridgeRelayerObjectId),r.pure.u64(e),r.pure.u8(a.decimals)],typeArguments:[o]});const n=await this.connection.devInspectTransactionBlock({transactionBlock:r,sender:U.encode(new Uint8Array(32))});if(!n.results||n.results.length==0||!((l=n.results[0])!=null&&l.returnValues)||((s=n.results[0])==null?void 0:s.returnValues.length)!==1)throw Error("swap rate not set");return H.decode(new Uint8Array(n.results[0].returnValues[0][0].toReversed()))}async getRegisteredTokens(){const e=(await this.getFields()).registered_tokens.fields.id.id;return(await this.connection.getDynamicFields({parentId:e})).data.map(a=>{const{address:d,module:r,name:n}=be(a.objectType);return new O([d,r,n].join(Ie))})}async isRegisteredToken(t){const e=new O(v(t)?I.nativeTokenId(this.network,this.chain).address:t).unwrap();try{return await this.getTokenInfo(e)!==null}catch(i){console.error(i)}return!1}async getTokenInfo(t){var n;const e=await this.getFields(),o=new O(e.registered_tokens.type).getPackageId(),a=e.registered_tokens.fields.id.id,d=new O(t),r=L(Q,d.unwrap())?Q:d.getCoinType();try{const l=await this.connection.getDynamicFieldObject({parentId:a,name:{type:`${o}::registered_tokens::Key<${r}>`,value:{dummy_field:!1}}});if(l.error)throw new Error("Failed to get token info: "+JSON.stringify(l.error));if(!l.data||!l.data.content)throw new Error("Failed to get token info: "+JSON.stringify(l));const{content:s}=l.data;return b(s)&&b(s.fields.value)?s.fields.value.fields:null}catch(l){if((l==null?void 0:l.code)===-32e3&&((n=l.message)!=null&&n.includes("RPC Error")))return console.error(l),null;throw l}}async getFields(){if(!this.fields){const t=await F(this.connection,this.tokenBridgeRelayerObjectId);if(t===null)throw new Error("Failed to get fields from token bridge relayer state");this.fields=t}return this.fields}async getPackageId(){const t=await this.getFields();return new O(t.registered_tokens.type).getPackageId()}async getPackageIds(){const[t,e]=await Promise.all([x(this.connection,this.coreBridgeObjectId),x(this.connection,this.tokenBridgeObjectId)]);return{coreBridge:t,tokenBridge:e}}createUnsignedTx(t,e,i=!1){return new ee(t,this.network,this.chain,e,i)}}X("Sui","TokenBridge",z);X("Sui","AutomaticTokenBridge",J);export{J as SuiAutomaticTokenBridge,z as SuiTokenBridge,P as getTokenCoinType,Y as getTokenFromTokenRegistry};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var H=Object.defineProperty;var Z=(i,t,e)=>t in i?H(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e;var d=(i,t,e)=>Z(i,typeof t!="symbol"?t+"":t,e);import{P as s,i as c,bJ as h,bf as J,bg as E,bh as W,bi as Q,bj as X,bk as Y,ci as $,cj as ee,ck as te,a6 as ie,a7 as K,co as ne,cp as se,cq as ae,cr as re,cs as oe,bv as x,ct as ce,cu as v,cv as de,cw as N,V as G,cx as ue,cy as ge,cz as me,cn as fe,bW as le,a8 as he}from"../main.js";import{deriveWrappedMetaKey as O,deriveTokenBridgeConfigKey as R,deriveAuthoritySignerKey as pe,deriveSenderAccountKey as ye,deriveMintAuthorityKey as we,deriveEndpointKey as ke}from"./index-D1RqQWR4.js";const Se={version:"0.1.0",name:"wormhole_gateway",instructions:[{name:"initialize",accounts:[{name:"authority",isMut:!0,isSigner:!0},{name:"custodian",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!1,isSigner:!1,docs:["TBTC Program's mint PDA address bump is saved in this program's config. Ordinarily, we would","not have to deserialize this account. But we do in this case to make sure the TBTC program","has been initialized before this program."]},{name:"wrappedTbtcMint",isMut:!1,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1},{name:"tokenBridgeSender",isMut:!1,isSigner:!1,docs:["sign for transferring via Token Bridge program with a message."]},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1}],args:[{name:"mintingLimit",type:"u64"}]},{name:"changeAuthority",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0},{name:"newAuthority",isMut:!1,isSigner:!1}],args:[]},{name:"cancelAuthorityChange",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0}],args:[]},{name:"takeAuthority",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"pendingAuthority",isMut:!1,isSigner:!0}],args:[]},{name:"updateGatewayAddress",accounts:[{name:"custodian",isMut:!1,isSigner:!1},{name:"gatewayInfo",isMut:!0,isSigner:!1},{name:"authority",isMut:!0,isSigner:!0},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"UpdateGatewayAddressArgs"}}]},{name:"updateMintingLimit",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0}],args:[{name:"newLimit",type:"u64"}]},{name:"receiveTbtc",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"custodian",isMut:!0,isSigner:!1},{name:"postedVaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["transfer. By checking whether this account exists is a short-circuit way of bailing out","early if this transfer has already been redeemed (as opposed to letting the Token Bridge","instruction fail)."]},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1,docs:["This mint is owned by the Wormhole Token Bridge program. This PDA address is stored in the","custodian account."]},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"recipientToken",isMut:!0,isSigner:!1,docs:["Token account for minted tBTC.","","NOTE: Because the recipient is encoded in the transfer message payload, we can check the","authority from the deserialized VAA. But we should still check whether the authority is the","zero address in access control."]},{name:"recipient",isMut:!1,isSigner:!1,docs:["be created for him."]},{name:"recipientWrappedToken",isMut:!0,isSigner:!1,docs:["The gateway will create an associated token account for the recipient if it doesn't exist.","","NOTE: When the minting limit increases, the recipient can use this token account to mint","tBTC using the deposit_wormhole_tbtc instruction."]},{name:"tbtcConfig",isMut:!1,isSigner:!1},{name:"tbtcMinterInfo",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeRegisteredEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"tbtcProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"messageHash",type:{array:["u8",32]}}]},{name:"sendTbtcGateway",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"gatewayInfo",isMut:!1,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"senderToken",isMut:!0,isSigner:!1},{name:"sender",isMut:!0,isSigner:!0},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeTransferAuthority",isMut:!1,isSigner:!1},{name:"coreBridgeData",isMut:!0,isSigner:!1},{name:"coreMessage",isMut:!0,isSigner:!1},{name:"tokenBridgeCoreEmitter",isMut:!1,isSigner:!1},{name:"coreEmitterSequence",isMut:!0,isSigner:!1},{name:"coreFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"tokenBridgeSender",isMut:!1,isSigner:!1,docs:["sign for transferring via Token Bridge program with a message."]},{name:"rent",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"SendTbtcGatewayArgs"}}]},{name:"sendTbtcWrapped",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"senderToken",isMut:!0,isSigner:!1},{name:"sender",isMut:!0,isSigner:!0},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeTransferAuthority",isMut:!1,isSigner:!1},{name:"coreBridgeData",isMut:!0,isSigner:!1},{name:"coreMessage",isMut:!0,isSigner:!1},{name:"tokenBridgeCoreEmitter",isMut:!1,isSigner:!1},{name:"coreEmitterSequence",isMut:!0,isSigner:!1},{name:"coreFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"SendTbtcWrappedArgs"}}]},{name:"depositWormholeTbtc",accounts:[{name:"custodian",isMut:!0,isSigner:!1,docs:["NOTE: This account also acts as a minter for the TBTC program."]},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["This token account is owned by this program, whose mint is the wrapped TBTC mint. This PDA","address is stored in the custodian account."]},{name:"wrappedTbtcMint",isMut:!1,isSigner:!1,docs:["This mint is owned by the Wormhole Token Bridge program. This PDA address is stored in the","custodian account."]},{name:"tbtcMint",isMut:!0,isSigner:!1,docs:["This mint is owned by the TBTC program. This PDA address is stored in the custodian account."]},{name:"recipientWrappedToken",isMut:!0,isSigner:!1},{name:"recipientToken",isMut:!0,isSigner:!1},{name:"recipient",isMut:!1,isSigner:!0,docs:["This program requires that the owner of the TBTC token account sign for TBTC being minted","into his account."]},{name:"tbtcConfig",isMut:!1,isSigner:!1},{name:"tbtcMinterInfo",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"tbtcProgram",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"}]}],accounts:[{name:"custodian",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"authority",type:"publicKey"},{name:"pendingAuthority",type:{option:"publicKey"}},{name:"tbtcMint",type:"publicKey"},{name:"wrappedTbtcMint",type:"publicKey"},{name:"wrappedTbtcToken",type:"publicKey"},{name:"tokenBridgeSender",type:"publicKey"},{name:"tokenBridgeSenderBump",type:"u8"},{name:"mintingLimit",type:"u64"},{name:"mintedAmount",type:"u64"}]}},{name:"GatewayInfo",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"address",type:{array:["u8",32]}}]}}],types:[{name:"UpdateGatewayAddressArgs",type:{kind:"struct",fields:[{name:"chain",type:"u16"},{name:"address",type:{array:["u8",32]}}]}},{name:"SendTbtcGatewayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipient",type:{array:["u8",32]}},{name:"nonce",type:"u32"}]}},{name:"SendTbtcWrappedArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipient",type:{array:["u8",32]}},{name:"arbiterFee",type:"u64"},{name:"nonce",type:"u32"}]}}],events:[{name:"WormholeTbtcReceived",fields:[{name:"receiver",type:"publicKey",index:!1},{name:"amount",type:"u64",index:!1}]},{name:"WormholeTbtcSent",fields:[{name:"amount",type:"u64",index:!1},{name:"recipientChain",type:"u16",index:!1},{name:"gateway",type:{array:["u8",32]},index:!1},{name:"recipient",type:{array:["u8",32]},index:!1},{name:"arbiterFee",type:"u64",index:!1},{name:"nonce",type:"u32",index:!1}]},{name:"WormholeTbtcDeposited",fields:[{name:"depositor",type:"publicKey",index:!1},{name:"amount",type:"u64",index:!1}]},{name:"GatewayAddressUpdated",fields:[{name:"chain",type:"u16",index:!1},{name:"gateway",type:{array:["u8",32]},index:!1}]},{name:"MintingLimitUpdated",fields:[{name:"mintingLimit",type:"u64",index:!1}]}],errors:[{code:6016,name:"MintingLimitExceeded",msg:"Cannot mint more than the minting limit"},{code:6032,name:"IsNotAuthority",msg:"Only custodian authority is permitted for this action"},{code:6034,name:"IsNotPendingAuthority",msg:"Not valid pending authority to take authority"},{code:6036,name:"NoPendingAuthorityChange",msg:"No pending authority"},{code:6048,name:"ZeroRecipient",msg:"0x0 recipient not allowed"},{code:6064,name:"NotEnoughWrappedTbtc",msg:"Not enough wormhole tBTC in the gateway to bridge"},{code:6080,name:"ZeroAmount",msg:"Amount must not be 0"},{code:6112,name:"TransferAlreadyRedeemed",msg:"Token Bridge transfer already redeemed"},{code:6128,name:"InvalidEthereumTbtc",msg:"Token chain and address do not match Ethereum's tBTC"},{code:6144,name:"NoTbtcTransferred",msg:"No tBTC transferred"},{code:6160,name:"RecipientZeroAddress",msg:"0x0 receiver not allowed"},{code:6176,name:"MintedAmountUnderflow",msg:"Not enough minted by the gateway to satisfy sending tBTC"},{code:6178,name:"MintedAmountOverflow",msg:"Minted amount after deposit exceeds u64"}]};function L(i){return s.findProgramAddressSync([c.Buffer.from("redeemer")],new s(i))[0]}function Me(i,t){const e=c.Buffer.alloc(8);return e.writeBigUInt64LE(t),s.findProgramAddressSync([c.Buffer.from("msg"),e],new s(i))[0]}function Te(i,t){const e=c.Buffer.alloc(2);return e.writeUInt16LE(h(t)),s.findProgramAddressSync([c.Buffer.from("gateway-info"),e],new s(i))[0]}const T=new s("Gj93RRt6QB7FjmyokAD5rcMAku7pq3Fk2Aa8y6nNbwsV");function Be(){return s.findProgramAddressSync([c.Buffer.from("config")],T)[0]}function be(i){return s.findProgramAddressSync([c.Buffer.from("minter-info"),i.toBuffer()],T)[0]}const B=new s("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA");new s("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb");const b=new s("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL");new s("So11111111111111111111111111111111111111112");new s("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class Ae extends Error{constructor(t){super(t)}}class Ce extends Ae{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}const Pe=J([E("mintAuthorityOption"),W("mintAuthority"),Q("supply"),X("decimals"),Y("isInitialized"),E("freezeAuthorityOption"),W("freezeAuthority")]);Pe.span;async function M(i,t,e=!1,r=B,n=b){if(!e&&!s.isOnCurve(t.toBuffer()))throw new Ce;const[a]=await s.findProgramAddress([t.toBuffer(),r.toBuffer(),i.toBuffer()],n);return a}function Ie(i,t,e,r,n=B,a=b){return Ee(i,t,e,r,c.Buffer.alloc(0),n,a)}function Ee(i,t,e,r,n,a=B,o=b){const u=[{pubkey:i,isSigner:!0,isWritable:!0},{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:$.programId,isSigner:!1,isWritable:!1},{pubkey:a,isSigner:!1,isWritable:!1}];return new ee({keys:u,programId:o,data:n})}class A{constructor(t,e,r,n){d(this,"network");d(this,"chain");d(this,"connection");d(this,"contracts");d(this,"gateway");d(this,"tokenBridgeId");d(this,"coreBridgeId");if(this.network=t,this.chain=e,this.connection=r,this.contracts=n,this.network!=="Mainnet")throw new Error("TBTC is only supported on Mainnet");if(!this.contracts.tbtc)throw new Error("TBTC contract address is required");if(!this.contracts.tokenBridge)throw new Error("TokenBridge contract address is required");if(!this.contracts.coreBridge)throw new Error("CoreBridge contract address is required");this.gateway=new te(Se,this.contracts.tbtc,{connection:r}),this.tokenBridgeId=new s(this.contracts.tokenBridge),this.coreBridgeId=new s(this.contracts.coreBridge)}static async fromRpc(t,e){const[r,n]=await ie.chainFromRpc(t),a=e[n];if(a.network!==r)throw new Error(`Network mismatch: ${a.network} != ${r}`);return new A(r,n,t,a.contracts)}async*transfer(t,e,r){const n=new K(t).unwrap(),a=L(this.gateway.programId),{tbtcMint:o,wrappedTbtcToken:u,wrappedTbtcMint:g}=await this.gateway.account.custodian.fetch(a),p=O(this.tokenBridgeId,g),m=R(this.tokenBridgeId),f=pe(this.tokenBridgeId),C=ne(this.coreBridgeId),{sequence:y}=await se(this.connection,this.tokenBridgeId,this.coreBridgeId),w=Me(this.gateway.programId,y),k=ae(this.coreBridgeId),l=re(this.tokenBridgeId),S=oe(l,this.coreBridgeId),U=Te(this.gateway.programId,e.chain),V=ye(this.gateway.programId),P={amount:new x(r.toString()),recipientChain:h(e.chain),recipient:[...e.address.toUniversalAddress().toUint8Array()],nonce:0},q=await M(o,n),D=ce.get(this.network,e.chain),I={custodian:a,wrappedTbtcToken:u,wrappedTbtcMint:g,tbtcMint:o,senderToken:q,sender:n,tokenBridgeConfig:m,tokenBridgeWrappedAsset:p,tokenBridgeTransferAuthority:f,coreBridgeData:k,coreMessage:w,tokenBridgeCoreEmitter:l,coreEmitterSequence:S,coreFeeCollector:C,clock:de,rent:v,tokenBridgeProgram:this.tokenBridgeId,coreBridgeProgram:this.coreBridgeId},_=D?await this.gateway.methods.sendTbtcGateway({...P}).accounts({...I,gatewayInfo:U,tokenBridgeSender:V}).instruction():await this.gateway.methods.sendTbtcWrapped({...P,arbiterFee:new x(0)}).accounts(I).instruction(),{blockhash:F}=await this.connection.getLatestBlockhash(),z=N.compile({instructions:[_],payerKey:n,recentBlockhash:F}),j=new G(z);yield this.createUnsignedTransaction({transaction:j},"TBTCBridge.Send")}async*redeem(t,e){if(e.payloadName!=="GatewayTransfer")throw new Error("Invalid VAA payload");yield*new ue(this.network,this.chain,this.connection,this.contracts).postVaa(t,e);const n=[],a=new K(t).unwrap(),o=e.payload.payload.recipient.toNative(this.chain).unwrap(),u=L(this.gateway.programId),{tbtcMint:g,wrappedTbtcToken:p,wrappedTbtcMint:m}=await this.gateway.account.custodian.fetch(u),f=await M(g,o);await this.connection.getAccountInfo(f)||n.push(Ie(a,f,o,g));const y=O(this.tokenBridgeId,m),w=await M(m,o);n.push(await this.gateway.methods.receiveTbtc([...e.hash]).accounts({payer:a,custodian:u,postedVaa:me(this.coreBridgeId,c.Buffer.from(e.hash)),tokenBridgeClaim:ge(this.tokenBridgeId,e.emitterAddress.toUint8Array(),h(e.emitterChain),e.sequence),wrappedTbtcToken:p,wrappedTbtcMint:m,tbtcMint:g,recipientToken:f,recipient:o,recipientWrappedToken:w,tbtcConfig:Be(),tbtcMinterInfo:be(u),tokenBridgeConfig:R(this.tokenBridgeId),tokenBridgeRegisteredEmitter:ke(this.tokenBridgeId,h(e.emitterChain),e.emitterAddress.toUint8Array()),tokenBridgeWrappedAsset:y,tokenBridgeMintAuthority:we(this.tokenBridgeId),rent:v,tbtcProgram:T,tokenBridgeProgram:this.tokenBridgeId,coreBridgeProgram:this.coreBridgeId}).instruction());const{blockhash:k}=await this.connection.getLatestBlockhash(),l=N.compile({instructions:n,payerKey:a,recentBlockhash:k}),S=new G(l);yield this.createUnsignedTransaction({transaction:S},"TBTCBridge.Send")}createUnsignedTransaction(t,e){return new fe(t,this.network,this.chain,e,!1)}}le(he,"TBTCBridge",A);export{A as SolanaTBTCBridge};
|
|
1
|
+
var H=Object.defineProperty;var Z=(i,t,e)=>t in i?H(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e;var d=(i,t,e)=>Z(i,typeof t!="symbol"?t+"":t,e);import{P as s,i as c,bI as h,bf as Q,bg as E,bh as W,bi as X,bj as Y,bk as J,ch as $,ci as ee,cj as te,a6 as ie,a7 as K,cn as ne,co as se,cp as ae,cq as re,cr as oe,bu as x,cs as ce,ct as v,cu as de,cv as N,V as G,cw as ue,cx as me,cy as ge,cm as fe,bV as le,a8 as he}from"../main.js";import{deriveWrappedMetaKey as O,deriveTokenBridgeConfigKey as R,deriveAuthoritySignerKey as pe,deriveSenderAccountKey as ye,deriveMintAuthorityKey as we,deriveEndpointKey as ke}from"./index-BIdhtTCf.js";const Se={version:"0.1.0",name:"wormhole_gateway",instructions:[{name:"initialize",accounts:[{name:"authority",isMut:!0,isSigner:!0},{name:"custodian",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!1,isSigner:!1,docs:["TBTC Program's mint PDA address bump is saved in this program's config. Ordinarily, we would","not have to deserialize this account. But we do in this case to make sure the TBTC program","has been initialized before this program."]},{name:"wrappedTbtcMint",isMut:!1,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1},{name:"tokenBridgeSender",isMut:!1,isSigner:!1,docs:["sign for transferring via Token Bridge program with a message."]},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1}],args:[{name:"mintingLimit",type:"u64"}]},{name:"changeAuthority",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0},{name:"newAuthority",isMut:!1,isSigner:!1}],args:[]},{name:"cancelAuthorityChange",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0}],args:[]},{name:"takeAuthority",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"pendingAuthority",isMut:!1,isSigner:!0}],args:[]},{name:"updateGatewayAddress",accounts:[{name:"custodian",isMut:!1,isSigner:!1},{name:"gatewayInfo",isMut:!0,isSigner:!1},{name:"authority",isMut:!0,isSigner:!0},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"UpdateGatewayAddressArgs"}}]},{name:"updateMintingLimit",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!0}],args:[{name:"newLimit",type:"u64"}]},{name:"receiveTbtc",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"custodian",isMut:!0,isSigner:!1},{name:"postedVaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["transfer. By checking whether this account exists is a short-circuit way of bailing out","early if this transfer has already been redeemed (as opposed to letting the Token Bridge","instruction fail)."]},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1,docs:["This mint is owned by the Wormhole Token Bridge program. This PDA address is stored in the","custodian account."]},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"recipientToken",isMut:!0,isSigner:!1,docs:["Token account for minted tBTC.","","NOTE: Because the recipient is encoded in the transfer message payload, we can check the","authority from the deserialized VAA. But we should still check whether the authority is the","zero address in access control."]},{name:"recipient",isMut:!1,isSigner:!1,docs:["be created for him."]},{name:"recipientWrappedToken",isMut:!0,isSigner:!1,docs:["The gateway will create an associated token account for the recipient if it doesn't exist.","","NOTE: When the minting limit increases, the recipient can use this token account to mint","tBTC using the deposit_wormhole_tbtc instruction."]},{name:"tbtcConfig",isMut:!1,isSigner:!1},{name:"tbtcMinterInfo",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeRegisteredEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"tbtcProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"messageHash",type:{array:["u8",32]}}]},{name:"sendTbtcGateway",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"gatewayInfo",isMut:!1,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"senderToken",isMut:!0,isSigner:!1},{name:"sender",isMut:!0,isSigner:!0},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeTransferAuthority",isMut:!1,isSigner:!1},{name:"coreBridgeData",isMut:!0,isSigner:!1},{name:"coreMessage",isMut:!0,isSigner:!1},{name:"tokenBridgeCoreEmitter",isMut:!1,isSigner:!1},{name:"coreEmitterSequence",isMut:!0,isSigner:!1},{name:"coreFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"tokenBridgeSender",isMut:!1,isSigner:!1,docs:["sign for transferring via Token Bridge program with a message."]},{name:"rent",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"SendTbtcGatewayArgs"}}]},{name:"sendTbtcWrapped",accounts:[{name:"custodian",isMut:!0,isSigner:!1},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["Custody account."]},{name:"wrappedTbtcMint",isMut:!0,isSigner:!1},{name:"tbtcMint",isMut:!0,isSigner:!1},{name:"senderToken",isMut:!0,isSigner:!1},{name:"sender",isMut:!0,isSigner:!0},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedAsset",isMut:!1,isSigner:!1},{name:"tokenBridgeTransferAuthority",isMut:!1,isSigner:!1},{name:"coreBridgeData",isMut:!0,isSigner:!1},{name:"coreMessage",isMut:!0,isSigner:!1},{name:"tokenBridgeCoreEmitter",isMut:!1,isSigner:!1},{name:"coreEmitterSequence",isMut:!0,isSigner:!1},{name:"coreFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"coreBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"SendTbtcWrappedArgs"}}]},{name:"depositWormholeTbtc",accounts:[{name:"custodian",isMut:!0,isSigner:!1,docs:["NOTE: This account also acts as a minter for the TBTC program."]},{name:"wrappedTbtcToken",isMut:!0,isSigner:!1,docs:["This token account is owned by this program, whose mint is the wrapped TBTC mint. This PDA","address is stored in the custodian account."]},{name:"wrappedTbtcMint",isMut:!1,isSigner:!1,docs:["This mint is owned by the Wormhole Token Bridge program. This PDA address is stored in the","custodian account."]},{name:"tbtcMint",isMut:!0,isSigner:!1,docs:["This mint is owned by the TBTC program. This PDA address is stored in the custodian account."]},{name:"recipientWrappedToken",isMut:!0,isSigner:!1},{name:"recipientToken",isMut:!0,isSigner:!1},{name:"recipient",isMut:!1,isSigner:!0,docs:["This program requires that the owner of the TBTC token account sign for TBTC being minted","into his account."]},{name:"tbtcConfig",isMut:!1,isSigner:!1},{name:"tbtcMinterInfo",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"tbtcProgram",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"}]}],accounts:[{name:"custodian",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"authority",type:"publicKey"},{name:"pendingAuthority",type:{option:"publicKey"}},{name:"tbtcMint",type:"publicKey"},{name:"wrappedTbtcMint",type:"publicKey"},{name:"wrappedTbtcToken",type:"publicKey"},{name:"tokenBridgeSender",type:"publicKey"},{name:"tokenBridgeSenderBump",type:"u8"},{name:"mintingLimit",type:"u64"},{name:"mintedAmount",type:"u64"}]}},{name:"GatewayInfo",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"address",type:{array:["u8",32]}}]}}],types:[{name:"UpdateGatewayAddressArgs",type:{kind:"struct",fields:[{name:"chain",type:"u16"},{name:"address",type:{array:["u8",32]}}]}},{name:"SendTbtcGatewayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipient",type:{array:["u8",32]}},{name:"nonce",type:"u32"}]}},{name:"SendTbtcWrappedArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipient",type:{array:["u8",32]}},{name:"arbiterFee",type:"u64"},{name:"nonce",type:"u32"}]}}],events:[{name:"WormholeTbtcReceived",fields:[{name:"receiver",type:"publicKey",index:!1},{name:"amount",type:"u64",index:!1}]},{name:"WormholeTbtcSent",fields:[{name:"amount",type:"u64",index:!1},{name:"recipientChain",type:"u16",index:!1},{name:"gateway",type:{array:["u8",32]},index:!1},{name:"recipient",type:{array:["u8",32]},index:!1},{name:"arbiterFee",type:"u64",index:!1},{name:"nonce",type:"u32",index:!1}]},{name:"WormholeTbtcDeposited",fields:[{name:"depositor",type:"publicKey",index:!1},{name:"amount",type:"u64",index:!1}]},{name:"GatewayAddressUpdated",fields:[{name:"chain",type:"u16",index:!1},{name:"gateway",type:{array:["u8",32]},index:!1}]},{name:"MintingLimitUpdated",fields:[{name:"mintingLimit",type:"u64",index:!1}]}],errors:[{code:6016,name:"MintingLimitExceeded",msg:"Cannot mint more than the minting limit"},{code:6032,name:"IsNotAuthority",msg:"Only custodian authority is permitted for this action"},{code:6034,name:"IsNotPendingAuthority",msg:"Not valid pending authority to take authority"},{code:6036,name:"NoPendingAuthorityChange",msg:"No pending authority"},{code:6048,name:"ZeroRecipient",msg:"0x0 recipient not allowed"},{code:6064,name:"NotEnoughWrappedTbtc",msg:"Not enough wormhole tBTC in the gateway to bridge"},{code:6080,name:"ZeroAmount",msg:"Amount must not be 0"},{code:6112,name:"TransferAlreadyRedeemed",msg:"Token Bridge transfer already redeemed"},{code:6128,name:"InvalidEthereumTbtc",msg:"Token chain and address do not match Ethereum's tBTC"},{code:6144,name:"NoTbtcTransferred",msg:"No tBTC transferred"},{code:6160,name:"RecipientZeroAddress",msg:"0x0 receiver not allowed"},{code:6176,name:"MintedAmountUnderflow",msg:"Not enough minted by the gateway to satisfy sending tBTC"},{code:6178,name:"MintedAmountOverflow",msg:"Minted amount after deposit exceeds u64"}]};function V(i){return s.findProgramAddressSync([c.Buffer.from("redeemer")],new s(i))[0]}function Me(i,t){const e=c.Buffer.alloc(8);return e.writeBigUInt64LE(t),s.findProgramAddressSync([c.Buffer.from("msg"),e],new s(i))[0]}function Te(i,t){const e=c.Buffer.alloc(2);return e.writeUInt16LE(h(t)),s.findProgramAddressSync([c.Buffer.from("gateway-info"),e],new s(i))[0]}const T=new s("Gj93RRt6QB7FjmyokAD5rcMAku7pq3Fk2Aa8y6nNbwsV");function Be(){return s.findProgramAddressSync([c.Buffer.from("config")],T)[0]}function be(i){return s.findProgramAddressSync([c.Buffer.from("minter-info"),i.toBuffer()],T)[0]}const B=new s("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA");new s("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb");const b=new s("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL");new s("So11111111111111111111111111111111111111112");new s("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class Ae extends Error{constructor(t){super(t)}}class Ce extends Ae{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}const Pe=Q([E("mintAuthorityOption"),W("mintAuthority"),X("supply"),Y("decimals"),J("isInitialized"),E("freezeAuthorityOption"),W("freezeAuthority")]);Pe.span;async function M(i,t,e=!1,r=B,n=b){if(!e&&!s.isOnCurve(t.toBuffer()))throw new Ce;const[a]=await s.findProgramAddress([t.toBuffer(),r.toBuffer(),i.toBuffer()],n);return a}function Ie(i,t,e,r,n=B,a=b){return Ee(i,t,e,r,c.Buffer.alloc(0),n,a)}function Ee(i,t,e,r,n,a=B,o=b){const u=[{pubkey:i,isSigner:!0,isWritable:!0},{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:$.programId,isSigner:!1,isWritable:!1},{pubkey:a,isSigner:!1,isWritable:!1}];return new ee({keys:u,programId:o,data:n})}class A{constructor(t,e,r,n){d(this,"network");d(this,"chain");d(this,"connection");d(this,"contracts");d(this,"gateway");d(this,"tokenBridgeId");d(this,"coreBridgeId");if(this.network=t,this.chain=e,this.connection=r,this.contracts=n,this.network!=="Mainnet")throw new Error("TBTC is only supported on Mainnet");if(!this.contracts.tbtc)throw new Error("TBTC contract address is required");if(!this.contracts.tokenBridge)throw new Error("TokenBridge contract address is required");if(!this.contracts.coreBridge)throw new Error("CoreBridge contract address is required");this.gateway=new te(Se,this.contracts.tbtc,{connection:r}),this.tokenBridgeId=new s(this.contracts.tokenBridge),this.coreBridgeId=new s(this.contracts.coreBridge)}static async fromRpc(t,e){const[r,n]=await ie.chainFromRpc(t),a=e[n];if(a.network!==r)throw new Error(`Network mismatch: ${a.network} != ${r}`);return new A(r,n,t,a.contracts)}async*transfer(t,e,r){const n=new K(t).unwrap(),a=V(this.gateway.programId),{tbtcMint:o,wrappedTbtcToken:u,wrappedTbtcMint:m}=await this.gateway.account.custodian.fetch(a),p=O(this.tokenBridgeId,m),g=R(this.tokenBridgeId),f=pe(this.tokenBridgeId),C=ne(this.coreBridgeId),{sequence:y}=await se(this.connection,this.tokenBridgeId,this.coreBridgeId),w=Me(this.gateway.programId,y),k=ae(this.coreBridgeId),l=re(this.tokenBridgeId),S=oe(l,this.coreBridgeId),L=Te(this.gateway.programId,e.chain),U=ye(this.gateway.programId),P={amount:new x(r.toString()),recipientChain:h(e.chain),recipient:[...e.address.toUniversalAddress().toUint8Array()],nonce:0},q=await M(o,n),D=ce.get(this.network,e.chain),I={custodian:a,wrappedTbtcToken:u,wrappedTbtcMint:m,tbtcMint:o,senderToken:q,sender:n,tokenBridgeConfig:g,tokenBridgeWrappedAsset:p,tokenBridgeTransferAuthority:f,coreBridgeData:k,coreMessage:w,tokenBridgeCoreEmitter:l,coreEmitterSequence:S,coreFeeCollector:C,clock:de,rent:v,tokenBridgeProgram:this.tokenBridgeId,coreBridgeProgram:this.coreBridgeId},_=D?await this.gateway.methods.sendTbtcGateway({...P}).accounts({...I,gatewayInfo:L,tokenBridgeSender:U}).instruction():await this.gateway.methods.sendTbtcWrapped({...P,arbiterFee:new x(0)}).accounts(I).instruction(),{blockhash:F}=await this.connection.getLatestBlockhash(),z=N.compile({instructions:[_],payerKey:n,recentBlockhash:F}),j=new G(z);yield this.createUnsignedTransaction({transaction:j},"TBTCBridge.Send")}async*redeem(t,e){if(e.payloadName!=="GatewayTransfer")throw new Error("Invalid VAA payload");yield*new ue(this.network,this.chain,this.connection,this.contracts).postVaa(t,e);const n=[],a=new K(t).unwrap(),o=e.payload.payload.recipient.toNative(this.chain).unwrap(),u=V(this.gateway.programId),{tbtcMint:m,wrappedTbtcToken:p,wrappedTbtcMint:g}=await this.gateway.account.custodian.fetch(u),f=await M(m,o);await this.connection.getAccountInfo(f)||n.push(Ie(a,f,o,m));const y=O(this.tokenBridgeId,g),w=await M(g,o);n.push(await this.gateway.methods.receiveTbtc([...e.hash]).accounts({payer:a,custodian:u,postedVaa:ge(this.coreBridgeId,c.Buffer.from(e.hash)),tokenBridgeClaim:me(this.tokenBridgeId,e.emitterAddress.toUint8Array(),h(e.emitterChain),e.sequence),wrappedTbtcToken:p,wrappedTbtcMint:g,tbtcMint:m,recipientToken:f,recipient:o,recipientWrappedToken:w,tbtcConfig:Be(),tbtcMinterInfo:be(u),tokenBridgeConfig:R(this.tokenBridgeId),tokenBridgeRegisteredEmitter:ke(this.tokenBridgeId,h(e.emitterChain),e.emitterAddress.toUint8Array()),tokenBridgeWrappedAsset:y,tokenBridgeMintAuthority:we(this.tokenBridgeId),rent:v,tbtcProgram:T,tokenBridgeProgram:this.tokenBridgeId,coreBridgeProgram:this.coreBridgeId}).instruction());const{blockhash:k}=await this.connection.getLatestBlockhash(),l=N.compile({instructions:n,payerKey:a,recentBlockhash:k}),S=new G(l);yield this.createUnsignedTransaction({transaction:S},"TBTCBridge.Send")}createUnsignedTransaction(t,e){return new fe(t,this.network,this.chain,e,!1)}}le(he,"TBTCBridge",A);export{A as SolanaTBTCBridge};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var k=Object.defineProperty;var v=(u,s,t)=>s in u?k(u,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):u[s]=t;var i=(u,s,t)=>v(u,typeof s!="symbol"?s+"":s,t);import{T as f,S as w}from"./sui-
|
|
1
|
+
var k=Object.defineProperty;var v=(u,s,t)=>s in u?k(u,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):u[s]=t;var i=(u,s,t)=>v(u,typeof s!="symbol"?s+"":s,t);import{T as f,S as w}from"./sui-DZhbOaP_.js";import{c$ as C,c5 as S,c3 as _,c4 as b,af as y,c6 as T,bV as M}from"../main.js";import{S as x}from"./unsignedTransaction-arVvzoJx.js";import"./blake2b-C_UGgjrB.js";import"./index-WlpSU6Q6.js";const j=[["Testnet",{tokenMessengerState:"0x5252abd1137094ed1db3e0d75bc36abcd287aee4bc310f8e047727ef5682e7c2",messageTransmitterState:"0x98234bd0fa9ac12cc0a20a144a22e36d6a32f7e0a97baaeaf9c76cdc6d122d2e",usdcTreasury:"0x7170137d4a6431bf83351ac025baf462909bffe2877d87716374fb42b9629ebe"}],["Mainnet",{tokenMessengerState:"0x45993eecc0382f37419864992c12faee2238f5cfe22b98ad3bf455baf65c8a2f",messageTransmitterState:"0xf68268c3d9b1df3215f2439400c1c4ea08ac4ef4bb7d6f3ca6a2a239e17510af",usdcTreasury:"0x57d6725e7a8b49a7b2a612f6bd66ab5f39fc95332ca48be421c3229d514a6de7"}]],$=C(j,[0,1]);class p{constructor(s,t,r,e){i(this,"network");i(this,"chain");i(this,"provider");i(this,"contracts");i(this,"usdcId");i(this,"usdcTreasuryId");i(this,"tokenMessengerId");i(this,"tokenMessengerStateId");i(this,"messageTransmitterId");i(this,"messageTransmitterStateId");var m,d,g,h;if(this.network=s,this.chain=t,this.provider=r,this.contracts=e,s==="Devnet")throw new Error("CircleBridge not supported on Devnet");const n=S.get(this.network,this.chain);if(!n)throw new Error(`No USDC contract configured for network=${this.network} chain=${this.chain}`);const{tokenMessengerState:o,messageTransmitterState:a,usdcTreasury:c}=$(s);if(!((m=e.cctp)!=null&&m.tokenMessenger))throw new Error(`Circle Token Messenger contract for domain ${t} not found`);if(!((d=e.cctp)!=null&&d.messageTransmitter))throw new Error(`Circle Message Transmitter contract for domain ${t} not found`);this.usdcId=n,this.usdcTreasuryId=c,this.tokenMessengerId=(g=e.cctp)==null?void 0:g.tokenMessenger,this.messageTransmitterId=(h=e.cctp)==null?void 0:h.messageTransmitter,this.tokenMessengerStateId=o,this.messageTransmitterStateId=a}async*transfer(s,t,r){const e=new f,n=_.get(this.network,t.chain),[o,...a]=await w.getCoins(this.provider,s,this.usdcId);if(o===void 0)throw new Error("No USDC in wallet");const c=e.object(o.coinObjectId);a.length>0&&e.mergeCoins(c,a.map(d=>e.object(d.coinObjectId)));const[m]=e.splitCoins(c,[r]);e.moveCall({target:`${this.tokenMessengerId}::deposit_for_burn::deposit_for_burn`,arguments:[m,e.pure.u32(n),e.pure.address(t.address.toUniversalAddress().toString()),e.object(this.tokenMessengerStateId),e.object(this.messageTransmitterStateId),e.object("0x403"),e.object(this.usdcTreasuryId)],typeArguments:[this.usdcId]}),yield this.createUnsignedTx(e,"Sui.CircleBridge.Transfer")}async isTransferCompleted(s){const t=new f;t.moveCall({target:`${this.messageTransmitterId}::state::is_nonce_used`,arguments:[t.object(this.messageTransmitterStateId),t.pure.u32(s.sourceDomain),t.pure.u64(s.nonce)]});const r=await this.provider.devInspectTransactionBlock({sender:"0x0000000000000000000000000000000000000000000000000000000000000000",transactionBlock:t});try{return!!r.results[0].returnValues[0][0][0]}catch(e){return console.error(`Error reading if nonce was used: ${e}`),!1}}async*redeem(s,t,r){const e=new f,[n]=e.moveCall({target:`${this.messageTransmitterId}::receive_message::receive_message`,arguments:[e.pure.vector("u8",b.serialize(t)),e.pure.vector("u8",y.decode(r)),e.object(this.messageTransmitterStateId)]});if(!n)throw new Error("Failed to produce receipt");const[o]=e.moveCall({target:`${this.tokenMessengerId}::handle_receive_message::handle_receive_message`,arguments:[n,e.object(this.tokenMessengerStateId),e.object("0x403"),e.object(this.usdcTreasuryId)],typeArguments:[this.usdcId]});if(!o)throw new Error("Failed to produce stamp receipt ticket with burn message");const[a]=e.moveCall({target:`${this.tokenMessengerId}::handle_receive_message::deconstruct_stamp_receipt_ticket_with_burn_message`,arguments:[o]});if(!a)throw new Error("Failed to produce stamp receipt ticket");const[c]=e.moveCall({target:`${this.messageTransmitterId}::receive_message::stamp_receipt`,arguments:[a,e.object(this.messageTransmitterStateId)],typeArguments:[`${this.tokenMessengerId}::message_transmitter_authenticator::MessageTransmitterAuthenticator`]});if(!c)throw new Error("Failed to produce stamped receipt");e.moveCall({target:`${this.messageTransmitterId}::receive_message::complete_receive_message`,arguments:[c,e.object(this.messageTransmitterStateId)]}),yield this.createUnsignedTx(e,"Sui.CircleBridge.Redeem")}async parseTransactionDetails(s){var l;const t=await this.provider.waitForTransaction({digest:s,options:{showEvents:!0,showEffects:!0,showInput:!0}});if(!t)throw new Error("Transaction not found");if(!t.events)throw new Error("Transaction events not found");const r=(l=t.events)==null?void 0:l.find(I=>I.type.includes("send_message::MessageSent"));if(!r)throw new Error("No MessageSent event found");const e=new Uint8Array((r==null?void 0:r.parsedJson).message),[n,o]=b.deserialize(e),{payload:a}=n,c=a.messageSender,m=a.mintRecipient,d=T(this.network,n.sourceDomain),g=T(this.network,n.destinationDomain),h={chain:d,address:a.burnToken};return{from:{chain:d,address:c},to:{chain:g,address:m},token:h,amount:a.amount,message:n,id:{hash:o}}}static async fromRpc(s,t){const[r,e]=await w.chainFromRpc(s),n=t[e];if(n.network!==r)throw new Error(`Network mismatch: ${n.network} != ${r}`);return new p(r,e,s,n.contracts)}createUnsignedTx(s,t,r=!1){return new x(s,this.network,this.chain,t,r)}}M("Sui","CircleBridge",p);export{p as SuiCircleBridge};
|