@wormhole-foundation/wormhole-connect 4.0.0-beta.0-development → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (205) hide show
  1. package/dist/assets/{aptos-CIKjhZ5R.js → aptos-CaGPw7HM.js} +2 -2
  2. package/dist/assets/create-54a95t1x.js +1 -0
  3. package/dist/assets/{evm-Ky_mCHhS.js → evm-Bv0RsFka.js} +2 -2
  4. package/dist/assets/{index-DW7sWcdW.js → index-B5JfIVKE.js} +1 -1
  5. package/dist/assets/{index-DHLr3HmO.js → index-BCD-VOiF.js} +1 -1
  6. package/dist/assets/index-BwhO0jGm.js +1 -0
  7. package/dist/assets/{index-DpM61P6H.js → index-CMULoTsT.js} +1 -1
  8. package/dist/assets/{index-DZpeOp3V.js → index-CO4HXUmy.js} +1 -1
  9. package/dist/assets/{index-Bg3NWSHL.js → index-COw2RtBx.js} +1 -1
  10. package/dist/assets/{index-DRk-Cj0P.js → index-ClrVAZUa.js} +1 -1
  11. package/dist/assets/{index-D7RgFG0F.js → index-CzQeh-hT.js} +1 -1
  12. package/dist/assets/{index-Csghphw2.js → index-DC4mZtDw.js} +1 -1
  13. package/dist/assets/{index-Cqs_fFht.js → index-DI-xN_q3.js} +1 -1
  14. package/dist/assets/{index-DVbfoP0w.js → index-DRsHBjoG.js} +1 -1
  15. package/dist/assets/{index-CdAFGcxx.js → index-DXcQbQ8r.js} +1 -1
  16. package/dist/assets/{index-DJ52h-dV.js → index-DxHhcWFS.js} +1 -1
  17. package/dist/assets/{index-g9iLhWvp.js → index-GKTf0CV7.js} +1 -1
  18. package/dist/assets/{index-DuR9wYhp.js → index-aoYIFErC.js} +1 -1
  19. package/dist/assets/{index-DfNgilHG.js → index-jixjwN_L.js} +1 -1
  20. package/dist/assets/{solana-jYIeIu4B.js → solana-DpD0VkQS.js} +2 -2
  21. package/dist/assets/{sui-B96bqBVv.js → sui-7K04yY2U.js} +2 -2
  22. package/dist/main.js +75 -75
  23. package/dist/src/components/TokenBalance.d.ts.map +1 -1
  24. package/dist/src/config/mainnet/tokens.d.ts.map +1 -1
  25. package/dist/src/config/testnet/tokens.d.ts.map +1 -1
  26. package/dist/src/contexts/wallet/WalletProvider.d.ts.map +1 -1
  27. package/dist/src/hooks/useFetchSupportedRoutes.d.ts.map +1 -1
  28. package/dist/src/hooks/useTokenListWithSearch.d.ts +1 -4
  29. package/dist/src/hooks/useTokenListWithSearch.d.ts.map +1 -1
  30. package/dist/src/routes/operator.d.ts.map +1 -1
  31. package/dist/src/routes/sdkv2/route.d.ts +2 -2
  32. package/dist/src/routes/sdkv2/route.d.ts.map +1 -1
  33. package/dist/src/telemetry/types.d.ts +1 -0
  34. package/dist/src/telemetry/types.d.ts.map +1 -1
  35. package/dist/src/utils/sdkv2.d.ts.map +1 -1
  36. package/dist/src/utils/wrappedNativeTokens.d.ts +12 -0
  37. package/dist/src/utils/wrappedNativeTokens.d.ts.map +1 -0
  38. package/dist/src/views/Terms.d.ts.map +1 -1
  39. package/dist/src/views/v2/Bridge/AssetPicker/TokenList.d.ts.map +1 -1
  40. package/dist/src/views/v3/Bridge/AssetPicker/SearchableList/index.d.ts.map +1 -1
  41. package/dist/src/views/v3/Bridge/AssetPicker/TokenList.d.ts.map +1 -1
  42. package/dist/src/views/v3/Bridge/AssetPicker/TokenSectionHeader.d.ts +2 -4
  43. package/dist/src/views/v3/Bridge/AssetPicker/TokenSectionHeader.d.ts.map +1 -1
  44. package/lib/{account-D0Q4K1CI.js → account-24z6tDMM.js} +1 -1
  45. package/lib/{account-BdDruAAr.mjs → account-BcnWVXmg.mjs} +1 -1
  46. package/lib/{address-fSXS9iww.mjs → address-BX2fIOro.mjs} +1 -1
  47. package/lib/{address-BO6rj6uK.js → address-Bc-5yO4D.js} +1 -1
  48. package/lib/{aptos-BnKScTtI.mjs → aptos-DO_Sexq-.mjs} +7 -7
  49. package/lib/{aptos-B3C7cnvM.js → aptos-DffuIzI0.js} +2 -2
  50. package/lib/{aptos-B1VSCmD9.mjs → aptos-Dol0ReEK.mjs} +4 -4
  51. package/lib/{aptos-DG7QN21P.js → aptos-eGdJuKke.js} +1 -1
  52. package/lib/{basic-CN2jAqvS.js → basic-B3aoOwRb.js} +1 -1
  53. package/lib/{basic-BRYkcAmD.mjs → basic-BI1HDLIO.mjs} +4 -4
  54. package/lib/{basic-Cw13RoYq.mjs → basic-C6oQe5cg.mjs} +4 -4
  55. package/lib/{basic-DufHOLGA.js → basic-pJmrDH53.js} +1 -1
  56. package/lib/{blake2b-CT6EW399.mjs → blake2b-CVpPk5O9.mjs} +1 -1
  57. package/lib/{blake2b-B_Q_lTGN.js → blake2b-DXExLbRg.js} +1 -1
  58. package/lib/{browser-ponyfill-CnfcLhK-.mjs → browser-ponyfill-DeOApqpH.mjs} +1 -1
  59. package/lib/{browser-ponyfill-DbGoEOBo.js → browser-ponyfill-VhIu9z_I.js} +1 -1
  60. package/lib/{chain-BCKkYvDb.js → chain-BxNUWKZE.js} +1 -1
  61. package/lib/{chain-_dXKRkCE.mjs → chain-CvZsIsLh.mjs} +1 -1
  62. package/lib/{chunk-KJH4KKG6-RA0hChr8.mjs → chunk-KJH4KKG6-BgebMATq.mjs} +2 -2
  63. package/lib/{chunk-KJH4KKG6-BXBLZwfY.js → chunk-KJH4KKG6-DNlN4p21.js} +1 -1
  64. package/lib/{constants-QsbOfMbk.mjs → constants-BPs5UFxq.mjs} +1 -1
  65. package/lib/constants-BqHCu7gS.js +1 -0
  66. package/lib/{contract-MkLF5rqi.js → contract-CTycrpaK.js} +1 -1
  67. package/lib/{contract-C_4H8x77.mjs → contract-KYuIk_vR.mjs} +1 -1
  68. package/lib/{core-Cpb3gtg_.js → core-BN_eDiBJ.js} +3 -3
  69. package/lib/{core-ntLR7o2S.mjs → core-BZzw8R4f.mjs} +6 -6
  70. package/lib/{create-naslyPfU.mjs → create-BvzkkBPW.mjs} +1 -1
  71. package/lib/{create-CfgTxAS-.js → create-CGZYy2vu.js} +1 -1
  72. package/lib/{evm-aSG_vFbw.js → evm-BdbjSrMR.js} +2 -2
  73. package/lib/{evm-B20n3mf_.mjs → evm-CUhPokEi.mjs} +7 -7
  74. package/lib/{evm-C6xp3v8Z.mjs → evm-IC5cigOX.mjs} +9 -9
  75. package/lib/{evm-B3G2Vkzg.js → evm-bdCQPjof.js} +2 -2
  76. package/lib/executor.js +1 -1
  77. package/lib/executor.mjs +815 -572
  78. package/lib/hosted.js +1 -1
  79. package/lib/hosted.mjs +1 -1
  80. package/lib/{index-B9ybSY9R.mjs → index-1boJ8yzF.mjs} +5 -5
  81. package/lib/{index-BJcbyvof.js → index-943_uCEO.js} +1 -1
  82. package/lib/{index-Dq7WWqFe.js → index-B7HBnPLP.js} +1 -1
  83. package/lib/{index-DQX74QAE.js → index-BFBwRlid.js} +1 -1
  84. package/lib/{index-C6XNAQ4w.js → index-BZZZ8OeS.js} +1 -1
  85. package/lib/{index-CU73EUQW.js → index-BeBO_sCU.js} +1 -1
  86. package/lib/{index-BTUx12aa.js → index-Bhwzpq1T.js} +1 -1
  87. package/lib/{index-MsaML_Ju.mjs → index-Bicx897u.mjs} +2 -2
  88. package/lib/{index-Dajw3Alx.mjs → index-BlWksu-f.mjs} +1 -1
  89. package/lib/{index-QlIJYJce.js → index-Blvg4PFN.js} +66 -66
  90. package/lib/{index-DS8bl8fA.mjs → index-Bn0hkKKz.mjs} +4 -4
  91. package/lib/{index-tztRp3yJ.js → index-BnMkdrhM.js} +1 -1
  92. package/lib/{index-BojkMsXD.js → index-BoKTcLq-.js} +1 -1
  93. package/lib/{index-BRYq_Nt2.mjs → index-Bp4ojxz6.mjs} +4 -4
  94. package/lib/{index-Cnznwcdb.js → index-BqabgGIh.js} +1 -1
  95. package/lib/{index-DxYgNWMY.mjs → index-BtEjOWoP.mjs} +3 -3
  96. package/lib/{index-Bhd_YhUf.js → index-C9Bk-rKp.js} +1 -1
  97. package/lib/{index-YAL4zolc.js → index-C9uGqcwH.js} +1 -1
  98. package/lib/{index-BQvEIlB2.mjs → index-CBGUPQXa.mjs} +3 -3
  99. package/lib/{index-IHxtA-NL.js → index-CGpn3INM.js} +1 -1
  100. package/lib/{index-DSmKiYkD.mjs → index-CQ0RB2r3.mjs} +5 -5
  101. package/lib/{index-7_BfcP8x.mjs → index-CR3DmYPt.mjs} +2105 -2021
  102. package/lib/{index-BRyW-hBN.mjs → index-CTpINVAG.mjs} +2 -2
  103. package/lib/{index-C3LC73WN.js → index-CbFvm_Mr.js} +1 -1
  104. package/lib/{index-bNUantLb.js → index-CjjP3Qp5.js} +1 -1
  105. package/lib/{index-DqzqJgVc.mjs → index-CkvxfaqA.mjs} +3 -3
  106. package/lib/{index-DfDB5FLw.js → index-ClMpLrxa.js} +1 -1
  107. package/lib/{index-B7VNYedX.mjs → index-CtU_hkYp.mjs} +4 -4
  108. package/lib/index-Cv9hvmqc.js +1 -0
  109. package/lib/{index-DMOY218i.js → index-CzRVzbTC.js} +1 -1
  110. package/lib/{index-B4S4sz6p.mjs → index-Czxl_5Tr.mjs} +5 -5
  111. package/lib/{index-Cb9lswnP.js → index-D61fXWwH.js} +8 -8
  112. package/lib/{index-D0XQIiQn.js → index-D6qJDbzm.js} +1 -1
  113. package/lib/{index-C3L-xKvN.mjs → index-DJs1h8_N.mjs} +4839 -4850
  114. package/lib/{index-BD0gcmCp.mjs → index-DPpi4Don.mjs} +5 -5
  115. package/lib/{index-D5ENAOm3.js → index-DmsirrTI.js} +1 -1
  116. package/lib/{index-DnO0ZdKy.mjs → index-DpN0dULN.mjs} +1 -1
  117. package/lib/{index-BNuKzxGJ.js → index-DydXCN0v.js} +1 -1
  118. package/lib/{index-D-H8WyKb.mjs → index-N8cPdMnf.mjs} +1 -1
  119. package/lib/{index-CSMunRpZ.mjs → index-NKV6j8zE.mjs} +3 -3
  120. package/lib/{index-BIYx5IBr.mjs → index-OlMuNft9.mjs} +3 -3
  121. package/lib/{index-Bz7ogqhR.mjs → index-UOvy4usi.mjs} +1 -1
  122. package/lib/{index-D1y-l93C.js → index-UbeUI3Ir.js} +1 -1
  123. package/lib/{index-BZYEbYGY.mjs → index-ZGgSxaDf.mjs} +3 -3
  124. package/lib/{index-DFpSbD7R.mjs → index-_e8uUnEK.mjs} +5 -5
  125. package/lib/{index-vhQ5Q8ov.mjs → index-dU3yVyBt.mjs} +52 -97
  126. package/lib/{index.es-C476iHvN.mjs → index.es-B5hLka3L.mjs} +4 -4
  127. package/lib/{index.es-CkGpObng.js → index.es-CSmeunOk.js} +3 -3
  128. package/lib/{index.es-CU6nhwJO.js → index.es-E2DQPkYK.js} +1 -1
  129. package/lib/{index.es-CtiAoQ78.mjs → index.es-Vlpe_OYB.mjs} +3 -3
  130. package/lib/index.js +1 -1
  131. package/lib/index.mjs +5 -5
  132. package/lib/mayan.js +1 -1
  133. package/lib/mayan.mjs +11 -11
  134. package/lib/{mint-zy6P38iu.js → mint-B4t2SvV6.js} +1 -1
  135. package/lib/{mint-DyoU9X22.mjs → mint-BGuU5y5m.mjs} +1 -1
  136. package/lib/ntt.js +1 -1
  137. package/lib/ntt.mjs +14 -12
  138. package/lib/{platform-x3ZBJ0YM.js → platform-Bkbg7A9d.js} +1 -1
  139. package/lib/{platform-BqpAMtgx.mjs → platform-C5gJAqtZ.mjs} +3 -3
  140. package/lib/{platform-BhspUaMJ.js → platform-C6QB7aIN.js} +1 -1
  141. package/lib/{platform-DQfpyXSV.mjs → platform-DBNvSsue.mjs} +4 -4
  142. package/lib/{platform-BHAZvZ_O.mjs → platform-DtB8gGMl.mjs} +4 -4
  143. package/lib/{platform-4nANkJAM.js → platform-qdbxkhTI.js} +1 -1
  144. package/lib/{provider-jsonrpc-DIXcAw4Q.mjs → provider-jsonrpc-BIIDy-Aw.mjs} +2 -2
  145. package/lib/{provider-jsonrpc-BCKoIijx.js → provider-jsonrpc-DHzam3ud.js} +1 -1
  146. package/lib/{secp256k1-CaaRyr2C.mjs → secp256k1-B-wUOgWh.mjs} +1 -1
  147. package/lib/{secp256k1-CFt7TfEF.js → secp256k1-BAjH_sHz.js} +1 -1
  148. package/lib/{secp256k1-UnRv5Suy.mjs → secp256k1-CpJIg24C.mjs} +1 -1
  149. package/lib/{secp256k1-C60XBS-e.js → secp256k1-Ds1M1Mtb.js} +1 -1
  150. package/lib/{secp256k1-BIiWvuxu.js → secp256k1-PbbUc2aU.js} +1 -1
  151. package/lib/{secp256k1-BWFGSbjt.mjs → secp256k1-YWWAmpaN.mjs} +1 -1
  152. package/lib/{signer-DhO2iGae.mjs → signer-BH3gAHuj.mjs} +2 -2
  153. package/lib/{signer-BFY1Ytf6.js → signer-MBixef_P.js} +1 -1
  154. package/lib/{solana-CQk4ocg8.mjs → solana-Bh5bkUXQ.mjs} +11 -11
  155. package/lib/solana-C8xK8qJY.mjs +18 -0
  156. package/lib/solana-CRSliekb.js +1 -0
  157. package/lib/{solana-Cp49k9--.js → solana-sjjxa4_B.js} +4 -4
  158. package/lib/{solanaEmbed.esm-Cwa6cl_R.js → solanaEmbed.esm-CDt8Bk0U.js} +1 -1
  159. package/lib/{solanaEmbed.esm-DBOqO9Ii.mjs → solanaEmbed.esm-DGgxfQDB.mjs} +3 -3
  160. package/lib/src/components/TokenBalance.d.ts.map +1 -1
  161. package/lib/src/config/mainnet/tokens.d.ts.map +1 -1
  162. package/lib/src/config/testnet/tokens.d.ts.map +1 -1
  163. package/lib/src/contexts/wallet/WalletProvider.d.ts.map +1 -1
  164. package/lib/src/hooks/useFetchSupportedRoutes.d.ts.map +1 -1
  165. package/lib/src/hooks/useTokenListWithSearch.d.ts +1 -4
  166. package/lib/src/hooks/useTokenListWithSearch.d.ts.map +1 -1
  167. package/lib/src/routes/operator.d.ts.map +1 -1
  168. package/lib/src/routes/sdkv2/route.d.ts +2 -2
  169. package/lib/src/routes/sdkv2/route.d.ts.map +1 -1
  170. package/lib/src/telemetry/types.d.ts +1 -0
  171. package/lib/src/telemetry/types.d.ts.map +1 -1
  172. package/lib/src/utils/sdkv2.d.ts.map +1 -1
  173. package/lib/src/utils/wrappedNativeTokens.d.ts +12 -0
  174. package/lib/src/utils/wrappedNativeTokens.d.ts.map +1 -0
  175. package/lib/src/views/Terms.d.ts.map +1 -1
  176. package/lib/src/views/v2/Bridge/AssetPicker/TokenList.d.ts.map +1 -1
  177. package/lib/src/views/v3/Bridge/AssetPicker/SearchableList/index.d.ts.map +1 -1
  178. package/lib/src/views/v3/Bridge/AssetPicker/TokenList.d.ts.map +1 -1
  179. package/lib/src/views/v3/Bridge/AssetPicker/TokenSectionHeader.d.ts +2 -4
  180. package/lib/src/views/v3/Bridge/AssetPicker/TokenSectionHeader.d.ts.map +1 -1
  181. package/lib/{sui-9gsoM56W.js → sui-Do5RtJvP.js} +1 -1
  182. package/lib/{sui-Cr98JBgS.js → sui-QcDjGW68.js} +1 -1
  183. package/lib/{sui-B4RvzEXx.mjs → sui-euceXgYf.mjs} +7 -7
  184. package/lib/{sui-C2a1eehP.mjs → sui-tKXg9e-c.mjs} +4 -4
  185. package/lib/{tokens-BbFKf6Hv.mjs → tokens-CNITO7DN.mjs} +3 -3
  186. package/lib/{tokens-LVHsSbYG.js → tokens-DhBcLH6x.js} +1 -1
  187. package/lib/{transfer-DZ-wNocj.js → transfer-BinEH6ml.js} +1 -1
  188. package/lib/{transfer-BV1ou1GP.mjs → transfer-DTvv5m_5.mjs} +2 -2
  189. package/lib/{units-BqUlbZ46.mjs → units-CVEv4txp.mjs} +2 -2
  190. package/lib/{units-D-oRQjOa.js → units-DtldPRXy.js} +1 -1
  191. package/lib/{unsignedTransaction-BmxD6VsY.mjs → unsignedTransaction-CVE7GUdC.mjs} +3 -3
  192. package/lib/{unsignedTransaction-CiPKh85X.js → unsignedTransaction-DL3WyIkF.js} +1 -1
  193. package/lib/{w3m-modal-CoTG8Zu4.js → w3m-modal-BUP-c20y.js} +1 -1
  194. package/lib/{w3m-modal-D4-nrnEK.mjs → w3m-modal-Bj2tG9wb.mjs} +2 -2
  195. package/lib/{w3m-modal-xqVExHU-.js → w3m-modal-CGeDlu49.js} +1 -1
  196. package/lib/{w3m-modal-3qLkbPfi.mjs → w3m-modal-D78VqEEI.mjs} +2 -2
  197. package/lib/{web3-C1wK6wIV.js → web3-BKaP497Y.js} +1 -1
  198. package/lib/{web3-BkEb7AgB.mjs → web3-BifDBsFp.mjs} +8 -4
  199. package/package.json +49 -44
  200. package/dist/assets/create-q7V6muDT.js +0 -1
  201. package/dist/assets/index-B59bCuJJ.js +0 -1
  202. package/lib/constants-BR_zyzqY.js +0 -1
  203. package/lib/index-CXsUtRJQ.js +0 -1
  204. package/lib/solana-Dv_mUYcl.mjs +0 -18
  205. package/lib/solana-g3YsP966.js +0 -1
@@ -1 +1 @@
1
- import{h as P,i as Ce,j as rn,n as sn,k as te,l as an,e as Q,f as Y,B as on,m as cn,o as un,p as Be,q as Et,S as Wt,r as dn,s as ln}from"./index-DZpeOp3V.js";import{P as c,k as l,cT as m,T as fe,cV as O,cW as $,cU as M,dq as W,dl as v,cY as w,aX as mn,db as _t,dr as Ue,dm as B,bh as S,da as Ne,d0 as gn,aT as q,cP as xe,K as ie,ae as D,ds as fn,de as hn,df as dt,dg as pn,dh as yn,di as wn,aj as lt,V as mt,cN as Sn,d4 as Oe,bi as ze}from"../main.js";import{P as ke,c as Mn}from"./index-g9iLhWvp.js";import{b as Z,e as Le}from"./signer-Dl8_VMmx.js";import"./create-q7V6muDT.js";import"./chain-gFcyni6Z.js";const A=new c("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA");new c("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb");const H=new c("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"),F=new c("So11111111111111111111111111111111111111112");new c("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class oe extends Error{constructor(e){super(e)}}class qe extends oe{constructor(){super(...arguments),this.name="TokenAccountNotFoundError"}}class kn extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountError"}}class Nt extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountOwnerError"}}class le extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountSizeError"}}class An extends oe{constructor(){super(...arguments),this.name="TokenInvalidMintError"}}class Ft extends oe{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}var ae;(function(t){t[t.InitializeMint=0]="InitializeMint",t[t.InitializeAccount=1]="InitializeAccount",t[t.InitializeMultisig=2]="InitializeMultisig",t[t.Transfer=3]="Transfer",t[t.Approve=4]="Approve",t[t.Revoke=5]="Revoke",t[t.SetAuthority=6]="SetAuthority",t[t.MintTo=7]="MintTo",t[t.Burn=8]="Burn",t[t.CloseAccount=9]="CloseAccount",t[t.FreezeAccount=10]="FreezeAccount",t[t.ThawAccount=11]="ThawAccount",t[t.TransferChecked=12]="TransferChecked",t[t.ApproveChecked=13]="ApproveChecked",t[t.MintToChecked=14]="MintToChecked",t[t.BurnChecked=15]="BurnChecked",t[t.InitializeAccount2=16]="InitializeAccount2",t[t.SyncNative=17]="SyncNative",t[t.InitializeAccount3=18]="InitializeAccount3",t[t.InitializeMultisig2=19]="InitializeMultisig2",t[t.InitializeMint2=20]="InitializeMint2",t[t.GetAccountDataSize=21]="GetAccountDataSize",t[t.InitializeImmutableOwner=22]="InitializeImmutableOwner",t[t.AmountToUiAmount=23]="AmountToUiAmount",t[t.UiAmountToAmount=24]="UiAmountToAmount",t[t.InitializeMintCloseAuthority=25]="InitializeMintCloseAuthority",t[t.TransferFeeExtension=26]="TransferFeeExtension",t[t.ConfidentialTransferExtension=27]="ConfidentialTransferExtension",t[t.DefaultAccountStateExtension=28]="DefaultAccountStateExtension",t[t.Reallocate=29]="Reallocate",t[t.MemoTransferExtension=30]="MemoTransferExtension",t[t.CreateNativeMint=31]="CreateNativeMint",t[t.InitializeNonTransferableMint=32]="InitializeNonTransferableMint",t[t.InterestBearingMintExtension=33]="InterestBearingMintExtension",t[t.CpiGuardExtension=34]="CpiGuardExtension",t[t.InitializePermanentDelegate=35]="InitializePermanentDelegate",t[t.TransferHookExtension=36]="TransferHookExtension",t[t.MetadataPointerExtension=39]="MetadataPointerExtension"})(ae||(ae={}));function De(t,e,r){if(r.length){t.push({pubkey:e,isSigner:!1,isWritable:!1});for(const n of r)t.push({pubkey:n instanceof c?n:n.publicKey,isSigner:!0,isWritable:!1})}else t.push({pubkey:e,isSigner:!0,isWritable:!1});return t}const gt=m.struct([m.u8("instruction"),O("amount")]);function Tn(t,e,r,n,i=[],s=A){const o=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1}],r,i),a=l.alloc(gt.span);return gt.encode({instruction:ae.Approve,amount:BigInt(n)},a),new fe({keys:o,programId:s,data:a})}const ft=m.struct([m.u8("instruction")]);function ht(t,e,r,n=[],i=A){const s=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,n),o=l.alloc(ft.span);return ft.encode({instruction:ae.CloseAccount},o),new fe({keys:s,programId:i,data:o})}var Ae;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Mint=1]="Mint",t[t.Account=2]="Account"})(Ae||(Ae={}));const Ke=1,bn=m.struct([m.u8("m"),m.u8("n"),$("isInitialized"),M("signer1"),M("signer2"),M("signer3"),M("signer4"),M("signer5"),M("signer6"),M("signer7"),M("signer8"),M("signer9"),M("signer10"),M("signer11")]),Ve=bn.span;var Te;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Initialized=1]="Initialized",t[t.Frozen=2]="Frozen"})(Te||(Te={}));const Ut=m.struct([M("mint"),M("owner"),O("amount"),m.u32("delegateOption"),M("delegate"),m.u8("state"),m.u32("isNativeOption"),O("isNative"),O("delegatedAmount"),m.u32("closeAuthorityOption"),M("closeAuthority")]),U=Ut.span;async function Cn(t,e,r,n=A){const i=await t.getAccountInfo(e,r);return vn(e,i,n)}async function pt(t,e){return await Bn(t,[],e)}async function Bn(t,e,r){const n=or(e);return await t.getMinimumBalanceForRentExemption(n,r)}function vn(t,e,r=A){if(!e)throw new qe;if(!e.owner.equals(r))throw new Nt;if(e.data.length<U)throw new le;const n=Ut.decode(e.data.slice(0,U));let i=l.alloc(0);if(e.data.length>U){if(e.data.length===Ve)throw new le;if(e.data[U]!=Ae.Account)throw new kn;i=e.data.slice(U+Ke)}return{address:t,mint:n.mint,owner:n.owner,amount:n.amount,delegate:n.delegateOption?n.delegate:null,delegatedAmount:n.delegatedAmount,isInitialized:n.state!==Te.Uninitialized,isFrozen:n.state===Te.Frozen,isNative:!!n.isNativeOption,rentExemptReserve:n.isNativeOption?n.isNative:null,closeAuthority:n.closeAuthorityOption?n.closeAuthority:null,tlvData:i}}const xt=m.struct([m.u32("mintAuthorityOption"),M("mintAuthority"),O("supply"),m.u8("decimals"),$("isInitialized"),m.u32("freezeAuthorityOption"),M("freezeAuthority")]),Fe=xt.span;async function Pn(t,e,r,n=A){const i=await t.getAccountInfo(e,r);return In(e,i,n)}function In(t,e,r=A){if(!e)throw new qe;if(!e.owner.equals(r))throw new Nt;if(e.data.length<Fe)throw new le;const n=xt.decode(e.data.slice(0,Fe));let i=l.alloc(0);if(e.data.length>Fe){if(e.data.length<=U)throw new le;if(e.data.length===Ve)throw new le;if(e.data[U]!=Ae.Mint)throw new An;i=e.data.slice(U+Ke)}return{address:t,mintAuthority:n.mintAuthorityOption?n.mintAuthority:null,supply:n.supply,decimals:n.decimals,isInitialized:n.isInitialized,freezeAuthority:n.freezeAuthorityOption?n.freezeAuthority:null,tlvData:i}}async function yt(t,e,r=!1,n=A,i=H){if(!r&&!c.isOnCurve(e.toBuffer()))throw new Ft;const[s]=await c.findProgramAddress([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}function V(t,e,r=!1,n=A,i=H){if(!r&&!c.isOnCurve(e.toBuffer()))throw new Ft;const[s]=c.findProgramAddressSync([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}const Rn=m.struct([$("lockCpi")]),En=Rn.span,Wn=m.struct([m.u8("state")]),_n=Wn.span,Nn=m.struct([]),Fn=Nn.span,Un=m.struct([M("rateAuthority"),m.ns64("initializationTimestamp"),m.s16("preUpdateAverageRate"),m.ns64("lastUpdateTimestamp"),m.s16("currentRate")]),xn=Un.span,On=m.struct([$("requireIncomingTransferMemos")]),zn=On.span,Ln=m.struct([M("authority"),M("metadataAddress")]),qn=Ln.span,Dn=m.struct([M("closeAuthority")]),Kn=Dn.span,Ot=m.struct([]),Vn=Ot.span,Gn=Ot.span,Zn=m.struct([M("delegate")]),Hn=Zn.span,Qn=1e4;BigInt(Qn);function wt(t){return m.struct([O("epoch"),O("maximumFee"),m.u16("transferFeeBasisPoints")],t)}const Yn=m.struct([M("transferFeeConfigAuthority"),M("withdrawWithheldAuthority"),O("withheldAmount"),wt("olderTransferFee"),wt("newerTransferFee")]),$n=Yn.span,Xn=m.struct([O("withheldAmount")]),Jn=Xn.span,jn=m.struct([M("authority"),M("programId")]),er=jn.span,tr=m.struct([$("transferring")]),nr=tr.span,St=m.struct([m.u8("discriminator"),m.blob(32,"addressConfig"),$("isSigner"),$("isWritable")]),rr=m.struct([m.u32("count"),m.seq(St,m.greedy(St.span),"extraAccounts")]);m.struct([O("instructionDiscriminator"),m.u32("length"),rr.replicate("extraAccountsList")]);var b;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.TransferFeeConfig=1]="TransferFeeConfig",t[t.TransferFeeAmount=2]="TransferFeeAmount",t[t.MintCloseAuthority=3]="MintCloseAuthority",t[t.ConfidentialTransferMint=4]="ConfidentialTransferMint",t[t.ConfidentialTransferAccount=5]="ConfidentialTransferAccount",t[t.DefaultAccountState=6]="DefaultAccountState",t[t.ImmutableOwner=7]="ImmutableOwner",t[t.MemoTransfer=8]="MemoTransfer",t[t.NonTransferable=9]="NonTransferable",t[t.InterestBearingConfig=10]="InterestBearingConfig",t[t.CpiGuard=11]="CpiGuard",t[t.PermanentDelegate=12]="PermanentDelegate",t[t.NonTransferableAccount=13]="NonTransferableAccount",t[t.TransferHook=14]="TransferHook",t[t.TransferHookAccount=15]="TransferHookAccount",t[t.MetadataPointer=18]="MetadataPointer"})(b||(b={}));const Mt=2,ir=2;function sr(t){switch(t){case b.Uninitialized:return 0;case b.TransferFeeConfig:return $n;case b.TransferFeeAmount:return Jn;case b.MintCloseAuthority:return Kn;case b.ConfidentialTransferMint:return 97;case b.ConfidentialTransferAccount:return 286;case b.CpiGuard:return En;case b.DefaultAccountState:return _n;case b.ImmutableOwner:return Fn;case b.MemoTransfer:return zn;case b.MetadataPointer:return qn;case b.NonTransferable:return Vn;case b.InterestBearingConfig:return xn;case b.PermanentDelegate:return Hn;case b.NonTransferableAccount:return Gn;case b.TransferHook:return er;case b.TransferHookAccount:return nr;default:throw Error(`Unknown extension type: ${t}`)}}function ar(t,e){if(t.length===0)return e;{const r=U+Ke+t.filter((n,i)=>i===t.indexOf(n)).map(n=>sr(n)+Mt+ir).reduce((n,i)=>n+i);return r===Ve?r+Mt:r}}function or(t){return ar(t,U)}const kt=m.struct([m.u8("instruction")]);function At(t,e,r,n=A){const i=[{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:W,isSigner:!1,isWritable:!1}],s=l.alloc(kt.span);return kt.encode({instruction:ae.InitializeAccount},s),new fe({keys:i,programId:n,data:s})}function zt(t,e,r,n,i=A,s=H){return Lt(t,e,r,n,l.alloc(0),i,s)}function cr(t,e,r,n,i=A,s=H){return Lt(t,e,r,n,l.from([1]),i,s)}function Lt(t,e,r,n,i,s=A,o=H){const a=[{pubkey:t,isSigner:!0,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:n,isSigner:!1,isWritable:!1},{pubkey:v.programId,isSigner:!1,isWritable:!1},{pubkey:s,isSigner:!1,isWritable:!1}];return new fe({keys:a,programId:o,data:i})}const Tt=m.struct([m.u8("instruction"),O("amount")]);function qt(t,e,r,n,i=[],s=A){const o=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,i),a=l.alloc(Tt.span);return Tt.encode({instruction:ae.Transfer,amount:BigInt(n)},a),new fe({keys:o,programId:s,data:a})}function Ge(t,e){const r=l.alloc(2);return r.writeUInt16BE(w(e)),P([l.from("foreign_contract"),r],t)}function ur(t){return P([l.from("redeemer")],t)}function Ze(t,e){return P([l.from("mint"),new c(e).toBuffer()],t)}function Dt(t){return P([l.from("sender")],t)}function Kt(t,e){return P([l.from("tmp"),new c(e).toBuffer()],t)}function Vt(t,e,r){return P([l.from("bridged"),new c(e).toBuffer(),l.from(mn.toBytes(BigInt(r.toString()),8))],t)}function _(t){return P([l.from("config")],t)}async function ti(t,e,r){return t.getAccountInfo(_(e),r).then(n=>He.deserialize(Ce(n)))}class He{wormhole;constructor(e){this.wormhole=new c(e)}static deserialize(e){if(e.length!=32)throw new Error("data.length != 32");const r=e.subarray(0,32);return new He(r)}}function ve(t,e){return P([new c(e).toBuffer()],t)}function X(t,e,r){const n=typeof r=="string"?new _t(r).toUint8Array():r;return P([(()=>{const i=l.alloc(2);return i.writeUInt16BE(e),i})(),n],t)}async function ni(t,e,r){return t.getAccountInfo(new c(e),r).then(n=>Qe.deserialize(Ce(n)))}class Qe{chain;contract;constructor(e,r){this.chain=e,this.contract=r}static deserialize(e){if(e.length!=34)throw new Error("data.length != 34");const r=e.readUInt16LE(0),n=e.subarray(2,34);return new Qe(r,n)}}function Ye(t){return P([l.from("sender")],t)}function $e(t){return P([l.from("redeemer")],t)}function ce(t){return P([l.from("authority_signer")],t)}function he(t){return P([l.from("custody_signer")],t)}function pe(t){return P([l.from("mint_signer")],t)}function ue(t,e,r){return P([l.from("wrapped"),(()=>{const n=l.alloc(2);return n.writeUInt16BE(e),n})(),r],t)}function K(t,e){return P([l.from("meta"),new c(e).toBuffer()],t)}async function Me(t,e,r,n){return t.getAccountInfo(K(e,r),n).then(i=>Xe.deserialize(Ce(i)))}class Xe{chain;tokenAddress;originalDecimals;lastUpdatedSequence;constructor(e,r,n,i){this.chain=e,this.tokenAddress=r,this.originalDecimals=n,this.lastUpdatedSequence=i}static deserialize(e){if(e.length!==35&&e.length!==43)throw new Error(`invalid wrapped meta length: ${e.length}`);const r=e.readUInt16LE(0),n=e.subarray(2,34),i=e.readUInt8(34),s=e.length===43?e.readBigUInt64LE(35):void 0;return new Xe(r,n,i,s)}}function bt(t,e,r,n){return Tn(new c(e),ce(t),new c(r),n)}class dr{idl;constructor(e){this.idl=e}async encode(e,r){throw new Error(`Invalid account name: ${e}`)}decode(e,r){return this.decodeUnchecked(e,r)}decodeUnchecked(e,r){throw new Error(`Invalid account name: ${e}`)}memcmp(e,r){throw new Error(`Invalid account name: ${e}`)}size(e){return rn(this.idl,e)??0}}class lr{constructor(e){}decode(e){throw new Error("Token Bridge program does not have events")}}class mr{constructor(e){}encode(e,r){switch(e){case"initialize":return gr(r);case"attestToken":return fr(r);case"completeNative":return hr(r);case"completeWrapped":return pr(r);case"transferWrapped":return yr(r);case"transferNative":return wr(r);case"registerChain":return Sr(r);case"createWrapped":return Mr(r);case"upgradeContract":return kr(r);case"transferWrappedWithPayload":return Ar(r);case"transferNativeWithPayload":return Tr(r);default:throw new Error(`Invalid instruction: ${e}`)}}encodeState(e,r){throw new Error("Token Bridge program does not have state")}}var N;(function(t){t[t.Initialize=0]="Initialize",t[t.AttestToken=1]="AttestToken",t[t.CompleteNative=2]="CompleteNative",t[t.CompleteWrapped=3]="CompleteWrapped",t[t.TransferWrapped=4]="TransferWrapped",t[t.TransferNative=5]="TransferNative",t[t.RegisterChain=6]="RegisterChain",t[t.CreateWrapped=7]="CreateWrapped",t[t.UpgradeContract=8]="UpgradeContract",t[t.CompleteNativeWithPayload=9]="CompleteNativeWithPayload",t[t.CompleteWrappedWithPayload=10]="CompleteWrappedWithPayload",t[t.TransferWrappedWithPayload=11]="TransferWrappedWithPayload",t[t.TransferNativeWithPayload=12]="TransferNativeWithPayload"})(N||(N={}));function z(t,e){const r=e===void 0?0:e.length,n=l.alloc(1+r);return n.writeUInt8(t,0),r>0&&n.write(e.toString("hex"),1,"hex"),n}function gr({wormhole:t}){const e=l.alloc(32);return e.write(new c(t).toBuffer().toString("hex"),0,"hex"),z(N.Initialize,e)}function fr({nonce:t}){const e=l.alloc(4);return e.writeUInt32LE(t,0),z(N.AttestToken,e)}function hr({}){return z(N.CompleteNative)}function pr({}){return z(N.CompleteWrapped)}function Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){if(typeof e!="bigint"&&(e=BigInt(e)),typeof r!="bigint"&&(r=BigInt(r)),!l.isBuffer(n))throw new Error("targetAddress must be Buffer");const s=l.alloc(54);return s.writeUInt32LE(t,0),s.writeBigUInt64LE(e,4),s.writeBigUInt64LE(r,12),s.write(n.toString("hex"),20,"hex"),s.writeUInt16LE(i,52),s}function yr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return z(N.TransferWrapped,Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function wr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return z(N.TransferNative,Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Sr({}){return z(N.RegisterChain)}function Mr({}){return z(N.CreateWrapped)}function kr({}){return z(N.UpgradeContract)}function Zt({nonce:t,amount:e,targetAddress:r,targetChain:n,payload:i}){if(typeof e!="bigint"&&(e=BigInt(e)),!l.isBuffer(r))throw new Error("targetAddress must be Buffer");if(!l.isBuffer(i))throw new Error("payload must be Buffer");const s=l.alloc(50);return s.writeUInt32LE(t,0),s.writeBigUInt64LE(e,4),s.write(r.toString("hex"),12,"hex"),s.writeUInt16LE(n,44),s.writeUInt32LE(i.length,46),l.concat([s,i,l.alloc(1)])}function Ar({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return z(N.TransferWrappedWithPayload,Zt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}function Tr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return z(N.TransferNativeWithPayload,Zt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}class br{constructor(e){}encode(e,r){throw new Error("Token Bridge program does not have state")}decode(e){throw new Error("Token Bridge program does not have state")}}class Cr{constructor(e){}encode(e,r){throw new Error("Token Bridge program does not have user-defined types")}decode(e,r){throw new Error("Token Bridge program does not have user-defined types")}}class Br{instruction;accounts;state;events;types;constructor(e){this.instruction=new mr(e),this.accounts=new dr(e),this.state=new br(e),this.events=new lr(e),this.types=new Cr(e)}}const Ht={version:"0.1.0",name:"wormhole",instructions:[{name:"initialize",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"wormhole",type:"publicKey"}]},{name:"attestToken",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!0,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"splMetadata",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"}]},{name:"completeNative",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"to",isMut:!0,isSigner:!1},{name:"toFees",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"rent",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"completeWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"to",isMut:!0,isSigner:!1},{name:"toFees",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"mintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"transferWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"fromOwner",isMut:!0,isSigner:!0},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"fee",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"}]},{name:"transferNative",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"fee",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"}]},{name:"registerChain",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"endpoint",isMut:!0,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"createWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!0,isSigner:!1},{name:"splMetadata",isMut:!0,isSigner:!1},{name:"mintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"splMetadataProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"upgradeContract",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"upgradeAuthority",isMut:!1,isSigner:!1},{name:"spill",isMut:!0,isSigner:!1},{name:"implementation",isMut:!0,isSigner:!1},{name:"programData",isMut:!0,isSigner:!1},{name:"tokenBridgeProgram",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"bpfLoaderUpgradeable",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[]},{name:"transferWrappedWithPayload",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"fromOwner",isMut:!0,isSigner:!0},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"sender",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"},{name:"payload",type:"bytes"},{name:"cpiProgramId",type:{option:"publicKey"}}]},{name:"transferNativeWithPayload",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"sender",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"},{name:"payload",type:"bytes"},{name:"cpiProgramId",type:{option:"publicKey"}}]}],accounts:[]};function vr(t,e){return new ke(Ht,new c(t),e===void 0?{connection:null}:e,Pr())}function x(t,e){return vr(t,Mn(e))}function Pr(){return new Br(Ht)}class G{address;verified;share;constructor(e,r,n){this.address=new c(e),this.verified=r,this.share=n}static size=34;serialize(){const e=l.alloc(G.size);return e.write(this.address.toBuffer().toString("hex"),0,"hex"),this.verified&&e.writeUInt8(1,32),e.writeUInt8(this.share,33),e}static deserialize(e){const r=e.subarray(0,32),n=e.readUInt8(32)>0,i=e.readUInt8(33);return new G(r,n,i)}}class Pe{name;symbol;uri;sellerFeeBasisPoints;creators;constructor(e,r,n,i,s){this.name=e,this.symbol=r,this.uri=n,this.sellerFeeBasisPoints=i,this.creators=s}serialize(){const e=this.name.length,r=this.symbol.length,n=this.uri.length,i=this.creators,[s,o]=(()=>{if(i===null)return[0,0];const d=i.length;return[d,4+d*G.size]})(),a=l.alloc(15+e+r+n+o);if(a.writeUInt32LE(e,0),a.write(this.name,4),a.writeUInt32LE(r,4+e),a.write(this.symbol,8+e),a.writeUInt32LE(n,8+e+r),a.write(this.uri,12+e+r),a.writeUInt16LE(this.sellerFeeBasisPoints,12+e+r+n),i===null)a.writeUInt8(0,14+e+r+n);else{a.writeUInt8(1,14+e+r+n),a.writeUInt32LE(s,15+e+r+n);for(let d=0;d<s;++d){const u=i.at(d),g=19+e+r+n+d*G.size;a.write(u.serialize().toString("hex"),g,"hex")}}return a}static deserialize(e){const r=e.readUInt32LE(0),n=e.subarray(4,4+r).toString(),i=e.readUInt32LE(4+r),s=e.subarray(8+r,8+r+i).toString(),o=e.readUInt32LE(8+r+i),a=e.subarray(12+r+i,12+r+i+o).toString(),d=e.readUInt16LE(12+r+i+o),u=e.readUInt8(14+r+i+o),g=(()=>{if(u==0)return null;const f=[],h=e.readUInt32LE(15+r+i+o);for(let y=0;y<h;++y){const p=19+r+i+o+y*G.size;f.push(G.deserialize(e.subarray(p,p+G.size)))}return f})();return new Pe(n,s,a,d,g)}}class be extends Pe{isMutable;constructor(e,r,n,i,s,o){super(e,r,n,i,s),this.isMutable=o}static serialize(e,r,n,i,s,o){return new be(e,r,n,i,s,o).serialize()}static serializeInstructionData(e,r,n,i,s,o){return l.concat([l.alloc(1,0),be.serialize(e,r,n,i,s,o)])}serialize(){return l.concat([super.serialize(),l.alloc(1,this.isMutable?1:0)])}}class me{constructor(){}static programId=new c("metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s");static createMetadataAccounts(e,r,n,i,s,o,a=!1,d,u,g,f=!1,h=Ie(r)){const y=[sn(h,!1),te(r,!1),te(n,!0),te(e,!0),te(o,a),te(v.programId,!1),te(W,!1)],p=be.serializeInstructionData(i,s,d===void 0?"":d,g===void 0?0:g,u===void 0?null:u,f);return{programId:me.programId,keys:y,data:p}}}function Ie(t){return P([l.from("metadata"),me.programId.toBuffer(),new c(t).toBuffer()],me.programId)}var Ct;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.EditionV1=1]="EditionV1",t[t.MasterEditionV1=2]="MasterEditionV1",t[t.ReservationListV1=3]="ReservationListV1",t[t.MetadataV1=4]="MetadataV1",t[t.ReservationListV2=5]="ReservationListV2",t[t.MasterEditionV2=6]="MasterEditionV2",t[t.EditionMarker=7]="EditionMarker"})(Ct||(Ct={}));class Je{key;updateAuthority;mint;data;primarySaleHappened;isMutable;constructor(e,r,n,i,s,o){this.key=e,this.updateAuthority=new c(r),this.mint=new c(n),this.data=i,this.primarySaleHappened=s,this.isMutable=o}static deserialize(e){const r=e.readUInt8(0),n=e.subarray(1,33),i=e.subarray(33,65),s=Pe.deserialize(e.subarray(65)),o=s.serialize().length,a=e.readUInt8(65+o)>0,d=e.readUInt8(66+o)>0;return new Je(r,n,i,s,a,d)}}async function ri(t,e,r){return t.getAccountInfo(Ie(e),r).then(n=>Je.deserialize(Ce(n)))}function Ir(t,e,r,n,i,s,o){const a=x(e,t).methods.attestToken(o);return console.log(Bt(e,r,n,i,s)),a._ixFn(...a._args,{accounts:Bt(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Bt(t,e,r,n,i){const{bridge:s,emitter:o,sequence:a,feeCollector:d,clock:u,rent:g,systemProgram:f}=an(e,r,i,t);return{payer:new c(r),config:_(t),mint:new c(n),wrappedMeta:K(t,n),splMetadata:Ie(n),wormholeBridge:s,wormholeMessage:new c(i),wormholeEmitter:o,wormholeSequence:a,wormholeFeeCollector:d,clock:u,rent:g,systemProgram:f,wormholeProgram:new c(e)}}function vt(t,e,r,n,i,s){const o=x(e,t).methods.completeNative();return o._ixFn(...o._args,{accounts:Rr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Rr(t,e,r,n,i){const s=new c(n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),to:new c(n.payload.to.address.toUint8Array()),toFees:new c(i===void 0?n.payload.to.address.toUint8Array():i),custody:ve(t,s),mint:s,custodySigner:he(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function Er(t,e,r,n,i,s){const o=x(e,t).methods.completeWrapped();return o._ixFn(...o._args,{accounts:Wr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Wr(t,e,r,n,i){const s=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),to:new c(n.payload.to.address.toUint8Array()),toFees:new c(i===void 0?n.payload.to.address.toUint8Array():i),mint:s,wrappedMeta:K(t,s),mintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function _r(t,e,r,n,i){const s=x(e,t).methods.createWrapped();return s._ixFn(...s._args,{accounts:Nr(e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Nr(t,e,r,n){const i=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),mint:i,wrappedMeta:K(t,i),splMetadata:Ie(i),mintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,splMetadataProgram:me.programId,wormholeProgram:new c(e)}}function ii(t,e,r){const n=x(t).methods.initialize(r);return n._ixFn(...n._args,{accounts:Fr(t,e),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Fr(t,e){return{payer:new c(e),config:_(t),rent:W,systemProgram:v.programId}}function si(t,e,r,n){const i=x(t).methods.registerChain();return i._ixFn(...i._args,{accounts:Ur(t,e,r,n),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Ur(t,e,r,n){return{payer:new c(r),config:_(t),endpoint:X(t,w(n.payload.actionArgs.foreignChain),n.payload.actionArgs.foreignAddress.toUint8Array()),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),rent:W,systemProgram:v.programId,wormholeProgram:new c(e)}}function ai(t,e,r,n,i){const s=x(t).methods.upgradeContract();return s._ixFn(...s._args,{accounts:xr(t,e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function xr(t,e,r,n,i){return{payer:new c(r),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),upgradeAuthority:un(t),spill:new c(i===void 0?r:i),implementation:new c(n.payload.actionArgs.newContract),programData:cn(t),tokenBridgeProgram:new c(t),rent:W,clock:Ue,bpfLoaderUpgradeable:on,systemProgram:v.programId}}function Pt(t,e,r,n,i,s,o,a,d,u,g,f){const h=x(e,t).methods.transferNative(a,d,u,l.from(g),f);return h._ixFn(...h._args,{accounts:Or(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Or(t,e,r,n,i,s){const{wormholeBridge:o,wormholeMessage:a,wormholeEmitter:d,wormholeSequence:u,wormholeFeeCollector:g,clock:f,rent:h,systemProgram:y}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),mint:new c(s),custody:ve(t,s),authoritySigner:ce(t),custodySigner:he(t),wormholeBridge:o,wormholeMessage:a,wormholeEmitter:d,wormholeSequence:u,wormholeFeeCollector:g,clock:f,rent:h,systemProgram:y,tokenProgram:A,wormholeProgram:new c(e)}}function It(t,e,r,n,i,s,o,a,d,u,g,f){const h=x(e,t).methods.transferNativeWithPayload(a,d,l.from(u),g,l.from(f),null);return h._ixFn(...h._args,{accounts:Qt(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Qt(t,e,r,n,i,s,o){const{wormholeBridge:a,wormholeMessage:d,wormholeEmitter:u,wormholeSequence:g,wormholeFeeCollector:f,clock:h,rent:y,systemProgram:p}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),mint:new c(s),custody:ve(t,s),authoritySigner:ce(t),custodySigner:he(t),wormholeBridge:a,wormholeMessage:d,wormholeEmitter:u,wormholeSequence:g,wormholeFeeCollector:f,clock:h,sender:new c(o===void 0?r:Ye(o)),rent:y,systemProgram:p,tokenProgram:A,wormholeProgram:new c(e)}}function zr(t,e,r,n,i,s,o,a,d,u,g,f,h,y){const p=x(e,t).methods.transferWrapped(u,g,f,l.from(h),y);return p._ixFn(...p._args,{accounts:Lr(e,r,n,i,s,o,a,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Lr(t,e,r,n,i,s,o,a){const d=ue(t,o,a),{wormholeBridge:u,wormholeMessage:g,wormholeEmitter:f,wormholeSequence:h,wormholeFeeCollector:y,clock:p,rent:T,systemProgram:C}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),fromOwner:new c(s),mint:d,wrappedMeta:K(t,d),authoritySigner:ce(t),wormholeBridge:u,wormholeMessage:g,wormholeEmitter:f,wormholeSequence:h,wormholeFeeCollector:y,clock:p,rent:T,systemProgram:C,wormholeProgram:new c(e),tokenProgram:A}}function qr(t,e,r,n,i,s,o,a,d,u,g,f,h,y){const p=x(e,t).methods.transferWrappedWithPayload(u,g,l.from(f),h,l.from(y),null);return p._ixFn(...p._args,{accounts:Yt(e,r,n,i,s,o,a,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Yt(t,e,r,n,i,s,o,a,d){const u=ue(t,o,a),{wormholeBridge:g,wormholeMessage:f,wormholeEmitter:h,wormholeSequence:y,wormholeFeeCollector:p,clock:T,rent:C,systemProgram:R}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),fromOwner:new c(s),mint:u,wrappedMeta:K(t,u),authoritySigner:ce(t),wormholeBridge:g,wormholeMessage:f,wormholeEmitter:h,wormholeSequence:y,wormholeFeeCollector:p,clock:T,sender:new c(d===void 0?r:Ye(d)),rent:C,systemProgram:R,wormholeProgram:new c(e),tokenProgram:A}}function oi(t,e,r){const{wormholeEmitter:n,wormholeBridge:i,wormholeFeeCollector:s,wormholeSequence:o}=Et(e,r);return{tokenBridgeConfig:_(e),tokenBridgeAuthoritySigner:ce(e),tokenBridgeCustodySigner:he(e),tokenBridgeMintAuthority:pe(e),tokenBridgeSender:Ye(t),tokenBridgeRedeemer:$e(t),wormholeBridge:i,tokenBridgeEmitter:n,wormholeFeeCollector:s,tokenBridgeSequence:o}}function Dr(t,e,r,n,i,s,o){const a=Qt(e,r,n,i,s,o,t);return{payer:a.payer,tokenBridgeConfig:a.config,fromTokenAccount:a.from,mint:a.mint,tokenBridgeCustody:a.custody,tokenBridgeAuthoritySigner:a.authoritySigner,tokenBridgeCustodySigner:a.custodySigner,wormholeBridge:a.wormholeBridge,wormholeMessage:a.wormholeMessage,tokenBridgeEmitter:a.wormholeEmitter,tokenBridgeSequence:a.wormholeSequence,wormholeFeeCollector:a.wormholeFeeCollector,clock:a.clock,tokenBridgeSender:a.sender,rent:a.rent,systemProgram:a.systemProgram,tokenProgram:a.tokenProgram,wormholeProgram:a.wormholeProgram}}function Kr(t,e,r,n,i,s,o,a,d){const u=Yt(e,r,n,i,s,d===void 0?t:d,o,a,t);return{payer:u.payer,tokenBridgeConfig:u.config,fromTokenAccount:u.from,fromTokenAccountOwner:u.fromOwner,tokenBridgeWrappedMint:u.mint,tokenBridgeWrappedMeta:u.wrappedMeta,tokenBridgeAuthoritySigner:u.authoritySigner,wormholeBridge:u.wormholeBridge,wormholeMessage:u.wormholeMessage,tokenBridgeEmitter:u.wormholeEmitter,tokenBridgeSequence:u.wormholeSequence,wormholeFeeCollector:u.wormholeFeeCollector,clock:u.clock,tokenBridgeSender:u.sender,rent:u.rent,systemProgram:u.systemProgram,tokenProgram:u.tokenProgram,wormholeProgram:u.wormholeProgram}}function ci(t,e,r,n,i){const s=new c(n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:_(t),vaa:Y(e,l.from(n.hash)),tokenBridgeClaim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:$e(o),toFeesTokenAccount:new c(i),tokenBridgeCustody:ve(t,s),mint:s,tokenBridgeCustodySigner:he(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function ui(t,e,r,n,i){const s=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:_(t),vaa:Y(e,l.from(n.hash)),tokenBridgeClaim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:$e(o),toFeesTokenAccount:new c(i),tokenBridgeWrappedMint:s,tokenBridgeWrappedMeta:K(t,s),tokenBridgeMintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}const Vr={version:"0.1.0",name:"token_bridge_relayer",constants:[{name:"SEED_PREFIX_BRIDGED",type:"bytes",value:"[98, 114, 105, 100, 103, 101, 100]"},{name:"SEED_PREFIX_TMP",type:"bytes",value:"[116, 109, 112]"},{name:"SWAP_RATE_PRECISION",type:"u32",value:"100_000_000"}],instructions:[{name:"initialize",docs:["This instruction is be used to generate your program's config.","And for convenience, we will store Wormhole-related PDAs in the","config so we can verify these accounts with a simple == constraint.","# Arguments","","* `ctx` - `Initialize` context","* `fee_recipient` - Recipient of all relayer fees and swap proceeds","* `assistant` - Privileged key to manage certain accounts"],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Deployer of the program."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account, which saves program data useful for other","instructions, specifically for outbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account, which saves program data useful for other","instructions, specifically for inbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner config account, which saves the owner, assistant and","pending owner keys. This account is used to manage the ownership of the","program."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1,docs:["that holds data; it is purely just a signer for posting Wormhole","messages on behalf of the Token Bridge program."]},{name:"tokenBridgeSequence",isMut:!1,isSigner:!1,docs:["Token Bridge emitter's sequence account. Like with all Wormhole","emitters, this account keeps track of the sequence number of the last","posted message."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]},{name:"programData",isMut:!0,isSigner:!1,docs:["upgrade authority. We check this PDA address just in case there is another program that this","deployer has deployed.","","NOTE: Set upgrade authority is scary because any public key can be used to set as the","authority."]},{name:"bpfLoaderUpgradeableProgram",isMut:!1,isSigner:!1}],args:[{name:"feeRecipient",type:"publicKey"},{name:"assistant",type:"publicKey"}]},{name:"registerForeignContract",docs:["This instruction registers a new foreign contract (from another","network) and saves the emitter information in a ForeignEmitter account.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can add and update foreign","contracts.","","# Arguments","","* `ctx` - `RegisterForeignContract` context","* `chain` - Wormhole Chain ID","* `address` - Wormhole Emitter Address","* `relayer_fee` - Relayer fee scaled by the `relayer_fee_precision`"],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"foreignContract",isMut:!0,isSigner:!1,docs:["Foreign Contract account. Create this account if an emitter has not been","registered yet for this Wormhole chain ID. If there already is a","contract address saved in this account, overwrite it."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["Token Bridge foreign endpoint. This account should really be one","endpoint per chain, but Token Bridge's PDA allows for multiple","endpoints for each chain. We store the proper endpoint for the","emitter chain."]},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1,docs:["Token Bridge program."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"chain",type:"u16"},{name:"address",type:{array:["u8",32]}},{name:"relayerFee",type:"u64"}]},{name:"registerToken",docs:["This instruction registers a new token and saves the initial `swap_rate`","and `max_native_token_amount` in a RegisteredToken account.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can register a token.","","# Arguments","","* `ctx` - `RegisterToken` context","* `swap_rate`:","- USD conversion rate scaled by the `swap_rate_precision`. For example,","- if the conversion rate is $15 and the `swap_rate_precision` is","- 1000000, the `swap_rate` should be set to 15000000.","* `max_native_swap_amount`:","- Maximum amount of native tokens that can be swapped for this token","- on this chain."],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. Create this","account if the mint has not been registered yet. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"swapRate",type:"u64"},{name:"maxNativeSwapAmount",type:"u64"}]},{name:"deregisterToken",docs:["This instruction deregisters a token by closing the existing","`RegisteredToken` account for a particular mint. This instruction is","owner-only, meaning that only the owner of the program (defined in the","[Config] account) can deregister a token."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","closing [`RegisteredToken`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. This account","also determines if a mint is registered or not."]}],args:[]},{name:"updateRelayerFee",docs:["This instruction updates the `relayer_fee` in the `ForeignContract` account.","The `relayer_fee` is scaled by the `relayer_fee_precision`. For example,","if the `relayer_fee` is $15 and the `relayer_fee_precision` is 1000000,","the `relayer_fee` should be set to 15000000. This instruction can","only be called by the owner or assistant, which are defined in the","[OwnerConfig] account.","","# Arguments","","* `ctx` - `UpdateRelayerFee` context","* `chain` - Wormhole Chain ID","* `fee` - Relayer fee scaled by the `relayer_fee_precision`"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Signer of the transaction. Must be the owner or assistant."]},{name:"ownerConfig",isMut:!1,isSigner:!1,docs:["The owner_config is used when updating the swap rate","so that the assistant key can be used in addition to the","owner key."]},{name:"foreignContract",isMut:!0,isSigner:!1,docs:["This account holds the USD denominated relayer fee for the specified","`chain`. This account is used to determine the cost of relaying","a transfer to a target chain. If there already is a relayer fee","saved in this account, overwrite it."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"chain",type:"u16"},{name:"fee",type:"u64"}]},{name:"updateRelayerFeePrecision",docs:["This instruction updates the `relayer_fee_precision` in the","`SenderConfig` and `RedeemerConfig` accounts. The `relayer_fee_precision`","is used to scale the `relayer_fee`. This instruction is owner-only,","meaning that only the owner of the program (defined in the [Config]","account) can register a token.","","# Arguments","","* `ctx` - `UpdatePrecision` context","* `relayer_fee_precision` - Precision used to scale the relayer fee."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`RedeemerConfig`] and [`SenderConfig`] account."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account. This program requires that the `owner`","specified in the context equals the pubkey specified in this account.","Mutable."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account. This program requires that the `owner`","specified in the context equals the pubkey specified in this account.","Mutable. The `owner` check is redundant here, but we keep it as an","extra protection for future changes to the context. Mutable."]}],args:[{name:"relayerFeePrecision",type:"u32"}]},{name:"updateSwapRate",docs:["This instruction updates the `swap_rate` in the `RegisteredToken`","account. This instruction can only be called by the owner or","assistant, which are defined in the [OwnerConfig] account.","","# Arguments","","* `ctx` - `UpdateSwapRate` context","* `swap_rate` - USD conversion rate for the specified token."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["The signer of the transaction. Must be the owner or assistant."]},{name:"ownerConfig",isMut:!1,isSigner:!1,docs:["The owner_config is used when updating the swap rate so that the","assistant key can be used in additional to the owner key."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. The program","will modify this account to update the swap rate. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]}],args:[{name:"swapRate",type:"u64"}]},{name:"updateMaxNativeSwapAmount",docs:["This instruction updates the `max_native_swap_amount` in the","`RegisteredToken` account. This instruction is owner-only,","meaning that only the owner of the program (defined in the [Config]","account) can register a token.","","# Arguments","","* `ctx` - `UpdateMaxNativeSwapAmount` context","* `max_native_swap_amount`:","- Maximum amount of native tokens that can be swapped for this token","- on this chain."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. The program","will modify this account when the swap rate or max native swap amount","changes. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]}],args:[{name:"maxNativeSwapAmount",type:"u64"}]},{name:"setPauseForTransfers",docs:["This instruction updates the `paused` boolean in the `SenderConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can pause outbound","transfers.","","# Arguments","","* `ctx` - `PauseOutboundTransfers` context","* `paused` - Boolean indicating whether outbound transfers are paused."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account."]},{name:"config",isMut:!0,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"paused",type:"bool"}]},{name:"submitOwnershipTransferRequest",docs:["This instruction sets the `pending_owner` field in the `OwnerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can submit an","ownership transfer request.","","# Arguments","","* `ctx` - `ManageOwnership` context","* `new_owner` - Pubkey of the pending owner."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"newOwner",type:"publicKey"}]},{name:"confirmOwnershipTransferRequest",docs:["This instruction confirms that the `pending_owner` is the signer of","the transaction and updates the `owner` field in the `SenderConfig`,","`RedeemerConfig`, and `OwnerConfig` accounts."],accounts:[{name:"pendingOwner",isMut:!1,isSigner:!0,docs:["Must be the pending owner of the program set in the [`OwnerConfig`]","account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `pending_owner`","specified in the context equals the pubkey specified in this account."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account. This instruction will update the `owner`","specified in this account to the `pending_owner` specified in the","[`OwnerConfig`] account. Mutable."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account. This instruction will update the `owner`","specified in this account to the `pending_owner` specified in the","[`OwnerConfig`] account. Mutable."]}],args:[]},{name:"cancelOwnershipTransferRequest",docs:["This instruction cancels the ownership transfer request by setting","the `pending_owner` field in the `OwnerConfig` account to `None`.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can cancel an ownership","transfer request."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[]},{name:"updateAssistant",docs:["This instruction updates the `assistant` field in the `OwnerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can update the","assistant.","","# Arguments","","* `ctx` - `ManageOwnership` context","* `new_assistant` - Pubkey of the new assistant."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"newAssistant",type:"publicKey"}]},{name:"updateFeeRecipient",docs:["This instruction updates the `fee_recipient` field in the `RedeemerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can update the","fee recipient.","","# Arguments","","* `ctx` - `UpdateFeeRecipient` context","* `new_fee_recipient` - Pubkey of the new fee recipient."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`RedeemerConfig`] account."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account, which saves program data useful for other","instructions, specifically for inbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]}],args:[{name:"newFeeRecipient",type:"publicKey"}]},{name:"transferNativeTokensWithRelay",docs:["This instruction is used to transfer native tokens from Solana to a","foreign blockchain. The user can optionally specify a","`to_native_token_amount` to swap some of the tokens for the native","asset on the target chain. For a fee, an off-chain relayer will redeem","the transfer on the target chain. If the user is transferring native","SOL, the contract will automatically wrap the lamports into a WSOL.","","# Arguments","","* `ctx` - `TransferNativeWithRelay` context","* `amount` - Amount of tokens to send","* `to_native_token_amount`:","- Amount of tokens to swap for native assets on the target chain","* `recipient_chain` - Chain ID of the target chain","* `recipient_address` - Address of the target wallet on the target chain","* `batch_id` - Nonce of Wormhole message","* `wrap_native` - Whether to wrap native SOL"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"payerSequence",isMut:!0,isSigner:!1,docs:["Used to keep track of payer's Wormhole sequence number."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. Acts as the signer for the Token Bridge token","transfer. Read-only."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. Send tokens to the contract specified in this","account. Funnily enough, the Token Bridge program does not have any","requirements for outbound transfers for the recipient chain to be","registered. This account provides extra protection against sending","tokens to an unregistered Wormhole chain ID. Read-only."]},{name:"mint",isMut:!0,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract. Mutable."]},{name:"fromTokenAccount",isMut:!0,isSigner:!1,docs:["Payer's associated token account. We may want to make this a generic","token account in the future."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged out, the token account","will have zero balance and can be closed."]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1,docs:["account that holds this mint's balance. This account needs to be","unchecked because a token account may not have been created for this","mint yet. Mutable."]},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!1,docs:["tokens transferred in this account for our program. Mutable."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"},{name:"toNativeTokenAmount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"batchId",type:"u32"},{name:"wrapNative",type:"bool"}]},{name:"transferWrappedTokensWithRelay",docs:["This instruction is used to transfer wrapped tokens from Solana to a","foreign blockchain. The user can optionally specify a","`to_native_token_amount` to swap some of the tokens for the native","assets on the target chain. For a fee, an off-chain relayer will redeem","the transfer on the target chain. This instruction should only be called","when the user is transferring a wrapped token.","","# Arguments","","* `ctx` - `TransferWrappedWithRelay` context","* `amount` - Amount of tokens to send","* `to_native_token_amount`:","- Amount of tokens to swap for native assets on the target chain","* `recipient_chain` - Chain ID of the target chain","* `recipient_address` - Address of the target wallet on the target chain","* `batch_id` - Nonce of Wormhole message"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens."]},{name:"payerSequence",isMut:!0,isSigner:!1,docs:["Used to keep track of payer's Wormhole sequence number."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. Acts as the Token Bridge sender PDA. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. Send tokens to the contract specified in this","account. Funnily enough, the Token Bridge program does not have any","requirements for outbound transfers for the recipient chain to be","registered. This account provides extra protection against sending","tokens to an unregistered Wormhole chain ID. Read-only."]},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1,docs:["Token Bridge wrapped mint info. This is the SPL token that will be","bridged to the foreign contract. The wrapped mint PDA must agree","with the native token's metadata. Mutable."]},{name:"fromTokenAccount",isMut:!0,isSigner:!1,docs:["Payer's associated token account. We may want to make this a generic","token account in the future."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged out, the token account","will have zero balance and can be closed."]},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1,docs:["about the token from its native chain:","* Wormhole Chain ID","* Token's native contract address","* Token's native decimals"]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!1,docs:["tokens transferred in this account."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"},{name:"toNativeTokenAmount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"batchId",type:"u32"}]},{name:"completeNativeTransferWithRelay",docs:["This instruction is used to redeem token transfers from foreign emitters.","It takes custody of the released native tokens and sends the tokens to the","encoded `recipient`. It pays the `fee_recipient` in the token","denomination. If requested by the user, it will perform a swap with the","off-chain relayer to provide the user with lamports. If the token","being transferred is WSOL, the contract will unwrap the WSOL and send","the lamports to the recipient and pay the relayer in lamports.","","# Arguments","","* `ctx` - `CompleteNativeWithRelay` context","* `vaa_hash` - Hash of the VAA that triggered the transfer"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Redeemer Config account. Acts as the Token Bridge redeemer, which signs","for the complete transfer instruction. Read-only."]},{name:"feeRecipientTokenAccount",isMut:!0,isSigner:!1,docs:["Fee recipient's token account. Must be an associated token account. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. The registered contract specified in this","account must agree with the target address for the Token Bridge's token","transfer. Read-only."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over from the","foreign contract. This must match the token address specified in the","signed Wormhole message. Read-only."]},{name:"recipientTokenAccount",isMut:!0,isSigner:!1,docs:["Recipient associated token account. The recipient authority check","is necessary to ensure that the recipient is the intended recipient","of the bridged tokens. Mutable."]},{name:"recipient",isMut:!0,isSigner:!1,docs:["transaction. This instruction verifies that the recipient key","passed in this context matches the intended recipient in the vaa."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"nativeRegisteredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged in, the tokens will be","transferred to the destination token accounts. This account will have","zero balance and can be closed."]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1,docs:["Verified Wormhole message account. The Wormhole program verified","signatures and posted the account data here. Read-only."]},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["is true if the bridged assets have been claimed. If the transfer has","not been redeemed, this account will not exist yet.","","NOTE: The Token Bridge program's claim account is only initialized when","a transfer is redeemed (and the boolean value `true` is written as","its data).","","The Token Bridge program will automatically fail if this transfer","is redeemed again. But we choose to short-circuit the failure as the","first evaluation of this instruction."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["endpoint per chain, but the PDA allows for multiple endpoints for each","chain! We store the proper endpoint for the emitter chain."]},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1,docs:["account that holds this mint's balance."]},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"completeWrappedTransferWithRelay",docs:["This instruction is used to redeem token transfers from foreign emitters.","It takes custody of the minted wrapped tokens and sends the tokens to the","encoded `recipient`. It pays the `fee_recipient` in the wrapped-token","denomination. If requested by the user, it will perform a swap with the","off-chain relayer to provide the user with lamports.","","# Arguments","","* `ctx` - `CompleteWrappedWithRelay` context","* `vaa_hash` - Hash of the VAA that triggered the transfer"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Redeemer Config account. Acts as the Token Bridge redeemer, which signs","for the complete transfer instruction. Read-only."]},{name:"feeRecipientTokenAccount",isMut:!0,isSigner:!1,docs:["Fee recipient's token account. Must be an associated token account. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. The registered contract specified in this","account must agree with the target address for the Token Bridge's token","transfer. Read-only."]},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1,docs:["Token Bridge wrapped mint info. This is the SPL token that will be","bridged from the foreign contract. The wrapped mint PDA must agree","with the native token's metadata in the wormhole message. Mutable."]},{name:"recipientTokenAccount",isMut:!0,isSigner:!1,docs:["Recipient associated token account. The recipient authority check","is necessary to ensure that the recipient is the intended recipient","of the bridged tokens. Mutable."]},{name:"recipient",isMut:!0,isSigner:!1,docs:["transaction. This instruction verifies that the recipient key","passed in this context matches the intended recipient in the vaa."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"nativeRegisteredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged in, the tokens will be","transferred to the destination token accounts. This account will have","zero balance and can be closed."]},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1,docs:["about the token from its native chain:","* Wormhole Chain ID","* Token's native contract address","* Token's native decimals"]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1,docs:["Verified Wormhole message account. The Wormhole program verified","signatures and posted the account data here. Read-only."]},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["is true if the bridged assets have been claimed. If the transfer has","not been redeemed, this account will not exist yet.","","NOTE: The Token Bridge program's claim account is only initialized when","a transfer is redeemed (and the boolean value `true` is written as","its data).","","The Token Bridge program will automatically fail if this transfer","is redeemed again. But we choose to short-circuit the failure as the","first evaluation of this instruction."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["endpoint per chain, but the PDA allows for multiple endpoints for each","chain! We store the proper endpoint for the emitter chain."]},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]}],accounts:[{name:"foreignContract",docs:["Foreign emitter account data."],type:{kind:"struct",fields:[{name:"chain",docs:["Emitter chain. Cannot equal `1` (Solana's Chain ID)."],type:"u16"},{name:"address",docs:["Emitter address. Cannot be zero address."],type:{array:["u8",32]}},{name:"tokenBridgeForeignEndpoint",docs:["Token Bridge program's foreign endpoint account key."],type:"publicKey"},{name:"fee",docs:["The fee that is paid to the `fee_recipient` upon redeeming a transfer.","This value is set in terms of USD and scaled by the `relayer_fee_precision`.","For example, if the `relayer_fee_precision` is `100000000` and the intended","fee is $5, then the `fee` value should be `500000000`."],type:"u64"}]}},{name:"ownerConfig",docs:["Owner account data."],type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"assistant",docs:["Program's assistant. Can be used to update the relayer fee and swap rate."],type:"publicKey"},{name:"pendingOwner",docs:["Intermediate storage for the pending owner. Is used to transfer ownership."],type:{option:"publicKey"}}]}},{name:"redeemerConfig",type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"bump",docs:["PDA bump."],type:"u8"},{name:"relayerFeePrecision",docs:["Relayer fee and swap rate precision."],type:"u32"},{name:"feeRecipient",docs:["Recipient of all relayer fees and swap proceeds."],type:"publicKey"}]}},{name:"registeredToken",docs:["Registered token account data."],type:{kind:"struct",fields:[{name:"swapRate",docs:["Token swap rate. The swap rate is the USD conversion rate of the token."],type:"u64"},{name:"maxNativeSwapAmount",docs:["Maximum amount of native SOL the contract will swap for each transfer."],type:"u64"}]}},{name:"senderConfig",type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"bump",docs:["PDA bump."],type:"u8"},{name:"tokenBridge",docs:["Token Bridge program's relevant addresses."],type:{defined:"OutboundTokenBridgeAddresses"}},{name:"relayerFeePrecision",docs:["Relayer fee and swap rate precision."],type:"u32"},{name:"paused",docs:["Boolean indicating whether outbound transfers are paused."],type:"bool"}]}},{name:"signerSequence",type:{kind:"struct",fields:[{name:"value",type:"u64"}]}}],types:[{name:"OutboundTokenBridgeAddresses",type:{kind:"struct",fields:[{name:"sequence",type:"publicKey"}]}},{name:"TokenBridgeRelayerMessage",docs:["Expected message types for this program. Only valid payloads are:","* `TransferWithRelay`: Payload ID == 1.","","Payload IDs are encoded as u8."],type:{kind:"enum",variants:[{name:"TransferWithRelay",fields:[{name:"target_relayer_fee",type:"u64"},{name:"to_native_token_amount",type:"u64"},{name:"recipient",type:{array:["u8",32]}}]}]}}],errors:[{code:6e3,name:"InvalidWormholeBridge",msg:"InvalidWormholeBridge"},{code:6001,name:"InvalidWormholeFeeCollector",msg:"InvalidWormholeFeeCollector"},{code:6002,name:"OwnerOnly",msg:"OwnerOnly"},{code:6003,name:"OutboundTransfersPaused",msg:"OutboundTransfersPaused"},{code:6004,name:"OwnerOrAssistantOnly",msg:"OwnerOrAssistantOnly"},{code:6005,name:"NotPendingOwner",msg:"NotPendingOwner"},{code:6006,name:"AlreadyTheOwner",msg:"AlreadyTheOwner"},{code:6007,name:"AlreadyTheAssistant",msg:"AlreadyTheAssistant"},{code:6008,name:"AlreadyTheFeeRecipient",msg:"AlreadyTheFeeRecipient"},{code:6009,name:"BumpNotFound",msg:"BumpNotFound"},{code:6010,name:"FailedToMakeImmutable",msg:"FailedToMakeImmutable"},{code:6011,name:"InvalidForeignContract",msg:"InvalidForeignContract"},{code:6012,name:"ZeroBridgeAmount",msg:"ZeroBridgeAmount"},{code:6013,name:"InvalidToNativeAmount",msg:"InvalidToNativeAmount"},{code:6014,name:"NativeMintRequired",msg:"NativeMintRequired"},{code:6015,name:"SwapsNotAllowedForNativeMint",msg:"SwapsNotAllowedForNativeMint"},{code:6016,name:"InvalidTokenBridgeConfig",msg:"InvalidTokenBridgeConfig"},{code:6017,name:"InvalidTokenBridgeAuthoritySigner",msg:"InvalidTokenBridgeAuthoritySigner"},{code:6018,name:"InvalidTokenBridgeCustodySigner",msg:"InvalidTokenBridgeCustodySigner"},{code:6019,name:"InvalidTokenBridgeEmitter",msg:"InvalidTokenBridgeEmitter"},{code:6020,name:"InvalidTokenBridgeSequence",msg:"InvalidTokenBridgeSequence"},{code:6021,name:"InvalidRecipient",msg:"InvalidRecipient"},{code:6022,name:"InvalidTransferToChain",msg:"InvalidTransferToChain"},{code:6023,name:"InvalidTransferTokenChain",msg:"InvalidTransferTokenChain"},{code:6024,name:"InvalidPrecision",msg:"InvalidPrecision"},{code:6025,name:"InvalidTransferToAddress",msg:"InvalidTransferToAddress"},{code:6026,name:"AlreadyRedeemed",msg:"AlreadyRedeemed"},{code:6027,name:"InvalidTokenBridgeForeignEndpoint",msg:"InvalidTokenBridgeForeignEndpoint"},{code:6028,name:"InvalidTokenBridgeMintAuthority",msg:"InvalidTokenBridgeMintAuthority"},{code:6029,name:"InvalidPublicKey",msg:"InvalidPublicKey"},{code:6030,name:"ZeroSwapRate",msg:"ZeroSwapRate"},{code:6031,name:"TokenNotRegistered",msg:"TokenNotRegistered"},{code:6032,name:"ChainNotRegistered",msg:"ChainNotRegistered"},{code:6033,name:"TokenAlreadyRegistered",msg:"TokenAlreadyRegistered"},{code:6034,name:"FeeCalculationError",msg:"TokenFeeCalculationError"},{code:6035,name:"InvalidSwapCalculation",msg:"InvalidSwapCalculation"},{code:6036,name:"InsufficientFunds",msg:"InsufficientFunds"}]};function je(t,e){return new ke(Vr,new c(t),{connection:e})}function $t(t,e){return P([l.from("seq"),new c(e).toBuffer()],t)}async function Gr(t,e,r,n,i,s,o,a,d,u,g,f){const{methods:{transferNativeTokensWithRelay:h},account:{signerSequence:y}}=je(e,t),p=$t(e,r),T=await y.fetch(p).then(({value:k})=>k).catch(k=>{if(k.message?.includes("Account does not exist"))return new B(0);throw k}),C=Vt(e,r,T),R=V(new c(s),new c(r)),I=Kt(e,s),L=Dr(e,n,i,r,C,R,s);return h(new B(o.toString()),new B(a.toString()),w(u),[...d],g,f).accounts({config:Dt(e),payerSequence:p,foreignContract:Ge(e,u),registeredToken:Ze(e,s),tmpTokenAccount:I,tokenBridgeProgram:new c(n),...L}).instruction()}async function Zr(t,e,r,n,i,s,o,a,d,u,g){const{methods:{transferWrappedTokensWithRelay:f},account:{signerSequence:h}}=je(e,t),y=$t(e,r),p=await h.fetch(y).then(({value:E})=>E).catch(E=>{if(E.message?.includes("Account does not exist"))return new B(0);throw E}),T=Vt(e,r,p),C=V(new c(s),new c(r)),{chain:R,tokenAddress:I}=await Me(t,n,s),L=Kt(e,s),k=Kr(e,n,i,r,T,C,R,I);return f(new B(o.toString()),new B(a.toString()),w(u),[...d],g).accounts({config:Dt(e),payerSequence:y,foreignContract:Ge(e,u),registeredToken:Ze(e,new c(s)),tmpTokenAccount:L,tokenBridgeProgram:new c(n),...k}).instruction()}class ge{network;chain;connection;contracts;chainId;coreBridge;tokenBridge;constructor(e,r,n,i){this.network=e,this.chain=r,this.connection=n,this.contracts=i,this.chainId=w(r);const s=i.tokenBridge;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridge=x(s,n),this.coreBridge=new Wt(e,r,n,i)}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new ge(n,i,e,s.contracts)}async isWrappedAsset(e){return Me(this.connection,this.tokenBridge.programId,new S(e).toUint8Array()).catch(r=>null).then(r=>r!=null)}async getOriginalAsset(e){if(!await this.isWrappedAsset(e))throw Ne(e.toString());const r=new S(e).toUint8Array(),n=new c(r);try{const i=await Me(this.connection,this.tokenBridge.programId,r);return i===null?{chain:this.chain,address:new S(n.toBytes()).toUniversalAddress()}:{chain:gn(i.chain),address:new _t(new Uint8Array(i.tokenAddress))}}catch{throw Ne(e.toString())}}async getTokenUniversalAddress(e){return new S(e).toUniversalAddress()}async getTokenNativeAddress(e,r){return new S(r).toNative()}async hasWrappedAsset(e){try{return await this.getWrappedAsset(e),!0}catch{}return!1}async getWrappedAsset(e){if(q(e.address))throw new Error("Native cannot be a wrapped asset");if(e.chain===this.chain)throw new Error(`Token ${e.address} is already native to chain ${this.chain}`);const r=ue(this.tokenBridge.programId,w(e.chain),e.address.toUniversalAddress().toUint8Array());try{return await Me(this.connection,this.tokenBridge.programId,r),xe(this.chain,r.toBase58())}catch{}throw Ne(`${r}: ${e.address.toUniversalAddress().toString()}`)}async isTransferCompleted(e){return dn(this.connection,this.tokenBridge.programId,e.emitterAddress.toUint8Array(),w(e.emitterChain),e.sequence,this.connection.commitment).catch(()=>!1)}async getWrappedNative(){return xe(this.chain,F.toBase58())}async*createAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new S(r).unwrap(),i=0,s=await this.coreBridge.getMessageFee(),o=ln(this.coreBridge.coreBridge.programId,n,s),a=ie.generate(),d=Ir(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,new S(e).unwrap(),a.publicKey,i),u=new D().add(o,d);u.feePayer=n,yield this.createUnsignedTx({transaction:u,signers:[a]},"Solana.AttestToken")}async*submitAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new S(r).unwrap();yield*this.coreBridge.postVaa(n,e);const i=new D().add(_r(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,e));i.feePayer=n,yield this.createUnsignedTx({transaction:i},"Solana.CreateWrapped")}async transferSol(e,r,n,i){const s=new S(e).unwrap(),o=s,a=r.address.toUniversalAddress().toUint8Array(),d=w(r.chain),u=0,g=0n,f=ie.generate(),h=ie.generate(),y=await pt(this.connection),p=v.createAccount({fromPubkey:o,newAccountPubkey:h.publicKey,lamports:y,space:U,programId:A}),T=v.transfer({fromPubkey:o,lamports:n,toPubkey:h.publicKey}),C=At(h.publicKey,F,o),R=bt(this.tokenBridge.programId,h.publicKey,o,n),I=i?It(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,f.publicKey,h.publicKey,F,u,n,a,d,i):Pt(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,f.publicKey,h.publicKey,F,u,n,g,a,d),L=ht(h.publicKey,o,o),k=new D;return k.feePayer=o,k.add(p,T,C,R,I,L),this.createUnsignedTx({transaction:k,signers:[f,h]},"TokenBridge.TransferNative")}async*transfer(e,r,n,i,s){if(q(n)){yield await this.transferSol(e,r,i,s);return}const o=new S(n).unwrap(),a=new S(e).unwrap(),d=await yt(o,a),u=r.address.toUniversalAddress().toUint8Array(),g=w(r.chain),f=0,h=0n,y=!await this.isWrappedAsset(n),p=ie.generate();let T;if(y)T=s?It(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,o,f,i,u,g,s):Pt(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,o,f,i,h,u,g);else{const I=await this.getOriginalAsset(n);if(q(I.address))throw new Error("Native cannot be an original asset");T=s?qr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,a,w(I.chain),I.address.toUint8Array(),f,i,u,g,s):zr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,a,w(I.chain),I.address.toUint8Array(),f,i,h,u,g)}const C=bt(this.tokenBridge.programId,d,a,i),R=new D().add(C,T);R.feePayer=a,yield this.createUnsignedTx({transaction:R,signers:[p]},"TokenBridge.TransferTokens")}async*redeemAndUnwrap(e,r){const n=new S(e).unwrap(),i=new S(r.payload.to.address).unwrap(),s=await Pn(this.connection,F).then(p=>r.payload.token.amount*BigInt(Math.pow(10,p.decimals-8))),o=await pt(this.connection),a=ie.generate(),d=vt(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,r),u=v.createAccount({fromPubkey:n,newAccountPubkey:a.publicKey,lamports:o,space:U,programId:A}),g=At(a.publicKey,F,n),f=qt(i,a.publicKey,n,s.valueOf()),h=ht(a.publicKey,n,n),y=new D;y.feePayer=n,y.add(d,u,g,f,h),yield this.createUnsignedTx({transaction:y,signers:[a]},"TokenBridge.RedeemAndUnwrap")}async*createAta(e,r){const n=new S(e).unwrap(),i=new S(r).unwrap(),s=await yt(i,n);if(await this.connection.getAccountInfo(s)===null){const a=new D().add(zt(n,s,n,i));a.feePayer=n,yield this.createUnsignedTx({transaction:a},"Redeem.CreateATA")}}async*redeem(e,r,n=!0){const i=r.payload.token.chain===this.chain?r.payload.token.address:(await this.getWrappedAsset(r.payload.token)).toUniversalAddress();if(yield*this.createAta(e,i),yield*this.coreBridge.postVaa(e,r),n){const d=new S(await this.getWrappedNative());if(fn.equals(i.toUint8Array(),d.toUint8Array())){yield*this.redeemAndUnwrap(e,r);return}}const s=new S(e).unwrap(),o=r.payload.token.chain==this.chain?vt:Er,a=new D().add(o(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,r));a.feePayer=s,yield this.createUnsignedTx({transaction:a},"Solana.RedeemTransfer")}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}const Hr={Testnet:["7VPWjBhCXrpYYBiRKZh1ubh9tLZZNkZGp2ReRphEV4Mc","3WK3mEDNPrNuQReBvM28NcsqrExMnPxD9pPJmgrUeKKH","BaGfF51MQ3a61papTRDYaNefBgTQ9ywnVne5fCff4bxT","ACbmcQxbbhiXWM1GmapUSMmBYKMvnFLfAAXKqdo8xKwo","GQtMXZxnuacCFTXVeTvyHi6P9F6chbtzhVc8JgD8hv7c","3Ftc5hTz9sG4huk79onufGiebJNDMZNL8HYgdMJ9E7JR","DMw2tLaq1bVoAEKtkoUtieSk9bfCPUvubYLatTMsSVop","84F2QX9278ToDmA98u4A86xSV9hz1ovazr8zwGaX6qjS","So11111111111111111111111111111111111111112","8987WGkYa5viiZ9DD8sS3PB5XghKmWjkEgmzvwDuoAEc","BJZ72CjPQojVoH68mzrd4VQ4nr6KuhbAGnhZEZCujKxY"],Mainnet:["7vfCXTUXx5WJV5JADk17DUJ4ksgau7utNKj4b963voxs","A9mUU4qviSctJVPJdBJWkb28deg915LYJKrzQ19ji3FM","Dn4noZ5jgGfkntzcQSUZ8czkreiZ1ForXYoV2H8Dm7S1","3NZ9JMVBmGAqocybic2c7LQCJScmgsAZ6vQqTDzcqmJh","9gP2kCy3wA1ctvYWQk75guqXuHfrEomqydHLtcTCqiLa","Gz7VkD4MacbEB6yC5XD3HcumEiYx2EtDYYrfikGsvopG","KgV1GvrHQmRBY8sHQQeUKwTm2r2h8t4C8qt12Cw1HVE","DRQBDBEWmwWGK13fRTLhSPzjbvMSUavhV6nW4RUH8W6T","9kvAcwQbqejuJMd59mKuw2bfSsLRaQ7zuvaTVHEeBBec","7ixSaXGsHAFy34wogPk2YXiUX3BMmQMFdercdaHLnBby","G1vJEgzepqhnVu35BN4jrkv3wVwkujYWFFCxhbEZ1CZr","So11111111111111111111111111111111111111112"],Devnet:[]},ne=9,de=new B(10),re=new B(1e8);class et{network;chain;connection;contracts;chainId;coreBridgeProgramId;tokenBridgeProgramId;tokenBridgeRelayer;constructor(e,r,n,i){this.network=e,this.chain=r,this.connection=n,this.contracts=i,this.chainId=w(r);const s=i.tokenBridgeRelayer;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridgeRelayer=je(s,n),this.tokenBridgeProgramId=new c(i.tokenBridge),this.coreBridgeProgramId=new c(i.coreBridge)}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new et(n,i,e,s.contracts)}async*transfer(e,r,n,i,s){const a=new S(e).unwrap(),d=r.address.toUniversalAddress().toUint8Array(),u=this.mintAddress(n),g=new D;if(q(n)){const p=V(u,a);try{await Cn(this.connection,p)}catch(T){if(T instanceof qe){const C=zt(a,p,a,u);g.add(C)}else throw T}}const f=s||0n,h=q(n),y=h?await Gr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,u,i,f,d,r.chain,0,h):await Zr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,u,i,f,d,r.chain,0);g.add(y),g.feePayer=a,yield this.createUnsignedTx({transaction:g},"AutomaticTokenBridge.Transfer")}async*redeem(e,r){const n=new D;throw yield this.createUnsignedTx({transaction:n},"AutomaticTokenBridge.Redeem"),new Error("Method not implemented.")}async getRelayerFee(e,r){const n=this.mintAddress(r),[{fee:i},{swapRate:s},{relayerFeePrecision:o}]=await Promise.all([this.getForeignContract(e),this.getRegisteredToken(n),this.getRedeemerConfig()]),a=Number(await Z.getDecimals(this.network,this.chain,this.connection,r)),d=de.pow(new B(a)).mul(i).mul(re).div(new B(o).mul(s));return BigInt(d.toString())}async maxSwapAmount(e){const r=this.mintAddress(e),[{swapRate:n,maxNativeSwapAmount:i},{swapRate:s}]=await Promise.all([this.getRegisteredToken(r),this.getRegisteredToken(F)]),o=Number(await Z.getDecimals(this.network,this.chain,this.connection,e)),a=this.calculateNativeSwapRate(s,n),d=o>ne?i.mul(a).mul(de.pow(new B(o-ne))).div(re):i.mul(a).div(de.pow(new B(ne-o)).mul(re));return BigInt(d.toString())}async nativeTokenAmount(e,r){if(r===0n)return 0n;const n=this.mintAddress(e),i=Number(await Z.getDecimals(this.network,this.chain,this.connection,e)),[{swapRate:s},{swapRate:o}]=await Promise.all([this.getRegisteredToken(n),this.getRegisteredToken(F)]),a=this.calculateNativeSwapRate(o,s),d=i>ne?re.mul(new B(r.toString())).div(a.mul(de.pow(new B(i-ne)))):re.mul(new B(r.toString())).mul(de.pow(new B(ne-i))).div(a);return BigInt(d.toString())}async isRegisteredToken(e){const r=this.mintAddress(e);try{return await this.getRegisteredToken(r),!0}catch(n){if(n.message?.includes("Account does not exist"))return!1;throw n}}mintAddress(e){return q(e)?new c(F):new S(e).unwrap()}async getRegisteredTokens(){return Hr[this.network].map(e=>xe(this.chain,e))}calculateNativeSwapRate(e,r){return re.mul(e).div(r)}async getForeignContract(e){return await this.tokenBridgeRelayer.account.foreignContract.fetch(Ge(this.tokenBridgeRelayer.programId,e))}async getRegisteredToken(e){return await this.tokenBridgeRelayer.account.registeredToken.fetch(Ze(this.tokenBridgeRelayer.programId,e))}async getRedeemerConfig(){return await this.tokenBridgeRelayer.account.redeemerConfig.fetch(ur(this.tokenBridgeRelayer.programId))}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}const Rt={version:"0.4.0",name:"tokenBridgeRelayer",instructions:[{name:"completeNativeTransferWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"recipientTokenAccount",isMut:!0,isSigner:!1},{name:"recipient",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"completeWrappedTransferWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1},{name:"recipientTokenAccount",isMut:!0,isSigner:!1},{name:"recipient",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"initialize",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"senderConfig",isMut:!0,isSigner:!1},{name:"redeemerConfig",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!1},{name:"lutAddress",isMut:!0,isSigner:!1},{name:"lut",isMut:!0,isSigner:!1},{name:"lutProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"recentSlot",type:"u64"}]},{name:"resolveExecuteVaaV1",accounts:[],args:[{name:"vaaBody",type:"bytes"}],returns:{defined:"ResolverInstructionGroups"}},{name:"transferNativeTokensWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"fromTokenAccount",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"payee",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"executorProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"TransferNativeTokensWithRelayArgs"}}]},{name:"transferWrappedTokensWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1},{name:"fromTokenAccount",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"payee",isMut:!0,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"executorProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"TransferWrappedTokensWithRelayArgs"}}]}],accounts:[{name:"LUT",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"address",type:"publicKey"}]}},{name:"RedeemerConfig",type:{kind:"struct",fields:[{name:"bump",type:"u8"}]}},{name:"SenderConfig",type:{kind:"struct",fields:[{name:"bump",type:"u8"}]}}],types:[{name:"InstructionGroup",type:{kind:"struct",fields:[{name:"instructions",type:{vec:{defined:"SerializableInstruction"}}},{name:"addressLookupTables",type:{vec:"publicKey"}}]}},{name:"InstructionGroups",type:{kind:"struct",fields:[{name:"groups",type:{vec:{defined:"InstructionGroup"}}}]}},{name:"MissingAccounts",type:{kind:"struct",fields:[{name:"accounts",type:{vec:"publicKey"}},{name:"addressLookupTables",type:{vec:"publicKey"}}]}},{name:"ResolverInstructionGroups",type:{kind:"enum",variants:[{name:"Resolved",fields:[{name:"groups",type:{defined:"InstructionGroups"}}]},{name:"Missing",fields:[{name:"accounts",type:{defined:"MissingAccounts"}}]},{name:"Account"}]}},{name:"SerializableAccountMeta",type:{kind:"struct",fields:[{name:"pubkey",type:"publicKey"},{name:"isSigner",type:"bool"},{name:"isWritable",type:"bool"}]}},{name:"SerializableInstruction",type:{kind:"struct",fields:[{name:"programId",type:"publicKey"},{name:"accounts",type:{vec:{defined:"SerializableAccountMeta"}}},{name:"data",type:"bytes"}]}},{name:"TransferNativeTokensWithRelayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"nonce",type:"u32"},{name:"wrapNative",type:"bool"},{name:"dstTransferRecipient",type:{array:["u8",32]}},{name:"dstExecutionAddress",type:{array:["u8",32]}},{name:"execAmount",type:"u64"},{name:"signedQuoteBytes",type:"bytes"},{name:"relayInstructions",type:"bytes"}]}},{name:"TransferWrappedTokensWithRelayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"nonce",type:"u32"},{name:"dstTransferRecipient",type:{array:["u8",32]}},{name:"dstExecutionAddress",type:{array:["u8",32]}},{name:"execAmount",type:"u64"},{name:"signedQuoteBytes",type:"bytes"},{name:"relayInstructions",type:"bytes"}]}}],errors:[{code:6e3,name:"InvalidWormholeBridge",msg:"invalidWormholeBridge"},{code:6001,name:"InvalidWormholeFeeCollector",msg:"invalidWormholeFeeCollector"},{code:6002,name:"OwnerOnly",msg:"ownerOnly"},{code:6003,name:"OutboundTransfersPaused",msg:"outboundTransfersPaused"},{code:6004,name:"OwnerOrAssistantOnly",msg:"ownerOrAssistantOnly"},{code:6005,name:"NotPendingOwner",msg:"notPendingOwner"},{code:6006,name:"AlreadyTheOwner",msg:"alreadyTheOwner"},{code:6007,name:"AlreadyTheAssistant",msg:"alreadyTheAssistant"},{code:6008,name:"AlreadyTheFeeRecipient",msg:"alreadyTheFeeRecipient"},{code:6009,name:"BumpNotFound",msg:"bumpNotFound"},{code:6010,name:"FailedToMakeImmutable",msg:"failedToMakeImmutable"},{code:6011,name:"InvalidForeignContract",msg:"invalidForeignContract"},{code:6012,name:"ZeroBridgeAmount",msg:"zeroBridgeAmount"},{code:6013,name:"InvalidToNativeAmount",msg:"invalidToNativeAmount"},{code:6014,name:"NativeMintRequired",msg:"nativeMintRequired"},{code:6015,name:"SwapsNotAllowedForNativeMint",msg:"swapsNotAllowedForNativeMint"},{code:6016,name:"InvalidTokenBridgeConfig",msg:"invalidTokenBridgeConfig"},{code:6017,name:"InvalidTokenBridgeAuthoritySigner",msg:"invalidTokenBridgeAuthoritySigner"},{code:6018,name:"InvalidTokenBridgeCustodySigner",msg:"invalidTokenBridgeCustodySigner"},{code:6019,name:"InvalidTokenBridgeEmitter",msg:"invalidTokenBridgeEmitter"},{code:6020,name:"InvalidTokenBridgeSequence",msg:"invalidTokenBridgeSequence"},{code:6021,name:"InvalidRecipient",msg:"invalidRecipient"},{code:6022,name:"InvalidTransferToChain",msg:"invalidTransferToChain"},{code:6023,name:"InvalidTransferTokenChain",msg:"invalidTransferTokenChain"},{code:6024,name:"InvalidPrecision",msg:"invalidPrecision"},{code:6025,name:"InvalidTransferToAddress",msg:"invalidTransferToAddress"},{code:6026,name:"AlreadyRedeemed",msg:"alreadyRedeemed"},{code:6027,name:"InvalidTokenBridgeForeignEndpoint",msg:"invalidTokenBridgeForeignEndpoint"},{code:6028,name:"InvalidTokenBridgeMintAuthority",msg:"invalidTokenBridgeMintAuthority"},{code:6029,name:"InvalidPublicKey",msg:"invalidPublicKey"},{code:6030,name:"ZeroSwapRate",msg:"zeroSwapRate"},{code:6031,name:"TokenNotRegistered",msg:"tokenNotRegistered"},{code:6032,name:"ChainNotRegistered",msg:"chainNotRegistered"},{code:6033,name:"TokenAlreadyRegistered",msg:"tokenAlreadyRegistered"},{code:6034,name:"FeeCalculationError",msg:"tokenFeeCalculationError"},{code:6035,name:"InvalidSwapCalculation",msg:"invalidSwapCalculation"},{code:6036,name:"InsufficientFunds",msg:"insufficientFunds"},{code:6037,name:"FailedToParseVaaBody",msg:"failedToParseVaaBody"}]};class se{network;chain;connection;contracts;relayerProgramId;executorProgramId;wormholeProgramId;tokenBridgeProgramId;relayerProgram;constructor(e,r,n,i){if(this.network=e,this.chain=r,this.connection=n,this.contracts=i,!i.executorTokenBridge)throw new Error(`Executor Token Bridge contracts not found for network ${e} and chain ${r}`);this.relayerProgramId=new c(i.executorTokenBridge.relayer),this.executorProgramId=new c(i.executor),this.wormholeProgramId=new c(i.coreBridge),this.tokenBridgeProgramId=new c(i.tokenBridge),this.relayerProgram=new ke(Rt,this.relayerProgramId,{connection:this.connection})}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch: ${s.network} != ${n}`);return new se(n,i,e,s.contracts)}async*transfer(e,r,n,i,s,o){const a=hn.get(this.network,r.chain);if(!a||!a.relayer)throw new Error(`Token Bridge Executor Relayer contract for domain ${r.chain} not found`);const d=a.relayer,u=new S(e).unwrap(),g=w(r.chain),f=r.address.toUniversalAddress(),{estimatedCost:h,signedQuote:y,relayInstructions:p}=s,T=dt(pn,y),C=dt(yn,p),R=new ge(this.network,this.chain,this.connection,this.contracts),I=q(n),L=!I&&await R.isWrappedAsset(n),k=I?F:new S(n).unwrap(),E=await Z.getTokenProgramId(this.connection,k),J=new c(y.quote.payeeAddress),j=ie.generate(),ye=wn(r.chain,d),Re=ye,we=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],Ee=c.findProgramAddressSync([k.toBuffer()],this.tokenBridgeProgramId)[0],Se=c.findProgramAddressSync([l.from("authority_signer")],this.tokenBridgeProgramId)[0],Xt=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0],{wormholeEmitter:tt,wormholeSequence:nt,wormholeFeeCollector:rt,wormholeBridge:it}=Et(this.tokenBridgeProgramId,this.wormholeProgramId),st=c.findProgramAddressSync([l.from("sender")],this.relayerProgramId)[0],at=V(k,u,!1,E),ot=c.findProgramAddressSync([l.from("tmp"),k.toBytes()],this.relayerProgramId)[0],ee=[];if(o&&o.feeAmount>0n){const We=new c(o.referrer.address.toString());if(k.equals(F))ee.push(v.transfer({fromPubkey:u,toPubkey:We,lamports:o.feeAmount}));else{const _e=V(k,We,!0,E),nn=V(k,u,!0,E);await this.connection.getAccountInfo(_e)||ee.push(cr(u,_e,We,k,E)),ee.push(qt(nn,_e,u,o.feeAmount,void 0,E))}}const Jt=o?o.remainingAmount:i,ct={amount:new B(Jt.toString()),recipientChain:g,recipientAddress:Array.from(f.toUint8Array()),nonce:0,dstTransferRecipient:Array.from(ye.toUint8Array()),dstExecutionAddress:Array.from(Re.toUint8Array()),execAmount:new B(h.toString()),signedQuoteBytes:l.from(T),relayInstructions:l.from(C)};L?ee.push(await this.relayerProgram.methods.transferWrappedTokensWithRelay(ct).accountsStrict({payer:u,config:st,tokenBridgeWrappedMint:k,fromTokenAccount:at,tmpTokenAccount:ot,tokenBridgeWrappedMeta:K(this.tokenBridgeProgramId,k),tokenBridgeConfig:we,tokenBridgeAuthoritySigner:Se,wormholeBridge:it,wormholeMessage:j.publicKey,tokenBridgeEmitter:tt,tokenBridgeSequence:nt,wormholeFeeCollector:rt,payee:J,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,systemProgram:v.programId,tokenProgram:E,executorProgram:this.executorProgramId,clock:Ue,rent:W}).instruction()):ee.push(await this.relayerProgram.methods.transferNativeTokensWithRelay({...ct,wrapNative:q(n)}).accountsStrict({payer:u,config:st,mint:k,fromTokenAccount:at,tmpTokenAccount:ot,tokenBridgeConfig:we,tokenBridgeCustody:Ee,tokenBridgeAuthoritySigner:Se,tokenBridgeCustodySigner:Xt,wormholeBridge:it,wormholeMessage:j.publicKey,tokenBridgeEmitter:tt,tokenBridgeSequence:nt,wormholeFeeCollector:rt,payee:J,systemProgram:v.programId,tokenProgram:E,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,associatedTokenProgram:H,executorProgram:this.executorProgramId,clock:Ue,rent:W}).instruction());const ut=await this.getAddressLookupTable(),{blockhash:jt}=await this.connection.getLatestBlockhash(),en=new lt({payerKey:u,instructions:ee,recentBlockhash:jt}).compileToV0Message(ut?[ut]:[]),tn=new mt(en);yield this.createUnsignedTx({transaction:tn,signers:[j]},"ExecutorTokenBridge.transfer")}async*redeem(e,r){const n=new S(e).unwrap(),i=new S(r.payload.payload.targetRecipient).unwrap(),s=r.payload.token.chain,o=r.payload.token.address,a=s===this.chain;let d;if(a)d=new S(o).unwrap();else{const Se=await new ge(this.network,this.chain,this.connection,this.contracts).getWrappedAsset({chain:s,address:o});d=new S(Se).unwrap()}const u=await Z.getTokenProgramId(this.connection,d),g=V(d,i,!0,u),f=Y(this.wormholeProgramId,l.from(r.hash));await this.connection.getAccountInfo(f)||(yield*new Wt(this.network,this.chain,this.connection,this.contracts).postVaa(n,r));const y=new S(r.payload.to.address).unwrap(),p=new ke(Rt,y,{connection:this.connection}),T=c.findProgramAddressSync([l.from("redeemer")],p.programId)[0],C=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],R=c.findProgramAddressSync([l.from("tmp"),d.toBytes()],p.programId)[0],I=Q(this.tokenBridgeProgramId,r.emitterAddress.toUint8Array(),w(r.emitterChain),r.sequence),L=X(this.tokenBridgeProgramId,w(r.emitterChain),r.emitterAddress.toUint8Array()),k=c.findProgramAddressSync([d.toBuffer()],this.tokenBridgeProgramId)[0],E=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0];let J;const j=Array.from(r.hash);a?J=await p.methods.completeNativeTransferWithRelay(j).accountsStrict({payer:n,config:T,mint:d,recipientTokenAccount:g,recipient:i,tmpTokenAccount:R,tokenBridgeConfig:C,vaa:f,tokenBridgeClaim:I,tokenBridgeForeignEndpoint:L,tokenBridgeCustody:k,tokenBridgeCustodySigner:E,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:u,associatedTokenProgram:H,systemProgram:v.programId,rent:W}).instruction():J=await p.methods.completeWrappedTransferWithRelay(j).accountsStrict({payer:n,config:T,tokenBridgeWrappedMint:d,recipientTokenAccount:g,recipient:i,tmpTokenAccount:R,tokenBridgeWrappedMeta:K(this.tokenBridgeProgramId,d),tokenBridgeConfig:C,vaa:f,tokenBridgeClaim:I,tokenBridgeForeignEndpoint:L,tokenBridgeMintAuthority:pe(this.tokenBridgeProgramId),wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:u,associatedTokenProgram:H,systemProgram:v.programId,rent:W}).instruction();const{blockhash:ye}=await this.connection.getLatestBlockhash(),Re=new lt({payerKey:n,instructions:[J],recentBlockhash:ye}).compileToV0Message(),we=new mt(Re);yield this.createUnsignedTx({transaction:we,signers:[]},"ExecutorTokenBridge.redeem")}async getAddressLookupTable(){const e=c.findProgramAddressSync([l.from("lut")],this.relayerProgramId)[0];try{const r=(await this.relayerProgram.account.lut.fetch(e)).address,n=await this.connection.getAddressLookupTable(r);if(n.value)return n.value}catch{}return null}static associatedTokenAccountMinRent=void 0;async estimateMsgValueAndGasLimit(e,r){let n=0n;if(n+=2n*5000n+7n*5000n+1400000n,n+=2n*5000n+7n*5000n,n+=5000n+3200000n,q(e.address)||Sn(e)===F.toString()?n+=5000n+5000000n:n+=5000n+1200000n,r){const i=new c(r.address.toString());if(!q(e.address)){const s=new S(e.address).unwrap(),o=await this.connection.getAccountInfo(s);if(o===null)throw new Error("Couldn't determine token program. Mint account is null.");const a=V(s,i,!0,o.owner);await this.connection.getAccountInfo(a)===null&&(se.associatedTokenAccountMinRent||(se.associatedTokenAccountMinRent=BigInt(await this.connection.getMinimumBalanceForRentExemption(165))),n+=se.associatedTokenAccountMinRent)}}return{msgValue:n,gasLimit:310000n}}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}Oe(ze,"TokenBridge",ge);Oe(ze,"AutomaticTokenBridge",et);Oe(ze,"ExecutorTokenBridge",se);export{be as CreateMetadataAccountArgs,G as Creator,Pe as Data,Qe as EndpointRegistration,Rt as ExecutorTokenBridgeRelayerIdl,Ct as Key,Je as Metadata,et as SolanaAutomaticTokenBridge,se as SolanaExecutorTokenBridge,ge as SolanaTokenBridge,me as SplTokenMetadataProgram,Ht as TOKEN_BRIDGE_IDL,Vr as TOKEN_BRIDGE_RELAYER_IDL,He as TokenBridgeConfig,Xe as WrappedMeta,Pr as coder,bt as createApproveAuthoritySignerInstruction,Ir as createAttestTokenInstruction,vt as createCompleteTransferNativeInstruction,Er as createCompleteTransferWrappedInstruction,_r as createCreateWrappedInstruction,ii as createInitializeInstruction,x as createReadOnlyTokenBridgeProgramInterface,si as createRegisterChainInstruction,vr as createTokenBridgeProgramInterface,je as createTokenBridgeRelayerProgramInterface,Pt as createTransferNativeInstruction,Gr as createTransferNativeTokensWithRelayInstruction,It as createTransferNativeWithPayloadInstruction,zr as createTransferWrappedInstruction,Zr as createTransferWrappedTokensWithRelayInstruction,qr as createTransferWrappedWithPayloadInstruction,ai as createUpgradeContractInstruction,ce as deriveAuthoritySignerKey,ve as deriveCustodyKey,he as deriveCustodySignerKey,X as deriveEndpointKey,Ge as deriveForeignContractAddress,pe as deriveMintAuthorityKey,$e as deriveRedeemerAccountKey,ur as deriveRedeemerConfigAddress,Ze as deriveRegisteredTokenAddress,Ye as deriveSenderAccountKey,Dt as deriveSenderConfigAddress,Ie as deriveSplTokenMetadataKey,Kt as deriveTmpTokenAccountAddress,_ as deriveTokenBridgeConfigKey,Vt as deriveTokenTransferMessageAddress,K as deriveWrappedMetaKey,ue as deriveWrappedMintKey,Bt as getAttestTokenAccounts,Rr as getCompleteTransferNativeAccounts,ci as getCompleteTransferNativeWithPayloadCpiAccounts,Wr as getCompleteTransferWrappedAccounts,ui as getCompleteTransferWrappedWithPayloadCpiAccounts,Nr as getCreateWrappedAccounts,ni as getEndpointRegistration,Fr as getInitializeAccounts,ri as getMetadata,Ur as getRegisterChainAccounts,ti as getTokenBridgeConfig,oi as getTokenBridgeDerivedAccounts,Or as getTransferNativeAccounts,Qt as getTransferNativeWithPayloadAccounts,Dr as getTransferNativeWithPayloadCpiAccounts,Lr as getTransferWrappedAccounts,Yt as getTransferWrappedWithPayloadAccounts,Kr as getTransferWrappedWithPayloadCpiAccounts,xr as getUpgradeContractAccounts,Me as getWrappedMeta};
1
+ import{h as P,i as Ce,j as rn,n as sn,k as te,l as an,e as Q,f as Y,B as on,m as cn,o as un,p as Be,q as Et,S as Wt,r as dn,s as ln}from"./index-CO4HXUmy.js";import{P as c,k as l,cT as m,T as fe,cV as O,cW as $,cU as M,dr as W,dm as v,cY as w,aX as mn,db as _t,ds as Ue,dn as B,bh as S,da as Ne,d0 as gn,aT as q,cP as xe,K as ie,ae as D,dt as fn,df as hn,dg as dt,dh as pn,di as yn,dj as wn,aj as lt,V as mt,cN as Sn,d4 as Oe,bi as ze}from"../main.js";import{P as ke,c as Mn}from"./index-GKTf0CV7.js";import{b as Z,e as Le}from"./signer-Dl8_VMmx.js";import"./create-54a95t1x.js";import"./chain-gFcyni6Z.js";const A=new c("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA");new c("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb");const H=new c("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"),F=new c("So11111111111111111111111111111111111111112");new c("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class oe extends Error{constructor(e){super(e)}}class qe extends oe{constructor(){super(...arguments),this.name="TokenAccountNotFoundError"}}class kn extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountError"}}class Nt extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountOwnerError"}}class le extends oe{constructor(){super(...arguments),this.name="TokenInvalidAccountSizeError"}}class An extends oe{constructor(){super(...arguments),this.name="TokenInvalidMintError"}}class Ft extends oe{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}var ae;(function(t){t[t.InitializeMint=0]="InitializeMint",t[t.InitializeAccount=1]="InitializeAccount",t[t.InitializeMultisig=2]="InitializeMultisig",t[t.Transfer=3]="Transfer",t[t.Approve=4]="Approve",t[t.Revoke=5]="Revoke",t[t.SetAuthority=6]="SetAuthority",t[t.MintTo=7]="MintTo",t[t.Burn=8]="Burn",t[t.CloseAccount=9]="CloseAccount",t[t.FreezeAccount=10]="FreezeAccount",t[t.ThawAccount=11]="ThawAccount",t[t.TransferChecked=12]="TransferChecked",t[t.ApproveChecked=13]="ApproveChecked",t[t.MintToChecked=14]="MintToChecked",t[t.BurnChecked=15]="BurnChecked",t[t.InitializeAccount2=16]="InitializeAccount2",t[t.SyncNative=17]="SyncNative",t[t.InitializeAccount3=18]="InitializeAccount3",t[t.InitializeMultisig2=19]="InitializeMultisig2",t[t.InitializeMint2=20]="InitializeMint2",t[t.GetAccountDataSize=21]="GetAccountDataSize",t[t.InitializeImmutableOwner=22]="InitializeImmutableOwner",t[t.AmountToUiAmount=23]="AmountToUiAmount",t[t.UiAmountToAmount=24]="UiAmountToAmount",t[t.InitializeMintCloseAuthority=25]="InitializeMintCloseAuthority",t[t.TransferFeeExtension=26]="TransferFeeExtension",t[t.ConfidentialTransferExtension=27]="ConfidentialTransferExtension",t[t.DefaultAccountStateExtension=28]="DefaultAccountStateExtension",t[t.Reallocate=29]="Reallocate",t[t.MemoTransferExtension=30]="MemoTransferExtension",t[t.CreateNativeMint=31]="CreateNativeMint",t[t.InitializeNonTransferableMint=32]="InitializeNonTransferableMint",t[t.InterestBearingMintExtension=33]="InterestBearingMintExtension",t[t.CpiGuardExtension=34]="CpiGuardExtension",t[t.InitializePermanentDelegate=35]="InitializePermanentDelegate",t[t.TransferHookExtension=36]="TransferHookExtension",t[t.MetadataPointerExtension=39]="MetadataPointerExtension"})(ae||(ae={}));function De(t,e,r){if(r.length){t.push({pubkey:e,isSigner:!1,isWritable:!1});for(const n of r)t.push({pubkey:n instanceof c?n:n.publicKey,isSigner:!0,isWritable:!1})}else t.push({pubkey:e,isSigner:!0,isWritable:!1});return t}const gt=m.struct([m.u8("instruction"),O("amount")]);function Tn(t,e,r,n,i=[],s=A){const o=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1}],r,i),a=l.alloc(gt.span);return gt.encode({instruction:ae.Approve,amount:BigInt(n)},a),new fe({keys:o,programId:s,data:a})}const ft=m.struct([m.u8("instruction")]);function ht(t,e,r,n=[],i=A){const s=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,n),o=l.alloc(ft.span);return ft.encode({instruction:ae.CloseAccount},o),new fe({keys:s,programId:i,data:o})}var Ae;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Mint=1]="Mint",t[t.Account=2]="Account"})(Ae||(Ae={}));const Ke=1,bn=m.struct([m.u8("m"),m.u8("n"),$("isInitialized"),M("signer1"),M("signer2"),M("signer3"),M("signer4"),M("signer5"),M("signer6"),M("signer7"),M("signer8"),M("signer9"),M("signer10"),M("signer11")]),Ve=bn.span;var Te;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Initialized=1]="Initialized",t[t.Frozen=2]="Frozen"})(Te||(Te={}));const Ut=m.struct([M("mint"),M("owner"),O("amount"),m.u32("delegateOption"),M("delegate"),m.u8("state"),m.u32("isNativeOption"),O("isNative"),O("delegatedAmount"),m.u32("closeAuthorityOption"),M("closeAuthority")]),U=Ut.span;async function Cn(t,e,r,n=A){const i=await t.getAccountInfo(e,r);return vn(e,i,n)}async function pt(t,e){return await Bn(t,[],e)}async function Bn(t,e,r){const n=or(e);return await t.getMinimumBalanceForRentExemption(n,r)}function vn(t,e,r=A){if(!e)throw new qe;if(!e.owner.equals(r))throw new Nt;if(e.data.length<U)throw new le;const n=Ut.decode(e.data.slice(0,U));let i=l.alloc(0);if(e.data.length>U){if(e.data.length===Ve)throw new le;if(e.data[U]!=Ae.Account)throw new kn;i=e.data.slice(U+Ke)}return{address:t,mint:n.mint,owner:n.owner,amount:n.amount,delegate:n.delegateOption?n.delegate:null,delegatedAmount:n.delegatedAmount,isInitialized:n.state!==Te.Uninitialized,isFrozen:n.state===Te.Frozen,isNative:!!n.isNativeOption,rentExemptReserve:n.isNativeOption?n.isNative:null,closeAuthority:n.closeAuthorityOption?n.closeAuthority:null,tlvData:i}}const xt=m.struct([m.u32("mintAuthorityOption"),M("mintAuthority"),O("supply"),m.u8("decimals"),$("isInitialized"),m.u32("freezeAuthorityOption"),M("freezeAuthority")]),Fe=xt.span;async function Pn(t,e,r,n=A){const i=await t.getAccountInfo(e,r);return In(e,i,n)}function In(t,e,r=A){if(!e)throw new qe;if(!e.owner.equals(r))throw new Nt;if(e.data.length<Fe)throw new le;const n=xt.decode(e.data.slice(0,Fe));let i=l.alloc(0);if(e.data.length>Fe){if(e.data.length<=U)throw new le;if(e.data.length===Ve)throw new le;if(e.data[U]!=Ae.Mint)throw new An;i=e.data.slice(U+Ke)}return{address:t,mintAuthority:n.mintAuthorityOption?n.mintAuthority:null,supply:n.supply,decimals:n.decimals,isInitialized:n.isInitialized,freezeAuthority:n.freezeAuthorityOption?n.freezeAuthority:null,tlvData:i}}async function yt(t,e,r=!1,n=A,i=H){if(!r&&!c.isOnCurve(e.toBuffer()))throw new Ft;const[s]=await c.findProgramAddress([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}function V(t,e,r=!1,n=A,i=H){if(!r&&!c.isOnCurve(e.toBuffer()))throw new Ft;const[s]=c.findProgramAddressSync([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}const Rn=m.struct([$("lockCpi")]),En=Rn.span,Wn=m.struct([m.u8("state")]),_n=Wn.span,Nn=m.struct([]),Fn=Nn.span,Un=m.struct([M("rateAuthority"),m.ns64("initializationTimestamp"),m.s16("preUpdateAverageRate"),m.ns64("lastUpdateTimestamp"),m.s16("currentRate")]),xn=Un.span,On=m.struct([$("requireIncomingTransferMemos")]),zn=On.span,Ln=m.struct([M("authority"),M("metadataAddress")]),qn=Ln.span,Dn=m.struct([M("closeAuthority")]),Kn=Dn.span,Ot=m.struct([]),Vn=Ot.span,Gn=Ot.span,Zn=m.struct([M("delegate")]),Hn=Zn.span,Qn=1e4;BigInt(Qn);function wt(t){return m.struct([O("epoch"),O("maximumFee"),m.u16("transferFeeBasisPoints")],t)}const Yn=m.struct([M("transferFeeConfigAuthority"),M("withdrawWithheldAuthority"),O("withheldAmount"),wt("olderTransferFee"),wt("newerTransferFee")]),$n=Yn.span,Xn=m.struct([O("withheldAmount")]),jn=Xn.span,Jn=m.struct([M("authority"),M("programId")]),er=Jn.span,tr=m.struct([$("transferring")]),nr=tr.span,St=m.struct([m.u8("discriminator"),m.blob(32,"addressConfig"),$("isSigner"),$("isWritable")]),rr=m.struct([m.u32("count"),m.seq(St,m.greedy(St.span),"extraAccounts")]);m.struct([O("instructionDiscriminator"),m.u32("length"),rr.replicate("extraAccountsList")]);var b;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.TransferFeeConfig=1]="TransferFeeConfig",t[t.TransferFeeAmount=2]="TransferFeeAmount",t[t.MintCloseAuthority=3]="MintCloseAuthority",t[t.ConfidentialTransferMint=4]="ConfidentialTransferMint",t[t.ConfidentialTransferAccount=5]="ConfidentialTransferAccount",t[t.DefaultAccountState=6]="DefaultAccountState",t[t.ImmutableOwner=7]="ImmutableOwner",t[t.MemoTransfer=8]="MemoTransfer",t[t.NonTransferable=9]="NonTransferable",t[t.InterestBearingConfig=10]="InterestBearingConfig",t[t.CpiGuard=11]="CpiGuard",t[t.PermanentDelegate=12]="PermanentDelegate",t[t.NonTransferableAccount=13]="NonTransferableAccount",t[t.TransferHook=14]="TransferHook",t[t.TransferHookAccount=15]="TransferHookAccount",t[t.MetadataPointer=18]="MetadataPointer"})(b||(b={}));const Mt=2,ir=2;function sr(t){switch(t){case b.Uninitialized:return 0;case b.TransferFeeConfig:return $n;case b.TransferFeeAmount:return jn;case b.MintCloseAuthority:return Kn;case b.ConfidentialTransferMint:return 97;case b.ConfidentialTransferAccount:return 286;case b.CpiGuard:return En;case b.DefaultAccountState:return _n;case b.ImmutableOwner:return Fn;case b.MemoTransfer:return zn;case b.MetadataPointer:return qn;case b.NonTransferable:return Vn;case b.InterestBearingConfig:return xn;case b.PermanentDelegate:return Hn;case b.NonTransferableAccount:return Gn;case b.TransferHook:return er;case b.TransferHookAccount:return nr;default:throw Error(`Unknown extension type: ${t}`)}}function ar(t,e){if(t.length===0)return e;{const r=U+Ke+t.filter((n,i)=>i===t.indexOf(n)).map(n=>sr(n)+Mt+ir).reduce((n,i)=>n+i);return r===Ve?r+Mt:r}}function or(t){return ar(t,U)}const kt=m.struct([m.u8("instruction")]);function At(t,e,r,n=A){const i=[{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:W,isSigner:!1,isWritable:!1}],s=l.alloc(kt.span);return kt.encode({instruction:ae.InitializeAccount},s),new fe({keys:i,programId:n,data:s})}function zt(t,e,r,n,i=A,s=H){return Lt(t,e,r,n,l.alloc(0),i,s)}function cr(t,e,r,n,i=A,s=H){return Lt(t,e,r,n,l.from([1]),i,s)}function Lt(t,e,r,n,i,s=A,o=H){const a=[{pubkey:t,isSigner:!0,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:n,isSigner:!1,isWritable:!1},{pubkey:v.programId,isSigner:!1,isWritable:!1},{pubkey:s,isSigner:!1,isWritable:!1}];return new fe({keys:a,programId:o,data:i})}const Tt=m.struct([m.u8("instruction"),O("amount")]);function qt(t,e,r,n,i=[],s=A){const o=De([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,i),a=l.alloc(Tt.span);return Tt.encode({instruction:ae.Transfer,amount:BigInt(n)},a),new fe({keys:o,programId:s,data:a})}function Ge(t,e){const r=l.alloc(2);return r.writeUInt16BE(w(e)),P([l.from("foreign_contract"),r],t)}function ur(t){return P([l.from("redeemer")],t)}function Ze(t,e){return P([l.from("mint"),new c(e).toBuffer()],t)}function Dt(t){return P([l.from("sender")],t)}function Kt(t,e){return P([l.from("tmp"),new c(e).toBuffer()],t)}function Vt(t,e,r){return P([l.from("bridged"),new c(e).toBuffer(),l.from(mn.toBytes(BigInt(r.toString()),8))],t)}function _(t){return P([l.from("config")],t)}async function ti(t,e,r){return t.getAccountInfo(_(e),r).then(n=>He.deserialize(Ce(n)))}class He{wormhole;constructor(e){this.wormhole=new c(e)}static deserialize(e){if(e.length!=32)throw new Error("data.length != 32");const r=e.subarray(0,32);return new He(r)}}function ve(t,e){return P([new c(e).toBuffer()],t)}function X(t,e,r){const n=typeof r=="string"?new _t(r).toUint8Array():r;return P([(()=>{const i=l.alloc(2);return i.writeUInt16BE(e),i})(),n],t)}async function ni(t,e,r){return t.getAccountInfo(new c(e),r).then(n=>Qe.deserialize(Ce(n)))}class Qe{chain;contract;constructor(e,r){this.chain=e,this.contract=r}static deserialize(e){if(e.length!=34)throw new Error("data.length != 34");const r=e.readUInt16LE(0),n=e.subarray(2,34);return new Qe(r,n)}}function Ye(t){return P([l.from("sender")],t)}function $e(t){return P([l.from("redeemer")],t)}function ce(t){return P([l.from("authority_signer")],t)}function he(t){return P([l.from("custody_signer")],t)}function pe(t){return P([l.from("mint_signer")],t)}function ue(t,e,r){return P([l.from("wrapped"),(()=>{const n=l.alloc(2);return n.writeUInt16BE(e),n})(),r],t)}function K(t,e){return P([l.from("meta"),new c(e).toBuffer()],t)}async function Me(t,e,r,n){return t.getAccountInfo(K(e,r),n).then(i=>Xe.deserialize(Ce(i)))}class Xe{chain;tokenAddress;originalDecimals;lastUpdatedSequence;constructor(e,r,n,i){this.chain=e,this.tokenAddress=r,this.originalDecimals=n,this.lastUpdatedSequence=i}static deserialize(e){if(e.length!==35&&e.length!==43)throw new Error(`invalid wrapped meta length: ${e.length}`);const r=e.readUInt16LE(0),n=e.subarray(2,34),i=e.readUInt8(34),s=e.length===43?e.readBigUInt64LE(35):void 0;return new Xe(r,n,i,s)}}function bt(t,e,r,n){return Tn(new c(e),ce(t),new c(r),n)}class dr{idl;constructor(e){this.idl=e}async encode(e,r){throw new Error(`Invalid account name: ${e}`)}decode(e,r){return this.decodeUnchecked(e,r)}decodeUnchecked(e,r){throw new Error(`Invalid account name: ${e}`)}memcmp(e,r){throw new Error(`Invalid account name: ${e}`)}size(e){return rn(this.idl,e)??0}}class lr{constructor(e){}decode(e){throw new Error("Token Bridge program does not have events")}}class mr{constructor(e){}encode(e,r){switch(e){case"initialize":return gr(r);case"attestToken":return fr(r);case"completeNative":return hr(r);case"completeWrapped":return pr(r);case"transferWrapped":return yr(r);case"transferNative":return wr(r);case"registerChain":return Sr(r);case"createWrapped":return Mr(r);case"upgradeContract":return kr(r);case"transferWrappedWithPayload":return Ar(r);case"transferNativeWithPayload":return Tr(r);default:throw new Error(`Invalid instruction: ${e}`)}}encodeState(e,r){throw new Error("Token Bridge program does not have state")}}var N;(function(t){t[t.Initialize=0]="Initialize",t[t.AttestToken=1]="AttestToken",t[t.CompleteNative=2]="CompleteNative",t[t.CompleteWrapped=3]="CompleteWrapped",t[t.TransferWrapped=4]="TransferWrapped",t[t.TransferNative=5]="TransferNative",t[t.RegisterChain=6]="RegisterChain",t[t.CreateWrapped=7]="CreateWrapped",t[t.UpgradeContract=8]="UpgradeContract",t[t.CompleteNativeWithPayload=9]="CompleteNativeWithPayload",t[t.CompleteWrappedWithPayload=10]="CompleteWrappedWithPayload",t[t.TransferWrappedWithPayload=11]="TransferWrappedWithPayload",t[t.TransferNativeWithPayload=12]="TransferNativeWithPayload"})(N||(N={}));function z(t,e){const r=e===void 0?0:e.length,n=l.alloc(1+r);return n.writeUInt8(t,0),r>0&&n.write(e.toString("hex"),1,"hex"),n}function gr({wormhole:t}){const e=l.alloc(32);return e.write(new c(t).toBuffer().toString("hex"),0,"hex"),z(N.Initialize,e)}function fr({nonce:t}){const e=l.alloc(4);return e.writeUInt32LE(t,0),z(N.AttestToken,e)}function hr({}){return z(N.CompleteNative)}function pr({}){return z(N.CompleteWrapped)}function Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){if(typeof e!="bigint"&&(e=BigInt(e)),typeof r!="bigint"&&(r=BigInt(r)),!l.isBuffer(n))throw new Error("targetAddress must be Buffer");const s=l.alloc(54);return s.writeUInt32LE(t,0),s.writeBigUInt64LE(e,4),s.writeBigUInt64LE(r,12),s.write(n.toString("hex"),20,"hex"),s.writeUInt16LE(i,52),s}function yr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return z(N.TransferWrapped,Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function wr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return z(N.TransferNative,Gt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Sr({}){return z(N.RegisterChain)}function Mr({}){return z(N.CreateWrapped)}function kr({}){return z(N.UpgradeContract)}function Zt({nonce:t,amount:e,targetAddress:r,targetChain:n,payload:i}){if(typeof e!="bigint"&&(e=BigInt(e)),!l.isBuffer(r))throw new Error("targetAddress must be Buffer");if(!l.isBuffer(i))throw new Error("payload must be Buffer");const s=l.alloc(50);return s.writeUInt32LE(t,0),s.writeBigUInt64LE(e,4),s.write(r.toString("hex"),12,"hex"),s.writeUInt16LE(n,44),s.writeUInt32LE(i.length,46),l.concat([s,i,l.alloc(1)])}function Ar({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return z(N.TransferWrappedWithPayload,Zt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}function Tr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return z(N.TransferNativeWithPayload,Zt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}class br{constructor(e){}encode(e,r){throw new Error("Token Bridge program does not have state")}decode(e){throw new Error("Token Bridge program does not have state")}}class Cr{constructor(e){}encode(e,r){throw new Error("Token Bridge program does not have user-defined types")}decode(e,r){throw new Error("Token Bridge program does not have user-defined types")}}class Br{instruction;accounts;state;events;types;constructor(e){this.instruction=new mr(e),this.accounts=new dr(e),this.state=new br(e),this.events=new lr(e),this.types=new Cr(e)}}const Ht={version:"0.1.0",name:"wormhole",instructions:[{name:"initialize",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"wormhole",type:"publicKey"}]},{name:"attestToken",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!0,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"splMetadata",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"}]},{name:"completeNative",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"to",isMut:!0,isSigner:!1},{name:"toFees",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"rent",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"completeWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"to",isMut:!0,isSigner:!1},{name:"toFees",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"mintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"transferWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"fromOwner",isMut:!0,isSigner:!0},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"fee",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"}]},{name:"transferNative",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"fee",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"}]},{name:"registerChain",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"endpoint",isMut:!0,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"createWrapped",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"endpoint",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!0,isSigner:!1},{name:"splMetadata",isMut:!0,isSigner:!1},{name:"mintAuthority",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"splMetadataProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[]},{name:"upgradeContract",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"vaa",isMut:!1,isSigner:!1},{name:"claim",isMut:!0,isSigner:!1},{name:"upgradeAuthority",isMut:!1,isSigner:!1},{name:"spill",isMut:!0,isSigner:!1},{name:"implementation",isMut:!0,isSigner:!1},{name:"programData",isMut:!0,isSigner:!1},{name:"tokenBridgeProgram",isMut:!0,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"bpfLoaderUpgradeable",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[]},{name:"transferWrappedWithPayload",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"fromOwner",isMut:!0,isSigner:!0},{name:"mint",isMut:!0,isSigner:!1},{name:"wrappedMeta",isMut:!1,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"sender",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"},{name:"payload",type:"bytes"},{name:"cpiProgramId",type:{option:"publicKey"}}]},{name:"transferNativeWithPayload",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"from",isMut:!0,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"custody",isMut:!0,isSigner:!1},{name:"authoritySigner",isMut:!1,isSigner:!1},{name:"custodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"wormholeEmitter",isMut:!1,isSigner:!1},{name:"wormholeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"sender",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1}],args:[{name:"nonce",type:"u32"},{name:"amount",type:"u64"},{name:"targetAddress",type:{array:["u8",32]}},{name:"targetChain",type:"u16"},{name:"payload",type:"bytes"},{name:"cpiProgramId",type:{option:"publicKey"}}]}],accounts:[]};function vr(t,e){return new ke(Ht,new c(t),e===void 0?{connection:null}:e,Pr())}function x(t,e){return vr(t,Mn(e))}function Pr(){return new Br(Ht)}class G{address;verified;share;constructor(e,r,n){this.address=new c(e),this.verified=r,this.share=n}static size=34;serialize(){const e=l.alloc(G.size);return e.write(this.address.toBuffer().toString("hex"),0,"hex"),this.verified&&e.writeUInt8(1,32),e.writeUInt8(this.share,33),e}static deserialize(e){const r=e.subarray(0,32),n=e.readUInt8(32)>0,i=e.readUInt8(33);return new G(r,n,i)}}class Pe{name;symbol;uri;sellerFeeBasisPoints;creators;constructor(e,r,n,i,s){this.name=e,this.symbol=r,this.uri=n,this.sellerFeeBasisPoints=i,this.creators=s}serialize(){const e=this.name.length,r=this.symbol.length,n=this.uri.length,i=this.creators,[s,o]=(()=>{if(i===null)return[0,0];const d=i.length;return[d,4+d*G.size]})(),a=l.alloc(15+e+r+n+o);if(a.writeUInt32LE(e,0),a.write(this.name,4),a.writeUInt32LE(r,4+e),a.write(this.symbol,8+e),a.writeUInt32LE(n,8+e+r),a.write(this.uri,12+e+r),a.writeUInt16LE(this.sellerFeeBasisPoints,12+e+r+n),i===null)a.writeUInt8(0,14+e+r+n);else{a.writeUInt8(1,14+e+r+n),a.writeUInt32LE(s,15+e+r+n);for(let d=0;d<s;++d){const u=i.at(d),g=19+e+r+n+d*G.size;a.write(u.serialize().toString("hex"),g,"hex")}}return a}static deserialize(e){const r=e.readUInt32LE(0),n=e.subarray(4,4+r).toString(),i=e.readUInt32LE(4+r),s=e.subarray(8+r,8+r+i).toString(),o=e.readUInt32LE(8+r+i),a=e.subarray(12+r+i,12+r+i+o).toString(),d=e.readUInt16LE(12+r+i+o),u=e.readUInt8(14+r+i+o),g=(()=>{if(u==0)return null;const f=[],h=e.readUInt32LE(15+r+i+o);for(let y=0;y<h;++y){const p=19+r+i+o+y*G.size;f.push(G.deserialize(e.subarray(p,p+G.size)))}return f})();return new Pe(n,s,a,d,g)}}class be extends Pe{isMutable;constructor(e,r,n,i,s,o){super(e,r,n,i,s),this.isMutable=o}static serialize(e,r,n,i,s,o){return new be(e,r,n,i,s,o).serialize()}static serializeInstructionData(e,r,n,i,s,o){return l.concat([l.alloc(1,0),be.serialize(e,r,n,i,s,o)])}serialize(){return l.concat([super.serialize(),l.alloc(1,this.isMutable?1:0)])}}class me{constructor(){}static programId=new c("metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s");static createMetadataAccounts(e,r,n,i,s,o,a=!1,d,u,g,f=!1,h=Ie(r)){const y=[sn(h,!1),te(r,!1),te(n,!0),te(e,!0),te(o,a),te(v.programId,!1),te(W,!1)],p=be.serializeInstructionData(i,s,d===void 0?"":d,g===void 0?0:g,u===void 0?null:u,f);return{programId:me.programId,keys:y,data:p}}}function Ie(t){return P([l.from("metadata"),me.programId.toBuffer(),new c(t).toBuffer()],me.programId)}var Ct;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.EditionV1=1]="EditionV1",t[t.MasterEditionV1=2]="MasterEditionV1",t[t.ReservationListV1=3]="ReservationListV1",t[t.MetadataV1=4]="MetadataV1",t[t.ReservationListV2=5]="ReservationListV2",t[t.MasterEditionV2=6]="MasterEditionV2",t[t.EditionMarker=7]="EditionMarker"})(Ct||(Ct={}));class je{key;updateAuthority;mint;data;primarySaleHappened;isMutable;constructor(e,r,n,i,s,o){this.key=e,this.updateAuthority=new c(r),this.mint=new c(n),this.data=i,this.primarySaleHappened=s,this.isMutable=o}static deserialize(e){const r=e.readUInt8(0),n=e.subarray(1,33),i=e.subarray(33,65),s=Pe.deserialize(e.subarray(65)),o=s.serialize().length,a=e.readUInt8(65+o)>0,d=e.readUInt8(66+o)>0;return new je(r,n,i,s,a,d)}}async function ri(t,e,r){return t.getAccountInfo(Ie(e),r).then(n=>je.deserialize(Ce(n)))}function Ir(t,e,r,n,i,s,o){const a=x(e,t).methods.attestToken(o);return console.log(Bt(e,r,n,i,s)),a._ixFn(...a._args,{accounts:Bt(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Bt(t,e,r,n,i){const{bridge:s,emitter:o,sequence:a,feeCollector:d,clock:u,rent:g,systemProgram:f}=an(e,r,i,t);return{payer:new c(r),config:_(t),mint:new c(n),wrappedMeta:K(t,n),splMetadata:Ie(n),wormholeBridge:s,wormholeMessage:new c(i),wormholeEmitter:o,wormholeSequence:a,wormholeFeeCollector:d,clock:u,rent:g,systemProgram:f,wormholeProgram:new c(e)}}function vt(t,e,r,n,i,s){const o=x(e,t).methods.completeNative();return o._ixFn(...o._args,{accounts:Rr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Rr(t,e,r,n,i){const s=new c(n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),to:new c(n.payload.to.address.toUint8Array()),toFees:new c(i===void 0?n.payload.to.address.toUint8Array():i),custody:ve(t,s),mint:s,custodySigner:he(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function Er(t,e,r,n,i,s){const o=x(e,t).methods.completeWrapped();return o._ixFn(...o._args,{accounts:Wr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Wr(t,e,r,n,i){const s=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),to:new c(n.payload.to.address.toUint8Array()),toFees:new c(i===void 0?n.payload.to.address.toUint8Array():i),mint:s,wrappedMeta:K(t,s),mintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function _r(t,e,r,n,i){const s=x(e,t).methods.createWrapped();return s._ixFn(...s._args,{accounts:Nr(e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Nr(t,e,r,n){const i=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:_(t),endpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),mint:i,wrappedMeta:K(t,i),splMetadata:Ie(i),mintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,splMetadataProgram:me.programId,wormholeProgram:new c(e)}}function ii(t,e,r){const n=x(t).methods.initialize(r);return n._ixFn(...n._args,{accounts:Fr(t,e),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Fr(t,e){return{payer:new c(e),config:_(t),rent:W,systemProgram:v.programId}}function si(t,e,r,n){const i=x(t).methods.registerChain();return i._ixFn(...i._args,{accounts:Ur(t,e,r,n),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Ur(t,e,r,n){return{payer:new c(r),config:_(t),endpoint:X(t,w(n.payload.actionArgs.foreignChain),n.payload.actionArgs.foreignAddress.toUint8Array()),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),rent:W,systemProgram:v.programId,wormholeProgram:new c(e)}}function ai(t,e,r,n,i){const s=x(t).methods.upgradeContract();return s._ixFn(...s._args,{accounts:xr(t,e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function xr(t,e,r,n,i){return{payer:new c(r),vaa:Y(e,l.from(n.hash)),claim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),upgradeAuthority:un(t),spill:new c(i===void 0?r:i),implementation:new c(n.payload.actionArgs.newContract),programData:cn(t),tokenBridgeProgram:new c(t),rent:W,clock:Ue,bpfLoaderUpgradeable:on,systemProgram:v.programId}}function Pt(t,e,r,n,i,s,o,a,d,u,g,f){const h=x(e,t).methods.transferNative(a,d,u,l.from(g),f);return h._ixFn(...h._args,{accounts:Or(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Or(t,e,r,n,i,s){const{wormholeBridge:o,wormholeMessage:a,wormholeEmitter:d,wormholeSequence:u,wormholeFeeCollector:g,clock:f,rent:h,systemProgram:y}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),mint:new c(s),custody:ve(t,s),authoritySigner:ce(t),custodySigner:he(t),wormholeBridge:o,wormholeMessage:a,wormholeEmitter:d,wormholeSequence:u,wormholeFeeCollector:g,clock:f,rent:h,systemProgram:y,tokenProgram:A,wormholeProgram:new c(e)}}function It(t,e,r,n,i,s,o,a,d,u,g,f){const h=x(e,t).methods.transferNativeWithPayload(a,d,l.from(u),g,l.from(f),null);return h._ixFn(...h._args,{accounts:Qt(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Qt(t,e,r,n,i,s,o){const{wormholeBridge:a,wormholeMessage:d,wormholeEmitter:u,wormholeSequence:g,wormholeFeeCollector:f,clock:h,rent:y,systemProgram:p}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),mint:new c(s),custody:ve(t,s),authoritySigner:ce(t),custodySigner:he(t),wormholeBridge:a,wormholeMessage:d,wormholeEmitter:u,wormholeSequence:g,wormholeFeeCollector:f,clock:h,sender:new c(o===void 0?r:Ye(o)),rent:y,systemProgram:p,tokenProgram:A,wormholeProgram:new c(e)}}function zr(t,e,r,n,i,s,o,a,d,u,g,f,h,y){const p=x(e,t).methods.transferWrapped(u,g,f,l.from(h),y);return p._ixFn(...p._args,{accounts:Lr(e,r,n,i,s,o,a,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Lr(t,e,r,n,i,s,o,a){const d=ue(t,o,a),{wormholeBridge:u,wormholeMessage:g,wormholeEmitter:f,wormholeSequence:h,wormholeFeeCollector:y,clock:p,rent:T,systemProgram:C}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),fromOwner:new c(s),mint:d,wrappedMeta:K(t,d),authoritySigner:ce(t),wormholeBridge:u,wormholeMessage:g,wormholeEmitter:f,wormholeSequence:h,wormholeFeeCollector:y,clock:p,rent:T,systemProgram:C,wormholeProgram:new c(e),tokenProgram:A}}function qr(t,e,r,n,i,s,o,a,d,u,g,f,h,y){const p=x(e,t).methods.transferWrappedWithPayload(u,g,l.from(f),h,l.from(y),null);return p._ixFn(...p._args,{accounts:Yt(e,r,n,i,s,o,a,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Yt(t,e,r,n,i,s,o,a,d){const u=ue(t,o,a),{wormholeBridge:g,wormholeMessage:f,wormholeEmitter:h,wormholeSequence:y,wormholeFeeCollector:p,clock:T,rent:C,systemProgram:R}=Be(t,e,r,n);return{payer:new c(r),config:_(t),from:new c(i),fromOwner:new c(s),mint:u,wrappedMeta:K(t,u),authoritySigner:ce(t),wormholeBridge:g,wormholeMessage:f,wormholeEmitter:h,wormholeSequence:y,wormholeFeeCollector:p,clock:T,sender:new c(d===void 0?r:Ye(d)),rent:C,systemProgram:R,wormholeProgram:new c(e),tokenProgram:A}}function oi(t,e,r){const{wormholeEmitter:n,wormholeBridge:i,wormholeFeeCollector:s,wormholeSequence:o}=Et(e,r);return{tokenBridgeConfig:_(e),tokenBridgeAuthoritySigner:ce(e),tokenBridgeCustodySigner:he(e),tokenBridgeMintAuthority:pe(e),tokenBridgeSender:Ye(t),tokenBridgeRedeemer:$e(t),wormholeBridge:i,tokenBridgeEmitter:n,wormholeFeeCollector:s,tokenBridgeSequence:o}}function Dr(t,e,r,n,i,s,o){const a=Qt(e,r,n,i,s,o,t);return{payer:a.payer,tokenBridgeConfig:a.config,fromTokenAccount:a.from,mint:a.mint,tokenBridgeCustody:a.custody,tokenBridgeAuthoritySigner:a.authoritySigner,tokenBridgeCustodySigner:a.custodySigner,wormholeBridge:a.wormholeBridge,wormholeMessage:a.wormholeMessage,tokenBridgeEmitter:a.wormholeEmitter,tokenBridgeSequence:a.wormholeSequence,wormholeFeeCollector:a.wormholeFeeCollector,clock:a.clock,tokenBridgeSender:a.sender,rent:a.rent,systemProgram:a.systemProgram,tokenProgram:a.tokenProgram,wormholeProgram:a.wormholeProgram}}function Kr(t,e,r,n,i,s,o,a,d){const u=Yt(e,r,n,i,s,d===void 0?t:d,o,a,t);return{payer:u.payer,tokenBridgeConfig:u.config,fromTokenAccount:u.from,fromTokenAccountOwner:u.fromOwner,tokenBridgeWrappedMint:u.mint,tokenBridgeWrappedMeta:u.wrappedMeta,tokenBridgeAuthoritySigner:u.authoritySigner,wormholeBridge:u.wormholeBridge,wormholeMessage:u.wormholeMessage,tokenBridgeEmitter:u.wormholeEmitter,tokenBridgeSequence:u.wormholeSequence,wormholeFeeCollector:u.wormholeFeeCollector,clock:u.clock,tokenBridgeSender:u.sender,rent:u.rent,systemProgram:u.systemProgram,tokenProgram:u.tokenProgram,wormholeProgram:u.wormholeProgram}}function ci(t,e,r,n,i){const s=new c(n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:_(t),vaa:Y(e,l.from(n.hash)),tokenBridgeClaim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:$e(o),toFeesTokenAccount:new c(i),tokenBridgeCustody:ve(t,s),mint:s,tokenBridgeCustodySigner:he(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}function ui(t,e,r,n,i){const s=ue(t,w(n.payload.token.chain),n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:_(t),vaa:Y(e,l.from(n.hash)),tokenBridgeClaim:Q(t,n.emitterAddress.toUint8Array(),w(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:X(t,w(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:$e(o),toFeesTokenAccount:new c(i),tokenBridgeWrappedMint:s,tokenBridgeWrappedMeta:K(t,s),tokenBridgeMintAuthority:pe(t),rent:W,systemProgram:v.programId,tokenProgram:A,wormholeProgram:new c(e)}}const Vr={version:"0.1.0",name:"token_bridge_relayer",constants:[{name:"SEED_PREFIX_BRIDGED",type:"bytes",value:"[98, 114, 105, 100, 103, 101, 100]"},{name:"SEED_PREFIX_TMP",type:"bytes",value:"[116, 109, 112]"},{name:"SWAP_RATE_PRECISION",type:"u32",value:"100_000_000"}],instructions:[{name:"initialize",docs:["This instruction is be used to generate your program's config.","And for convenience, we will store Wormhole-related PDAs in the","config so we can verify these accounts with a simple == constraint.","# Arguments","","* `ctx` - `Initialize` context","* `fee_recipient` - Recipient of all relayer fees and swap proceeds","* `assistant` - Privileged key to manage certain accounts"],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Deployer of the program."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account, which saves program data useful for other","instructions, specifically for outbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account, which saves program data useful for other","instructions, specifically for inbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner config account, which saves the owner, assistant and","pending owner keys. This account is used to manage the ownership of the","program."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1,docs:["that holds data; it is purely just a signer for posting Wormhole","messages on behalf of the Token Bridge program."]},{name:"tokenBridgeSequence",isMut:!1,isSigner:!1,docs:["Token Bridge emitter's sequence account. Like with all Wormhole","emitters, this account keeps track of the sequence number of the last","posted message."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]},{name:"programData",isMut:!0,isSigner:!1,docs:["upgrade authority. We check this PDA address just in case there is another program that this","deployer has deployed.","","NOTE: Set upgrade authority is scary because any public key can be used to set as the","authority."]},{name:"bpfLoaderUpgradeableProgram",isMut:!1,isSigner:!1}],args:[{name:"feeRecipient",type:"publicKey"},{name:"assistant",type:"publicKey"}]},{name:"registerForeignContract",docs:["This instruction registers a new foreign contract (from another","network) and saves the emitter information in a ForeignEmitter account.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can add and update foreign","contracts.","","# Arguments","","* `ctx` - `RegisterForeignContract` context","* `chain` - Wormhole Chain ID","* `address` - Wormhole Emitter Address","* `relayer_fee` - Relayer fee scaled by the `relayer_fee_precision`"],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"foreignContract",isMut:!0,isSigner:!1,docs:["Foreign Contract account. Create this account if an emitter has not been","registered yet for this Wormhole chain ID. If there already is a","contract address saved in this account, overwrite it."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["Token Bridge foreign endpoint. This account should really be one","endpoint per chain, but Token Bridge's PDA allows for multiple","endpoints for each chain. We store the proper endpoint for the","emitter chain."]},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1,docs:["Token Bridge program."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"chain",type:"u16"},{name:"address",type:{array:["u8",32]}},{name:"relayerFee",type:"u64"}]},{name:"registerToken",docs:["This instruction registers a new token and saves the initial `swap_rate`","and `max_native_token_amount` in a RegisteredToken account.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can register a token.","","# Arguments","","* `ctx` - `RegisterToken` context","* `swap_rate`:","- USD conversion rate scaled by the `swap_rate_precision`. For example,","- if the conversion rate is $15 and the `swap_rate_precision` is","- 1000000, the `swap_rate` should be set to 15000000.","* `max_native_swap_amount`:","- Maximum amount of native tokens that can be swapped for this token","- on this chain."],accounts:[{name:"owner",isMut:!0,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. Create this","account if the mint has not been registered yet. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"swapRate",type:"u64"},{name:"maxNativeSwapAmount",type:"u64"}]},{name:"deregisterToken",docs:["This instruction deregisters a token by closing the existing","`RegisteredToken` account for a particular mint. This instruction is","owner-only, meaning that only the owner of the program (defined in the","[Config] account) can deregister a token."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","closing [`RegisteredToken`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. This account","also determines if a mint is registered or not."]}],args:[]},{name:"updateRelayerFee",docs:["This instruction updates the `relayer_fee` in the `ForeignContract` account.","The `relayer_fee` is scaled by the `relayer_fee_precision`. For example,","if the `relayer_fee` is $15 and the `relayer_fee_precision` is 1000000,","the `relayer_fee` should be set to 15000000. This instruction can","only be called by the owner or assistant, which are defined in the","[OwnerConfig] account.","","# Arguments","","* `ctx` - `UpdateRelayerFee` context","* `chain` - Wormhole Chain ID","* `fee` - Relayer fee scaled by the `relayer_fee_precision`"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Signer of the transaction. Must be the owner or assistant."]},{name:"ownerConfig",isMut:!1,isSigner:!1,docs:["The owner_config is used when updating the swap rate","so that the assistant key can be used in addition to the","owner key."]},{name:"foreignContract",isMut:!0,isSigner:!1,docs:["This account holds the USD denominated relayer fee for the specified","`chain`. This account is used to determine the cost of relaying","a transfer to a target chain. If there already is a relayer fee","saved in this account, overwrite it."]},{name:"systemProgram",isMut:!1,isSigner:!1,docs:["System program."]}],args:[{name:"chain",type:"u16"},{name:"fee",type:"u64"}]},{name:"updateRelayerFeePrecision",docs:["This instruction updates the `relayer_fee_precision` in the","`SenderConfig` and `RedeemerConfig` accounts. The `relayer_fee_precision`","is used to scale the `relayer_fee`. This instruction is owner-only,","meaning that only the owner of the program (defined in the [Config]","account) can register a token.","","# Arguments","","* `ctx` - `UpdatePrecision` context","* `relayer_fee_precision` - Precision used to scale the relayer fee."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`RedeemerConfig`] and [`SenderConfig`] account."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account. This program requires that the `owner`","specified in the context equals the pubkey specified in this account.","Mutable."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account. This program requires that the `owner`","specified in the context equals the pubkey specified in this account.","Mutable. The `owner` check is redundant here, but we keep it as an","extra protection for future changes to the context. Mutable."]}],args:[{name:"relayerFeePrecision",type:"u32"}]},{name:"updateSwapRate",docs:["This instruction updates the `swap_rate` in the `RegisteredToken`","account. This instruction can only be called by the owner or","assistant, which are defined in the [OwnerConfig] account.","","# Arguments","","* `ctx` - `UpdateSwapRate` context","* `swap_rate` - USD conversion rate for the specified token."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["The signer of the transaction. Must be the owner or assistant."]},{name:"ownerConfig",isMut:!1,isSigner:!1,docs:["The owner_config is used when updating the swap rate so that the","assistant key can be used in additional to the owner key."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. The program","will modify this account to update the swap rate. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]}],args:[{name:"swapRate",type:"u64"}]},{name:"updateMaxNativeSwapAmount",docs:["This instruction updates the `max_native_swap_amount` in the","`RegisteredToken` account. This instruction is owner-only,","meaning that only the owner of the program (defined in the [Config]","account) can register a token.","","# Arguments","","* `ctx` - `UpdateMaxNativeSwapAmount` context","* `max_native_swap_amount`:","- Maximum amount of native tokens that can be swapped for this token","- on this chain."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account. Signer for","creating [`ForeignContract`] account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Read-only."]},{name:"registeredToken",isMut:!0,isSigner:!1,docs:["Registered Token account. This account stores information about the","token, including the swap rate and max native swap amount. The program","will modify this account when the swap rate or max native swap amount","changes. Mutable."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract."]}],args:[{name:"maxNativeSwapAmount",type:"u64"}]},{name:"setPauseForTransfers",docs:["This instruction updates the `paused` boolean in the `SenderConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can pause outbound","transfers.","","# Arguments","","* `ctx` - `PauseOutboundTransfers` context","* `paused` - Boolean indicating whether outbound transfers are paused."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`SenderConfig`] account."]},{name:"config",isMut:!0,isSigner:!1,docs:["Sender Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"paused",type:"bool"}]},{name:"submitOwnershipTransferRequest",docs:["This instruction sets the `pending_owner` field in the `OwnerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can submit an","ownership transfer request.","","# Arguments","","* `ctx` - `ManageOwnership` context","* `new_owner` - Pubkey of the pending owner."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"newOwner",type:"publicKey"}]},{name:"confirmOwnershipTransferRequest",docs:["This instruction confirms that the `pending_owner` is the signer of","the transaction and updates the `owner` field in the `SenderConfig`,","`RedeemerConfig`, and `OwnerConfig` accounts."],accounts:[{name:"pendingOwner",isMut:!1,isSigner:!0,docs:["Must be the pending owner of the program set in the [`OwnerConfig`]","account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `pending_owner`","specified in the context equals the pubkey specified in this account."]},{name:"senderConfig",isMut:!0,isSigner:!1,docs:["Sender Config account. This instruction will update the `owner`","specified in this account to the `pending_owner` specified in the","[`OwnerConfig`] account. Mutable."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account. This instruction will update the `owner`","specified in this account to the `pending_owner` specified in the","[`OwnerConfig`] account. Mutable."]}],args:[]},{name:"cancelOwnershipTransferRequest",docs:["This instruction cancels the ownership transfer request by setting","the `pending_owner` field in the `OwnerConfig` account to `None`.","This instruction is owner-only, meaning that only the owner of the","program (defined in the [Config] account) can cancel an ownership","transfer request."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[]},{name:"updateAssistant",docs:["This instruction updates the `assistant` field in the `OwnerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can update the","assistant.","","# Arguments","","* `ctx` - `ManageOwnership` context","* `new_assistant` - Pubkey of the new assistant."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`OwnerConfig`] account."]},{name:"ownerConfig",isMut:!0,isSigner:!1,docs:["Owner Config account. This program requires that the `owner` specified","in the context equals the pubkey specified in this account. Mutable."]}],args:[{name:"newAssistant",type:"publicKey"}]},{name:"updateFeeRecipient",docs:["This instruction updates the `fee_recipient` field in the `RedeemerConfig`","account. This instruction is owner-only, meaning that only the owner","of the program (defined in the [Config] account) can update the","fee recipient.","","# Arguments","","* `ctx` - `UpdateFeeRecipient` context","* `new_fee_recipient` - Pubkey of the new fee recipient."],accounts:[{name:"owner",isMut:!1,isSigner:!0,docs:["Owner of the program set in the [`RedeemerConfig`] account."]},{name:"redeemerConfig",isMut:!0,isSigner:!1,docs:["Redeemer Config account, which saves program data useful for other","instructions, specifically for inbound transfers. Also saves the payer","of the [`initialize`](crate::initialize) instruction as the program's","owner."]}],args:[{name:"newFeeRecipient",type:"publicKey"}]},{name:"transferNativeTokensWithRelay",docs:["This instruction is used to transfer native tokens from Solana to a","foreign blockchain. The user can optionally specify a","`to_native_token_amount` to swap some of the tokens for the native","asset on the target chain. For a fee, an off-chain relayer will redeem","the transfer on the target chain. If the user is transferring native","SOL, the contract will automatically wrap the lamports into a WSOL.","","# Arguments","","* `ctx` - `TransferNativeWithRelay` context","* `amount` - Amount of tokens to send","* `to_native_token_amount`:","- Amount of tokens to swap for native assets on the target chain","* `recipient_chain` - Chain ID of the target chain","* `recipient_address` - Address of the target wallet on the target chain","* `batch_id` - Nonce of Wormhole message","* `wrap_native` - Whether to wrap native SOL"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"payerSequence",isMut:!0,isSigner:!1,docs:["Used to keep track of payer's Wormhole sequence number."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. Acts as the signer for the Token Bridge token","transfer. Read-only."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. Send tokens to the contract specified in this","account. Funnily enough, the Token Bridge program does not have any","requirements for outbound transfers for the recipient chain to be","registered. This account provides extra protection against sending","tokens to an unregistered Wormhole chain ID. Read-only."]},{name:"mint",isMut:!0,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over to the","foreign contract. Mutable."]},{name:"fromTokenAccount",isMut:!0,isSigner:!1,docs:["Payer's associated token account. We may want to make this a generic","token account in the future."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged out, the token account","will have zero balance and can be closed."]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1,docs:["account that holds this mint's balance. This account needs to be","unchecked because a token account may not have been created for this","mint yet. Mutable."]},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!1,docs:["tokens transferred in this account for our program. Mutable."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"},{name:"toNativeTokenAmount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"batchId",type:"u32"},{name:"wrapNative",type:"bool"}]},{name:"transferWrappedTokensWithRelay",docs:["This instruction is used to transfer wrapped tokens from Solana to a","foreign blockchain. The user can optionally specify a","`to_native_token_amount` to swap some of the tokens for the native","assets on the target chain. For a fee, an off-chain relayer will redeem","the transfer on the target chain. This instruction should only be called","when the user is transferring a wrapped token.","","# Arguments","","* `ctx` - `TransferWrappedWithRelay` context","* `amount` - Amount of tokens to send","* `to_native_token_amount`:","- Amount of tokens to swap for native assets on the target chain","* `recipient_chain` - Chain ID of the target chain","* `recipient_address` - Address of the target wallet on the target chain","* `batch_id` - Nonce of Wormhole message"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens."]},{name:"payerSequence",isMut:!0,isSigner:!1,docs:["Used to keep track of payer's Wormhole sequence number."]},{name:"config",isMut:!1,isSigner:!1,docs:["Sender Config account. Acts as the Token Bridge sender PDA. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. Send tokens to the contract specified in this","account. Funnily enough, the Token Bridge program does not have any","requirements for outbound transfers for the recipient chain to be","registered. This account provides extra protection against sending","tokens to an unregistered Wormhole chain ID. Read-only."]},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1,docs:["Token Bridge wrapped mint info. This is the SPL token that will be","bridged to the foreign contract. The wrapped mint PDA must agree","with the native token's metadata. Mutable."]},{name:"fromTokenAccount",isMut:!0,isSigner:!1,docs:["Payer's associated token account. We may want to make this a generic","token account in the future."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged out, the token account","will have zero balance and can be closed."]},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1,docs:["about the token from its native chain:","* Wormhole Chain ID","* Token's native contract address","* Token's native decimals"]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!1,docs:["tokens transferred in this account."]},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"amount",type:"u64"},{name:"toNativeTokenAmount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"batchId",type:"u32"}]},{name:"completeNativeTransferWithRelay",docs:["This instruction is used to redeem token transfers from foreign emitters.","It takes custody of the released native tokens and sends the tokens to the","encoded `recipient`. It pays the `fee_recipient` in the token","denomination. If requested by the user, it will perform a swap with the","off-chain relayer to provide the user with lamports. If the token","being transferred is WSOL, the contract will unwrap the WSOL and send","the lamports to the recipient and pay the relayer in lamports.","","# Arguments","","* `ctx` - `CompleteNativeWithRelay` context","* `vaa_hash` - Hash of the VAA that triggered the transfer"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Redeemer Config account. Acts as the Token Bridge redeemer, which signs","for the complete transfer instruction. Read-only."]},{name:"feeRecipientTokenAccount",isMut:!0,isSigner:!1,docs:["Fee recipient's token account. Must be an associated token account. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. The registered contract specified in this","account must agree with the target address for the Token Bridge's token","transfer. Read-only."]},{name:"mint",isMut:!1,isSigner:!1,docs:["Mint info. This is the SPL token that will be bridged over from the","foreign contract. This must match the token address specified in the","signed Wormhole message. Read-only."]},{name:"recipientTokenAccount",isMut:!0,isSigner:!1,docs:["Recipient associated token account. The recipient authority check","is necessary to ensure that the recipient is the intended recipient","of the bridged tokens. Mutable."]},{name:"recipient",isMut:!0,isSigner:!1,docs:["transaction. This instruction verifies that the recipient key","passed in this context matches the intended recipient in the vaa."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"nativeRegisteredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged in, the tokens will be","transferred to the destination token accounts. This account will have","zero balance and can be closed."]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1,docs:["Verified Wormhole message account. The Wormhole program verified","signatures and posted the account data here. Read-only."]},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["is true if the bridged assets have been claimed. If the transfer has","not been redeemed, this account will not exist yet.","","NOTE: The Token Bridge program's claim account is only initialized when","a transfer is redeemed (and the boolean value `true` is written as","its data).","","The Token Bridge program will automatically fail if this transfer","is redeemed again. But we choose to short-circuit the failure as the","first evaluation of this instruction."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["endpoint per chain, but the PDA allows for multiple endpoints for each","chain! We store the proper endpoint for the emitter chain."]},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1,docs:["account that holds this mint's balance."]},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"completeWrappedTransferWithRelay",docs:["This instruction is used to redeem token transfers from foreign emitters.","It takes custody of the minted wrapped tokens and sends the tokens to the","encoded `recipient`. It pays the `fee_recipient` in the wrapped-token","denomination. If requested by the user, it will perform a swap with the","off-chain relayer to provide the user with lamports.","","# Arguments","","* `ctx` - `CompleteWrappedWithRelay` context","* `vaa_hash` - Hash of the VAA that triggered the transfer"],accounts:[{name:"payer",isMut:!0,isSigner:!0,docs:["Payer will pay Wormhole fee to transfer tokens and create temporary","token account."]},{name:"config",isMut:!1,isSigner:!1,docs:["Redeemer Config account. Acts as the Token Bridge redeemer, which signs","for the complete transfer instruction. Read-only."]},{name:"feeRecipientTokenAccount",isMut:!0,isSigner:!1,docs:["Fee recipient's token account. Must be an associated token account. Mutable."]},{name:"foreignContract",isMut:!1,isSigner:!1,docs:["Foreign Contract account. The registered contract specified in this","account must agree with the target address for the Token Bridge's token","transfer. Read-only."]},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1,docs:["Token Bridge wrapped mint info. This is the SPL token that will be","bridged from the foreign contract. The wrapped mint PDA must agree","with the native token's metadata in the wormhole message. Mutable."]},{name:"recipientTokenAccount",isMut:!0,isSigner:!1,docs:["Recipient associated token account. The recipient authority check","is necessary to ensure that the recipient is the intended recipient","of the bridged tokens. Mutable."]},{name:"recipient",isMut:!0,isSigner:!1,docs:["transaction. This instruction verifies that the recipient key","passed in this context matches the intended recipient in the vaa."]},{name:"registeredToken",isMut:!1,isSigner:!1},{name:"nativeRegisteredToken",isMut:!1,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1,docs:["Program's temporary token account. This account is created before the","instruction is invoked to temporarily take custody of the payer's","tokens. When the tokens are finally bridged in, the tokens will be","transferred to the destination token accounts. This account will have","zero balance and can be closed."]},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1,docs:["about the token from its native chain:","* Wormhole Chain ID","* Token's native contract address","* Token's native decimals"]},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1,docs:["Verified Wormhole message account. The Wormhole program verified","signatures and posted the account data here. Read-only."]},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1,docs:["is true if the bridged assets have been claimed. If the transfer has","not been redeemed, this account will not exist yet.","","NOTE: The Token Bridge program's claim account is only initialized when","a transfer is redeemed (and the boolean value `true` is written as","its data).","","The Token Bridge program will automatically fail if this transfer","is redeemed again. But we choose to short-circuit the failure as the","first evaluation of this instruction."]},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1,docs:["endpoint per chain, but the PDA allows for multiple endpoints for each","chain! We store the proper endpoint for the emitter chain."]},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]}],accounts:[{name:"foreignContract",docs:["Foreign emitter account data."],type:{kind:"struct",fields:[{name:"chain",docs:["Emitter chain. Cannot equal `1` (Solana's Chain ID)."],type:"u16"},{name:"address",docs:["Emitter address. Cannot be zero address."],type:{array:["u8",32]}},{name:"tokenBridgeForeignEndpoint",docs:["Token Bridge program's foreign endpoint account key."],type:"publicKey"},{name:"fee",docs:["The fee that is paid to the `fee_recipient` upon redeeming a transfer.","This value is set in terms of USD and scaled by the `relayer_fee_precision`.","For example, if the `relayer_fee_precision` is `100000000` and the intended","fee is $5, then the `fee` value should be `500000000`."],type:"u64"}]}},{name:"ownerConfig",docs:["Owner account data."],type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"assistant",docs:["Program's assistant. Can be used to update the relayer fee and swap rate."],type:"publicKey"},{name:"pendingOwner",docs:["Intermediate storage for the pending owner. Is used to transfer ownership."],type:{option:"publicKey"}}]}},{name:"redeemerConfig",type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"bump",docs:["PDA bump."],type:"u8"},{name:"relayerFeePrecision",docs:["Relayer fee and swap rate precision."],type:"u32"},{name:"feeRecipient",docs:["Recipient of all relayer fees and swap proceeds."],type:"publicKey"}]}},{name:"registeredToken",docs:["Registered token account data."],type:{kind:"struct",fields:[{name:"swapRate",docs:["Token swap rate. The swap rate is the USD conversion rate of the token."],type:"u64"},{name:"maxNativeSwapAmount",docs:["Maximum amount of native SOL the contract will swap for each transfer."],type:"u64"}]}},{name:"senderConfig",type:{kind:"struct",fields:[{name:"owner",docs:["Program's owner."],type:"publicKey"},{name:"bump",docs:["PDA bump."],type:"u8"},{name:"tokenBridge",docs:["Token Bridge program's relevant addresses."],type:{defined:"OutboundTokenBridgeAddresses"}},{name:"relayerFeePrecision",docs:["Relayer fee and swap rate precision."],type:"u32"},{name:"paused",docs:["Boolean indicating whether outbound transfers are paused."],type:"bool"}]}},{name:"signerSequence",type:{kind:"struct",fields:[{name:"value",type:"u64"}]}}],types:[{name:"OutboundTokenBridgeAddresses",type:{kind:"struct",fields:[{name:"sequence",type:"publicKey"}]}},{name:"TokenBridgeRelayerMessage",docs:["Expected message types for this program. Only valid payloads are:","* `TransferWithRelay`: Payload ID == 1.","","Payload IDs are encoded as u8."],type:{kind:"enum",variants:[{name:"TransferWithRelay",fields:[{name:"target_relayer_fee",type:"u64"},{name:"to_native_token_amount",type:"u64"},{name:"recipient",type:{array:["u8",32]}}]}]}}],errors:[{code:6e3,name:"InvalidWormholeBridge",msg:"InvalidWormholeBridge"},{code:6001,name:"InvalidWormholeFeeCollector",msg:"InvalidWormholeFeeCollector"},{code:6002,name:"OwnerOnly",msg:"OwnerOnly"},{code:6003,name:"OutboundTransfersPaused",msg:"OutboundTransfersPaused"},{code:6004,name:"OwnerOrAssistantOnly",msg:"OwnerOrAssistantOnly"},{code:6005,name:"NotPendingOwner",msg:"NotPendingOwner"},{code:6006,name:"AlreadyTheOwner",msg:"AlreadyTheOwner"},{code:6007,name:"AlreadyTheAssistant",msg:"AlreadyTheAssistant"},{code:6008,name:"AlreadyTheFeeRecipient",msg:"AlreadyTheFeeRecipient"},{code:6009,name:"BumpNotFound",msg:"BumpNotFound"},{code:6010,name:"FailedToMakeImmutable",msg:"FailedToMakeImmutable"},{code:6011,name:"InvalidForeignContract",msg:"InvalidForeignContract"},{code:6012,name:"ZeroBridgeAmount",msg:"ZeroBridgeAmount"},{code:6013,name:"InvalidToNativeAmount",msg:"InvalidToNativeAmount"},{code:6014,name:"NativeMintRequired",msg:"NativeMintRequired"},{code:6015,name:"SwapsNotAllowedForNativeMint",msg:"SwapsNotAllowedForNativeMint"},{code:6016,name:"InvalidTokenBridgeConfig",msg:"InvalidTokenBridgeConfig"},{code:6017,name:"InvalidTokenBridgeAuthoritySigner",msg:"InvalidTokenBridgeAuthoritySigner"},{code:6018,name:"InvalidTokenBridgeCustodySigner",msg:"InvalidTokenBridgeCustodySigner"},{code:6019,name:"InvalidTokenBridgeEmitter",msg:"InvalidTokenBridgeEmitter"},{code:6020,name:"InvalidTokenBridgeSequence",msg:"InvalidTokenBridgeSequence"},{code:6021,name:"InvalidRecipient",msg:"InvalidRecipient"},{code:6022,name:"InvalidTransferToChain",msg:"InvalidTransferToChain"},{code:6023,name:"InvalidTransferTokenChain",msg:"InvalidTransferTokenChain"},{code:6024,name:"InvalidPrecision",msg:"InvalidPrecision"},{code:6025,name:"InvalidTransferToAddress",msg:"InvalidTransferToAddress"},{code:6026,name:"AlreadyRedeemed",msg:"AlreadyRedeemed"},{code:6027,name:"InvalidTokenBridgeForeignEndpoint",msg:"InvalidTokenBridgeForeignEndpoint"},{code:6028,name:"InvalidTokenBridgeMintAuthority",msg:"InvalidTokenBridgeMintAuthority"},{code:6029,name:"InvalidPublicKey",msg:"InvalidPublicKey"},{code:6030,name:"ZeroSwapRate",msg:"ZeroSwapRate"},{code:6031,name:"TokenNotRegistered",msg:"TokenNotRegistered"},{code:6032,name:"ChainNotRegistered",msg:"ChainNotRegistered"},{code:6033,name:"TokenAlreadyRegistered",msg:"TokenAlreadyRegistered"},{code:6034,name:"FeeCalculationError",msg:"TokenFeeCalculationError"},{code:6035,name:"InvalidSwapCalculation",msg:"InvalidSwapCalculation"},{code:6036,name:"InsufficientFunds",msg:"InsufficientFunds"}]};function Je(t,e){return new ke(Vr,new c(t),{connection:e})}function $t(t,e){return P([l.from("seq"),new c(e).toBuffer()],t)}async function Gr(t,e,r,n,i,s,o,a,d,u,g,f){const{methods:{transferNativeTokensWithRelay:h},account:{signerSequence:y}}=Je(e,t),p=$t(e,r),T=await y.fetch(p).then(({value:k})=>k).catch(k=>{if(k.message?.includes("Account does not exist"))return new B(0);throw k}),C=Vt(e,r,T),R=V(new c(s),new c(r)),I=Kt(e,s),L=Dr(e,n,i,r,C,R,s);return h(new B(o.toString()),new B(a.toString()),w(u),[...d],g,f).accounts({config:Dt(e),payerSequence:p,foreignContract:Ge(e,u),registeredToken:Ze(e,s),tmpTokenAccount:I,tokenBridgeProgram:new c(n),...L}).instruction()}async function Zr(t,e,r,n,i,s,o,a,d,u,g){const{methods:{transferWrappedTokensWithRelay:f},account:{signerSequence:h}}=Je(e,t),y=$t(e,r),p=await h.fetch(y).then(({value:E})=>E).catch(E=>{if(E.message?.includes("Account does not exist"))return new B(0);throw E}),T=Vt(e,r,p),C=V(new c(s),new c(r)),{chain:R,tokenAddress:I}=await Me(t,n,s),L=Kt(e,s),k=Kr(e,n,i,r,T,C,R,I);return f(new B(o.toString()),new B(a.toString()),w(u),[...d],g).accounts({config:Dt(e),payerSequence:y,foreignContract:Ge(e,u),registeredToken:Ze(e,new c(s)),tmpTokenAccount:L,tokenBridgeProgram:new c(n),...k}).instruction()}class ge{network;chain;connection;contracts;chainId;coreBridge;tokenBridge;constructor(e,r,n,i){this.network=e,this.chain=r,this.connection=n,this.contracts=i,this.chainId=w(r);const s=i.tokenBridge;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridge=x(s,n),this.coreBridge=new Wt(e,r,n,i)}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new ge(n,i,e,s.contracts)}async isWrappedAsset(e){return Me(this.connection,this.tokenBridge.programId,new S(e).toUint8Array()).catch(r=>null).then(r=>r!=null)}async getOriginalAsset(e){if(!await this.isWrappedAsset(e))throw Ne(e.toString());const r=new S(e).toUint8Array(),n=new c(r);try{const i=await Me(this.connection,this.tokenBridge.programId,r);return i===null?{chain:this.chain,address:new S(n.toBytes()).toUniversalAddress()}:{chain:gn(i.chain),address:new _t(new Uint8Array(i.tokenAddress))}}catch{throw Ne(e.toString())}}async getTokenUniversalAddress(e){return new S(e).toUniversalAddress()}async getTokenNativeAddress(e,r){return new S(r).toNative()}async hasWrappedAsset(e){try{return await this.getWrappedAsset(e),!0}catch{}return!1}async getWrappedAsset(e){if(q(e.address))throw new Error("Native cannot be a wrapped asset");if(e.chain===this.chain)throw new Error(`Token ${e.address} is already native to chain ${this.chain}`);const r=ue(this.tokenBridge.programId,w(e.chain),e.address.toUniversalAddress().toUint8Array());try{return await Me(this.connection,this.tokenBridge.programId,r),xe(this.chain,r.toBase58())}catch{}throw Ne(`${r}: ${e.address.toUniversalAddress().toString()}`)}async isTransferCompleted(e){return dn(this.connection,this.tokenBridge.programId,e.emitterAddress.toUint8Array(),w(e.emitterChain),e.sequence,this.connection.commitment).catch(()=>!1)}async getWrappedNative(){return xe(this.chain,F.toBase58())}async*createAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new S(r).unwrap(),i=0,s=await this.coreBridge.getMessageFee(),o=ln(this.coreBridge.coreBridge.programId,n,s),a=ie.generate(),d=Ir(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,new S(e).unwrap(),a.publicKey,i),u=new D().add(o,d);u.feePayer=n,yield this.createUnsignedTx({transaction:u,signers:[a]},"Solana.AttestToken")}async*submitAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new S(r).unwrap();yield*this.coreBridge.postVaa(n,e);const i=new D().add(_r(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,e));i.feePayer=n,yield this.createUnsignedTx({transaction:i},"Solana.CreateWrapped")}async transferSol(e,r,n,i){const s=new S(e).unwrap(),o=s,a=r.address.toUniversalAddress().toUint8Array(),d=w(r.chain),u=0,g=0n,f=ie.generate(),h=ie.generate(),y=await pt(this.connection),p=v.createAccount({fromPubkey:o,newAccountPubkey:h.publicKey,lamports:y,space:U,programId:A}),T=v.transfer({fromPubkey:o,lamports:n,toPubkey:h.publicKey}),C=At(h.publicKey,F,o),R=bt(this.tokenBridge.programId,h.publicKey,o,n),I=i?It(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,f.publicKey,h.publicKey,F,u,n,a,d,i):Pt(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,f.publicKey,h.publicKey,F,u,n,g,a,d),L=ht(h.publicKey,o,o),k=new D;return k.feePayer=o,k.add(p,T,C,R,I,L),this.createUnsignedTx({transaction:k,signers:[f,h]},"TokenBridge.TransferNative")}async*transfer(e,r,n,i,s){if(q(n)){yield await this.transferSol(e,r,i,s);return}const o=new S(n).unwrap(),a=new S(e).unwrap(),d=await yt(o,a),u=r.address.toUniversalAddress().toUint8Array(),g=w(r.chain),f=0,h=0n,y=!await this.isWrappedAsset(n),p=ie.generate();let T;if(y)T=s?It(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,o,f,i,u,g,s):Pt(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,o,f,i,h,u,g);else{const I=await this.getOriginalAsset(n);if(q(I.address))throw new Error("Native cannot be an original asset");T=s?qr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,a,w(I.chain),I.address.toUint8Array(),f,i,u,g,s):zr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,p.publicKey,d,a,w(I.chain),I.address.toUint8Array(),f,i,h,u,g)}const C=bt(this.tokenBridge.programId,d,a,i),R=new D().add(C,T);R.feePayer=a,yield this.createUnsignedTx({transaction:R,signers:[p]},"TokenBridge.TransferTokens")}async*redeemAndUnwrap(e,r){const n=new S(e).unwrap(),i=new S(r.payload.to.address).unwrap(),s=await Pn(this.connection,F).then(p=>r.payload.token.amount*BigInt(Math.pow(10,p.decimals-8))),o=await pt(this.connection),a=ie.generate(),d=vt(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,r),u=v.createAccount({fromPubkey:n,newAccountPubkey:a.publicKey,lamports:o,space:U,programId:A}),g=At(a.publicKey,F,n),f=qt(i,a.publicKey,n,s.valueOf()),h=ht(a.publicKey,n,n),y=new D;y.feePayer=n,y.add(d,u,g,f,h),yield this.createUnsignedTx({transaction:y,signers:[a]},"TokenBridge.RedeemAndUnwrap")}async*createAta(e,r){const n=new S(e).unwrap(),i=new S(r).unwrap(),s=await yt(i,n);if(await this.connection.getAccountInfo(s)===null){const a=new D().add(zt(n,s,n,i));a.feePayer=n,yield this.createUnsignedTx({transaction:a},"Redeem.CreateATA")}}async*redeem(e,r,n=!0){const i=r.payload.token.chain===this.chain?r.payload.token.address:(await this.getWrappedAsset(r.payload.token)).toUniversalAddress();if(yield*this.createAta(e,i),yield*this.coreBridge.postVaa(e,r),n){const d=new S(await this.getWrappedNative());if(fn.equals(i.toUint8Array(),d.toUint8Array())){yield*this.redeemAndUnwrap(e,r);return}}const s=new S(e).unwrap(),o=r.payload.token.chain==this.chain?vt:Er,a=new D().add(o(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,r));a.feePayer=s,yield this.createUnsignedTx({transaction:a},"Solana.RedeemTransfer")}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}const Hr={Testnet:["7VPWjBhCXrpYYBiRKZh1ubh9tLZZNkZGp2ReRphEV4Mc","3WK3mEDNPrNuQReBvM28NcsqrExMnPxD9pPJmgrUeKKH","BaGfF51MQ3a61papTRDYaNefBgTQ9ywnVne5fCff4bxT","ACbmcQxbbhiXWM1GmapUSMmBYKMvnFLfAAXKqdo8xKwo","GQtMXZxnuacCFTXVeTvyHi6P9F6chbtzhVc8JgD8hv7c","3Ftc5hTz9sG4huk79onufGiebJNDMZNL8HYgdMJ9E7JR","DMw2tLaq1bVoAEKtkoUtieSk9bfCPUvubYLatTMsSVop","84F2QX9278ToDmA98u4A86xSV9hz1ovazr8zwGaX6qjS","So11111111111111111111111111111111111111112","8987WGkYa5viiZ9DD8sS3PB5XghKmWjkEgmzvwDuoAEc","BJZ72CjPQojVoH68mzrd4VQ4nr6KuhbAGnhZEZCujKxY"],Mainnet:["7vfCXTUXx5WJV5JADk17DUJ4ksgau7utNKj4b963voxs","A9mUU4qviSctJVPJdBJWkb28deg915LYJKrzQ19ji3FM","Dn4noZ5jgGfkntzcQSUZ8czkreiZ1ForXYoV2H8Dm7S1","3NZ9JMVBmGAqocybic2c7LQCJScmgsAZ6vQqTDzcqmJh","9gP2kCy3wA1ctvYWQk75guqXuHfrEomqydHLtcTCqiLa","Gz7VkD4MacbEB6yC5XD3HcumEiYx2EtDYYrfikGsvopG","KgV1GvrHQmRBY8sHQQeUKwTm2r2h8t4C8qt12Cw1HVE","DRQBDBEWmwWGK13fRTLhSPzjbvMSUavhV6nW4RUH8W6T","9kvAcwQbqejuJMd59mKuw2bfSsLRaQ7zuvaTVHEeBBec","7ixSaXGsHAFy34wogPk2YXiUX3BMmQMFdercdaHLnBby","G1vJEgzepqhnVu35BN4jrkv3wVwkujYWFFCxhbEZ1CZr","So11111111111111111111111111111111111111112"],Devnet:[]},ne=9,de=new B(10),re=new B(1e8);class et{network;chain;connection;contracts;chainId;coreBridgeProgramId;tokenBridgeProgramId;tokenBridgeRelayer;constructor(e,r,n,i){this.network=e,this.chain=r,this.connection=n,this.contracts=i,this.chainId=w(r);const s=i.tokenBridgeRelayer;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridgeRelayer=Je(s,n),this.tokenBridgeProgramId=new c(i.tokenBridge),this.coreBridgeProgramId=new c(i.coreBridge)}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new et(n,i,e,s.contracts)}async*transfer(e,r,n,i,s){const a=new S(e).unwrap(),d=r.address.toUniversalAddress().toUint8Array(),u=this.mintAddress(n),g=new D;if(q(n)){const p=V(u,a);try{await Cn(this.connection,p)}catch(T){if(T instanceof qe){const C=zt(a,p,a,u);g.add(C)}else throw T}}const f=s||0n,h=q(n),y=h?await Gr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,u,i,f,d,r.chain,0,h):await Zr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,u,i,f,d,r.chain,0);g.add(y),g.feePayer=a,yield this.createUnsignedTx({transaction:g},"AutomaticTokenBridge.Transfer")}async*redeem(e,r){const n=new D;throw yield this.createUnsignedTx({transaction:n},"AutomaticTokenBridge.Redeem"),new Error("Method not implemented.")}async getRelayerFee(e,r){const n=this.mintAddress(r),[{fee:i},{swapRate:s},{relayerFeePrecision:o}]=await Promise.all([this.getForeignContract(e),this.getRegisteredToken(n),this.getRedeemerConfig()]),a=Number(await Z.getDecimals(this.network,this.chain,this.connection,r)),d=de.pow(new B(a)).mul(i).mul(re).div(new B(o).mul(s));return BigInt(d.toString())}async maxSwapAmount(e){const r=this.mintAddress(e),[{swapRate:n,maxNativeSwapAmount:i},{swapRate:s}]=await Promise.all([this.getRegisteredToken(r),this.getRegisteredToken(F)]),o=Number(await Z.getDecimals(this.network,this.chain,this.connection,e)),a=this.calculateNativeSwapRate(s,n),d=o>ne?i.mul(a).mul(de.pow(new B(o-ne))).div(re):i.mul(a).div(de.pow(new B(ne-o)).mul(re));return BigInt(d.toString())}async nativeTokenAmount(e,r){if(r===0n)return 0n;const n=this.mintAddress(e),i=Number(await Z.getDecimals(this.network,this.chain,this.connection,e)),[{swapRate:s},{swapRate:o}]=await Promise.all([this.getRegisteredToken(n),this.getRegisteredToken(F)]),a=this.calculateNativeSwapRate(o,s),d=i>ne?re.mul(new B(r.toString())).div(a.mul(de.pow(new B(i-ne)))):re.mul(new B(r.toString())).mul(de.pow(new B(ne-i))).div(a);return BigInt(d.toString())}async isRegisteredToken(e){const r=this.mintAddress(e);try{return await this.getRegisteredToken(r),!0}catch(n){if(n.message?.includes("Account does not exist"))return!1;throw n}}mintAddress(e){return q(e)?new c(F):new S(e).unwrap()}async getRegisteredTokens(){return Hr[this.network].map(e=>xe(this.chain,e))}calculateNativeSwapRate(e,r){return re.mul(e).div(r)}async getForeignContract(e){return await this.tokenBridgeRelayer.account.foreignContract.fetch(Ge(this.tokenBridgeRelayer.programId,e))}async getRegisteredToken(e){return await this.tokenBridgeRelayer.account.registeredToken.fetch(Ze(this.tokenBridgeRelayer.programId,e))}async getRedeemerConfig(){return await this.tokenBridgeRelayer.account.redeemerConfig.fetch(ur(this.tokenBridgeRelayer.programId))}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}const Rt={version:"0.4.0",name:"tokenBridgeRelayer",instructions:[{name:"completeNativeTransferWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"mint",isMut:!1,isSigner:!1},{name:"recipientTokenAccount",isMut:!0,isSigner:!1},{name:"recipient",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"completeWrappedTransferWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1},{name:"recipientTokenAccount",isMut:!0,isSigner:!1},{name:"recipient",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"vaa",isMut:!1,isSigner:!1},{name:"tokenBridgeClaim",isMut:!0,isSigner:!1},{name:"tokenBridgeForeignEndpoint",isMut:!1,isSigner:!1},{name:"tokenBridgeMintAuthority",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"vaaHash",type:{array:["u8",32]}}]},{name:"initialize",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"senderConfig",isMut:!0,isSigner:!1},{name:"redeemerConfig",isMut:!0,isSigner:!1},{name:"authority",isMut:!1,isSigner:!1},{name:"lutAddress",isMut:!0,isSigner:!1},{name:"lut",isMut:!0,isSigner:!1},{name:"lutProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1}],args:[{name:"recentSlot",type:"u64"}]},{name:"resolveExecuteVaaV1",accounts:[],args:[{name:"vaaBody",type:"bytes"}],returns:{defined:"ResolverInstructionGroups"}},{name:"transferNativeTokensWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"mint",isMut:!0,isSigner:!1},{name:"fromTokenAccount",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeCustody",isMut:!0,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"tokenBridgeCustodySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"payee",isMut:!0,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"associatedTokenProgram",isMut:!1,isSigner:!1},{name:"executorProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"TransferNativeTokensWithRelayArgs"}}]},{name:"transferWrappedTokensWithRelay",accounts:[{name:"payer",isMut:!0,isSigner:!0},{name:"config",isMut:!1,isSigner:!1},{name:"tokenBridgeWrappedMint",isMut:!0,isSigner:!1},{name:"fromTokenAccount",isMut:!0,isSigner:!1},{name:"tmpTokenAccount",isMut:!0,isSigner:!1},{name:"tokenBridgeWrappedMeta",isMut:!1,isSigner:!1},{name:"tokenBridgeConfig",isMut:!1,isSigner:!1},{name:"tokenBridgeAuthoritySigner",isMut:!1,isSigner:!1},{name:"wormholeBridge",isMut:!0,isSigner:!1},{name:"wormholeMessage",isMut:!0,isSigner:!0},{name:"tokenBridgeEmitter",isMut:!1,isSigner:!1},{name:"tokenBridgeSequence",isMut:!0,isSigner:!1},{name:"wormholeFeeCollector",isMut:!0,isSigner:!1},{name:"payee",isMut:!0,isSigner:!1},{name:"wormholeProgram",isMut:!1,isSigner:!1},{name:"tokenBridgeProgram",isMut:!1,isSigner:!1},{name:"systemProgram",isMut:!1,isSigner:!1},{name:"tokenProgram",isMut:!1,isSigner:!1},{name:"executorProgram",isMut:!1,isSigner:!1},{name:"clock",isMut:!1,isSigner:!1},{name:"rent",isMut:!1,isSigner:!1}],args:[{name:"args",type:{defined:"TransferWrappedTokensWithRelayArgs"}}]}],accounts:[{name:"LUT",type:{kind:"struct",fields:[{name:"bump",type:"u8"},{name:"address",type:"publicKey"}]}},{name:"RedeemerConfig",type:{kind:"struct",fields:[{name:"bump",type:"u8"}]}},{name:"SenderConfig",type:{kind:"struct",fields:[{name:"bump",type:"u8"}]}}],types:[{name:"InstructionGroup",type:{kind:"struct",fields:[{name:"instructions",type:{vec:{defined:"SerializableInstruction"}}},{name:"addressLookupTables",type:{vec:"publicKey"}}]}},{name:"InstructionGroups",type:{kind:"struct",fields:[{name:"groups",type:{vec:{defined:"InstructionGroup"}}}]}},{name:"MissingAccounts",type:{kind:"struct",fields:[{name:"accounts",type:{vec:"publicKey"}},{name:"addressLookupTables",type:{vec:"publicKey"}}]}},{name:"ResolverInstructionGroups",type:{kind:"enum",variants:[{name:"Resolved",fields:[{name:"groups",type:{defined:"InstructionGroups"}}]},{name:"Missing",fields:[{name:"accounts",type:{defined:"MissingAccounts"}}]},{name:"Account"}]}},{name:"SerializableAccountMeta",type:{kind:"struct",fields:[{name:"pubkey",type:"publicKey"},{name:"isSigner",type:"bool"},{name:"isWritable",type:"bool"}]}},{name:"SerializableInstruction",type:{kind:"struct",fields:[{name:"programId",type:"publicKey"},{name:"accounts",type:{vec:{defined:"SerializableAccountMeta"}}},{name:"data",type:"bytes"}]}},{name:"TransferNativeTokensWithRelayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"nonce",type:"u32"},{name:"wrapNative",type:"bool"},{name:"dstTransferRecipient",type:{array:["u8",32]}},{name:"dstExecutionAddress",type:{array:["u8",32]}},{name:"execAmount",type:"u64"},{name:"signedQuoteBytes",type:"bytes"},{name:"relayInstructions",type:"bytes"}]}},{name:"TransferWrappedTokensWithRelayArgs",type:{kind:"struct",fields:[{name:"amount",type:"u64"},{name:"recipientChain",type:"u16"},{name:"recipientAddress",type:{array:["u8",32]}},{name:"nonce",type:"u32"},{name:"dstTransferRecipient",type:{array:["u8",32]}},{name:"dstExecutionAddress",type:{array:["u8",32]}},{name:"execAmount",type:"u64"},{name:"signedQuoteBytes",type:"bytes"},{name:"relayInstructions",type:"bytes"}]}}],errors:[{code:6e3,name:"InvalidWormholeBridge",msg:"invalidWormholeBridge"},{code:6001,name:"InvalidWormholeFeeCollector",msg:"invalidWormholeFeeCollector"},{code:6002,name:"OwnerOnly",msg:"ownerOnly"},{code:6003,name:"OutboundTransfersPaused",msg:"outboundTransfersPaused"},{code:6004,name:"OwnerOrAssistantOnly",msg:"ownerOrAssistantOnly"},{code:6005,name:"NotPendingOwner",msg:"notPendingOwner"},{code:6006,name:"AlreadyTheOwner",msg:"alreadyTheOwner"},{code:6007,name:"AlreadyTheAssistant",msg:"alreadyTheAssistant"},{code:6008,name:"AlreadyTheFeeRecipient",msg:"alreadyTheFeeRecipient"},{code:6009,name:"BumpNotFound",msg:"bumpNotFound"},{code:6010,name:"FailedToMakeImmutable",msg:"failedToMakeImmutable"},{code:6011,name:"InvalidForeignContract",msg:"invalidForeignContract"},{code:6012,name:"ZeroBridgeAmount",msg:"zeroBridgeAmount"},{code:6013,name:"InvalidToNativeAmount",msg:"invalidToNativeAmount"},{code:6014,name:"NativeMintRequired",msg:"nativeMintRequired"},{code:6015,name:"SwapsNotAllowedForNativeMint",msg:"swapsNotAllowedForNativeMint"},{code:6016,name:"InvalidTokenBridgeConfig",msg:"invalidTokenBridgeConfig"},{code:6017,name:"InvalidTokenBridgeAuthoritySigner",msg:"invalidTokenBridgeAuthoritySigner"},{code:6018,name:"InvalidTokenBridgeCustodySigner",msg:"invalidTokenBridgeCustodySigner"},{code:6019,name:"InvalidTokenBridgeEmitter",msg:"invalidTokenBridgeEmitter"},{code:6020,name:"InvalidTokenBridgeSequence",msg:"invalidTokenBridgeSequence"},{code:6021,name:"InvalidRecipient",msg:"invalidRecipient"},{code:6022,name:"InvalidTransferToChain",msg:"invalidTransferToChain"},{code:6023,name:"InvalidTransferTokenChain",msg:"invalidTransferTokenChain"},{code:6024,name:"InvalidPrecision",msg:"invalidPrecision"},{code:6025,name:"InvalidTransferToAddress",msg:"invalidTransferToAddress"},{code:6026,name:"AlreadyRedeemed",msg:"alreadyRedeemed"},{code:6027,name:"InvalidTokenBridgeForeignEndpoint",msg:"invalidTokenBridgeForeignEndpoint"},{code:6028,name:"InvalidTokenBridgeMintAuthority",msg:"invalidTokenBridgeMintAuthority"},{code:6029,name:"InvalidPublicKey",msg:"invalidPublicKey"},{code:6030,name:"ZeroSwapRate",msg:"zeroSwapRate"},{code:6031,name:"TokenNotRegistered",msg:"tokenNotRegistered"},{code:6032,name:"ChainNotRegistered",msg:"chainNotRegistered"},{code:6033,name:"TokenAlreadyRegistered",msg:"tokenAlreadyRegistered"},{code:6034,name:"FeeCalculationError",msg:"tokenFeeCalculationError"},{code:6035,name:"InvalidSwapCalculation",msg:"invalidSwapCalculation"},{code:6036,name:"InsufficientFunds",msg:"insufficientFunds"},{code:6037,name:"FailedToParseVaaBody",msg:"failedToParseVaaBody"}]};class se{network;chain;connection;contracts;relayerProgramId;executorProgramId;wormholeProgramId;tokenBridgeProgramId;relayerProgram;constructor(e,r,n,i){if(this.network=e,this.chain=r,this.connection=n,this.contracts=i,!i.executorTokenBridge)throw new Error(`Executor Token Bridge contracts not found for network ${e} and chain ${r}`);this.relayerProgramId=new c(i.executorTokenBridge.relayer),this.executorProgramId=new c(i.executor),this.wormholeProgramId=new c(i.coreBridge),this.tokenBridgeProgramId=new c(i.tokenBridge),this.relayerProgram=new ke(Rt,this.relayerProgramId,{connection:this.connection})}static async fromRpc(e,r){const[n,i]=await Z.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch: ${s.network} != ${n}`);return new se(n,i,e,s.contracts)}async*transfer(e,r,n,i,s,o){const a=hn.get(this.network,r.chain);if(!a||!a.relayer)throw new Error(`Token Bridge Executor Relayer contract for domain ${r.chain} not found`);const d=a.relayer,u=new S(e).unwrap(),g=w(r.chain),f=r.address.toUniversalAddress(),{estimatedCost:h,signedQuote:y,relayInstructions:p}=s,T=dt(pn,y),C=dt(yn,p),R=new ge(this.network,this.chain,this.connection,this.contracts),I=q(n),L=!I&&await R.isWrappedAsset(n),k=I?F:new S(n).unwrap(),E=await Z.getTokenProgramId(this.connection,k),j=new c(y.quote.payeeAddress),J=ie.generate(),ye=wn(r.chain,d),Re=ye,we=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],Ee=c.findProgramAddressSync([k.toBuffer()],this.tokenBridgeProgramId)[0],Se=c.findProgramAddressSync([l.from("authority_signer")],this.tokenBridgeProgramId)[0],Xt=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0],{wormholeEmitter:tt,wormholeSequence:nt,wormholeFeeCollector:rt,wormholeBridge:it}=Et(this.tokenBridgeProgramId,this.wormholeProgramId),st=c.findProgramAddressSync([l.from("sender")],this.relayerProgramId)[0],at=V(k,u,!1,E),ot=c.findProgramAddressSync([l.from("tmp"),k.toBytes()],this.relayerProgramId)[0],ee=[];if(o&&o.feeAmount>0n){const We=new c(o.referrer.address.toString());if(k.equals(F))ee.push(v.transfer({fromPubkey:u,toPubkey:We,lamports:o.feeAmount}));else{const _e=V(k,We,!0,E),nn=V(k,u,!0,E);await this.connection.getAccountInfo(_e)||ee.push(cr(u,_e,We,k,E)),ee.push(qt(nn,_e,u,o.feeAmount,void 0,E))}}const jt=o?o.remainingAmount:i,ct={amount:new B(jt.toString()),recipientChain:g,recipientAddress:Array.from(f.toUint8Array()),nonce:0,dstTransferRecipient:Array.from(ye.toUint8Array()),dstExecutionAddress:Array.from(Re.toUint8Array()),execAmount:new B(h.toString()),signedQuoteBytes:l.from(T),relayInstructions:l.from(C)};L?ee.push(await this.relayerProgram.methods.transferWrappedTokensWithRelay(ct).accountsStrict({payer:u,config:st,tokenBridgeWrappedMint:k,fromTokenAccount:at,tmpTokenAccount:ot,tokenBridgeWrappedMeta:K(this.tokenBridgeProgramId,k),tokenBridgeConfig:we,tokenBridgeAuthoritySigner:Se,wormholeBridge:it,wormholeMessage:J.publicKey,tokenBridgeEmitter:tt,tokenBridgeSequence:nt,wormholeFeeCollector:rt,payee:j,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,systemProgram:v.programId,tokenProgram:E,executorProgram:this.executorProgramId,clock:Ue,rent:W}).instruction()):ee.push(await this.relayerProgram.methods.transferNativeTokensWithRelay({...ct,wrapNative:q(n)}).accountsStrict({payer:u,config:st,mint:k,fromTokenAccount:at,tmpTokenAccount:ot,tokenBridgeConfig:we,tokenBridgeCustody:Ee,tokenBridgeAuthoritySigner:Se,tokenBridgeCustodySigner:Xt,wormholeBridge:it,wormholeMessage:J.publicKey,tokenBridgeEmitter:tt,tokenBridgeSequence:nt,wormholeFeeCollector:rt,payee:j,systemProgram:v.programId,tokenProgram:E,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,associatedTokenProgram:H,executorProgram:this.executorProgramId,clock:Ue,rent:W}).instruction());const ut=await this.getAddressLookupTable(),{blockhash:Jt}=await this.connection.getLatestBlockhash(),en=new lt({payerKey:u,instructions:ee,recentBlockhash:Jt}).compileToV0Message(ut?[ut]:[]),tn=new mt(en);yield this.createUnsignedTx({transaction:tn,signers:[J]},"ExecutorTokenBridge.transfer")}async*redeem(e,r){const n=new S(e).unwrap(),i=new S(r.payload.payload.targetRecipient).unwrap(),s=r.payload.token.chain,o=r.payload.token.address,a=s===this.chain;let d;if(a)d=new S(o).unwrap();else{const Se=await new ge(this.network,this.chain,this.connection,this.contracts).getWrappedAsset({chain:s,address:o});d=new S(Se).unwrap()}const u=await Z.getTokenProgramId(this.connection,d),g=V(d,i,!0,u),f=Y(this.wormholeProgramId,l.from(r.hash));await this.connection.getAccountInfo(f)||(yield*new Wt(this.network,this.chain,this.connection,this.contracts).postVaa(n,r));const y=new S(r.payload.to.address).unwrap(),p=new ke(Rt,y,{connection:this.connection}),T=c.findProgramAddressSync([l.from("redeemer")],p.programId)[0],C=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],R=c.findProgramAddressSync([l.from("tmp"),d.toBytes()],p.programId)[0],I=Q(this.tokenBridgeProgramId,r.emitterAddress.toUint8Array(),w(r.emitterChain),r.sequence),L=X(this.tokenBridgeProgramId,w(r.emitterChain),r.emitterAddress.toUint8Array()),k=c.findProgramAddressSync([d.toBuffer()],this.tokenBridgeProgramId)[0],E=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0];let j;const J=Array.from(r.hash);a?j=await p.methods.completeNativeTransferWithRelay(J).accountsStrict({payer:n,config:T,mint:d,recipientTokenAccount:g,recipient:i,tmpTokenAccount:R,tokenBridgeConfig:C,vaa:f,tokenBridgeClaim:I,tokenBridgeForeignEndpoint:L,tokenBridgeCustody:k,tokenBridgeCustodySigner:E,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:u,associatedTokenProgram:H,systemProgram:v.programId,rent:W}).instruction():j=await p.methods.completeWrappedTransferWithRelay(J).accountsStrict({payer:n,config:T,tokenBridgeWrappedMint:d,recipientTokenAccount:g,recipient:i,tmpTokenAccount:R,tokenBridgeWrappedMeta:K(this.tokenBridgeProgramId,d),tokenBridgeConfig:C,vaa:f,tokenBridgeClaim:I,tokenBridgeForeignEndpoint:L,tokenBridgeMintAuthority:pe(this.tokenBridgeProgramId),wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:u,associatedTokenProgram:H,systemProgram:v.programId,rent:W}).instruction();const{blockhash:ye}=await this.connection.getLatestBlockhash(),Re=new lt({payerKey:n,instructions:[j],recentBlockhash:ye}).compileToV0Message(),we=new mt(Re);yield this.createUnsignedTx({transaction:we,signers:[]},"ExecutorTokenBridge.redeem")}async getAddressLookupTable(){const e=c.findProgramAddressSync([l.from("lut")],this.relayerProgramId)[0];try{const r=(await this.relayerProgram.account.lut.fetch(e)).address,n=await this.connection.getAddressLookupTable(r);if(n.value)return n.value}catch{}return null}static associatedTokenAccountMinRent=void 0;async estimateMsgValueAndGasLimit(e,r){let n=0n;if(n+=2n*5000n+7n*5000n+1400000n,n+=2n*5000n+7n*5000n,n+=5000n+3200000n,q(e.address)||Sn(e)===F.toString()?n+=5000n+5000000n:n+=5000n+1200000n,r){const i=new c(r.address.toString());if(!q(e.address)){const s=new S(e.address).unwrap(),o=await this.connection.getAccountInfo(s);if(o===null)throw new Error("Couldn't determine token program. Mint account is null.");const a=V(s,i,!0,o.owner);await this.connection.getAccountInfo(a)===null&&(se.associatedTokenAccountMinRent||(se.associatedTokenAccountMinRent=BigInt(await this.connection.getMinimumBalanceForRentExemption(165))),n+=se.associatedTokenAccountMinRent)}}return{msgValue:n,gasLimit:310000n}}createUnsignedTx(e,r,n=!1){return new Le(e,this.network,this.chain,r,n)}}Oe(ze,"TokenBridge",ge);Oe(ze,"AutomaticTokenBridge",et);Oe(ze,"ExecutorTokenBridge",se);export{be as CreateMetadataAccountArgs,G as Creator,Pe as Data,Qe as EndpointRegistration,Rt as ExecutorTokenBridgeRelayerIdl,Ct as Key,je as Metadata,et as SolanaAutomaticTokenBridge,se as SolanaExecutorTokenBridge,ge as SolanaTokenBridge,me as SplTokenMetadataProgram,Ht as TOKEN_BRIDGE_IDL,Vr as TOKEN_BRIDGE_RELAYER_IDL,He as TokenBridgeConfig,Xe as WrappedMeta,Pr as coder,bt as createApproveAuthoritySignerInstruction,Ir as createAttestTokenInstruction,vt as createCompleteTransferNativeInstruction,Er as createCompleteTransferWrappedInstruction,_r as createCreateWrappedInstruction,ii as createInitializeInstruction,x as createReadOnlyTokenBridgeProgramInterface,si as createRegisterChainInstruction,vr as createTokenBridgeProgramInterface,Je as createTokenBridgeRelayerProgramInterface,Pt as createTransferNativeInstruction,Gr as createTransferNativeTokensWithRelayInstruction,It as createTransferNativeWithPayloadInstruction,zr as createTransferWrappedInstruction,Zr as createTransferWrappedTokensWithRelayInstruction,qr as createTransferWrappedWithPayloadInstruction,ai as createUpgradeContractInstruction,ce as deriveAuthoritySignerKey,ve as deriveCustodyKey,he as deriveCustodySignerKey,X as deriveEndpointKey,Ge as deriveForeignContractAddress,pe as deriveMintAuthorityKey,$e as deriveRedeemerAccountKey,ur as deriveRedeemerConfigAddress,Ze as deriveRegisteredTokenAddress,Ye as deriveSenderAccountKey,Dt as deriveSenderConfigAddress,Ie as deriveSplTokenMetadataKey,Kt as deriveTmpTokenAccountAddress,_ as deriveTokenBridgeConfigKey,Vt as deriveTokenTransferMessageAddress,K as deriveWrappedMetaKey,ue as deriveWrappedMintKey,Bt as getAttestTokenAccounts,Rr as getCompleteTransferNativeAccounts,ci as getCompleteTransferNativeWithPayloadCpiAccounts,Wr as getCompleteTransferWrappedAccounts,ui as getCompleteTransferWrappedWithPayloadCpiAccounts,Nr as getCreateWrappedAccounts,ni as getEndpointRegistration,Fr as getInitializeAccounts,ri as getMetadata,Ur as getRegisterChainAccounts,ti as getTokenBridgeConfig,oi as getTokenBridgeDerivedAccounts,Or as getTransferNativeAccounts,Qt as getTransferNativeWithPayloadAccounts,Dr as getTransferNativeWithPayloadCpiAccounts,Lr as getTransferWrappedAccounts,Yt as getTransferWrappedWithPayloadAccounts,Kr as getTransferWrappedWithPayloadCpiAccounts,xr as getUpgradeContractAccounts,Me as getWrappedMeta};