@wormhole-foundation/wormhole-connect 4.1.0-beta.1-development → 4.2.0-beta.0-development

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (350) hide show
  1. package/dist/assets/{aptos-C9pj8h2Q.js → aptos-DgUCX7ng.js} +3 -3
  2. package/dist/assets/{evm-DCydYqBI.js → evm-B6bqAPTR.js} +4 -4
  3. package/dist/assets/{evm-CJXv6IQV.js → evm-Ve5nG8Fs.js} +1 -1
  4. package/dist/assets/{index-LvDsy6wR.js → index-BJokXZAc.js} +1 -1
  5. package/dist/assets/{index-BqxX-Ey7.js → index-BJv9sngo.js} +1 -1
  6. package/dist/assets/{index-C9cy4cDs.js → index-BjZMFLjq.js} +1 -1
  7. package/dist/assets/{index-FJ-n91Op.js → index-BwbPlAQZ.js} +1 -1
  8. package/dist/assets/{index-Clu5I99l.js → index-Bzg4DNh9.js} +1 -1
  9. package/dist/assets/{index-ezhfpCvx.js → index-CKXa657f.js} +1 -1
  10. package/dist/assets/index-CXiuP738.js +1 -0
  11. package/dist/assets/{index-CNExx9Zb.js → index-CvTvoHH-.js} +1 -1
  12. package/dist/assets/{index-C25bHdOM.js → index-D1ULRVbZ.js} +1 -1
  13. package/dist/assets/{index-DpabQJOX.js → index-DlH9IMQl.js} +1 -1
  14. package/dist/assets/{index-C8u74RER.js → index-Dsb-5apv.js} +1 -1
  15. package/dist/assets/{index-D9ApKauA.js → index-_YFUWLUM.js} +1 -1
  16. package/dist/assets/{index-CoIvdDsX.js → index-jg26xdEi.js} +1 -1
  17. package/dist/assets/{provider-jsonrpc-DuMpLBV0.js → provider-jsonrpc-DNgUKjG6.js} +1 -1
  18. package/dist/assets/{solana-DWuIx6gK.js → solana-D4RepnSA.js} +2 -2
  19. package/dist/assets/{sui-BcTGBE_4.js → sui-Du5h-f8S.js} +3 -3
  20. package/dist/main.mjs +185 -140
  21. package/dist/src/components/ConfigurablePageHeader.d.ts +1 -1
  22. package/dist/src/components/ConfigurablePageHeader.d.ts.map +1 -1
  23. package/dist/src/components/Header.d.ts +1 -0
  24. package/dist/src/components/Header.d.ts.map +1 -1
  25. package/dist/src/components/PageHeader.d.ts +1 -3
  26. package/dist/src/components/PageHeader.d.ts.map +1 -1
  27. package/dist/src/components/SampleApp/index.d.ts.map +1 -1
  28. package/dist/src/components/v3/BackButton.d.ts +6 -0
  29. package/dist/src/components/v3/BackButton.d.ts.map +1 -0
  30. package/dist/src/components/v3/FormContent.d.ts +5 -0
  31. package/dist/src/components/v3/FormContent.d.ts.map +1 -0
  32. package/dist/src/config/constants.d.ts.map +1 -1
  33. package/dist/src/config/events.d.ts +2 -1
  34. package/dist/src/config/events.d.ts.map +1 -1
  35. package/dist/src/config/mainnet/chains.d.ts.map +1 -1
  36. package/dist/src/config/mainnet/rpcs.d.ts.map +1 -1
  37. package/dist/src/config/mainnet/tokens.d.ts.map +1 -1
  38. package/dist/src/config/mainnet/wrappedTokens.d.ts +6 -0
  39. package/dist/src/config/mainnet/wrappedTokens.d.ts.map +1 -1
  40. package/dist/src/config/types.d.ts +6 -11
  41. package/dist/src/config/types.d.ts.map +1 -1
  42. package/dist/src/config/ui.d.ts +9 -0
  43. package/dist/src/config/ui.d.ts.map +1 -1
  44. package/dist/src/consts/wallet.d.ts.map +1 -1
  45. package/dist/src/hooks/useAutoEnableGasDropoff.d.ts +3 -1
  46. package/dist/src/hooks/useAutoEnableGasDropoff.d.ts.map +1 -1
  47. package/dist/src/hooks/useConnectToLastUsedWallet.d.ts.map +1 -1
  48. package/dist/src/hooks/useSortedRoutesWithQuotes.d.ts.map +1 -1
  49. package/dist/src/hooks/useTransactionHistory.d.ts.map +1 -1
  50. package/dist/src/hooks/useTransactionHistoryLiFi.d.ts +2 -0
  51. package/dist/src/hooks/useTransactionHistoryLiFi.d.ts.map +1 -1
  52. package/dist/src/hooks/useTransactionHistoryMayan.d.ts +2 -0
  53. package/dist/src/hooks/useTransactionHistoryMayan.d.ts.map +1 -1
  54. package/dist/src/hooks/useTransactionHistoryWHScan.d.ts +2 -1
  55. package/dist/src/hooks/useTransactionHistoryWHScan.d.ts.map +1 -1
  56. package/dist/src/icons/PoweredBy.d.ts.map +1 -1
  57. package/dist/src/icons/TokenIcons.d.ts.map +1 -1
  58. package/dist/src/icons/Tokens/AUSD.d.ts +4 -0
  59. package/dist/src/icons/Tokens/AUSD.d.ts.map +1 -0
  60. package/dist/src/routes/lifi/LiFiRoute.d.ts.map +1 -1
  61. package/dist/src/routes/mayan/utils.d.ts.map +1 -1
  62. package/dist/src/routes/monad/consts.d.ts +1 -0
  63. package/dist/src/routes/monad/consts.d.ts.map +1 -1
  64. package/dist/src/routes/monad/monad.test.d.ts +1 -0
  65. package/dist/src/routes/monad/monad.test.d.ts.map +1 -0
  66. package/dist/src/routes/monad/utils.d.ts.map +1 -1
  67. package/dist/src/sdklegacy/config/MAINNET.d.ts.map +1 -1
  68. package/dist/src/telemetry/types.d.ts +4 -2
  69. package/dist/src/telemetry/types.d.ts.map +1 -1
  70. package/dist/src/theme.d.ts +4 -3
  71. package/dist/src/theme.d.ts.map +1 -1
  72. package/dist/src/utils/errors.d.ts.map +1 -1
  73. package/dist/src/utils/fees.d.ts.map +1 -1
  74. package/dist/src/utils/index.d.ts.map +1 -1
  75. package/dist/src/utils/sdkv2.d.ts.map +1 -1
  76. package/dist/src/utils/wallet/index.d.ts +1 -0
  77. package/dist/src/utils/wallet/index.d.ts.map +1 -1
  78. package/dist/src/views/Terms.d.ts.map +1 -1
  79. package/dist/src/views/TxSearch.d.ts.map +1 -1
  80. package/dist/src/views/v3/Bridge/AssetPicker/PickerModal.d.ts.map +1 -1
  81. package/dist/src/views/v3/Bridge/AssetPicker/TokenPickerButton.d.ts +17 -0
  82. package/dist/src/views/v3/Bridge/AssetPicker/TokenPickerButton.d.ts.map +1 -0
  83. package/dist/src/views/v3/Bridge/AssetPicker/TokenPickerButtonContent.d.ts +8 -0
  84. package/dist/src/views/v3/Bridge/AssetPicker/TokenPickerButtonContent.d.ts.map +1 -0
  85. package/dist/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButton.test.d.ts +2 -0
  86. package/dist/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButton.test.d.ts.map +1 -0
  87. package/dist/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButtonContent.test.d.ts +2 -0
  88. package/dist/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButtonContent.test.d.ts.map +1 -0
  89. package/dist/src/views/v3/Bridge/AssetPicker/index.d.ts.map +1 -1
  90. package/dist/src/views/v3/Bridge/GasSlider/index.d.ts.map +1 -1
  91. package/dist/src/views/v3/Bridge/Routes/SingleRoute.d.ts.map +1 -1
  92. package/dist/src/views/v3/Bridge/Routes/index.d.ts +2 -1
  93. package/dist/src/views/v3/Bridge/Routes/index.d.ts.map +1 -1
  94. package/dist/src/views/v3/Bridge/WalletConnector/Controller.d.ts.map +1 -1
  95. package/dist/src/views/v3/Bridge/WalletConnector/ExplorerLink.d.ts.map +1 -1
  96. package/dist/src/views/v3/Bridge/WalletConnector/WalletAddress.d.ts +9 -0
  97. package/dist/src/views/v3/Bridge/WalletConnector/WalletAddress.d.ts.map +1 -0
  98. package/dist/src/views/v3/Bridge/WalletConnector/WalletPickerContent.d.ts.map +1 -1
  99. package/dist/src/views/v3/Bridge/WalletConnector/__tests__/WalletAddress.test.d.ts +2 -0
  100. package/dist/src/views/v3/Bridge/WalletConnector/__tests__/WalletAddress.test.d.ts.map +1 -0
  101. package/dist/src/views/v3/Bridge/index.d.ts.map +1 -1
  102. package/dist/src/views/v3/Redeem/TransactionDetails/index.d.ts.map +1 -1
  103. package/dist/src/views/v3/Redeem/index.d.ts.map +1 -1
  104. package/dist/src/views/v3/TxHistory/Item/index.d.ts.map +1 -1
  105. package/dist/src/views/v3/TxHistory/Widget/Item.d.ts.map +1 -1
  106. package/lib/{account-cIQhxn1E.js → account-K005OXgL.js} +1 -1
  107. package/lib/{account-BVl6Reot.mjs → account-TXlxMyv4.mjs} +2 -2
  108. package/lib/{address-rVHWlcKQ.mjs → address-CX0E32ut.mjs} +1 -1
  109. package/lib/{address-W9jn6Qdk.js → address-DqbIfKOu.js} +1 -1
  110. package/lib/{aptos-B84P9rJZ.mjs → aptos-B1Gf2eCD.mjs} +5 -5
  111. package/lib/{aptos-CNHYHK9c.js → aptos-CnswqE-C.js} +2 -2
  112. package/lib/{aptos-D1WFzBMy.mjs → aptos-DRfXJ8Ba.mjs} +7 -7
  113. package/lib/{aptos-DWDR5o78.js → aptos-DcdKyekw.js} +1 -1
  114. package/lib/{associatedTokenAccount-C4vEEbG5.js → associatedTokenAccount-CeqdaO2m.js} +1 -1
  115. package/lib/{associatedTokenAccount-DF6phO3l.mjs → associatedTokenAccount-Dsm4Hq32.mjs} +3 -3
  116. package/lib/{basic-DJXXfABO.js → basic-BS7Z1PMG.js} +1 -1
  117. package/lib/{basic-NhXxxbR1.js → basic-C6VXQ7m-.js} +1 -1
  118. package/lib/{basic-CukRIaOD.mjs → basic-CFbslwLM.mjs} +3 -3
  119. package/lib/{basic-BERCwt2M.mjs → basic-DnhL0oWa.mjs} +3 -3
  120. package/lib/{chunk-KJH4KKG6-Brt4fyqz.mjs → chunk-KJH4KKG6-BfVMUPsB.mjs} +3 -3
  121. package/lib/{chunk-KJH4KKG6-BbF5W1_N.js → chunk-KJH4KKG6-CJx-rDa6.js} +1 -1
  122. package/lib/constants-BCFTvlgh.js +1 -0
  123. package/lib/{constants-VaoVbllu.mjs → constants-CTJ_-E0d.mjs} +2 -1
  124. package/lib/{core-BCZrVb_s.mjs → core-DT6TBPQP.mjs} +6 -6
  125. package/lib/{core-BE6SS7Ye.js → core-RRp0K__1.js} +3 -3
  126. package/lib/{create-CChLkbGc.mjs → create-C5dhTMHL.mjs} +1 -1
  127. package/lib/{create-4w0DrcRO.js → create-bA3Gyivs.js} +1 -1
  128. package/lib/{evm--K7mr7Kr.js → evm-BwCfQIyJ.js} +2 -2
  129. package/lib/{evm-DKaWm7eC.mjs → evm-BxF9XPn4.mjs} +7 -7
  130. package/lib/{evm-C5BixKBn.js → evm-C3B8jHD7.js} +1 -1
  131. package/lib/{evm-CmmnpcFD.mjs → evm-DlOCiplA.mjs} +5 -5
  132. package/lib/executor.js +1 -1
  133. package/lib/executor.mjs +13 -15
  134. package/lib/hosted.js +1 -1
  135. package/lib/hosted.mjs +1 -1
  136. package/lib/hypercore-DbqOAqKF.js +4 -0
  137. package/lib/{hypercore-birmbh9T.mjs → hypercore-H7pw_pN4.mjs} +4858 -3107
  138. package/lib/{index-qL4D-cpk.js → index-1T4sIL8n.js} +1 -1
  139. package/lib/{index-Ap7250Gf.mjs → index-39tU5Y5t.mjs} +6 -6
  140. package/lib/{index-D7gCsil9.js → index-6m7yero0.js} +1 -1
  141. package/lib/{index-C5I7QiZ7.mjs → index-B6Ppg6EZ.mjs} +3 -3
  142. package/lib/{index-xvG6cxNx.js → index-BEIFBxtP.js} +1 -1
  143. package/lib/{index-zIzzPp6D.mjs → index-BHpJUZne.mjs} +3 -3
  144. package/lib/{index-BTcij9Np.js → index-BJ0xVutl.js} +1 -1
  145. package/lib/{index-Bs28m4ya.js → index-BNpkgexR.js} +1 -1
  146. package/lib/{index-C61IKE_V.mjs → index-BSIPYyeZ.mjs} +2 -2
  147. package/lib/{index-EbSw7SbC.js → index-BTjUHY0e.js} +1 -1
  148. package/lib/{index-BuHdMHLz.mjs → index-Ba1zbu3Q.mjs} +2 -2
  149. package/lib/{index-HrZv1SyT.js → index-BbE02hdW.js} +8 -8
  150. package/lib/{index-BU35GfG0.mjs → index-Bdtj4LUz.mjs} +2 -2
  151. package/lib/{index-pYTU7pQK.mjs → index-BmP0jPVN.mjs} +12 -11
  152. package/lib/{index-CR1itkLl.mjs → index-BnKf2rOm.mjs} +3225 -3035
  153. package/lib/{index-Txz5xwr6.mjs → index-BtU67kjy.mjs} +1 -1
  154. package/lib/{index-CH0iw38J.mjs → index-BuEKhdrW.mjs} +3 -3
  155. package/lib/{index-CN7M4gwf.mjs → index-BviSNDV7.mjs} +5 -5
  156. package/lib/{index-Cys9e11O.js → index-C-SMuVS3.js} +1 -1
  157. package/lib/{index-Cg1Xo1eZ.js → index-C85u3Gj5.js} +1 -1
  158. package/lib/{index-BN_2mA2n.mjs → index-CGqJokTg.mjs} +1 -1
  159. package/lib/{index-Da9rvmCc.js → index-Cb0UWLGI.js} +1 -1
  160. package/lib/{index-DHnmtpvA.mjs → index-CcbY14s5.mjs} +4 -4
  161. package/lib/{index-BKgliEPZ.mjs → index-CrWTw0Se.mjs} +2 -2
  162. package/lib/{index-C8YhpD9T.mjs → index-CsLyPoC6.mjs} +4 -4
  163. package/lib/{index-B_JJ50Y-.mjs → index-D-HUNEka.mjs} +4 -4
  164. package/lib/index-DAJZN12d.js +1 -0
  165. package/lib/{index-BhMcIAHt.js → index-DJ2w1fz1.js} +1 -1
  166. package/lib/{index-BRFbmsc_.js → index-DVm_f5E1.js} +1 -1
  167. package/lib/{index-CO4ZoIAU.mjs → index-DjmVBSGQ.mjs} +4 -4
  168. package/lib/{index-Co3mm7UN.mjs → index-DrJE8udd.mjs} +1 -1
  169. package/lib/{index-fTUcaKb4.js → index-DuhYwr0t.js} +1 -1
  170. package/lib/{index-BQ0lWQfT.mjs → index-DwEx1Hn-.mjs} +2 -2
  171. package/lib/{index-DBofyYkS.js → index-DziujHu1.js} +1 -1
  172. package/lib/{index-Dou5sFku.js → index-JWbF-m3e.js} +1 -1
  173. package/lib/{index-N4FkpEh9.mjs → index-NAUBlFLG.mjs} +4 -4
  174. package/lib/{index-D1odbjeH.mjs → index-VnJcNK62.mjs} +3 -3
  175. package/lib/{index-DVxmRy4C.js → index-WrXSs0ic.js} +1 -1
  176. package/lib/{index-CsdD1TNi.js → index-aMKUba1k.js} +1 -1
  177. package/lib/{index-DSnylejH.mjs → index-dufPAW5T.mjs} +292 -269
  178. package/lib/{index-lZY5fTXF.js → index-lAqXlt-a.js} +1 -1
  179. package/lib/{index-BUbUhbMe.js → index-mikg85u5.js} +1 -1
  180. package/lib/{index-BScgBddV.mjs → index-o1SAPXm_.mjs} +3 -3
  181. package/lib/{index-CED5jdrg.js → index-pn6NZmOS.js} +1 -1
  182. package/lib/{index-DNZ-Pkpm.mjs → index-rxQSA9t0.mjs} +6 -6
  183. package/lib/{index-Cw0jWBks.js → index-t_koRpGi.js} +1 -1
  184. package/lib/{index-DALvn9lg.js → index-v7w8krM0.js} +1 -1
  185. package/lib/{index-japympio.js → index-wadjmD_G.js} +1 -1
  186. package/lib/{index.es-CDqFguL5.mjs → index.es-3KAM8l3G.mjs} +4 -4
  187. package/lib/{index.es-DmmqAOLD.js → index.es-B3FwsRfN.js} +3 -3
  188. package/lib/{index.es-B0fk_42a.mjs → index.es-CYyuSfPG.mjs} +4 -4
  189. package/lib/{index.es-Dg6IFrL4.js → index.es-ClIr5Gv-.js} +1 -1
  190. package/lib/index.js +78 -33
  191. package/lib/index.mjs +9157 -8833
  192. package/lib/{keypair-DWucLGoA.js → keypair-DCgXFOw5.js} +1 -1
  193. package/lib/{keypair-CP7syX9B.mjs → keypair-vpG2fl-q.mjs} +3 -3
  194. package/lib/lifi.js +1 -1
  195. package/lib/lifi.mjs +75 -76
  196. package/lib/mayan.js +2 -2
  197. package/lib/mayan.mjs +11 -10
  198. package/lib/{mint-CoNdQTGM.mjs → mint-BPrKG-Zc.mjs} +3 -3
  199. package/lib/{mint-CxQ6P5lT.js → mint-DW-XgF68.js} +1 -1
  200. package/lib/monad.js +1 -1
  201. package/lib/monad.mjs +91 -58
  202. package/lib/multiToken-B9BoSxdr.js +1 -0
  203. package/lib/{multiToken-Bm-K5dRJ.mjs → multiToken-DMllgxzT.mjs} +4 -3
  204. package/lib/ntt.js +2 -2
  205. package/lib/ntt.mjs +77 -86
  206. package/lib/{platform-Cil_UtAQ.mjs → platform-CSpAb386.mjs} +2788 -2748
  207. package/lib/{platform-BMKYxqvv.js → platform-Csj1Outc.js} +1 -1
  208. package/lib/platform-DCcL7jHP.js +11 -0
  209. package/lib/{platform-vRQufc6j.mjs → platform-YzJZdSCf.mjs} +3 -3
  210. package/lib/{secp256k1-CglUNI04.js → secp256k1-B2G0zB-5.js} +1 -1
  211. package/lib/{secp256k1-LTcmQEQ5.mjs → secp256k1-BZFiBDHQ.mjs} +1 -1
  212. package/lib/{secp256k1-CcVQkYNr.js → secp256k1-Bz-QjKBU.js} +1 -1
  213. package/lib/{secp256k1-DROP2Lhv.mjs → secp256k1-Cteng3v9.mjs} +1 -1
  214. package/lib/{secp256k1-BkoM1Jum.js → secp256k1-CxjctkO3.js} +1 -1
  215. package/lib/{secp256k1-DzRCmd6a.mjs → secp256k1-D3i7kc2M.mjs} +1 -1
  216. package/lib/{signer-0hWrZ5BZ.mjs → signer-D2GRgRrw.mjs} +2 -2
  217. package/lib/{signer-DyqulDUM.js → signer-gjSiV5v3.js} +1 -1
  218. package/lib/{solana-C4k_Yg7w.js → solana-BE2DAanS.js} +4 -4
  219. package/lib/{solana-D1LVIhGd.mjs → solana-Df231Yni.mjs} +10 -10
  220. package/lib/solana-DfW5T_64.mjs +18 -0
  221. package/lib/solana-Edd9tIkX.js +1 -0
  222. package/lib/{solanaEmbed.esm-AvWQUA9e.mjs → solanaEmbed.esm-B9WG-Afi.mjs} +4 -4
  223. package/lib/{solanaEmbed.esm--Ac-IlRA.js → solanaEmbed.esm-BqcrHrhl.js} +1 -1
  224. package/lib/{solidity-CbDkqHjE.js → solidity-BW7c8rFv.js} +1 -1
  225. package/lib/{solidity-Dk_mvceo.mjs → solidity-D9gSgFcp.mjs} +1 -1
  226. package/lib/src/components/ConfigurablePageHeader.d.ts +1 -1
  227. package/lib/src/components/ConfigurablePageHeader.d.ts.map +1 -1
  228. package/lib/src/components/Header.d.ts +1 -0
  229. package/lib/src/components/Header.d.ts.map +1 -1
  230. package/lib/src/components/PageHeader.d.ts +1 -3
  231. package/lib/src/components/PageHeader.d.ts.map +1 -1
  232. package/lib/src/components/SampleApp/index.d.ts.map +1 -1
  233. package/lib/src/components/v3/BackButton.d.ts +6 -0
  234. package/lib/src/components/v3/BackButton.d.ts.map +1 -0
  235. package/lib/src/components/v3/FormContent.d.ts +5 -0
  236. package/lib/src/components/v3/FormContent.d.ts.map +1 -0
  237. package/lib/src/config/constants.d.ts.map +1 -1
  238. package/lib/src/config/events.d.ts +2 -1
  239. package/lib/src/config/events.d.ts.map +1 -1
  240. package/lib/src/config/mainnet/chains.d.ts.map +1 -1
  241. package/lib/src/config/mainnet/rpcs.d.ts.map +1 -1
  242. package/lib/src/config/mainnet/tokens.d.ts.map +1 -1
  243. package/lib/src/config/mainnet/wrappedTokens.d.ts +6 -0
  244. package/lib/src/config/mainnet/wrappedTokens.d.ts.map +1 -1
  245. package/lib/src/config/types.d.ts +6 -11
  246. package/lib/src/config/types.d.ts.map +1 -1
  247. package/lib/src/config/ui.d.ts +9 -0
  248. package/lib/src/config/ui.d.ts.map +1 -1
  249. package/lib/src/consts/wallet.d.ts.map +1 -1
  250. package/lib/src/hooks/useAutoEnableGasDropoff.d.ts +3 -1
  251. package/lib/src/hooks/useAutoEnableGasDropoff.d.ts.map +1 -1
  252. package/lib/src/hooks/useConnectToLastUsedWallet.d.ts.map +1 -1
  253. package/lib/src/hooks/useSortedRoutesWithQuotes.d.ts.map +1 -1
  254. package/lib/src/hooks/useTransactionHistory.d.ts.map +1 -1
  255. package/lib/src/hooks/useTransactionHistoryLiFi.d.ts +2 -0
  256. package/lib/src/hooks/useTransactionHistoryLiFi.d.ts.map +1 -1
  257. package/lib/src/hooks/useTransactionHistoryMayan.d.ts +2 -0
  258. package/lib/src/hooks/useTransactionHistoryMayan.d.ts.map +1 -1
  259. package/lib/src/hooks/useTransactionHistoryWHScan.d.ts +2 -1
  260. package/lib/src/hooks/useTransactionHistoryWHScan.d.ts.map +1 -1
  261. package/lib/src/icons/PoweredBy.d.ts.map +1 -1
  262. package/lib/src/icons/TokenIcons.d.ts.map +1 -1
  263. package/lib/src/icons/Tokens/AUSD.d.ts +4 -0
  264. package/lib/src/icons/Tokens/AUSD.d.ts.map +1 -0
  265. package/lib/src/routes/lifi/LiFiRoute.d.ts.map +1 -1
  266. package/lib/src/routes/mayan/utils.d.ts.map +1 -1
  267. package/lib/src/routes/monad/consts.d.ts +1 -0
  268. package/lib/src/routes/monad/consts.d.ts.map +1 -1
  269. package/lib/src/routes/monad/monad.test.d.ts +1 -0
  270. package/lib/src/routes/monad/monad.test.d.ts.map +1 -0
  271. package/lib/src/routes/monad/utils.d.ts.map +1 -1
  272. package/lib/src/sdklegacy/config/MAINNET.d.ts.map +1 -1
  273. package/lib/src/telemetry/types.d.ts +4 -2
  274. package/lib/src/telemetry/types.d.ts.map +1 -1
  275. package/lib/src/theme.d.ts +4 -3
  276. package/lib/src/theme.d.ts.map +1 -1
  277. package/lib/src/utils/errors.d.ts.map +1 -1
  278. package/lib/src/utils/fees.d.ts.map +1 -1
  279. package/lib/src/utils/index.d.ts.map +1 -1
  280. package/lib/src/utils/sdkv2.d.ts.map +1 -1
  281. package/lib/src/utils/wallet/index.d.ts +1 -0
  282. package/lib/src/utils/wallet/index.d.ts.map +1 -1
  283. package/lib/src/views/Terms.d.ts.map +1 -1
  284. package/lib/src/views/TxSearch.d.ts.map +1 -1
  285. package/lib/src/views/v3/Bridge/AssetPicker/PickerModal.d.ts.map +1 -1
  286. package/lib/src/views/v3/Bridge/AssetPicker/TokenPickerButton.d.ts +17 -0
  287. package/lib/src/views/v3/Bridge/AssetPicker/TokenPickerButton.d.ts.map +1 -0
  288. package/lib/src/views/v3/Bridge/AssetPicker/TokenPickerButtonContent.d.ts +8 -0
  289. package/lib/src/views/v3/Bridge/AssetPicker/TokenPickerButtonContent.d.ts.map +1 -0
  290. package/lib/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButton.test.d.ts +2 -0
  291. package/lib/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButton.test.d.ts.map +1 -0
  292. package/lib/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButtonContent.test.d.ts +2 -0
  293. package/lib/src/views/v3/Bridge/AssetPicker/__tests__/TokenPickerButtonContent.test.d.ts.map +1 -0
  294. package/lib/src/views/v3/Bridge/AssetPicker/index.d.ts.map +1 -1
  295. package/lib/src/views/v3/Bridge/GasSlider/index.d.ts.map +1 -1
  296. package/lib/src/views/v3/Bridge/Routes/SingleRoute.d.ts.map +1 -1
  297. package/lib/src/views/v3/Bridge/Routes/index.d.ts +2 -1
  298. package/lib/src/views/v3/Bridge/Routes/index.d.ts.map +1 -1
  299. package/lib/src/views/v3/Bridge/WalletConnector/Controller.d.ts.map +1 -1
  300. package/lib/src/views/v3/Bridge/WalletConnector/ExplorerLink.d.ts.map +1 -1
  301. package/lib/src/views/v3/Bridge/WalletConnector/WalletAddress.d.ts +9 -0
  302. package/lib/src/views/v3/Bridge/WalletConnector/WalletAddress.d.ts.map +1 -0
  303. package/lib/src/views/v3/Bridge/WalletConnector/WalletPickerContent.d.ts.map +1 -1
  304. package/lib/src/views/v3/Bridge/WalletConnector/__tests__/WalletAddress.test.d.ts +2 -0
  305. package/lib/src/views/v3/Bridge/WalletConnector/__tests__/WalletAddress.test.d.ts.map +1 -0
  306. package/lib/src/views/v3/Bridge/index.d.ts.map +1 -1
  307. package/lib/src/views/v3/Redeem/TransactionDetails/index.d.ts.map +1 -1
  308. package/lib/src/views/v3/Redeem/index.d.ts.map +1 -1
  309. package/lib/src/views/v3/TxHistory/Item/index.d.ts.map +1 -1
  310. package/lib/src/views/v3/TxHistory/Widget/Item.d.ts.map +1 -1
  311. package/lib/{sui-BPAb7kcs.mjs → sui-B9tYcgyb.mjs} +4 -4
  312. package/lib/{sui-CgmDTkXK.js → sui-BVwNcgQT.js} +1 -1
  313. package/lib/{sui-LiXjD27c.js → sui-BtyZE8YC.js} +1 -1
  314. package/lib/{sui-cpCvd7RC.mjs → sui-QP4AZGNc.mjs} +6 -6
  315. package/lib/{tokenHelpers-DvWQs1tu.mjs → tokenHelpers-C53sepsl.mjs} +1 -1
  316. package/lib/{tokenHelpers-CbE0g9BP.js → tokenHelpers-DITWDel1.js} +1 -1
  317. package/lib/{tokens-BJDttoCp.mjs → tokens-CO0YQ3R2.mjs} +3 -3
  318. package/lib/{tokens-CvZuVW-g.js → tokens-CiSHS7oi.js} +1 -1
  319. package/lib/types-CgveSjsw.js +1 -0
  320. package/lib/{types-iFgwQ7vG.mjs → types-Dxx2g1wS.mjs} +170 -168
  321. package/lib/{unsignedTransaction-DCDxTFq8.mjs → unsignedTransaction-D2Ja0SuN.mjs} +2 -2
  322. package/lib/{unsignedTransaction-DA4tlY5u.js → unsignedTransaction-qRBv5Cnd.js} +2 -2
  323. package/lib/{utils-DMf7wRGI.js → utils-BEljbqMf.js} +1 -1
  324. package/lib/{utils-BSxsyW2c.mjs → utils-mBHX3Jpu.mjs} +4 -4
  325. package/lib/{w3m-modal-CtQ0TPA4.mjs → w3m-modal-5v-rsnN8.mjs} +2 -2
  326. package/lib/{w3m-modal-k23UDiov.js → w3m-modal-B0Lu-6W8.js} +1 -1
  327. package/lib/{w3m-modal-ByamyZny.js → w3m-modal-B2xHxAWg.js} +1 -1
  328. package/lib/{w3m-modal-DM5Pf8SH.mjs → w3m-modal-SlcSCSnx.mjs} +2 -2
  329. package/lib/{wallet-CMTEE6Oa.mjs → wallet-Cyosy4Hc.mjs} +1 -1
  330. package/lib/{wallet-BMli0fbu.js → wallet-a0_jwP8j.js} +1 -1
  331. package/lib/{web3-CUwFm9Lx.mjs → web3-CdErAVj5.mjs} +2 -2
  332. package/lib/{web3-DdUeM7iQ.js → web3-x1WCGDiy.js} +1 -1
  333. package/package.json +49 -47
  334. package/dist/assets/index-_UMHESh0.js +0 -1
  335. package/dist/src/components/Button.d.ts +0 -13
  336. package/dist/src/components/Button.d.ts.map +0 -1
  337. package/dist/src/icons/Down.d.ts +0 -5
  338. package/dist/src/icons/Down.d.ts.map +0 -1
  339. package/lib/constants-B9TBfA4z.js +0 -1
  340. package/lib/hypercore-4R7JGmbr.js +0 -4
  341. package/lib/index-C8eqQ_7p.js +0 -1
  342. package/lib/multiToken-YoNvxjur.js +0 -1
  343. package/lib/platform-CCG_jgOO.js +0 -11
  344. package/lib/solana-DKFJvqX8.mjs +0 -18
  345. package/lib/solana-Dmje_Si8.js +0 -1
  346. package/lib/src/components/Button.d.ts +0 -13
  347. package/lib/src/components/Button.d.ts.map +0 -1
  348. package/lib/src/icons/Down.d.ts +0 -5
  349. package/lib/src/icons/Down.d.ts.map +0 -1
  350. package/lib/types-CjNs2oB0.js +0 -1
@@ -1 +1 @@
1
- import{h as R,i as ve,j as un,n as dn,k as ie,l as ln,e as Y,f as X,B as mn,m as gn,o as fn,p as Pe,q as Ut,S as Ft,r as hn,s as pn}from"./index-DDWBTFUk.js";import{P as c,B as l,cG as f,dj as pe,cI as q,cJ as te,cH as A,dr as N,dk as P,cS as S,aI as yn,d7 as xt,ds as De,dl as I,bc as L,bd as M,d6 as Fe,cX as wn,aE as K,da as Ke,dm as j,T as G,du as Sn,dn as Ge,dc as Mn,dd as yt,de as kn,df as An,dg as Tn,dv as wt,V as St,cU as bn,c$ as Ze,be as He}from"../main.mjs";import{P as Ae,c as Cn}from"./index-DmYxP1Uj.js";import"./create-CbNCGANY.js";const T=new c("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"),xe=new c("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb"),$=new c("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"),O=new c("So11111111111111111111111111111111111111112");new c("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class ue extends Error{constructor(e){super(e)}}class Qe extends ue{constructor(){super(...arguments),this.name="TokenAccountNotFoundError"}}class Bn extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountError"}}class Ot extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountOwnerError"}}class ge extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountSizeError"}}class vn extends ue{constructor(){super(...arguments),this.name="TokenInvalidMintError"}}class zt extends ue{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}var ce;(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"})(ce||(ce={}));function $e(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 Mt=f.struct([f.u8("instruction"),q("amount")]);function Pn(t,e,r,n,i=[],s=T){const o=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1}],r,i),a=l.alloc(Mt.span);return Mt.encode({instruction:ce.Approve,amount:BigInt(n)},a),new pe({keys:o,programId:s,data:a})}const kt=f.struct([f.u8("instruction")]);function Oe(t,e,r,n=[],i=T){const s=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,n),o=l.alloc(kt.span);return kt.encode({instruction:ce.CloseAccount},o),new pe({keys:s,programId:i,data:o})}var Te;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Mint=1]="Mint",t[t.Account=2]="Account"})(Te||(Te={}));const Ye=1,In=f.struct([f.u8("m"),f.u8("n"),te("isInitialized"),A("signer1"),A("signer2"),A("signer3"),A("signer4"),A("signer5"),A("signer6"),A("signer7"),A("signer8"),A("signer9"),A("signer10"),A("signer11")]),Xe=In.span;var be;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Initialized=1]="Initialized",t[t.Frozen=2]="Frozen"})(be||(be={}));const Lt=f.struct([A("mint"),A("owner"),q("amount"),f.u32("delegateOption"),A("delegate"),f.u8("state"),f.u32("isNativeOption"),q("isNative"),q("delegatedAmount"),f.u32("closeAuthorityOption"),A("closeAuthority")]),_=Lt.span;async function qt(t,e,r,n=T){const i=await t.getAccountInfo(e,r);return En(e,i,n)}async function ze(t,e){return await Rn(t,[],e)}async function Rn(t,e,r){const n=ur(e);return await t.getMinimumBalanceForRentExemption(n,r)}function En(t,e,r=T){if(!e)throw new Qe;if(!e.owner.equals(r))throw new Ot;if(e.data.length<_)throw new ge;const n=Lt.decode(e.data.slice(0,_));let i=l.alloc(0);if(e.data.length>_){if(e.data.length===Xe)throw new ge;if(e.data[_]!=Te.Account)throw new Bn;i=e.data.slice(_+Ye)}return{address:t,mint:n.mint,owner:n.owner,amount:n.amount,delegate:n.delegateOption?n.delegate:null,delegatedAmount:n.delegatedAmount,isInitialized:n.state!==be.Uninitialized,isFrozen:n.state===be.Frozen,isNative:!!n.isNativeOption,rentExemptReserve:n.isNativeOption?n.isNative:null,closeAuthority:n.closeAuthorityOption?n.closeAuthority:null,tlvData:i}}const Dt=f.struct([f.u32("mintAuthorityOption"),A("mintAuthority"),q("supply"),f.u8("decimals"),te("isInitialized"),f.u32("freezeAuthorityOption"),A("freezeAuthority")]),Le=Dt.span;async function At(t,e,r,n=T){const i=await t.getAccountInfo(e,r);return Wn(e,i,n)}function Wn(t,e,r=T){if(!e)throw new Qe;if(!e.owner.equals(r))throw new Ot;if(e.data.length<Le)throw new ge;const n=Dt.decode(e.data.slice(0,Le));let i=l.alloc(0);if(e.data.length>Le){if(e.data.length<=_)throw new ge;if(e.data.length===Xe)throw new ge;if(e.data[_]!=Te.Mint)throw new vn;i=e.data.slice(_+Ye)}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 Tt(t,e,r=!1,n=T,i=$){if(!r&&!c.isOnCurve(e.toBuffer()))throw new zt;const[s]=await c.findProgramAddress([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}function H(t,e,r=!1,n=T,i=$){if(!r&&!c.isOnCurve(e.toBuffer()))throw new zt;const[s]=c.findProgramAddressSync([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}const _n=f.struct([te("lockCpi")]),Nn=_n.span,Un=f.struct([f.u8("state")]),Fn=Un.span,xn=f.struct([]),On=xn.span,zn=f.struct([A("rateAuthority"),f.ns64("initializationTimestamp"),f.s16("preUpdateAverageRate"),f.ns64("lastUpdateTimestamp"),f.s16("currentRate")]),Ln=zn.span,qn=f.struct([te("requireIncomingTransferMemos")]),Dn=qn.span,Kt=f.struct([A("authority"),A("metadataAddress")]),Kn=Kt.span;function Vn(t){const e=dr(C.MetadataPointer,t.tlvData);if(e!==null){const{authority:r,metadataAddress:n}=Kt.decode(e);return{authority:r.equals(c.default)?null:r,metadataAddress:n.equals(c.default)?null:n}}else return null}const Gn=f.struct([A("closeAuthority")]),Zn=Gn.span,Vt=f.struct([]),Hn=Vt.span,Qn=Vt.span,$n=f.struct([A("delegate")]),Yn=$n.span,Xn=1e4;BigInt(Xn);function bt(t){return f.struct([q("epoch"),q("maximumFee"),f.u16("transferFeeBasisPoints")],t)}const Jn=f.struct([A("transferFeeConfigAuthority"),A("withdrawWithheldAuthority"),q("withheldAmount"),bt("olderTransferFee"),bt("newerTransferFee")]),jn=Jn.span,er=f.struct([q("withheldAmount")]),tr=er.span,nr=f.struct([A("authority"),A("programId")]),rr=nr.span,ir=f.struct([te("transferring")]),sr=ir.span,Ct=f.struct([f.u8("discriminator"),f.blob(32,"addressConfig"),te("isSigner"),te("isWritable")]),ar=f.struct([f.u32("count"),f.seq(Ct,f.greedy(Ct.span),"extraAccounts")]);f.struct([q("instructionDiscriminator"),f.u32("length"),ar.replicate("extraAccountsList")]);var C;(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"})(C||(C={}));const ee=2,Ce=2;function or(t){switch(t){case C.Uninitialized:return 0;case C.TransferFeeConfig:return jn;case C.TransferFeeAmount:return tr;case C.MintCloseAuthority:return Zn;case C.ConfidentialTransferMint:return 97;case C.ConfidentialTransferAccount:return 286;case C.CpiGuard:return Nn;case C.DefaultAccountState:return Fn;case C.ImmutableOwner:return On;case C.MemoTransfer:return Dn;case C.MetadataPointer:return Kn;case C.NonTransferable:return Hn;case C.InterestBearingConfig:return Ln;case C.PermanentDelegate:return Yn;case C.NonTransferableAccount:return Qn;case C.TransferHook:return rr;case C.TransferHookAccount:return sr;default:throw Error(`Unknown extension type: ${t}`)}}function cr(t,e){if(t.length===0)return e;{const r=_+Ye+t.filter((n,i)=>i===t.indexOf(n)).map(n=>or(n)+ee+Ce).reduce((n,i)=>n+i);return r===Xe?r+ee:r}}function ur(t){return cr(t,_)}function dr(t,e){let r=0;for(;r+ee+Ce<=e.length;){const n=e.readUInt16LE(r),i=e.readUInt16LE(r+ee),s=r+ee+Ce;if(n==t)return e.slice(s,s+i);r=s+i}return null}function lr(t){const e=[];let r=0;for(;r<t.length;){const n=t.readUInt16LE(r);e.push(n);const i=t.readUInt16LE(r+ee);r+=ee+Ce+i}return e}const Bt=f.struct([f.u8("instruction")]);function qe(t,e,r,n=T){const i=[{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:N,isSigner:!1,isWritable:!1}],s=l.alloc(Bt.span);return Bt.encode({instruction:ce.InitializeAccount},s),new pe({keys:i,programId:n,data:s})}function Gt(t,e,r,n,i=T,s=$){return Zt(t,e,r,n,l.alloc(0),i,s)}function mr(t,e,r,n,i=T,s=$){return Zt(t,e,r,n,l.from([1]),i,s)}function Zt(t,e,r,n,i,s=T,o=$){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:P.programId,isSigner:!1,isWritable:!1},{pubkey:s,isSigner:!1,isWritable:!1}];return new pe({keys:a,programId:o,data:i})}const vt=f.struct([f.u8("instruction"),q("amount")]);function Ve(t,e,r,n,i=[],s=T){const o=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,i),a=l.alloc(vt.span);return vt.encode({instruction:ce.Transfer,amount:BigInt(n)},a),new pe({keys:o,programId:s,data:a})}function Je(t,e){const r=l.alloc(2);return r.writeUInt16BE(S(e)),R([l.from("foreign_contract"),r],t)}function gr(t){return R([l.from("redeemer")],t)}function je(t,e){return R([l.from("mint"),new c(e).toBuffer()],t)}function Ht(t){return R([l.from("sender")],t)}function Qt(t,e){return R([l.from("tmp"),new c(e).toBuffer()],t)}function $t(t,e,r){return R([l.from("bridged"),new c(e).toBuffer(),l.from(yn.toBytes(BigInt(r.toString()),8))],t)}function U(t){return R([l.from("config")],t)}async function ri(t,e,r){return t.getAccountInfo(U(e),r).then(n=>et.deserialize(ve(n)))}class et{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 et(r)}}function Ie(t,e){return R([new c(e).toBuffer()],t)}function ne(t,e,r){const n=typeof r=="string"?new xt(r).toUint8Array():r;return R([(()=>{const i=l.alloc(2);return i.writeUInt16BE(e),i})(),n],t)}async function ii(t,e,r){return t.getAccountInfo(new c(e),r).then(n=>tt.deserialize(ve(n)))}class tt{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 tt(r,n)}}function nt(t){return R([l.from("sender")],t)}function rt(t){return R([l.from("redeemer")],t)}function de(t){return R([l.from("authority_signer")],t)}function ye(t){return R([l.from("custody_signer")],t)}function we(t){return R([l.from("mint_signer")],t)}function le(t,e,r){return R([l.from("wrapped"),(()=>{const n=l.alloc(2);return n.writeUInt16BE(e),n})(),r],t)}function Z(t,e){return R([l.from("meta"),new c(e).toBuffer()],t)}async function ke(t,e,r,n){return t.getAccountInfo(Z(e,r),n).then(i=>it.deserialize(ve(i)))}class it{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 it(r,n,i,s)}}function Pt(t,e,r,n,i){return Pn(new c(e),de(t),new c(r),n,void 0,new c(i))}class fr{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 un(this.idl,e)??0}}class hr{constructor(e){}decode(e){throw new Error("Token Bridge program does not have events")}}class pr{constructor(e){}encode(e,r){switch(e){case"initialize":return yr(r);case"attestToken":return wr(r);case"completeNative":return Sr(r);case"completeWrapped":return Mr(r);case"transferWrapped":return kr(r);case"transferNative":return Ar(r);case"registerChain":return Tr(r);case"createWrapped":return br(r);case"upgradeContract":return Cr(r);case"transferWrappedWithPayload":return Br(r);case"transferNativeWithPayload":return vr(r);default:throw new Error(`Invalid instruction: ${e}`)}}encodeState(e,r){throw new Error("Token Bridge program does not have state")}}var x;(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"})(x||(x={}));function D(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 yr({wormhole:t}){const e=l.alloc(32);return e.write(new c(t).toBuffer().toString("hex"),0,"hex"),D(x.Initialize,e)}function wr({nonce:t}){const e=l.alloc(4);return e.writeUInt32LE(t,0),D(x.AttestToken,e)}function Sr({}){return D(x.CompleteNative)}function Mr({}){return D(x.CompleteWrapped)}function Yt({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 kr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return D(x.TransferWrapped,Yt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Ar({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return D(x.TransferNative,Yt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Tr({}){return D(x.RegisterChain)}function br({}){return D(x.CreateWrapped)}function Cr({}){return D(x.UpgradeContract)}function Xt({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 Br({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return D(x.TransferWrappedWithPayload,Xt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}function vr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return D(x.TransferNativeWithPayload,Xt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}class Pr{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 Ir{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 Rr{instruction;accounts;state;events;types;constructor(e){this.instruction=new pr(e),this.accounts=new fr(e),this.state=new Pr(e),this.events=new hr(e),this.types=new Ir(e)}}const Jt={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 Er(t,e){return new Ae(Jt,new c(t),e===void 0?{connection:null}:e,Wr())}function z(t,e){return Er(t,Cn(e))}function Wr(){return new Rr(Jt)}class Q{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(Q.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 Q(r,n,i)}}class Re{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 u=i.length;return[u,4+u*Q.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 u=0;u<s;++u){const d=i.at(u),g=19+e+r+n+u*Q.size;a.write(d.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(),u=e.readUInt16LE(12+r+i+o),d=e.readUInt8(14+r+i+o),g=(()=>{if(d==0)return null;const m=[],h=e.readUInt32LE(15+r+i+o);for(let p=0;p<h;++p){const y=19+r+i+o+p*Q.size;m.push(Q.deserialize(e.subarray(y,y+Q.size)))}return m})();return new Re(n,s,a,u,g)}}class Be extends Re{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 fe{constructor(){}static programId=new c("metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s");static createMetadataAccounts(e,r,n,i,s,o,a=!1,u,d,g,m=!1,h=Ee(r)){const p=[dn(h,!1),ie(r,!1),ie(n,!0),ie(e,!0),ie(o,a),ie(P.programId,!1),ie(N,!1)],y=Be.serializeInstructionData(i,s,u===void 0?"":u,g===void 0?0:g,d===void 0?null:d,m);return{programId:fe.programId,keys:p,data:y}}}function Ee(t){return R([l.from("metadata"),fe.programId.toBuffer(),new c(t).toBuffer()],fe.programId)}var It;(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"})(It||(It={}));class st{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=Re.deserialize(e.subarray(65)),o=s.serialize().length,a=e.readUInt8(65+o)>0,u=e.readUInt8(66+o)>0;return new st(r,n,i,s,a,u)}}async function si(t,e,r){return t.getAccountInfo(Ee(e),r).then(n=>st.deserialize(ve(n)))}function _r(t,e,r,n,i,s,o,a){const u=z(e,t).methods.attestToken(o);return console.log(Rt(e,r,n,i,s,a)),u._ixFn(...u._args,{accounts:Rt(e,r,n,i,s,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Rt(t,e,r,n,i,s){const{bridge:o,emitter:a,sequence:u,feeCollector:d,clock:g,rent:m,systemProgram:h}=ln(e,r,i,t);return{payer:new c(r),config:U(t),mint:new c(n),wrappedMeta:Z(t,n),splMetadata:s?new c(s):Ee(n),wormholeBridge:o,wormholeMessage:new c(i),wormholeEmitter:a,wormholeSequence:u,wormholeFeeCollector:d,clock:g,rent:m,systemProgram:h,wormholeProgram:new c(e)}}function Et(t,e,r,n,i,s,o){const a=z(e,t).methods.completeNative();return a._ixFn(...a._args,{accounts:Nr(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Nr(t,e,r,n,i,s){const o=new c(n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),endpoint:ne(t,S(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:Ie(t,o),mint:o,custodySigner:ye(t),rent:N,systemProgram:P.programId,tokenProgram:s?new c(s):T,wormholeProgram:new c(e)}}function Ur(t,e,r,n,i,s){const o=z(e,t).methods.completeWrapped();return o._ixFn(...o._args,{accounts:Fr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Fr(t,e,r,n,i){const s=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),endpoint:ne(t,S(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:Z(t,s),mintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}function xr(t,e,r,n,i){const s=z(e,t).methods.createWrapped();return s._ixFn(...s._args,{accounts:Or(e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Or(t,e,r,n){const i=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),endpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),mint:i,wrappedMeta:Z(t,i),splMetadata:Ee(i),mintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,splMetadataProgram:fe.programId,wormholeProgram:new c(e)}}function ai(t,e,r){const n=z(t).methods.initialize(r);return n._ixFn(...n._args,{accounts:zr(t,e),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function zr(t,e){return{payer:new c(e),config:U(t),rent:N,systemProgram:P.programId}}function oi(t,e,r,n){const i=z(t).methods.registerChain();return i._ixFn(...i._args,{accounts:Lr(t,e,r,n),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Lr(t,e,r,n){return{payer:new c(r),config:U(t),endpoint:ne(t,S(n.payload.actionArgs.foreignChain),n.payload.actionArgs.foreignAddress.toUint8Array()),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),rent:N,systemProgram:P.programId,wormholeProgram:new c(e)}}function ci(t,e,r,n,i){const s=z(t).methods.upgradeContract();return s._ixFn(...s._args,{accounts:qr(t,e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function qr(t,e,r,n,i){return{payer:new c(r),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),upgradeAuthority:fn(t),spill:new c(i===void 0?r:i),implementation:new c(n.payload.actionArgs.newContract),programData:gn(t),tokenBridgeProgram:new c(t),rent:N,clock:De,bpfLoaderUpgradeable:mn,systemProgram:P.programId}}function Wt(t,e,r,n,i,s,o,a,u,d,g,m,h){const p=z(e,t).methods.transferNative(u,d,g,l.from(m),h);return p._ixFn(...p._args,{accounts:Dr(e,r,n,i,s,o,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Dr(t,e,r,n,i,s,o){const{wormholeBridge:a,wormholeMessage:u,wormholeEmitter:d,wormholeSequence:g,wormholeFeeCollector:m,clock:h,rent:p,systemProgram:y}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),mint:new c(s),custody:Ie(t,s),authoritySigner:de(t),custodySigner:ye(t),wormholeBridge:a,wormholeMessage:u,wormholeEmitter:d,wormholeSequence:g,wormholeFeeCollector:m,clock:h,rent:p,systemProgram:y,tokenProgram:new c(o),wormholeProgram:new c(e)}}function _t(t,e,r,n,i,s,o,a,u,d,g,m,h){const p=z(e,t).methods.transferNativeWithPayload(u,d,l.from(g),m,l.from(h),null);return p._ixFn(...p._args,{accounts:jt(e,r,n,i,s,o,void 0,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function jt(t,e,r,n,i,s,o,a){const{wormholeBridge:u,wormholeMessage:d,wormholeEmitter:g,wormholeSequence:m,wormholeFeeCollector:h,clock:p,rent:y,systemProgram:w}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),mint:new c(s),custody:Ie(t,s),authoritySigner:de(t),custodySigner:ye(t),wormholeBridge:u,wormholeMessage:d,wormholeEmitter:g,wormholeSequence:m,wormholeFeeCollector:h,clock:p,sender:new c(o===void 0?r:nt(o)),rent:y,systemProgram:w,tokenProgram:a?new c(a):T,wormholeProgram:new c(e)}}function Kr(t,e,r,n,i,s,o,a,u,d,g,m,h,p,y){const w=z(e,t).methods.transferWrapped(g,m,h,l.from(p),y);return w._ixFn(...w._args,{accounts:Vr(e,r,n,i,s,o,a,u,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Vr(t,e,r,n,i,s,o,a,u){const d=le(t,o,a),{wormholeBridge:g,wormholeMessage:m,wormholeEmitter:h,wormholeSequence:p,wormholeFeeCollector:y,clock:w,rent:v,systemProgram:B}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),fromOwner:new c(s),mint:d,wrappedMeta:Z(t,d),authoritySigner:de(t),wormholeBridge:g,wormholeMessage:m,wormholeEmitter:h,wormholeSequence:p,wormholeFeeCollector:y,clock:w,rent:v,systemProgram:B,wormholeProgram:new c(e),tokenProgram:new c(u)}}function Gr(t,e,r,n,i,s,o,a,u,d,g,m,h,p,y){const w=z(e,t).methods.transferWrappedWithPayload(g,m,l.from(h),p,l.from(y),null);return w._ixFn(...w._args,{accounts:en(e,r,n,i,s,o,a,u,void 0,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function en(t,e,r,n,i,s,o,a,u,d){const g=le(t,o,a),{wormholeBridge:m,wormholeMessage:h,wormholeEmitter:p,wormholeSequence:y,wormholeFeeCollector:w,clock:v,rent:B,systemProgram:b}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),fromOwner:new c(s),mint:g,wrappedMeta:Z(t,g),authoritySigner:de(t),wormholeBridge:m,wormholeMessage:h,wormholeEmitter:p,wormholeSequence:y,wormholeFeeCollector:w,clock:v,sender:new c(u===void 0?r:nt(u)),rent:B,systemProgram:b,wormholeProgram:new c(e),tokenProgram:d?new c(d):T}}function ui(t,e,r){const{wormholeEmitter:n,wormholeBridge:i,wormholeFeeCollector:s,wormholeSequence:o}=Ut(e,r);return{tokenBridgeConfig:U(e),tokenBridgeAuthoritySigner:de(e),tokenBridgeCustodySigner:ye(e),tokenBridgeMintAuthority:we(e),tokenBridgeSender:nt(t),tokenBridgeRedeemer:rt(t),wormholeBridge:i,tokenBridgeEmitter:n,wormholeFeeCollector:s,tokenBridgeSequence:o}}function Zr(t,e,r,n,i,s,o){const a=jt(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 Hr(t,e,r,n,i,s,o,a,u){const d=en(e,r,n,i,s,u===void 0?t:u,o,a,t);return{payer:d.payer,tokenBridgeConfig:d.config,fromTokenAccount:d.from,fromTokenAccountOwner:d.fromOwner,tokenBridgeWrappedMint:d.mint,tokenBridgeWrappedMeta:d.wrappedMeta,tokenBridgeAuthoritySigner:d.authoritySigner,wormholeBridge:d.wormholeBridge,wormholeMessage:d.wormholeMessage,tokenBridgeEmitter:d.wormholeEmitter,tokenBridgeSequence:d.wormholeSequence,wormholeFeeCollector:d.wormholeFeeCollector,clock:d.clock,tokenBridgeSender:d.sender,rent:d.rent,systemProgram:d.systemProgram,tokenProgram:d.tokenProgram,wormholeProgram:d.wormholeProgram}}function di(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:U(t),vaa:X(e,l.from(n.hash)),tokenBridgeClaim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:rt(o),toFeesTokenAccount:new c(i),tokenBridgeCustody:Ie(t,s),mint:s,tokenBridgeCustodySigner:ye(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}function li(t,e,r,n,i){const s=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:U(t),vaa:X(e,l.from(n.hash)),tokenBridgeClaim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:rt(o),toFeesTokenAccount:new c(i),tokenBridgeWrappedMint:s,tokenBridgeWrappedMeta:Z(t,s),tokenBridgeMintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}const Qr={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 at(t,e){return new Ae(Qr,new c(t),{connection:e})}function tn(t,e){return R([l.from("seq"),new c(e).toBuffer()],t)}async function $r(t,e,r,n,i,s,o,a,u,d,g,m){const{methods:{transferNativeTokensWithRelay:h},account:{signerSequence:p}}=at(e,t),y=tn(e,r),w=await p.fetch(y).then(({value:k})=>k).catch(k=>{if(k.message?.includes("Account does not exist"))return new I(0);throw k}),v=$t(e,r,w),B=H(new c(s),new c(r)),b=Qt(e,s),F=Zr(e,n,i,r,v,B,s);return h(new I(o.toString()),new I(a.toString()),S(d),[...u],g,m).accounts({config:Ht(e),payerSequence:y,foreignContract:Je(e,d),registeredToken:je(e,s),tmpTokenAccount:b,tokenBridgeProgram:new c(n),...F}).instruction()}async function Yr(t,e,r,n,i,s,o,a,u,d,g){const{methods:{transferWrappedTokensWithRelay:m},account:{signerSequence:h}}=at(e,t),p=tn(e,r),y=await h.fetch(p).then(({value:W})=>W).catch(W=>{if(W.message?.includes("Account does not exist"))return new I(0);throw W}),w=$t(e,r,y),v=H(new c(s),new c(r)),{chain:B,tokenAddress:b}=await ke(t,n,s),F=Qt(e,s),k=Hr(e,n,i,r,w,v,B,b);return m(new I(o.toString()),new I(a.toString()),S(d),[...u],g).accounts({config:Ht(e),payerSequence:p,foreignContract:Je(e,d),registeredToken:je(e,new c(s)),tmpTokenAccount:F,tokenBridgeProgram:new c(n),...k}).instruction()}class he{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=S(r);const s=i.tokenBridge;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridge=z(s,n),this.coreBridge=new Ft(e,r,n,i)}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new he(n,i,e,s.contracts)}async isWrappedAsset(e){return ke(this.connection,this.tokenBridge.programId,new M(e).toUint8Array()).catch(r=>null).then(r=>r!=null)}async getOriginalAsset(e){if(!await this.isWrappedAsset(e))throw Fe(e.toString());const r=new M(e).toUint8Array(),n=new c(r);try{const i=await ke(this.connection,this.tokenBridge.programId,r);return i===null?{chain:this.chain,address:new M(n.toBytes()).toUniversalAddress()}:{chain:wn(i.chain),address:new xt(new Uint8Array(i.tokenAddress))}}catch{throw Fe(e.toString())}}async getTokenUniversalAddress(e){return new M(e).toUniversalAddress()}async getTokenNativeAddress(e,r){return new M(r).toNative()}async hasWrappedAsset(e){try{return await this.getWrappedAsset(e),!0}catch{}return!1}async getWrappedAsset(e){if(K(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=le(this.tokenBridge.programId,S(e.chain),e.address.toUniversalAddress().toUint8Array());try{return await ke(this.connection,this.tokenBridge.programId,r),Ke(this.chain,r.toBase58())}catch{}throw Fe(`${r}: ${e.address.toUniversalAddress().toString()}`)}async isTransferCompleted(e){return hn(this.connection,this.tokenBridge.programId,e.emitterAddress.toUint8Array(),S(e.emitterChain),e.sequence,this.connection.commitment).catch(()=>!1)}async getWrappedNative(){return Ke(this.chain,O.toBase58())}async*createAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new M(r).unwrap(),i=0,s=await this.coreBridge.getMessageFee(),o=pn(this.coreBridge.coreBridge.programId,n,s),a=new M(e).unwrap(),u=await L.getTokenProgramId(this.connection,a);let d;if(u.equals(xe)){const p=await At(this.connection,a,void 0,u),y=Vn(p);y?.metadataAddress&&(d=y?.metadataAddress)}const g=j.generate(),m=_r(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,new M(e).unwrap(),g.publicKey,i,d),h=new G().add(o,m);h.feePayer=n,yield this.createUnsignedTx({transaction:h,signers:[g]},"Solana.AttestToken")}async*submitAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new M(r).unwrap();yield*this.coreBridge.postVaa(n,e);const i=new G().add(xr(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 M(e).unwrap(),o=s,a=r.address.toUniversalAddress().toUint8Array(),u=S(r.chain),d=0,g=0n,m=j.generate(),h=j.generate(),p=await ze(this.connection),y=P.createAccount({fromPubkey:o,newAccountPubkey:h.publicKey,lamports:p,space:_,programId:T}),w=P.transfer({fromPubkey:o,lamports:n,toPubkey:h.publicKey}),v=qe(h.publicKey,O,o),B=Pt(this.tokenBridge.programId,h.publicKey,o,n,T),b=i?_t(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,m.publicKey,h.publicKey,O,T,d,n,a,u,i):Wt(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,m.publicKey,h.publicKey,O,T,d,n,g,a,u),F=Oe(h.publicKey,o,o),k=new G;return k.feePayer=o,k.add(y,w,v,B,b,F),this.createUnsignedTx({transaction:k,signers:[m,h]},"TokenBridge.TransferNative")}async*transfer(e,r,n,i,s){if(K(n)){yield await this.transferSol(e,r,i,s);return}const o=new M(n).unwrap(),a=new M(e).unwrap(),u=await L.getTokenProgramId(this.connection,o);if(u.equals(xe))throw new Error("Transfers of Token-2022 assets are not supported via the Manual Token Bridge route. Please use the Executor Token Bridge route instead.");let d=await Tt(o,a,!1,u);const g=!await this.isWrappedAsset(n);let m,h=!1;if(g&&u.equals(xe)){const E=await this.connection.getAccountInfo(d);if(E&&E.data.length>_){const J=await qt(this.connection,d,void 0,u);J.tlvData&&(h=lr(J.tlvData).includes(C.ImmutableOwner))}}const p=r.address.toUniversalAddress().toUint8Array(),y=S(r.chain),w=0,v=0n,B=j.generate(),b=[],F=[B];if(h){m=j.generate(),F.push(m);const E=await ze(this.connection);b.push(P.createAccount({fromPubkey:a,newAccountPubkey:m.publicKey,lamports:E,space:_,programId:u})),b.push(qe(m.publicKey,o,a,u)),b.push(Ve(d,m.publicKey,a,i,[],u)),d=m.publicKey}let k;if(g)k=s?_t(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,o,u,w,i,p,y,s):Wt(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,o,u,w,i,v,p,y);else{const E=await this.getOriginalAsset(n);if(K(E.address))throw new Error("Native cannot be an original asset");k=s?Gr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,a,S(E.chain),E.address.toUint8Array(),u,w,i,p,y,s):Kr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,a,S(E.chain),E.address.toUint8Array(),u,w,i,v,p,y)}const W=Pt(this.tokenBridge.programId,d,a,i,u);b.push(W),b.push(k),m&&b.push(Oe(m.publicKey,a,a,[],u));const V=new G().add(...b);V.feePayer=a,yield this.createUnsignedTx({transaction:V,signers:F},"TokenBridge.TransferTokens")}async*redeemAndUnwrap(e,r){const n=new M(e).unwrap(),i=new M(r.payload.to.address).unwrap(),s=await At(this.connection,O).then(y=>r.payload.token.amount*BigInt(Math.pow(10,y.decimals-8))),o=await ze(this.connection),a=j.generate(),u=Et(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,r),d=P.createAccount({fromPubkey:n,newAccountPubkey:a.publicKey,lamports:o,space:_,programId:T}),g=qe(a.publicKey,O,n),m=Ve(i,a.publicKey,n,s.valueOf()),h=Oe(a.publicKey,n,n),p=new G;p.feePayer=n,p.add(u,d,g,m,h),yield this.createUnsignedTx({transaction:p,signers:[a]},"TokenBridge.RedeemAndUnwrap")}async*createAta(e,r,n){const i=new M(e).unwrap(),s=new M(r).unwrap(),o=await Tt(s,i,!1,n);if(await this.connection.getAccountInfo(o)===null){const u=new G().add(Gt(i,o,i,s,n));u.feePayer=i,yield this.createUnsignedTx({transaction:u},"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(),s=await L.getTokenProgramId(this.connection,new M(i).unwrap());if(yield*this.createAta(e,i,s),yield*this.coreBridge.postVaa(e,r),n){const d=new M(await this.getWrappedNative());if(Sn.equals(i.toUint8Array(),d.toUint8Array())){yield*this.redeemAndUnwrap(e,r);return}}const o=new M(e).unwrap(),a=r.payload.token.chain==this.chain?Et:Ur,u=new G().add(a(this.connection,this.tokenBridge.programId,this.coreBridge.address,o,r,void 0,s));u.feePayer=o,yield this.createUnsignedTx({transaction:u},"Solana.RedeemTransfer")}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}const Xr={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:[]},se=9,me=new I(10),ae=new I(1e8);class ot{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=S(r);const s=i.tokenBridgeRelayer;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridgeRelayer=at(s,n),this.tokenBridgeProgramId=new c(i.tokenBridge),this.coreBridgeProgramId=new c(i.coreBridge)}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new ot(n,i,e,s.contracts)}async*transfer(e,r,n,i,s){const a=new M(e).unwrap(),u=r.address.toUniversalAddress().toUint8Array(),d=this.mintAddress(n),g=new G;if(K(n)){const y=H(d,a);try{await qt(this.connection,y)}catch(w){if(w instanceof Qe){const v=Gt(a,y,a,d);g.add(v)}else throw w}}const m=s||0n,h=K(n),p=h?await $r(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,d,i,m,u,r.chain,0,h):await Yr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,d,i,m,u,r.chain,0);g.add(p),g.feePayer=a,yield this.createUnsignedTx({transaction:g},"AutomaticTokenBridge.Transfer")}async*redeem(e,r){const n=new G;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 L.getDecimals(this.network,this.chain,this.connection,r)),u=me.pow(new I(a)).mul(i).mul(ae).div(new I(o).mul(s));return BigInt(u.toString())}async maxSwapAmount(e){const r=this.mintAddress(e),[{swapRate:n,maxNativeSwapAmount:i},{swapRate:s}]=await Promise.all([this.getRegisteredToken(r),this.getRegisteredToken(O)]),o=Number(await L.getDecimals(this.network,this.chain,this.connection,e)),a=this.calculateNativeSwapRate(s,n),u=o>se?i.mul(a).mul(me.pow(new I(o-se))).div(ae):i.mul(a).div(me.pow(new I(se-o)).mul(ae));return BigInt(u.toString())}async nativeTokenAmount(e,r){if(r===0n)return 0n;const n=this.mintAddress(e),i=Number(await L.getDecimals(this.network,this.chain,this.connection,e)),[{swapRate:s},{swapRate:o}]=await Promise.all([this.getRegisteredToken(n),this.getRegisteredToken(O)]),a=this.calculateNativeSwapRate(o,s),u=i>se?ae.mul(new I(r.toString())).div(a.mul(me.pow(new I(i-se)))):ae.mul(new I(r.toString())).mul(me.pow(new I(se-i))).div(a);return BigInt(u.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 K(e)?new c(O):new M(e).unwrap()}async getRegisteredTokens(){return Xr[this.network].map(e=>Ke(this.chain,e))}calculateNativeSwapRate(e,r){return ae.mul(e).div(r)}async getForeignContract(e){return await this.tokenBridgeRelayer.account.foreignContract.fetch(Je(this.tokenBridgeRelayer.programId,e))}async getRegisteredToken(e){return await this.tokenBridgeRelayer.account.registeredToken.fetch(je(this.tokenBridgeRelayer.programId,e))}async getRedeemerConfig(){return await this.tokenBridgeRelayer.account.redeemerConfig.fetch(gr(this.tokenBridgeRelayer.programId))}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}const Nt={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 oe{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 Ae(Nt,this.relayerProgramId,{connection:this.connection})}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch: ${s.network} != ${n}`);return new oe(n,i,e,s.contracts)}async*transfer(e,r,n,i,s,o){const a=Mn.get(this.network,r.chain);if(!a||!a.relayer)throw new Error(`Token Bridge Executor Relayer contract for domain ${r.chain} not found`);const u=a.relayer,d=new M(e).unwrap(),g=S(r.chain),m=r.address.toUniversalAddress(),{estimatedCost:h,signedQuote:p,relayInstructions:y}=s,w=yt(kn,p),v=yt(An,y),B=new he(this.network,this.chain,this.connection,this.contracts),b=K(n),F=!b&&await B.isWrappedAsset(n),k=b?O:new M(n).unwrap(),W=await L.getTokenProgramId(this.connection,k),V=new c(p.quote.payeeAddress),E=j.generate(),J=Tn(r.chain,u),We=J,Se=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],_e=c.findProgramAddressSync([k.toBuffer()],this.tokenBridgeProgramId)[0],Me=c.findProgramAddressSync([l.from("authority_signer")],this.tokenBridgeProgramId)[0],nn=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0],{wormholeEmitter:ct,wormholeSequence:ut,wormholeFeeCollector:dt,wormholeBridge:lt}=Ut(this.tokenBridgeProgramId,this.wormholeProgramId),mt=c.findProgramAddressSync([l.from("sender")],this.relayerProgramId)[0],gt=H(k,d,!1,W),ft=c.findProgramAddressSync([l.from("tmp"),k.toBytes()],this.relayerProgramId)[0],re=[];if(o&&o.feeAmount>0n){const Ne=new c(o.referrer.address.toString());if(k.equals(O))re.push(P.transfer({fromPubkey:d,toPubkey:Ne,lamports:o.feeAmount}));else{const Ue=H(k,Ne,!0,W),cn=H(k,d,!0,W);await this.connection.getAccountInfo(Ue)||re.push(mr(d,Ue,Ne,k,W)),re.push(Ve(cn,Ue,d,o.feeAmount,void 0,W))}}const rn=o?o.remainingAmount:i,ht={amount:new I(rn.toString()),recipientChain:g,recipientAddress:Array.from(m.toUint8Array()),nonce:0,dstTransferRecipient:Array.from(J.toUint8Array()),dstExecutionAddress:Array.from(We.toUint8Array()),execAmount:new I(h.toString()),signedQuoteBytes:l.from(w),relayInstructions:l.from(v)};F?re.push(await this.relayerProgram.methods.transferWrappedTokensWithRelay(ht).accountsStrict({payer:d,config:mt,tokenBridgeWrappedMint:k,fromTokenAccount:gt,tmpTokenAccount:ft,tokenBridgeWrappedMeta:Z(this.tokenBridgeProgramId,k),tokenBridgeConfig:Se,tokenBridgeAuthoritySigner:Me,wormholeBridge:lt,wormholeMessage:E.publicKey,tokenBridgeEmitter:ct,tokenBridgeSequence:ut,wormholeFeeCollector:dt,payee:V,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,systemProgram:P.programId,tokenProgram:W,executorProgram:this.executorProgramId,clock:De,rent:N}).instruction()):re.push(await this.relayerProgram.methods.transferNativeTokensWithRelay({...ht,wrapNative:K(n)}).accountsStrict({payer:d,config:mt,mint:k,fromTokenAccount:gt,tmpTokenAccount:ft,tokenBridgeConfig:Se,tokenBridgeCustody:_e,tokenBridgeAuthoritySigner:Me,tokenBridgeCustodySigner:nn,wormholeBridge:lt,wormholeMessage:E.publicKey,tokenBridgeEmitter:ct,tokenBridgeSequence:ut,wormholeFeeCollector:dt,payee:V,systemProgram:P.programId,tokenProgram:W,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,associatedTokenProgram:$,executorProgram:this.executorProgramId,clock:De,rent:N}).instruction());const pt=await this.getAddressLookupTable(),{blockhash:sn}=await this.connection.getLatestBlockhash(),an=new wt({payerKey:d,instructions:re,recentBlockhash:sn}).compileToV0Message(pt?[pt]:[]),on=new St(an);yield this.createUnsignedTx({transaction:on,signers:[E]},"ExecutorTokenBridge.transfer")}async*redeem(e,r){const n=new M(e).unwrap(),i=new M(r.payload.payload.targetRecipient).unwrap(),s=r.payload.token.chain,o=r.payload.token.address,a=s===this.chain;let u;if(a)u=new M(o).unwrap();else{const Me=await new he(this.network,this.chain,this.connection,this.contracts).getWrappedAsset({chain:s,address:o});u=new M(Me).unwrap()}const d=await L.getTokenProgramId(this.connection,u),g=H(u,i,!0,d),m=X(this.wormholeProgramId,l.from(r.hash));await this.connection.getAccountInfo(m)||(yield*new Ft(this.network,this.chain,this.connection,this.contracts).postVaa(n,r));const p=new M(r.payload.to.address).unwrap(),y=new Ae(Nt,p,{connection:this.connection}),w=c.findProgramAddressSync([l.from("redeemer")],y.programId)[0],v=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],B=c.findProgramAddressSync([l.from("tmp"),u.toBytes()],y.programId)[0],b=Y(this.tokenBridgeProgramId,r.emitterAddress.toUint8Array(),S(r.emitterChain),r.sequence),F=ne(this.tokenBridgeProgramId,S(r.emitterChain),r.emitterAddress.toUint8Array()),k=c.findProgramAddressSync([u.toBuffer()],this.tokenBridgeProgramId)[0],W=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0];let V;const E=Array.from(r.hash);a?V=await y.methods.completeNativeTransferWithRelay(E).accountsStrict({payer:n,config:w,mint:u,recipientTokenAccount:g,recipient:i,tmpTokenAccount:B,tokenBridgeConfig:v,vaa:m,tokenBridgeClaim:b,tokenBridgeForeignEndpoint:F,tokenBridgeCustody:k,tokenBridgeCustodySigner:W,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:d,associatedTokenProgram:$,systemProgram:P.programId,rent:N}).instruction():V=await y.methods.completeWrappedTransferWithRelay(E).accountsStrict({payer:n,config:w,tokenBridgeWrappedMint:u,recipientTokenAccount:g,recipient:i,tmpTokenAccount:B,tokenBridgeWrappedMeta:Z(this.tokenBridgeProgramId,u),tokenBridgeConfig:v,vaa:m,tokenBridgeClaim:b,tokenBridgeForeignEndpoint:F,tokenBridgeMintAuthority:we(this.tokenBridgeProgramId),wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:d,associatedTokenProgram:$,systemProgram:P.programId,rent:N}).instruction();const{blockhash:J}=await this.connection.getLatestBlockhash(),We=new wt({payerKey:n,instructions:[V],recentBlockhash:J}).compileToV0Message(),Se=new St(We);yield this.createUnsignedTx({transaction:Se,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,K(e.address)||bn(e)===O.toString()?n+=5000n+5000000n:n+=5000n+1200000n,r){const i=new c(r.address.toString());if(!K(e.address)){const s=new M(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=H(s,i,!0,o.owner);await this.connection.getAccountInfo(a)===null&&(oe.associatedTokenAccountMinRent||(oe.associatedTokenAccountMinRent=BigInt(await this.connection.getMinimumBalanceForRentExemption(165))),n+=oe.associatedTokenAccountMinRent)}}return{msgValue:n,gasLimit:310000n}}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}Ze(He,"TokenBridge",he);Ze(He,"AutomaticTokenBridge",ot);Ze(He,"ExecutorTokenBridge",oe);export{Be as CreateMetadataAccountArgs,Q as Creator,Re as Data,tt as EndpointRegistration,Nt as ExecutorTokenBridgeRelayerIdl,It as Key,st as Metadata,ot as SolanaAutomaticTokenBridge,oe as SolanaExecutorTokenBridge,he as SolanaTokenBridge,fe as SplTokenMetadataProgram,Jt as TOKEN_BRIDGE_IDL,Qr as TOKEN_BRIDGE_RELAYER_IDL,et as TokenBridgeConfig,it as WrappedMeta,Wr as coder,Pt as createApproveAuthoritySignerInstruction,_r as createAttestTokenInstruction,Et as createCompleteTransferNativeInstruction,Ur as createCompleteTransferWrappedInstruction,xr as createCreateWrappedInstruction,ai as createInitializeInstruction,z as createReadOnlyTokenBridgeProgramInterface,oi as createRegisterChainInstruction,Er as createTokenBridgeProgramInterface,at as createTokenBridgeRelayerProgramInterface,Wt as createTransferNativeInstruction,$r as createTransferNativeTokensWithRelayInstruction,_t as createTransferNativeWithPayloadInstruction,Kr as createTransferWrappedInstruction,Yr as createTransferWrappedTokensWithRelayInstruction,Gr as createTransferWrappedWithPayloadInstruction,ci as createUpgradeContractInstruction,de as deriveAuthoritySignerKey,Ie as deriveCustodyKey,ye as deriveCustodySignerKey,ne as deriveEndpointKey,Je as deriveForeignContractAddress,we as deriveMintAuthorityKey,rt as deriveRedeemerAccountKey,gr as deriveRedeemerConfigAddress,je as deriveRegisteredTokenAddress,nt as deriveSenderAccountKey,Ht as deriveSenderConfigAddress,Ee as deriveSplTokenMetadataKey,Qt as deriveTmpTokenAccountAddress,U as deriveTokenBridgeConfigKey,$t as deriveTokenTransferMessageAddress,Z as deriveWrappedMetaKey,le as deriveWrappedMintKey,Rt as getAttestTokenAccounts,Nr as getCompleteTransferNativeAccounts,di as getCompleteTransferNativeWithPayloadCpiAccounts,Fr as getCompleteTransferWrappedAccounts,li as getCompleteTransferWrappedWithPayloadCpiAccounts,Or as getCreateWrappedAccounts,ii as getEndpointRegistration,zr as getInitializeAccounts,si as getMetadata,Lr as getRegisterChainAccounts,ri as getTokenBridgeConfig,ui as getTokenBridgeDerivedAccounts,Dr as getTransferNativeAccounts,jt as getTransferNativeWithPayloadAccounts,Zr as getTransferNativeWithPayloadCpiAccounts,Vr as getTransferWrappedAccounts,en as getTransferWrappedWithPayloadAccounts,Hr as getTransferWrappedWithPayloadCpiAccounts,qr as getUpgradeContractAccounts,ke as getWrappedMeta};
1
+ import{h as R,i as ve,j as un,n as dn,k as ie,l as ln,e as Y,f as X,B as mn,m as gn,o as fn,p as Pe,q as Ut,S as Ft,r as hn,s as pn}from"./index-DDWBTFUk.js";import{P as c,B as l,cG as f,dj as pe,cI as q,cJ as te,cH as A,dr as N,dk as P,cS as S,a8 as yn,d7 as xt,ds as De,dl as I,bc as L,bd as M,d6 as Fe,cX as wn,aF as K,da as Ke,dm as j,T as G,du as Sn,dn as Ge,dc as Mn,dd as yt,de as kn,df as An,dg as Tn,dv as wt,V as St,cU as bn,c$ as Ze,be as He}from"../main.mjs";import{P as Ae,c as Cn}from"./index-DmYxP1Uj.js";import"./create-CbNCGANY.js";const T=new c("TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA"),xe=new c("TokenzQdBNbLqP5VEhdkAS6EPFLC1PHnBqCXEpPxuEb"),$=new c("ATokenGPvbdGVxr1b2hvZbsiqW5xWH25efTNsLJA8knL"),O=new c("So11111111111111111111111111111111111111112");new c("9pan9bMn5HatX4EJdBwg9VgCa7Uz5HL8N1m5D3NdXejP");class ue extends Error{constructor(e){super(e)}}class Qe extends ue{constructor(){super(...arguments),this.name="TokenAccountNotFoundError"}}class Bn extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountError"}}class Ot extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountOwnerError"}}class ge extends ue{constructor(){super(...arguments),this.name="TokenInvalidAccountSizeError"}}class vn extends ue{constructor(){super(...arguments),this.name="TokenInvalidMintError"}}class zt extends ue{constructor(){super(...arguments),this.name="TokenOwnerOffCurveError"}}var ce;(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"})(ce||(ce={}));function $e(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 Mt=f.struct([f.u8("instruction"),q("amount")]);function Pn(t,e,r,n,i=[],s=T){const o=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1}],r,i),a=l.alloc(Mt.span);return Mt.encode({instruction:ce.Approve,amount:BigInt(n)},a),new pe({keys:o,programId:s,data:a})}const kt=f.struct([f.u8("instruction")]);function Oe(t,e,r,n=[],i=T){const s=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,n),o=l.alloc(kt.span);return kt.encode({instruction:ce.CloseAccount},o),new pe({keys:s,programId:i,data:o})}var Te;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Mint=1]="Mint",t[t.Account=2]="Account"})(Te||(Te={}));const Ye=1,In=f.struct([f.u8("m"),f.u8("n"),te("isInitialized"),A("signer1"),A("signer2"),A("signer3"),A("signer4"),A("signer5"),A("signer6"),A("signer7"),A("signer8"),A("signer9"),A("signer10"),A("signer11")]),Xe=In.span;var be;(function(t){t[t.Uninitialized=0]="Uninitialized",t[t.Initialized=1]="Initialized",t[t.Frozen=2]="Frozen"})(be||(be={}));const Lt=f.struct([A("mint"),A("owner"),q("amount"),f.u32("delegateOption"),A("delegate"),f.u8("state"),f.u32("isNativeOption"),q("isNative"),q("delegatedAmount"),f.u32("closeAuthorityOption"),A("closeAuthority")]),_=Lt.span;async function qt(t,e,r,n=T){const i=await t.getAccountInfo(e,r);return En(e,i,n)}async function ze(t,e){return await Rn(t,[],e)}async function Rn(t,e,r){const n=ur(e);return await t.getMinimumBalanceForRentExemption(n,r)}function En(t,e,r=T){if(!e)throw new Qe;if(!e.owner.equals(r))throw new Ot;if(e.data.length<_)throw new ge;const n=Lt.decode(e.data.slice(0,_));let i=l.alloc(0);if(e.data.length>_){if(e.data.length===Xe)throw new ge;if(e.data[_]!=Te.Account)throw new Bn;i=e.data.slice(_+Ye)}return{address:t,mint:n.mint,owner:n.owner,amount:n.amount,delegate:n.delegateOption?n.delegate:null,delegatedAmount:n.delegatedAmount,isInitialized:n.state!==be.Uninitialized,isFrozen:n.state===be.Frozen,isNative:!!n.isNativeOption,rentExemptReserve:n.isNativeOption?n.isNative:null,closeAuthority:n.closeAuthorityOption?n.closeAuthority:null,tlvData:i}}const Dt=f.struct([f.u32("mintAuthorityOption"),A("mintAuthority"),q("supply"),f.u8("decimals"),te("isInitialized"),f.u32("freezeAuthorityOption"),A("freezeAuthority")]),Le=Dt.span;async function At(t,e,r,n=T){const i=await t.getAccountInfo(e,r);return Wn(e,i,n)}function Wn(t,e,r=T){if(!e)throw new Qe;if(!e.owner.equals(r))throw new Ot;if(e.data.length<Le)throw new ge;const n=Dt.decode(e.data.slice(0,Le));let i=l.alloc(0);if(e.data.length>Le){if(e.data.length<=_)throw new ge;if(e.data.length===Xe)throw new ge;if(e.data[_]!=Te.Mint)throw new vn;i=e.data.slice(_+Ye)}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 Tt(t,e,r=!1,n=T,i=$){if(!r&&!c.isOnCurve(e.toBuffer()))throw new zt;const[s]=await c.findProgramAddress([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}function H(t,e,r=!1,n=T,i=$){if(!r&&!c.isOnCurve(e.toBuffer()))throw new zt;const[s]=c.findProgramAddressSync([e.toBuffer(),n.toBuffer(),t.toBuffer()],i);return s}const _n=f.struct([te("lockCpi")]),Nn=_n.span,Un=f.struct([f.u8("state")]),Fn=Un.span,xn=f.struct([]),On=xn.span,zn=f.struct([A("rateAuthority"),f.ns64("initializationTimestamp"),f.s16("preUpdateAverageRate"),f.ns64("lastUpdateTimestamp"),f.s16("currentRate")]),Ln=zn.span,qn=f.struct([te("requireIncomingTransferMemos")]),Dn=qn.span,Kt=f.struct([A("authority"),A("metadataAddress")]),Kn=Kt.span;function Vn(t){const e=dr(C.MetadataPointer,t.tlvData);if(e!==null){const{authority:r,metadataAddress:n}=Kt.decode(e);return{authority:r.equals(c.default)?null:r,metadataAddress:n.equals(c.default)?null:n}}else return null}const Gn=f.struct([A("closeAuthority")]),Zn=Gn.span,Vt=f.struct([]),Hn=Vt.span,Qn=Vt.span,$n=f.struct([A("delegate")]),Yn=$n.span,Xn=1e4;BigInt(Xn);function bt(t){return f.struct([q("epoch"),q("maximumFee"),f.u16("transferFeeBasisPoints")],t)}const Jn=f.struct([A("transferFeeConfigAuthority"),A("withdrawWithheldAuthority"),q("withheldAmount"),bt("olderTransferFee"),bt("newerTransferFee")]),jn=Jn.span,er=f.struct([q("withheldAmount")]),tr=er.span,nr=f.struct([A("authority"),A("programId")]),rr=nr.span,ir=f.struct([te("transferring")]),sr=ir.span,Ct=f.struct([f.u8("discriminator"),f.blob(32,"addressConfig"),te("isSigner"),te("isWritable")]),ar=f.struct([f.u32("count"),f.seq(Ct,f.greedy(Ct.span),"extraAccounts")]);f.struct([q("instructionDiscriminator"),f.u32("length"),ar.replicate("extraAccountsList")]);var C;(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"})(C||(C={}));const ee=2,Ce=2;function or(t){switch(t){case C.Uninitialized:return 0;case C.TransferFeeConfig:return jn;case C.TransferFeeAmount:return tr;case C.MintCloseAuthority:return Zn;case C.ConfidentialTransferMint:return 97;case C.ConfidentialTransferAccount:return 286;case C.CpiGuard:return Nn;case C.DefaultAccountState:return Fn;case C.ImmutableOwner:return On;case C.MemoTransfer:return Dn;case C.MetadataPointer:return Kn;case C.NonTransferable:return Hn;case C.InterestBearingConfig:return Ln;case C.PermanentDelegate:return Yn;case C.NonTransferableAccount:return Qn;case C.TransferHook:return rr;case C.TransferHookAccount:return sr;default:throw Error(`Unknown extension type: ${t}`)}}function cr(t,e){if(t.length===0)return e;{const r=_+Ye+t.filter((n,i)=>i===t.indexOf(n)).map(n=>or(n)+ee+Ce).reduce((n,i)=>n+i);return r===Xe?r+ee:r}}function ur(t){return cr(t,_)}function dr(t,e){let r=0;for(;r+ee+Ce<=e.length;){const n=e.readUInt16LE(r),i=e.readUInt16LE(r+ee),s=r+ee+Ce;if(n==t)return e.slice(s,s+i);r=s+i}return null}function lr(t){const e=[];let r=0;for(;r<t.length;){const n=t.readUInt16LE(r);e.push(n);const i=t.readUInt16LE(r+ee);r+=ee+Ce+i}return e}const Bt=f.struct([f.u8("instruction")]);function qe(t,e,r,n=T){const i=[{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!1},{pubkey:r,isSigner:!1,isWritable:!1},{pubkey:N,isSigner:!1,isWritable:!1}],s=l.alloc(Bt.span);return Bt.encode({instruction:ce.InitializeAccount},s),new pe({keys:i,programId:n,data:s})}function Gt(t,e,r,n,i=T,s=$){return Zt(t,e,r,n,l.alloc(0),i,s)}function mr(t,e,r,n,i=T,s=$){return Zt(t,e,r,n,l.from([1]),i,s)}function Zt(t,e,r,n,i,s=T,o=$){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:P.programId,isSigner:!1,isWritable:!1},{pubkey:s,isSigner:!1,isWritable:!1}];return new pe({keys:a,programId:o,data:i})}const vt=f.struct([f.u8("instruction"),q("amount")]);function Ve(t,e,r,n,i=[],s=T){const o=$e([{pubkey:t,isSigner:!1,isWritable:!0},{pubkey:e,isSigner:!1,isWritable:!0}],r,i),a=l.alloc(vt.span);return vt.encode({instruction:ce.Transfer,amount:BigInt(n)},a),new pe({keys:o,programId:s,data:a})}function Je(t,e){const r=l.alloc(2);return r.writeUInt16BE(S(e)),R([l.from("foreign_contract"),r],t)}function gr(t){return R([l.from("redeemer")],t)}function je(t,e){return R([l.from("mint"),new c(e).toBuffer()],t)}function Ht(t){return R([l.from("sender")],t)}function Qt(t,e){return R([l.from("tmp"),new c(e).toBuffer()],t)}function $t(t,e,r){return R([l.from("bridged"),new c(e).toBuffer(),l.from(yn.toBytes(BigInt(r.toString()),8))],t)}function U(t){return R([l.from("config")],t)}async function ri(t,e,r){return t.getAccountInfo(U(e),r).then(n=>et.deserialize(ve(n)))}class et{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 et(r)}}function Ie(t,e){return R([new c(e).toBuffer()],t)}function ne(t,e,r){const n=typeof r=="string"?new xt(r).toUint8Array():r;return R([(()=>{const i=l.alloc(2);return i.writeUInt16BE(e),i})(),n],t)}async function ii(t,e,r){return t.getAccountInfo(new c(e),r).then(n=>tt.deserialize(ve(n)))}class tt{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 tt(r,n)}}function nt(t){return R([l.from("sender")],t)}function rt(t){return R([l.from("redeemer")],t)}function de(t){return R([l.from("authority_signer")],t)}function ye(t){return R([l.from("custody_signer")],t)}function we(t){return R([l.from("mint_signer")],t)}function le(t,e,r){return R([l.from("wrapped"),(()=>{const n=l.alloc(2);return n.writeUInt16BE(e),n})(),r],t)}function Z(t,e){return R([l.from("meta"),new c(e).toBuffer()],t)}async function ke(t,e,r,n){return t.getAccountInfo(Z(e,r),n).then(i=>it.deserialize(ve(i)))}class it{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 it(r,n,i,s)}}function Pt(t,e,r,n,i){return Pn(new c(e),de(t),new c(r),n,void 0,new c(i))}class fr{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 un(this.idl,e)??0}}class hr{constructor(e){}decode(e){throw new Error("Token Bridge program does not have events")}}class pr{constructor(e){}encode(e,r){switch(e){case"initialize":return yr(r);case"attestToken":return wr(r);case"completeNative":return Sr(r);case"completeWrapped":return Mr(r);case"transferWrapped":return kr(r);case"transferNative":return Ar(r);case"registerChain":return Tr(r);case"createWrapped":return br(r);case"upgradeContract":return Cr(r);case"transferWrappedWithPayload":return Br(r);case"transferNativeWithPayload":return vr(r);default:throw new Error(`Invalid instruction: ${e}`)}}encodeState(e,r){throw new Error("Token Bridge program does not have state")}}var x;(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"})(x||(x={}));function D(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 yr({wormhole:t}){const e=l.alloc(32);return e.write(new c(t).toBuffer().toString("hex"),0,"hex"),D(x.Initialize,e)}function wr({nonce:t}){const e=l.alloc(4);return e.writeUInt32LE(t,0),D(x.AttestToken,e)}function Sr({}){return D(x.CompleteNative)}function Mr({}){return D(x.CompleteWrapped)}function Yt({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 kr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return D(x.TransferWrapped,Yt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Ar({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}){return D(x.TransferNative,Yt({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i}))}function Tr({}){return D(x.RegisterChain)}function br({}){return D(x.CreateWrapped)}function Cr({}){return D(x.UpgradeContract)}function Xt({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 Br({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return D(x.TransferWrappedWithPayload,Xt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}function vr({nonce:t,amount:e,fee:r,targetAddress:n,targetChain:i,payload:s}){return D(x.TransferNativeWithPayload,Xt({nonce:t,amount:e,targetAddress:n,targetChain:i,payload:s}))}class Pr{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 Ir{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 Rr{instruction;accounts;state;events;types;constructor(e){this.instruction=new pr(e),this.accounts=new fr(e),this.state=new Pr(e),this.events=new hr(e),this.types=new Ir(e)}}const Jt={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 Er(t,e){return new Ae(Jt,new c(t),e===void 0?{connection:null}:e,Wr())}function z(t,e){return Er(t,Cn(e))}function Wr(){return new Rr(Jt)}class Q{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(Q.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 Q(r,n,i)}}class Re{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 u=i.length;return[u,4+u*Q.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 u=0;u<s;++u){const d=i.at(u),g=19+e+r+n+u*Q.size;a.write(d.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(),u=e.readUInt16LE(12+r+i+o),d=e.readUInt8(14+r+i+o),g=(()=>{if(d==0)return null;const m=[],h=e.readUInt32LE(15+r+i+o);for(let p=0;p<h;++p){const y=19+r+i+o+p*Q.size;m.push(Q.deserialize(e.subarray(y,y+Q.size)))}return m})();return new Re(n,s,a,u,g)}}class Be extends Re{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 fe{constructor(){}static programId=new c("metaqbxxUerdq28cj1RbAWkYQm3ybzjb6a8bt518x1s");static createMetadataAccounts(e,r,n,i,s,o,a=!1,u,d,g,m=!1,h=Ee(r)){const p=[dn(h,!1),ie(r,!1),ie(n,!0),ie(e,!0),ie(o,a),ie(P.programId,!1),ie(N,!1)],y=Be.serializeInstructionData(i,s,u===void 0?"":u,g===void 0?0:g,d===void 0?null:d,m);return{programId:fe.programId,keys:p,data:y}}}function Ee(t){return R([l.from("metadata"),fe.programId.toBuffer(),new c(t).toBuffer()],fe.programId)}var It;(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"})(It||(It={}));class st{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=Re.deserialize(e.subarray(65)),o=s.serialize().length,a=e.readUInt8(65+o)>0,u=e.readUInt8(66+o)>0;return new st(r,n,i,s,a,u)}}async function si(t,e,r){return t.getAccountInfo(Ee(e),r).then(n=>st.deserialize(ve(n)))}function _r(t,e,r,n,i,s,o,a){const u=z(e,t).methods.attestToken(o);return console.log(Rt(e,r,n,i,s,a)),u._ixFn(...u._args,{accounts:Rt(e,r,n,i,s,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Rt(t,e,r,n,i,s){const{bridge:o,emitter:a,sequence:u,feeCollector:d,clock:g,rent:m,systemProgram:h}=ln(e,r,i,t);return{payer:new c(r),config:U(t),mint:new c(n),wrappedMeta:Z(t,n),splMetadata:s?new c(s):Ee(n),wormholeBridge:o,wormholeMessage:new c(i),wormholeEmitter:a,wormholeSequence:u,wormholeFeeCollector:d,clock:g,rent:m,systemProgram:h,wormholeProgram:new c(e)}}function Et(t,e,r,n,i,s,o){const a=z(e,t).methods.completeNative();return a._ixFn(...a._args,{accounts:Nr(e,r,n,i,s,o),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Nr(t,e,r,n,i,s){const o=new c(n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),endpoint:ne(t,S(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:Ie(t,o),mint:o,custodySigner:ye(t),rent:N,systemProgram:P.programId,tokenProgram:s?new c(s):T,wormholeProgram:new c(e)}}function Ur(t,e,r,n,i,s){const o=z(e,t).methods.completeWrapped();return o._ixFn(...o._args,{accounts:Fr(e,r,n,i,s),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Fr(t,e,r,n,i){const s=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),endpoint:ne(t,S(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:Z(t,s),mintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}function xr(t,e,r,n,i){const s=z(e,t).methods.createWrapped();return s._ixFn(...s._args,{accounts:Or(e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Or(t,e,r,n){const i=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array());return{payer:new c(r),config:U(t),endpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),mint:i,wrappedMeta:Z(t,i),splMetadata:Ee(i),mintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,splMetadataProgram:fe.programId,wormholeProgram:new c(e)}}function ai(t,e,r){const n=z(t).methods.initialize(r);return n._ixFn(...n._args,{accounts:zr(t,e),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function zr(t,e){return{payer:new c(e),config:U(t),rent:N,systemProgram:P.programId}}function oi(t,e,r,n){const i=z(t).methods.registerChain();return i._ixFn(...i._args,{accounts:Lr(t,e,r,n),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Lr(t,e,r,n){return{payer:new c(r),config:U(t),endpoint:ne(t,S(n.payload.actionArgs.foreignChain),n.payload.actionArgs.foreignAddress.toUint8Array()),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),rent:N,systemProgram:P.programId,wormholeProgram:new c(e)}}function ci(t,e,r,n,i){const s=z(t).methods.upgradeContract();return s._ixFn(...s._args,{accounts:qr(t,e,r,n,i),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function qr(t,e,r,n,i){return{payer:new c(r),vaa:X(e,l.from(n.hash)),claim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),upgradeAuthority:fn(t),spill:new c(i===void 0?r:i),implementation:new c(n.payload.actionArgs.newContract),programData:gn(t),tokenBridgeProgram:new c(t),rent:N,clock:De,bpfLoaderUpgradeable:mn,systemProgram:P.programId}}function Wt(t,e,r,n,i,s,o,a,u,d,g,m,h){const p=z(e,t).methods.transferNative(u,d,g,l.from(m),h);return p._ixFn(...p._args,{accounts:Dr(e,r,n,i,s,o,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Dr(t,e,r,n,i,s,o){const{wormholeBridge:a,wormholeMessage:u,wormholeEmitter:d,wormholeSequence:g,wormholeFeeCollector:m,clock:h,rent:p,systemProgram:y}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),mint:new c(s),custody:Ie(t,s),authoritySigner:de(t),custodySigner:ye(t),wormholeBridge:a,wormholeMessage:u,wormholeEmitter:d,wormholeSequence:g,wormholeFeeCollector:m,clock:h,rent:p,systemProgram:y,tokenProgram:new c(o),wormholeProgram:new c(e)}}function _t(t,e,r,n,i,s,o,a,u,d,g,m,h){const p=z(e,t).methods.transferNativeWithPayload(u,d,l.from(g),m,l.from(h),null);return p._ixFn(...p._args,{accounts:jt(e,r,n,i,s,o,void 0,a),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function jt(t,e,r,n,i,s,o,a){const{wormholeBridge:u,wormholeMessage:d,wormholeEmitter:g,wormholeSequence:m,wormholeFeeCollector:h,clock:p,rent:y,systemProgram:w}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),mint:new c(s),custody:Ie(t,s),authoritySigner:de(t),custodySigner:ye(t),wormholeBridge:u,wormholeMessage:d,wormholeEmitter:g,wormholeSequence:m,wormholeFeeCollector:h,clock:p,sender:new c(o===void 0?r:nt(o)),rent:y,systemProgram:w,tokenProgram:a?new c(a):T,wormholeProgram:new c(e)}}function Kr(t,e,r,n,i,s,o,a,u,d,g,m,h,p,y){const w=z(e,t).methods.transferWrapped(g,m,h,l.from(p),y);return w._ixFn(...w._args,{accounts:Vr(e,r,n,i,s,o,a,u,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function Vr(t,e,r,n,i,s,o,a,u){const d=le(t,o,a),{wormholeBridge:g,wormholeMessage:m,wormholeEmitter:h,wormholeSequence:p,wormholeFeeCollector:y,clock:w,rent:v,systemProgram:B}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),fromOwner:new c(s),mint:d,wrappedMeta:Z(t,d),authoritySigner:de(t),wormholeBridge:g,wormholeMessage:m,wormholeEmitter:h,wormholeSequence:p,wormholeFeeCollector:y,clock:w,rent:v,systemProgram:B,wormholeProgram:new c(e),tokenProgram:new c(u)}}function Gr(t,e,r,n,i,s,o,a,u,d,g,m,h,p,y){const w=z(e,t).methods.transferWrappedWithPayload(g,m,l.from(h),p,l.from(y),null);return w._ixFn(...w._args,{accounts:en(e,r,n,i,s,o,a,u,void 0,d),signers:void 0,remainingAccounts:void 0,preInstructions:void 0,postInstructions:void 0})}function en(t,e,r,n,i,s,o,a,u,d){const g=le(t,o,a),{wormholeBridge:m,wormholeMessage:h,wormholeEmitter:p,wormholeSequence:y,wormholeFeeCollector:w,clock:v,rent:B,systemProgram:b}=Pe(t,e,r,n);return{payer:new c(r),config:U(t),from:new c(i),fromOwner:new c(s),mint:g,wrappedMeta:Z(t,g),authoritySigner:de(t),wormholeBridge:m,wormholeMessage:h,wormholeEmitter:p,wormholeSequence:y,wormholeFeeCollector:w,clock:v,sender:new c(u===void 0?r:nt(u)),rent:B,systemProgram:b,wormholeProgram:new c(e),tokenProgram:d?new c(d):T}}function ui(t,e,r){const{wormholeEmitter:n,wormholeBridge:i,wormholeFeeCollector:s,wormholeSequence:o}=Ut(e,r);return{tokenBridgeConfig:U(e),tokenBridgeAuthoritySigner:de(e),tokenBridgeCustodySigner:ye(e),tokenBridgeMintAuthority:we(e),tokenBridgeSender:nt(t),tokenBridgeRedeemer:rt(t),wormholeBridge:i,tokenBridgeEmitter:n,wormholeFeeCollector:s,tokenBridgeSequence:o}}function Zr(t,e,r,n,i,s,o){const a=jt(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 Hr(t,e,r,n,i,s,o,a,u){const d=en(e,r,n,i,s,u===void 0?t:u,o,a,t);return{payer:d.payer,tokenBridgeConfig:d.config,fromTokenAccount:d.from,fromTokenAccountOwner:d.fromOwner,tokenBridgeWrappedMint:d.mint,tokenBridgeWrappedMeta:d.wrappedMeta,tokenBridgeAuthoritySigner:d.authoritySigner,wormholeBridge:d.wormholeBridge,wormholeMessage:d.wormholeMessage,tokenBridgeEmitter:d.wormholeEmitter,tokenBridgeSequence:d.wormholeSequence,wormholeFeeCollector:d.wormholeFeeCollector,clock:d.clock,tokenBridgeSender:d.sender,rent:d.rent,systemProgram:d.systemProgram,tokenProgram:d.tokenProgram,wormholeProgram:d.wormholeProgram}}function di(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:U(t),vaa:X(e,l.from(n.hash)),tokenBridgeClaim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:rt(o),toFeesTokenAccount:new c(i),tokenBridgeCustody:Ie(t,s),mint:s,tokenBridgeCustodySigner:ye(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}function li(t,e,r,n,i){const s=le(t,S(n.payload.token.chain),n.payload.token.address.toUint8Array()),o=new c(n.payload.to.address.toUint8Array());return{payer:new c(r),tokenBridgeConfig:U(t),vaa:X(e,l.from(n.hash)),tokenBridgeClaim:Y(t,n.emitterAddress.toUint8Array(),S(n.emitterChain),n.sequence),tokenBridgeForeignEndpoint:ne(t,S(n.emitterChain),n.emitterAddress.toUint8Array()),toTokenAccount:new c(i),tokenBridgeRedeemer:rt(o),toFeesTokenAccount:new c(i),tokenBridgeWrappedMint:s,tokenBridgeWrappedMeta:Z(t,s),tokenBridgeMintAuthority:we(t),rent:N,systemProgram:P.programId,tokenProgram:T,wormholeProgram:new c(e)}}const Qr={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 at(t,e){return new Ae(Qr,new c(t),{connection:e})}function tn(t,e){return R([l.from("seq"),new c(e).toBuffer()],t)}async function $r(t,e,r,n,i,s,o,a,u,d,g,m){const{methods:{transferNativeTokensWithRelay:h},account:{signerSequence:p}}=at(e,t),y=tn(e,r),w=await p.fetch(y).then(({value:k})=>k).catch(k=>{if(k.message?.includes("Account does not exist"))return new I(0);throw k}),v=$t(e,r,w),B=H(new c(s),new c(r)),b=Qt(e,s),F=Zr(e,n,i,r,v,B,s);return h(new I(o.toString()),new I(a.toString()),S(d),[...u],g,m).accounts({config:Ht(e),payerSequence:y,foreignContract:Je(e,d),registeredToken:je(e,s),tmpTokenAccount:b,tokenBridgeProgram:new c(n),...F}).instruction()}async function Yr(t,e,r,n,i,s,o,a,u,d,g){const{methods:{transferWrappedTokensWithRelay:m},account:{signerSequence:h}}=at(e,t),p=tn(e,r),y=await h.fetch(p).then(({value:W})=>W).catch(W=>{if(W.message?.includes("Account does not exist"))return new I(0);throw W}),w=$t(e,r,y),v=H(new c(s),new c(r)),{chain:B,tokenAddress:b}=await ke(t,n,s),F=Qt(e,s),k=Hr(e,n,i,r,w,v,B,b);return m(new I(o.toString()),new I(a.toString()),S(d),[...u],g).accounts({config:Ht(e),payerSequence:p,foreignContract:Je(e,d),registeredToken:je(e,new c(s)),tmpTokenAccount:F,tokenBridgeProgram:new c(n),...k}).instruction()}class he{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=S(r);const s=i.tokenBridge;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridge=z(s,n),this.coreBridge=new Ft(e,r,n,i)}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new he(n,i,e,s.contracts)}async isWrappedAsset(e){return ke(this.connection,this.tokenBridge.programId,new M(e).toUint8Array()).catch(r=>null).then(r=>r!=null)}async getOriginalAsset(e){if(!await this.isWrappedAsset(e))throw Fe(e.toString());const r=new M(e).toUint8Array(),n=new c(r);try{const i=await ke(this.connection,this.tokenBridge.programId,r);return i===null?{chain:this.chain,address:new M(n.toBytes()).toUniversalAddress()}:{chain:wn(i.chain),address:new xt(new Uint8Array(i.tokenAddress))}}catch{throw Fe(e.toString())}}async getTokenUniversalAddress(e){return new M(e).toUniversalAddress()}async getTokenNativeAddress(e,r){return new M(r).toNative()}async hasWrappedAsset(e){try{return await this.getWrappedAsset(e),!0}catch{}return!1}async getWrappedAsset(e){if(K(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=le(this.tokenBridge.programId,S(e.chain),e.address.toUniversalAddress().toUint8Array());try{return await ke(this.connection,this.tokenBridge.programId,r),Ke(this.chain,r.toBase58())}catch{}throw Fe(`${r}: ${e.address.toUniversalAddress().toString()}`)}async isTransferCompleted(e){return hn(this.connection,this.tokenBridge.programId,e.emitterAddress.toUint8Array(),S(e.emitterChain),e.sequence,this.connection.commitment).catch(()=>!1)}async getWrappedNative(){return Ke(this.chain,O.toBase58())}async*createAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new M(r).unwrap(),i=0,s=await this.coreBridge.getMessageFee(),o=pn(this.coreBridge.coreBridge.programId,n,s),a=new M(e).unwrap(),u=await L.getTokenProgramId(this.connection,a);let d;if(u.equals(xe)){const p=await At(this.connection,a,void 0,u),y=Vn(p);y?.metadataAddress&&(d=y?.metadataAddress)}const g=j.generate(),m=_r(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,new M(e).unwrap(),g.publicKey,i,d),h=new G().add(o,m);h.feePayer=n,yield this.createUnsignedTx({transaction:h,signers:[g]},"Solana.AttestToken")}async*submitAttestation(e,r){if(!r)throw new Error("Payer required to create attestation");const n=new M(r).unwrap();yield*this.coreBridge.postVaa(n,e);const i=new G().add(xr(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 M(e).unwrap(),o=s,a=r.address.toUniversalAddress().toUint8Array(),u=S(r.chain),d=0,g=0n,m=j.generate(),h=j.generate(),p=await ze(this.connection),y=P.createAccount({fromPubkey:o,newAccountPubkey:h.publicKey,lamports:p,space:_,programId:T}),w=P.transfer({fromPubkey:o,lamports:n,toPubkey:h.publicKey}),v=qe(h.publicKey,O,o),B=Pt(this.tokenBridge.programId,h.publicKey,o,n,T),b=i?_t(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,m.publicKey,h.publicKey,O,T,d,n,a,u,i):Wt(this.connection,this.tokenBridge.programId,this.coreBridge.address,s,m.publicKey,h.publicKey,O,T,d,n,g,a,u),F=Oe(h.publicKey,o,o),k=new G;return k.feePayer=o,k.add(y,w,v,B,b,F),this.createUnsignedTx({transaction:k,signers:[m,h]},"TokenBridge.TransferNative")}async*transfer(e,r,n,i,s){if(K(n)){yield await this.transferSol(e,r,i,s);return}const o=new M(n).unwrap(),a=new M(e).unwrap(),u=await L.getTokenProgramId(this.connection,o);if(u.equals(xe))throw new Error("Transfers of Token-2022 assets are not supported via the Manual Token Bridge route. Please use the Executor Token Bridge route instead.");let d=await Tt(o,a,!1,u);const g=!await this.isWrappedAsset(n);let m,h=!1;if(g&&u.equals(xe)){const E=await this.connection.getAccountInfo(d);if(E&&E.data.length>_){const J=await qt(this.connection,d,void 0,u);J.tlvData&&(h=lr(J.tlvData).includes(C.ImmutableOwner))}}const p=r.address.toUniversalAddress().toUint8Array(),y=S(r.chain),w=0,v=0n,B=j.generate(),b=[],F=[B];if(h){m=j.generate(),F.push(m);const E=await ze(this.connection);b.push(P.createAccount({fromPubkey:a,newAccountPubkey:m.publicKey,lamports:E,space:_,programId:u})),b.push(qe(m.publicKey,o,a,u)),b.push(Ve(d,m.publicKey,a,i,[],u)),d=m.publicKey}let k;if(g)k=s?_t(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,o,u,w,i,p,y,s):Wt(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,o,u,w,i,v,p,y);else{const E=await this.getOriginalAsset(n);if(K(E.address))throw new Error("Native cannot be an original asset");k=s?Gr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,a,S(E.chain),E.address.toUint8Array(),u,w,i,p,y,s):Kr(this.connection,this.tokenBridge.programId,this.coreBridge.address,a,B.publicKey,d,a,S(E.chain),E.address.toUint8Array(),u,w,i,v,p,y)}const W=Pt(this.tokenBridge.programId,d,a,i,u);b.push(W),b.push(k),m&&b.push(Oe(m.publicKey,a,a,[],u));const V=new G().add(...b);V.feePayer=a,yield this.createUnsignedTx({transaction:V,signers:F},"TokenBridge.TransferTokens")}async*redeemAndUnwrap(e,r){const n=new M(e).unwrap(),i=new M(r.payload.to.address).unwrap(),s=await At(this.connection,O).then(y=>r.payload.token.amount*BigInt(Math.pow(10,y.decimals-8))),o=await ze(this.connection),a=j.generate(),u=Et(this.connection,this.tokenBridge.programId,this.coreBridge.address,n,r),d=P.createAccount({fromPubkey:n,newAccountPubkey:a.publicKey,lamports:o,space:_,programId:T}),g=qe(a.publicKey,O,n),m=Ve(i,a.publicKey,n,s.valueOf()),h=Oe(a.publicKey,n,n),p=new G;p.feePayer=n,p.add(u,d,g,m,h),yield this.createUnsignedTx({transaction:p,signers:[a]},"TokenBridge.RedeemAndUnwrap")}async*createAta(e,r,n){const i=new M(e).unwrap(),s=new M(r).unwrap(),o=await Tt(s,i,!1,n);if(await this.connection.getAccountInfo(o)===null){const u=new G().add(Gt(i,o,i,s,n));u.feePayer=i,yield this.createUnsignedTx({transaction:u},"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(),s=await L.getTokenProgramId(this.connection,new M(i).unwrap());if(yield*this.createAta(e,i,s),yield*this.coreBridge.postVaa(e,r),n){const d=new M(await this.getWrappedNative());if(Sn.equals(i.toUint8Array(),d.toUint8Array())){yield*this.redeemAndUnwrap(e,r);return}}const o=new M(e).unwrap(),a=r.payload.token.chain==this.chain?Et:Ur,u=new G().add(a(this.connection,this.tokenBridge.programId,this.coreBridge.address,o,r,void 0,s));u.feePayer=o,yield this.createUnsignedTx({transaction:u},"Solana.RedeemTransfer")}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}const Xr={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:[]},se=9,me=new I(10),ae=new I(1e8);class ot{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=S(r);const s=i.tokenBridgeRelayer;if(!s)throw new Error(`TokenBridge contract Address for chain ${r} not found`);this.tokenBridgeRelayer=at(s,n),this.tokenBridgeProgramId=new c(i.tokenBridge),this.coreBridgeProgramId=new c(i.coreBridge)}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch for chain ${i}: ${s.network} != ${n}`);return new ot(n,i,e,s.contracts)}async*transfer(e,r,n,i,s){const a=new M(e).unwrap(),u=r.address.toUniversalAddress().toUint8Array(),d=this.mintAddress(n),g=new G;if(K(n)){const y=H(d,a);try{await qt(this.connection,y)}catch(w){if(w instanceof Qe){const v=Gt(a,y,a,d);g.add(v)}else throw w}}const m=s||0n,h=K(n),p=h?await $r(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,d,i,m,u,r.chain,0,h):await Yr(this.connection,this.tokenBridgeRelayer.programId,a,this.tokenBridgeProgramId,this.coreBridgeProgramId,d,i,m,u,r.chain,0);g.add(p),g.feePayer=a,yield this.createUnsignedTx({transaction:g},"AutomaticTokenBridge.Transfer")}async*redeem(e,r){const n=new G;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 L.getDecimals(this.network,this.chain,this.connection,r)),u=me.pow(new I(a)).mul(i).mul(ae).div(new I(o).mul(s));return BigInt(u.toString())}async maxSwapAmount(e){const r=this.mintAddress(e),[{swapRate:n,maxNativeSwapAmount:i},{swapRate:s}]=await Promise.all([this.getRegisteredToken(r),this.getRegisteredToken(O)]),o=Number(await L.getDecimals(this.network,this.chain,this.connection,e)),a=this.calculateNativeSwapRate(s,n),u=o>se?i.mul(a).mul(me.pow(new I(o-se))).div(ae):i.mul(a).div(me.pow(new I(se-o)).mul(ae));return BigInt(u.toString())}async nativeTokenAmount(e,r){if(r===0n)return 0n;const n=this.mintAddress(e),i=Number(await L.getDecimals(this.network,this.chain,this.connection,e)),[{swapRate:s},{swapRate:o}]=await Promise.all([this.getRegisteredToken(n),this.getRegisteredToken(O)]),a=this.calculateNativeSwapRate(o,s),u=i>se?ae.mul(new I(r.toString())).div(a.mul(me.pow(new I(i-se)))):ae.mul(new I(r.toString())).mul(me.pow(new I(se-i))).div(a);return BigInt(u.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 K(e)?new c(O):new M(e).unwrap()}async getRegisteredTokens(){return Xr[this.network].map(e=>Ke(this.chain,e))}calculateNativeSwapRate(e,r){return ae.mul(e).div(r)}async getForeignContract(e){return await this.tokenBridgeRelayer.account.foreignContract.fetch(Je(this.tokenBridgeRelayer.programId,e))}async getRegisteredToken(e){return await this.tokenBridgeRelayer.account.registeredToken.fetch(je(this.tokenBridgeRelayer.programId,e))}async getRedeemerConfig(){return await this.tokenBridgeRelayer.account.redeemerConfig.fetch(gr(this.tokenBridgeRelayer.programId))}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}const Nt={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 oe{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 Ae(Nt,this.relayerProgramId,{connection:this.connection})}static async fromRpc(e,r){const[n,i]=await L.chainFromRpc(e),s=r[i];if(s.network!==n)throw new Error(`Network mismatch: ${s.network} != ${n}`);return new oe(n,i,e,s.contracts)}async*transfer(e,r,n,i,s,o){const a=Mn.get(this.network,r.chain);if(!a||!a.relayer)throw new Error(`Token Bridge Executor Relayer contract for domain ${r.chain} not found`);const u=a.relayer,d=new M(e).unwrap(),g=S(r.chain),m=r.address.toUniversalAddress(),{estimatedCost:h,signedQuote:p,relayInstructions:y}=s,w=yt(kn,p),v=yt(An,y),B=new he(this.network,this.chain,this.connection,this.contracts),b=K(n),F=!b&&await B.isWrappedAsset(n),k=b?O:new M(n).unwrap(),W=await L.getTokenProgramId(this.connection,k),V=new c(p.quote.payeeAddress),E=j.generate(),J=Tn(r.chain,u),We=J,Se=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],_e=c.findProgramAddressSync([k.toBuffer()],this.tokenBridgeProgramId)[0],Me=c.findProgramAddressSync([l.from("authority_signer")],this.tokenBridgeProgramId)[0],nn=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0],{wormholeEmitter:ct,wormholeSequence:ut,wormholeFeeCollector:dt,wormholeBridge:lt}=Ut(this.tokenBridgeProgramId,this.wormholeProgramId),mt=c.findProgramAddressSync([l.from("sender")],this.relayerProgramId)[0],gt=H(k,d,!1,W),ft=c.findProgramAddressSync([l.from("tmp"),k.toBytes()],this.relayerProgramId)[0],re=[];if(o&&o.feeAmount>0n){const Ne=new c(o.referrer.address.toString());if(k.equals(O))re.push(P.transfer({fromPubkey:d,toPubkey:Ne,lamports:o.feeAmount}));else{const Ue=H(k,Ne,!0,W),cn=H(k,d,!0,W);await this.connection.getAccountInfo(Ue)||re.push(mr(d,Ue,Ne,k,W)),re.push(Ve(cn,Ue,d,o.feeAmount,void 0,W))}}const rn=o?o.remainingAmount:i,ht={amount:new I(rn.toString()),recipientChain:g,recipientAddress:Array.from(m.toUint8Array()),nonce:0,dstTransferRecipient:Array.from(J.toUint8Array()),dstExecutionAddress:Array.from(We.toUint8Array()),execAmount:new I(h.toString()),signedQuoteBytes:l.from(w),relayInstructions:l.from(v)};F?re.push(await this.relayerProgram.methods.transferWrappedTokensWithRelay(ht).accountsStrict({payer:d,config:mt,tokenBridgeWrappedMint:k,fromTokenAccount:gt,tmpTokenAccount:ft,tokenBridgeWrappedMeta:Z(this.tokenBridgeProgramId,k),tokenBridgeConfig:Se,tokenBridgeAuthoritySigner:Me,wormholeBridge:lt,wormholeMessage:E.publicKey,tokenBridgeEmitter:ct,tokenBridgeSequence:ut,wormholeFeeCollector:dt,payee:V,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,systemProgram:P.programId,tokenProgram:W,executorProgram:this.executorProgramId,clock:De,rent:N}).instruction()):re.push(await this.relayerProgram.methods.transferNativeTokensWithRelay({...ht,wrapNative:K(n)}).accountsStrict({payer:d,config:mt,mint:k,fromTokenAccount:gt,tmpTokenAccount:ft,tokenBridgeConfig:Se,tokenBridgeCustody:_e,tokenBridgeAuthoritySigner:Me,tokenBridgeCustodySigner:nn,wormholeBridge:lt,wormholeMessage:E.publicKey,tokenBridgeEmitter:ct,tokenBridgeSequence:ut,wormholeFeeCollector:dt,payee:V,systemProgram:P.programId,tokenProgram:W,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,associatedTokenProgram:$,executorProgram:this.executorProgramId,clock:De,rent:N}).instruction());const pt=await this.getAddressLookupTable(),{blockhash:sn}=await this.connection.getLatestBlockhash(),an=new wt({payerKey:d,instructions:re,recentBlockhash:sn}).compileToV0Message(pt?[pt]:[]),on=new St(an);yield this.createUnsignedTx({transaction:on,signers:[E]},"ExecutorTokenBridge.transfer")}async*redeem(e,r){const n=new M(e).unwrap(),i=new M(r.payload.payload.targetRecipient).unwrap(),s=r.payload.token.chain,o=r.payload.token.address,a=s===this.chain;let u;if(a)u=new M(o).unwrap();else{const Me=await new he(this.network,this.chain,this.connection,this.contracts).getWrappedAsset({chain:s,address:o});u=new M(Me).unwrap()}const d=await L.getTokenProgramId(this.connection,u),g=H(u,i,!0,d),m=X(this.wormholeProgramId,l.from(r.hash));await this.connection.getAccountInfo(m)||(yield*new Ft(this.network,this.chain,this.connection,this.contracts).postVaa(n,r));const p=new M(r.payload.to.address).unwrap(),y=new Ae(Nt,p,{connection:this.connection}),w=c.findProgramAddressSync([l.from("redeemer")],y.programId)[0],v=c.findProgramAddressSync([l.from("config")],this.tokenBridgeProgramId)[0],B=c.findProgramAddressSync([l.from("tmp"),u.toBytes()],y.programId)[0],b=Y(this.tokenBridgeProgramId,r.emitterAddress.toUint8Array(),S(r.emitterChain),r.sequence),F=ne(this.tokenBridgeProgramId,S(r.emitterChain),r.emitterAddress.toUint8Array()),k=c.findProgramAddressSync([u.toBuffer()],this.tokenBridgeProgramId)[0],W=c.findProgramAddressSync([l.from("custody_signer")],this.tokenBridgeProgramId)[0];let V;const E=Array.from(r.hash);a?V=await y.methods.completeNativeTransferWithRelay(E).accountsStrict({payer:n,config:w,mint:u,recipientTokenAccount:g,recipient:i,tmpTokenAccount:B,tokenBridgeConfig:v,vaa:m,tokenBridgeClaim:b,tokenBridgeForeignEndpoint:F,tokenBridgeCustody:k,tokenBridgeCustodySigner:W,wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:d,associatedTokenProgram:$,systemProgram:P.programId,rent:N}).instruction():V=await y.methods.completeWrappedTransferWithRelay(E).accountsStrict({payer:n,config:w,tokenBridgeWrappedMint:u,recipientTokenAccount:g,recipient:i,tmpTokenAccount:B,tokenBridgeWrappedMeta:Z(this.tokenBridgeProgramId,u),tokenBridgeConfig:v,vaa:m,tokenBridgeClaim:b,tokenBridgeForeignEndpoint:F,tokenBridgeMintAuthority:we(this.tokenBridgeProgramId),wormholeProgram:this.wormholeProgramId,tokenBridgeProgram:this.tokenBridgeProgramId,tokenProgram:d,associatedTokenProgram:$,systemProgram:P.programId,rent:N}).instruction();const{blockhash:J}=await this.connection.getLatestBlockhash(),We=new wt({payerKey:n,instructions:[V],recentBlockhash:J}).compileToV0Message(),Se=new St(We);yield this.createUnsignedTx({transaction:Se,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,K(e.address)||bn(e)===O.toString()?n+=5000n+5000000n:n+=5000n+1200000n,r){const i=new c(r.address.toString());if(!K(e.address)){const s=new M(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=H(s,i,!0,o.owner);await this.connection.getAccountInfo(a)===null&&(oe.associatedTokenAccountMinRent||(oe.associatedTokenAccountMinRent=BigInt(await this.connection.getMinimumBalanceForRentExemption(165))),n+=oe.associatedTokenAccountMinRent)}}return{msgValue:n,gasLimit:310000n}}createUnsignedTx(e,r,n=!1){return new Ge(e,this.network,this.chain,r,n)}}Ze(He,"TokenBridge",he);Ze(He,"AutomaticTokenBridge",ot);Ze(He,"ExecutorTokenBridge",oe);export{Be as CreateMetadataAccountArgs,Q as Creator,Re as Data,tt as EndpointRegistration,Nt as ExecutorTokenBridgeRelayerIdl,It as Key,st as Metadata,ot as SolanaAutomaticTokenBridge,oe as SolanaExecutorTokenBridge,he as SolanaTokenBridge,fe as SplTokenMetadataProgram,Jt as TOKEN_BRIDGE_IDL,Qr as TOKEN_BRIDGE_RELAYER_IDL,et as TokenBridgeConfig,it as WrappedMeta,Wr as coder,Pt as createApproveAuthoritySignerInstruction,_r as createAttestTokenInstruction,Et as createCompleteTransferNativeInstruction,Ur as createCompleteTransferWrappedInstruction,xr as createCreateWrappedInstruction,ai as createInitializeInstruction,z as createReadOnlyTokenBridgeProgramInterface,oi as createRegisterChainInstruction,Er as createTokenBridgeProgramInterface,at as createTokenBridgeRelayerProgramInterface,Wt as createTransferNativeInstruction,$r as createTransferNativeTokensWithRelayInstruction,_t as createTransferNativeWithPayloadInstruction,Kr as createTransferWrappedInstruction,Yr as createTransferWrappedTokensWithRelayInstruction,Gr as createTransferWrappedWithPayloadInstruction,ci as createUpgradeContractInstruction,de as deriveAuthoritySignerKey,Ie as deriveCustodyKey,ye as deriveCustodySignerKey,ne as deriveEndpointKey,Je as deriveForeignContractAddress,we as deriveMintAuthorityKey,rt as deriveRedeemerAccountKey,gr as deriveRedeemerConfigAddress,je as deriveRegisteredTokenAddress,nt as deriveSenderAccountKey,Ht as deriveSenderConfigAddress,Ee as deriveSplTokenMetadataKey,Qt as deriveTmpTokenAccountAddress,U as deriveTokenBridgeConfigKey,$t as deriveTokenTransferMessageAddress,Z as deriveWrappedMetaKey,le as deriveWrappedMintKey,Rt as getAttestTokenAccounts,Nr as getCompleteTransferNativeAccounts,di as getCompleteTransferNativeWithPayloadCpiAccounts,Fr as getCompleteTransferWrappedAccounts,li as getCompleteTransferWrappedWithPayloadCpiAccounts,Or as getCreateWrappedAccounts,ii as getEndpointRegistration,zr as getInitializeAccounts,si as getMetadata,Lr as getRegisterChainAccounts,ri as getTokenBridgeConfig,ui as getTokenBridgeDerivedAccounts,Dr as getTransferNativeAccounts,jt as getTransferNativeWithPayloadAccounts,Zr as getTransferNativeWithPayloadCpiAccounts,Vr as getTransferWrappedAccounts,en as getTransferWrappedWithPayloadAccounts,Hr as getTransferWrappedWithPayloadCpiAccounts,qr as getUpgradeContractAccounts,ke as getWrappedMeta};