@latticexyz/explorer 2.2.24-38fee1657dd544e31a8ea005836205dc3f8dfdd0 → 2.2.24-3c39d69e3d503a5007e9821ce442bccc43ac310f

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 (446) hide show
  1. package/.next/standalone/packages/explorer/.next/BUILD_ID +1 -1
  2. package/.next/standalone/packages/explorer/.next/app-build-manifest.json +58 -58
  3. package/.next/standalone/packages/explorer/.next/app-path-routes-manifest.json +1 -1
  4. package/.next/standalone/packages/explorer/.next/build-manifest.json +5 -5
  5. package/.next/standalone/packages/explorer/.next/prerender-manifest.json +1 -1
  6. package/.next/standalone/packages/explorer/.next/react-loadable-manifest.json +538 -538
  7. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/page.js +1 -1
  8. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/page.js.nft.json +1 -1
  9. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/page_client-reference-manifest.js +1 -1
  10. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/decode/page.js +1 -1
  11. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/decode/page.js.nft.json +1 -1
  12. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/decode/page_client-reference-manifest.js +1 -1
  13. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/explore/page.js +2 -2
  14. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/explore/page.js.nft.json +1 -1
  15. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/explore/page_client-reference-manifest.js +1 -1
  16. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/interact/page.js +3 -3
  17. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/interact/page.js.nft.json +1 -1
  18. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/interact/page_client-reference-manifest.js +1 -1
  19. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/observe/page.js +2 -2
  20. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/observe/page.js.nft.json +1 -1
  21. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/observe/page_client-reference-manifest.js +1 -1
  22. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/page.js +1 -1
  23. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/page.js.nft.json +1 -1
  24. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/[worldAddress]/page_client-reference-manifest.js +1 -1
  25. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/page.js +1 -1
  26. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/page.js.nft.json +1 -1
  27. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/[chainName]/worlds/page_client-reference-manifest.js +1 -1
  28. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/api/system-abis/route.js +2 -2
  29. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/api/system-abis/route.js.nft.json +1 -1
  30. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/api/world-abi/route.js +1 -1
  31. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/api/world-abi/route.js.nft.json +1 -1
  32. package/.next/standalone/packages/explorer/.next/server/app/(explorer)/page_client-reference-manifest.js +1 -1
  33. package/.next/standalone/packages/explorer/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  34. package/.next/standalone/packages/explorer/.next/server/app/_not-found.html +1 -1
  35. package/.next/standalone/packages/explorer/.next/server/app/_not-found.rsc +1 -1
  36. package/.next/standalone/packages/explorer/.next/server/app/internal/observer-relay/page_client-reference-manifest.js +1 -1
  37. package/.next/standalone/packages/explorer/.next/server/app/internal/observer-relay.html +1 -1
  38. package/.next/standalone/packages/explorer/.next/server/app/internal/observer-relay.rsc +1 -1
  39. package/.next/standalone/packages/explorer/.next/server/app-paths-manifest.json +3 -3
  40. package/.next/standalone/packages/explorer/.next/server/chunks/1009.js +1 -0
  41. package/.next/standalone/packages/explorer/.next/server/chunks/{9713.js → 1021.js} +1 -1
  42. package/.next/standalone/packages/explorer/.next/server/chunks/{4052.js → 1024.js} +1 -1
  43. package/.next/standalone/packages/explorer/.next/server/chunks/1120.js +1 -0
  44. package/.next/standalone/packages/explorer/.next/server/chunks/{6556.js → 1172.js} +1 -1
  45. package/.next/standalone/packages/explorer/.next/server/chunks/{4470.js → 1190.js} +1 -1
  46. package/.next/standalone/packages/explorer/.next/server/chunks/{327.js → 1209.js} +7 -7
  47. package/.next/standalone/packages/explorer/.next/server/chunks/{8108.js → 1215.js} +1 -1
  48. package/.next/standalone/packages/explorer/.next/server/chunks/{8817.js → 1217.js} +1 -1
  49. package/.next/standalone/packages/explorer/.next/server/chunks/{6652.js → 1262.js} +1 -1
  50. package/.next/standalone/packages/explorer/.next/server/chunks/{1529.js → 1523.js} +1 -1
  51. package/.next/standalone/packages/explorer/.next/server/chunks/{6669.js → 1633.js} +1 -1
  52. package/.next/standalone/packages/explorer/.next/server/chunks/{4342.js → 1664.js} +1 -1
  53. package/.next/standalone/packages/explorer/.next/server/chunks/{8683.js → 1737.js} +1 -1
  54. package/.next/standalone/packages/explorer/.next/server/chunks/{1744.js → 1929.js} +1 -1
  55. package/.next/standalone/packages/explorer/.next/server/chunks/{1049.js → 2107.js} +1 -1
  56. package/.next/standalone/packages/explorer/.next/server/chunks/{2485.js → 2219.js} +1 -1
  57. package/.next/standalone/packages/explorer/.next/server/chunks/{2212.js → 2298.js} +1 -1
  58. package/.next/standalone/packages/explorer/.next/server/chunks/{6802.js → 2329.js} +1 -1
  59. package/.next/standalone/packages/explorer/.next/server/chunks/{2516.js → 2371.js} +1 -1
  60. package/.next/standalone/packages/explorer/.next/server/chunks/2455.js +5 -11
  61. package/.next/standalone/packages/explorer/.next/server/chunks/{340.js → 2521.js} +1 -1
  62. package/.next/standalone/packages/explorer/.next/server/chunks/2544.js +1 -0
  63. package/.next/standalone/packages/explorer/.next/server/chunks/{7144.js → 2545.js} +1 -1
  64. package/.next/standalone/packages/explorer/.next/server/chunks/{9107.js → 2723.js} +1 -1
  65. package/.next/standalone/packages/explorer/.next/server/chunks/{9605.js → 2763.js} +1 -1
  66. package/.next/standalone/packages/explorer/.next/server/chunks/{8184.js → 2778.js} +1 -1
  67. package/.next/standalone/packages/explorer/.next/server/chunks/{117.js → 2795.js} +1 -1
  68. package/.next/standalone/packages/explorer/.next/server/chunks/{2498.js → 290.js} +1 -1
  69. package/.next/standalone/packages/explorer/.next/server/chunks/{3201.js → 2918.js} +1 -1
  70. package/.next/standalone/packages/explorer/.next/server/chunks/{6214.js → 3051.js} +1 -1
  71. package/.next/standalone/packages/explorer/.next/server/chunks/{2726.js → 3148.js} +1 -1
  72. package/.next/standalone/packages/explorer/.next/server/chunks/3182.js +1 -0
  73. package/.next/standalone/packages/explorer/.next/server/chunks/{3878.js → 3233.js} +1 -1
  74. package/.next/standalone/packages/explorer/.next/server/chunks/{6895.js → 3258.js} +1 -1
  75. package/.next/standalone/packages/explorer/.next/server/chunks/{9089.js → 3306.js} +1 -1
  76. package/.next/standalone/packages/explorer/.next/server/chunks/{7094.js → 3313.js} +1 -1
  77. package/.next/standalone/packages/explorer/.next/server/chunks/{3933.js → 3354.js} +1 -1
  78. package/.next/standalone/packages/explorer/.next/server/chunks/{5079.js → 3434.js} +1 -1
  79. package/.next/standalone/packages/explorer/.next/server/chunks/{6334.js → 3437.js} +1 -1
  80. package/.next/standalone/packages/explorer/.next/server/chunks/{7300.js → 3482.js} +1 -1
  81. package/.next/standalone/packages/explorer/.next/server/chunks/3556.js +1 -1
  82. package/.next/standalone/packages/explorer/.next/server/chunks/{8248.js → 3583.js} +1 -1
  83. package/.next/standalone/packages/explorer/.next/server/chunks/3677.js +1 -0
  84. package/.next/standalone/packages/explorer/.next/server/chunks/{5262.js → 3710.js} +1 -1
  85. package/.next/standalone/packages/explorer/.next/server/chunks/{9374.js → 3789.js} +1 -1
  86. package/.next/standalone/packages/explorer/.next/server/chunks/{2182.js → 3803.js} +1 -1
  87. package/.next/standalone/packages/explorer/.next/server/chunks/3852.js +1 -0
  88. package/.next/standalone/packages/explorer/.next/server/chunks/{6499.js → 4027.js} +1 -1
  89. package/.next/standalone/packages/explorer/.next/server/chunks/{2305.js → 4088.js} +1 -1
  90. package/.next/standalone/packages/explorer/.next/server/chunks/{1845.js → 4096.js} +1 -1
  91. package/.next/standalone/packages/explorer/.next/server/chunks/{3010.js → 4131.js} +2 -2
  92. package/.next/standalone/packages/explorer/.next/server/chunks/{7794.js → 418.js} +1 -1
  93. package/.next/standalone/packages/explorer/.next/server/chunks/{7904.js → 4216.js} +1 -1
  94. package/.next/standalone/packages/explorer/.next/server/chunks/{6902.js → 4253.js} +1 -1
  95. package/.next/standalone/packages/explorer/.next/server/chunks/{9287.js → 4298.js} +1 -1
  96. package/.next/standalone/packages/explorer/.next/server/chunks/{7443.js → 4420.js} +1 -1
  97. package/.next/standalone/packages/explorer/.next/server/chunks/{4447.js → 4423.js} +1 -1
  98. package/.next/standalone/packages/explorer/.next/server/chunks/{2605.js → 4431.js} +1 -1
  99. package/.next/standalone/packages/explorer/.next/server/chunks/{4384.js → 4526.js} +1 -1
  100. package/.next/standalone/packages/explorer/.next/server/chunks/4613.js +1 -0
  101. package/.next/standalone/packages/explorer/.next/server/chunks/{9428.js → 4716.js} +1 -1
  102. package/.next/standalone/packages/explorer/.next/server/chunks/{8342.js → 4759.js} +1 -1
  103. package/.next/standalone/packages/explorer/.next/server/chunks/{9542.js → 4793.js} +1 -1
  104. package/.next/standalone/packages/explorer/.next/server/chunks/482.js +1 -1
  105. package/.next/standalone/packages/explorer/.next/server/chunks/4863.js +1 -0
  106. package/.next/standalone/packages/explorer/.next/server/chunks/{3896.js → 4886.js} +12 -12
  107. package/.next/standalone/packages/explorer/.next/server/chunks/{4487.js → 5011.js} +1 -1
  108. package/.next/standalone/packages/explorer/.next/server/chunks/{2078.js → 5154.js} +1 -1
  109. package/.next/standalone/packages/explorer/.next/server/chunks/{2501.js → 5168.js} +1 -1
  110. package/.next/standalone/packages/explorer/.next/server/chunks/{2441.js → 519.js} +1 -1
  111. package/.next/standalone/packages/explorer/.next/server/chunks/{2482.js → 5209.js} +5 -5
  112. package/.next/standalone/packages/explorer/.next/server/chunks/{5921.js → 5245.js} +1 -1
  113. package/.next/standalone/packages/explorer/.next/server/chunks/{9175.js → 5391.js} +1 -1
  114. package/.next/standalone/packages/explorer/.next/server/chunks/{8423.js → 5447.js} +1 -1
  115. package/.next/standalone/packages/explorer/.next/server/chunks/{483.js → 5454.js} +1 -1
  116. package/.next/standalone/packages/explorer/.next/server/chunks/{8016.js → 5574.js} +7 -7
  117. package/.next/standalone/packages/explorer/.next/server/chunks/{7262.js → 5576.js} +1 -1
  118. package/.next/standalone/packages/explorer/.next/server/chunks/{3041.js → 5586.js} +1 -1
  119. package/.next/standalone/packages/explorer/.next/server/chunks/{3555.js → 5594.js} +1 -1
  120. package/.next/standalone/packages/explorer/.next/server/chunks/{72.js → 5698.js} +1 -1
  121. package/.next/standalone/packages/explorer/.next/server/chunks/{85.js → 5754.js} +1 -1
  122. package/.next/standalone/packages/explorer/.next/server/chunks/{2897.js → 5778.js} +1 -1
  123. package/.next/standalone/packages/explorer/.next/server/chunks/{6036.js → 5789.js} +1 -1
  124. package/.next/standalone/packages/explorer/.next/server/chunks/{6827.js → 5794.js} +1 -1
  125. package/.next/standalone/packages/explorer/.next/server/chunks/{804.js → 5799.js} +1 -1
  126. package/.next/standalone/packages/explorer/.next/server/chunks/{7622.js → 5833.js} +1 -1
  127. package/.next/standalone/packages/explorer/.next/server/chunks/5852.js +1 -0
  128. package/.next/standalone/packages/explorer/.next/server/chunks/5875.js +1 -0
  129. package/.next/standalone/packages/explorer/.next/server/chunks/{2944.js → 5931.js} +1 -1
  130. package/.next/standalone/packages/explorer/.next/server/chunks/{9744.js → 6090.js} +1 -1
  131. package/.next/standalone/packages/explorer/.next/server/chunks/{7445.js → 6124.js} +1 -1
  132. package/.next/standalone/packages/explorer/.next/server/chunks/{1535.js → 6269.js} +1 -1
  133. package/.next/standalone/packages/explorer/.next/server/chunks/{3209.js → 6318.js} +1 -1
  134. package/.next/standalone/packages/explorer/.next/server/chunks/{5651.js → 6353.js} +1 -1
  135. package/.next/standalone/packages/explorer/.next/server/chunks/644.js +1 -0
  136. package/.next/standalone/packages/explorer/.next/server/chunks/6483.js +2 -2
  137. package/.next/standalone/packages/explorer/.next/server/chunks/6674.js +1 -8
  138. package/.next/standalone/packages/explorer/.next/server/chunks/6685.js +1 -0
  139. package/.next/standalone/packages/explorer/.next/server/chunks/6944.js +1 -0
  140. package/.next/standalone/packages/explorer/.next/server/chunks/701.js +1 -0
  141. package/.next/standalone/packages/explorer/.next/server/chunks/{1353.js → 7010.js} +1 -1
  142. package/.next/standalone/packages/explorer/.next/server/chunks/{5899.js → 7029.js} +1 -1
  143. package/.next/standalone/packages/explorer/.next/server/chunks/{4376.js → 7063.js} +1 -1
  144. package/.next/standalone/packages/explorer/.next/server/chunks/{1978.js → 7067.js} +1 -1
  145. package/.next/standalone/packages/explorer/.next/server/chunks/{9055.js → 7304.js} +1 -1
  146. package/.next/standalone/packages/explorer/.next/server/chunks/{1435.js → 7366.js} +1 -1
  147. package/.next/standalone/packages/explorer/.next/server/chunks/{7882.js → 7388.js} +1 -1
  148. package/.next/standalone/packages/explorer/.next/server/chunks/{3687.js → 7422.js} +1 -1
  149. package/.next/standalone/packages/explorer/.next/server/chunks/{8516.js → 7528.js} +1 -1
  150. package/.next/standalone/packages/explorer/.next/server/chunks/{5660.js → 7601.js} +1 -1
  151. package/.next/standalone/packages/explorer/.next/server/chunks/{1389.js → 7645.js} +1 -1
  152. package/.next/standalone/packages/explorer/.next/server/chunks/{1713.js → 7765.js} +1 -1
  153. package/.next/standalone/packages/explorer/.next/server/chunks/{8716.js → 7807.js} +1 -1
  154. package/.next/standalone/packages/explorer/.next/server/chunks/{1742.js → 7837.js} +1 -1
  155. package/.next/standalone/packages/explorer/.next/server/chunks/{2965.js → 7839.js} +1 -1
  156. package/.next/standalone/packages/explorer/.next/server/chunks/7876.js +12 -0
  157. package/.next/standalone/packages/explorer/.next/server/chunks/{2669.js → 7885.js} +1 -1
  158. package/.next/standalone/packages/explorer/.next/server/chunks/{44.js → 7891.js} +1 -1
  159. package/.next/standalone/packages/explorer/.next/server/chunks/{246.js → 8125.js} +9 -9
  160. package/.next/standalone/packages/explorer/.next/server/chunks/{9457.js → 8173.js} +1 -1
  161. package/.next/standalone/packages/explorer/.next/server/chunks/{9346.js → 8190.js} +1 -1
  162. package/.next/standalone/packages/explorer/.next/server/chunks/{1850.js → 8222.js} +1 -1
  163. package/.next/standalone/packages/explorer/.next/server/chunks/{4192.js → 824.js} +1 -1
  164. package/.next/standalone/packages/explorer/.next/server/chunks/{5555.js → 8304.js} +1 -1
  165. package/.next/standalone/packages/explorer/.next/server/chunks/{3384.js → 8310.js} +1 -1
  166. package/.next/standalone/packages/explorer/.next/server/chunks/{6125.js → 8429.js} +1 -1
  167. package/.next/standalone/packages/explorer/.next/server/chunks/{1005.js → 8478.js} +1 -1
  168. package/.next/standalone/packages/explorer/.next/server/chunks/{3244.js → 8560.js} +1 -1
  169. package/.next/standalone/packages/explorer/.next/server/chunks/{8252.js → 8562.js} +1 -1
  170. package/.next/standalone/packages/explorer/.next/server/chunks/{7333.js → 8571.js} +1 -1
  171. package/.next/standalone/packages/explorer/.next/server/chunks/{1677.js → 8593.js} +1 -1
  172. package/.next/standalone/packages/explorer/.next/server/chunks/{1751.js → 8610.js} +1 -1
  173. package/.next/standalone/packages/explorer/.next/server/chunks/{8479.js → 8674.js} +1 -1
  174. package/.next/standalone/packages/explorer/.next/server/chunks/{2527.js → 8724.js} +1 -1
  175. package/.next/standalone/packages/explorer/.next/server/chunks/{5382.js → 8758.js} +1 -1
  176. package/.next/standalone/packages/explorer/.next/server/chunks/{3113.js → 8785.js} +1 -1
  177. package/.next/standalone/packages/explorer/.next/server/chunks/{2532.js → 8814.js} +1 -1
  178. package/.next/standalone/packages/explorer/.next/server/chunks/{8359.js → 8820.js} +1 -1
  179. package/.next/standalone/packages/explorer/.next/server/chunks/{5129.js → 8842.js} +1 -1
  180. package/.next/standalone/packages/explorer/.next/server/chunks/89.js +1 -0
  181. package/.next/standalone/packages/explorer/.next/server/chunks/{7023.js → 8921.js} +1 -1
  182. package/.next/standalone/packages/explorer/.next/server/chunks/{4502.js → 8962.js} +1 -1
  183. package/.next/standalone/packages/explorer/.next/server/chunks/{4438.js → 9047.js} +1 -1
  184. package/.next/standalone/packages/explorer/.next/server/chunks/9138.js +1 -0
  185. package/.next/standalone/packages/explorer/.next/server/chunks/924.js +1 -0
  186. package/.next/standalone/packages/explorer/.next/server/chunks/9256.js +8 -0
  187. package/.next/standalone/packages/explorer/.next/server/chunks/928.js +1 -0
  188. package/.next/standalone/packages/explorer/.next/server/chunks/933.js +3 -0
  189. package/.next/standalone/packages/explorer/.next/server/chunks/944.js +1 -0
  190. package/.next/standalone/packages/explorer/.next/server/chunks/{3901.js → 9469.js} +1 -1
  191. package/.next/standalone/packages/explorer/.next/server/chunks/{3984.js → 9496.js} +1 -1
  192. package/.next/standalone/packages/explorer/.next/server/chunks/95.js +1 -0
  193. package/.next/standalone/packages/explorer/.next/server/chunks/{2915.js → 9571.js} +1 -1
  194. package/.next/standalone/packages/explorer/.next/server/chunks/{2336.js → 9597.js} +1 -1
  195. package/.next/standalone/packages/explorer/.next/server/chunks/{1134.js → 9669.js} +1 -1
  196. package/.next/standalone/packages/explorer/.next/server/chunks/9705.js +2 -0
  197. package/.next/standalone/packages/explorer/.next/server/chunks/{1543.js → 9767.js} +1 -1
  198. package/.next/standalone/packages/explorer/.next/server/chunks/{9193.js → 9780.js} +1 -1
  199. package/.next/standalone/packages/explorer/.next/server/chunks/984.js +2 -2
  200. package/.next/standalone/packages/explorer/.next/server/chunks/{4725.js → 9851.js} +1 -1
  201. package/.next/standalone/packages/explorer/.next/server/chunks/{9082.js → 9884.js} +1 -1
  202. package/.next/standalone/packages/explorer/.next/server/chunks/{9860.js → 9897.js} +1 -1
  203. package/.next/standalone/packages/explorer/.next/server/chunks/{1717.js → 991.js} +1 -1
  204. package/.next/standalone/packages/explorer/.next/server/middleware-build-manifest.js +1 -1
  205. package/.next/standalone/packages/explorer/.next/server/middleware-react-loadable-manifest.js +1 -1
  206. package/.next/standalone/packages/explorer/.next/server/pages/404.html +1 -1
  207. package/.next/standalone/packages/explorer/.next/server/pages/500.html +1 -1
  208. package/.next/standalone/packages/explorer/.next/server/server-reference-manifest.js +1 -1
  209. package/.next/standalone/packages/explorer/.next/server/server-reference-manifest.json +1 -1
  210. package/.next/standalone/packages/explorer/.next/static/chunks/{5707.2168cec3679a75d4.js → 1014.4ba21604a8ff0a7c.js} +1 -1
  211. package/.next/standalone/packages/explorer/.next/static/chunks/{6216.814b09f1d33755a0.js → 1030.df0b932c6048eed0.js} +1 -1
  212. package/.next/standalone/packages/explorer/.next/static/chunks/{4612.b8d26f2c64576aa7.js → 1057.db828565fc70ed13.js} +1 -1
  213. package/.next/standalone/packages/explorer/.next/static/chunks/1093.3c3a72caa160a338.js +1 -0
  214. package/.next/standalone/packages/explorer/.next/static/chunks/{4387.151ef1617cbd9211.js → 1132.0a8cbedb66ae9c25.js} +1 -1
  215. package/.next/standalone/packages/explorer/.next/static/chunks/{2078.bfe2e04051d8dd57.js → 1140.8ebd07f73b28878b.js} +1 -1
  216. package/.next/standalone/packages/explorer/.next/static/chunks/{7492.ac97f5e0c08fd9ba.js → 1145.c4b49340913ddb46.js} +1 -1
  217. package/.next/standalone/packages/explorer/.next/static/chunks/119.5bff2cabf11cf984.js +1 -0
  218. package/.next/standalone/packages/explorer/.next/static/chunks/{8470.8e1af6f3ca19da9a.js → 1204.50a3939fd98b54ef.js} +1 -1
  219. package/.next/standalone/packages/explorer/.next/static/chunks/1252.8e440b628e7df29e.js +1 -0
  220. package/.next/standalone/packages/explorer/.next/static/chunks/{8680.784fef5adbda3eec.js → 1308.1c8a13184e0b5b3a.js} +1 -1
  221. package/.next/standalone/packages/explorer/.next/static/chunks/{4287.38bdf02b55569458.js → 1315.812052b945416ecc.js} +1 -1
  222. package/.next/standalone/packages/explorer/.next/static/chunks/{5725.d8d87609a2398573.js → 135.fab26391b6434414.js} +1 -1
  223. package/.next/standalone/packages/explorer/.next/static/chunks/{2760.4c4407fe18139698.js → 1573.b4c31769b33614d3.js} +1 -1
  224. package/.next/standalone/packages/explorer/.next/static/chunks/{1843.630c9230e455c38c.js → 1627.f71433214183c21d.js} +1 -1
  225. package/.next/standalone/packages/explorer/.next/static/chunks/{9564.c52829e26a119e21.js → 1746.2e6fce3dc06207bd.js} +1 -1
  226. package/.next/standalone/packages/explorer/.next/static/chunks/{1571.ad94e2a4839b8e7c.js → 1816.6d789a586ea3025d.js} +1 -1
  227. package/.next/standalone/packages/explorer/.next/static/chunks/{5767.ebedf0e3d7ff2dc8.js → 1880.2ae855fe7d1a75c3.js} +1 -1
  228. package/.next/standalone/packages/explorer/.next/static/chunks/{7235.dd7c1fa78a15fe62.js → 1913.cdf5546f2757a6f3.js} +1 -1
  229. package/.next/standalone/packages/explorer/.next/static/chunks/2052.1c75cf4fd1648ebf.js +1 -0
  230. package/.next/standalone/packages/explorer/.next/static/chunks/{2285.7f0e8e6f1159657b.js → 2087.40c75258b070bf0d.js} +1 -1
  231. package/.next/standalone/packages/explorer/.next/static/chunks/{7934.6563ab21f1803901.js → 2091.866c36091b7f2f8b.js} +1 -1
  232. package/.next/standalone/packages/explorer/.next/static/chunks/{5289.87d8ab9af63b6034.js → 2104.616040a442c00518.js} +1 -1
  233. package/.next/standalone/packages/explorer/.next/static/chunks/{3475.55d5a2f63dbd5bb6.js → 2192.f06ddfc5e6365b5c.js} +1 -1
  234. package/.next/standalone/packages/explorer/.next/static/chunks/{8112.472af03f40775188.js → 2209.4f4e046eb76fc941.js} +1 -1
  235. package/.next/standalone/packages/explorer/.next/static/chunks/228.f28c82949db5928c.js +1 -0
  236. package/.next/standalone/packages/explorer/.next/static/chunks/{666.8ff8b0dce9eecefc.js → 2393.72d722f5a770a25a.js} +1 -1
  237. package/.next/standalone/packages/explorer/.next/static/chunks/{6060.afbda74c8f3de115.js → 2408.904be335c0b2272c.js} +1 -1
  238. package/.next/standalone/packages/explorer/.next/static/chunks/{538.f4358fcee95be1f8.js → 2506.dfcdfd44df303655.js} +1 -1
  239. package/.next/standalone/packages/explorer/.next/static/chunks/251.7af0b951f11055f6.js +1 -0
  240. package/.next/standalone/packages/explorer/.next/static/chunks/{4702.09b6032efb8d32a3.js → 2547.8ac851b737e09e4c.js} +1 -1
  241. package/.next/standalone/packages/explorer/.next/static/chunks/{2302.668f2962f77e1b7e.js → 2562.712b52191f480337.js} +1 -1
  242. package/.next/standalone/packages/explorer/.next/static/chunks/264.fb94ac5817d74e93.js +1 -0
  243. package/.next/standalone/packages/explorer/.next/static/chunks/275.caa3ff9605db045c.js +1 -0
  244. package/.next/standalone/packages/explorer/.next/static/chunks/{1640.4df689b4087618b5.js → 2778.9aaeadb6683874ee.js} +1 -1
  245. package/.next/standalone/packages/explorer/.next/static/chunks/28.a08888768e6a68b3.js +1 -0
  246. package/.next/standalone/packages/explorer/.next/static/chunks/{6222.e099f0b8e5b94508.js → 2848.2cc03d00a8014d4d.js} +1 -1
  247. package/.next/standalone/packages/explorer/.next/static/chunks/{8247.58e5a46ad2c8dbe0.js → 2901.3f0903f047e32c0d.js} +1 -1
  248. package/.next/standalone/packages/explorer/.next/static/chunks/{2897.a0e4bf57cdb17b91.js → 2924.d54c95ce83e87e8f.js} +1 -1
  249. package/.next/standalone/packages/explorer/.next/static/chunks/{5040.7edd13faf5f6ff94.js → 3004.ca09a2ebe714a265.js} +1 -1
  250. package/.next/standalone/packages/explorer/.next/static/chunks/{5970.16c50bf63c7e69ed.js → 3022.6ba88a43e36c2da8.js} +1 -1
  251. package/.next/standalone/packages/explorer/.next/static/chunks/{6639.3c98f2f6071ab830.js → 3244.3413d44b5a4f7e01.js} +1 -1
  252. package/.next/standalone/packages/explorer/.next/static/chunks/{6673.2d3fab2c13afed25.js → 3257.15f2f356aea35fb5.js} +1 -1
  253. package/.next/standalone/packages/explorer/.next/static/chunks/{9021.7325988af065a249.js → 3266.523fbefd05b04975.js} +1 -1
  254. package/.next/standalone/packages/explorer/.next/static/chunks/{5483.17f69edc85dacf4b.js → 3348.5c91b49667b7cb6f.js} +1 -1
  255. package/.next/standalone/packages/explorer/.next/static/chunks/{5490.20a476b20d7ddc9b.js → 3351.44d7b8df35992945.js} +1 -1
  256. package/.next/standalone/packages/explorer/.next/static/chunks/{3361-f2ba237b63580aa1.js → 3361-3b8e51c24a0bb5d9.js} +1 -1
  257. package/.next/standalone/packages/explorer/.next/static/chunks/3365.ff209ae9c74a2b4a.js +1 -0
  258. package/.next/standalone/packages/explorer/.next/static/chunks/{3072-5fcfcd18c0c33abd.js → 3470-b5ab24e56e70a4b4.js} +2 -2
  259. package/.next/standalone/packages/explorer/.next/static/chunks/{4915.35427023817dcdba.js → 3491.b861bdeb7414430c.js} +1 -1
  260. package/.next/standalone/packages/explorer/.next/static/chunks/{8159.9f01dec60be6fbed.js → 3503.17d5e3bb8631095a.js} +1 -1
  261. package/.next/standalone/packages/explorer/.next/static/chunks/{5921-9031ae3e65ad35e5.js → 3519-2972cd6e49b49aaf.js} +3 -3
  262. package/.next/standalone/packages/explorer/.next/static/chunks/{9375.487de5fa3c6b9aef.js → 3602.c0f428b4c971321c.js} +1 -1
  263. package/.next/standalone/packages/explorer/.next/static/chunks/{5468.17e7d04f4693f9f5.js → 3958.46759b92c7861e2a.js} +1 -1
  264. package/.next/standalone/packages/explorer/.next/static/chunks/{7706.199d0ba0953f99d8.js → 3961.e266d9f1b81727e2.js} +1 -1
  265. package/.next/standalone/packages/explorer/.next/static/chunks/{1178.36ad98ce0049e76f.js → 3980.5044cdac5d857375.js} +1 -1
  266. package/.next/standalone/packages/explorer/.next/static/chunks/404.1b80736f6a3d17a7.js +1 -0
  267. package/.next/standalone/packages/explorer/.next/static/chunks/4081.42af509ded9fbe14.js +1 -0
  268. package/.next/standalone/packages/explorer/.next/static/chunks/4096.bfed9a0d6147b192.js +1 -0
  269. package/.next/standalone/packages/explorer/.next/static/chunks/{8804.81f7e17de0f31a54.js → 4156.414b9655a2988dcb.js} +1 -1
  270. package/.next/standalone/packages/explorer/.next/static/chunks/{6714.6df2bf6cb51616e2.js → 4172.af752e7d96997799.js} +1 -1
  271. package/.next/standalone/packages/explorer/.next/static/chunks/{4852.94bf6d693e6aaf76.js → 4261.d50efc7668cd8824.js} +1 -1
  272. package/.next/standalone/packages/explorer/.next/static/chunks/{3445.016df412c6f8fe0a.js → 4285.08ebd9ccc23f3722.js} +9 -9
  273. package/.next/standalone/packages/explorer/.next/static/chunks/{4838.00da67ccf034db42.js → 4293.c9de099b06039a89.js} +1 -1
  274. package/.next/standalone/packages/explorer/.next/static/chunks/4351.99eaebdc0d884813.js +1 -0
  275. package/.next/standalone/packages/explorer/.next/static/chunks/{5230.d9bbe57e560c2a64.js → 4386.93ba530e6dee15ad.js} +1 -1
  276. package/.next/standalone/packages/explorer/.next/static/chunks/{7352.24bc96bebeec26e6.js → 4393.ed6283721bf42975.js} +1 -1
  277. package/.next/standalone/packages/explorer/.next/static/chunks/{5776.fd4e1ce39a87d68b.js → 4397.365ab09892ade36a.js} +1 -1
  278. package/.next/standalone/packages/explorer/.next/static/chunks/{6013.db94cc6bdca9a6e4.js → 4489.e90863c78ed47bdc.js} +1 -1
  279. package/.next/standalone/packages/explorer/.next/static/chunks/4519.187c99c744cf44fc.js +1 -0
  280. package/.next/standalone/packages/explorer/.next/static/chunks/{2136.88fb846c3a9d7943.js → 4528.f7db8c5701f81d9a.js} +1 -1
  281. package/.next/standalone/packages/explorer/.next/static/chunks/4532.63ff161992465357.js +1 -0
  282. package/.next/standalone/packages/explorer/.next/static/chunks/{8405.8752befbea58413e.js → 4617.06dd697b6fb6c73e.js} +1 -1
  283. package/.next/standalone/packages/explorer/.next/static/chunks/4798.de72d7781604c5bf.js +1 -0
  284. package/.next/standalone/packages/explorer/.next/static/chunks/4830-b09590659af64cb4.js +1 -0
  285. package/.next/standalone/packages/explorer/.next/static/chunks/{2455.16ecffbb9051088a.js → 4858.fc7d55104765af48.js} +1 -1
  286. package/.next/standalone/packages/explorer/.next/static/chunks/{7287.456d3eeaf52131f4.js → 4953.a3ff5f1962af3f9b.js} +1 -1
  287. package/.next/standalone/packages/explorer/.next/static/chunks/{5723.8a623c0736e1d139.js → 4963.7d3210364ab60f32.js} +1 -1
  288. package/.next/standalone/packages/explorer/.next/static/chunks/{3239.b7a4f3d43595f403.js → 5055.b8852732a3a46ff2.js} +1 -1
  289. package/.next/standalone/packages/explorer/.next/static/chunks/{2676.2bb2fb88e4ae5664.js → 5107.0b3e34b2b3d35eea.js} +1 -1
  290. package/.next/standalone/packages/explorer/.next/static/chunks/5167.762d8444089f9b36.js +1 -0
  291. package/.next/standalone/packages/explorer/.next/static/chunks/523.2a40ceab310e2814.js +1 -0
  292. package/.next/standalone/packages/explorer/.next/static/chunks/{1795.5493c8fe1bb68ca9.js → 5236.63c343c538a6d4cf.js} +1 -1
  293. package/.next/standalone/packages/explorer/.next/static/chunks/{8762.d78507c94fe83cf0.js → 5282.fea886db6e6202f1.js} +1 -1
  294. package/.next/standalone/packages/explorer/.next/static/chunks/5341.af6642be2c9cec46.js +1 -0
  295. package/.next/standalone/packages/explorer/.next/static/chunks/{6695.dd891082edac252c.js → 540.54d135a28baf12d3.js} +1 -1
  296. package/.next/standalone/packages/explorer/.next/static/chunks/{1459.bfbbc146439f89b8.js → 5482.a35b5bf1e253ec0a.js} +1 -1
  297. package/.next/standalone/packages/explorer/.next/static/chunks/{1664.d88320fd52dd6f43.js → 5484.61824f17cc2e18d2.js} +1 -1
  298. package/.next/standalone/packages/explorer/.next/static/chunks/{6869.4cde172718483dd5.js → 5562.954dc5c689c8d471.js} +1 -1
  299. package/.next/standalone/packages/explorer/.next/static/chunks/5697.08f04cbdbc7dd177.js +1 -0
  300. package/.next/standalone/packages/explorer/.next/static/chunks/{5572.207850b90bbb1f73.js → 5731.1855fcd4153cb928.js} +7 -7
  301. package/.next/standalone/packages/explorer/.next/static/chunks/5961.e2bd5a01b1dcf2c8.js +1 -0
  302. package/.next/standalone/packages/explorer/.next/static/chunks/{1745.e1ad963ec7bc48f5.js → 5980.f97948cbaff2522d.js} +1 -1
  303. package/.next/standalone/packages/explorer/.next/static/chunks/{4530.e2762289e0a29652.js → 6017.74775b72e371b82b.js} +1 -1
  304. package/.next/standalone/packages/explorer/.next/static/chunks/{4030.9719f7dede794921.js → 6038.da4d72a1c26e7282.js} +1 -1
  305. package/.next/standalone/packages/explorer/.next/static/chunks/{8231.f91e8d44e296349a.js → 6063.c545ac213b0e78b5.js} +1 -1
  306. package/.next/standalone/packages/explorer/.next/static/chunks/{7992.58f33ef1bd27b77d.js → 613.6d6c2d03b00d5941.js} +1 -1
  307. package/.next/standalone/packages/explorer/.next/static/chunks/{6632.278ff1e8ec2978f0.js → 6176.f11bc2f581ec807a.js} +1 -1
  308. package/.next/standalone/packages/explorer/.next/static/chunks/{5298.7218e365ef1b7347.js → 6206.0f6a6891b36a4b99.js} +1 -1
  309. package/.next/standalone/packages/explorer/.next/static/chunks/{6469.3bf359b6bf253c9e.js → 6213.d500b229cf1922f7.js} +1 -1
  310. package/.next/standalone/packages/explorer/.next/static/chunks/{6265.cdcf99705a5d601e.js → 6288.d0f58f4bd919cfd0.js} +1 -1
  311. package/.next/standalone/packages/explorer/.next/static/chunks/{5697.6550248d9ffb60cf.js → 6384.d67ee3fa657f752b.js} +1 -1
  312. package/.next/standalone/packages/explorer/.next/static/chunks/{406.5d5b8801e2ff2ac9.js → 6440.ed316bfb21b6393b.js} +1 -1
  313. package/.next/standalone/packages/explorer/.next/static/chunks/{7972.d554b45119808f74.js → 6505.9b78f6ae1f2af8dd.js} +1 -1
  314. package/.next/standalone/packages/explorer/.next/static/chunks/6506.a6918a1341a32cca.js +1 -0
  315. package/.next/standalone/packages/explorer/.next/static/chunks/{7942.0d6e91d16bd3f2ce.js → 6586.6d5c0eea113bb4b0.js} +1 -1
  316. package/.next/standalone/packages/explorer/.next/static/chunks/661.6e5ac0b4200972f9.js +1 -0
  317. package/.next/standalone/packages/explorer/.next/static/chunks/{1750.7cc12738384f9bce.js → 6618.79c0c6b01a0f27fd.js} +1 -1
  318. package/.next/standalone/packages/explorer/.next/static/chunks/6662-0b0fdb05ea0ae6b6.js +32 -0
  319. package/.next/standalone/packages/explorer/.next/static/chunks/{8730.933c8bce84ca95c7.js → 6769.06e9307b5d4faa5e.js} +1 -1
  320. package/.next/standalone/packages/explorer/.next/static/chunks/{8846.771534b4f07239fd.js → 6792.aabfc6bebf9140dc.js} +1 -1
  321. package/.next/standalone/packages/explorer/.next/static/chunks/{7870.606c3b3cfc9c85c6.js → 6886.8c1749ccc2d215a3.js} +1 -1
  322. package/.next/standalone/packages/explorer/.next/static/chunks/{6412.2e3b70ab08515358.js → 6923.5083417dd9b67755.js} +1 -1
  323. package/.next/standalone/packages/explorer/.next/static/chunks/{324.942fb8dc1137e300.js → 7029.a7e7c2fdcd670806.js} +1 -1
  324. package/.next/standalone/packages/explorer/.next/static/chunks/{8381.55d3f3a29e3f422a.js → 7102.aad33978670aa099.js} +1 -1
  325. package/.next/standalone/packages/explorer/.next/static/chunks/{6140.822d85602565bf13.js → 7141.732883ca4239b926.js} +1 -1
  326. package/.next/standalone/packages/explorer/.next/static/chunks/7329.42ac082b28f96d1b.js +1 -0
  327. package/.next/standalone/packages/explorer/.next/static/chunks/7334.6d42e67414f7f887.js +1 -0
  328. package/.next/standalone/packages/explorer/.next/static/chunks/7394.04071196f06aa4b7.js +1 -0
  329. package/.next/standalone/packages/explorer/.next/static/chunks/{9359.3a02ae6be6860155.js → 7418.e9e25b41a3fde82f.js} +1 -1
  330. package/.next/standalone/packages/explorer/.next/static/chunks/{645.7219230242e7f55c.js → 7462.e1c746ace33ce6ef.js} +5 -5
  331. package/.next/standalone/packages/explorer/.next/static/chunks/{1352.ccc39ef233bc37ad.js → 7496.b56218dedcb5afb8.js} +1 -1
  332. package/.next/standalone/packages/explorer/.next/static/chunks/{8789.adccc5ac02be239f.js → 7533.682cce06e9f73e15.js} +1 -1
  333. package/.next/standalone/packages/explorer/.next/static/chunks/{8013.c709ed36f25dd7f9.js → 7731.29557460680ccd39.js} +1 -1
  334. package/.next/standalone/packages/explorer/.next/static/chunks/787.0eaf7fa24944d562.js +1 -0
  335. package/.next/standalone/packages/explorer/.next/static/chunks/{1436.4e3945ac125013be.js → 7884.1d3ac8a71414fdcd.js} +1 -1
  336. package/.next/standalone/packages/explorer/.next/static/chunks/{3374.e88a010b4ba7f314.js → 8018.81dfbd1ce2cb7ed8.js} +1 -1
  337. package/.next/standalone/packages/explorer/.next/static/chunks/{8979.ab872ddc62b5a5ac.js → 810.a3bdcff1c629e638.js} +1 -1
  338. package/.next/standalone/packages/explorer/.next/static/chunks/{4452.1f845388aec52571.js → 8363.66ce1bc3767b5f07.js} +1 -1
  339. package/.next/standalone/packages/explorer/.next/static/chunks/{9678.676083e6b5d28f48.js → 8423.1c3662b6941971d4.js} +1 -1
  340. package/.next/standalone/packages/explorer/.next/static/chunks/{8486.607f9ba8b522b4ca.js → 8505.3bbe441d99a7de81.js} +1 -1
  341. package/.next/standalone/packages/explorer/.next/static/chunks/853.261f2d14d650053b.js +1 -0
  342. package/.next/standalone/packages/explorer/.next/static/chunks/{8184.5c1698d05f1789a3.js → 8743.dc364169ad9be549.js} +12 -12
  343. package/.next/standalone/packages/explorer/.next/static/chunks/882.760be3adb47e0c05.js +1 -0
  344. package/.next/standalone/packages/explorer/.next/static/chunks/8859.3e34df7f3935f137.js +1 -0
  345. package/.next/standalone/packages/explorer/.next/static/chunks/{150.109cca675f4b87e3.js → 8880.0463de6a27a67bb7.js} +1 -1
  346. package/.next/standalone/packages/explorer/.next/static/chunks/{8216.f306755db33fefaf.js → 89.e36536c1c5ebebfb.js} +1 -1
  347. package/.next/standalone/packages/explorer/.next/static/chunks/{6592.2417196f00fd62e4.js → 8932.677cb100581af19c.js} +1 -1
  348. package/.next/standalone/packages/explorer/.next/static/chunks/{3842.fd64f956fa0865a8.js → 9000.e1ac9e183884ee97.js} +1 -1
  349. package/.next/standalone/packages/explorer/.next/static/chunks/{7237.351c2f67f9ff0431.js → 9023.2458f38b4a6f50e1.js} +1 -1
  350. package/.next/standalone/packages/explorer/.next/static/chunks/{4275.01277908f0b58493.js → 9058.ef785ae1b6ee0ad5.js} +1 -1
  351. package/.next/standalone/packages/explorer/.next/static/chunks/{5353.db808f348c43be36.js → 9108.bea67958490a0cb7.js} +1 -1
  352. package/.next/standalone/packages/explorer/.next/static/chunks/{9168.6f8f42624ab8239a.js → 9134.247efac267798d1f.js} +1 -1
  353. package/.next/standalone/packages/explorer/.next/static/chunks/{5166.f47a5dfc84922b5e.js → 9175.ab8f44a6980dd4f7.js} +1 -1
  354. package/.next/standalone/packages/explorer/.next/static/chunks/{9057.8fde161b19fe0cb0.js → 9183.5240dfcc6922fb0e.js} +1 -1
  355. package/.next/standalone/packages/explorer/.next/static/chunks/{8059.eb54fc050fa9d2f2.js → 9334.c5b313f0e4e21250.js} +1 -1
  356. package/.next/standalone/packages/explorer/.next/static/chunks/{7087.cd839889cac38c16.js → 9408.f813a686cc5081d5.js} +1 -1
  357. package/.next/standalone/packages/explorer/.next/static/chunks/{1913.7b3600b8db77945f.js → 9419.f91791299e53018f.js} +1 -1
  358. package/.next/standalone/packages/explorer/.next/static/chunks/{7883.98cdad645438ba70.js → 9456.0aad3b925fab8567.js} +1 -1
  359. package/.next/standalone/packages/explorer/.next/static/chunks/{4853.2d17c593a99cb640.js → 9484.b0122999cedee102.js} +1 -1
  360. package/.next/standalone/packages/explorer/.next/static/chunks/{4139.60156888ead6b8dd.js → 9491.a8de15ae367fc536.js} +1 -1
  361. package/.next/standalone/packages/explorer/.next/static/chunks/{2921.d92e5811d4ad9c8d.js → 9496.4554ae9833bdf559.js} +1 -1
  362. package/.next/standalone/packages/explorer/.next/static/chunks/{2746.b2abcee91c5de99b.js → 9547.1573d5f43a1538bf.js} +1 -1
  363. package/.next/standalone/packages/explorer/.next/static/chunks/9555.7b6f93d90e3772c9.js +1 -0
  364. package/.next/standalone/packages/explorer/.next/static/chunks/{5389.cd81f2b29c2e1091.js → 9562.fad55bc1dec02348.js} +2 -2
  365. package/.next/standalone/packages/explorer/.next/static/chunks/{1131.8346b7edfbc6bcd8.js → 9752.fc5c99183d447f16.js} +1 -1
  366. package/.next/standalone/packages/explorer/.next/static/chunks/{7344.c1b85d1df4afe8cd.js → 9763.d40f0d0663c6e15d.js} +1 -1
  367. package/.next/standalone/packages/explorer/.next/static/chunks/{2461.1d156c9bd38a2804.js → 9770.6499a4fcf3dc0d02.js} +1 -1
  368. package/.next/standalone/packages/explorer/.next/static/chunks/{9802-eb3b3481e7818004.js → 9869-d883c531dade949d.js} +2 -2
  369. package/.next/standalone/packages/explorer/.next/static/chunks/987.7af0052a09bc861d.js +1 -0
  370. package/.next/standalone/packages/explorer/.next/static/chunks/9916.91d225b26c0992ae.js +1 -0
  371. package/.next/standalone/packages/explorer/.next/static/chunks/{1069.7199c46d89a9b0b1.js → 9988.d2bf8fc3ae539808.js} +1 -1
  372. package/.next/standalone/packages/explorer/.next/static/chunks/{1461.ba5dabcd2b84f9c9.js → 9998.4edf2b9f4f42ba05.js} +1 -1
  373. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/{layout-ce650f447d8cff20.js → layout-699e3208ee69265c.js} +1 -1
  374. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/explore/{page-3aa583846ba9ff0c.js → page-7f96cd2577ac326f.js} +2 -2
  375. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/interact/page-ac3c96291d05d2dc.js +1 -0
  376. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/layout-9c8fe0a33de7ce82.js +1 -0
  377. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/observe/{page-4aa643449dd1bbbd.js → page-092d30374483ae80.js} +1 -1
  378. package/.next/standalone/packages/explorer/.next/static/chunks/c56315a7-0f08af84ca4053d0.js +1 -0
  379. package/.next/standalone/packages/explorer/.next/static/chunks/webpack-6b22c91fb83f9652.js +1 -0
  380. package/package.json +10 -10
  381. package/.next/standalone/packages/explorer/.next/server/chunks/1177.js +0 -1
  382. package/.next/standalone/packages/explorer/.next/server/chunks/1250.js +0 -1
  383. package/.next/standalone/packages/explorer/.next/server/chunks/229.js +0 -1
  384. package/.next/standalone/packages/explorer/.next/server/chunks/3149.js +0 -1
  385. package/.next/standalone/packages/explorer/.next/server/chunks/3453.js +0 -1
  386. package/.next/standalone/packages/explorer/.next/server/chunks/369.js +0 -1
  387. package/.next/standalone/packages/explorer/.next/server/chunks/3955.js +0 -1
  388. package/.next/standalone/packages/explorer/.next/server/chunks/3977.js +0 -1
  389. package/.next/standalone/packages/explorer/.next/server/chunks/4173.js +0 -1
  390. package/.next/standalone/packages/explorer/.next/server/chunks/4243.js +0 -2
  391. package/.next/standalone/packages/explorer/.next/server/chunks/4929.js +0 -1
  392. package/.next/standalone/packages/explorer/.next/server/chunks/567.js +0 -3
  393. package/.next/standalone/packages/explorer/.next/server/chunks/5834.js +0 -1
  394. package/.next/standalone/packages/explorer/.next/server/chunks/6208.js +0 -1
  395. package/.next/standalone/packages/explorer/.next/server/chunks/635.js +0 -1
  396. package/.next/standalone/packages/explorer/.next/server/chunks/6730.js +0 -1
  397. package/.next/standalone/packages/explorer/.next/server/chunks/6932.js +0 -1
  398. package/.next/standalone/packages/explorer/.next/server/chunks/6976.js +0 -1
  399. package/.next/standalone/packages/explorer/.next/server/chunks/7115.js +0 -6
  400. package/.next/standalone/packages/explorer/.next/server/chunks/7534.js +0 -1
  401. package/.next/standalone/packages/explorer/.next/server/chunks/803.js +0 -1
  402. package/.next/standalone/packages/explorer/.next/server/chunks/8042.js +0 -1
  403. package/.next/standalone/packages/explorer/.next/server/chunks/9562.js +0 -1
  404. package/.next/standalone/packages/explorer/.next/server/chunks/9992.js +0 -1
  405. package/.next/standalone/packages/explorer/.next/static/chunks/1685.1ecbc40f2eb8d609.js +0 -1
  406. package/.next/standalone/packages/explorer/.next/static/chunks/2086.fb96f89eabe35fd8.js +0 -1
  407. package/.next/standalone/packages/explorer/.next/static/chunks/2183.e16e93357fae4297.js +0 -1
  408. package/.next/standalone/packages/explorer/.next/static/chunks/243.119694114da3b6c4.js +0 -1
  409. package/.next/standalone/packages/explorer/.next/static/chunks/306.eb870a2723132ed9.js +0 -1
  410. package/.next/standalone/packages/explorer/.next/static/chunks/3202.4b45589defcb7f3a.js +0 -1
  411. package/.next/standalone/packages/explorer/.next/static/chunks/3363.07dee13e704f2fcf.js +0 -1
  412. package/.next/standalone/packages/explorer/.next/static/chunks/376.42a841187481f559.js +0 -1
  413. package/.next/standalone/packages/explorer/.next/static/chunks/414.26a6b0020f280494.js +0 -1
  414. package/.next/standalone/packages/explorer/.next/static/chunks/4444.757b905ce68f8be3.js +0 -1
  415. package/.next/standalone/packages/explorer/.next/static/chunks/4619.0aedd2ffb8afca7b.js +0 -1
  416. package/.next/standalone/packages/explorer/.next/static/chunks/4766.04aee6e0a78b1243.js +0 -1
  417. package/.next/standalone/packages/explorer/.next/static/chunks/5079.658668eb58c3c044.js +0 -1
  418. package/.next/standalone/packages/explorer/.next/static/chunks/5102.6dfa06b0bb83bd63.js +0 -1
  419. package/.next/standalone/packages/explorer/.next/static/chunks/5252.c1a080b133c70898.js +0 -1
  420. package/.next/standalone/packages/explorer/.next/static/chunks/5331df31-4f64f325f8f52a23.js +0 -1
  421. package/.next/standalone/packages/explorer/.next/static/chunks/5359.81469991b1536197.js +0 -1
  422. package/.next/standalone/packages/explorer/.next/static/chunks/5543.56c9c3f1bb929fbb.js +0 -1
  423. package/.next/standalone/packages/explorer/.next/static/chunks/5727.6aa4fc93d3091a6b.js +0 -1
  424. package/.next/standalone/packages/explorer/.next/static/chunks/5766.64973290309fba89.js +0 -1
  425. package/.next/standalone/packages/explorer/.next/static/chunks/578.594ae424a461a87e.js +0 -1
  426. package/.next/standalone/packages/explorer/.next/static/chunks/6092.9dd9e53ea38177de.js +0 -1
  427. package/.next/standalone/packages/explorer/.next/static/chunks/6475.a124aea718607be6.js +0 -1
  428. package/.next/standalone/packages/explorer/.next/static/chunks/6634.cd960e0a9e70346a.js +0 -1
  429. package/.next/standalone/packages/explorer/.next/static/chunks/6663.eec50c91854cb7c6.js +0 -1
  430. package/.next/standalone/packages/explorer/.next/static/chunks/6739.31a964015298983d.js +0 -1
  431. package/.next/standalone/packages/explorer/.next/static/chunks/7000.17938ee73690f931.js +0 -1
  432. package/.next/standalone/packages/explorer/.next/static/chunks/758.677d52c3cb5c5058.js +0 -1
  433. package/.next/standalone/packages/explorer/.next/static/chunks/7794.8949721bc0d95dbd.js +0 -1
  434. package/.next/standalone/packages/explorer/.next/static/chunks/8259.9b671bf6066db1cf.js +0 -1
  435. package/.next/standalone/packages/explorer/.next/static/chunks/8414.ba8b7284e28b4dc1.js +0 -1
  436. package/.next/standalone/packages/explorer/.next/static/chunks/8523.51b7a35240f2d457.js +0 -1
  437. package/.next/standalone/packages/explorer/.next/static/chunks/8714.f57f519ef0898d1f.js +0 -1
  438. package/.next/standalone/packages/explorer/.next/static/chunks/887.c380d2cea46374d9.js +0 -1
  439. package/.next/standalone/packages/explorer/.next/static/chunks/906.bc43921730a003e8.js +0 -1
  440. package/.next/standalone/packages/explorer/.next/static/chunks/9258-4e8adbfd1e18bda9.js +0 -32
  441. package/.next/standalone/packages/explorer/.next/static/chunks/995-1b52a5c157d10137.js +0 -1
  442. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/interact/page-d921d3e409207a76.js +0 -1
  443. package/.next/standalone/packages/explorer/.next/static/chunks/app/(explorer)/[chainName]/worlds/[worldAddress]/layout-012917f72f09d2c5.js +0 -1
  444. package/.next/standalone/packages/explorer/.next/static/chunks/webpack-bb847e7f171dfc4d.js +0 -1
  445. /package/.next/standalone/packages/explorer/.next/static/{hqRSXHtK-RogH3rI3ZaE- → 3nWDfqoSPUgB3QCaiOmWH}/_buildManifest.js +0 -0
  446. /package/.next/standalone/packages/explorer/.next/static/{hqRSXHtK-RogH3rI3ZaE- → 3nWDfqoSPUgB3QCaiOmWH}/_ssgManifest.js +0 -0
@@ -1,14 +1,14 @@
1
- exports.id=327,exports.ids=[327],exports.modules={50691:(e,t,r)=>{"use strict";r.d(t,{Z:()=>ln});var i=r(82361),s=r.n(i),n=r(98563),a=r(42253),o=r(41434),c=r(36627),l=Object.defineProperty,h=(e,t,r)=>t in e?l(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,d=(e,t,r)=>h(e,"symbol"!=typeof t?t+"":t,r);class u extends c.q{constructor(e){super(),this.opts=e,d(this,"protocol","wc"),d(this,"version",2)}}var p=Object.defineProperty,g=(e,t,r)=>t in e?p(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,f=(e,t,r)=>g(e,"symbol"!=typeof t?t+"":t,r);class m extends c.q{constructor(e,t){super(),this.core=e,this.logger=t,f(this,"records",new Map)}}class w{constructor(e,t){this.logger=e,this.core=t}}class y extends c.q{constructor(e,t){super(),this.relayer=e,this.logger=t}}class b extends c.q{constructor(e){super()}}class v{constructor(e,t,r,i){this.core=e,this.logger=t,this.name=r}}class C extends c.q{constructor(e,t){super(),this.relayer=e,this.logger=t}}class E extends c.q{constructor(e,t){super(),this.core=e,this.logger=t}}class N{constructor(e,t,r){this.core=e,this.logger=t,this.store=r}}class I{constructor(e,t){this.projectId=e,this.logger=t}}class A{constructor(e,t,r){this.core=e,this.logger=t,this.telemetryEnabled=r}}var _=Object.defineProperty,S=(e,t,r)=>t in e?_(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,O=(e,t,r)=>S(e,"symbol"!=typeof t?t+"":t,r);class P{constructor(e){this.opts=e,O(this,"protocol","wc"),O(this,"version",2)}}class T{constructor(e){this.client=e}}var R=r(39064),k=r(60143),x=r(97952),U=r(274),D=r(74892),$=r(65731),M=r(68779),L=r(48787),j=r(34345),q=r(23577);function B(e){let[t,r]=e.split(":");return{namespace:t,reference:r}}function F(e,t){return e.includes(":")?[e]:t.chains||[]}var H=Object.defineProperty,W=Object.defineProperties,V=Object.getOwnPropertyDescriptors,z=Object.getOwnPropertySymbols,K=Object.prototype.hasOwnProperty,J=Object.prototype.propertyIsEnumerable,G=(e,t,r)=>t in e?H(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,Y=(e,t)=>{for(var r in t||(t={}))K.call(t,r)&&G(e,r,t[r]);if(z)for(var r of z(t))J.call(t,r)&&G(e,r,t[r]);return e},X=(e,t)=>W(e,V(t));let Z={reactNative:"react-native",node:"node",browser:"browser",unknown:"unknown"};function Q(){return"u">typeof process&&"u">typeof process.versions&&"u">typeof process.versions.node}function ee(){return!(0,D.getDocument)()&&!!(0,D.getNavigator)()&&"ReactNative"===navigator.product}function et(){return!Q()&&!!(0,D.getNavigator)()&&!!(0,D.getDocument)()}function er(){return ee()?Z.reactNative:Q()?Z.node:et()?Z.browser:Z.unknown}function ei(){var e;try{return ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Application)?null==(e=global.Application)?void 0:e.applicationId:void 0}catch{return}}function es(){return(0,$.D)()||{name:"",description:"",url:"",icons:[""]}}function en(e,t,r){let i=function(){if(er()===Z.reactNative&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)){let{OS:e,Version:t}=global.Platform;return[e,t].join("-")}let e=(0,U.qY)();if(null===e)return"unknown";let t=e.os?e.os.replace(" ","").toLowerCase():"unknown";return"browser"===e.type?[t,e.name,e.version].join("-"):[t,e.version].join("-")}(),s=function(){var e;let t=er();return t===Z.browser?[t,(null==(e=(0,D.getLocation)())?void 0:e.host)||"unknown"].join(":"):t}();return[[e,t].join("-"),["js",r].join("-"),i,s].join("/")}function ea(e,t){return e.filter(e=>t.includes(e)).length===e.length}function eo(e){return Object.fromEntries(e.entries())}function ec(e){return new Map(Object.entries(e))}function el(e=R.FIVE_MINUTES,t){let r,i,s,n;let a=(0,R.toMiliseconds)(e||R.FIVE_MINUTES);return{resolve:e=>{s&&r&&(clearTimeout(s),r(e),n=Promise.resolve(e))},reject:e=>{s&&i&&(clearTimeout(s),i(e))},done:()=>new Promise((e,o)=>{if(n)return e(n);s=setTimeout(()=>{let e=Error(t);n=Promise.reject(e),o(e)},a),r=e,i=o})}}function eh(e,t,r){return new Promise(async(i,s)=>{let n=setTimeout(()=>s(Error(r)),t);try{let t=await e;i(t)}catch(e){s(e)}clearTimeout(n)})}function ed(e,t){if("string"==typeof t&&t.startsWith(`${e}:`))return t;if("topic"===e.toLowerCase()){if("string"!=typeof t)throw Error('Value must be "string" for expirer target type: topic');return`topic:${t}`}if("id"===e.toLowerCase()){if("number"!=typeof t)throw Error('Value must be "number" for expirer target type: id');return`id:${t}`}throw Error(`Unknown expirer target type: ${e}`)}function eu(e){let[t,r]=e.split(":"),i={id:void 0,topic:void 0};if("topic"===t&&"string"==typeof r)i.topic=r;else if("id"===t&&Number.isInteger(Number(r)))i.id=Number(r);else throw Error(`Invalid target, expected id:number or topic:string, got ${t}:${r}`);return i}function ep(e,t){return(0,R.fromMiliseconds)((t||Date.now())+(0,R.toMiliseconds)(e))}function eg(e){return Date.now()>=(0,R.toMiliseconds)(e)}function ef(e,t){return`${e}${t?`:${t}`:""}`}function em(e=[],t=[]){return[...new Set([...e,...t])]}async function ew({id:e,topic:t,wcDeepLink:r}){var i;try{if(!r)return;let s="string"==typeof r?JSON.parse(r):r,n=s?.href;if("string"!=typeof n)return;let a=function(e,t,r){let i=`requestId=${t}&sessionTopic=${r}`;e.endsWith("/")&&(e=e.slice(0,-1));let s=`${e}`;if(e.startsWith("https://t.me")){let t=e.includes("?")?"&startapp=":"?startapp=";s=`${s}${t}${function(e,t=!1){let r=Buffer.from(e).toString("base64");return t?r.replace(/[=]/g,""):r}(i,!0)}`}else s=`${s}/wc?${i}`;return s}(n,e,t),o=er();if(o===Z.browser){let e;if(!(null!=(i=(0,D.getDocument)())&&i.hasFocus())){console.warn("Document does not have focus, skipping deeplink.");return}e="_self",function(){try{return window.self!==window.top}catch{return!1}}()?e="_top":("u">typeof window&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)||a.startsWith("https://")||a.startsWith("http://"))&&(e="_blank"),window.open(a,e,"noreferrer noopener")}else o===Z.reactNative&&"u">typeof(null==global?void 0:global.Linking)&&await global.Linking.openURL(a)}catch(e){console.error(e)}}async function ey(e,t){let r="";try{if(et()&&(r=localStorage.getItem(t)))return r;r=await e.getItem(t)}catch(e){console.error(e)}return r}function eb(e,t){if(!e.includes(t))return null;let r=e.split(/([&,?,=])/),i=r.indexOf(t);return r[i+2]}function ev(){return"u">typeof crypto&&null!=crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,e=>{let t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)})}function eC(){return"u">typeof process&&"true"===process.env.IS_VITEST}function eE(e){return Buffer.from(e,"base64").toString("utf-8")}function eN(e){if(!Number.isSafeInteger(e)||e<0)throw Error("positive integer expected, got "+e)}function eI(e,...t){if(!(e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name))throw Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw Error("Uint8Array expected of length "+t+", got length="+e.length)}function eA(e){if("function"!=typeof e||"function"!=typeof e.create)throw Error("Hash should be wrapped by utils.wrapConstructor");eN(e.outputLen),eN(e.blockLen)}function e_(e,t=!0){if(e.destroyed)throw Error("Hash instance has been destroyed");if(t&&e.finished)throw Error("Hash#digest() has already been called")}function eS(e,t){eI(e);let r=t.outputLen;if(e.length<r)throw Error("digestInto() expects output buffer of length at least "+r)}let eO=BigInt(4294967296-1),eP=BigInt(32),eT=(e,t,r)=>e<<r|t>>>32-r,eR=(e,t,r)=>t<<r|e>>>32-r,ek=(e,t,r)=>t<<r-32|e>>>64-r,ex=(e,t,r)=>e<<r-32|t>>>64-r,eU="object"==typeof globalThis&&"crypto"in globalThis?globalThis.crypto:void 0;function eD(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function e$(e,t){return e<<32-t|e>>>t}let eM=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];function eL(e){for(let r=0;r<e.length;r++){var t;e[r]=(t=e[r])<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}}function ej(e){return"string"==typeof e&&(e=function(e){if("string"!=typeof e)throw Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array(new TextEncoder().encode(e))}(e)),eI(e),e}class eq{clone(){return this._cloneInto()}}function eB(e){let t=t=>e().update(ej(t)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function eF(e=32){if(eU&&"function"==typeof eU.getRandomValues)return eU.getRandomValues(new Uint8Array(e));if(eU&&"function"==typeof eU.randomBytes)return eU.randomBytes(e);throw Error("crypto.getRandomValues must be defined")}let eH=[],eW=[],eV=[],ez=BigInt(0),eK=BigInt(1),eJ=BigInt(2),eG=BigInt(7),eY=BigInt(256),eX=BigInt(113);for(let e=0,t=eK,r=1,i=0;e<24;e++){[r,i]=[i,(2*r+3*i)%5],eH.push(2*(5*i+r)),eW.push((e+1)*(e+2)/2%64);let s=ez;for(let e=0;e<7;e++)(t=(t<<eK^(t>>eG)*eX)%eY)&eJ&&(s^=eK<<(eK<<BigInt(e))-eK);eV.push(s)}let[eZ,eQ]=function(e,t=!1){let r=new Uint32Array(e.length),i=new Uint32Array(e.length);for(let s=0;s<e.length;s++){let{h:n,l:a}=function(e,t=!1){return t?{h:Number(e&eO),l:Number(e>>eP&eO)}:{h:0|Number(e>>eP&eO),l:0|Number(e&eO)}}(e[s],t);[r[s],i[s]]=[n,a]}return[r,i]}(eV,!0),e0=(e,t,r)=>r>32?ek(e,t,r):eT(e,t,r),e1=(e,t,r)=>r>32?ex(e,t,r):eR(e,t,r);class e2 extends eq{constructor(e,t,r,i=!1,s=24){if(super(),this.blockLen=e,this.suffix=t,this.outputLen=r,this.enableXOF=i,this.rounds=s,this.pos=0,this.posOut=0,this.finished=!1,this.destroyed=!1,eN(r),0>=this.blockLen||this.blockLen>=200)throw Error("Sha3 supports only keccak-f1600 function");this.state=new Uint8Array(200),this.state32=function(e){return new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4))}(this.state)}keccak(){eM||eL(this.state32),function(e,t=24){let r=new Uint32Array(10);for(let i=24-t;i<24;i++){for(let t=0;t<10;t++)r[t]=e[t]^e[t+10]^e[t+20]^e[t+30]^e[t+40];for(let t=0;t<10;t+=2){let i=(t+8)%10,s=(t+2)%10,n=r[s],a=r[s+1],o=e0(n,a,1)^r[i],c=e1(n,a,1)^r[i+1];for(let r=0;r<50;r+=10)e[t+r]^=o,e[t+r+1]^=c}let t=e[2],s=e[3];for(let r=0;r<24;r++){let i=eW[r],n=e0(t,s,i),a=e1(t,s,i),o=eH[r];t=e[o],s=e[o+1],e[o]=n,e[o+1]=a}for(let t=0;t<50;t+=10){for(let i=0;i<10;i++)r[i]=e[t+i];for(let i=0;i<10;i++)e[t+i]^=~r[(i+2)%10]&r[(i+4)%10]}e[0]^=eZ[i],e[1]^=eQ[i]}r.fill(0)}(this.state32,this.rounds),eM||eL(this.state32),this.posOut=0,this.pos=0}update(e){e_(this);let{blockLen:t,state:r}=this,i=(e=ej(e)).length;for(let s=0;s<i;){let n=Math.min(t-this.pos,i-s);for(let t=0;t<n;t++)r[this.pos++]^=e[s++];this.pos===t&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;let{state:e,suffix:t,pos:r,blockLen:i}=this;e[r]^=t,(128&t)!=0&&r===i-1&&this.keccak(),e[i-1]^=128,this.keccak()}writeInto(e){e_(this,!1),eI(e),this.finish();let t=this.state,{blockLen:r}=this;for(let i=0,s=e.length;i<s;){this.posOut>=r&&this.keccak();let n=Math.min(r-this.posOut,s-i);e.set(t.subarray(this.posOut,this.posOut+n),i),this.posOut+=n,i+=n}return e}xofInto(e){if(!this.enableXOF)throw Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return eN(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(eS(e,this),this.finished)throw Error("digest() was already called");return this.writeInto(e),this.destroy(),e}digest(){return this.digestInto(new Uint8Array(this.outputLen))}destroy(){this.destroyed=!0,this.state.fill(0)}_cloneInto(e){let{blockLen:t,suffix:r,outputLen:i,rounds:s,enableXOF:n}=this;return e||(e=new e2(t,r,i,n,s)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=s,e.suffix=r,e.outputLen=i,e.enableXOF=n,e.destroyed=this.destroyed,e}}let e5=eB(()=>new e2(136,1,32));function e3(e){let t=`Ethereum Signed Message:
2
- ${e.length}`,r=new TextEncoder().encode(t+e);return"0x"+Buffer.from(e5(r)).toString("hex")}async function e4(e,t,r,i,s,n){switch(r.t){case"eip191":return await e8(e,t,r.s);case"eip1271":return await e6(e,t,r.s,i,s,n);default:throw Error(`verifySignature failed: Attempted to verify CacaoSignature with unknown type: ${r.t}`)}}async function e8(e,t,r){return(await (0,M.R)({hash:e3(t),signature:r})).toLowerCase()===e.toLowerCase()}async function e6(e,t,r,i,s,n){let a=B(i);if(!a.namespace||!a.reference)throw Error(`isValidEip1271Signature failed: chainId must be in CAIP-2 format, received: ${i}`);try{let a="0x1626ba7e",o=r.substring(2),c=e3(t).substring(2),l=await fetch(`${n||"https://rpc.walletconnect.org/v1"}/?chainId=${i}&projectId=${s}`,{method:"POST",body:JSON.stringify({id:Date.now()+Math.floor(1e3*Math.random()),jsonrpc:"2.0",method:"eth_call",params:[{to:e,data:a+c+"00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000041"+o},"latest"]})}),{result:h}=await l.json();return!!h&&h.slice(0,a.length).toLowerCase()===a.toLowerCase()}catch(e){return console.error("isValidEip1271Signature: ",e),!1}}var e9=Object.defineProperty,e7=Object.defineProperties,te=Object.getOwnPropertyDescriptors,tt=Object.getOwnPropertySymbols,tr=Object.prototype.hasOwnProperty,ti=Object.prototype.propertyIsEnumerable,ts=(e,t,r)=>t in e?e9(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,tn=(e,t)=>{for(var r in t||(t={}))tr.call(t,r)&&ts(e,r,t[r]);if(tt)for(var r of tt(t))ti.call(t,r)&&ts(e,r,t[r]);return e},ta=(e,t)=>e7(e,te(t));let to=e=>e?.split(":"),tc=e=>{let t=e&&to(e);if(t)return e.includes("did:pkh:")?t[3]:t[1]},tl=e=>{let t=e&&to(e);if(t)return t[2]+":"+t[3]},th=e=>{let t=e&&to(e);if(t)return t.pop()};async function td(e){let{cacao:t,projectId:r}=e,{s:i,p:s}=t,n=tu(s,s.iss),a=th(s.iss);return await e4(a,n,i,tl(s.iss),r)}let tu=(e,t)=>{let r=`${e.domain} wants you to sign in with your Ethereum account:`,i=th(t);if(!e.aud&&!e.uri)throw Error("Either `aud` or `uri` is required to construct the message");let s=e.statement||void 0,n=`URI: ${e.aud||e.uri}`,a=`Version: ${e.version}`,o=`Chain ID: ${tc(t)}`,c=`Nonce: ${e.nonce}`,l=`Issued At: ${e.iat}`,h=e.exp?`Expiration Time: ${e.exp}`:void 0,d=e.nbf?`Not Before: ${e.nbf}`:void 0,u=e.requestId?`Request ID: ${e.requestId}`:void 0,p=e.resources?`Resources:${e.resources.map(e=>`
1
+ exports.id=1209,exports.ids=[1209],exports.modules={50691:(e,t,r)=>{"use strict";r.d(t,{Z:()=>ln});var i=r(82361),s=r.n(i),n=r(98563),a=r(42253),o=r(41434),c=r(36627),l=Object.defineProperty,h=(e,t,r)=>t in e?l(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,d=(e,t,r)=>h(e,"symbol"!=typeof t?t+"":t,r);class u extends c.q{constructor(e){super(),this.opts=e,d(this,"protocol","wc"),d(this,"version",2)}}var p=Object.defineProperty,g=(e,t,r)=>t in e?p(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,f=(e,t,r)=>g(e,"symbol"!=typeof t?t+"":t,r);class m extends c.q{constructor(e,t){super(),this.core=e,this.logger=t,f(this,"records",new Map)}}class w{constructor(e,t){this.logger=e,this.core=t}}class y extends c.q{constructor(e,t){super(),this.relayer=e,this.logger=t}}class b extends c.q{constructor(e){super()}}class v{constructor(e,t,r,i){this.core=e,this.logger=t,this.name=r}}class C extends c.q{constructor(e,t){super(),this.relayer=e,this.logger=t}}class E extends c.q{constructor(e,t){super(),this.core=e,this.logger=t}}class N{constructor(e,t,r){this.core=e,this.logger=t,this.store=r}}class I{constructor(e,t){this.projectId=e,this.logger=t}}class A{constructor(e,t,r){this.core=e,this.logger=t,this.telemetryEnabled=r}}var _=Object.defineProperty,S=(e,t,r)=>t in e?_(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,O=(e,t,r)=>S(e,"symbol"!=typeof t?t+"":t,r);class P{constructor(e){this.opts=e,O(this,"protocol","wc"),O(this,"version",2)}}class T{constructor(e){this.client=e}}var R=r(39064),k=r(60143),x=r(97952),U=r(274),D=r(74892),$=r(65731),M=r(68779),L=r(48787),j=r(34345),q=r(23577);function B(e){let[t,r]=e.split(":");return{namespace:t,reference:r}}function F(e,t){return e.includes(":")?[e]:t.chains||[]}var H=Object.defineProperty,W=Object.defineProperties,V=Object.getOwnPropertyDescriptors,z=Object.getOwnPropertySymbols,K=Object.prototype.hasOwnProperty,J=Object.prototype.propertyIsEnumerable,G=(e,t,r)=>t in e?H(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,Y=(e,t)=>{for(var r in t||(t={}))K.call(t,r)&&G(e,r,t[r]);if(z)for(var r of z(t))J.call(t,r)&&G(e,r,t[r]);return e},X=(e,t)=>W(e,V(t));let Z={reactNative:"react-native",node:"node",browser:"browser",unknown:"unknown"};function Q(){return"u">typeof process&&"u">typeof process.versions&&"u">typeof process.versions.node}function ee(){return!(0,D.getDocument)()&&!!(0,D.getNavigator)()&&"ReactNative"===navigator.product}function et(){return!Q()&&!!(0,D.getNavigator)()&&!!(0,D.getDocument)()}function er(){return ee()?Z.reactNative:Q()?Z.node:et()?Z.browser:Z.unknown}function ei(){var e;try{return ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Application)?null==(e=global.Application)?void 0:e.applicationId:void 0}catch{return}}function es(){return(0,$.D)()||{name:"",description:"",url:"",icons:[""]}}function en(e,t,r){let i=function(){if(er()===Z.reactNative&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)){let{OS:e,Version:t}=global.Platform;return[e,t].join("-")}let e=(0,U.qY)();if(null===e)return"unknown";let t=e.os?e.os.replace(" ","").toLowerCase():"unknown";return"browser"===e.type?[t,e.name,e.version].join("-"):[t,e.version].join("-")}(),s=function(){var e;let t=er();return t===Z.browser?[t,(null==(e=(0,D.getLocation)())?void 0:e.host)||"unknown"].join(":"):t}();return[[e,t].join("-"),["js",r].join("-"),i,s].join("/")}function ea(e,t){return e.filter(e=>t.includes(e)).length===e.length}function eo(e){return Object.fromEntries(e.entries())}function ec(e){return new Map(Object.entries(e))}function el(e=R.FIVE_MINUTES,t){let r,i,s,n;let a=(0,R.toMiliseconds)(e||R.FIVE_MINUTES);return{resolve:e=>{s&&r&&(clearTimeout(s),r(e),n=Promise.resolve(e))},reject:e=>{s&&i&&(clearTimeout(s),i(e))},done:()=>new Promise((e,o)=>{if(n)return e(n);s=setTimeout(()=>{let e=Error(t);n=Promise.reject(e),o(e)},a),r=e,i=o})}}function eh(e,t,r){return new Promise(async(i,s)=>{let n=setTimeout(()=>s(Error(r)),t);try{let t=await e;i(t)}catch(e){s(e)}clearTimeout(n)})}function ed(e,t){if("string"==typeof t&&t.startsWith(`${e}:`))return t;if("topic"===e.toLowerCase()){if("string"!=typeof t)throw Error('Value must be "string" for expirer target type: topic');return`topic:${t}`}if("id"===e.toLowerCase()){if("number"!=typeof t)throw Error('Value must be "number" for expirer target type: id');return`id:${t}`}throw Error(`Unknown expirer target type: ${e}`)}function eu(e){let[t,r]=e.split(":"),i={id:void 0,topic:void 0};if("topic"===t&&"string"==typeof r)i.topic=r;else if("id"===t&&Number.isInteger(Number(r)))i.id=Number(r);else throw Error(`Invalid target, expected id:number or topic:string, got ${t}:${r}`);return i}function ep(e,t){return(0,R.fromMiliseconds)((t||Date.now())+(0,R.toMiliseconds)(e))}function eg(e){return Date.now()>=(0,R.toMiliseconds)(e)}function ef(e,t){return`${e}${t?`:${t}`:""}`}function em(e=[],t=[]){return[...new Set([...e,...t])]}async function ew({id:e,topic:t,wcDeepLink:r}){var i;try{if(!r)return;let s="string"==typeof r?JSON.parse(r):r,n=s?.href;if("string"!=typeof n)return;let a=function(e,t,r){let i=`requestId=${t}&sessionTopic=${r}`;e.endsWith("/")&&(e=e.slice(0,-1));let s=`${e}`;if(e.startsWith("https://t.me")){let t=e.includes("?")?"&startapp=":"?startapp=";s=`${s}${t}${function(e,t=!1){let r=Buffer.from(e).toString("base64");return t?r.replace(/[=]/g,""):r}(i,!0)}`}else s=`${s}/wc?${i}`;return s}(n,e,t),o=er();if(o===Z.browser){let e;if(!(null!=(i=(0,D.getDocument)())&&i.hasFocus())){console.warn("Document does not have focus, skipping deeplink.");return}e="_self",function(){try{return window.self!==window.top}catch{return!1}}()?e="_top":("u">typeof window&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)||a.startsWith("https://")||a.startsWith("http://"))&&(e="_blank"),window.open(a,e,"noreferrer noopener")}else o===Z.reactNative&&"u">typeof(null==global?void 0:global.Linking)&&await global.Linking.openURL(a)}catch(e){console.error(e)}}async function ey(e,t){let r="";try{if(et()&&(r=localStorage.getItem(t)))return r;r=await e.getItem(t)}catch(e){console.error(e)}return r}function eb(e,t){if(!e.includes(t))return null;let r=e.split(/([&,?,=])/),i=r.indexOf(t);return r[i+2]}function ev(){return"u">typeof crypto&&null!=crypto&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,e=>{let t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)})}function eC(){return"u">typeof process&&"true"===process.env.IS_VITEST}function eE(e){return Buffer.from(e,"base64").toString("utf-8")}function eN(e){if(!Number.isSafeInteger(e)||e<0)throw Error("positive integer expected, got "+e)}function eI(e,...t){if(!(e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name))throw Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw Error("Uint8Array expected of length "+t+", got length="+e.length)}function eA(e){if("function"!=typeof e||"function"!=typeof e.create)throw Error("Hash should be wrapped by utils.wrapConstructor");eN(e.outputLen),eN(e.blockLen)}function e_(e,t=!0){if(e.destroyed)throw Error("Hash instance has been destroyed");if(t&&e.finished)throw Error("Hash#digest() has already been called")}function eS(e,t){eI(e);let r=t.outputLen;if(e.length<r)throw Error("digestInto() expects output buffer of length at least "+r)}let eO=BigInt(4294967296-1),eP=BigInt(32),eT=(e,t,r)=>e<<r|t>>>32-r,eR=(e,t,r)=>t<<r|e>>>32-r,ek=(e,t,r)=>t<<r-32|e>>>64-r,ex=(e,t,r)=>e<<r-32|t>>>64-r,eU="object"==typeof globalThis&&"crypto"in globalThis?globalThis.crypto:void 0;function eD(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function e$(e,t){return e<<32-t|e>>>t}let eM=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];function eL(e){for(let r=0;r<e.length;r++){var t;e[r]=(t=e[r])<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}}function ej(e){return"string"==typeof e&&(e=function(e){if("string"!=typeof e)throw Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array(new TextEncoder().encode(e))}(e)),eI(e),e}class eq{clone(){return this._cloneInto()}}function eB(e){let t=t=>e().update(ej(t)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function eF(e=32){if(eU&&"function"==typeof eU.getRandomValues)return eU.getRandomValues(new Uint8Array(e));if(eU&&"function"==typeof eU.randomBytes)return eU.randomBytes(e);throw Error("crypto.getRandomValues must be defined")}let eH=[],eW=[],eV=[],ez=BigInt(0),eK=BigInt(1),eJ=BigInt(2),eG=BigInt(7),eY=BigInt(256),eX=BigInt(113);for(let e=0,t=eK,r=1,i=0;e<24;e++){[r,i]=[i,(2*r+3*i)%5],eH.push(2*(5*i+r)),eW.push((e+1)*(e+2)/2%64);let s=ez;for(let e=0;e<7;e++)(t=(t<<eK^(t>>eG)*eX)%eY)&eJ&&(s^=eK<<(eK<<BigInt(e))-eK);eV.push(s)}let[eZ,eQ]=function(e,t=!1){let r=new Uint32Array(e.length),i=new Uint32Array(e.length);for(let s=0;s<e.length;s++){let{h:n,l:a}=function(e,t=!1){return t?{h:Number(e&eO),l:Number(e>>eP&eO)}:{h:0|Number(e>>eP&eO),l:0|Number(e&eO)}}(e[s],t);[r[s],i[s]]=[n,a]}return[r,i]}(eV,!0),e0=(e,t,r)=>r>32?ek(e,t,r):eT(e,t,r),e1=(e,t,r)=>r>32?ex(e,t,r):eR(e,t,r);class e2 extends eq{constructor(e,t,r,i=!1,s=24){if(super(),this.blockLen=e,this.suffix=t,this.outputLen=r,this.enableXOF=i,this.rounds=s,this.pos=0,this.posOut=0,this.finished=!1,this.destroyed=!1,eN(r),0>=this.blockLen||this.blockLen>=200)throw Error("Sha3 supports only keccak-f1600 function");this.state=new Uint8Array(200),this.state32=function(e){return new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4))}(this.state)}keccak(){eM||eL(this.state32),function(e,t=24){let r=new Uint32Array(10);for(let i=24-t;i<24;i++){for(let t=0;t<10;t++)r[t]=e[t]^e[t+10]^e[t+20]^e[t+30]^e[t+40];for(let t=0;t<10;t+=2){let i=(t+8)%10,s=(t+2)%10,n=r[s],a=r[s+1],o=e0(n,a,1)^r[i],c=e1(n,a,1)^r[i+1];for(let r=0;r<50;r+=10)e[t+r]^=o,e[t+r+1]^=c}let t=e[2],s=e[3];for(let r=0;r<24;r++){let i=eW[r],n=e0(t,s,i),a=e1(t,s,i),o=eH[r];t=e[o],s=e[o+1],e[o]=n,e[o+1]=a}for(let t=0;t<50;t+=10){for(let i=0;i<10;i++)r[i]=e[t+i];for(let i=0;i<10;i++)e[t+i]^=~r[(i+2)%10]&r[(i+4)%10]}e[0]^=eZ[i],e[1]^=eQ[i]}r.fill(0)}(this.state32,this.rounds),eM||eL(this.state32),this.posOut=0,this.pos=0}update(e){e_(this);let{blockLen:t,state:r}=this,i=(e=ej(e)).length;for(let s=0;s<i;){let n=Math.min(t-this.pos,i-s);for(let t=0;t<n;t++)r[this.pos++]^=e[s++];this.pos===t&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;let{state:e,suffix:t,pos:r,blockLen:i}=this;e[r]^=t,(128&t)!=0&&r===i-1&&this.keccak(),e[i-1]^=128,this.keccak()}writeInto(e){e_(this,!1),eI(e),this.finish();let t=this.state,{blockLen:r}=this;for(let i=0,s=e.length;i<s;){this.posOut>=r&&this.keccak();let n=Math.min(r-this.posOut,s-i);e.set(t.subarray(this.posOut,this.posOut+n),i),this.posOut+=n,i+=n}return e}xofInto(e){if(!this.enableXOF)throw Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return eN(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(eS(e,this),this.finished)throw Error("digest() was already called");return this.writeInto(e),this.destroy(),e}digest(){return this.digestInto(new Uint8Array(this.outputLen))}destroy(){this.destroyed=!0,this.state.fill(0)}_cloneInto(e){let{blockLen:t,suffix:r,outputLen:i,rounds:s,enableXOF:n}=this;return e||(e=new e2(t,r,i,n,s)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=s,e.suffix=r,e.outputLen=i,e.enableXOF=n,e.destroyed=this.destroyed,e}}let e5=eB(()=>new e2(136,1,32));function e3(e){let t=`Ethereum Signed Message:
2
+ ${e.length}`,r=new TextEncoder().encode(t+e);return"0x"+Buffer.from(e5(r)).toString("hex")}async function e8(e,t,r,i,s,n){switch(r.t){case"eip191":return await e4(e,t,r.s);case"eip1271":return await e6(e,t,r.s,i,s,n);default:throw Error(`verifySignature failed: Attempted to verify CacaoSignature with unknown type: ${r.t}`)}}async function e4(e,t,r){return(await (0,M.R)({hash:e3(t),signature:r})).toLowerCase()===e.toLowerCase()}async function e6(e,t,r,i,s,n){let a=B(i);if(!a.namespace||!a.reference)throw Error(`isValidEip1271Signature failed: chainId must be in CAIP-2 format, received: ${i}`);try{let a="0x1626ba7e",o=r.substring(2),c=e3(t).substring(2),l=await fetch(`${n||"https://rpc.walletconnect.org/v1"}/?chainId=${i}&projectId=${s}`,{method:"POST",body:JSON.stringify({id:Date.now()+Math.floor(1e3*Math.random()),jsonrpc:"2.0",method:"eth_call",params:[{to:e,data:a+c+"00000000000000000000000000000000000000000000000000000000000000400000000000000000000000000000000000000000000000000000000000000041"+o},"latest"]})}),{result:h}=await l.json();return!!h&&h.slice(0,a.length).toLowerCase()===a.toLowerCase()}catch(e){return console.error("isValidEip1271Signature: ",e),!1}}var e9=Object.defineProperty,e7=Object.defineProperties,te=Object.getOwnPropertyDescriptors,tt=Object.getOwnPropertySymbols,tr=Object.prototype.hasOwnProperty,ti=Object.prototype.propertyIsEnumerable,ts=(e,t,r)=>t in e?e9(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,tn=(e,t)=>{for(var r in t||(t={}))tr.call(t,r)&&ts(e,r,t[r]);if(tt)for(var r of tt(t))ti.call(t,r)&&ts(e,r,t[r]);return e},ta=(e,t)=>e7(e,te(t));let to=e=>e?.split(":"),tc=e=>{let t=e&&to(e);if(t)return e.includes("did:pkh:")?t[3]:t[1]},tl=e=>{let t=e&&to(e);if(t)return t[2]+":"+t[3]},th=e=>{let t=e&&to(e);if(t)return t.pop()};async function td(e){let{cacao:t,projectId:r}=e,{s:i,p:s}=t,n=tu(s,s.iss),a=th(s.iss);return await e8(a,n,i,tl(s.iss),r)}let tu=(e,t)=>{let r=`${e.domain} wants you to sign in with your Ethereum account:`,i=th(t);if(!e.aud&&!e.uri)throw Error("Either `aud` or `uri` is required to construct the message");let s=e.statement||void 0,n=`URI: ${e.aud||e.uri}`,a=`Version: ${e.version}`,o=`Chain ID: ${tc(t)}`,c=`Nonce: ${e.nonce}`,l=`Issued At: ${e.iat}`,h=e.exp?`Expiration Time: ${e.exp}`:void 0,d=e.nbf?`Not Before: ${e.nbf}`:void 0,u=e.requestId?`Request ID: ${e.requestId}`:void 0,p=e.resources?`Resources:${e.resources.map(e=>`
3
3
  - ${e}`).join("")}`:void 0,g=ty(e.resources);return g&&(s=function(e="",t){tp(t);let r="I further authorize the stated URI to perform the following actions on my behalf: ";if(e.includes(r))return e;let i=[],s=0;Object.keys(t.att).forEach(e=>{let r=Object.keys(t.att[e]).map(e=>({ability:e.split("/")[0],action:e.split("/")[1]}));r.sort((e,t)=>e.action.localeCompare(t.action));let n={};r.forEach(e=>{n[e.ability]||(n[e.ability]=[]),n[e.ability].push(e.action)});let a=Object.keys(n).map(t=>(s++,`(${s}) '${t}': '${n[t].join("', '")}' for '${e}'.`));i.push(a.join(", ").replace(".,","."))});let n=i.join(" "),a=`${r}${n}`;return`${e?e+" ":""}${a}`}(s,tf(g))),[r,i,"",s,"",n,a,o,c,l,h,d,u,p].filter(e=>null!=e).join(`
4
- `)};function tp(e){if(!e)throw Error("No recap provided, value is undefined");if(!e.att)throw Error("No `att` property found");let t=Object.keys(e.att);if(!(null!=t&&t.length))throw Error("No resources found in `att` property");t.forEach(t=>{let r=e.att[t];if(Array.isArray(r)||"object"!=typeof r)throw Error(`Resource must be an object: ${t}`);if(!Object.keys(r).length)throw Error(`Resource object is empty: ${t}`);Object.keys(r).forEach(e=>{let t=r[e];if(!Array.isArray(t))throw Error(`Ability limits ${e} must be an array of objects, found: ${t}`);if(!t.length)throw Error(`Value of ${e} is empty array, must be an array with objects`);t.forEach(t=>{if("object"!=typeof t)throw Error(`Ability limits (${e}) must be an array of objects, found: ${t}`)})})})}function tg(e){return tp(e),`urn:recap:${Buffer.from(JSON.stringify(e)).toString("base64").replace(/=/g,"")}`}function tf(e){var t;let r=(t=e.replace("urn:recap:",""),JSON.parse(Buffer.from(t,"base64").toString("utf-8")));return tp(r),r}function tm(e){var t;let r=tf(e);tp(r);let i=null==(t=r.att)?void 0:t.eip155;return i?Object.keys(i).map(e=>e.split("/")[1]):[]}function tw(e){let t=tf(e);tp(t);let r=[];return Object.values(t.att).forEach(e=>{Object.values(e).forEach(e=>{var t;null!=(t=e?.[0])&&t.chains&&r.push(e[0].chains)})}),[...new Set(r.flat())]}function ty(e){if(!e)return;let t=e?.[e.length-1];return t&&t.includes("urn:recap:")?t:void 0}function tb(e){if(!Number.isSafeInteger(e)||e<0)throw Error("positive integer expected, got "+e)}function tv(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name}function tC(e,...t){if(!tv(e))throw Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw Error("Uint8Array expected of length "+t+", got length="+e.length)}function tE(e,t=!0){if(e.destroyed)throw Error("Hash instance has been destroyed");if(t&&e.finished)throw Error("Hash#digest() has already been called")}function tN(e){if("boolean"!=typeof e)throw Error(`boolean expected, not ${e}`)}let tI=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),tA=e=>new DataView(e.buffer,e.byteOffset,e.byteLength);if(68!==new Uint8Array(new Uint32Array([287454020]).buffer)[0])throw Error("Non little-endian hardware is not supported");function t_(e){if("string"==typeof e)e=function(e){if("string"!=typeof e)throw Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}(e);else if(tv(e))e=tP(e);else throw Error("Uint8Array expected, got "+typeof e);return e}function tS(e,t,r=!0){if(void 0===t)return new Uint8Array(e);if(t.length!==e)throw Error("invalid output length, expected "+e+", got: "+t.length);if(r&&t.byteOffset%4!=0)throw Error("invalid output, must be aligned");return t}function tO(e,t,r,i){if("function"==typeof e.setBigUint64)return e.setBigUint64(t,r,i);let s=BigInt(32),n=BigInt(4294967295),a=Number(r>>s&n),o=Number(r&n),c=i?4:0,l=i?0:4;e.setUint32(t+c,a,i),e.setUint32(t+l,o,i)}function tP(e){return Uint8Array.from(e)}function tT(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}let tR=e=>Uint8Array.from(e.split("").map(e=>e.charCodeAt(0))),tk=tR("expand 16-byte k"),tx=tR("expand 32-byte k"),tU=tI(tk),tD=tI(tx);function t$(e,t){return e<<t|e>>>32-t}function tM(e){return e.byteOffset%4==0}let tL=4294967296-1,tj=new Uint32Array,tq=(e,t)=>255&e[t++]|(255&e[t++])<<8;class tB{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,tC(e=t_(e),32);let t=tq(e,0),r=tq(e,2),i=tq(e,4),s=tq(e,6),n=tq(e,8),a=tq(e,10),o=tq(e,12),c=tq(e,14);this.r[0]=8191&t,this.r[1]=(t>>>13|r<<3)&8191,this.r[2]=(r>>>10|i<<6)&7939,this.r[3]=(i>>>7|s<<9)&8191,this.r[4]=(s>>>4|n<<12)&255,this.r[5]=n>>>1&8190,this.r[6]=(n>>>14|a<<2)&8191,this.r[7]=(a>>>11|o<<5)&8065,this.r[8]=(o>>>8|c<<8)&8191,this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=tq(e,16+2*t)}process(e,t,r=!1){let{h:i,r:s}=this,n=s[0],a=s[1],o=s[2],c=s[3],l=s[4],h=s[5],d=s[6],u=s[7],p=s[8],g=s[9],f=tq(e,t+0),m=tq(e,t+2),w=tq(e,t+4),y=tq(e,t+6),b=tq(e,t+8),v=tq(e,t+10),C=tq(e,t+12),E=tq(e,t+14),N=i[0]+(8191&f),I=i[1]+((f>>>13|m<<3)&8191),A=i[2]+((m>>>10|w<<6)&8191),_=i[3]+((w>>>7|y<<9)&8191),S=i[4]+((y>>>4|b<<12)&8191),O=i[5]+(b>>>1&8191),P=i[6]+((b>>>14|v<<2)&8191),T=i[7]+((v>>>11|C<<5)&8191),R=i[8]+((C>>>8|E<<8)&8191),k=i[9]+(E>>>5|(r?0:2048)),x=0,U=0+N*n+5*g*I+5*p*A+5*u*_+5*d*S;x=U>>>13,U&=8191,U+=5*h*O+5*l*P+5*c*T+5*o*R+5*a*k,x+=U>>>13,U&=8191;let D=x+N*a+I*n+5*g*A+5*p*_+5*u*S;x=D>>>13,D&=8191,D+=5*d*O+5*h*P+5*l*T+5*c*R+5*o*k,x+=D>>>13,D&=8191;let $=x+N*o+I*a+A*n+5*g*_+5*p*S;x=$>>>13,$&=8191,$+=5*u*O+5*d*P+5*h*T+5*l*R+5*c*k,x+=$>>>13,$&=8191;let M=x+N*c+I*o+A*a+_*n+5*g*S;x=M>>>13,M&=8191,M+=5*p*O+5*u*P+5*d*T+5*h*R+5*l*k,x+=M>>>13,M&=8191;let L=x+N*l+I*c+A*o+_*a+S*n;x=L>>>13,L&=8191,L+=5*g*O+5*p*P+5*u*T+5*d*R+5*h*k,x+=L>>>13,L&=8191;let j=x+N*h+I*l+A*c+_*o+S*a;x=j>>>13,j&=8191,j+=O*n+5*g*P+5*p*T+5*u*R+5*d*k,x+=j>>>13,j&=8191;let q=x+N*d+I*h+A*l+_*c+S*o;x=q>>>13,q&=8191,q+=O*a+P*n+5*g*T+5*p*R+5*u*k,x+=q>>>13,q&=8191;let B=x+N*u+I*d+A*h+_*l+S*c;x=B>>>13,B&=8191,B+=O*o+P*a+T*n+5*g*R+5*p*k,x+=B>>>13,B&=8191;let F=x+N*p+I*u+A*d+_*h+S*l;x=F>>>13,F&=8191,F+=O*c+P*o+T*a+R*n+5*g*k,x+=F>>>13,F&=8191;let H=x+N*g+I*p+A*u+_*d+S*h;x=H>>>13,H&=8191,H+=O*l+P*c+T*o+R*a+k*n,x+=H>>>13,H&=8191,U=8191&(x=(x=(x<<2)+x|0)+U|0),x>>>=13,D+=x,i[0]=U,i[1]=D,i[2]=$,i[3]=M,i[4]=L,i[5]=j,i[6]=q,i[7]=B,i[8]=F,i[9]=H}finalize(){let{h:e,pad:t}=this,r=new Uint16Array(10),i=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=i,i=e[t]>>>13,e[t]&=8191;e[0]+=5*i,i=e[0]>>>13,e[0]&=8191,e[1]+=i,i=e[1]>>>13,e[1]&=8191,e[2]+=i,r[0]=e[0]+5,i=r[0]>>>13,r[0]&=8191;for(let t=1;t<10;t++)r[t]=e[t]+i,i=r[t]>>>13,r[t]&=8191;r[9]-=8192;let s=(1^i)-1;for(let e=0;e<10;e++)r[e]&=s;s=~s;for(let t=0;t<10;t++)e[t]=e[t]&s|r[t];e[0]=(e[0]|e[1]<<13)&65535,e[1]=(e[1]>>>3|e[2]<<10)&65535,e[2]=(e[2]>>>6|e[3]<<7)&65535,e[3]=(e[3]>>>9|e[4]<<4)&65535,e[4]=(e[4]>>>12|e[5]<<1|e[6]<<14)&65535,e[5]=(e[6]>>>2|e[7]<<11)&65535,e[6]=(e[7]>>>5|e[8]<<8)&65535,e[7]=(e[8]>>>8|e[9]<<5)&65535;let n=e[0]+t[0];e[0]=65535&n;for(let r=1;r<8;r++)n=(e[r]+t[r]|0)+(n>>>16)|0,e[r]=65535&n;tT(r)}update(e){tE(this);let{buffer:t,blockLen:r}=this,i=(e=t_(e)).length;for(let s=0;s<i;){let n=Math.min(r-this.pos,i-s);if(n===r){for(;r<=i-s;s+=r)this.process(e,s);continue}t.set(e.subarray(s,s+n),this.pos),this.pos+=n,s+=n,this.pos===r&&(this.process(t,0,!1),this.pos=0)}return this}destroy(){tT(this.h,this.r,this.buffer,this.pad)}digestInto(e){tE(this),function(e,t){tC(e);let r=t.outputLen;if(e.length<r)throw Error("digestInto() expects output buffer of length at least "+r)}(e,this),this.finished=!0;let{buffer:t,h:r}=this,{pos:i}=this;if(i){for(t[i++]=1;i<16;i++)t[i]=0;this.process(t,0,!0)}this.finalize();let s=0;for(let t=0;t<8;t++)e[s++]=r[t]>>>0,e[s++]=r[t]>>>8;return e}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}}let tF=function(e){let t=(t,r)=>e(r).update(t_(t)).digest(),r=e(new Uint8Array(32));return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=t=>e(t),t}(e=>new tB(e)),tH=function(e,t){let{allowShortKeys:r,extendNonceFn:i,counterLength:s,counterRight:n,rounds:a}=function(e,t){if(null==t||"object"!=typeof t)throw Error("options must be defined");return Object.assign(e,t)}({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if("function"!=typeof e)throw Error("core must be a function");return tb(s),tb(a),tN(n),tN(r),(t,o,c,l,h=0)=>{tC(t),tC(o),tC(c);let d=c.length;if(void 0===l&&(l=new Uint8Array(d)),tC(l),tb(h),h<0||h>=tL)throw Error("arx: counter overflow");if(l.length<d)throw Error(`arx: output (${l.length}) is shorter than data (${d})`);let u=[],p=t.length,g,f;if(32===p)u.push(g=tP(t)),f=tD;else if(16===p&&r)(g=new Uint8Array(32)).set(t),g.set(t,16),f=tU,u.push(g);else throw Error(`arx: invalid 32-byte key, got length=${p}`);tM(o)||u.push(o=tP(o));let m=tI(g);if(i){if(24!==o.length)throw Error("arx: extended nonce must be 24 bytes");i(f,m,tI(o.subarray(0,16)),m),o=o.subarray(16)}let w=16-s;if(w!==o.length)throw Error(`arx: nonce must be ${w} or 16 bytes`);if(12!==w){let e=new Uint8Array(12);e.set(o,n?0:12-o.length),o=e,u.push(o)}return function(e,t,r,i,s,n,a,o){let c=s.length,l=new Uint8Array(64),h=tI(l),d=tM(s)&&tM(n),u=d?tI(s):tj,p=d?tI(n):tj;for(let g=0;g<c;a++){if(e(t,r,i,h,a,o),a>=tL)throw Error("arx: counter overflow");let f=Math.min(64,c-g);if(d&&64===f){let e=g/4;if(g%4!=0)throw Error("arx: invalid block position");for(let t=0,r;t<16;t++)p[r=e+t]=u[r]^h[t];g+=64;continue}for(let e=0,t;e<f;e++)n[t=g+e]=s[t]^l[e];g+=f}}(e,f,m,tI(o),c,l,h,a),tT(...u),l}}(function(e,t,r,i,s,n=20){let a=e[0],o=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],p=t[3],g=t[4],f=t[5],m=t[6],w=t[7],y=r[0],b=r[1],v=r[2],C=a,E=o,N=c,I=l,A=h,_=d,S=u,O=p,P=g,T=f,R=m,k=w,x=s,U=y,D=b,$=v;for(let e=0;e<n;e+=2)P=P+(x=t$(x^(C=C+A|0),16))|0,C=C+(A=t$(A^P,12))|0,P=P+(x=t$(x^C,8))|0,A=t$(A^P,7),T=T+(U=t$(U^(E=E+_|0),16))|0,E=E+(_=t$(_^T,12))|0,T=T+(U=t$(U^E,8))|0,_=t$(_^T,7),R=R+(D=t$(D^(N=N+S|0),16))|0,N=N+(S=t$(S^R,12))|0,R=R+(D=t$(D^N,8))|0,S=t$(S^R,7),k=k+($=t$($^(I=I+O|0),16))|0,I=I+(O=t$(O^k,12))|0,k=k+($=t$($^I,8))|0,O=t$(O^k,7),R=R+($=t$($^(C=C+_|0),16))|0,C=C+(_=t$(_^R,12))|0,R=R+($=t$($^C,8))|0,_=t$(_^R,7),k=k+(x=t$(x^(E=E+S|0),16))|0,E=E+(S=t$(S^k,12))|0,k=k+(x=t$(x^E,8))|0,S=t$(S^k,7),P=P+(U=t$(U^(N=N+O|0),16))|0,N=N+(O=t$(O^P,12))|0,P=P+(U=t$(U^N,8))|0,O=t$(O^P,7),T=T+(D=t$(D^(I=I+A|0),16))|0,I=I+(A=t$(A^T,12))|0,T=T+(D=t$(D^I,8))|0,A=t$(A^T,7);let M=0;i[M++]=a+C|0,i[M++]=o+E|0,i[M++]=c+N|0,i[M++]=l+I|0,i[M++]=h+A|0,i[M++]=d+_|0,i[M++]=u+S|0,i[M++]=p+O|0,i[M++]=g+P|0,i[M++]=f+T|0,i[M++]=m+R|0,i[M++]=w+k|0,i[M++]=s+x|0,i[M++]=y+U|0,i[M++]=b+D|0,i[M++]=v+$|0},{counterRight:!1,counterLength:4,allowShortKeys:!1}),tW=new Uint8Array(16),tV=(e,t)=>{e.update(t);let r=t.length%16;r&&e.update(tW.subarray(r))},tz=new Uint8Array(32);function tK(e,t,r,i,s){let n=e(t,r,tz),a=tF.create(n);s&&tV(a,s),tV(a,i);let o=new Uint8Array(16),c=tA(o);tO(c,0,BigInt(s?s.length:0),!0),tO(c,8,BigInt(i.length),!0),a.update(o);let l=a.digest();return tT(n,o),l}let tJ=((e,t)=>{function r(i,...s){if(tC(i),void 0!==e.nonceLength){let t=s[0];if(!t)throw Error("nonce / iv required");e.varSizeNonce?tC(t):tC(t,e.nonceLength)}let n=e.tagLength;n&&void 0!==s[1]&&tC(s[1]);let a=t(i,...s),o=(e,t)=>{if(void 0!==t){if(2!==e)throw Error("cipher output not supported");tC(t)}},c=!1;return{encrypt(e,t){if(c)throw Error("cannot encrypt() twice with same key + nonce");return c=!0,tC(e),o(a.encrypt.length,t),a.encrypt(e,t)},decrypt(e,t){if(tC(e),n&&e.length<n)throw Error("invalid ciphertext length: smaller than tagLength="+n);return o(a.decrypt.length,t),a.decrypt(e,t)}}}return Object.assign(r,e),r})({blockSize:64,nonceLength:12,tagLength:16},(e,t,r)=>({encrypt(i,s){let n=i.length;(s=tS(n+16,s,!1)).set(i);let a=s.subarray(0,-16);tH(e,t,a,a,1);let o=tK(tH,e,t,a,r);return s.set(o,n),tT(o),s},decrypt(i,s){s=tS(i.length-16,s,!1);let n=i.subarray(0,-16),a=i.subarray(-16),o=tK(tH,e,t,n,r);if(!function(e,t){if(e.length!==t.length)return!1;let r=0;for(let i=0;i<e.length;i++)r|=e[i]^t[i];return 0===r}(a,o))throw Error("invalid tag");return s.set(i.subarray(0,-16)),tH(e,t,s,s,1),tT(o),s}}));class tG extends eq{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,eA(e);let r=ej(t);if(this.iHash=e.create(),"function"!=typeof this.iHash.update)throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let i=this.blockLen,s=new Uint8Array(i);s.set(r.length>i?e.create().update(r).digest():r);for(let e=0;e<s.length;e++)s[e]^=54;this.iHash.update(s),this.oHash=e.create();for(let e=0;e<s.length;e++)s[e]^=106;this.oHash.update(s),s.fill(0)}update(e){return e_(this),this.iHash.update(e),this}digestInto(e){e_(this),eI(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:r,finished:i,destroyed:s,blockLen:n,outputLen:a}=this;return e.finished=i,e.destroyed=s,e.blockLen=n,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}let tY=(e,t,r)=>new tG(e,t).update(r).digest();tY.create=(e,t)=>new tG(e,t);let tX=new Uint8Array([0]),tZ=new Uint8Array,tQ=(e,t,r,i,s)=>(function(e,t,r,i=32){if(eA(e),eN(i),i>255*e.outputLen)throw Error("Length should be <= 255*HashLen");let s=Math.ceil(i/e.outputLen);void 0===r&&(r=tZ);let n=new Uint8Array(s*e.outputLen),a=tY.create(e,t),o=a._cloneInto(),c=new Uint8Array(a.outputLen);for(let t=0;t<s;t++)tX[0]=t+1,o.update(0===t?tZ:c).update(r).update(tX).digestInto(c),n.set(c,e.outputLen*t),a._cloneInto(o);return a.destroy(),o.destroy(),c.fill(0),tX.fill(0),n.slice(0,i)})(e,function(e,t,r){return eA(e),void 0===r&&(r=new Uint8Array(e.outputLen)),tY(e,ej(r),ej(t))}(e,t,r),i,s);class t0 extends eq{constructor(e,t,r,i){super(),this.blockLen=e,this.outputLen=t,this.padOffset=r,this.isLE=i,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=eD(this.buffer)}update(e){e_(this);let{view:t,buffer:r,blockLen:i}=this,s=(e=ej(e)).length;for(let n=0;n<s;){let a=Math.min(i-this.pos,s-n);if(a===i){let t=eD(e);for(;i<=s-n;n+=i)this.process(t,n);continue}r.set(e.subarray(n,n+a),this.pos),this.pos+=a,n+=a,this.pos===i&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){e_(this),eS(e,this),this.finished=!0;let{buffer:t,view:r,blockLen:i,isLE:s}=this,{pos:n}=this;t[n++]=128,this.buffer.subarray(n).fill(0),this.padOffset>i-n&&(this.process(r,0),n=0);for(let e=n;e<i;e++)t[e]=0;(function(e,t,r,i){if("function"==typeof e.setBigUint64)return e.setBigUint64(t,r,i);let s=BigInt(32),n=BigInt(4294967295),a=Number(r>>s&n),o=Number(r&n),c=i?4:0,l=i?0:4;e.setUint32(t+c,a,i),e.setUint32(t+l,o,i)})(r,i-8,BigInt(8*this.length),s),this.process(r,0);let a=eD(e),o=this.outputLen;if(o%4)throw Error("_sha2: outputLen should be aligned to 32bit");let c=o/4,l=this.get();if(c>l.length)throw Error("_sha2: outputLen bigger than state");for(let e=0;e<c;e++)a.setUint32(4*e,l[e],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:r,length:i,finished:s,destroyed:n,pos:a}=this;return e.length=i,e.pos=a,e.finished=s,e.destroyed=n,i%t&&e.buffer.set(r),e}}let t1=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),t2=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),t5=new Uint32Array(64);class t3 extends t0{constructor(){super(64,32,8,!1),this.A=0|t2[0],this.B=0|t2[1],this.C=0|t2[2],this.D=0|t2[3],this.E=0|t2[4],this.F=0|t2[5],this.G=0|t2[6],this.H=0|t2[7]}get(){let{A:e,B:t,C:r,D:i,E:s,F:n,G:a,H:o}=this;return[e,t,r,i,s,n,a,o]}set(e,t,r,i,s,n,a,o){this.A=0|e,this.B=0|t,this.C=0|r,this.D=0|i,this.E=0|s,this.F=0|n,this.G=0|a,this.H=0|o}process(e,t){for(let r=0;r<16;r++,t+=4)t5[r]=e.getUint32(t,!1);for(let e=16;e<64;e++){let t=t5[e-15],r=t5[e-2],i=e$(t,7)^e$(t,18)^t>>>3,s=e$(r,17)^e$(r,19)^r>>>10;t5[e]=s+t5[e-7]+i+t5[e-16]|0}let{A:r,B:i,C:s,D:n,E:a,F:o,G:c,H:l}=this;for(let e=0;e<64;e++){var h,d,u,p;let t=l+(e$(a,6)^e$(a,11)^e$(a,25))+((h=a)&o^~h&c)+t1[e]+t5[e]|0,g=(e$(r,2)^e$(r,13)^e$(r,22))+((d=r)&(u=i)^d&(p=s)^u&p)|0;l=c,c=o,o=a,a=n+t|0,n=s,s=i,i=r,r=t+g|0}r=r+this.A|0,i=i+this.B|0,s=s+this.C|0,n=n+this.D|0,a=a+this.E|0,o=o+this.F|0,c=c+this.G|0,l=l+this.H|0,this.set(r,i,s,n,a,o,c,l)}roundClean(){t5.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}}let t4=eB(()=>new t3),t8=BigInt(0),t6=BigInt(1),t9=BigInt(2);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function t7(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name}function re(e){if(!t7(e))throw Error("Uint8Array expected")}function rt(e,t){if("boolean"!=typeof t)throw Error(e+" boolean expected, got "+t)}let rr=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function ri(e){re(e);let t="";for(let r=0;r<e.length;r++)t+=rr[e[r]];return t}function rs(e){let t=e.toString(16);return 1&t.length?"0"+t:t}function rn(e){if("string"!=typeof e)throw Error("hex string expected, got "+typeof e);return""===e?t8:BigInt("0x"+e)}let ra={_0:48,_9:57,A:65,F:70,a:97,f:102};function ro(e){return e>=ra._0&&e<=ra._9?e-ra._0:e>=ra.A&&e<=ra.F?e-(ra.A-10):e>=ra.a&&e<=ra.f?e-(ra.a-10):void 0}function rc(e){if("string"!=typeof e)throw Error("hex string expected, got "+typeof e);let t=e.length,r=t/2;if(t%2)throw Error("hex string expected, got unpadded hex of length "+t);let i=new Uint8Array(r);for(let t=0,s=0;t<r;t++,s+=2){let r=ro(e.charCodeAt(s)),n=ro(e.charCodeAt(s+1));if(void 0===r||void 0===n)throw Error('hex string expected, got non-hex character "'+(e[s]+e[s+1])+'" at index '+s);i[t]=16*r+n}return i}function rl(e){return rn(ri(e))}function rh(e){return re(e),rn(ri(Uint8Array.from(e).reverse()))}function rd(e,t){return rc(e.toString(16).padStart(2*t,"0"))}function ru(e,t){return rd(e,t).reverse()}function rp(e,t,r){let i;if("string"==typeof t)try{i=rc(t)}catch(t){throw Error(e+" must be hex string or Uint8Array, cause: "+t)}else if(t7(t))i=Uint8Array.from(t);else throw Error(e+" must be hex string or Uint8Array");let s=i.length;if("number"==typeof r&&s!==r)throw Error(e+" of length "+r+" expected, got "+s);return i}function rg(...e){let t=0;for(let r=0;r<e.length;r++){let i=e[r];re(i),t+=i.length}let r=new Uint8Array(t);for(let t=0,i=0;t<e.length;t++){let s=e[t];r.set(s,i),i+=s.length}return r}let rf=e=>"bigint"==typeof e&&t8<=e;function rm(e,t,r){return rf(e)&&rf(t)&&rf(r)&&t<=e&&e<r}function rw(e,t,r,i){if(!rm(t,r,i))throw Error("expected valid "+e+": "+r+" <= n < "+i+", got "+t)}function ry(e){let t;for(t=0;e>t8;e>>=t6,t+=1);return t}let rb=e=>(t9<<BigInt(e-1))-t6,rv=e=>new Uint8Array(e),rC=e=>Uint8Array.from(e);function rE(e,t,r){if("number"!=typeof e||e<2)throw Error("hashLen must be a number");if("number"!=typeof t||t<2)throw Error("qByteLen must be a number");if("function"!=typeof r)throw Error("hmacFn must be a function");let i=rv(e),s=rv(e),n=0,a=()=>{i.fill(1),s.fill(0),n=0},o=(...e)=>r(s,i,...e),c=(e=rv())=>{s=o(rC([0]),e),i=o(),0!==e.length&&(s=o(rC([1]),e),i=o())},l=()=>{if(n++>=1e3)throw Error("drbg: tried 1000 values");let e=0,r=[];for(;e<t;){let t=(i=o()).slice();r.push(t),e+=i.length}return rg(...r)};return(e,t)=>{let r;for(a(),c(e);!(r=t(l()));)c();return a(),r}}let rN={bigint:e=>"bigint"==typeof e,function:e=>"function"==typeof e,boolean:e=>"boolean"==typeof e,string:e=>"string"==typeof e,stringOrUint8Array:e=>"string"==typeof e||t7(e),isSafeInteger:e=>Number.isSafeInteger(e),array:e=>Array.isArray(e),field:(e,t)=>t.Fp.isValid(e),hash:e=>"function"==typeof e&&Number.isSafeInteger(e.outputLen)};function rI(e,t,r={}){let i=(t,r,i)=>{let s=rN[r];if("function"!=typeof s)throw Error("invalid validator function");let n=e[t];if(!(i&&void 0===n)&&!s(n,e))throw Error("param "+String(t)+" is invalid. Expected "+r+", got "+n)};for(let[e,r]of Object.entries(t))i(e,r,!1);for(let[e,t]of Object.entries(r))i(e,t,!0);return e}function rA(e){let t=new WeakMap;return(r,...i)=>{let s=t.get(r);if(void 0!==s)return s;let n=e(r,...i);return t.set(r,n),n}}var r_=Object.freeze({__proto__:null,isBytes:t7,abytes:re,abool:rt,bytesToHex:ri,numberToHexUnpadded:rs,hexToNumber:rn,hexToBytes:rc,bytesToNumberBE:rl,bytesToNumberLE:rh,numberToBytesBE:rd,numberToBytesLE:ru,numberToVarBytesBE:function(e){return rc(rs(e))},ensureBytes:rp,concatBytes:rg,equalBytes:function(e,t){if(e.length!==t.length)return!1;let r=0;for(let i=0;i<e.length;i++)r|=e[i]^t[i];return 0===r},utf8ToBytes:function(e){if("string"!=typeof e)throw Error("string expected");return new Uint8Array(new TextEncoder().encode(e))},inRange:rm,aInRange:rw,bitLen:ry,bitGet:function(e,t){return e>>BigInt(t)&t6},bitSet:function(e,t,r){return e|(r?t6:t8)<<BigInt(t)},bitMask:rb,createHmacDrbg:rE,validateObject:rI,notImplemented:()=>{throw Error("not implemented")},memoized:rA});let rS=BigInt(0),rO=BigInt(1),rP=BigInt(2),rT=BigInt(3),rR=BigInt(4),rk=BigInt(5),rx=BigInt(8);function rU(e,t){let r=e%t;return r>=rS?r:t+r}function rD(e,t,r){if(t<rS)throw Error("invalid exponent, negatives unsupported");if(r<=rS)throw Error("invalid modulus");if(r===rO)return rS;let i=rO;for(;t>rS;)t&rO&&(i=i*e%r),e=e*e%r,t>>=rO;return i}function r$(e,t,r){let i=e;for(;t-- >rS;)i*=i,i%=r;return i}function rM(e,t){if(e===rS)throw Error("invert: expected non-zero number");if(t<=rS)throw Error("invert: expected positive modulus, got "+t);let r=rU(e,t),i=t,s=rS,n=rO;for(;r!==rS;){let e=i/r,t=i%r,a=s-n*e;i=r,r=t,s=n,n=a}if(i!==rO)throw Error("invert: does not exist");return rU(s,t)}let rL=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function rj(e,t){let r=void 0!==t?t:e.toString(2).length;return{nBitLength:r,nByteLength:Math.ceil(r/8)}}function rq(e,t,r=!1,i={}){let s;if(e<=rS)throw Error("invalid field: expected ORDER > 0, got "+e);let{nBitLength:n,nByteLength:a}=rj(e,t);if(a>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let o=Object.freeze({ORDER:e,isLE:r,BITS:n,BYTES:a,MASK:rb(n),ZERO:rS,ONE:rO,create:t=>rU(t,e),isValid:t=>{if("bigint"!=typeof t)throw Error("invalid field element: expected bigint, got "+typeof t);return rS<=t&&t<e},is0:e=>e===rS,isOdd:e=>(e&rO)===rO,neg:t=>rU(-t,e),eql:(e,t)=>e===t,sqr:t=>rU(t*t,e),add:(t,r)=>rU(t+r,e),sub:(t,r)=>rU(t-r,e),mul:(t,r)=>rU(t*r,e),pow:(e,t)=>(function(e,t,r){if(r<rS)throw Error("invalid exponent, negatives unsupported");if(r===rS)return e.ONE;if(r===rO)return t;let i=e.ONE,s=t;for(;r>rS;)r&rO&&(i=e.mul(i,s)),s=e.sqr(s),r>>=rO;return i})(o,e,t),div:(t,r)=>rU(t*rM(r,e),e),sqrN:e=>e*e,addN:(e,t)=>e+t,subN:(e,t)=>e-t,mulN:(e,t)=>e*t,inv:t=>rM(t,e),sqrt:i.sqrt||(t=>(s||(s=function(e){if(e%rR===rT){let t=(e+rO)/rR;return function(e,r){let i=e.pow(r,t);if(!e.eql(e.sqr(i),r))throw Error("Cannot find square root");return i}}if(e%rx===rk){let t=(e-rk)/rx;return function(e,r){let i=e.mul(r,rP),s=e.pow(i,t),n=e.mul(r,s),a=e.mul(e.mul(n,rP),s),o=e.mul(n,e.sub(a,e.ONE));if(!e.eql(e.sqr(o),r))throw Error("Cannot find square root");return o}}return function(e){let t,r,i;let s=(e-rO)/rP;for(t=e-rO,r=0;t%rP===rS;t/=rP,r++);for(i=rP;i<e&&rD(i,s,e)!==e-rO;i++)if(i>1e3)throw Error("Cannot find square root: likely non-prime P");if(1===r){let t=(e+rO)/rR;return function(e,r){let i=e.pow(r,t);if(!e.eql(e.sqr(i),r))throw Error("Cannot find square root");return i}}let n=(t+rO)/rP;return function(e,a){if(e.pow(a,s)===e.neg(e.ONE))throw Error("Cannot find square root");let o=r,c=e.pow(e.mul(e.ONE,i),t),l=e.pow(a,n),h=e.pow(a,t);for(;!e.eql(h,e.ONE);){if(e.eql(h,e.ZERO))return e.ZERO;let t=1;for(let r=e.sqr(h);t<o&&!e.eql(r,e.ONE);t++)r=e.sqr(r);let r=e.pow(c,rO<<BigInt(o-t-1));c=e.sqr(r),l=e.mul(l,r),h=e.mul(h,c),o=t}return l}}(e)}(e)),s(o,t))),invertBatch:e=>(function(e,t){let r=Array(t.length),i=t.reduce((t,i,s)=>e.is0(i)?t:(r[s]=t,e.mul(t,i)),e.ONE),s=e.inv(i);return t.reduceRight((t,i,s)=>e.is0(i)?t:(r[s]=e.mul(t,r[s]),e.mul(t,i)),s),r})(o,e),cmov:(e,t,r)=>r?t:e,toBytes:e=>r?ru(e,a):rd(e,a),fromBytes:e=>{if(e.length!==a)throw Error("Field.fromBytes: expected "+a+" bytes, got "+e.length);return r?rh(e):rl(e)}});return Object.freeze(o)}function rB(e){if("bigint"!=typeof e)throw Error("field order must be bigint");return Math.ceil(e.toString(2).length/8)}function rF(e){let t=rB(e);return t+Math.ceil(t/2)}let rH=BigInt(0),rW=BigInt(1);function rV(e,t){let r=t.negate();return e?r:t}function rz(e,t){if(!Number.isSafeInteger(e)||e<=0||e>t)throw Error("invalid window size, expected [1.."+t+"], got W="+e)}function rK(e,t){return rz(e,t),{windows:Math.ceil(t/e)+1,windowSize:2**(e-1)}}let rJ=new WeakMap,rG=new WeakMap;function rY(e){return rG.get(e)||1}function rX(e){return rI(e.Fp,rL.reduce((e,t)=>(e[t]="function",e),{ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"})),rI(e,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...rj(e.n,e.nBitLength),...e,p:e.Fp.ORDER})}BigInt(0),BigInt(1),BigInt(2),BigInt(8);let rZ=BigInt(0),rQ=BigInt(1),r0=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949");BigInt(0);let r1=BigInt(1),r2=BigInt(2),r5=BigInt(3),r3=BigInt(5);BigInt(8);let r4=function(e){let t=(rI(e,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...e})),{P:r}=t,i=e=>rU(e,r),s=t.montgomeryBits,n=Math.ceil(s/8),a=t.nByteLength,o=t.adjustScalarBytes||(e=>e),c=t.powPminus2||(e=>rD(e,r-BigInt(2),r));function l(e,t,r){let s=i(e*(t-r));return[t=i(t-s),r=i(r+s)]}let h=(t.a-BigInt(2))/BigInt(4);function d(e,t){let d=function(e,t){rw("u",e,rZ,r),rw("scalar",t,rZ,r);let n=rQ,a=rZ,o=e,d=rQ,u=rZ,p;for(let r=BigInt(s-1);r>=rZ;r--){let s=t>>r&rQ;u^=s,n=(p=l(u,n,o))[0],o=p[1],a=(p=l(u,a,d))[0],d=p[1],u=s;let c=n+a,g=i(c*c),f=n-a,m=i(f*f),w=g-m,y=o+d,b=i((o-d)*c),v=i(y*f),C=b+v,E=b-v;o=i(C*C),d=i(e*i(E*E)),n=i(g*m),a=i(w*(g+i(h*w)))}return n=(p=l(u,n,o))[0],o=p[1],a=(p=l(u,a,d))[0],d=p[1],i(n*c(a))}(function(e){let t=rp("u coordinate",e,n);return 32===a&&(t[31]&=127),rh(t)}(t),function(e){let t=rp("scalar",e),r=t.length;if(r!==n&&r!==a)throw Error("invalid scalar, expected "+n+" or "+a+" bytes, got "+r);return rh(o(t))}(e));if(d===rZ)throw Error("invalid private or public key received");return ru(i(d),n)}let u=ru(i(t.Gu),n);function p(e){return d(e,u)}return{scalarMult:d,scalarMultBase:p,getSharedSecret:(e,t)=>d(e,t),getPublicKey:e=>p(e),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:u}}({P:r0,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:e=>{let{pow_p_5_8:t,b2:r}=function(e){let t=BigInt(10),r=BigInt(20),i=BigInt(40),s=BigInt(80),n=e*e%r0*e%r0,a=r$(n,r2,r0)*n%r0,o=r$(a,r1,r0)*e%r0,c=r$(o,r3,r0)*o%r0,l=r$(c,t,r0)*c%r0,h=r$(l,r,r0)*l%r0,d=r$(h,i,r0)*h%r0,u=r$(d,s,r0)*d%r0,p=r$(u,s,r0)*d%r0,g=r$(p,t,r0)*c%r0;return{pow_p_5_8:r$(g,r2,r0)*e%r0,b2:n}}(e);return rU(r$(t,r5,r0)*r,r0)},adjustScalarBytes:function(e){return e[0]&=248,e[31]&=127,e[31]|=64,e},randomBytes:eF});function r8(e){void 0!==e.lowS&&rt("lowS",e.lowS),void 0!==e.prehash&&rt("prehash",e.prehash)}let{bytesToNumberBE:r6,hexToBytes:r9}=r_;class r7 extends Error{constructor(e=""){super(e)}}let ie={Err:r7,_tlv:{encode:(e,t)=>{let{Err:r}=ie;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(1&t.length)throw new r("tlv.encode: unpadded data");let i=t.length/2,s=rs(i);if(s.length/2&128)throw new r("tlv.encode: long form length too big");let n=i>127?rs(s.length/2|128):"";return rs(e)+n+s+t},decode(e,t){let{Err:r}=ie,i=0;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length<2||t[i++]!==e)throw new r("tlv.decode: wrong tlv");let s=t[i++],n=0;if(128&s){let e=127&s;if(!e)throw new r("tlv.decode(long): indefinite length not supported");if(e>4)throw new r("tlv.decode(long): byte length is too big");let a=t.subarray(i,i+e);if(a.length!==e)throw new r("tlv.decode: length bytes not complete");if(0===a[0])throw new r("tlv.decode(long): zero leftmost byte");for(let e of a)n=n<<8|e;if(i+=e,n<128)throw new r("tlv.decode(long): not minimal encoding")}else n=s;let a=t.subarray(i,i+n);if(a.length!==n)throw new r("tlv.decode: wrong value length");return{v:a,l:t.subarray(i+n)}}},_int:{encode(e){let{Err:t}=ie;if(e<it)throw new t("integer: negative integers are not allowed");let r=rs(e);if(8&Number.parseInt(r[0],16)&&(r="00"+r),1&r.length)throw new t("unexpected DER parsing assertion: unpadded hex");return r},decode(e){let{Err:t}=ie;if(128&e[0])throw new t("invalid signature integer: negative");if(0===e[0]&&!(128&e[1]))throw new t("invalid signature integer: unnecessary leading zero");return r6(e)}},toSig(e){let{Err:t,_int:r,_tlv:i}=ie,s="string"==typeof e?r9(e):e;re(s);let{v:n,l:a}=i.decode(48,s);if(a.length)throw new t("invalid signature: left bytes after parsing");let{v:o,l:c}=i.decode(2,n),{v:l,l:h}=i.decode(2,c);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:r.decode(o),s:r.decode(l)}},hexFromSig(e){let{_tlv:t,_int:r}=ie,i=t.encode(2,r.encode(e.r)),s=t.encode(2,r.encode(e.s));return t.encode(48,i+s)}},it=BigInt(0),ir=BigInt(1);BigInt(2);let ii=BigInt(3);BigInt(4);let is=rq(BigInt("0xffffffff00000001000000000000000000000000ffffffffffffffffffffffff")),ia=function(e,t){let r=t=>(function(e){let t=function(e){let t=rX(e);return rI(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}(e),{Fp:r,n:i}=t,s=r.BYTES+1,n=2*r.BYTES+1;function a(e){return rU(e,i)}let{ProjectivePoint:o,normPrivateKeyToScalar:c,weierstrassEquation:l,isWithinCurveOrder:h}=function(e){var t;let r=function(e){let t=rX(e);rI(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:r,Fp:i,a:s}=t;if(r){if(!i.eql(s,i.ZERO))throw Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if("object"!=typeof r||"bigint"!=typeof r.beta||"function"!=typeof r.splitScalar)throw Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}(e),{Fp:i}=r,s=rq(r.n,r.nBitLength),n=r.toBytes||((e,t,r)=>{let s=t.toAffine();return rg(Uint8Array.from([4]),i.toBytes(s.x),i.toBytes(s.y))}),a=r.fromBytes||(e=>{let t=e.subarray(1);return{x:i.fromBytes(t.subarray(0,i.BYTES)),y:i.fromBytes(t.subarray(i.BYTES,2*i.BYTES))}});function o(e){let{a:t,b:s}=r,n=i.sqr(e),a=i.mul(n,e);return i.add(i.add(a,i.mul(e,t)),s)}if(!i.eql(i.sqr(r.Gy),o(r.Gx)))throw Error("bad generator point: equation left != right");function c(e){let t;let{allowedPrivateKeyLengths:i,nByteLength:s,wrapPrivateKey:n,n:a}=r;if(i&&"bigint"!=typeof e){if(t7(e)&&(e=ri(e)),"string"!=typeof e||!i.includes(e.length))throw Error("invalid private key");e=e.padStart(2*s,"0")}try{t="bigint"==typeof e?e:rl(rp("private key",e,s))}catch{throw Error("invalid private key, expected hex or "+s+" bytes, got "+typeof e)}return n&&(t=rU(t,a)),rw("private key",t,ir,a),t}function l(e){if(!(e instanceof u))throw Error("ProjectivePoint expected")}let h=rA((e,t)=>{let{px:r,py:s,pz:n}=e;if(i.eql(n,i.ONE))return{x:r,y:s};let a=e.is0();null==t&&(t=a?i.ONE:i.inv(n));let o=i.mul(r,t),c=i.mul(s,t),l=i.mul(n,t);if(a)return{x:i.ZERO,y:i.ZERO};if(!i.eql(l,i.ONE))throw Error("invZ was invalid");return{x:o,y:c}}),d=rA(e=>{if(e.is0()){if(r.allowInfinityPoint&&!i.is0(e.py))return;throw Error("bad point: ZERO")}let{x:t,y:s}=e.toAffine();if(!i.isValid(t)||!i.isValid(s))throw Error("bad point: x or y not FE");let n=i.sqr(s),a=o(t);if(!i.eql(n,a))throw Error("bad point: equation left != right");if(!e.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});class u{constructor(e,t,r){if(this.px=e,this.py=t,this.pz=r,null==e||!i.isValid(e))throw Error("x required");if(null==t||!i.isValid(t))throw Error("y required");if(null==r||!i.isValid(r))throw Error("z required");Object.freeze(this)}static fromAffine(e){let{x:t,y:r}=e||{};if(!e||!i.isValid(t)||!i.isValid(r))throw Error("invalid affine point");if(e instanceof u)throw Error("projective point not allowed");let s=e=>i.eql(e,i.ZERO);return s(t)&&s(r)?u.ZERO:new u(t,r,i.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(e){let t=i.invertBatch(e.map(e=>e.pz));return e.map((e,r)=>e.toAffine(t[r])).map(u.fromAffine)}static fromHex(e){let t=u.fromAffine(a(rp("pointHex",e)));return t.assertValidity(),t}static fromPrivateKey(e){return u.BASE.multiply(c(e))}static msm(e,t){return function(e,t,r,i){if(function(e,t){if(!Array.isArray(e))throw Error("array expected");e.forEach((e,r)=>{if(!(e instanceof t))throw Error("invalid point at index "+r)})}(r,e),function(e,t){if(!Array.isArray(e))throw Error("array of scalars expected");e.forEach((e,r)=>{if(!t.isValid(e))throw Error("invalid scalar at index "+r)})}(i,t),r.length!==i.length)throw Error("arrays of points and scalars must have equal length");let s=e.ZERO,n=ry(BigInt(r.length)),a=n>12?n-3:n>4?n-2:n?2:1,o=(1<<a)-1,c=Array(o+1).fill(s),l=Math.floor((t.BITS-1)/a)*a,h=s;for(let e=l;e>=0;e-=a){c.fill(s);for(let t=0;t<i.length;t++){let s=Number(i[t]>>BigInt(e)&BigInt(o));c[s]=c[s].add(r[t])}let t=s;for(let e=c.length-1,r=s;e>0;e--)r=r.add(c[e]),t=t.add(r);if(h=h.add(t),0!==e)for(let e=0;e<a;e++)h=h.double()}return h}(u,s,e,t)}_setWindowSize(e){g.setWindowSize(this,e)}assertValidity(){d(this)}hasEvenY(){let{y:e}=this.toAffine();if(i.isOdd)return!i.isOdd(e);throw Error("Field doesn't support isOdd")}equals(e){l(e);let{px:t,py:r,pz:s}=this,{px:n,py:a,pz:o}=e,c=i.eql(i.mul(t,o),i.mul(n,s)),h=i.eql(i.mul(r,o),i.mul(a,s));return c&&h}negate(){return new u(this.px,i.neg(this.py),this.pz)}double(){let{a:e,b:t}=r,s=i.mul(t,ii),{px:n,py:a,pz:o}=this,c=i.ZERO,l=i.ZERO,h=i.ZERO,d=i.mul(n,n),p=i.mul(a,a),g=i.mul(o,o),f=i.mul(n,a);return f=i.add(f,f),h=i.mul(n,o),h=i.add(h,h),c=i.mul(e,h),l=i.mul(s,g),l=i.add(c,l),c=i.sub(p,l),l=i.add(p,l),l=i.mul(c,l),c=i.mul(f,c),h=i.mul(s,h),g=i.mul(e,g),f=i.sub(d,g),f=i.mul(e,f),f=i.add(f,h),h=i.add(d,d),d=i.add(h,d),d=i.add(d,g),d=i.mul(d,f),l=i.add(l,d),g=i.mul(a,o),g=i.add(g,g),d=i.mul(g,f),c=i.sub(c,d),h=i.mul(g,p),h=i.add(h,h),new u(c,l,h=i.add(h,h))}add(e){l(e);let{px:t,py:s,pz:n}=this,{px:a,py:o,pz:c}=e,h=i.ZERO,d=i.ZERO,p=i.ZERO,g=r.a,f=i.mul(r.b,ii),m=i.mul(t,a),w=i.mul(s,o),y=i.mul(n,c),b=i.add(t,s),v=i.add(a,o);b=i.mul(b,v),v=i.add(m,w),b=i.sub(b,v),v=i.add(t,n);let C=i.add(a,c);return v=i.mul(v,C),C=i.add(m,y),v=i.sub(v,C),C=i.add(s,n),h=i.add(o,c),C=i.mul(C,h),h=i.add(w,y),C=i.sub(C,h),p=i.mul(g,v),h=i.mul(f,y),p=i.add(h,p),h=i.sub(w,p),p=i.add(w,p),d=i.mul(h,p),w=i.add(m,m),w=i.add(w,m),y=i.mul(g,y),v=i.mul(f,v),w=i.add(w,y),y=i.sub(m,y),y=i.mul(g,y),v=i.add(v,y),m=i.mul(w,v),d=i.add(d,m),m=i.mul(C,v),h=i.mul(b,h),h=i.sub(h,m),m=i.mul(b,w),p=i.mul(C,p),new u(h,d,p=i.add(p,m))}subtract(e){return this.add(e.negate())}is0(){return this.equals(u.ZERO)}wNAF(e){return g.wNAFCached(this,e,u.normalizeZ)}multiplyUnsafe(e){let{endo:t,n:s}=r;rw("scalar",e,it,s);let n=u.ZERO;if(e===it)return n;if(this.is0()||e===ir)return this;if(!t||g.hasPrecomputes(this))return g.wNAFCachedUnsafe(this,e,u.normalizeZ);let{k1neg:a,k1:o,k2neg:c,k2:l}=t.splitScalar(e),h=n,d=n,p=this;for(;o>it||l>it;)o&ir&&(h=h.add(p)),l&ir&&(d=d.add(p)),p=p.double(),o>>=ir,l>>=ir;return a&&(h=h.negate()),c&&(d=d.negate()),d=new u(i.mul(d.px,t.beta),d.py,d.pz),h.add(d)}multiply(e){let t,s;let{endo:n,n:a}=r;if(rw("scalar",e,ir,a),n){let{k1neg:r,k1:a,k2neg:o,k2:c}=n.splitScalar(e),{p:l,f:h}=this.wNAF(a),{p:d,f:p}=this.wNAF(c);l=g.constTimeNegate(r,l),d=g.constTimeNegate(o,d),d=new u(i.mul(d.px,n.beta),d.py,d.pz),t=l.add(d),s=h.add(p)}else{let{p:r,f:i}=this.wNAF(e);t=r,s=i}return u.normalizeZ([t,s])[0]}multiplyAndAddUnsafe(e,t,r){let i=u.BASE,s=(e,t)=>t!==it&&t!==ir&&e.equals(i)?e.multiply(t):e.multiplyUnsafe(t),n=s(this,t).add(s(e,r));return n.is0()?void 0:n}toAffine(e){return h(this,e)}isTorsionFree(){let{h:e,isTorsionFree:t}=r;if(e===ir)return!0;if(t)return t(u,this);throw Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:e,clearCofactor:t}=r;return e===ir?this:t?t(u,this):this.multiplyUnsafe(r.h)}toRawBytes(e=!0){return rt("isCompressed",e),this.assertValidity(),n(u,this,e)}toHex(e=!0){return rt("isCompressed",e),ri(this.toRawBytes(e))}}u.BASE=new u(r.Gx,r.Gy,i.ONE),u.ZERO=new u(i.ZERO,i.ONE,i.ZERO);let p=r.nBitLength,g=(t=r.endo?Math.ceil(p/2):p,{constTimeNegate:rV,hasPrecomputes:e=>1!==rY(e),unsafeLadder(e,t,r=u.ZERO){let i=e;for(;t>rH;)t&rW&&(r=r.add(i)),i=i.double(),t>>=rW;return r},precomputeWindow(e,r){let{windows:i,windowSize:s}=rK(r,t),n=[],a=e,o=a;for(let e=0;e<i;e++){o=a,n.push(o);for(let e=1;e<s;e++)o=o.add(a),n.push(o);a=o.double()}return n},wNAF(e,r,i){let{windows:s,windowSize:n}=rK(e,t),a=u.ZERO,o=u.BASE,c=BigInt(2**e-1),l=2**e,h=BigInt(e);for(let e=0;e<s;e++){let t=e*n,s=Number(i&c);i>>=h,s>n&&(s-=l,i+=rW);let d=t+Math.abs(s)-1,u=e%2!=0,p=s<0;0===s?o=o.add(rV(u,r[t])):a=a.add(rV(p,r[d]))}return{p:a,f:o}},wNAFUnsafe(e,r,i,s=u.ZERO){let{windows:n,windowSize:a}=rK(e,t),o=BigInt(2**e-1),c=2**e,l=BigInt(e);for(let e=0;e<n;e++){let t=e*a;if(i===rH)break;let n=Number(i&o);if(i>>=l,n>a&&(n-=c,i+=rW),0===n)continue;let h=r[t+Math.abs(n)-1];n<0&&(h=h.negate()),s=s.add(h)}return s},getPrecomputes(e,t,r){let i=rJ.get(t);return i||(i=this.precomputeWindow(t,e),1!==e&&rJ.set(t,r(i))),i},wNAFCached(e,t,r){let i=rY(e);return this.wNAF(i,this.getPrecomputes(i,e,r),t)},wNAFCachedUnsafe(e,t,r,i){let s=rY(e);return 1===s?this.unsafeLadder(e,t,i):this.wNAFUnsafe(s,this.getPrecomputes(s,e,r),t,i)},setWindowSize(e,r){rz(r,t),rG.set(e,r),rJ.delete(e)}});return{CURVE:r,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:function(e){return rm(e,ir,r.n)}}}({...t,toBytes(e,t,i){let s=t.toAffine(),n=r.toBytes(s.x);return rt("isCompressed",i),i?rg(Uint8Array.from([t.hasEvenY()?2:3]),n):rg(Uint8Array.from([4]),n,r.toBytes(s.y))},fromBytes(e){let t=e.length,i=e[0],a=e.subarray(1);if(t===s&&(2===i||3===i)){let e;let t=rl(a);if(!rm(t,ir,r.ORDER))throw Error("Point is not on curve");let s=l(t);try{e=r.sqrt(s)}catch(e){throw Error("Point is not on curve"+(e instanceof Error?": "+e.message:""))}return(1&i)==1!=((e&ir)===ir)&&(e=r.neg(e)),{x:t,y:e}}if(t===n&&4===i)return{x:r.fromBytes(a.subarray(0,r.BYTES)),y:r.fromBytes(a.subarray(r.BYTES,2*r.BYTES))};throw Error("invalid Point, expected length of "+s+", or uncompressed "+n+", got "+t)}}),d=e=>ri(rd(e,t.nByteLength)),u=(e,t,r)=>rl(e.slice(t,r));class p{constructor(e,t,r){this.r=e,this.s=t,this.recovery=r,this.assertValidity()}static fromCompact(e){let r=t.nByteLength;return new p(u(e=rp("compactSignature",e,2*r),0,r),u(e,r,2*r))}static fromDER(e){let{r:t,s:r}=ie.toSig(rp("DER",e));return new p(t,r)}assertValidity(){rw("r",this.r,ir,i),rw("s",this.s,ir,i)}addRecoveryBit(e){return new p(this.r,this.s,e)}recoverPublicKey(e){let{r:s,s:n,recovery:c}=this,l=m(rp("msgHash",e));if(null==c||![0,1,2,3].includes(c))throw Error("recovery id invalid");let h=2===c||3===c?s+t.n:s;if(h>=r.ORDER)throw Error("recovery id 2 or 3 invalid");let u=(1&c)==0?"02":"03",p=o.fromHex(u+d(h)),g=rM(h,i),f=a(-l*g),w=a(n*g),y=o.BASE.multiplyAndAddUnsafe(p,f,w);if(!y)throw Error("point at infinify");return y.assertValidity(),y}hasHighS(){return this.s>i>>ir}normalizeS(){return this.hasHighS()?new p(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return rc(this.toDERHex())}toDERHex(){return ie.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return rc(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}function g(e){let t=t7(e),r="string"==typeof e,i=(t||r)&&e.length;return t?i===s||i===n:r?i===2*s||i===2*n:e instanceof o}let f=t.bits2int||function(e){if(e.length>8192)throw Error("input is too large");let r=rl(e),i=8*e.length-t.nBitLength;return i>0?r>>BigInt(i):r},m=t.bits2int_modN||function(e){return a(f(e))},w=rb(t.nBitLength);function y(e){return rw("num < 2^"+t.nBitLength,e,it,w),rd(e,t.nByteLength)}let b={lowS:t.lowS,prehash:!1},v={lowS:t.lowS,prehash:!1};return o.BASE._setWindowSize(8),{CURVE:t,getPublicKey:function(e,t=!0){return o.fromPrivateKey(e).toRawBytes(t)},getSharedSecret:function(e,t,r=!0){if(g(e))throw Error("first arg must be private key");if(!g(t))throw Error("second arg must be public key");return o.fromHex(t).multiply(c(e)).toRawBytes(r)},sign:function(e,s,n=b){let{seed:l,k2sig:d}=function(e,s,n=b){if(["recovered","canonical"].some(e=>e in n))throw Error("sign() legacy options not supported");let{hash:l,randomBytes:d}=t,{lowS:u,prehash:g,extraEntropy:w}=n;null==u&&(u=!0),e=rp("msgHash",e),r8(n),g&&(e=rp("prehashed msgHash",l(e)));let v=m(e),C=c(s),E=[y(C),y(v)];if(null!=w&&!1!==w){let e=!0===w?d(r.BYTES):w;E.push(rp("extraEntropy",e))}return{seed:rg(...E),k2sig:function(e){let t=f(e);if(!h(t))return;let r=rM(t,i),s=o.BASE.multiply(t).toAffine(),n=a(s.x);if(n===it)return;let c=a(r*a(v+n*C));if(c===it)return;let l=(s.x===n?0:2)|Number(s.y&ir),d=c;return u&&c>i>>ir&&(d=c>i>>ir?a(-c):c,l^=1),new p(n,d,l)}}}(e,s,n);return rE(t.hash.outputLen,t.nByteLength,t.hmac)(l,d)},verify:function(e,r,s,n=v){let c,l;r=rp("msgHash",r),s=rp("publicKey",s);let{lowS:h,prehash:d,format:u}=n;if(r8(n),"strict"in n)throw Error("options.strict was renamed to lowS");if(void 0!==u&&"compact"!==u&&"der"!==u)throw Error("format must be compact or der");let g="string"==typeof e||t7(e),f=!g&&!u&&"object"==typeof e&&null!==e&&"bigint"==typeof e.r&&"bigint"==typeof e.s;if(!g&&!f)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");try{if(f&&(c=new p(e.r,e.s)),g){try{"compact"!==u&&(c=p.fromDER(e))}catch(e){if(!(e instanceof ie.Err))throw e}c||"der"===u||(c=p.fromCompact(e))}l=o.fromHex(s)}catch{return!1}if(!c||h&&c.hasHighS())return!1;d&&(r=t.hash(r));let{r:w,s:y}=c,b=m(r),C=rM(y,i),E=a(b*C),N=a(w*C),I=o.BASE.multiplyAndAddUnsafe(l,E,N)?.toAffine();return!!I&&a(I.x)===w},ProjectivePoint:o,Signature:p,utils:{isValidPrivateKey(e){try{return c(e),!0}catch{return!1}},normPrivateKeyToScalar:c,randomPrivateKey:()=>{let e=rF(t.n);return function(e,t,r=!1){let i=e.length,s=rB(t),n=rF(t);if(i<16||i<n||i>1024)throw Error("expected "+n+"-1024 bytes of input, got "+i);let a=rU(r?rh(e):rl(e),t-rO)+rO;return r?ru(a,s):rd(a,s)}(t.randomBytes(e),t.n)},precompute:(e=8,t=o.BASE)=>(t._setWindowSize(e),t.multiply(BigInt(3)),t)}}})({...e,hash:t,hmac:(e,...r)=>tY(t,e,function(...e){let t=0;for(let r=0;r<e.length;r++){let i=e[r];eI(i),t+=i.length}let r=new Uint8Array(t);for(let t=0,i=0;t<e.length;t++){let s=e[t];r.set(s,i),i+=s.length}return r}(...r)),randomBytes:eF});return{...r(t),create:r}}({a:is.create(BigInt("-3")),b:BigInt("0x5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b"),Fp:is,n:BigInt("0xffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551"),Gx:BigInt("0x6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296"),Gy:BigInt("0x4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5"),h:BigInt(1),lowS:!1},t4),io="base10",ic="base16",il="base64pad",ih="base64url",id="utf8";function iu(){let e=eF(32);return(0,j.BB)(e,ic)}function ip(e){let t=t4((0,j.mL)(e,ic));return(0,j.BB)(t,ic)}function ig(e){let t=t4((0,j.mL)(e,id));return(0,j.BB)(t,ic)}function im(e){return(0,j.mL)(`${e}`,io)}function iw(e){return Number((0,j.BB)(e,io))}function iy(e){return e.replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function ib(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=(4-t.length%4)%4;return t+"=".repeat(r)}function iv(e){if(2===iw(e.type))return(0,j.BB)((0,j.zo)([e.type,e.sealed]),il);if(1===iw(e.type)){if(typeof e.senderPublicKey>"u")throw Error("Missing sender public key for type 1 envelope");return(0,j.BB)((0,j.zo)([e.type,e.senderPublicKey,e.iv,e.sealed]),il)}return(0,j.BB)((0,j.zo)([e.type,e.iv,e.sealed]),il)}function iC(e){let t=(e.encoding||il)===ih?ib(e.encoded):e.encoded,r=(0,j.mL)(t,il),i=r.slice(0,1);if(1===iw(i)){let e=r.slice(1,33),t=r.slice(33,45);return{type:i,sealed:r.slice(45),iv:t,senderPublicKey:e}}if(2===iw(i))return{type:i,sealed:r.slice(1),iv:eF(12)};let s=r.slice(1,13);return{type:i,sealed:r.slice(13),iv:s}}function iE(e){let t=e?.type||0;if(1===t){if(typeof e?.senderPublicKey>"u")throw Error("missing sender public key");if(typeof e?.receiverPublicKey>"u")throw Error("missing receiver public key")}return{type:t,senderPublicKey:e?.senderPublicKey,receiverPublicKey:e?.receiverPublicKey}}function iN(e){return 1===e.type&&"string"==typeof e.senderPublicKey&&"string"==typeof e.receiverPublicKey}function iI(e){return e?.relay||{protocol:"irn"}}function iA(e){let t=q.iO[e];if(typeof t>"u")throw Error(`Relay Protocol not supported: ${e}`);return t}function i_(e){var t;if(!e.includes("wc:")){let t=eE(e);null!=t&&t.includes("wc:")&&(e=t)}let r=(e=(e=e.includes("wc://")?e.replace("wc://",""):e).includes("wc:")?e.replace("wc:",""):e).indexOf(":"),i=-1!==e.indexOf("?")?e.indexOf("?"):void 0,s=e.substring(0,r),n=e.substring(r+1,i).split("@"),a=new URLSearchParams("u">typeof i?e.substring(i):""),o={};a.forEach((e,t)=>{o[t]=e});let c="string"==typeof o.methods?o.methods.split(","):void 0;return{protocol:s,topic:(t=n[0]).startsWith("//")?t.substring(2):t,version:parseInt(n[1],10),symKey:o.symKey,relay:function(e,t="-"){let r={},i="relay"+t;return Object.keys(e).forEach(t=>{if(t.startsWith(i)){let s=t.replace(i,""),n=e[t];r[s]=n}}),r}(o),methods:c,expiryTimestamp:o.expiryTimestamp?parseInt(o.expiryTimestamp,10):void 0}}function iS(e){let t=new URLSearchParams,r=function(e,t="-"){let r={};return Object.keys(e).forEach(i=>{e[i]&&(r["relay"+t+i]=e[i])}),r}(e.relay);Object.keys(r).sort().forEach(e=>{t.set(e,r[e])}),t.set("symKey",e.symKey),e.expiryTimestamp&&t.set("expiryTimestamp",e.expiryTimestamp.toString()),e.methods&&t.set("methods",e.methods.join(","));let i=t.toString();return`${e.protocol}:${e.topic}@${e.version}?${i}`}function iO(e,t,r){return`${e}?wc_ev=${r}&topic=${t}`}var iP=Object.defineProperty,iT=Object.defineProperties,iR=Object.getOwnPropertyDescriptors,ik=Object.getOwnPropertySymbols,ix=Object.prototype.hasOwnProperty,iU=Object.prototype.propertyIsEnumerable,iD=(e,t,r)=>t in e?iP(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,i$=(e,t)=>{for(var r in t||(t={}))ix.call(t,r)&&iD(e,r,t[r]);if(ik)for(var r of ik(t))iU.call(t,r)&&iD(e,r,t[r]);return e},iM=(e,t)=>iT(e,iR(t));function iL(e){let t=[];return e.forEach(e=>{let[r,i]=e.split(":");t.push(`${r}:${i}`)}),t}function ij(e){return e.includes(":")}function iq(e){return ij(e)?e.split(":")[0]:e}function iB(e){var t,r,i;let s={};if(!iJ(e))return s;for(let[n,a]of Object.entries(e)){let e=ij(n)?[n]:a.chains,o=a.methods||[],c=a.events||[],l=iq(n);s[l]=iM(i$({},s[l]),{chains:em(e,null==(t=s[l])?void 0:t.chains),methods:em(o,null==(r=s[l])?void 0:r.methods),events:em(c,null==(i=s[l])?void 0:i.events)})}return s}function iF(e,t){let r=function(e){let t={};return e?.forEach(e=>{var r;let[i,s]=e.split(":");t[i]||(t[i]={accounts:[],chains:[],events:[],methods:[]}),t[i].accounts.push(e),null==(r=t[i].chains)||r.push(`${i}:${s}`)}),t}(t=t.map(e=>e.replace("did:pkh:","")));for(let[t,i]of Object.entries(r))i.methods?i.methods=em(i.methods,e):i.methods=e,i.events=["chainChanged","accountsChanged"];return r}let iH={INVALID_METHOD:{message:"Invalid method.",code:1001},INVALID_EVENT:{message:"Invalid event.",code:1002},INVALID_UPDATE_REQUEST:{message:"Invalid update request.",code:1003},INVALID_EXTEND_REQUEST:{message:"Invalid extend request.",code:1004},INVALID_SESSION_SETTLE_REQUEST:{message:"Invalid session settle request.",code:1005},UNAUTHORIZED_METHOD:{message:"Unauthorized method.",code:3001},UNAUTHORIZED_EVENT:{message:"Unauthorized event.",code:3002},UNAUTHORIZED_UPDATE_REQUEST:{message:"Unauthorized update request.",code:3003},UNAUTHORIZED_EXTEND_REQUEST:{message:"Unauthorized extend request.",code:3004},USER_REJECTED:{message:"User rejected.",code:5e3},USER_REJECTED_CHAINS:{message:"User rejected chains.",code:5001},USER_REJECTED_METHODS:{message:"User rejected methods.",code:5002},USER_REJECTED_EVENTS:{message:"User rejected events.",code:5003},UNSUPPORTED_CHAINS:{message:"Unsupported chains.",code:5100},UNSUPPORTED_METHODS:{message:"Unsupported methods.",code:5101},UNSUPPORTED_EVENTS:{message:"Unsupported events.",code:5102},UNSUPPORTED_ACCOUNTS:{message:"Unsupported accounts.",code:5103},UNSUPPORTED_NAMESPACE_KEY:{message:"Unsupported namespace key.",code:5104},USER_DISCONNECTED:{message:"User disconnected.",code:6e3},SESSION_SETTLEMENT_FAILED:{message:"Session settlement failed.",code:7e3},WC_METHOD_UNSUPPORTED:{message:"Unsupported wc_ method.",code:10001}},iW={NOT_INITIALIZED:{message:"Not initialized.",code:1},NO_MATCHING_KEY:{message:"No matching key.",code:2},RESTORE_WILL_OVERRIDE:{message:"Restore will override.",code:3},RESUBSCRIBED:{message:"Resubscribed.",code:4},MISSING_OR_INVALID:{message:"Missing or invalid.",code:5},EXPIRED:{message:"Expired.",code:6},UNKNOWN_TYPE:{message:"Unknown type.",code:7},MISMATCHED_TOPIC:{message:"Mismatched topic.",code:8},NON_CONFORMING_NAMESPACES:{message:"Non conforming namespaces.",code:9}};function iV(e,t){let{message:r,code:i}=iW[e];return{message:t?`${r} ${t}`:r,code:i}}function iz(e,t){let{message:r,code:i}=iH[e];return{message:t?`${r} ${t}`:r,code:i}}function iK(e,t){return!!Array.isArray(e)&&(!("u">typeof t)||!e.length||e.every(t))}function iJ(e){return Object.getPrototypeOf(e)===Object.prototype&&Object.keys(e).length}function iG(e){return typeof e>"u"}function iY(e,t){return!!(t&&iG(e))||"string"==typeof e&&!!e.trim().length}function iX(e,t){return!!(t&&iG(e))||"number"==typeof e&&!isNaN(e)}function iZ(e){return!!(iY(e,!1)&&e.includes(":"))&&2===e.split(":").length}function iQ(e){let t=!0;return iK(e)?e.length&&(t=e.every(e=>iY(e,!1))):t=!1,t}function i0(e,t){let r=null;return Object.values(e).forEach(e=>{var i;let s;if(r)return;let n=(i=`${t}, namespace`,s=null,iQ(e?.methods)?iQ(e?.events)||(s=iz("UNSUPPORTED_EVENTS",`${i}, events should be an array of strings or empty array for no events`)):s=iz("UNSUPPORTED_METHODS",`${i}, methods should be an array of strings or empty array for no methods`),s);n&&(r=n)}),r}function i1(e,t){let r=null;if(e&&iJ(e)){let i;let s=i0(e,t);s&&(r=s);let n=(i=null,Object.values(e).forEach(e=>{var r,s;let n;if(i)return;let a=(r=e?.accounts,s=`${t} namespace`,n=null,iK(r)?r.forEach(e=>{n||function(e){if(iY(e,!1)&&e.includes(":")){let t=e.split(":");if(3===t.length){let e=t[0]+":"+t[1];return!!t[2]&&iZ(e)}}return!1}(e)||(n=iz("UNSUPPORTED_ACCOUNTS",`${s}, account ${e} should be a string and conform to "namespace:chainId:address" format`))}):n=iz("UNSUPPORTED_ACCOUNTS",`${s}, accounts should be an array of strings conforming to "namespace:chainId:address" format`),n);a&&(i=a)}),i);n&&(r=n)}else r=iV("MISSING_OR_INVALID",`${t}, namespaces should be an object with data`);return r}function i2(e){return iY(e.protocol,!0)}function i5(e){return"u">typeof e}function i3(e,t){return!(!iZ(t)||!(function(e){let t=[];return Object.values(e).forEach(e=>{t.push(...iL(e.accounts))}),t})(e).includes(t))}function i4(e,t,r){let i=null,s=function(e){let t={};return Object.keys(e).forEach(r=>{var i;r.includes(":")?t[r]=e[r]:null==(i=e[r].chains)||i.forEach(i=>{t[i]={methods:e[r].methods,events:e[r].events}})}),t}(e),n=function(e){let t={};return Object.keys(e).forEach(r=>{if(r.includes(":"))t[r]=e[r];else{let i=iL(e[r].accounts);i?.forEach(i=>{t[i]={accounts:e[r].accounts.filter(e=>e.includes(`${i}:`)),methods:e[r].methods,events:e[r].events}})}}),t}(t),a=Object.keys(s),o=Object.keys(n),c=i8(Object.keys(e)),l=i8(Object.keys(t)),h=c.filter(e=>!l.includes(e));return h.length&&(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces keys don't satisfy requiredNamespaces.
4
+ `)};function tp(e){if(!e)throw Error("No recap provided, value is undefined");if(!e.att)throw Error("No `att` property found");let t=Object.keys(e.att);if(!(null!=t&&t.length))throw Error("No resources found in `att` property");t.forEach(t=>{let r=e.att[t];if(Array.isArray(r)||"object"!=typeof r)throw Error(`Resource must be an object: ${t}`);if(!Object.keys(r).length)throw Error(`Resource object is empty: ${t}`);Object.keys(r).forEach(e=>{let t=r[e];if(!Array.isArray(t))throw Error(`Ability limits ${e} must be an array of objects, found: ${t}`);if(!t.length)throw Error(`Value of ${e} is empty array, must be an array with objects`);t.forEach(t=>{if("object"!=typeof t)throw Error(`Ability limits (${e}) must be an array of objects, found: ${t}`)})})})}function tg(e){return tp(e),`urn:recap:${Buffer.from(JSON.stringify(e)).toString("base64").replace(/=/g,"")}`}function tf(e){var t;let r=(t=e.replace("urn:recap:",""),JSON.parse(Buffer.from(t,"base64").toString("utf-8")));return tp(r),r}function tm(e){var t;let r=tf(e);tp(r);let i=null==(t=r.att)?void 0:t.eip155;return i?Object.keys(i).map(e=>e.split("/")[1]):[]}function tw(e){let t=tf(e);tp(t);let r=[];return Object.values(t.att).forEach(e=>{Object.values(e).forEach(e=>{var t;null!=(t=e?.[0])&&t.chains&&r.push(e[0].chains)})}),[...new Set(r.flat())]}function ty(e){if(!e)return;let t=e?.[e.length-1];return t&&t.includes("urn:recap:")?t:void 0}function tb(e){if(!Number.isSafeInteger(e)||e<0)throw Error("positive integer expected, got "+e)}function tv(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name}function tC(e,...t){if(!tv(e))throw Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw Error("Uint8Array expected of length "+t+", got length="+e.length)}function tE(e,t=!0){if(e.destroyed)throw Error("Hash instance has been destroyed");if(t&&e.finished)throw Error("Hash#digest() has already been called")}function tN(e){if("boolean"!=typeof e)throw Error(`boolean expected, not ${e}`)}let tI=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),tA=e=>new DataView(e.buffer,e.byteOffset,e.byteLength);if(68!==new Uint8Array(new Uint32Array([287454020]).buffer)[0])throw Error("Non little-endian hardware is not supported");function t_(e){if("string"==typeof e)e=function(e){if("string"!=typeof e)throw Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}(e);else if(tv(e))e=tP(e);else throw Error("Uint8Array expected, got "+typeof e);return e}function tS(e,t,r=!0){if(void 0===t)return new Uint8Array(e);if(t.length!==e)throw Error("invalid output length, expected "+e+", got: "+t.length);if(r&&t.byteOffset%4!=0)throw Error("invalid output, must be aligned");return t}function tO(e,t,r,i){if("function"==typeof e.setBigUint64)return e.setBigUint64(t,r,i);let s=BigInt(32),n=BigInt(4294967295),a=Number(r>>s&n),o=Number(r&n),c=i?4:0,l=i?0:4;e.setUint32(t+c,a,i),e.setUint32(t+l,o,i)}function tP(e){return Uint8Array.from(e)}function tT(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}let tR=e=>Uint8Array.from(e.split("").map(e=>e.charCodeAt(0))),tk=tR("expand 16-byte k"),tx=tR("expand 32-byte k"),tU=tI(tk),tD=tI(tx);function t$(e,t){return e<<t|e>>>32-t}function tM(e){return e.byteOffset%4==0}let tL=4294967296-1,tj=new Uint32Array,tq=(e,t)=>255&e[t++]|(255&e[t++])<<8;class tB{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,tC(e=t_(e),32);let t=tq(e,0),r=tq(e,2),i=tq(e,4),s=tq(e,6),n=tq(e,8),a=tq(e,10),o=tq(e,12),c=tq(e,14);this.r[0]=8191&t,this.r[1]=(t>>>13|r<<3)&8191,this.r[2]=(r>>>10|i<<6)&7939,this.r[3]=(i>>>7|s<<9)&8191,this.r[4]=(s>>>4|n<<12)&255,this.r[5]=n>>>1&8190,this.r[6]=(n>>>14|a<<2)&8191,this.r[7]=(a>>>11|o<<5)&8065,this.r[8]=(o>>>8|c<<8)&8191,this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=tq(e,16+2*t)}process(e,t,r=!1){let{h:i,r:s}=this,n=s[0],a=s[1],o=s[2],c=s[3],l=s[4],h=s[5],d=s[6],u=s[7],p=s[8],g=s[9],f=tq(e,t+0),m=tq(e,t+2),w=tq(e,t+4),y=tq(e,t+6),b=tq(e,t+8),v=tq(e,t+10),C=tq(e,t+12),E=tq(e,t+14),N=i[0]+(8191&f),I=i[1]+((f>>>13|m<<3)&8191),A=i[2]+((m>>>10|w<<6)&8191),_=i[3]+((w>>>7|y<<9)&8191),S=i[4]+((y>>>4|b<<12)&8191),O=i[5]+(b>>>1&8191),P=i[6]+((b>>>14|v<<2)&8191),T=i[7]+((v>>>11|C<<5)&8191),R=i[8]+((C>>>8|E<<8)&8191),k=i[9]+(E>>>5|(r?0:2048)),x=0,U=0+N*n+5*g*I+5*p*A+5*u*_+5*d*S;x=U>>>13,U&=8191,U+=5*h*O+5*l*P+5*c*T+5*o*R+5*a*k,x+=U>>>13,U&=8191;let D=x+N*a+I*n+5*g*A+5*p*_+5*u*S;x=D>>>13,D&=8191,D+=5*d*O+5*h*P+5*l*T+5*c*R+5*o*k,x+=D>>>13,D&=8191;let $=x+N*o+I*a+A*n+5*g*_+5*p*S;x=$>>>13,$&=8191,$+=5*u*O+5*d*P+5*h*T+5*l*R+5*c*k,x+=$>>>13,$&=8191;let M=x+N*c+I*o+A*a+_*n+5*g*S;x=M>>>13,M&=8191,M+=5*p*O+5*u*P+5*d*T+5*h*R+5*l*k,x+=M>>>13,M&=8191;let L=x+N*l+I*c+A*o+_*a+S*n;x=L>>>13,L&=8191,L+=5*g*O+5*p*P+5*u*T+5*d*R+5*h*k,x+=L>>>13,L&=8191;let j=x+N*h+I*l+A*c+_*o+S*a;x=j>>>13,j&=8191,j+=O*n+5*g*P+5*p*T+5*u*R+5*d*k,x+=j>>>13,j&=8191;let q=x+N*d+I*h+A*l+_*c+S*o;x=q>>>13,q&=8191,q+=O*a+P*n+5*g*T+5*p*R+5*u*k,x+=q>>>13,q&=8191;let B=x+N*u+I*d+A*h+_*l+S*c;x=B>>>13,B&=8191,B+=O*o+P*a+T*n+5*g*R+5*p*k,x+=B>>>13,B&=8191;let F=x+N*p+I*u+A*d+_*h+S*l;x=F>>>13,F&=8191,F+=O*c+P*o+T*a+R*n+5*g*k,x+=F>>>13,F&=8191;let H=x+N*g+I*p+A*u+_*d+S*h;x=H>>>13,H&=8191,H+=O*l+P*c+T*o+R*a+k*n,x+=H>>>13,H&=8191,U=8191&(x=(x=(x<<2)+x|0)+U|0),x>>>=13,D+=x,i[0]=U,i[1]=D,i[2]=$,i[3]=M,i[4]=L,i[5]=j,i[6]=q,i[7]=B,i[8]=F,i[9]=H}finalize(){let{h:e,pad:t}=this,r=new Uint16Array(10),i=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=i,i=e[t]>>>13,e[t]&=8191;e[0]+=5*i,i=e[0]>>>13,e[0]&=8191,e[1]+=i,i=e[1]>>>13,e[1]&=8191,e[2]+=i,r[0]=e[0]+5,i=r[0]>>>13,r[0]&=8191;for(let t=1;t<10;t++)r[t]=e[t]+i,i=r[t]>>>13,r[t]&=8191;r[9]-=8192;let s=(1^i)-1;for(let e=0;e<10;e++)r[e]&=s;s=~s;for(let t=0;t<10;t++)e[t]=e[t]&s|r[t];e[0]=(e[0]|e[1]<<13)&65535,e[1]=(e[1]>>>3|e[2]<<10)&65535,e[2]=(e[2]>>>6|e[3]<<7)&65535,e[3]=(e[3]>>>9|e[4]<<4)&65535,e[4]=(e[4]>>>12|e[5]<<1|e[6]<<14)&65535,e[5]=(e[6]>>>2|e[7]<<11)&65535,e[6]=(e[7]>>>5|e[8]<<8)&65535,e[7]=(e[8]>>>8|e[9]<<5)&65535;let n=e[0]+t[0];e[0]=65535&n;for(let r=1;r<8;r++)n=(e[r]+t[r]|0)+(n>>>16)|0,e[r]=65535&n;tT(r)}update(e){tE(this);let{buffer:t,blockLen:r}=this,i=(e=t_(e)).length;for(let s=0;s<i;){let n=Math.min(r-this.pos,i-s);if(n===r){for(;r<=i-s;s+=r)this.process(e,s);continue}t.set(e.subarray(s,s+n),this.pos),this.pos+=n,s+=n,this.pos===r&&(this.process(t,0,!1),this.pos=0)}return this}destroy(){tT(this.h,this.r,this.buffer,this.pad)}digestInto(e){tE(this),function(e,t){tC(e);let r=t.outputLen;if(e.length<r)throw Error("digestInto() expects output buffer of length at least "+r)}(e,this),this.finished=!0;let{buffer:t,h:r}=this,{pos:i}=this;if(i){for(t[i++]=1;i<16;i++)t[i]=0;this.process(t,0,!0)}this.finalize();let s=0;for(let t=0;t<8;t++)e[s++]=r[t]>>>0,e[s++]=r[t]>>>8;return e}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}}let tF=function(e){let t=(t,r)=>e(r).update(t_(t)).digest(),r=e(new Uint8Array(32));return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=t=>e(t),t}(e=>new tB(e)),tH=function(e,t){let{allowShortKeys:r,extendNonceFn:i,counterLength:s,counterRight:n,rounds:a}=function(e,t){if(null==t||"object"!=typeof t)throw Error("options must be defined");return Object.assign(e,t)}({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if("function"!=typeof e)throw Error("core must be a function");return tb(s),tb(a),tN(n),tN(r),(t,o,c,l,h=0)=>{tC(t),tC(o),tC(c);let d=c.length;if(void 0===l&&(l=new Uint8Array(d)),tC(l),tb(h),h<0||h>=tL)throw Error("arx: counter overflow");if(l.length<d)throw Error(`arx: output (${l.length}) is shorter than data (${d})`);let u=[],p=t.length,g,f;if(32===p)u.push(g=tP(t)),f=tD;else if(16===p&&r)(g=new Uint8Array(32)).set(t),g.set(t,16),f=tU,u.push(g);else throw Error(`arx: invalid 32-byte key, got length=${p}`);tM(o)||u.push(o=tP(o));let m=tI(g);if(i){if(24!==o.length)throw Error("arx: extended nonce must be 24 bytes");i(f,m,tI(o.subarray(0,16)),m),o=o.subarray(16)}let w=16-s;if(w!==o.length)throw Error(`arx: nonce must be ${w} or 16 bytes`);if(12!==w){let e=new Uint8Array(12);e.set(o,n?0:12-o.length),o=e,u.push(o)}return function(e,t,r,i,s,n,a,o){let c=s.length,l=new Uint8Array(64),h=tI(l),d=tM(s)&&tM(n),u=d?tI(s):tj,p=d?tI(n):tj;for(let g=0;g<c;a++){if(e(t,r,i,h,a,o),a>=tL)throw Error("arx: counter overflow");let f=Math.min(64,c-g);if(d&&64===f){let e=g/4;if(g%4!=0)throw Error("arx: invalid block position");for(let t=0,r;t<16;t++)p[r=e+t]=u[r]^h[t];g+=64;continue}for(let e=0,t;e<f;e++)n[t=g+e]=s[t]^l[e];g+=f}}(e,f,m,tI(o),c,l,h,a),tT(...u),l}}(function(e,t,r,i,s,n=20){let a=e[0],o=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],p=t[3],g=t[4],f=t[5],m=t[6],w=t[7],y=r[0],b=r[1],v=r[2],C=a,E=o,N=c,I=l,A=h,_=d,S=u,O=p,P=g,T=f,R=m,k=w,x=s,U=y,D=b,$=v;for(let e=0;e<n;e+=2)P=P+(x=t$(x^(C=C+A|0),16))|0,C=C+(A=t$(A^P,12))|0,P=P+(x=t$(x^C,8))|0,A=t$(A^P,7),T=T+(U=t$(U^(E=E+_|0),16))|0,E=E+(_=t$(_^T,12))|0,T=T+(U=t$(U^E,8))|0,_=t$(_^T,7),R=R+(D=t$(D^(N=N+S|0),16))|0,N=N+(S=t$(S^R,12))|0,R=R+(D=t$(D^N,8))|0,S=t$(S^R,7),k=k+($=t$($^(I=I+O|0),16))|0,I=I+(O=t$(O^k,12))|0,k=k+($=t$($^I,8))|0,O=t$(O^k,7),R=R+($=t$($^(C=C+_|0),16))|0,C=C+(_=t$(_^R,12))|0,R=R+($=t$($^C,8))|0,_=t$(_^R,7),k=k+(x=t$(x^(E=E+S|0),16))|0,E=E+(S=t$(S^k,12))|0,k=k+(x=t$(x^E,8))|0,S=t$(S^k,7),P=P+(U=t$(U^(N=N+O|0),16))|0,N=N+(O=t$(O^P,12))|0,P=P+(U=t$(U^N,8))|0,O=t$(O^P,7),T=T+(D=t$(D^(I=I+A|0),16))|0,I=I+(A=t$(A^T,12))|0,T=T+(D=t$(D^I,8))|0,A=t$(A^T,7);let M=0;i[M++]=a+C|0,i[M++]=o+E|0,i[M++]=c+N|0,i[M++]=l+I|0,i[M++]=h+A|0,i[M++]=d+_|0,i[M++]=u+S|0,i[M++]=p+O|0,i[M++]=g+P|0,i[M++]=f+T|0,i[M++]=m+R|0,i[M++]=w+k|0,i[M++]=s+x|0,i[M++]=y+U|0,i[M++]=b+D|0,i[M++]=v+$|0},{counterRight:!1,counterLength:4,allowShortKeys:!1}),tW=new Uint8Array(16),tV=(e,t)=>{e.update(t);let r=t.length%16;r&&e.update(tW.subarray(r))},tz=new Uint8Array(32);function tK(e,t,r,i,s){let n=e(t,r,tz),a=tF.create(n);s&&tV(a,s),tV(a,i);let o=new Uint8Array(16),c=tA(o);tO(c,0,BigInt(s?s.length:0),!0),tO(c,8,BigInt(i.length),!0),a.update(o);let l=a.digest();return tT(n,o),l}let tJ=((e,t)=>{function r(i,...s){if(tC(i),void 0!==e.nonceLength){let t=s[0];if(!t)throw Error("nonce / iv required");e.varSizeNonce?tC(t):tC(t,e.nonceLength)}let n=e.tagLength;n&&void 0!==s[1]&&tC(s[1]);let a=t(i,...s),o=(e,t)=>{if(void 0!==t){if(2!==e)throw Error("cipher output not supported");tC(t)}},c=!1;return{encrypt(e,t){if(c)throw Error("cannot encrypt() twice with same key + nonce");return c=!0,tC(e),o(a.encrypt.length,t),a.encrypt(e,t)},decrypt(e,t){if(tC(e),n&&e.length<n)throw Error("invalid ciphertext length: smaller than tagLength="+n);return o(a.decrypt.length,t),a.decrypt(e,t)}}}return Object.assign(r,e),r})({blockSize:64,nonceLength:12,tagLength:16},(e,t,r)=>({encrypt(i,s){let n=i.length;(s=tS(n+16,s,!1)).set(i);let a=s.subarray(0,-16);tH(e,t,a,a,1);let o=tK(tH,e,t,a,r);return s.set(o,n),tT(o),s},decrypt(i,s){s=tS(i.length-16,s,!1);let n=i.subarray(0,-16),a=i.subarray(-16),o=tK(tH,e,t,n,r);if(!function(e,t){if(e.length!==t.length)return!1;let r=0;for(let i=0;i<e.length;i++)r|=e[i]^t[i];return 0===r}(a,o))throw Error("invalid tag");return s.set(i.subarray(0,-16)),tH(e,t,s,s,1),tT(o),s}}));class tG extends eq{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,eA(e);let r=ej(t);if(this.iHash=e.create(),"function"!=typeof this.iHash.update)throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let i=this.blockLen,s=new Uint8Array(i);s.set(r.length>i?e.create().update(r).digest():r);for(let e=0;e<s.length;e++)s[e]^=54;this.iHash.update(s),this.oHash=e.create();for(let e=0;e<s.length;e++)s[e]^=106;this.oHash.update(s),s.fill(0)}update(e){return e_(this),this.iHash.update(e),this}digestInto(e){e_(this),eI(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:r,finished:i,destroyed:s,blockLen:n,outputLen:a}=this;return e.finished=i,e.destroyed=s,e.blockLen=n,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=r._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}let tY=(e,t,r)=>new tG(e,t).update(r).digest();tY.create=(e,t)=>new tG(e,t);let tX=new Uint8Array([0]),tZ=new Uint8Array,tQ=(e,t,r,i,s)=>(function(e,t,r,i=32){if(eA(e),eN(i),i>255*e.outputLen)throw Error("Length should be <= 255*HashLen");let s=Math.ceil(i/e.outputLen);void 0===r&&(r=tZ);let n=new Uint8Array(s*e.outputLen),a=tY.create(e,t),o=a._cloneInto(),c=new Uint8Array(a.outputLen);for(let t=0;t<s;t++)tX[0]=t+1,o.update(0===t?tZ:c).update(r).update(tX).digestInto(c),n.set(c,e.outputLen*t),a._cloneInto(o);return a.destroy(),o.destroy(),c.fill(0),tX.fill(0),n.slice(0,i)})(e,function(e,t,r){return eA(e),void 0===r&&(r=new Uint8Array(e.outputLen)),tY(e,ej(r),ej(t))}(e,t,r),i,s);class t0 extends eq{constructor(e,t,r,i){super(),this.blockLen=e,this.outputLen=t,this.padOffset=r,this.isLE=i,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=eD(this.buffer)}update(e){e_(this);let{view:t,buffer:r,blockLen:i}=this,s=(e=ej(e)).length;for(let n=0;n<s;){let a=Math.min(i-this.pos,s-n);if(a===i){let t=eD(e);for(;i<=s-n;n+=i)this.process(t,n);continue}r.set(e.subarray(n,n+a),this.pos),this.pos+=a,n+=a,this.pos===i&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){e_(this),eS(e,this),this.finished=!0;let{buffer:t,view:r,blockLen:i,isLE:s}=this,{pos:n}=this;t[n++]=128,this.buffer.subarray(n).fill(0),this.padOffset>i-n&&(this.process(r,0),n=0);for(let e=n;e<i;e++)t[e]=0;(function(e,t,r,i){if("function"==typeof e.setBigUint64)return e.setBigUint64(t,r,i);let s=BigInt(32),n=BigInt(4294967295),a=Number(r>>s&n),o=Number(r&n),c=i?4:0,l=i?0:4;e.setUint32(t+c,a,i),e.setUint32(t+l,o,i)})(r,i-8,BigInt(8*this.length),s),this.process(r,0);let a=eD(e),o=this.outputLen;if(o%4)throw Error("_sha2: outputLen should be aligned to 32bit");let c=o/4,l=this.get();if(c>l.length)throw Error("_sha2: outputLen bigger than state");for(let e=0;e<c;e++)a.setUint32(4*e,l[e],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let r=e.slice(0,t);return this.destroy(),r}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:r,length:i,finished:s,destroyed:n,pos:a}=this;return e.length=i,e.pos=a,e.finished=s,e.destroyed=n,i%t&&e.buffer.set(r),e}}let t1=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),t2=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),t5=new Uint32Array(64);class t3 extends t0{constructor(){super(64,32,8,!1),this.A=0|t2[0],this.B=0|t2[1],this.C=0|t2[2],this.D=0|t2[3],this.E=0|t2[4],this.F=0|t2[5],this.G=0|t2[6],this.H=0|t2[7]}get(){let{A:e,B:t,C:r,D:i,E:s,F:n,G:a,H:o}=this;return[e,t,r,i,s,n,a,o]}set(e,t,r,i,s,n,a,o){this.A=0|e,this.B=0|t,this.C=0|r,this.D=0|i,this.E=0|s,this.F=0|n,this.G=0|a,this.H=0|o}process(e,t){for(let r=0;r<16;r++,t+=4)t5[r]=e.getUint32(t,!1);for(let e=16;e<64;e++){let t=t5[e-15],r=t5[e-2],i=e$(t,7)^e$(t,18)^t>>>3,s=e$(r,17)^e$(r,19)^r>>>10;t5[e]=s+t5[e-7]+i+t5[e-16]|0}let{A:r,B:i,C:s,D:n,E:a,F:o,G:c,H:l}=this;for(let e=0;e<64;e++){var h,d,u,p;let t=l+(e$(a,6)^e$(a,11)^e$(a,25))+((h=a)&o^~h&c)+t1[e]+t5[e]|0,g=(e$(r,2)^e$(r,13)^e$(r,22))+((d=r)&(u=i)^d&(p=s)^u&p)|0;l=c,c=o,o=a,a=n+t|0,n=s,s=i,i=r,r=t+g|0}r=r+this.A|0,i=i+this.B|0,s=s+this.C|0,n=n+this.D|0,a=a+this.E|0,o=o+this.F|0,c=c+this.G|0,l=l+this.H|0,this.set(r,i,s,n,a,o,c,l)}roundClean(){t5.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}}let t8=eB(()=>new t3),t4=BigInt(0),t6=BigInt(1),t9=BigInt(2);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function t7(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&"Uint8Array"===e.constructor.name}function re(e){if(!t7(e))throw Error("Uint8Array expected")}function rt(e,t){if("boolean"!=typeof t)throw Error(e+" boolean expected, got "+t)}let rr=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function ri(e){re(e);let t="";for(let r=0;r<e.length;r++)t+=rr[e[r]];return t}function rs(e){let t=e.toString(16);return 1&t.length?"0"+t:t}function rn(e){if("string"!=typeof e)throw Error("hex string expected, got "+typeof e);return""===e?t4:BigInt("0x"+e)}let ra={_0:48,_9:57,A:65,F:70,a:97,f:102};function ro(e){return e>=ra._0&&e<=ra._9?e-ra._0:e>=ra.A&&e<=ra.F?e-(ra.A-10):e>=ra.a&&e<=ra.f?e-(ra.a-10):void 0}function rc(e){if("string"!=typeof e)throw Error("hex string expected, got "+typeof e);let t=e.length,r=t/2;if(t%2)throw Error("hex string expected, got unpadded hex of length "+t);let i=new Uint8Array(r);for(let t=0,s=0;t<r;t++,s+=2){let r=ro(e.charCodeAt(s)),n=ro(e.charCodeAt(s+1));if(void 0===r||void 0===n)throw Error('hex string expected, got non-hex character "'+(e[s]+e[s+1])+'" at index '+s);i[t]=16*r+n}return i}function rl(e){return rn(ri(e))}function rh(e){return re(e),rn(ri(Uint8Array.from(e).reverse()))}function rd(e,t){return rc(e.toString(16).padStart(2*t,"0"))}function ru(e,t){return rd(e,t).reverse()}function rp(e,t,r){let i;if("string"==typeof t)try{i=rc(t)}catch(t){throw Error(e+" must be hex string or Uint8Array, cause: "+t)}else if(t7(t))i=Uint8Array.from(t);else throw Error(e+" must be hex string or Uint8Array");let s=i.length;if("number"==typeof r&&s!==r)throw Error(e+" of length "+r+" expected, got "+s);return i}function rg(...e){let t=0;for(let r=0;r<e.length;r++){let i=e[r];re(i),t+=i.length}let r=new Uint8Array(t);for(let t=0,i=0;t<e.length;t++){let s=e[t];r.set(s,i),i+=s.length}return r}let rf=e=>"bigint"==typeof e&&t4<=e;function rm(e,t,r){return rf(e)&&rf(t)&&rf(r)&&t<=e&&e<r}function rw(e,t,r,i){if(!rm(t,r,i))throw Error("expected valid "+e+": "+r+" <= n < "+i+", got "+t)}function ry(e){let t;for(t=0;e>t4;e>>=t6,t+=1);return t}let rb=e=>(t9<<BigInt(e-1))-t6,rv=e=>new Uint8Array(e),rC=e=>Uint8Array.from(e);function rE(e,t,r){if("number"!=typeof e||e<2)throw Error("hashLen must be a number");if("number"!=typeof t||t<2)throw Error("qByteLen must be a number");if("function"!=typeof r)throw Error("hmacFn must be a function");let i=rv(e),s=rv(e),n=0,a=()=>{i.fill(1),s.fill(0),n=0},o=(...e)=>r(s,i,...e),c=(e=rv())=>{s=o(rC([0]),e),i=o(),0!==e.length&&(s=o(rC([1]),e),i=o())},l=()=>{if(n++>=1e3)throw Error("drbg: tried 1000 values");let e=0,r=[];for(;e<t;){let t=(i=o()).slice();r.push(t),e+=i.length}return rg(...r)};return(e,t)=>{let r;for(a(),c(e);!(r=t(l()));)c();return a(),r}}let rN={bigint:e=>"bigint"==typeof e,function:e=>"function"==typeof e,boolean:e=>"boolean"==typeof e,string:e=>"string"==typeof e,stringOrUint8Array:e=>"string"==typeof e||t7(e),isSafeInteger:e=>Number.isSafeInteger(e),array:e=>Array.isArray(e),field:(e,t)=>t.Fp.isValid(e),hash:e=>"function"==typeof e&&Number.isSafeInteger(e.outputLen)};function rI(e,t,r={}){let i=(t,r,i)=>{let s=rN[r];if("function"!=typeof s)throw Error("invalid validator function");let n=e[t];if(!(i&&void 0===n)&&!s(n,e))throw Error("param "+String(t)+" is invalid. Expected "+r+", got "+n)};for(let[e,r]of Object.entries(t))i(e,r,!1);for(let[e,t]of Object.entries(r))i(e,t,!0);return e}function rA(e){let t=new WeakMap;return(r,...i)=>{let s=t.get(r);if(void 0!==s)return s;let n=e(r,...i);return t.set(r,n),n}}var r_=Object.freeze({__proto__:null,isBytes:t7,abytes:re,abool:rt,bytesToHex:ri,numberToHexUnpadded:rs,hexToNumber:rn,hexToBytes:rc,bytesToNumberBE:rl,bytesToNumberLE:rh,numberToBytesBE:rd,numberToBytesLE:ru,numberToVarBytesBE:function(e){return rc(rs(e))},ensureBytes:rp,concatBytes:rg,equalBytes:function(e,t){if(e.length!==t.length)return!1;let r=0;for(let i=0;i<e.length;i++)r|=e[i]^t[i];return 0===r},utf8ToBytes:function(e){if("string"!=typeof e)throw Error("string expected");return new Uint8Array(new TextEncoder().encode(e))},inRange:rm,aInRange:rw,bitLen:ry,bitGet:function(e,t){return e>>BigInt(t)&t6},bitSet:function(e,t,r){return e|(r?t6:t4)<<BigInt(t)},bitMask:rb,createHmacDrbg:rE,validateObject:rI,notImplemented:()=>{throw Error("not implemented")},memoized:rA});let rS=BigInt(0),rO=BigInt(1),rP=BigInt(2),rT=BigInt(3),rR=BigInt(4),rk=BigInt(5),rx=BigInt(8);function rU(e,t){let r=e%t;return r>=rS?r:t+r}function rD(e,t,r){if(t<rS)throw Error("invalid exponent, negatives unsupported");if(r<=rS)throw Error("invalid modulus");if(r===rO)return rS;let i=rO;for(;t>rS;)t&rO&&(i=i*e%r),e=e*e%r,t>>=rO;return i}function r$(e,t,r){let i=e;for(;t-- >rS;)i*=i,i%=r;return i}function rM(e,t){if(e===rS)throw Error("invert: expected non-zero number");if(t<=rS)throw Error("invert: expected positive modulus, got "+t);let r=rU(e,t),i=t,s=rS,n=rO;for(;r!==rS;){let e=i/r,t=i%r,a=s-n*e;i=r,r=t,s=n,n=a}if(i!==rO)throw Error("invert: does not exist");return rU(s,t)}let rL=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function rj(e,t){let r=void 0!==t?t:e.toString(2).length;return{nBitLength:r,nByteLength:Math.ceil(r/8)}}function rq(e,t,r=!1,i={}){let s;if(e<=rS)throw Error("invalid field: expected ORDER > 0, got "+e);let{nBitLength:n,nByteLength:a}=rj(e,t);if(a>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let o=Object.freeze({ORDER:e,isLE:r,BITS:n,BYTES:a,MASK:rb(n),ZERO:rS,ONE:rO,create:t=>rU(t,e),isValid:t=>{if("bigint"!=typeof t)throw Error("invalid field element: expected bigint, got "+typeof t);return rS<=t&&t<e},is0:e=>e===rS,isOdd:e=>(e&rO)===rO,neg:t=>rU(-t,e),eql:(e,t)=>e===t,sqr:t=>rU(t*t,e),add:(t,r)=>rU(t+r,e),sub:(t,r)=>rU(t-r,e),mul:(t,r)=>rU(t*r,e),pow:(e,t)=>(function(e,t,r){if(r<rS)throw Error("invalid exponent, negatives unsupported");if(r===rS)return e.ONE;if(r===rO)return t;let i=e.ONE,s=t;for(;r>rS;)r&rO&&(i=e.mul(i,s)),s=e.sqr(s),r>>=rO;return i})(o,e,t),div:(t,r)=>rU(t*rM(r,e),e),sqrN:e=>e*e,addN:(e,t)=>e+t,subN:(e,t)=>e-t,mulN:(e,t)=>e*t,inv:t=>rM(t,e),sqrt:i.sqrt||(t=>(s||(s=function(e){if(e%rR===rT){let t=(e+rO)/rR;return function(e,r){let i=e.pow(r,t);if(!e.eql(e.sqr(i),r))throw Error("Cannot find square root");return i}}if(e%rx===rk){let t=(e-rk)/rx;return function(e,r){let i=e.mul(r,rP),s=e.pow(i,t),n=e.mul(r,s),a=e.mul(e.mul(n,rP),s),o=e.mul(n,e.sub(a,e.ONE));if(!e.eql(e.sqr(o),r))throw Error("Cannot find square root");return o}}return function(e){let t,r,i;let s=(e-rO)/rP;for(t=e-rO,r=0;t%rP===rS;t/=rP,r++);for(i=rP;i<e&&rD(i,s,e)!==e-rO;i++)if(i>1e3)throw Error("Cannot find square root: likely non-prime P");if(1===r){let t=(e+rO)/rR;return function(e,r){let i=e.pow(r,t);if(!e.eql(e.sqr(i),r))throw Error("Cannot find square root");return i}}let n=(t+rO)/rP;return function(e,a){if(e.pow(a,s)===e.neg(e.ONE))throw Error("Cannot find square root");let o=r,c=e.pow(e.mul(e.ONE,i),t),l=e.pow(a,n),h=e.pow(a,t);for(;!e.eql(h,e.ONE);){if(e.eql(h,e.ZERO))return e.ZERO;let t=1;for(let r=e.sqr(h);t<o&&!e.eql(r,e.ONE);t++)r=e.sqr(r);let r=e.pow(c,rO<<BigInt(o-t-1));c=e.sqr(r),l=e.mul(l,r),h=e.mul(h,c),o=t}return l}}(e)}(e)),s(o,t))),invertBatch:e=>(function(e,t){let r=Array(t.length),i=t.reduce((t,i,s)=>e.is0(i)?t:(r[s]=t,e.mul(t,i)),e.ONE),s=e.inv(i);return t.reduceRight((t,i,s)=>e.is0(i)?t:(r[s]=e.mul(t,r[s]),e.mul(t,i)),s),r})(o,e),cmov:(e,t,r)=>r?t:e,toBytes:e=>r?ru(e,a):rd(e,a),fromBytes:e=>{if(e.length!==a)throw Error("Field.fromBytes: expected "+a+" bytes, got "+e.length);return r?rh(e):rl(e)}});return Object.freeze(o)}function rB(e){if("bigint"!=typeof e)throw Error("field order must be bigint");return Math.ceil(e.toString(2).length/8)}function rF(e){let t=rB(e);return t+Math.ceil(t/2)}let rH=BigInt(0),rW=BigInt(1);function rV(e,t){let r=t.negate();return e?r:t}function rz(e,t){if(!Number.isSafeInteger(e)||e<=0||e>t)throw Error("invalid window size, expected [1.."+t+"], got W="+e)}function rK(e,t){return rz(e,t),{windows:Math.ceil(t/e)+1,windowSize:2**(e-1)}}let rJ=new WeakMap,rG=new WeakMap;function rY(e){return rG.get(e)||1}function rX(e){return rI(e.Fp,rL.reduce((e,t)=>(e[t]="function",e),{ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"})),rI(e,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...rj(e.n,e.nBitLength),...e,p:e.Fp.ORDER})}BigInt(0),BigInt(1),BigInt(2),BigInt(8);let rZ=BigInt(0),rQ=BigInt(1),r0=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949");BigInt(0);let r1=BigInt(1),r2=BigInt(2),r5=BigInt(3),r3=BigInt(5);BigInt(8);let r8=function(e){let t=(rI(e,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...e})),{P:r}=t,i=e=>rU(e,r),s=t.montgomeryBits,n=Math.ceil(s/8),a=t.nByteLength,o=t.adjustScalarBytes||(e=>e),c=t.powPminus2||(e=>rD(e,r-BigInt(2),r));function l(e,t,r){let s=i(e*(t-r));return[t=i(t-s),r=i(r+s)]}let h=(t.a-BigInt(2))/BigInt(4);function d(e,t){let d=function(e,t){rw("u",e,rZ,r),rw("scalar",t,rZ,r);let n=rQ,a=rZ,o=e,d=rQ,u=rZ,p;for(let r=BigInt(s-1);r>=rZ;r--){let s=t>>r&rQ;u^=s,n=(p=l(u,n,o))[0],o=p[1],a=(p=l(u,a,d))[0],d=p[1],u=s;let c=n+a,g=i(c*c),f=n-a,m=i(f*f),w=g-m,y=o+d,b=i((o-d)*c),v=i(y*f),C=b+v,E=b-v;o=i(C*C),d=i(e*i(E*E)),n=i(g*m),a=i(w*(g+i(h*w)))}return n=(p=l(u,n,o))[0],o=p[1],a=(p=l(u,a,d))[0],d=p[1],i(n*c(a))}(function(e){let t=rp("u coordinate",e,n);return 32===a&&(t[31]&=127),rh(t)}(t),function(e){let t=rp("scalar",e),r=t.length;if(r!==n&&r!==a)throw Error("invalid scalar, expected "+n+" or "+a+" bytes, got "+r);return rh(o(t))}(e));if(d===rZ)throw Error("invalid private or public key received");return ru(i(d),n)}let u=ru(i(t.Gu),n);function p(e){return d(e,u)}return{scalarMult:d,scalarMultBase:p,getSharedSecret:(e,t)=>d(e,t),getPublicKey:e=>p(e),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:u}}({P:r0,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:e=>{let{pow_p_5_8:t,b2:r}=function(e){let t=BigInt(10),r=BigInt(20),i=BigInt(40),s=BigInt(80),n=e*e%r0*e%r0,a=r$(n,r2,r0)*n%r0,o=r$(a,r1,r0)*e%r0,c=r$(o,r3,r0)*o%r0,l=r$(c,t,r0)*c%r0,h=r$(l,r,r0)*l%r0,d=r$(h,i,r0)*h%r0,u=r$(d,s,r0)*d%r0,p=r$(u,s,r0)*d%r0,g=r$(p,t,r0)*c%r0;return{pow_p_5_8:r$(g,r2,r0)*e%r0,b2:n}}(e);return rU(r$(t,r5,r0)*r,r0)},adjustScalarBytes:function(e){return e[0]&=248,e[31]&=127,e[31]|=64,e},randomBytes:eF});function r4(e){void 0!==e.lowS&&rt("lowS",e.lowS),void 0!==e.prehash&&rt("prehash",e.prehash)}let{bytesToNumberBE:r6,hexToBytes:r9}=r_;class r7 extends Error{constructor(e=""){super(e)}}let ie={Err:r7,_tlv:{encode:(e,t)=>{let{Err:r}=ie;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(1&t.length)throw new r("tlv.encode: unpadded data");let i=t.length/2,s=rs(i);if(s.length/2&128)throw new r("tlv.encode: long form length too big");let n=i>127?rs(s.length/2|128):"";return rs(e)+n+s+t},decode(e,t){let{Err:r}=ie,i=0;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length<2||t[i++]!==e)throw new r("tlv.decode: wrong tlv");let s=t[i++],n=0;if(128&s){let e=127&s;if(!e)throw new r("tlv.decode(long): indefinite length not supported");if(e>4)throw new r("tlv.decode(long): byte length is too big");let a=t.subarray(i,i+e);if(a.length!==e)throw new r("tlv.decode: length bytes not complete");if(0===a[0])throw new r("tlv.decode(long): zero leftmost byte");for(let e of a)n=n<<8|e;if(i+=e,n<128)throw new r("tlv.decode(long): not minimal encoding")}else n=s;let a=t.subarray(i,i+n);if(a.length!==n)throw new r("tlv.decode: wrong value length");return{v:a,l:t.subarray(i+n)}}},_int:{encode(e){let{Err:t}=ie;if(e<it)throw new t("integer: negative integers are not allowed");let r=rs(e);if(8&Number.parseInt(r[0],16)&&(r="00"+r),1&r.length)throw new t("unexpected DER parsing assertion: unpadded hex");return r},decode(e){let{Err:t}=ie;if(128&e[0])throw new t("invalid signature integer: negative");if(0===e[0]&&!(128&e[1]))throw new t("invalid signature integer: unnecessary leading zero");return r6(e)}},toSig(e){let{Err:t,_int:r,_tlv:i}=ie,s="string"==typeof e?r9(e):e;re(s);let{v:n,l:a}=i.decode(48,s);if(a.length)throw new t("invalid signature: left bytes after parsing");let{v:o,l:c}=i.decode(2,n),{v:l,l:h}=i.decode(2,c);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:r.decode(o),s:r.decode(l)}},hexFromSig(e){let{_tlv:t,_int:r}=ie,i=t.encode(2,r.encode(e.r)),s=t.encode(2,r.encode(e.s));return t.encode(48,i+s)}},it=BigInt(0),ir=BigInt(1);BigInt(2);let ii=BigInt(3);BigInt(4);let is=rq(BigInt("0xffffffff00000001000000000000000000000000ffffffffffffffffffffffff")),ia=function(e,t){let r=t=>(function(e){let t=function(e){let t=rX(e);return rI(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}(e),{Fp:r,n:i}=t,s=r.BYTES+1,n=2*r.BYTES+1;function a(e){return rU(e,i)}let{ProjectivePoint:o,normPrivateKeyToScalar:c,weierstrassEquation:l,isWithinCurveOrder:h}=function(e){var t;let r=function(e){let t=rX(e);rI(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:r,Fp:i,a:s}=t;if(r){if(!i.eql(s,i.ZERO))throw Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if("object"!=typeof r||"bigint"!=typeof r.beta||"function"!=typeof r.splitScalar)throw Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}(e),{Fp:i}=r,s=rq(r.n,r.nBitLength),n=r.toBytes||((e,t,r)=>{let s=t.toAffine();return rg(Uint8Array.from([4]),i.toBytes(s.x),i.toBytes(s.y))}),a=r.fromBytes||(e=>{let t=e.subarray(1);return{x:i.fromBytes(t.subarray(0,i.BYTES)),y:i.fromBytes(t.subarray(i.BYTES,2*i.BYTES))}});function o(e){let{a:t,b:s}=r,n=i.sqr(e),a=i.mul(n,e);return i.add(i.add(a,i.mul(e,t)),s)}if(!i.eql(i.sqr(r.Gy),o(r.Gx)))throw Error("bad generator point: equation left != right");function c(e){let t;let{allowedPrivateKeyLengths:i,nByteLength:s,wrapPrivateKey:n,n:a}=r;if(i&&"bigint"!=typeof e){if(t7(e)&&(e=ri(e)),"string"!=typeof e||!i.includes(e.length))throw Error("invalid private key");e=e.padStart(2*s,"0")}try{t="bigint"==typeof e?e:rl(rp("private key",e,s))}catch{throw Error("invalid private key, expected hex or "+s+" bytes, got "+typeof e)}return n&&(t=rU(t,a)),rw("private key",t,ir,a),t}function l(e){if(!(e instanceof u))throw Error("ProjectivePoint expected")}let h=rA((e,t)=>{let{px:r,py:s,pz:n}=e;if(i.eql(n,i.ONE))return{x:r,y:s};let a=e.is0();null==t&&(t=a?i.ONE:i.inv(n));let o=i.mul(r,t),c=i.mul(s,t),l=i.mul(n,t);if(a)return{x:i.ZERO,y:i.ZERO};if(!i.eql(l,i.ONE))throw Error("invZ was invalid");return{x:o,y:c}}),d=rA(e=>{if(e.is0()){if(r.allowInfinityPoint&&!i.is0(e.py))return;throw Error("bad point: ZERO")}let{x:t,y:s}=e.toAffine();if(!i.isValid(t)||!i.isValid(s))throw Error("bad point: x or y not FE");let n=i.sqr(s),a=o(t);if(!i.eql(n,a))throw Error("bad point: equation left != right");if(!e.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});class u{constructor(e,t,r){if(this.px=e,this.py=t,this.pz=r,null==e||!i.isValid(e))throw Error("x required");if(null==t||!i.isValid(t))throw Error("y required");if(null==r||!i.isValid(r))throw Error("z required");Object.freeze(this)}static fromAffine(e){let{x:t,y:r}=e||{};if(!e||!i.isValid(t)||!i.isValid(r))throw Error("invalid affine point");if(e instanceof u)throw Error("projective point not allowed");let s=e=>i.eql(e,i.ZERO);return s(t)&&s(r)?u.ZERO:new u(t,r,i.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(e){let t=i.invertBatch(e.map(e=>e.pz));return e.map((e,r)=>e.toAffine(t[r])).map(u.fromAffine)}static fromHex(e){let t=u.fromAffine(a(rp("pointHex",e)));return t.assertValidity(),t}static fromPrivateKey(e){return u.BASE.multiply(c(e))}static msm(e,t){return function(e,t,r,i){if(function(e,t){if(!Array.isArray(e))throw Error("array expected");e.forEach((e,r)=>{if(!(e instanceof t))throw Error("invalid point at index "+r)})}(r,e),function(e,t){if(!Array.isArray(e))throw Error("array of scalars expected");e.forEach((e,r)=>{if(!t.isValid(e))throw Error("invalid scalar at index "+r)})}(i,t),r.length!==i.length)throw Error("arrays of points and scalars must have equal length");let s=e.ZERO,n=ry(BigInt(r.length)),a=n>12?n-3:n>4?n-2:n?2:1,o=(1<<a)-1,c=Array(o+1).fill(s),l=Math.floor((t.BITS-1)/a)*a,h=s;for(let e=l;e>=0;e-=a){c.fill(s);for(let t=0;t<i.length;t++){let s=Number(i[t]>>BigInt(e)&BigInt(o));c[s]=c[s].add(r[t])}let t=s;for(let e=c.length-1,r=s;e>0;e--)r=r.add(c[e]),t=t.add(r);if(h=h.add(t),0!==e)for(let e=0;e<a;e++)h=h.double()}return h}(u,s,e,t)}_setWindowSize(e){g.setWindowSize(this,e)}assertValidity(){d(this)}hasEvenY(){let{y:e}=this.toAffine();if(i.isOdd)return!i.isOdd(e);throw Error("Field doesn't support isOdd")}equals(e){l(e);let{px:t,py:r,pz:s}=this,{px:n,py:a,pz:o}=e,c=i.eql(i.mul(t,o),i.mul(n,s)),h=i.eql(i.mul(r,o),i.mul(a,s));return c&&h}negate(){return new u(this.px,i.neg(this.py),this.pz)}double(){let{a:e,b:t}=r,s=i.mul(t,ii),{px:n,py:a,pz:o}=this,c=i.ZERO,l=i.ZERO,h=i.ZERO,d=i.mul(n,n),p=i.mul(a,a),g=i.mul(o,o),f=i.mul(n,a);return f=i.add(f,f),h=i.mul(n,o),h=i.add(h,h),c=i.mul(e,h),l=i.mul(s,g),l=i.add(c,l),c=i.sub(p,l),l=i.add(p,l),l=i.mul(c,l),c=i.mul(f,c),h=i.mul(s,h),g=i.mul(e,g),f=i.sub(d,g),f=i.mul(e,f),f=i.add(f,h),h=i.add(d,d),d=i.add(h,d),d=i.add(d,g),d=i.mul(d,f),l=i.add(l,d),g=i.mul(a,o),g=i.add(g,g),d=i.mul(g,f),c=i.sub(c,d),h=i.mul(g,p),h=i.add(h,h),new u(c,l,h=i.add(h,h))}add(e){l(e);let{px:t,py:s,pz:n}=this,{px:a,py:o,pz:c}=e,h=i.ZERO,d=i.ZERO,p=i.ZERO,g=r.a,f=i.mul(r.b,ii),m=i.mul(t,a),w=i.mul(s,o),y=i.mul(n,c),b=i.add(t,s),v=i.add(a,o);b=i.mul(b,v),v=i.add(m,w),b=i.sub(b,v),v=i.add(t,n);let C=i.add(a,c);return v=i.mul(v,C),C=i.add(m,y),v=i.sub(v,C),C=i.add(s,n),h=i.add(o,c),C=i.mul(C,h),h=i.add(w,y),C=i.sub(C,h),p=i.mul(g,v),h=i.mul(f,y),p=i.add(h,p),h=i.sub(w,p),p=i.add(w,p),d=i.mul(h,p),w=i.add(m,m),w=i.add(w,m),y=i.mul(g,y),v=i.mul(f,v),w=i.add(w,y),y=i.sub(m,y),y=i.mul(g,y),v=i.add(v,y),m=i.mul(w,v),d=i.add(d,m),m=i.mul(C,v),h=i.mul(b,h),h=i.sub(h,m),m=i.mul(b,w),p=i.mul(C,p),new u(h,d,p=i.add(p,m))}subtract(e){return this.add(e.negate())}is0(){return this.equals(u.ZERO)}wNAF(e){return g.wNAFCached(this,e,u.normalizeZ)}multiplyUnsafe(e){let{endo:t,n:s}=r;rw("scalar",e,it,s);let n=u.ZERO;if(e===it)return n;if(this.is0()||e===ir)return this;if(!t||g.hasPrecomputes(this))return g.wNAFCachedUnsafe(this,e,u.normalizeZ);let{k1neg:a,k1:o,k2neg:c,k2:l}=t.splitScalar(e),h=n,d=n,p=this;for(;o>it||l>it;)o&ir&&(h=h.add(p)),l&ir&&(d=d.add(p)),p=p.double(),o>>=ir,l>>=ir;return a&&(h=h.negate()),c&&(d=d.negate()),d=new u(i.mul(d.px,t.beta),d.py,d.pz),h.add(d)}multiply(e){let t,s;let{endo:n,n:a}=r;if(rw("scalar",e,ir,a),n){let{k1neg:r,k1:a,k2neg:o,k2:c}=n.splitScalar(e),{p:l,f:h}=this.wNAF(a),{p:d,f:p}=this.wNAF(c);l=g.constTimeNegate(r,l),d=g.constTimeNegate(o,d),d=new u(i.mul(d.px,n.beta),d.py,d.pz),t=l.add(d),s=h.add(p)}else{let{p:r,f:i}=this.wNAF(e);t=r,s=i}return u.normalizeZ([t,s])[0]}multiplyAndAddUnsafe(e,t,r){let i=u.BASE,s=(e,t)=>t!==it&&t!==ir&&e.equals(i)?e.multiply(t):e.multiplyUnsafe(t),n=s(this,t).add(s(e,r));return n.is0()?void 0:n}toAffine(e){return h(this,e)}isTorsionFree(){let{h:e,isTorsionFree:t}=r;if(e===ir)return!0;if(t)return t(u,this);throw Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:e,clearCofactor:t}=r;return e===ir?this:t?t(u,this):this.multiplyUnsafe(r.h)}toRawBytes(e=!0){return rt("isCompressed",e),this.assertValidity(),n(u,this,e)}toHex(e=!0){return rt("isCompressed",e),ri(this.toRawBytes(e))}}u.BASE=new u(r.Gx,r.Gy,i.ONE),u.ZERO=new u(i.ZERO,i.ONE,i.ZERO);let p=r.nBitLength,g=(t=r.endo?Math.ceil(p/2):p,{constTimeNegate:rV,hasPrecomputes:e=>1!==rY(e),unsafeLadder(e,t,r=u.ZERO){let i=e;for(;t>rH;)t&rW&&(r=r.add(i)),i=i.double(),t>>=rW;return r},precomputeWindow(e,r){let{windows:i,windowSize:s}=rK(r,t),n=[],a=e,o=a;for(let e=0;e<i;e++){o=a,n.push(o);for(let e=1;e<s;e++)o=o.add(a),n.push(o);a=o.double()}return n},wNAF(e,r,i){let{windows:s,windowSize:n}=rK(e,t),a=u.ZERO,o=u.BASE,c=BigInt(2**e-1),l=2**e,h=BigInt(e);for(let e=0;e<s;e++){let t=e*n,s=Number(i&c);i>>=h,s>n&&(s-=l,i+=rW);let d=t+Math.abs(s)-1,u=e%2!=0,p=s<0;0===s?o=o.add(rV(u,r[t])):a=a.add(rV(p,r[d]))}return{p:a,f:o}},wNAFUnsafe(e,r,i,s=u.ZERO){let{windows:n,windowSize:a}=rK(e,t),o=BigInt(2**e-1),c=2**e,l=BigInt(e);for(let e=0;e<n;e++){let t=e*a;if(i===rH)break;let n=Number(i&o);if(i>>=l,n>a&&(n-=c,i+=rW),0===n)continue;let h=r[t+Math.abs(n)-1];n<0&&(h=h.negate()),s=s.add(h)}return s},getPrecomputes(e,t,r){let i=rJ.get(t);return i||(i=this.precomputeWindow(t,e),1!==e&&rJ.set(t,r(i))),i},wNAFCached(e,t,r){let i=rY(e);return this.wNAF(i,this.getPrecomputes(i,e,r),t)},wNAFCachedUnsafe(e,t,r,i){let s=rY(e);return 1===s?this.unsafeLadder(e,t,i):this.wNAFUnsafe(s,this.getPrecomputes(s,e,r),t,i)},setWindowSize(e,r){rz(r,t),rG.set(e,r),rJ.delete(e)}});return{CURVE:r,ProjectivePoint:u,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:function(e){return rm(e,ir,r.n)}}}({...t,toBytes(e,t,i){let s=t.toAffine(),n=r.toBytes(s.x);return rt("isCompressed",i),i?rg(Uint8Array.from([t.hasEvenY()?2:3]),n):rg(Uint8Array.from([4]),n,r.toBytes(s.y))},fromBytes(e){let t=e.length,i=e[0],a=e.subarray(1);if(t===s&&(2===i||3===i)){let e;let t=rl(a);if(!rm(t,ir,r.ORDER))throw Error("Point is not on curve");let s=l(t);try{e=r.sqrt(s)}catch(e){throw Error("Point is not on curve"+(e instanceof Error?": "+e.message:""))}return(1&i)==1!=((e&ir)===ir)&&(e=r.neg(e)),{x:t,y:e}}if(t===n&&4===i)return{x:r.fromBytes(a.subarray(0,r.BYTES)),y:r.fromBytes(a.subarray(r.BYTES,2*r.BYTES))};throw Error("invalid Point, expected length of "+s+", or uncompressed "+n+", got "+t)}}),d=e=>ri(rd(e,t.nByteLength)),u=(e,t,r)=>rl(e.slice(t,r));class p{constructor(e,t,r){this.r=e,this.s=t,this.recovery=r,this.assertValidity()}static fromCompact(e){let r=t.nByteLength;return new p(u(e=rp("compactSignature",e,2*r),0,r),u(e,r,2*r))}static fromDER(e){let{r:t,s:r}=ie.toSig(rp("DER",e));return new p(t,r)}assertValidity(){rw("r",this.r,ir,i),rw("s",this.s,ir,i)}addRecoveryBit(e){return new p(this.r,this.s,e)}recoverPublicKey(e){let{r:s,s:n,recovery:c}=this,l=m(rp("msgHash",e));if(null==c||![0,1,2,3].includes(c))throw Error("recovery id invalid");let h=2===c||3===c?s+t.n:s;if(h>=r.ORDER)throw Error("recovery id 2 or 3 invalid");let u=(1&c)==0?"02":"03",p=o.fromHex(u+d(h)),g=rM(h,i),f=a(-l*g),w=a(n*g),y=o.BASE.multiplyAndAddUnsafe(p,f,w);if(!y)throw Error("point at infinify");return y.assertValidity(),y}hasHighS(){return this.s>i>>ir}normalizeS(){return this.hasHighS()?new p(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return rc(this.toDERHex())}toDERHex(){return ie.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return rc(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}function g(e){let t=t7(e),r="string"==typeof e,i=(t||r)&&e.length;return t?i===s||i===n:r?i===2*s||i===2*n:e instanceof o}let f=t.bits2int||function(e){if(e.length>8192)throw Error("input is too large");let r=rl(e),i=8*e.length-t.nBitLength;return i>0?r>>BigInt(i):r},m=t.bits2int_modN||function(e){return a(f(e))},w=rb(t.nBitLength);function y(e){return rw("num < 2^"+t.nBitLength,e,it,w),rd(e,t.nByteLength)}let b={lowS:t.lowS,prehash:!1},v={lowS:t.lowS,prehash:!1};return o.BASE._setWindowSize(8),{CURVE:t,getPublicKey:function(e,t=!0){return o.fromPrivateKey(e).toRawBytes(t)},getSharedSecret:function(e,t,r=!0){if(g(e))throw Error("first arg must be private key");if(!g(t))throw Error("second arg must be public key");return o.fromHex(t).multiply(c(e)).toRawBytes(r)},sign:function(e,s,n=b){let{seed:l,k2sig:d}=function(e,s,n=b){if(["recovered","canonical"].some(e=>e in n))throw Error("sign() legacy options not supported");let{hash:l,randomBytes:d}=t,{lowS:u,prehash:g,extraEntropy:w}=n;null==u&&(u=!0),e=rp("msgHash",e),r4(n),g&&(e=rp("prehashed msgHash",l(e)));let v=m(e),C=c(s),E=[y(C),y(v)];if(null!=w&&!1!==w){let e=!0===w?d(r.BYTES):w;E.push(rp("extraEntropy",e))}return{seed:rg(...E),k2sig:function(e){let t=f(e);if(!h(t))return;let r=rM(t,i),s=o.BASE.multiply(t).toAffine(),n=a(s.x);if(n===it)return;let c=a(r*a(v+n*C));if(c===it)return;let l=(s.x===n?0:2)|Number(s.y&ir),d=c;return u&&c>i>>ir&&(d=c>i>>ir?a(-c):c,l^=1),new p(n,d,l)}}}(e,s,n);return rE(t.hash.outputLen,t.nByteLength,t.hmac)(l,d)},verify:function(e,r,s,n=v){let c,l;r=rp("msgHash",r),s=rp("publicKey",s);let{lowS:h,prehash:d,format:u}=n;if(r4(n),"strict"in n)throw Error("options.strict was renamed to lowS");if(void 0!==u&&"compact"!==u&&"der"!==u)throw Error("format must be compact or der");let g="string"==typeof e||t7(e),f=!g&&!u&&"object"==typeof e&&null!==e&&"bigint"==typeof e.r&&"bigint"==typeof e.s;if(!g&&!f)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");try{if(f&&(c=new p(e.r,e.s)),g){try{"compact"!==u&&(c=p.fromDER(e))}catch(e){if(!(e instanceof ie.Err))throw e}c||"der"===u||(c=p.fromCompact(e))}l=o.fromHex(s)}catch{return!1}if(!c||h&&c.hasHighS())return!1;d&&(r=t.hash(r));let{r:w,s:y}=c,b=m(r),C=rM(y,i),E=a(b*C),N=a(w*C),I=o.BASE.multiplyAndAddUnsafe(l,E,N)?.toAffine();return!!I&&a(I.x)===w},ProjectivePoint:o,Signature:p,utils:{isValidPrivateKey(e){try{return c(e),!0}catch{return!1}},normPrivateKeyToScalar:c,randomPrivateKey:()=>{let e=rF(t.n);return function(e,t,r=!1){let i=e.length,s=rB(t),n=rF(t);if(i<16||i<n||i>1024)throw Error("expected "+n+"-1024 bytes of input, got "+i);let a=rU(r?rh(e):rl(e),t-rO)+rO;return r?ru(a,s):rd(a,s)}(t.randomBytes(e),t.n)},precompute:(e=8,t=o.BASE)=>(t._setWindowSize(e),t.multiply(BigInt(3)),t)}}})({...e,hash:t,hmac:(e,...r)=>tY(t,e,function(...e){let t=0;for(let r=0;r<e.length;r++){let i=e[r];eI(i),t+=i.length}let r=new Uint8Array(t);for(let t=0,i=0;t<e.length;t++){let s=e[t];r.set(s,i),i+=s.length}return r}(...r)),randomBytes:eF});return{...r(t),create:r}}({a:is.create(BigInt("-3")),b:BigInt("0x5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b"),Fp:is,n:BigInt("0xffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551"),Gx:BigInt("0x6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296"),Gy:BigInt("0x4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5"),h:BigInt(1),lowS:!1},t8),io="base10",ic="base16",il="base64pad",ih="base64url",id="utf8";function iu(){let e=eF(32);return(0,j.BB)(e,ic)}function ip(e){let t=t8((0,j.mL)(e,ic));return(0,j.BB)(t,ic)}function ig(e){let t=t8((0,j.mL)(e,id));return(0,j.BB)(t,ic)}function im(e){return(0,j.mL)(`${e}`,io)}function iw(e){return Number((0,j.BB)(e,io))}function iy(e){return e.replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function ib(e){let t=e.replace(/-/g,"+").replace(/_/g,"/"),r=(4-t.length%4)%4;return t+"=".repeat(r)}function iv(e){if(2===iw(e.type))return(0,j.BB)((0,j.zo)([e.type,e.sealed]),il);if(1===iw(e.type)){if(typeof e.senderPublicKey>"u")throw Error("Missing sender public key for type 1 envelope");return(0,j.BB)((0,j.zo)([e.type,e.senderPublicKey,e.iv,e.sealed]),il)}return(0,j.BB)((0,j.zo)([e.type,e.iv,e.sealed]),il)}function iC(e){let t=(e.encoding||il)===ih?ib(e.encoded):e.encoded,r=(0,j.mL)(t,il),i=r.slice(0,1);if(1===iw(i)){let e=r.slice(1,33),t=r.slice(33,45);return{type:i,sealed:r.slice(45),iv:t,senderPublicKey:e}}if(2===iw(i))return{type:i,sealed:r.slice(1),iv:eF(12)};let s=r.slice(1,13);return{type:i,sealed:r.slice(13),iv:s}}function iE(e){let t=e?.type||0;if(1===t){if(typeof e?.senderPublicKey>"u")throw Error("missing sender public key");if(typeof e?.receiverPublicKey>"u")throw Error("missing receiver public key")}return{type:t,senderPublicKey:e?.senderPublicKey,receiverPublicKey:e?.receiverPublicKey}}function iN(e){return 1===e.type&&"string"==typeof e.senderPublicKey&&"string"==typeof e.receiverPublicKey}function iI(e){return e?.relay||{protocol:"irn"}}function iA(e){let t=q.iO[e];if(typeof t>"u")throw Error(`Relay Protocol not supported: ${e}`);return t}function i_(e){var t;if(!e.includes("wc:")){let t=eE(e);null!=t&&t.includes("wc:")&&(e=t)}let r=(e=(e=e.includes("wc://")?e.replace("wc://",""):e).includes("wc:")?e.replace("wc:",""):e).indexOf(":"),i=-1!==e.indexOf("?")?e.indexOf("?"):void 0,s=e.substring(0,r),n=e.substring(r+1,i).split("@"),a=new URLSearchParams("u">typeof i?e.substring(i):""),o={};a.forEach((e,t)=>{o[t]=e});let c="string"==typeof o.methods?o.methods.split(","):void 0;return{protocol:s,topic:(t=n[0]).startsWith("//")?t.substring(2):t,version:parseInt(n[1],10),symKey:o.symKey,relay:function(e,t="-"){let r={},i="relay"+t;return Object.keys(e).forEach(t=>{if(t.startsWith(i)){let s=t.replace(i,""),n=e[t];r[s]=n}}),r}(o),methods:c,expiryTimestamp:o.expiryTimestamp?parseInt(o.expiryTimestamp,10):void 0}}function iS(e){let t=new URLSearchParams,r=function(e,t="-"){let r={};return Object.keys(e).forEach(i=>{e[i]&&(r["relay"+t+i]=e[i])}),r}(e.relay);Object.keys(r).sort().forEach(e=>{t.set(e,r[e])}),t.set("symKey",e.symKey),e.expiryTimestamp&&t.set("expiryTimestamp",e.expiryTimestamp.toString()),e.methods&&t.set("methods",e.methods.join(","));let i=t.toString();return`${e.protocol}:${e.topic}@${e.version}?${i}`}function iO(e,t,r){return`${e}?wc_ev=${r}&topic=${t}`}var iP=Object.defineProperty,iT=Object.defineProperties,iR=Object.getOwnPropertyDescriptors,ik=Object.getOwnPropertySymbols,ix=Object.prototype.hasOwnProperty,iU=Object.prototype.propertyIsEnumerable,iD=(e,t,r)=>t in e?iP(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,i$=(e,t)=>{for(var r in t||(t={}))ix.call(t,r)&&iD(e,r,t[r]);if(ik)for(var r of ik(t))iU.call(t,r)&&iD(e,r,t[r]);return e},iM=(e,t)=>iT(e,iR(t));function iL(e){let t=[];return e.forEach(e=>{let[r,i]=e.split(":");t.push(`${r}:${i}`)}),t}function ij(e){return e.includes(":")}function iq(e){return ij(e)?e.split(":")[0]:e}function iB(e){var t,r,i;let s={};if(!iJ(e))return s;for(let[n,a]of Object.entries(e)){let e=ij(n)?[n]:a.chains,o=a.methods||[],c=a.events||[],l=iq(n);s[l]=iM(i$({},s[l]),{chains:em(e,null==(t=s[l])?void 0:t.chains),methods:em(o,null==(r=s[l])?void 0:r.methods),events:em(c,null==(i=s[l])?void 0:i.events)})}return s}function iF(e,t){let r=function(e){let t={};return e?.forEach(e=>{var r;let[i,s]=e.split(":");t[i]||(t[i]={accounts:[],chains:[],events:[],methods:[]}),t[i].accounts.push(e),null==(r=t[i].chains)||r.push(`${i}:${s}`)}),t}(t=t.map(e=>e.replace("did:pkh:","")));for(let[t,i]of Object.entries(r))i.methods?i.methods=em(i.methods,e):i.methods=e,i.events=["chainChanged","accountsChanged"];return r}let iH={INVALID_METHOD:{message:"Invalid method.",code:1001},INVALID_EVENT:{message:"Invalid event.",code:1002},INVALID_UPDATE_REQUEST:{message:"Invalid update request.",code:1003},INVALID_EXTEND_REQUEST:{message:"Invalid extend request.",code:1004},INVALID_SESSION_SETTLE_REQUEST:{message:"Invalid session settle request.",code:1005},UNAUTHORIZED_METHOD:{message:"Unauthorized method.",code:3001},UNAUTHORIZED_EVENT:{message:"Unauthorized event.",code:3002},UNAUTHORIZED_UPDATE_REQUEST:{message:"Unauthorized update request.",code:3003},UNAUTHORIZED_EXTEND_REQUEST:{message:"Unauthorized extend request.",code:3004},USER_REJECTED:{message:"User rejected.",code:5e3},USER_REJECTED_CHAINS:{message:"User rejected chains.",code:5001},USER_REJECTED_METHODS:{message:"User rejected methods.",code:5002},USER_REJECTED_EVENTS:{message:"User rejected events.",code:5003},UNSUPPORTED_CHAINS:{message:"Unsupported chains.",code:5100},UNSUPPORTED_METHODS:{message:"Unsupported methods.",code:5101},UNSUPPORTED_EVENTS:{message:"Unsupported events.",code:5102},UNSUPPORTED_ACCOUNTS:{message:"Unsupported accounts.",code:5103},UNSUPPORTED_NAMESPACE_KEY:{message:"Unsupported namespace key.",code:5104},USER_DISCONNECTED:{message:"User disconnected.",code:6e3},SESSION_SETTLEMENT_FAILED:{message:"Session settlement failed.",code:7e3},WC_METHOD_UNSUPPORTED:{message:"Unsupported wc_ method.",code:10001}},iW={NOT_INITIALIZED:{message:"Not initialized.",code:1},NO_MATCHING_KEY:{message:"No matching key.",code:2},RESTORE_WILL_OVERRIDE:{message:"Restore will override.",code:3},RESUBSCRIBED:{message:"Resubscribed.",code:4},MISSING_OR_INVALID:{message:"Missing or invalid.",code:5},EXPIRED:{message:"Expired.",code:6},UNKNOWN_TYPE:{message:"Unknown type.",code:7},MISMATCHED_TOPIC:{message:"Mismatched topic.",code:8},NON_CONFORMING_NAMESPACES:{message:"Non conforming namespaces.",code:9}};function iV(e,t){let{message:r,code:i}=iW[e];return{message:t?`${r} ${t}`:r,code:i}}function iz(e,t){let{message:r,code:i}=iH[e];return{message:t?`${r} ${t}`:r,code:i}}function iK(e,t){return!!Array.isArray(e)&&(!("u">typeof t)||!e.length||e.every(t))}function iJ(e){return Object.getPrototypeOf(e)===Object.prototype&&Object.keys(e).length}function iG(e){return typeof e>"u"}function iY(e,t){return!!(t&&iG(e))||"string"==typeof e&&!!e.trim().length}function iX(e,t){return!!(t&&iG(e))||"number"==typeof e&&!isNaN(e)}function iZ(e){return!!(iY(e,!1)&&e.includes(":"))&&2===e.split(":").length}function iQ(e){let t=!0;return iK(e)?e.length&&(t=e.every(e=>iY(e,!1))):t=!1,t}function i0(e,t){let r=null;return Object.values(e).forEach(e=>{var i;let s;if(r)return;let n=(i=`${t}, namespace`,s=null,iQ(e?.methods)?iQ(e?.events)||(s=iz("UNSUPPORTED_EVENTS",`${i}, events should be an array of strings or empty array for no events`)):s=iz("UNSUPPORTED_METHODS",`${i}, methods should be an array of strings or empty array for no methods`),s);n&&(r=n)}),r}function i1(e,t){let r=null;if(e&&iJ(e)){let i;let s=i0(e,t);s&&(r=s);let n=(i=null,Object.values(e).forEach(e=>{var r,s;let n;if(i)return;let a=(r=e?.accounts,s=`${t} namespace`,n=null,iK(r)?r.forEach(e=>{n||function(e){if(iY(e,!1)&&e.includes(":")){let t=e.split(":");if(3===t.length){let e=t[0]+":"+t[1];return!!t[2]&&iZ(e)}}return!1}(e)||(n=iz("UNSUPPORTED_ACCOUNTS",`${s}, account ${e} should be a string and conform to "namespace:chainId:address" format`))}):n=iz("UNSUPPORTED_ACCOUNTS",`${s}, accounts should be an array of strings conforming to "namespace:chainId:address" format`),n);a&&(i=a)}),i);n&&(r=n)}else r=iV("MISSING_OR_INVALID",`${t}, namespaces should be an object with data`);return r}function i2(e){return iY(e.protocol,!0)}function i5(e){return"u">typeof e}function i3(e,t){return!(!iZ(t)||!(function(e){let t=[];return Object.values(e).forEach(e=>{t.push(...iL(e.accounts))}),t})(e).includes(t))}function i8(e,t,r){let i=null,s=function(e){let t={};return Object.keys(e).forEach(r=>{var i;r.includes(":")?t[r]=e[r]:null==(i=e[r].chains)||i.forEach(i=>{t[i]={methods:e[r].methods,events:e[r].events}})}),t}(e),n=function(e){let t={};return Object.keys(e).forEach(r=>{if(r.includes(":"))t[r]=e[r];else{let i=iL(e[r].accounts);i?.forEach(i=>{t[i]={accounts:e[r].accounts.filter(e=>e.includes(`${i}:`)),methods:e[r].methods,events:e[r].events}})}}),t}(t),a=Object.keys(s),o=Object.keys(n),c=i4(Object.keys(e)),l=i4(Object.keys(t)),h=c.filter(e=>!l.includes(e));return h.length&&(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces keys don't satisfy requiredNamespaces.
5
5
  Required: ${h.toString()}
6
6
  Received: ${Object.keys(t).toString()}`)),ea(a,o)||(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces chains don't satisfy required namespaces.
7
7
  Required: ${a.toString()}
8
8
  Approved: ${o.toString()}`)),Object.keys(t).forEach(e=>{if(!e.includes(":")||i)return;let s=iL(t[e].accounts);s.includes(e)||(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces accounts don't satisfy namespace accounts for ${e}
9
9
  Required: ${e}
10
- Approved: ${s.toString()}`))}),a.forEach(e=>{i||(ea(s[e].methods,n[e].methods)?ea(s[e].events,n[e].events)||(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces events don't satisfy namespace events for ${e}`)):i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces methods don't satisfy namespace methods for ${e}`))}),i}function i8(e){return[...new Set(e.map(e=>e.includes(":")?e.split(":")[0]:e))]}function i6(){let e=er();return new Promise(t=>{switch(e){case Z.browser:t(et()&&navigator?.onLine);break;case Z.reactNative:t(i9());break;case Z.node:default:t(!0)}})}async function i9(){if(ee()&&"u">typeof global&&null!=global&&global.NetInfo){let e=await (null==global?void 0:global.NetInfo.fetch());return e?.isConnected}return!0}let i7={};class se{static get(e){return i7[e]}static set(e,t){i7[e]=t}static delete(e){delete i7[e]}}var st=r(44926),sr=r(26560),si=r(76755);let ss="core",sn=`wc@2:${ss}:`,sa={logger:"error"},so={database:":memory:"},sc="client_ed25519_seed",sl=R.ONE_DAY,sh=R.SIX_HOURS,sd="wss://relay.walletconnect.org",su={message:"relayer_message",message_ack:"relayer_message_ack",connect:"relayer_connect",disconnect:"relayer_disconnect",error:"relayer_error",connection_stalled:"relayer_connection_stalled",publish:"relayer_publish"},sp={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},sg="2.21.0",sf={link_mode:"link_mode",relay:"relay"},sm={inbound:"inbound",outbound:"outbound"},sw="WALLETCONNECT_LINK_MODE_APPS",sy={created:"subscription_created",deleted:"subscription_deleted",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},sb=(R.FIVE_SECONDS,{wc_pairingDelete:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:R.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:R.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:R.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:R.ONE_DAY,prompt:!1,tag:0},res:{ttl:R.ONE_DAY,prompt:!1,tag:0}}}),sv={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},sC={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},sE={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},sN="https://verify.walletconnect.org",sI=`${sN}/v3`,sA=["https://verify.walletconnect.com",sN],s_={pairing_started:"pairing_started",pairing_uri_validation_success:"pairing_uri_validation_success",pairing_uri_not_expired:"pairing_uri_not_expired",store_new_pairing:"store_new_pairing",subscribing_pairing_topic:"subscribing_pairing_topic",subscribe_pairing_topic_success:"subscribe_pairing_topic_success",existing_pairing:"existing_pairing",pairing_not_expired:"pairing_not_expired",emit_inactive_pairing:"emit_inactive_pairing",emit_session_proposal:"emit_session_proposal"},sS={no_internet_connection:"no_internet_connection",malformed_pairing_uri:"malformed_pairing_uri",active_pairing_already_exists:"active_pairing_already_exists",subscribe_pairing_topic_failure:"subscribe_pairing_topic_failure",pairing_expired:"pairing_expired",proposal_listener_not_found:"proposal_listener_not_found"},sO={session_approve_started:"session_approve_started",session_namespaces_validation_success:"session_namespaces_validation_success",subscribing_session_topic:"subscribing_session_topic",subscribe_session_topic_success:"subscribe_session_topic_success",publishing_session_approve:"publishing_session_approve",session_approve_publish_success:"session_approve_publish_success",store_session:"store_session",publishing_session_settle:"publishing_session_settle",session_settle_publish_success:"session_settle_publish_success"},sP={no_internet_connection:"no_internet_connection",proposal_expired:"proposal_expired",subscribe_session_topic_failure:"subscribe_session_topic_failure",session_approve_publish_failure:"session_approve_publish_failure",session_settle_publish_failure:"session_settle_publish_failure",session_approve_namespace_validation_failure:"session_approve_namespace_validation_failure",proposal_not_found:"proposal_not_found"},sT={authenticated_session_approve_started:"authenticated_session_approve_started",create_authenticated_session_topic:"create_authenticated_session_topic",cacaos_verified:"cacaos_verified",store_authenticated_session:"store_authenticated_session",subscribing_authenticated_session_topic:"subscribing_authenticated_session_topic",subscribe_authenticated_session_topic_success:"subscribe_authenticated_session_topic_success",publishing_authenticated_session_approve:"publishing_authenticated_session_approve"},sR={no_internet_connection:"no_internet_connection",invalid_cacao:"invalid_cacao",subscribe_authenticated_session_topic_failure:"subscribe_authenticated_session_topic_failure",authenticated_session_approve_publish_failure:"authenticated_session_approve_publish_failure",authenticated_session_pending_request_not_found:"authenticated_session_pending_request_not_found"};var sk=function(e,t){if(e.length>=255)throw TypeError("Alphabet too long");for(var r=new Uint8Array(256),i=0;i<r.length;i++)r[i]=255;for(var s=0;s<e.length;s++){var n=e.charAt(s),a=n.charCodeAt(0);if(255!==r[a])throw TypeError(n+" is ambiguous");r[a]=s}var o=e.length,c=e.charAt(0),l=Math.log(o)/Math.log(256),h=Math.log(256)/Math.log(o);function d(e){if("string"!=typeof e)throw TypeError("Expected String");if(0===e.length)return new Uint8Array;var t=0;if(" "!==e[0]){for(var i=0,s=0;e[t]===c;)i++,t++;for(var n=(e.length-t)*l+1>>>0,a=new Uint8Array(n);e[t];){var h=r[e.charCodeAt(t)];if(255===h)return;for(var d=0,u=n-1;(0!==h||d<s)&&-1!==u;u--,d++)h+=o*a[u]>>>0,a[u]=h%256>>>0,h=h/256>>>0;if(0!==h)throw Error("Non-zero carry");s=d,t++}if(" "!==e[t]){for(var p=n-s;p!==n&&0===a[p];)p++;for(var g=new Uint8Array(i+(n-p)),f=i;p!==n;)g[f++]=a[p++];return g}}}return{encode:function(t){if(t instanceof Uint8Array||(ArrayBuffer.isView(t)?t=new Uint8Array(t.buffer,t.byteOffset,t.byteLength):Array.isArray(t)&&(t=Uint8Array.from(t))),!(t instanceof Uint8Array))throw TypeError("Expected Uint8Array");if(0===t.length)return"";for(var r=0,i=0,s=0,n=t.length;s!==n&&0===t[s];)s++,r++;for(var a=(n-s)*h+1>>>0,l=new Uint8Array(a);s!==n;){for(var d=t[s],u=0,p=a-1;(0!==d||u<i)&&-1!==p;p--,u++)d+=256*l[p]>>>0,l[p]=d%o>>>0,d=d/o>>>0;if(0!==d)throw Error("Non-zero carry");i=u,s++}for(var g=a-i;g!==a&&0===l[g];)g++;for(var f=c.repeat(r);g<a;++g)f+=e.charAt(l[g]);return f},decodeUnsafe:d,decode:function(e){var r=d(e);if(r)return r;throw Error(`Non-${t} character`)}}};let sx=e=>{if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw Error("Unknown type, must be binary type")},sU=e=>new TextEncoder().encode(e),sD=e=>new TextDecoder().decode(e);class s${constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class sM{constructor(e,t,r){if(this.name=e,this.prefix=t,void 0===t.codePointAt(0))throw Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=r}decode(e){if("string"==typeof e){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}throw Error("Can only multibase decode strings")}or(e){return sj(this,e)}}class sL{constructor(e){this.decoders=e}or(e){return sj(this,e)}decode(e){let t=e[0],r=this.decoders[t];if(r)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}let sj=(e,t)=>new sL({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}});class sq{constructor(e,t,r,i){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=i,this.encoder=new s$(e,t,r),this.decoder=new sM(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}let sB=({name:e,prefix:t,encode:r,decode:i})=>new sq(e,t,r,i),sF=({prefix:e,name:t,alphabet:r})=>{let{encode:i,decode:s}=sk(r,t);return sB({prefix:e,name:t,encode:i,decode:e=>sx(s(e))})},sH=(e,t,r,i)=>{let s={};for(let e=0;e<t.length;++e)s[t[e]]=e;let n=e.length;for(;"="===e[n-1];)--n;let a=new Uint8Array(n*r/8|0),o=0,c=0,l=0;for(let t=0;t<n;++t){let n=s[e[t]];if(void 0===n)throw SyntaxError(`Non-${i} character`);c=c<<r|n,(o+=r)>=8&&(o-=8,a[l++]=255&c>>o)}if(o>=r||255&c<<8-o)throw SyntaxError("Unexpected end of data");return a},sW=(e,t,r)=>{let i="="===t[t.length-1],s=(1<<r)-1,n="",a=0,o=0;for(let i=0;i<e.length;++i)for(o=o<<8|e[i],a+=8;a>r;)a-=r,n+=t[s&o>>a];if(a&&(n+=t[s&o<<r-a]),i)for(;n.length*r&7;)n+="=";return n},sV=({name:e,prefix:t,bitsPerChar:r,alphabet:i})=>sB({prefix:t,name:e,encode:e=>sW(e,i,r),decode:t=>sH(t,i,r,e)});var sz=Object.freeze({__proto__:null,identity:sB({prefix:"\0",name:"identity",encode:e=>sD(e),decode:e=>sU(e)})}),sK=Object.freeze({__proto__:null,base2:sV({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1})}),sJ=Object.freeze({__proto__:null,base8:sV({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3})}),sG=Object.freeze({__proto__:null,base10:sF({prefix:"9",name:"base10",alphabet:"0123456789"})}),sY=Object.freeze({__proto__:null,base16:sV({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),base16upper:sV({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4})});let sX=sV({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sZ=sV({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),sQ=sV({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),s0=sV({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),s1=sV({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),s2=sV({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5});var s5=Object.freeze({__proto__:null,base32:sX,base32upper:sZ,base32pad:sQ,base32padupper:s0,base32hex:s1,base32hexupper:s2,base32hexpad:sV({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),base32hexpadupper:sV({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),base32z:sV({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5})}),s3=Object.freeze({__proto__:null,base36:sF({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),base36upper:sF({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"})}),s4=Object.freeze({__proto__:null,base58btc:sF({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),base58flickr:sF({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"})});let s8=sV({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6});var s6=Object.freeze({__proto__:null,base64:s8,base64pad:sV({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),base64url:sV({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),base64urlpad:sV({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6})});let s9=Array.from("\uD83D\uDE80\uD83E\uDE90☄\uD83D\uDEF0\uD83C\uDF0C\uD83C\uDF11\uD83C\uDF12\uD83C\uDF13\uD83C\uDF14\uD83C\uDF15\uD83C\uDF16\uD83C\uDF17\uD83C\uDF18\uD83C\uDF0D\uD83C\uDF0F\uD83C\uDF0E\uD83D\uDC09☀\uD83D\uDCBB\uD83D\uDDA5\uD83D\uDCBE\uD83D\uDCBF\uD83D\uDE02❤\uD83D\uDE0D\uD83E\uDD23\uD83D\uDE0A\uD83D\uDE4F\uD83D\uDC95\uD83D\uDE2D\uD83D\uDE18\uD83D\uDC4D\uD83D\uDE05\uD83D\uDC4F\uD83D\uDE01\uD83D\uDD25\uD83E\uDD70\uD83D\uDC94\uD83D\uDC96\uD83D\uDC99\uD83D\uDE22\uD83E\uDD14\uD83D\uDE06\uD83D\uDE44\uD83D\uDCAA\uD83D\uDE09☺\uD83D\uDC4C\uD83E\uDD17\uD83D\uDC9C\uD83D\uDE14\uD83D\uDE0E\uD83D\uDE07\uD83C\uDF39\uD83E\uDD26\uD83C\uDF89\uD83D\uDC9E✌✨\uD83E\uDD37\uD83D\uDE31\uD83D\uDE0C\uD83C\uDF38\uD83D\uDE4C\uD83D\uDE0B\uD83D\uDC97\uD83D\uDC9A\uD83D\uDE0F\uD83D\uDC9B\uD83D\uDE42\uD83D\uDC93\uD83E\uDD29\uD83D\uDE04\uD83D\uDE00\uD83D\uDDA4\uD83D\uDE03\uD83D\uDCAF\uD83D\uDE48\uD83D\uDC47\uD83C\uDFB6\uD83D\uDE12\uD83E\uDD2D❣\uD83D\uDE1C\uD83D\uDC8B\uD83D\uDC40\uD83D\uDE2A\uD83D\uDE11\uD83D\uDCA5\uD83D\uDE4B\uD83D\uDE1E\uD83D\uDE29\uD83D\uDE21\uD83E\uDD2A\uD83D\uDC4A\uD83E\uDD73\uD83D\uDE25\uD83E\uDD24\uD83D\uDC49\uD83D\uDC83\uD83D\uDE33✋\uD83D\uDE1A\uD83D\uDE1D\uD83D\uDE34\uD83C\uDF1F\uD83D\uDE2C\uD83D\uDE43\uD83C\uDF40\uD83C\uDF37\uD83D\uDE3B\uD83D\uDE13⭐✅\uD83E\uDD7A\uD83C\uDF08\uD83D\uDE08\uD83E\uDD18\uD83D\uDCA6✔\uD83D\uDE23\uD83C\uDFC3\uD83D\uDC90☹\uD83C\uDF8A\uD83D\uDC98\uD83D\uDE20☝\uD83D\uDE15\uD83C\uDF3A\uD83C\uDF82\uD83C\uDF3B\uD83D\uDE10\uD83D\uDD95\uD83D\uDC9D\uD83D\uDE4A\uD83D\uDE39\uD83D\uDDE3\uD83D\uDCAB\uD83D\uDC80\uD83D\uDC51\uD83C\uDFB5\uD83E\uDD1E\uD83D\uDE1B\uD83D\uDD34\uD83D\uDE24\uD83C\uDF3C\uD83D\uDE2B⚽\uD83E\uDD19☕\uD83C\uDFC6\uD83E\uDD2B\uD83D\uDC48\uD83D\uDE2E\uD83D\uDE46\uD83C\uDF7B\uD83C\uDF43\uD83D\uDC36\uD83D\uDC81\uD83D\uDE32\uD83C\uDF3F\uD83E\uDDE1\uD83C\uDF81⚡\uD83C\uDF1E\uD83C\uDF88❌✊\uD83D\uDC4B\uD83D\uDE30\uD83E\uDD28\uD83D\uDE36\uD83E\uDD1D\uD83D\uDEB6\uD83D\uDCB0\uD83C\uDF53\uD83D\uDCA2\uD83E\uDD1F\uD83D\uDE41\uD83D\uDEA8\uD83D\uDCA8\uD83E\uDD2C✈\uD83C\uDF80\uD83C\uDF7A\uD83E\uDD13\uD83D\uDE19\uD83D\uDC9F\uD83C\uDF31\uD83D\uDE16\uD83D\uDC76\uD83E\uDD74▶➡❓\uD83D\uDC8E\uD83D\uDCB8⬇\uD83D\uDE28\uD83C\uDF1A\uD83E\uDD8B\uD83D\uDE37\uD83D\uDD7A⚠\uD83D\uDE45\uD83D\uDE1F\uD83D\uDE35\uD83D\uDC4E\uD83E\uDD32\uD83E\uDD20\uD83E\uDD27\uD83D\uDCCC\uD83D\uDD35\uD83D\uDC85\uD83E\uDDD0\uD83D\uDC3E\uD83C\uDF52\uD83D\uDE17\uD83E\uDD11\uD83C\uDF0A\uD83E\uDD2F\uD83D\uDC37☎\uD83D\uDCA7\uD83D\uDE2F\uD83D\uDC86\uD83D\uDC46\uD83C\uDFA4\uD83D\uDE47\uD83C\uDF51❄\uD83C\uDF34\uD83D\uDCA3\uD83D\uDC38\uD83D\uDC8C\uD83D\uDCCD\uD83E\uDD40\uD83E\uDD22\uD83D\uDC45\uD83D\uDCA1\uD83D\uDCA9\uD83D\uDC50\uD83D\uDCF8\uD83D\uDC7B\uD83E\uDD10\uD83E\uDD2E\uD83C\uDFBC\uD83E\uDD75\uD83D\uDEA9\uD83C\uDF4E\uD83C\uDF4A\uD83D\uDC7C\uD83D\uDC8D\uD83D\uDCE3\uD83E\uDD42"),s7=s9.reduce((e,t,r)=>(e[r]=t,e),[]),ne=s9.reduce((e,t,r)=>(e[t.codePointAt(0)]=r,e),[]);var nt=Object.freeze({__proto__:null,base256emoji:sB({prefix:"\uD83D\uDE80",name:"base256emoji",encode:function(e){return e.reduce((e,t)=>e+=s7[t],"")},decode:function(e){let t=[];for(let r of e){let e=ne[r.codePointAt(0)];if(void 0===e)throw Error(`Non-base256emoji character: ${r}`);t.push(e)}return new Uint8Array(t)}})});function nr(e,t){var r,i=0,t=t||0,s=0,n=t,a=e.length;do{if(n>=a)throw nr.bytes=0,RangeError("Could not decode varint");r=e[n++],i+=s<28?(127&r)<<s:(127&r)*Math.pow(2,s),s+=7}while(r>=128);return nr.bytes=n-t,i}var ni={encode:function e(t,r,i){r=r||[],i=i||0;for(var s=i;t>=2147483648;)r[i++]=255&t|128,t/=128;for(;-128&t;)r[i++]=255&t|128,t>>>=7;return r[i]=0|t,e.bytes=i-s+1,r},encodingLength:function(e){return e<128?1:e<16384?2:e<2097152?3:e<268435456?4:e<34359738368?5:e<4398046511104?6:e<562949953421312?7:e<72057594037927940?8:e<0x7fffffffffffffff?9:10}};let ns=(e,t,r=0)=>(ni.encode(e,t,r),t),nn=e=>ni.encodingLength(e),na=(e,t)=>{let r=t.byteLength,i=nn(e),s=i+nn(r),n=new Uint8Array(s+r);return ns(e,n,0),ns(r,n,i),n.set(t,s),new no(e,r,t,n)};class no{constructor(e,t,r,i){this.code=e,this.size=t,this.digest=r,this.bytes=i}}let nc=({name:e,code:t,encode:r})=>new nl(e,t,r);class nl{constructor(e,t,r){this.name=e,this.code=t,this.encode=r}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?na(this.code,t):t.then(e=>na(this.code,e))}throw Error("Unknown type, must be binary type")}}let nh=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t));var nd=Object.freeze({__proto__:null,sha256:nc({name:"sha2-256",code:18,encode:nh("SHA-256")}),sha512:nc({name:"sha2-512",code:19,encode:nh("SHA-512")})}),nu=Object.freeze({__proto__:null,identity:{code:0,name:"identity",encode:sx,digest:e=>na(0,sx(e))}});new TextEncoder,new TextDecoder;let np={...sz,...sK,...sJ,...sG,...sY,...s5,...s3,...s4,...s6,...nt};function ng(e,t,r,i){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:i}}}({...nd,...nu});let nf=ng("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),nm=ng("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{let t=function(e=0){return null!=globalThis.Buffer&&null!=globalThis.Buffer.allocUnsafe?globalThis.Buffer.allocUnsafe(e):new Uint8Array(e)}((e=e.substring(1)).length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),nw={utf8:nf,"utf-8":nf,hex:np.base16,latin1:nm,ascii:nm,binary:nm,...np};var ny=Object.defineProperty,nb=(e,t,r)=>t in e?ny(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nv=(e,t,r)=>nb(e,"symbol"!=typeof t?t+"":t,r);class nC{constructor(e,t){this.core=e,this.logger=t,nv(this,"keychain",new Map),nv(this,"name","keychain"),nv(this,"version","0.3"),nv(this,"initialized",!1),nv(this,"storagePrefix",sn),nv(this,"init",async()=>{if(!this.initialized){let e=await this.getKeyChain();"u">typeof e&&(this.keychain=e),this.initialized=!0}}),nv(this,"has",e=>(this.isInitialized(),this.keychain.has(e))),nv(this,"set",async(e,t)=>{this.isInitialized(),this.keychain.set(e,t),await this.persist()}),nv(this,"get",e=>{this.isInitialized();let t=this.keychain.get(e);if(typeof t>"u"){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}),nv(this,"del",async e=>{this.isInitialized(),this.keychain.delete(e),await this.persist()}),this.core=e,this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,eo(e))}async getKeyChain(){let e=await this.core.storage.getItem(this.storageKey);return"u">typeof e?ec(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var nE=Object.defineProperty,nN=(e,t,r)=>t in e?nE(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nI=(e,t,r)=>nN(e,"symbol"!=typeof t?t+"":t,r);class nA{constructor(e,t,r){this.core=e,this.logger=t,nI(this,"name","crypto"),nI(this,"keychain"),nI(this,"randomSessionIdentifier",iu()),nI(this,"initialized",!1),nI(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),nI(this,"hasKeys",e=>(this.isInitialized(),this.keychain.has(e))),nI(this,"getClientId",async()=>{this.isInitialized();let e=await this.getClientSeed(),t=x.Au(e);return x.bG(t.publicKey)}),nI(this,"generateKeyPair",()=>{this.isInitialized();let e=function(){let e=r4.utils.randomPrivateKey(),t=r4.getPublicKey(e);return{privateKey:(0,j.BB)(e,ic),publicKey:(0,j.BB)(t,ic)}}();return this.setPrivateKey(e.publicKey,e.privateKey)}),nI(this,"signJWT",async e=>{this.isInitialized();let t=await this.getClientSeed(),r=x.Au(t),i=this.randomSessionIdentifier;return await x.vf(i,e,sl,r)}),nI(this,"generateSharedKey",(e,t,r)=>{this.isInitialized();let i=function(e,t){let r=tQ(t4,r4.getSharedSecret((0,j.mL)(e,ic),(0,j.mL)(t,ic)),void 0,void 0,32);return(0,j.BB)(r,ic)}(this.getPrivateKey(e),t);return this.setSymKey(i,r)}),nI(this,"setSymKey",async(e,t)=>{this.isInitialized();let r=t||ip(e);return await this.keychain.set(r,e),r}),nI(this,"deleteKeyPair",async e=>{this.isInitialized(),await this.keychain.del(e)}),nI(this,"deleteSymKey",async e=>{this.isInitialized(),await this.keychain.del(e)}),nI(this,"encode",async(e,t,r)=>{this.isInitialized();let i=iE(r),s=(0,k.u)(t);if(2===i.type)return function(e,t){let r=im(2),i=eF(12),s=iv({type:r,sealed:(0,j.mL)(e,id),iv:i});return t===ih?iy(s):s}(s,r?.encoding);if(iN(i)){let t=i.senderPublicKey,r=i.receiverPublicKey;e=await this.generateSharedKey(t,r)}let n=this.getSymKey(e),{type:a,senderPublicKey:o}=i;return function(e){let t=im("u">typeof e.type?e.type:0);if(1===iw(t)&&typeof e.senderPublicKey>"u")throw Error("Missing sender public key for type 1 envelope");let r="u">typeof e.senderPublicKey?(0,j.mL)(e.senderPublicKey,ic):void 0,i="u">typeof e.iv?(0,j.mL)(e.iv,ic):eF(12),s=iv({type:t,sealed:tJ((0,j.mL)(e.symKey,ic),i).encrypt((0,j.mL)(e.message,id)),iv:i,senderPublicKey:r});return e.encoding===ih?iy(s):s}({type:a,symKey:n,message:s,senderPublicKey:o,encoding:r?.encoding})}),nI(this,"decode",async(e,t,r)=>{this.isInitialized();let i=function(e,t){let r=iC({encoded:e,encoding:t?.encoding});return iE({type:iw(r.type),senderPublicKey:"u">typeof r.senderPublicKey?(0,j.BB)(r.senderPublicKey,ic):void 0,receiverPublicKey:t?.receiverPublicKey})}(t,r);if(2===i.type){let e=function(e,t){let{sealed:r}=iC({encoded:e,encoding:t});return(0,j.BB)(r,id)}(t,r?.encoding);return(0,k.D)(e)}if(iN(i)){let t=i.receiverPublicKey,r=i.senderPublicKey;e=await this.generateSharedKey(t,r)}try{let i=this.getSymKey(e),s=function(e){let t=(0,j.mL)(e.symKey,ic),{sealed:r,iv:i}=iC({encoded:e.encoded,encoding:e.encoding}),s=tJ(t,i).decrypt(r);if(null===s)throw Error("Failed to decrypt");return(0,j.BB)(s,id)}({symKey:i,encoded:t,encoding:r?.encoding});return(0,k.D)(s)}catch(t){this.logger.error(`Failed to decode message from topic: '${e}', clientId: '${await this.getClientId()}'`),this.logger.error(t)}}),nI(this,"getPayloadType",(e,t=il)=>iw(iC({encoded:e,encoding:t}).type)),nI(this,"getPayloadSenderPublicKey",(e,t=il)=>{let r=iC({encoded:e,encoding:t});return r.senderPublicKey?(0,j.BB)(r.senderPublicKey,ic):void 0}),this.core=e,this.logger=(0,o.Ep)(t,this.name),this.keychain=r||new nC(this.core,this.logger)}get context(){return(0,o.Fd)(this.logger)}async setPrivateKey(e,t){return await this.keychain.set(e,t),e}getPrivateKey(e){return this.keychain.get(e)}async getClientSeed(){let e="";try{e=this.keychain.get(sc)}catch{e=iu(),await this.keychain.set(sc,e)}return function(e,t="utf8"){let r=nw[t];if(!r)throw Error(`Unsupported encoding "${t}"`);return("utf8"===t||"utf-8"===t)&&null!=globalThis.Buffer&&null!=globalThis.Buffer.from?globalThis.Buffer.from(e,"utf8"):r.decoder.decode(`${r.prefix}${e}`)}(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var n_=Object.defineProperty,nS=Object.defineProperties,nO=Object.getOwnPropertyDescriptors,nP=Object.getOwnPropertySymbols,nT=Object.prototype.hasOwnProperty,nR=Object.prototype.propertyIsEnumerable,nk=(e,t,r)=>t in e?n_(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nx=(e,t)=>{for(var r in t||(t={}))nT.call(t,r)&&nk(e,r,t[r]);if(nP)for(var r of nP(t))nR.call(t,r)&&nk(e,r,t[r]);return e},nU=(e,t)=>nS(e,nO(t)),nD=(e,t,r)=>nk(e,"symbol"!=typeof t?t+"":t,r);class n$ extends w{constructor(e,t){super(e,t),this.logger=e,this.core=t,nD(this,"messages",new Map),nD(this,"messagesWithoutClientAck",new Map),nD(this,"name","messages"),nD(this,"version","0.3"),nD(this,"initialized",!1),nD(this,"storagePrefix",sn),nD(this,"init",async()=>{if(!this.initialized){this.logger.trace("Initialized");try{let e=await this.getRelayerMessages();"u">typeof e&&(this.messages=e);let t=await this.getRelayerMessagesWithoutClientAck();"u">typeof t&&(this.messagesWithoutClientAck=t),this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",size:this.messages.size})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}finally{this.initialized=!0}}}),nD(this,"set",async(e,t,r)=>{this.isInitialized();let i=ig(t),s=this.messages.get(e);if(typeof s>"u"&&(s={}),"u">typeof s[i])return i;if(s[i]=t,this.messages.set(e,s),r===sm.inbound){let r=this.messagesWithoutClientAck.get(e)||{};this.messagesWithoutClientAck.set(e,nU(nx({},r),{[i]:t}))}return await this.persist(),i}),nD(this,"get",e=>{this.isInitialized();let t=this.messages.get(e);return typeof t>"u"&&(t={}),t}),nD(this,"getWithoutAck",e=>{this.isInitialized();let t={};for(let r of e){let e=this.messagesWithoutClientAck.get(r)||{};t[r]=Object.values(e)}return t}),nD(this,"has",(e,t)=>(this.isInitialized(),"u">typeof this.get(e)[ig(t)])),nD(this,"ack",async(e,t)=>{this.isInitialized();let r=this.messagesWithoutClientAck.get(e);if(typeof r>"u")return;let i=ig(t);delete r[i],0===Object.keys(r).length?this.messagesWithoutClientAck.delete(e):this.messagesWithoutClientAck.set(e,r),await this.persist()}),nD(this,"del",async e=>{this.isInitialized(),this.messages.delete(e),this.messagesWithoutClientAck.delete(e),await this.persist()}),this.logger=(0,o.Ep)(e,this.name),this.core=t}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get storageKeyWithoutClientAck(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name+"_withoutClientAck"}async setRelayerMessages(e){await this.core.storage.setItem(this.storageKey,eo(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,eo(e))}async getRelayerMessages(){let e=await this.core.storage.getItem(this.storageKey);return"u">typeof e?ec(e):void 0}async getRelayerMessagesWithoutClientAck(){let e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return"u">typeof e?ec(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var nM=Object.defineProperty,nL=Object.defineProperties,nj=Object.getOwnPropertyDescriptors,nq=Object.getOwnPropertySymbols,nB=Object.prototype.hasOwnProperty,nF=Object.prototype.propertyIsEnumerable,nH=(e,t,r)=>t in e?nM(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nW=(e,t)=>{for(var r in t||(t={}))nB.call(t,r)&&nH(e,r,t[r]);if(nq)for(var r of nq(t))nF.call(t,r)&&nH(e,r,t[r]);return e},nV=(e,t)=>nL(e,nj(t)),nz=(e,t,r)=>nH(e,"symbol"!=typeof t?t+"":t,r);class nK extends y{constructor(e,t){super(e,t),this.relayer=e,this.logger=t,nz(this,"events",new i.EventEmitter),nz(this,"name","publisher"),nz(this,"queue",new Map),nz(this,"publishTimeout",(0,R.toMiliseconds)(R.ONE_MINUTE)),nz(this,"initialPublishTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),nz(this,"needsTransportRestart",!1),nz(this,"publish",async(e,t,r)=>{var i;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:e,message:t,opts:r}});let s=r?.ttl||sh,n=iI(r),a=r?.prompt||!1,o=r?.tag||0,c=r?.id||(0,sr.getBigIntRpcId)().toString(),l={topic:e,message:t,opts:{ttl:s,relay:n,prompt:a,tag:o,id:c,attestation:r?.attestation,tvf:r?.tvf}},h=`Failed to publish payload, please try again. id:${c} tag:${o}`;try{let i=new Promise(async i=>{let n=({id:e})=>{l.opts.id===e&&(this.removeRequestFromQueue(e),this.relayer.events.removeListener(su.publish,n),i(l))};this.relayer.events.on(su.publish,n);let h=eh(new Promise((i,n)=>{this.rpcPublish({topic:e,message:t,ttl:s,prompt:a,tag:o,id:c,attestation:r?.attestation,tvf:r?.tvf}).then(i).catch(e=>{this.logger.warn(e,e?.message),n(e)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${c} tag:${o}`);try{await h,this.events.removeListener(su.publish,n)}catch(e){this.queue.set(c,nV(nW({},l),{attempt:1})),this.logger.warn(e,e?.message)}});this.logger.trace({type:"method",method:"publish",params:{id:c,topic:e,message:t,opts:r}}),await eh(i,this.publishTimeout,h)}catch(e){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(e),null!=(i=r?.internal)&&i.throwOnFailedPublish)throw e}finally{this.queue.delete(c)}}),nz(this,"on",(e,t)=>{this.events.on(e,t)}),nz(this,"once",(e,t)=>{this.events.once(e,t)}),nz(this,"off",(e,t)=>{this.events.off(e,t)}),nz(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.relayer=e,this.logger=(0,o.Ep)(t,this.name),this.registerEventListeners()}get context(){return(0,o.Fd)(this.logger)}async rpcPublish(e){var t,r,i,s;let{topic:n,message:a,ttl:o=sh,prompt:c,tag:l,id:h,attestation:d,tvf:u}=e,p={method:iA(iI().protocol).publish,params:nW({topic:n,message:a,ttl:o,prompt:c,tag:l,attestation:d},u),id:h};iG(null==(t=p.params)?void 0:t.prompt)&&(null==(r=p.params)||delete r.prompt),iG(null==(i=p.params)?void 0:i.tag)&&(null==(s=p.params)||delete s.tag),this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"message",direction:"outgoing",request:p});let g=await this.relayer.request(p);return this.relayer.events.emit(su.publish,e),this.logger.debug("Successfully Published Payload"),g}removeRequestFromQueue(e){this.queue.delete(e)}checkQueue(){this.queue.forEach(async(e,t)=>{let r=e.attempt+1;this.queue.set(t,nV(nW({},e),{attempt:r}));let{topic:i,message:s,opts:n,attestation:a}=e;this.logger.warn({},`Publisher: queue->publishing: ${e.opts.id}, tag: ${e.opts.tag}, attempt: ${r}`),await this.rpcPublish(nV(nW({},e),{topic:i,message:s,ttl:n.ttl,prompt:n.prompt,tag:n.tag,id:n.id,attestation:a,tvf:n.tvf})),this.logger.warn({},`Publisher: queue->published: ${e.opts.id}`)})}registerEventListeners(){this.relayer.core.heartbeat.on(n.Lx.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(su.connection_stalled);return}this.checkQueue()}),this.relayer.on(su.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var nJ=Object.defineProperty,nG=(e,t,r)=>t in e?nJ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nY=(e,t,r)=>nG(e,"symbol"!=typeof t?t+"":t,r);class nX{constructor(){nY(this,"map",new Map),nY(this,"set",(e,t)=>{let r=this.get(e);this.exists(e,t)||this.map.set(e,[...r,t])}),nY(this,"get",e=>this.map.get(e)||[]),nY(this,"exists",(e,t)=>this.get(e).includes(t)),nY(this,"delete",(e,t)=>{if(typeof t>"u"){this.map.delete(e);return}if(!this.map.has(e))return;let r=this.get(e);if(!this.exists(e,t))return;let i=r.filter(e=>e!==t);if(!i.length){this.map.delete(e);return}this.map.set(e,i)}),nY(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var nZ=Object.defineProperty,nQ=Object.defineProperties,n0=Object.getOwnPropertyDescriptors,n1=Object.getOwnPropertySymbols,n2=Object.prototype.hasOwnProperty,n5=Object.prototype.propertyIsEnumerable,n3=(e,t,r)=>t in e?nZ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,n4=(e,t)=>{for(var r in t||(t={}))n2.call(t,r)&&n3(e,r,t[r]);if(n1)for(var r of n1(t))n5.call(t,r)&&n3(e,r,t[r]);return e},n8=(e,t)=>nQ(e,n0(t)),n6=(e,t,r)=>n3(e,"symbol"!=typeof t?t+"":t,r);class n9 extends C{constructor(e,t){super(e,t),this.relayer=e,this.logger=t,n6(this,"subscriptions",new Map),n6(this,"topicMap",new nX),n6(this,"events",new i.EventEmitter),n6(this,"name","subscription"),n6(this,"version","0.3"),n6(this,"pending",new Map),n6(this,"cached",[]),n6(this,"initialized",!1),n6(this,"storagePrefix",sn),n6(this,"subscribeTimeout",(0,R.toMiliseconds)(R.ONE_MINUTE)),n6(this,"initialSubscribeTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),n6(this,"clientId"),n6(this,"batchSubscribeTopicsLimit",500),n6(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),n6(this,"subscribe",async(e,t)=>{this.isInitialized(),this.logger.debug("Subscribing Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:e,opts:t}});try{let r=iI(t),i={topic:e,relay:r,transportType:t?.transportType};this.pending.set(e,i);let s=await this.rpcSubscribe(e,r,t);return"string"==typeof s&&(this.onSubscribe(s,i),this.logger.debug("Successfully Subscribed Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:e,opts:t}})),s}catch(e){throw this.logger.debug("Failed to Subscribe Topic"),this.logger.error(e),e}}),n6(this,"unsubscribe",async(e,t)=>{this.isInitialized(),"u">typeof t?.id?await this.unsubscribeById(e,t.id,t):await this.unsubscribeByTopic(e,t)}),n6(this,"isSubscribed",e=>new Promise(t=>{t(this.topicMap.topics.includes(e))})),n6(this,"isKnownTopic",e=>new Promise(t=>{t(this.topicMap.topics.includes(e)||this.pending.has(e)||this.cached.some(t=>t.topic===e))})),n6(this,"on",(e,t)=>{this.events.on(e,t)}),n6(this,"once",(e,t)=>{this.events.once(e,t)}),n6(this,"off",(e,t)=>{this.events.off(e,t)}),n6(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),n6(this,"start",async()=>{await this.onConnect()}),n6(this,"stop",async()=>{await this.onDisconnect()}),n6(this,"restart",async()=>{await this.restore(),await this.onRestart()}),n6(this,"checkPending",async()=>{if(0===this.pending.size&&(!this.initialized||!this.relayer.connected))return;let e=[];this.pending.forEach(t=>{e.push(t)}),await this.batchSubscribe(e)}),n6(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(n.Lx.pulse,async()=>{await this.checkPending()}),this.events.on(sy.created,async e=>{let t=sy.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),await this.persist()}),this.events.on(sy.deleted,async e=>{let t=sy.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),await this.persist()})}),this.relayer=e,this.logger=(0,o.Ep)(t,this.name),this.clientId=""}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.relayer.core.customStoragePrefix+"//"+this.name}get length(){return this.subscriptions.size}get ids(){return Array.from(this.subscriptions.keys())}get values(){return Array.from(this.subscriptions.values())}get topics(){return this.topicMap.topics}get hasAnyTopics(){return this.topicMap.topics.length>0||this.pending.size>0||this.cached.length>0||this.subscriptions.size>0}hasSubscription(e,t){let r=!1;try{r=this.getSubscription(e).topic===t}catch{}return r}reset(){this.cached=[],this.initialized=!0}onDisable(){this.values.length>0&&(this.cached=this.values),this.subscriptions.clear(),this.topicMap.clear()}async unsubscribeByTopic(e,t){let r=this.topicMap.get(e);await Promise.all(r.map(async r=>await this.unsubscribeById(e,r,t)))}async unsubscribeById(e,t,r){this.logger.debug("Unsubscribing Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:t,opts:r}});try{let i=iI(r);await this.restartToComplete({topic:e,id:t,relay:i}),await this.rpcUnsubscribe(e,t,i);let s=iz("USER_DISCONNECTED",`${this.name}, ${e}`);await this.onUnsubscribe(e,t,s),this.logger.debug("Successfully Unsubscribed Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:t,opts:r}})}catch(e){throw this.logger.debug("Failed to Unsubscribe Topic"),this.logger.error(e),e}}async rpcSubscribe(e,t,r){var i;r&&r?.transportType!==sf.relay||await this.restartToComplete({topic:e,id:e,relay:t});let s={method:iA(t.protocol).subscribe,params:{topic:e}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:s});let n=null==(i=r?.internal)?void 0:i.throwOnFailedPublish;try{let t=await this.getSubscriptionId(e);if(r?.transportType===sf.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(s).catch(e=>this.logger.warn(e))},(0,R.toMiliseconds)(R.ONE_SECOND)),t;let i=new Promise(async t=>{let r=i=>{i.topic===e&&(this.events.removeListener(sy.created,r),t(i.id))};this.events.on(sy.created,r);try{let i=await eh(new Promise((e,t)=>{this.relayer.request(s).catch(e=>{this.logger.warn(e,e?.message),t(e)}).then(e)}),this.initialSubscribeTimeout,`Subscribing to ${e} failed, please try again`);this.events.removeListener(sy.created,r),t(i)}catch{}}),a=await eh(i,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!a&&n)throw Error(`Subscribing to ${e} failed, please try again`);return a?t:null}catch(e){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(su.connection_stalled),n)throw e}return null}async rpcBatchSubscribe(e){if(!e.length)return;let t={method:iA(e[0].relay.protocol).batchSubscribe,params:{topics:e.map(e=>e.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:t});try{await await eh(new Promise(e=>{this.relayer.request(t).catch(e=>this.logger.warn(e)).then(e)}),this.subscribeTimeout,"rpcBatchSubscribe failed, please try again")}catch{this.relayer.events.emit(su.connection_stalled)}}async rpcBatchFetchMessages(e){let t;if(!e.length)return;let r={method:iA(e[0].relay.protocol).batchFetchMessages,params:{topics:e.map(e=>e.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:r});try{t=await await eh(new Promise((e,t)=>{this.relayer.request(r).catch(e=>{this.logger.warn(e),t(e)}).then(e)}),this.subscribeTimeout,"rpcBatchFetchMessages failed, please try again")}catch{this.relayer.events.emit(su.connection_stalled)}return t}rpcUnsubscribe(e,t,r){let i={method:iA(r.protocol).unsubscribe,params:{topic:e,id:t}};return this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:i}),this.relayer.request(i)}onSubscribe(e,t){this.setSubscription(e,n8(n4({},t),{id:e})),this.pending.delete(t.topic)}onBatchSubscribe(e){e.length&&e.forEach(e=>{this.setSubscription(e.id,n4({},e)),this.pending.delete(e.topic)})}async onUnsubscribe(e,t,r){this.events.removeAllListeners(t),this.hasSubscription(t,e)&&this.deleteSubscription(t,r),await this.relayer.messages.del(e)}async setRelayerSubscriptions(e){await this.relayer.core.storage.setItem(this.storageKey,e)}async getRelayerSubscriptions(){return await this.relayer.core.storage.getItem(this.storageKey)}setSubscription(e,t){this.logger.debug("Setting subscription"),this.logger.trace({type:"method",method:"setSubscription",id:e,subscription:t}),this.addSubscription(e,t)}addSubscription(e,t){this.subscriptions.set(e,n4({},t)),this.topicMap.set(t.topic,e),this.events.emit(sy.created,t)}getSubscription(e){this.logger.debug("Getting subscription"),this.logger.trace({type:"method",method:"getSubscription",id:e});let t=this.subscriptions.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}deleteSubscription(e,t){this.logger.debug("Deleting subscription"),this.logger.trace({type:"method",method:"deleteSubscription",id:e,reason:t});let r=this.getSubscription(e);this.subscriptions.delete(e),this.topicMap.delete(r.topic,e),this.events.emit(sy.deleted,n8(n4({},r),{reason:t}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(sy.sync)}async onRestart(){if(this.cached.length){let e=[...this.cached],t=Math.ceil(this.cached.length/this.batchSubscribeTopicsLimit);for(let r=0;r<t;r++){let t=e.splice(0,this.batchSubscribeTopicsLimit);await this.batchSubscribe(t)}}this.events.emit(sy.resubscribed)}async restore(){try{let e=await this.getRelayerSubscriptions();if(typeof e>"u"||!e.length)return;if(this.subscriptions.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),this.logger.error(`${this.name}: ${JSON.stringify(this.values)}`),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored subscriptions for ${this.name}`),this.logger.trace({type:"method",method:"restore",subscriptions:this.values})}catch(e){this.logger.debug(`Failed to Restore subscriptions for ${this.name}`),this.logger.error(e)}}async batchSubscribe(e){e.length&&(await this.rpcBatchSubscribe(e),this.onBatchSubscribe(await Promise.all(e.map(async e=>n8(n4({},e),{id:await this.getSubscriptionId(e.topic)})))))}async batchFetchMessages(e){var t;if(!e.length)return;this.logger.trace(`Fetching batch messages for ${e.length} subscriptions`);let r=await this.rpcBatchFetchMessages(e);r&&r.messages&&(await (t=(0,R.toMiliseconds)(R.ONE_SECOND),new Promise(e=>setTimeout(e,t))),await this.relayer.handleBatchMessageEvents(r.messages))}async onConnect(){await this.restart(),this.reset()}onDisconnect(){this.onDisable()}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async restartToComplete(e){this.relayer.connected||this.relayer.connecting||(this.cached.push(e),await this.relayer.transportOpen())}async getClientId(){return this.clientId||(this.clientId=await this.relayer.core.crypto.getClientId()),this.clientId}async getSubscriptionId(e){return ig(e+await this.getClientId())}}var n7=Object.defineProperty,ae=Object.getOwnPropertySymbols,at=Object.prototype.hasOwnProperty,ar=Object.prototype.propertyIsEnumerable,ai=(e,t,r)=>t in e?n7(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,as=(e,t)=>{for(var r in t||(t={}))at.call(t,r)&&ai(e,r,t[r]);if(ae)for(var r of ae(t))ar.call(t,r)&&ai(e,r,t[r]);return e},an=(e,t,r)=>ai(e,"symbol"!=typeof t?t+"":t,r);class aa extends b{constructor(e){super(e),an(this,"protocol","wc"),an(this,"version",2),an(this,"core"),an(this,"logger"),an(this,"events",new i.EventEmitter),an(this,"provider"),an(this,"messages"),an(this,"subscriber"),an(this,"publisher"),an(this,"name","relayer"),an(this,"transportExplicitlyClosed",!1),an(this,"initialized",!1),an(this,"connectionAttemptInProgress",!1),an(this,"relayUrl"),an(this,"projectId"),an(this,"packageName"),an(this,"bundleId"),an(this,"hasExperiencedNetworkDisruption",!1),an(this,"pingTimeout"),an(this,"heartBeatTimeout",(0,R.toMiliseconds)(R.THIRTY_SECONDS+R.FIVE_SECONDS)),an(this,"reconnectTimeout"),an(this,"connectPromise"),an(this,"reconnectInProgress",!1),an(this,"requestsInFlight",[]),an(this,"connectTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),an(this,"request",async e=>{var t,r;this.logger.debug("Publishing Request Payload");let i=e.id||(0,sr.getBigIntRpcId)().toString();await this.toEstablishConnection();try{this.logger.trace({id:i,method:e.method,topic:null==(t=e.params)?void 0:t.topic},"relayer.request - publishing...");let s=`${i}:${(null==(r=e.params)?void 0:r.tag)||""}`;this.requestsInFlight.push(s);let n=await this.provider.request(e);return this.requestsInFlight=this.requestsInFlight.filter(e=>e!==s),n}catch(e){throw this.logger.debug(`Failed to Publish Request: ${i}`),e}}),an(this,"resetPingTimeout",()=>{Q()&&(clearTimeout(this.pingTimeout),this.pingTimeout=setTimeout(()=>{var e,t,r,i;try{this.logger.debug({},"pingTimeout: Connection stalled, terminating..."),null==(i=null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.terminate)||i.call(r)}catch(e){this.logger.warn(e,e?.message)}},this.heartBeatTimeout))}),an(this,"onPayloadHandler",e=>{this.onProviderPayload(e),this.resetPingTimeout()}),an(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected \uD83D\uDEDC"),this.startPingTimeout(),this.events.emit(su.connect)}),an(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected \uD83D\uDED1"),this.requestsInFlight=[],this.onProviderDisconnect()}),an(this,"onProviderErrorHandler",e=>{this.logger.fatal(`Fatal socket error: ${e.message}`),this.events.emit(su.error,e),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),an(this,"registerProviderListeners",()=>{this.provider.on(sp.payload,this.onPayloadHandler),this.provider.on(sp.connect,this.onConnectHandler),this.provider.on(sp.disconnect,this.onDisconnectHandler),this.provider.on(sp.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger="u">typeof e.logger&&"string"!=typeof e.logger?(0,o.Ep)(e.logger,this.name):(0,o.gw)((0,o.jI)({level:e.logger||"error"})),this.messages=new n$(this.logger,e.core),this.subscriber=new n9(this,this.logger),this.publisher=new nK(this,this.logger),this.relayUrl=e?.relayUrl||sd,this.projectId=e.projectId,ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)&&(null==global?void 0:global.Platform.OS)==="android"?this.packageName=ei():ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)&&(null==global?void 0:global.Platform.OS)==="ios"&&(this.bundleId=ei()),this.provider={}}async init(){if(this.logger.trace("Initialized"),this.registerEventListeners(),await Promise.all([this.messages.init(),this.subscriber.init()]),this.initialized=!0,this.subscriber.hasAnyTopics)try{await this.transportOpen()}catch(e){this.logger.warn(e,e?.message)}}get context(){return(0,o.Fd)(this.logger)}get connected(){var e,t,r;return(null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.readyState)===1}get connecting(){var e,t,r;return(null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.readyState)===0||void 0!==this.connectPromise}async publish(e,t,r){this.isInitialized(),await this.publisher.publish(e,t,r),await this.recordMessageEvent({topic:e,message:t,publishedAt:Date.now(),transportType:sf.relay},sm.outbound)}async subscribe(e,t){var r,i,s;this.isInitialized(),null!=t&&t.transportType&&t?.transportType!=="relay"||await this.toEstablishConnection();let n=typeof(null==(r=t?.internal)?void 0:r.throwOnFailedPublish)>"u"||(null==(i=t?.internal)?void 0:i.throwOnFailedPublish),a=(null==(s=this.subscriber.topicMap.get(e))?void 0:s[0])||"",o,c=t=>{t.topic===e&&(this.subscriber.off(sy.created,c),o())};return await Promise.all([new Promise(e=>{o=e,this.subscriber.on(sy.created,c)}),new Promise(async(r,i)=>{a=await this.subscriber.subscribe(e,as({internal:{throwOnFailedPublish:n}},t)).catch(e=>{n&&i(e)})||a,r()})]),a}async unsubscribe(e,t){this.isInitialized(),await this.subscriber.unsubscribe(e,t)}on(e,t){this.events.on(e,t)}once(e,t){this.events.once(e,t)}off(e,t){this.events.off(e,t)}removeListener(e,t){this.events.removeListener(e,t)}async transportDisconnect(){this.provider.disconnect&&(this.hasExperiencedNetworkDisruption||this.connected)?await eh(this.provider.disconnect(),2e3,"provider.disconnect()").catch(()=>this.onProviderDisconnect()):this.onProviderDisconnect()}async transportClose(){this.transportExplicitlyClosed=!0,await this.transportDisconnect()}async transportOpen(e){if(!this.subscriber.hasAnyTopics){this.logger.warn("Starting WS connection skipped because the client has no topics to work with.");return}if(this.connectPromise?(this.logger.debug({},"Waiting for existing connection attempt to resolve..."),await this.connectPromise,this.logger.debug({},"Existing connection attempt resolved")):(this.connectPromise=new Promise(async(t,r)=>{await this.connect(e).then(t).catch(r).finally(()=>{this.connectPromise=void 0})}),await this.connectPromise),!this.connected)throw Error(`Couldn't establish socket connection to the relay server: ${this.relayUrl}`)}async restartTransport(e){this.logger.debug({},"Restarting transport..."),this.connectionAttemptInProgress||(this.relayUrl=e||this.relayUrl,await this.confirmOnlineStateOrThrow(),await this.transportClose(),await this.transportOpen())}async confirmOnlineStateOrThrow(){if(!await i6())throw Error("No internet connection detected. Please restart your network and try again.")}async handleBatchMessageEvents(e){if(e?.length===0){this.logger.trace("Batch message events is empty. Ignoring...");return}let t=e.sort((e,t)=>e.publishedAt-t.publishedAt);for(let e of(this.logger.debug(`Batch of ${t.length} message events sorted`),t))try{await this.onMessageEvent(e)}catch(e){this.logger.warn(e,"Error while processing batch message event: "+e?.message)}this.logger.trace(`Batch of ${t.length} message events processed`)}async onLinkMessageEvent(e,t){let{topic:r}=e;if(!t.sessionExists){let e=ep(R.FIVE_MINUTES);await this.core.pairing.pairings.set(r,{topic:r,expiry:e,relay:{protocol:"irn"},active:!1})}this.events.emit(su.message,e),await this.recordMessageEvent(e,sm.inbound)}async connect(e){await this.confirmOnlineStateOrThrow(),e&&e!==this.relayUrl&&(this.relayUrl=e,await this.transportDisconnect()),this.connectionAttemptInProgress=!0,this.transportExplicitlyClosed=!1;let t=1;for(;t<6;){try{if(this.transportExplicitlyClosed)break;this.logger.debug({},`Connecting to ${this.relayUrl}, attempt: ${t}...`),await this.createProvider(),await new Promise(async(e,t)=>{let r=()=>{t(Error("Connection interrupted while trying to subscribe"))};this.provider.once(sp.disconnect,r),await eh(new Promise((e,t)=>{this.provider.connect().then(e).catch(t)}),this.connectTimeout,`Socket stalled when trying to connect to ${this.relayUrl}`).catch(e=>{t(e)}).finally(()=>{this.provider.off(sp.disconnect,r),clearTimeout(this.reconnectTimeout)}),await new Promise(async(e,t)=>{let r=()=>{t(Error("Connection interrupted while trying to subscribe"))};this.provider.once(sp.disconnect,r),await this.subscriber.start().then(e).catch(t).finally(()=>{this.provider.off(sp.disconnect,r)})}),this.hasExperiencedNetworkDisruption=!1,e()})}catch(e){await this.subscriber.stop(),this.logger.warn({},e.message),this.hasExperiencedNetworkDisruption=!0}finally{this.connectionAttemptInProgress=!1}if(this.connected){this.logger.debug({},`Connected to ${this.relayUrl} successfully on attempt: ${t}`);break}await new Promise(e=>setTimeout(e,(0,R.toMiliseconds)(1*t))),t++}}startPingTimeout(){var e,t,r,i,s;if(Q())try{null!=(t=null==(e=this.provider)?void 0:e.connection)&&t.socket&&(null==(s=null==(i=null==(r=this.provider)?void 0:r.connection)?void 0:i.socket)||s.on("ping",()=>{this.resetPingTimeout()})),this.resetPingTimeout()}catch(e){this.logger.warn(e,e?.message)}}async createProvider(){this.provider.connection&&this.unregisterProviderListeners();let e=await this.core.crypto.signJWT(this.relayUrl);this.provider=new st.r(new si.Z(function({protocol:e,version:t,relayUrl:r,sdkVersion:i,auth:s,projectId:n,useOnCloseEvent:a,bundleId:o,packageName:c}){let l=r.split("?"),h=en(e,t,i),d=function(e,t){let r=new URLSearchParams(e);for(let e of Object.keys(t).sort())if(t.hasOwnProperty(e)){let i=t[e];void 0!==i&&r.set(e,i)}return r.toString()}(l[1]||"",{auth:s,ua:h,projectId:n,useOnCloseEvent:a||void 0,packageName:c||void 0,bundleId:o||void 0});return l[0]+"?"+d}({sdkVersion:sg,protocol:this.protocol,version:this.version,relayUrl:this.relayUrl,projectId:this.projectId,auth:e,useOnCloseEvent:!0,bundleId:this.bundleId,packageName:this.packageName}))),this.registerProviderListeners()}async recordMessageEvent(e,t){let{topic:r,message:i}=e;await this.messages.set(r,i,t)}async shouldIgnoreMessageEvent(e){let{topic:t,message:r}=e;if(!r||0===r.length)return this.logger.warn(`Ignoring invalid/empty message: ${r}`),!0;if(!await this.subscriber.isKnownTopic(t))return this.logger.warn(`Ignoring message for unknown topic ${t}`),!0;let i=this.messages.has(t,r);return i&&this.logger.warn(`Ignoring duplicate message: ${r}`),i}async onProviderPayload(e){if(this.logger.debug("Incoming Relay Payload"),this.logger.trace({type:"payload",direction:"incoming",payload:e}),(0,sr.isJsonRpcRequest)(e)){if(!e.method.endsWith("_subscription"))return;let t=e.params,{topic:r,message:i,publishedAt:s,attestation:n}=t.data,a={topic:r,message:i,publishedAt:s,transportType:sf.relay,attestation:n};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(as({type:"event",event:t.id},a)),this.events.emit(t.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else(0,sr.isJsonRpcResponse)(e)&&this.events.emit(su.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,sm.inbound),this.events.emit(su.message,e))}async acknowledgePayload(e){let t=(0,sr.formatJsonRpcResult)(e.id,!0);await this.provider.connection.send(t)}unregisterProviderListeners(){this.provider.off(sp.payload,this.onPayloadHandler),this.provider.off(sp.connect,this.onConnectHandler),this.provider.off(sp.disconnect,this.onDisconnectHandler),this.provider.off(sp.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await i6();(function(e){switch(er()){case Z.browser:!ee()&&et()&&(window.addEventListener("online",()=>e(!0)),window.addEventListener("offline",()=>e(!1)));break;case Z.reactNative:ee()&&"u">typeof global&&null!=global&&global.NetInfo&&global?.NetInfo.addEventListener(t=>e(t?.isConnected));case Z.node:}})(async t=>{e!==t&&(e=t,t?await this.transportOpen().catch(e=>this.logger.error(e,e?.message)):(this.hasExperiencedNetworkDisruption=!0,await this.transportDisconnect(),this.transportExplicitlyClosed=!1))}),this.core.heartbeat.on(n.Lx.pulse,async()=>{var e;if(!this.transportExplicitlyClosed&&!this.connected&&(!(et()&&(0,D.getDocument)())||(null==(e=(0,D.getDocument)())?void 0:e.visibilityState)==="visible"))try{await this.confirmOnlineStateOrThrow(),await this.transportOpen()}catch(e){this.logger.warn(e,e?.message)}})}async onProviderDisconnect(){clearTimeout(this.pingTimeout),this.events.emit(su.disconnect),this.connectionAttemptInProgress=!1,!this.reconnectInProgress&&(this.reconnectInProgress=!0,await this.subscriber.stop(),this.subscriber.hasAnyTopics&&(this.transportExplicitlyClosed||(this.reconnectTimeout=setTimeout(async()=>{await this.transportOpen().catch(e=>this.logger.error(e,e?.message)),this.reconnectTimeout=void 0,this.reconnectInProgress=!1},(0,R.toMiliseconds)(.1)))))}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async toEstablishConnection(){if(await this.confirmOnlineStateOrThrow(),!this.connected){if(this.connectPromise){await this.connectPromise;return}await this.connect()}}}function ao(){}function ac(e){if(!e||"object"!=typeof e)return!1;let t=Object.getPrototypeOf(e);return(null===t||t===Object.prototype||null===Object.getPrototypeOf(t))&&"[object Object]"===Object.prototype.toString.call(e)}function al(e){return Object.getOwnPropertySymbols(e).filter(t=>Object.prototype.propertyIsEnumerable.call(e,t))}function ah(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":Object.prototype.toString.call(e)}let ad="[object Arguments]",au="[object Object]";var ap=Object.defineProperty,ag=Object.getOwnPropertySymbols,af=Object.prototype.hasOwnProperty,am=Object.prototype.propertyIsEnumerable,aw=(e,t,r)=>t in e?ap(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,ay=(e,t)=>{for(var r in t||(t={}))af.call(t,r)&&aw(e,r,t[r]);if(ag)for(var r of ag(t))am.call(t,r)&&aw(e,r,t[r]);return e},ab=(e,t,r)=>aw(e,"symbol"!=typeof t?t+"":t,r);class av extends v{constructor(e,t,r,i=sn,s){super(e,t,r,i),this.core=e,this.logger=t,this.name=r,ab(this,"map",new Map),ab(this,"version","0.3"),ab(this,"cached",[]),ab(this,"initialized",!1),ab(this,"getKey"),ab(this,"storagePrefix",sn),ab(this,"recentlyDeleted",[]),ab(this,"recentlyDeletedLimit",200),ab(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>{this.getKey&&null!==e&&!iG(e)?this.map.set(this.getKey(e),e):function(e){var t;return null==(t=e?.proposer)?void 0:t.publicKey}(e)?this.map.set(e.id,e):e?.topic&&this.map.set(e.topic,e)}),this.cached=[],this.initialized=!0)}),ab(this,"set",async(e,t)=>{this.isInitialized(),this.map.has(e)?await this.update(e,t):(this.logger.debug("Setting value"),this.logger.trace({type:"method",method:"set",key:e,value:t}),this.map.set(e,t),await this.persist())}),ab(this,"get",e=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:e}),this.getData(e))),ab(this,"getAll",e=>(this.isInitialized(),e?this.values.filter(t=>Object.keys(e).every(r=>(function e(t,r,i,s,n,a,o){let c=o(t,r,i,s,n,a);if(void 0!==c)return c;if(typeof t==typeof r)switch(typeof t){case"bigint":case"string":case"boolean":case"symbol":case"undefined":case"function":return t===r;case"number":return t===r||Object.is(t,r)}return function t(r,i,s,n){if(Object.is(r,i))return!0;let a=ah(r),o=ah(i);if(a===ad&&(a=au),o===ad&&(o=au),a!==o)return!1;switch(a){case"[object String]":return r.toString()===i.toString();case"[object Number]":{let e=r.valueOf(),t=i.valueOf();return e===t||Number.isNaN(e)&&Number.isNaN(t)}case"[object Boolean]":case"[object Date]":case"[object Symbol]":return Object.is(r.valueOf(),i.valueOf());case"[object RegExp]":return r.source===i.source&&r.flags===i.flags;case"[object Function]":return r===i}let c=(s=s??new Map).get(r),l=s.get(i);if(null!=c&&null!=l)return c===i;s.set(r,i),s.set(i,r);try{switch(a){case"[object Map]":if(r.size!==i.size)return!1;for(let[t,a]of r.entries())if(!i.has(t)||!e(a,i.get(t),t,r,i,s,n))return!1;return!0;case"[object Set]":{if(r.size!==i.size)return!1;let t=Array.from(r.values()),a=Array.from(i.values());for(let o=0;o<t.length;o++){let c=t[o],l=a.findIndex(t=>e(c,t,void 0,r,i,s,n));if(-1===l)return!1;a.splice(l,1)}return!0}case"[object Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":case"[object BigUint64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object BigInt64Array]":case"[object Float32Array]":case"[object Float64Array]":if("u">typeof Buffer&&Buffer.isBuffer(r)!==Buffer.isBuffer(i)||r.length!==i.length)return!1;for(let t=0;t<r.length;t++)if(!e(r[t],i[t],t,r,i,s,n))return!1;return!0;case"[object ArrayBuffer]":return r.byteLength===i.byteLength&&t(new Uint8Array(r),new Uint8Array(i),s,n);case"[object DataView]":return r.byteLength===i.byteLength&&r.byteOffset===i.byteOffset&&t(new Uint8Array(r),new Uint8Array(i),s,n);case"[object Error]":return r.name===i.name&&r.message===i.message;case au:{if(!(t(r.constructor,i.constructor,s,n)||ac(r)&&ac(i)))return!1;let a=[...Object.keys(r),...al(r)],o=[...Object.keys(i),...al(i)];if(a.length!==o.length)return!1;for(let t=0;t<a.length;t++){let o=a[t],c=r[o];if(!Object.hasOwn(i,o))return!1;let l=i[o];if(!e(c,l,o,r,i,s,n))return!1}return!0}default:return!1}}finally{s.delete(r),s.delete(i)}}(t,r,a,o)})(t[r],e[r],void 0,void 0,void 0,void 0,ao))):this.values)),ab(this,"update",async(e,t)=>{this.isInitialized(),this.logger.debug("Updating value"),this.logger.trace({type:"method",method:"update",key:e,update:t});let r=ay(ay({},this.getData(e)),t);this.map.set(e,r),await this.persist()}),ab(this,"delete",async(e,t)=>{this.isInitialized(),this.map.has(e)&&(this.logger.debug("Deleting value"),this.logger.trace({type:"method",method:"delete",key:e,reason:t}),this.map.delete(e),this.addToRecentlyDeleted(e),await this.persist())}),this.logger=(0,o.Ep)(t,this.name),this.storagePrefix=i,this.getKey=s}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.map.size}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}addToRecentlyDeleted(e){this.recentlyDeleted.push(e),this.recentlyDeleted.length>=this.recentlyDeletedLimit&&this.recentlyDeleted.splice(0,this.recentlyDeletedLimit/2)}async setDataStore(e){await this.core.storage.setItem(this.storageKey,e)}async getDataStore(){return await this.core.storage.getItem(this.storageKey)}getData(e){let t=this.map.get(e);if(!t){if(this.recentlyDeleted.includes(e)){let{message:t}=iV("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(t),Error(t)}let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.error(t),Error(t)}return t}async persist(){await this.setDataStore(this.values)}async restore(){try{let e=await this.getDataStore();if(typeof e>"u"||!e.length)return;if(this.map.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored value for ${this.name}`),this.logger.trace({type:"method",method:"restore",value:this.values})}catch(e){this.logger.debug(`Failed to Restore value for ${this.name}`),this.logger.error(e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var aC=Object.defineProperty,aE=(e,t,r)=>t in e?aC(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aN=(e,t,r)=>aE(e,"symbol"!=typeof t?t+"":t,r);class aI{constructor(e,t){this.core=e,this.logger=t,aN(this,"name","pairing"),aN(this,"version","0.3"),aN(this,"events",new(s())),aN(this,"pairings"),aN(this,"initialized",!1),aN(this,"storagePrefix",sn),aN(this,"ignoredPayloadTypes",[1]),aN(this,"registeredMethods",[]),aN(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),aN(this,"register",({methods:e})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...e])]}),aN(this,"create",async e=>{this.isInitialized();let t=iu(),r=await this.core.crypto.setSymKey(t),i=ep(R.FIVE_MINUTES),s={protocol:"irn"},n={topic:r,expiry:i,relay:s,active:!1,methods:e?.methods},a=iS({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:t,relay:s,expiryTimestamp:i,methods:e?.methods});return this.events.emit(sv.create,n),this.core.expirer.set(r,i),await this.pairings.set(r,n),await this.core.relayer.subscribe(r,{transportType:e?.transportType}),{topic:r,uri:a}}),aN(this,"pair",async e=>{let t;this.isInitialized();let r=this.core.eventClient.createEvent({properties:{topic:e?.uri,trace:[s_.pairing_started]}});this.isValidPair(e,r);let{topic:i,symKey:s,relay:n,expiryTimestamp:a,methods:o}=i_(e.uri);if(r.props.properties.topic=i,r.addTrace(s_.pairing_uri_validation_success),r.addTrace(s_.pairing_uri_not_expired),this.pairings.keys.includes(i)){if(t=this.pairings.get(i),r.addTrace(s_.existing_pairing),t.active)throw r.setError(sS.active_pairing_already_exists),Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(s_.pairing_not_expired)}let c=a||ep(R.FIVE_MINUTES),l={topic:i,relay:n,expiry:c,active:!1,methods:o};this.core.expirer.set(i,c),await this.pairings.set(i,l),r.addTrace(s_.store_new_pairing),e.activatePairing&&await this.activate({topic:i}),this.events.emit(sv.create,l),r.addTrace(s_.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(s,i),r.addTrace(s_.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(sS.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:n})}catch(e){throw r.setError(sS.subscribe_pairing_topic_failure),e}return r.addTrace(s_.subscribe_pairing_topic_success),l}),aN(this,"activate",async({topic:e})=>{this.isInitialized();let t=ep(R.FIVE_MINUTES);this.core.expirer.set(e,t),await this.pairings.update(e,{active:!0,expiry:t})}),aN(this,"ping",async e=>{this.isInitialized(),await this.isValidPing(e),this.logger.warn("ping() is deprecated and will be removed in the next major release.");let{topic:t}=e;if(this.pairings.keys.includes(t)){let e=await this.sendRequest(t,"wc_pairingPing",{}),{done:r,resolve:i,reject:s}=el();this.events.once(ef("pairing_ping",e),({error:e})=>{e?s(e):i()}),await r()}}),aN(this,"updateExpiry",async({topic:e,expiry:t})=>{this.isInitialized(),await this.pairings.update(e,{expiry:t})}),aN(this,"updateMetadata",async({topic:e,metadata:t})=>{this.isInitialized(),await this.pairings.update(e,{peerMetadata:t})}),aN(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),aN(this,"disconnect",async e=>{this.isInitialized(),await this.isValidDisconnect(e);let{topic:t}=e;this.pairings.keys.includes(t)&&(await this.sendRequest(t,"wc_pairingDelete",iz("USER_DISCONNECTED")),await this.deletePairing(t))}),aN(this,"formatUriFromPairing",e=>{this.isInitialized();let{topic:t,relay:r,expiry:i,methods:s}=e,n=this.core.crypto.keychain.get(t);return iS({protocol:this.core.protocol,version:this.core.version,topic:t,symKey:n,relay:r,expiryTimestamp:i,methods:s})}),aN(this,"sendRequest",async(e,t,r)=>{let i=(0,sr.formatJsonRpcRequest)(t,r),s=await this.core.crypto.encode(e,i),n=sb[t].req;return this.core.history.set(e,i),this.core.relayer.publish(e,s,n),i.id}),aN(this,"sendResult",async(e,t,r)=>{let i=(0,sr.formatJsonRpcResult)(e,r),s=await this.core.crypto.encode(t,i),n=sb[(await this.core.history.get(t,e)).request.method].res;await this.core.relayer.publish(t,s,n),await this.core.history.resolve(i)}),aN(this,"sendError",async(e,t,r)=>{let i=(0,sr.formatJsonRpcError)(e,r),s=await this.core.crypto.encode(t,i),n=(await this.core.history.get(t,e)).request.method,a=sb[n]?sb[n].res:sb.unregistered_method.res;await this.core.relayer.publish(t,s,a),await this.core.history.resolve(i)}),aN(this,"deletePairing",async(e,t)=>{await this.core.relayer.unsubscribe(e),await Promise.all([this.pairings.delete(e,iz("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(e),t?Promise.resolve():this.core.expirer.del(e)])}),aN(this,"cleanup",async()=>{let e=this.pairings.getAll().filter(e=>eg(e.expiry));await Promise.all(e.map(e=>this.deletePairing(e.topic)))}),aN(this,"onRelayEventRequest",async e=>{let{topic:t,payload:r}=e;switch(r.method){case"wc_pairingPing":return await this.onPairingPingRequest(t,r);case"wc_pairingDelete":return await this.onPairingDeleteRequest(t,r);default:return await this.onUnknownRpcMethodRequest(t,r)}}),aN(this,"onRelayEventResponse",async e=>{let{topic:t,payload:r}=e,i=(await this.core.history.get(t,r.id)).request.method;return"wc_pairingPing"===i?this.onPairingPingResponse(t,r):this.onUnknownRpcMethodResponse(i)}),aN(this,"onPairingPingRequest",async(e,t)=>{let{id:r}=t;try{this.isValidPing({topic:e}),await this.sendResult(r,e,!0),this.events.emit(sv.ping,{id:r,topic:e})}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onPairingPingResponse",(e,t)=>{let{id:r}=t;setTimeout(()=>{(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("pairing_ping",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("pairing_ping",r),{error:t.error})},500)}),aN(this,"onPairingDeleteRequest",async(e,t)=>{let{id:r}=t;try{this.isValidDisconnect({topic:e}),await this.deletePairing(e),this.events.emit(sv.delete,{id:r,topic:e})}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onUnknownRpcMethodRequest",async(e,t)=>{let{id:r,method:i}=t;try{if(this.registeredMethods.includes(i))return;let t=iz("WC_METHOD_UNSUPPORTED",i);await this.sendError(r,e,t),this.logger.error(t)}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onUnknownRpcMethodResponse",e=>{this.registeredMethods.includes(e)||this.logger.error(iz("WC_METHOD_UNSUPPORTED",e))}),aN(this,"isValidPair",(e,t)=>{var r;if(!i5(e)){let{message:r}=iV("MISSING_OR_INVALID",`pair() params: ${e}`);throw t.setError(sS.malformed_pairing_uri),Error(r)}if(!function(e){function t(e){try{return"u">typeof new URL(e)}catch{return!1}}try{if(iY(e,!1)){if(t(e))return!0;let r=eE(e);return t(r)}}catch{}return!1}(e.uri)){let{message:r}=iV("MISSING_OR_INVALID",`pair() uri: ${e.uri}`);throw t.setError(sS.malformed_pairing_uri),Error(r)}let i=i_(e?.uri);if(!(null!=(r=i?.relay)&&r.protocol)){let{message:e}=iV("MISSING_OR_INVALID","pair() uri#relay-protocol");throw t.setError(sS.malformed_pairing_uri),Error(e)}if(!(null!=i&&i.symKey)){let{message:e}=iV("MISSING_OR_INVALID","pair() uri#symKey");throw t.setError(sS.malformed_pairing_uri),Error(e)}if(null!=i&&i.expiryTimestamp&&(0,R.toMiliseconds)(i?.expiryTimestamp)<Date.now()){t.setError(sS.pairing_expired);let{message:e}=iV("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw Error(e)}}),aN(this,"isValidPing",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`ping() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidPairingTopic(t)}),aN(this,"isValidDisconnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`disconnect() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidPairingTopic(t)}),aN(this,"isValidPairingTopic",async e=>{if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw Error(t)}if(!this.pairings.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.pairings.get(e).expiry)){await this.deletePairing(e);let{message:t}=iV("EXPIRED",`pairing topic: ${e}`);throw Error(t)}}),this.core=e,this.logger=(0,o.Ep)(t,this.name),this.pairings=new av(this.core,this.logger,this.name,this.storagePrefix)}get context(){return(0,o.Fd)(this.logger)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}registerRelayerEvents(){this.core.relayer.on(su.message,async e=>{let{topic:t,message:r,transportType:i}=e;if(this.pairings.keys.includes(t)&&i!==sf.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(r)))try{let e=await this.core.crypto.decode(t,r);(0,sr.isJsonRpcRequest)(e)?(this.core.history.set(t,e),await this.onRelayEventRequest({topic:t,payload:e})):(0,sr.isJsonRpcResponse)(e)&&(await this.core.history.resolve(e),await this.onRelayEventResponse({topic:t,payload:e}),this.core.history.delete(t,e.id)),await this.core.relayer.messages.ack(t,r)}catch(e){this.logger.error(e)}})}registerExpirerEvents(){this.core.expirer.on(sE.expired,async e=>{let{topic:t}=eu(e.target);t&&this.pairings.keys.includes(t)&&(await this.deletePairing(t,!0),this.events.emit(sv.expire,{topic:t}))})}}var aA=Object.defineProperty,a_=(e,t,r)=>t in e?aA(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aS=(e,t,r)=>a_(e,"symbol"!=typeof t?t+"":t,r);class aO extends m{constructor(e,t){super(e,t),this.core=e,this.logger=t,aS(this,"records",new Map),aS(this,"events",new i.EventEmitter),aS(this,"name","history"),aS(this,"version","0.3"),aS(this,"cached",[]),aS(this,"initialized",!1),aS(this,"storagePrefix",sn),aS(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>this.records.set(e.id,e)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),aS(this,"set",(e,t,r)=>{if(this.isInitialized(),this.logger.debug("Setting JSON-RPC request history record"),this.logger.trace({type:"method",method:"set",topic:e,request:t,chainId:r}),this.records.has(t.id))return;let i={id:t.id,topic:e,request:{method:t.method,params:t.params||null},chainId:r,expiry:ep(R.THIRTY_DAYS)};this.records.set(i.id,i),this.persist(),this.events.emit(sC.created,i)}),aS(this,"resolve",async e=>{if(this.isInitialized(),this.logger.debug("Updating JSON-RPC response history record"),this.logger.trace({type:"method",method:"update",response:e}),!this.records.has(e.id))return;let t=await this.getRecord(e.id);typeof t.response>"u"&&(t.response=(0,sr.isJsonRpcError)(e)?{error:e.error}:{result:e.result},this.records.set(t.id,t),this.persist(),this.events.emit(sC.updated,t))}),aS(this,"get",async(e,t)=>(this.isInitialized(),this.logger.debug("Getting record"),this.logger.trace({type:"method",method:"get",topic:e,id:t}),await this.getRecord(t))),aS(this,"delete",(e,t)=>{this.isInitialized(),this.logger.debug("Deleting record"),this.logger.trace({type:"method",method:"delete",id:t}),this.values.forEach(r=>{r.topic!==e||"u">typeof t&&r.id!==t||(this.records.delete(r.id),this.events.emit(sC.deleted,r))}),this.persist()}),aS(this,"exists",async(e,t)=>(this.isInitialized(),!!this.records.has(t)&&(await this.getRecord(t)).topic===e)),aS(this,"on",(e,t)=>{this.events.on(e,t)}),aS(this,"once",(e,t)=>{this.events.once(e,t)}),aS(this,"off",(e,t)=>{this.events.off(e,t)}),aS(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get size(){return this.records.size}get keys(){return Array.from(this.records.keys())}get values(){return Array.from(this.records.values())}get pending(){let e=[];return this.values.forEach(t=>{if("u">typeof t.response)return;let r={topic:t.topic,request:(0,sr.formatJsonRpcRequest)(t.request.method,t.request.params,t.id),chainId:t.chainId};return e.push(r)}),e}async setJsonRpcRecords(e){await this.core.storage.setItem(this.storageKey,e)}async getJsonRpcRecords(){return await this.core.storage.getItem(this.storageKey)}getRecord(e){this.isInitialized();let t=this.records.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(sC.sync)}async restore(){try{let e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",records:this.values})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}}registerEventListeners(){this.events.on(sC.created,e=>{let t=sC.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.events.on(sC.updated,e=>{let t=sC.updated;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.events.on(sC.deleted,e=>{let t=sC.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.core.heartbeat.on(n.Lx.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(t=>{(0,R.toMiliseconds)(t.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${t.id}`),this.records.delete(t.id),this.events.emit(sC.deleted,t,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var aP=Object.defineProperty,aT=(e,t,r)=>t in e?aP(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aR=(e,t,r)=>aT(e,"symbol"!=typeof t?t+"":t,r);class ak extends E{constructor(e,t){super(e,t),this.core=e,this.logger=t,aR(this,"expirations",new Map),aR(this,"events",new i.EventEmitter),aR(this,"name","expirer"),aR(this,"version","0.3"),aR(this,"cached",[]),aR(this,"initialized",!1),aR(this,"storagePrefix",sn),aR(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>this.expirations.set(e.target,e)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),aR(this,"has",e=>{try{let t=this.formatTarget(e);return"u">typeof this.getExpiration(t)}catch{return!1}}),aR(this,"set",(e,t)=>{this.isInitialized();let r=this.formatTarget(e),i={target:r,expiry:t};this.expirations.set(r,i),this.checkExpiry(r,i),this.events.emit(sE.created,{target:r,expiration:i})}),aR(this,"get",e=>{this.isInitialized();let t=this.formatTarget(e);return this.getExpiration(t)}),aR(this,"del",e=>{if(this.isInitialized(),this.has(e)){let t=this.formatTarget(e),r=this.getExpiration(t);this.expirations.delete(t),this.events.emit(sE.deleted,{target:t,expiration:r})}}),aR(this,"on",(e,t)=>{this.events.on(e,t)}),aR(this,"once",(e,t)=>{this.events.once(e,t)}),aR(this,"off",(e,t)=>{this.events.off(e,t)}),aR(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.expirations.size}get keys(){return Array.from(this.expirations.keys())}get values(){return Array.from(this.expirations.values())}formatTarget(e){if("string"==typeof e)return ed("topic",e);if("number"==typeof e)return ed("id",e);let{message:t}=iV("UNKNOWN_TYPE",`Target type: ${typeof e}`);throw Error(t)}async setExpirations(e){await this.core.storage.setItem(this.storageKey,e)}async getExpirations(){return await this.core.storage.getItem(this.storageKey)}async persist(){await this.setExpirations(this.values),this.events.emit(sE.sync)}async restore(){try{let e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored expirations for ${this.name}`),this.logger.trace({type:"method",method:"restore",expirations:this.values})}catch(e){this.logger.debug(`Failed to Restore expirations for ${this.name}`),this.logger.error(e)}}getExpiration(e){let t=this.expirations.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(t),Error(t)}return t}checkExpiry(e,t){let{expiry:r}=t;(0,R.toMiliseconds)(r)-Date.now()<=0&&this.expire(e,t)}expire(e,t){this.expirations.delete(e),this.events.emit(sE.expired,{target:e,expiration:t})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,t)=>this.checkExpiry(t,e))}registerEventListeners(){this.core.heartbeat.on(n.Lx.pulse,()=>this.checkExpirations()),this.events.on(sE.created,e=>{let t=sE.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()}),this.events.on(sE.expired,e=>{let t=sE.expired;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()}),this.events.on(sE.deleted,e=>{let t=sE.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()})}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var ax=Object.defineProperty,aU=(e,t,r)=>t in e?ax(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aD=(e,t,r)=>aU(e,"symbol"!=typeof t?t+"":t,r);class a$ extends N{constructor(e,t,r){super(e,t,r),this.core=e,this.logger=t,this.store=r,aD(this,"name","verify-api"),aD(this,"abortController"),aD(this,"isDevEnv"),aD(this,"verifyUrlV3",sI),aD(this,"storagePrefix",sn),aD(this,"version",2),aD(this,"publicKey"),aD(this,"fetchPromise"),aD(this,"init",async()=>{var e;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&(0,R.toMiliseconds)(null==(e=this.publicKey)?void 0:e.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),aD(this,"register",async e=>{if(!et()||this.isDevEnv)return;let t=window.location.origin,{id:r,decryptedId:i}=e,s=`${this.verifyUrlV3}/attestation?projectId=${this.core.projectId}&origin=${t}&id=${r}&decryptedId=${i}`;try{let e=(0,D.getDocument)(),t=this.startAbortTimer(5*R.ONE_SECOND),i=await new Promise((i,n)=>{let a=()=>{window.removeEventListener("message",c),e.body.removeChild(o),n("attestation aborted")};this.abortController.signal.addEventListener("abort",a);let o=e.createElement("iframe");o.src=s,o.style.display="none",o.addEventListener("error",a,{signal:this.abortController.signal});let c=s=>{if(s.data&&"string"==typeof s.data)try{let n=JSON.parse(s.data);if("verify_attestation"===n.type){if((0,x.xp)(n.attestation).payload.id!==r)return;clearInterval(t),e.body.removeChild(o),this.abortController.signal.removeEventListener("abort",a),window.removeEventListener("message",c),i(null===n.attestation?"":n.attestation)}}catch(e){this.logger.warn(e)}};e.body.appendChild(o),window.addEventListener("message",c,{signal:this.abortController.signal})});return this.logger.debug("jwt attestation",i),i}catch(e){this.logger.warn(e)}return""}),aD(this,"resolve",async e=>{if(this.isDevEnv)return"";let{attestationId:t,hash:r,encryptedId:i}=e;if(""===t){this.logger.debug("resolve: attestationId is empty, skipping");return}if(t){if((0,x.xp)(t).payload.id!==i)return;let e=await this.isValidJwtAttestation(t);if(e){if(!e.isVerified){this.logger.warn("resolve: jwt attestation: origin url not verified");return}return e}}if(!r)return;let s=this.getVerifyUrl(e?.verifyUrl);return this.fetchAttestation(r,s)}),aD(this,"fetchAttestation",async(e,t)=>{this.logger.debug(`resolving attestation: ${e} from url: ${t}`);let r=this.startAbortTimer(5*R.ONE_SECOND),i=await fetch(`${t}/attestation/${e}?v2Supported=true`,{signal:this.abortController.signal});return clearTimeout(r),200===i.status?await i.json():void 0}),aD(this,"getVerifyUrl",e=>{let t=e||sN;return sA.includes(t)||(this.logger.info(`verify url: ${t}, not included in trusted list, assigning default: ${sN}`),t=sN),t}),aD(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);let e=this.startAbortTimer(R.FIVE_SECONDS),t=await fetch(`${this.verifyUrlV3}/public-key`,{signal:this.abortController.signal});return clearTimeout(e),await t.json()}catch(e){this.logger.warn(e)}}),aD(this,"persistPublicKey",async e=>{this.logger.debug("persisting public key to local storage",e),await this.store.setItem(this.storeKey,e),this.publicKey=e}),aD(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),aD(this,"isValidJwtAttestation",async e=>{let t=await this.getPublicKey();try{if(t)return this.validateAttestation(e,t)}catch(e){this.logger.error(e),this.logger.warn("error validating attestation")}let r=await this.fetchAndPersistPublicKey();try{if(r)return this.validateAttestation(e,r)}catch(e){this.logger.error(e),this.logger.warn("error validating attestation")}}),aD(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),aD(this,"fetchAndPersistPublicKey",async()=>{if(this.fetchPromise)return await this.fetchPromise,this.publicKey;this.fetchPromise=new Promise(async e=>{let t=await this.fetchPublicKey();t&&(await this.persistPublicKey(t),e(t))});let e=await this.fetchPromise;return this.fetchPromise=void 0,e}),aD(this,"validateAttestation",(e,t)=>{let r=function(e,t){let[r,i,s]=e.split("."),n=Buffer.from(ib(s),"base64");if(64!==n.length)throw Error("Invalid signature length");let a=n.slice(0,32),o=n.slice(32,64),c=t4(`${r}.${i}`),l=function(e){let t=Buffer.from(e.x,"base64"),r=Buffer.from(e.y,"base64");return(0,j.zo)([new Uint8Array([4]),t,r])}(t);if(!ia.verify((0,j.zo)([a,o]),c,l))throw Error("Invalid signature");return(0,x.xp)(e).payload}(e,t.publicKey),i={hasExpired:(0,R.toMiliseconds)(r.exp)<Date.now(),payload:r};if(i.hasExpired)throw this.logger.warn("resolve: jwt attestation expired"),Error("JWT attestation expired");return{origin:i.payload.origin,isScam:i.payload.isScam,isVerified:i.payload.isVerified}}),this.logger=(0,o.Ep)(t,this.name),this.abortController=new AbortController,this.isDevEnv=eC(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return(0,o.Fd)(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),(0,R.toMiliseconds)(e))}}var aM=Object.defineProperty,aL=(e,t,r)=>t in e?aM(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aj=(e,t,r)=>aL(e,"symbol"!=typeof t?t+"":t,r);class aq extends I{constructor(e,t){super(e,t),this.projectId=e,this.logger=t,aj(this,"context","echo"),aj(this,"registerDeviceToken",async e=>{let{clientId:t,token:r,notificationType:i,enableEncrypted:s=!1}=e,n=`https://echo.walletconnect.com/${this.projectId}/clients`;await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_id:t,type:i,token:r,always_raw:s})})}),this.logger=(0,o.Ep)(t,this.context)}}var aB=Object.defineProperty,aF=Object.getOwnPropertySymbols,aH=Object.prototype.hasOwnProperty,aW=Object.prototype.propertyIsEnumerable,aV=(e,t,r)=>t in e?aB(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,az=(e,t)=>{for(var r in t||(t={}))aH.call(t,r)&&aV(e,r,t[r]);if(aF)for(var r of aF(t))aW.call(t,r)&&aV(e,r,t[r]);return e},aK=(e,t,r)=>aV(e,"symbol"!=typeof t?t+"":t,r);class aJ extends A{constructor(e,t,r=!0){super(e,t,r),this.core=e,this.logger=t,aK(this,"context","event-client"),aK(this,"storagePrefix",sn),aK(this,"storageVersion",.1),aK(this,"events",new Map),aK(this,"shouldPersist",!1),aK(this,"init",async()=>{if(!eC())try{let e={eventId:ev(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:en(this.core.relayer.protocol,this.core.relayer.version,sg)}}};await this.sendEvent([e])}catch(e){this.logger.warn(e)}}),aK(this,"createEvent",e=>{let{event:t="ERROR",type:r="",properties:{topic:i,trace:s}}=e,n=ev(),a=this.core.projectId||"",o=az({eventId:n,timestamp:Date.now(),props:{event:t,type:r,properties:{topic:i,trace:s}},bundleId:a,domain:this.getAppDomain()},this.setMethods(n));return this.telemetryEnabled&&(this.events.set(n,o),this.shouldPersist=!0),o}),aK(this,"getEvent",e=>{let{eventId:t,topic:r}=e;if(t)return this.events.get(t);let i=Array.from(this.events.values()).find(e=>e.props.properties.topic===r);if(i)return az(az({},i),this.setMethods(i.eventId))}),aK(this,"deleteEvent",e=>{let{eventId:t}=e;this.events.delete(t),this.shouldPersist=!0}),aK(this,"setEventListeners",()=>{this.core.heartbeat.on(n.Lx.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(e=>{(0,R.fromMiliseconds)(Date.now())-(0,R.fromMiliseconds)(e.timestamp)>86400&&(this.events.delete(e.eventId),this.shouldPersist=!0)})})}),aK(this,"setMethods",e=>({addTrace:t=>this.addTrace(e,t),setError:t=>this.setError(e,t)})),aK(this,"addTrace",(e,t)=>{let r=this.events.get(e);r&&(r.props.properties.trace.push(t),this.events.set(e,r),this.shouldPersist=!0)}),aK(this,"setError",(e,t)=>{let r=this.events.get(e);r&&(r.props.type=t,r.timestamp=Date.now(),this.events.set(e,r),this.shouldPersist=!0)}),aK(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),aK(this,"restore",async()=>{try{let e=await this.core.storage.getItem(this.storageKey)||[];if(!e.length)return;e.forEach(e=>{this.events.set(e.eventId,az(az({},e),this.setMethods(e.eventId)))})}catch(e){this.logger.warn(e)}}),aK(this,"submit",async()=>{if(!this.telemetryEnabled||0===this.events.size)return;let e=[];for(let[t,r]of this.events)r.props.type&&e.push(r);if(0!==e.length)try{if((await this.sendEvent(e)).ok)for(let t of e)this.events.delete(t.eventId),this.shouldPersist=!0}catch(e){this.logger.warn(e)}}),aK(this,"sendEvent",async e=>{let t=this.getAppDomain()?"":"&sp=desktop";return await fetch(`https://pulse.walletconnect.org/batch?projectId=${this.core.projectId}&st=events_sdk&sv=js-${sg}${t}`,{method:"POST",body:JSON.stringify(e)})}),aK(this,"getAppDomain",()=>es().url),this.logger=(0,o.Ep)(t,this.context),this.telemetryEnabled=r,r?this.restore().then(async()=>{await this.submit(),this.setEventListeners()}):this.persist()}get storageKey(){return this.storagePrefix+this.storageVersion+this.core.customStoragePrefix+"//"+this.context}}var aG=Object.defineProperty,aY=Object.getOwnPropertySymbols,aX=Object.prototype.hasOwnProperty,aZ=Object.prototype.propertyIsEnumerable,aQ=(e,t,r)=>t in e?aG(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,a0=(e,t)=>{for(var r in t||(t={}))aX.call(t,r)&&aQ(e,r,t[r]);if(aY)for(var r of aY(t))aZ.call(t,r)&&aQ(e,r,t[r]);return e},a1=(e,t,r)=>aQ(e,"symbol"!=typeof t?t+"":t,r);class a2 extends u{constructor(e){var t;super(e),a1(this,"protocol","wc"),a1(this,"version",2),a1(this,"name",ss),a1(this,"relayUrl"),a1(this,"projectId"),a1(this,"customStoragePrefix"),a1(this,"events",new i.EventEmitter),a1(this,"logger"),a1(this,"heartbeat"),a1(this,"relayer"),a1(this,"crypto"),a1(this,"storage"),a1(this,"history"),a1(this,"expirer"),a1(this,"pairing"),a1(this,"verify"),a1(this,"echoClient"),a1(this,"linkModeSupportedApps"),a1(this,"eventClient"),a1(this,"initialized",!1),a1(this,"logChunkController"),a1(this,"on",(e,t)=>this.events.on(e,t)),a1(this,"once",(e,t)=>this.events.once(e,t)),a1(this,"off",(e,t)=>this.events.off(e,t)),a1(this,"removeListener",(e,t)=>this.events.removeListener(e,t)),a1(this,"dispatchEnvelope",({topic:e,message:t,sessionExists:r})=>{if(!e||!t)return;let i={topic:e,message:t,publishedAt:Date.now(),transportType:sf.link_mode};this.relayer.onLinkMessageEvent(i,{sessionExists:r})});let r=this.getGlobalCore(e?.customStoragePrefix);if(r)try{return this.customStoragePrefix=r.customStoragePrefix,this.logger=r.logger,this.heartbeat=r.heartbeat,this.crypto=r.crypto,this.history=r.history,this.expirer=r.expirer,this.storage=r.storage,this.relayer=r.relayer,this.pairing=r.pairing,this.verify=r.verify,this.echoClient=r.echoClient,this.linkModeSupportedApps=r.linkModeSupportedApps,this.eventClient=r.eventClient,this.initialized=r.initialized,this.logChunkController=r.logChunkController,r}catch(e){console.warn("Failed to copy global core",e)}this.projectId=e?.projectId,this.relayUrl=e?.relayUrl||sd,this.customStoragePrefix=null!=e&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";let s=(0,o.jI)({level:"string"==typeof e?.logger&&e.logger?e.logger:sa.logger,name:ss}),{logger:c,chunkLoggerController:l}=(0,o.Rt)({opts:s,maxSizeInBytes:e?.maxLogBlobSizeInBytes,loggerOverride:e?.logger});this.logChunkController=l,null!=(t=this.logChunkController)&&t.downloadLogsBlobInBrowser&&(window.downloadLogsBlobInBrowser=async()=>{var e,t;null!=(e=this.logChunkController)&&e.downloadLogsBlobInBrowser&&(null==(t=this.logChunkController)||t.downloadLogsBlobInBrowser({clientId:await this.crypto.getClientId()}))}),this.logger=(0,o.Ep)(c,this.name),this.heartbeat=new n.C$,this.crypto=new nA(this,this.logger,e?.keychain),this.history=new aO(this,this.logger),this.expirer=new ak(this,this.logger),this.storage=null!=e&&e.storage?e.storage:new a.Z(a0(a0({},so),e?.storageOptions)),this.relayer=new aa({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new aI(this,this.logger),this.verify=new a$(this,this.logger,this.storage),this.echoClient=new aq(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new aJ(this,this.logger,e?.telemetryEnabled),this.setGlobalCore(this)}static async init(e){let t=new a2(e);await t.initialize();let r=await t.crypto.getClientId();return await t.storage.setItem("WALLETCONNECT_CLIENT_ID",r),t}get context(){return(0,o.Fd)(this.logger)}async start(){this.initialized||await this.initialize()}async getLogsBlob(){var e;return null==(e=this.logChunkController)?void 0:e.logsToBlob({clientId:await this.crypto.getClientId()})}async addLinkModeSupportedApp(e){this.linkModeSupportedApps.includes(e)||(this.linkModeSupportedApps.push(e),await this.storage.setItem(sw,this.linkModeSupportedApps))}async initialize(){this.logger.trace("Initialized");try{await this.crypto.init(),await this.history.init(),await this.expirer.init(),await this.relayer.init(),await this.heartbeat.init(),await this.pairing.init(),this.linkModeSupportedApps=await this.storage.getItem(sw)||[],this.initialized=!0,this.logger.info("Core Initialization Success")}catch(e){throw this.logger.warn(`Core Initialization Failure at epoch ${Date.now()}`,e),this.logger.error(e.message),e}}getGlobalCore(e=""){try{if(this.isGlobalCoreDisabled())return;let t=`_walletConnectCore_${e}`,r=`${t}_count`;return globalThis[r]=(globalThis[r]||0)+1,globalThis[r]>1&&console.warn(`WalletConnect Core is already initialized. This is probably a mistake and can lead to unexpected behavior. Init() was called ${globalThis[r]} times.`),globalThis[t]}catch(e){console.warn("Failed to get global WalletConnect core",e);return}}setGlobalCore(e){var t;try{if(this.isGlobalCoreDisabled())return;let r=`_walletConnectCore_${(null==(t=e.opts)?void 0:t.customStoragePrefix)||""}`;globalThis[r]=e}catch(e){console.warn("Failed to set global WalletConnect core",e)}}isGlobalCoreDisabled(){try{return"u">typeof process&&"true"===process.env.DISABLE_GLOBAL_CORE}catch{return!0}}}let a5="client",a3=`wc@2:${a5}:`,a4={name:a5,logger:"error"},a8="WALLETCONNECT_DEEPLINK_CHOICE",a6="Proposal expired",a9=R.SEVEN_DAYS,a7={wc_sessionPropose:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1104},res:{ttl:R.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1106},res:{ttl:R.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1112},res:{ttl:R.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1114},res:{ttl:R.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:R.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:R.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1119}}},oe={min:R.FIVE_MINUTES,max:R.SEVEN_DAYS},ot={idle:"IDLE",active:"ACTIVE"},or={eth_sendTransaction:{key:""},eth_sendRawTransaction:{key:""},wallet_sendCalls:{key:""},solana_signTransaction:{key:"signature"},solana_signAllTransactions:{key:"transactions"},solana_signAndSendTransaction:{key:"signature"}},oi=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],os="wc@1.5:auth:",on=`${os}:PUB_KEY`;var oa=Object.defineProperty,oo=Object.defineProperties,oc=Object.getOwnPropertyDescriptors,ol=Object.getOwnPropertySymbols,oh=Object.prototype.hasOwnProperty,od=Object.prototype.propertyIsEnumerable,ou=(e,t,r)=>t in e?oa(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,op=(e,t)=>{for(var r in t||(t={}))oh.call(t,r)&&ou(e,r,t[r]);if(ol)for(var r of ol(t))od.call(t,r)&&ou(e,r,t[r]);return e},og=(e,t)=>oo(e,oc(t)),of=(e,t,r)=>ou(e,"symbol"!=typeof t?t+"":t,r);class om extends T{constructor(e){super(e),of(this,"name","engine"),of(this,"events",new(s())),of(this,"initialized",!1),of(this,"requestQueue",{state:ot.idle,queue:[]}),of(this,"sessionRequestQueue",{state:ot.idle,queue:[]}),of(this,"requestQueueDelay",R.ONE_SECOND),of(this,"expectedPairingMethodMap",new Map),of(this,"recentlyDeletedMap",new Map),of(this,"recentlyDeletedLimit",200),of(this,"relayMessageCache",[]),of(this,"pendingSessions",new Map),of(this,"init",async()=>{this.initialized||(await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.registerPairingEvents(),await this.registerLinkModeListeners(),this.client.core.pairing.register({methods:Object.keys(a7)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},(0,R.toMiliseconds)(this.requestQueueDelay)))}),of(this,"connect",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();let t=og(op({},e),{requiredNamespaces:e.requiredNamespaces||{},optionalNamespaces:e.optionalNamespaces||{}});await this.isValidConnect(t),t.optionalNamespaces=function(e,t){var r,i,s,n,a,o;let c=iB(e),l=iB(t),h={};for(let e of Object.keys(c).concat(Object.keys(l)))h[e]={chains:em(null==(r=c[e])?void 0:r.chains,null==(i=l[e])?void 0:i.chains),methods:em(null==(s=c[e])?void 0:s.methods,null==(n=l[e])?void 0:n.methods),events:em(null==(a=c[e])?void 0:a.events,null==(o=l[e])?void 0:o.events)};return h}(t.requiredNamespaces,t.optionalNamespaces),t.requiredNamespaces={};let{pairingTopic:r,requiredNamespaces:i,optionalNamespaces:s,sessionProperties:n,scopedProperties:a,relays:o}=t,c=r,l,h=!1;try{if(c){let e=this.client.core.pairing.pairings.get(c);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),h=e.active}}catch(e){throw this.client.logger.error(`connect() -> pairing.get(${c}) failed`),e}if(!c||!h){let{topic:e,uri:t}=await this.client.core.pairing.create();c=e,l=t}if(!c){let{message:e}=iV("NO_MATCHING_KEY",`connect() pairing topic: ${c}`);throw Error(e)}let d=await this.client.core.crypto.generateKeyPair(),u=a7.wc_sessionPropose.req.ttl||R.FIVE_MINUTES,p=ep(u),g=og(op(op({requiredNamespaces:i,optionalNamespaces:s,relays:o??[{protocol:"irn"}],proposer:{publicKey:d,metadata:this.client.metadata},expiryTimestamp:p,pairingTopic:c},n&&{sessionProperties:n}),a&&{scopedProperties:a}),{id:(0,sr.payloadId)()}),f=ef("session_connect",g.id),{reject:m,resolve:w,done:y}=el(u,a6),b=({id:e})=>{e===g.id&&(this.client.events.off("proposal_expire",b),this.pendingSessions.delete(g.id),this.events.emit(f,{error:{message:a6,code:0}}))};return this.client.events.on("proposal_expire",b),this.events.once(f,({error:e,session:t})=>{this.client.events.off("proposal_expire",b),e?m(e):t&&w(t)}),await this.sendRequest({topic:c,method:"wc_sessionPropose",params:g,throwOnFailedPublish:!0,clientRpcId:g.id}),await this.setProposal(g.id,g),{uri:l,approval:y}}),of(this,"pair",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{return await this.client.core.pairing.pair(e)}catch(e){throw this.client.logger.error("pair() failed"),e}}),of(this,"approve",async e=>{var t,r,i;let s=this.client.core.eventClient.createEvent({properties:{topic:null==(t=e?.id)?void 0:t.toString(),trace:[sO.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(e){throw s.setError(sP.no_internet_connection),e}try{await this.isValidProposalId(e?.id)}catch(t){throw this.client.logger.error(`approve() -> proposal.get(${e?.id}) failed`),s.setError(sP.proposal_not_found),t}try{await this.isValidApprove(e)}catch(e){throw this.client.logger.error("approve() -> isValidApprove() failed"),s.setError(sP.session_approve_namespace_validation_failure),e}let{id:n,relayProtocol:a,namespaces:o,sessionProperties:c,scopedProperties:l,sessionConfig:h}=e,d=this.client.proposal.get(n);this.client.core.eventClient.deleteEvent({eventId:s.eventId});let{pairingTopic:u,proposer:p,requiredNamespaces:g,optionalNamespaces:f}=d,m=null==(r=this.client.core.eventClient)?void 0:r.getEvent({topic:u});m||(m=null==(i=this.client.core.eventClient)?void 0:i.createEvent({type:sO.session_approve_started,properties:{topic:u,trace:[sO.session_approve_started,sO.session_namespaces_validation_success]}}));let w=await this.client.core.crypto.generateKeyPair(),y=p.publicKey,b=await this.client.core.crypto.generateSharedKey(w,y),v=op(op(op({relay:{protocol:a??"irn"},namespaces:o,controller:{publicKey:w,metadata:this.client.metadata},expiry:ep(a9)},c&&{sessionProperties:c}),l&&{scopedProperties:l}),h&&{sessionConfig:h}),C=sf.relay;m.addTrace(sO.subscribing_session_topic);try{await this.client.core.relayer.subscribe(b,{transportType:C})}catch(e){throw m.setError(sP.subscribe_session_topic_failure),e}m.addTrace(sO.subscribe_session_topic_success);let E=og(op({},v),{topic:b,requiredNamespaces:g,optionalNamespaces:f,pairingTopic:u,acknowledged:!1,self:v.controller,peer:{publicKey:p.publicKey,metadata:p.metadata},controller:w,transportType:sf.relay});await this.client.session.set(b,E),m.addTrace(sO.store_session);try{m.addTrace(sO.publishing_session_settle),await this.sendRequest({topic:b,method:"wc_sessionSettle",params:v,throwOnFailedPublish:!0}).catch(e=>{throw m?.setError(sP.session_settle_publish_failure),e}),m.addTrace(sO.session_settle_publish_success),m.addTrace(sO.publishing_session_approve),await this.sendResult({id:n,topic:u,result:{relay:{protocol:a??"irn"},responderPublicKey:w},throwOnFailedPublish:!0}).catch(e=>{throw m?.setError(sP.session_approve_publish_failure),e}),m.addTrace(sO.session_approve_publish_success)}catch(e){throw this.client.logger.error(e),this.client.session.delete(b,iz("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(b),e}return this.client.core.eventClient.deleteEvent({eventId:m.eventId}),await this.client.core.pairing.updateMetadata({topic:u,metadata:p.metadata}),await this.client.proposal.delete(n,iz("USER_DISCONNECTED")),await this.client.core.pairing.activate({topic:u}),await this.setExpiry(b,ep(a9)),{topic:b,acknowledged:()=>Promise.resolve(this.client.session.get(b))}}),of(this,"reject",async e=>{let t;this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidReject(e)}catch(e){throw this.client.logger.error("reject() -> isValidReject() failed"),e}let{id:r,reason:i}=e;try{t=this.client.proposal.get(r).pairingTopic}catch(e){throw this.client.logger.error(`reject() -> proposal.get(${r}) failed`),e}t&&(await this.sendError({id:r,topic:t,error:i,rpcOpts:a7.wc_sessionPropose.reject}),await this.client.proposal.delete(r,iz("USER_DISCONNECTED")))}),of(this,"update",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(e)}catch(e){throw this.client.logger.error("update() -> isValidUpdate() failed"),e}let{topic:t,namespaces:r}=e,{done:i,resolve:s,reject:n}=el(),a=(0,sr.payloadId)(),o=(0,sr.getBigIntRpcId)().toString(),c=this.client.session.get(t).namespaces;return this.events.once(ef("session_update",a),({error:e})=>{e?n(e):s()}),await this.client.session.update(t,{namespaces:r}),await this.sendRequest({topic:t,method:"wc_sessionUpdate",params:{namespaces:r},throwOnFailedPublish:!0,clientRpcId:a,relayRpcId:o}).catch(e=>{this.client.logger.error(e),this.client.session.update(t,{namespaces:c}),n(e)}),{acknowledged:i}}),of(this,"extend",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidExtend(e)}catch(e){throw this.client.logger.error("extend() -> isValidExtend() failed"),e}let{topic:t}=e,r=(0,sr.payloadId)(),{done:i,resolve:s,reject:n}=el();return this.events.once(ef("session_extend",r),({error:e})=>{e?n(e):s()}),await this.setExpiry(t,ep(a9)),this.sendRequest({topic:t,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(e=>{n(e)}),{acknowledged:i}}),of(this,"request",async e=>{this.isInitialized();try{await this.isValidRequest(e)}catch(e){throw this.client.logger.error("request() -> isValidRequest() failed"),e}let{chainId:t,request:r,topic:i,expiry:s=a7.wc_sessionRequest.req.ttl}=e,n=this.client.session.get(i);n?.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let a=(0,sr.payloadId)(),o=(0,sr.getBigIntRpcId)().toString(),{done:c,resolve:l,reject:h}=el(s,"Request expired. Please try again.");this.events.once(ef("session_request",a),({error:e,result:t})=>{e?h(e):l(t)});let d="wc_sessionRequest",u=this.getAppLinkIfEnabled(n.peer.metadata,n.transportType);if(u)return await this.sendRequest({clientRpcId:a,relayRpcId:o,topic:i,method:d,params:{request:og(op({},r),{expiryTimestamp:ep(s)}),chainId:t},expiry:s,throwOnFailedPublish:!0,appLink:u}).catch(e=>h(e)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:t,id:a}),await c();let p={request:og(op({},r),{expiryTimestamp:ep(s)}),chainId:t},g=this.shouldSetTVF(d,p);return await Promise.all([new Promise(async e=>{await this.sendRequest(op({clientRpcId:a,relayRpcId:o,topic:i,method:d,params:p,expiry:s,throwOnFailedPublish:!0},g&&{tvf:this.getTVFParams(a,p)})).catch(e=>h(e)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:t,id:a}),e()}),new Promise(async e=>{var t;if(!(null!=(t=n.sessionConfig)&&t.disableDeepLink)){let e=await ey(this.client.core.storage,a8);await ew({id:a,topic:i,wcDeepLink:e})}e()}),c()]).then(e=>e[2])}),of(this,"respond",async e=>{this.isInitialized(),await this.isValidRespond(e);let{topic:t,response:r}=e,{id:i}=r,s=this.client.session.get(t);s.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let n=this.getAppLinkIfEnabled(s.peer.metadata,s.transportType);(0,sr.isJsonRpcResult)(r)?await this.sendResult({id:i,topic:t,result:r.result,throwOnFailedPublish:!0,appLink:n}):(0,sr.isJsonRpcError)(r)&&await this.sendError({id:i,topic:t,error:r.error,appLink:n}),this.cleanupAfterResponse(e)}),of(this,"ping",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidPing(e)}catch(e){throw this.client.logger.error("ping() -> isValidPing() failed"),e}let{topic:t}=e;if(this.client.session.keys.includes(t)){let e=(0,sr.payloadId)(),r=(0,sr.getBigIntRpcId)().toString(),{done:i,resolve:s,reject:n}=el();this.events.once(ef("session_ping",e),({error:e})=>{e?n(e):s()}),await Promise.all([this.sendRequest({topic:t,method:"wc_sessionPing",params:{},throwOnFailedPublish:!0,clientRpcId:e,relayRpcId:r}),i()])}else this.client.core.pairing.pairings.keys.includes(t)&&(this.client.logger.warn("ping() on pairing topic is deprecated and will be removed in the next major release."),await this.client.core.pairing.ping({topic:t}))}),of(this,"emit",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(e);let{topic:t,event:r,chainId:i}=e,s=(0,sr.getBigIntRpcId)().toString(),n=(0,sr.payloadId)();await this.sendRequest({topic:t,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:s,clientRpcId:n})}),of(this,"disconnect",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidDisconnect(e);let{topic:t}=e;if(this.client.session.keys.includes(t))await this.sendRequest({topic:t,method:"wc_sessionDelete",params:iz("USER_DISCONNECTED"),throwOnFailedPublish:!0}),await this.deleteSession({topic:t,emitEvent:!1});else if(this.client.core.pairing.pairings.keys.includes(t))await this.client.core.pairing.disconnect({topic:t});else{let{message:e}=iV("MISMATCHED_TOPIC",`Session or pairing topic not found: ${t}`);throw Error(e)}}),of(this,"find",e=>(this.isInitialized(),this.client.session.getAll().filter(t=>(function(e,t){let{requiredNamespaces:r}=t,i=Object.keys(e.namespaces),s=Object.keys(r),n=!0;return!!ea(s,i)&&(i.forEach(t=>{let{accounts:i,methods:s,events:a}=e.namespaces[t],o=iL(i),c=r[t];ea(F(t,c),o)&&ea(c.methods,s)&&ea(c.events,a)||(n=!1)}),n)})(t,e)))),of(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),of(this,"authenticate",async(e,t)=>{var r,i,s;let n;this.isInitialized(),this.isValidAuthenticate(e);let a=t&&this.client.core.linkModeSupportedApps.includes(t)&&(null==(r=this.client.metadata.redirect)?void 0:r.linkMode),o=a?sf.link_mode:sf.relay;o===sf.relay&&await this.confirmOnlineStateOrThrow();let{chains:c,statement:l="",uri:h,domain:d,nonce:u,type:p,exp:g,nbf:f,methods:m=[],expiry:w}=e,y=[...e.resources||[]],{topic:b,uri:v}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:b,uri:v}});let C=await this.client.core.crypto.generateKeyPair(),E=ip(C);if(await Promise.all([this.client.auth.authKeys.set(on,{responseTopic:E,publicKey:C}),this.client.auth.pairingTopics.set(E,{topic:E,pairingTopic:b})]),await this.client.core.relayer.subscribe(E,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${b}`),m.length>0){let{namespace:e}=B(c[0]),t=tg(function(e,t,r,i={}){return r?.sort((e,t)=>e.localeCompare(t)),{att:{[e]:function(e,t,r={}){return Object.assign({},...(t=t?.sort((e,t)=>e.localeCompare(t))).map(t=>({[`${e}/${t}`]:[r]})))}(t,r,i)}}}(e,"request",m));ty(y)&&(i=t,s=y.pop(),t=tg(function(e,t){tp(e),tp(t);let r=Object.keys(e.att).concat(Object.keys(t.att)).sort((e,t)=>e.localeCompare(t)),i={att:{}};return r.forEach(r=>{var s,n;Object.keys((null==(s=e.att)?void 0:s[r])||{}).concat(Object.keys((null==(n=t.att)?void 0:n[r])||{})).sort((e,t)=>e.localeCompare(t)).forEach(s=>{var n,a;i.att[r]=ta(tn({},i.att[r]),{[s]:(null==(n=e.att[r])?void 0:n[s])||(null==(a=t.att[r])?void 0:a[s])})})}),i}(tf(i),tf(s)))),y.push(t)}let N=w&&w>a7.wc_sessionAuthenticate.req.ttl?w:a7.wc_sessionAuthenticate.req.ttl,I={authPayload:{type:p??"caip122",chains:c,statement:l,aud:h,domain:d,version:"1",nonce:u,iat:new Date().toISOString(),exp:g,nbf:f,resources:y},requester:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:ep(N)},A={requiredNamespaces:{},optionalNamespaces:{eip155:{chains:c,methods:[...new Set(["personal_sign",...m])],events:["chainChanged","accountsChanged"]}},relays:[{protocol:"irn"}],pairingTopic:b,proposer:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:ep(a7.wc_sessionPropose.req.ttl),id:(0,sr.payloadId)()},{done:_,resolve:S,reject:O}=el(N,"Request expired"),P=(0,sr.payloadId)(),T=ef("session_connect",A.id),R=ef("session_request",P),k=async({error:e,session:t})=>{this.events.off(R,x),e?O(e):t&&S({session:t})},x=async e=>{var r,i,s;let n;if(await this.deletePendingAuthRequest(P,{message:"fulfilled",code:0}),e.error){let t=iz("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return e.error.code===t.code?void 0:(this.events.off(T,k),O(e.error.message))}await this.deleteProposal(A.id),this.events.off(T,k);let{cacaos:a,responder:c}=e.result,l=[],h=[];for(let e of a){await td({cacao:e,projectId:this.client.core.projectId})||(this.client.logger.error(e,"Signature verification failed"),O(iz("SESSION_SETTLEMENT_FAILED","Signature verification failed")));let{p:t}=e,r=ty(t.resources),i=[tl(t.iss)],s=th(t.iss);if(r){let e=tm(r),t=tw(r);l.push(...e),i.push(...t)}for(let e of i)h.push(`${e}:${s}`)}let d=await this.client.core.crypto.generateSharedKey(C,c.publicKey);l.length>0&&(n={topic:d,acknowledged:!0,self:{publicKey:C,metadata:this.client.metadata},peer:c,controller:c.publicKey,expiry:ep(a9),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:b,namespaces:iF([...new Set(l)],[...new Set(h)]),transportType:o},await this.client.core.relayer.subscribe(d,{transportType:o}),await this.client.session.set(d,n),b&&await this.client.core.pairing.updateMetadata({topic:b,metadata:c.metadata}),n=this.client.session.get(d)),null!=(r=this.client.metadata.redirect)&&r.linkMode&&null!=(i=c.metadata.redirect)&&i.linkMode&&null!=(s=c.metadata.redirect)&&s.universal&&t&&(this.client.core.addLinkModeSupportedApp(c.metadata.redirect.universal),this.client.session.update(d,{transportType:sf.link_mode})),S({auths:a,session:n})};this.events.once(T,k),this.events.once(R,x);try{if(a){let e=(0,sr.formatJsonRpcRequest)("wc_sessionAuthenticate",I,P);this.client.core.history.set(b,e);let r=await this.client.core.crypto.encode("",e,{type:2,encoding:ih});n=iO(t,b,r)}else await Promise.all([this.sendRequest({topic:b,method:"wc_sessionAuthenticate",params:I,expiry:e.expiry,throwOnFailedPublish:!0,clientRpcId:P}),this.sendRequest({topic:b,method:"wc_sessionPropose",params:A,expiry:a7.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:A.id})])}catch(e){throw this.events.off(T,k),this.events.off(R,x),e}return await this.setProposal(A.id,A),await this.setAuthRequest(P,{request:og(op({},I),{verifyContext:{}}),pairingTopic:b,transportType:o}),{uri:n??v,response:_}}),of(this,"approveSessionAuthenticate",async e=>{let t;let{id:r,auths:i}=e,s=this.client.core.eventClient.createEvent({properties:{topic:r.toString(),trace:[sT.authenticated_session_approve_started]}});try{this.isInitialized()}catch(e){throw s.setError(sR.no_internet_connection),e}let n=this.getPendingAuthRequest(r);if(!n)throw s.setError(sR.authenticated_session_pending_request_not_found),Error(`Could not find pending auth request with id ${r}`);let a=n.transportType||sf.relay;a===sf.relay&&await this.confirmOnlineStateOrThrow();let o=n.requester.publicKey,c=await this.client.core.crypto.generateKeyPair(),l=ip(o),h={type:1,receiverPublicKey:o,senderPublicKey:c},d=[],u=[];for(let e of i){if(!await td({cacao:e,projectId:this.client.core.projectId})){s.setError(sR.invalid_cacao);let e=iz("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:r,topic:l,error:e,encodeOpts:h}),Error(e.message)}s.addTrace(sT.cacaos_verified);let{p:t}=e,i=ty(t.resources),n=[tl(t.iss)],a=th(t.iss);if(i){let e=tm(i),t=tw(i);d.push(...e),n.push(...t)}for(let e of n)u.push(`${e}:${a}`)}let p=await this.client.core.crypto.generateSharedKey(c,o);if(s.addTrace(sT.create_authenticated_session_topic),d?.length>0){t={topic:p,acknowledged:!0,self:{publicKey:c,metadata:this.client.metadata},peer:{publicKey:o,metadata:n.requester.metadata},controller:o,expiry:ep(a9),authentication:i,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:n.pairingTopic,namespaces:iF([...new Set(d)],[...new Set(u)]),transportType:a},s.addTrace(sT.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(p,{transportType:a})}catch(e){throw s.setError(sR.subscribe_authenticated_session_topic_failure),e}s.addTrace(sT.subscribe_authenticated_session_topic_success),await this.client.session.set(p,t),s.addTrace(sT.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:n.pairingTopic,metadata:n.requester.metadata})}s.addTrace(sT.publishing_authenticated_session_approve);try{await this.sendResult({topic:l,id:r,result:{cacaos:i,responder:{publicKey:c,metadata:this.client.metadata}},encodeOpts:h,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(n.requester.metadata,a)})}catch(e){throw s.setError(sR.authenticated_session_approve_publish_failure),e}return await this.client.auth.requests.delete(r,{message:"fulfilled",code:0}),await this.client.core.pairing.activate({topic:n.pairingTopic}),this.client.core.eventClient.deleteEvent({eventId:s.eventId}),{session:t}}),of(this,"rejectSessionAuthenticate",async e=>{this.isInitialized();let{id:t,reason:r}=e,i=this.getPendingAuthRequest(t);if(!i)throw Error(`Could not find pending auth request with id ${t}`);i.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let s=i.requester.publicKey,n=await this.client.core.crypto.generateKeyPair(),a=ip(s);await this.sendError({id:t,topic:a,error:r,encodeOpts:{type:1,receiverPublicKey:s,senderPublicKey:n},rpcOpts:a7.wc_sessionAuthenticate.reject,appLink:this.getAppLinkIfEnabled(i.requester.metadata,i.transportType)}),await this.client.auth.requests.delete(t,{message:"rejected",code:0}),await this.client.proposal.delete(t,iz("USER_DISCONNECTED"))}),of(this,"formatAuthMessage",e=>{this.isInitialized();let{request:t,iss:r}=e;return tu(t,r)}),of(this,"processRelayMessageCache",()=>{setTimeout(async()=>{if(0!==this.relayMessageCache.length)for(;this.relayMessageCache.length>0;)try{let e=this.relayMessageCache.shift();e&&await this.onRelayMessage(e)}catch(e){this.client.logger.error(e)}},50)}),of(this,"cleanupDuplicatePairings",async e=>{if(e.pairingTopic)try{let t=this.client.core.pairing.pairings.get(e.pairingTopic),r=this.client.core.pairing.pairings.getAll().filter(r=>{var i,s;return(null==(i=r.peerMetadata)?void 0:i.url)&&(null==(s=r.peerMetadata)?void 0:s.url)===e.peer.metadata.url&&r.topic&&r.topic!==t.topic});if(0===r.length)return;this.client.logger.info(`Cleaning up ${r.length} duplicate pairing(s)`),await Promise.all(r.map(e=>this.client.core.pairing.disconnect({topic:e.topic}))),this.client.logger.info("Duplicate pairings clean up finished")}catch(e){this.client.logger.error(e)}}),of(this,"deleteSession",async e=>{var t;let{topic:r,expirerHasDeleted:i=!1,emitEvent:s=!0,id:n=0}=e,{self:a}=this.client.session.get(r);await this.client.core.relayer.unsubscribe(r),await this.client.session.delete(r,iz("USER_DISCONNECTED")),this.addToRecentlyDeleted(r,"session"),this.client.core.crypto.keychain.has(a.publicKey)&&await this.client.core.crypto.deleteKeyPair(a.publicKey),this.client.core.crypto.keychain.has(r)&&await this.client.core.crypto.deleteSymKey(r),i||this.client.core.expirer.del(r),this.client.core.storage.removeItem(a8).catch(e=>this.client.logger.warn(e)),this.getPendingSessionRequests().forEach(e=>{e.topic===r&&this.deletePendingSessionRequest(e.id,iz("USER_DISCONNECTED"))}),r===(null==(t=this.sessionRequestQueue.queue[0])?void 0:t.topic)&&(this.sessionRequestQueue.state=ot.idle),s&&this.client.events.emit("session_delete",{id:n,topic:r})}),of(this,"deleteProposal",async(e,t)=>{if(t)try{let t=this.client.proposal.get(e),r=this.client.core.eventClient.getEvent({topic:t.pairingTopic});r?.setError(sP.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(e,iz("USER_DISCONNECTED")),t?Promise.resolve():this.client.core.expirer.del(e)]),this.addToRecentlyDeleted(e,"proposal")}),of(this,"deletePendingSessionRequest",async(e,t,r=!1)=>{await Promise.all([this.client.pendingRequest.delete(e,t),r?Promise.resolve():this.client.core.expirer.del(e)]),this.addToRecentlyDeleted(e,"request"),this.sessionRequestQueue.queue=this.sessionRequestQueue.queue.filter(t=>t.id!==e),r&&(this.sessionRequestQueue.state=ot.idle,this.client.events.emit("session_request_expire",{id:e}))}),of(this,"deletePendingAuthRequest",async(e,t,r=!1)=>{await Promise.all([this.client.auth.requests.delete(e,t),r?Promise.resolve():this.client.core.expirer.del(e)])}),of(this,"setExpiry",async(e,t)=>{this.client.session.keys.includes(e)&&(this.client.core.expirer.set(e,t),await this.client.session.update(e,{expiry:t}))}),of(this,"setProposal",async(e,t)=>{this.client.core.expirer.set(e,ep(a7.wc_sessionPropose.req.ttl)),await this.client.proposal.set(e,t)}),of(this,"setAuthRequest",async(e,t)=>{let{request:r,pairingTopic:i,transportType:s=sf.relay}=t;this.client.core.expirer.set(e,r.expiryTimestamp),await this.client.auth.requests.set(e,{authPayload:r.authPayload,requester:r.requester,expiryTimestamp:r.expiryTimestamp,id:e,pairingTopic:i,verifyContext:r.verifyContext,transportType:s})}),of(this,"setPendingSessionRequest",async e=>{let{id:t,topic:r,params:i,verifyContext:s}=e,n=i.request.expiryTimestamp||ep(a7.wc_sessionRequest.req.ttl);this.client.core.expirer.set(t,n),await this.client.pendingRequest.set(t,{id:t,topic:r,params:i,verifyContext:s})}),of(this,"sendRequest",async e=>{let t,r;let{topic:i,method:s,params:n,expiry:a,relayRpcId:o,clientRpcId:c,throwOnFailedPublish:l,appLink:h,tvf:d}=e,u=(0,sr.formatJsonRpcRequest)(s,n,c),p=!!h;try{let e=p?ih:il;t=await this.client.core.crypto.encode(i,u,{encoding:e})}catch(e){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${i} failed`),e}if(oi.includes(s)){let e=ig(JSON.stringify(u)),i=ig(t);r=await this.client.core.verify.register({id:i,decryptedId:e})}let g=a7[s].req;if(g.attestation=r,a&&(g.ttl=a),o&&(g.id=o),this.client.core.history.set(i,u),p){let e=iO(h,i,t);await global.Linking.openURL(e,this.client.name)}else{let e=a7[s].req;a&&(e.ttl=a),o&&(e.id=o),e.tvf=og(op({},d),{correlationId:u.id}),l?(e.internal=og(op({},e.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(i,t,e)):this.client.core.relayer.publish(i,t,e).catch(e=>this.client.logger.error(e))}return u.id}),of(this,"sendResult",async e=>{let t,r,i;let{id:s,topic:n,result:a,throwOnFailedPublish:o,encodeOpts:c,appLink:l}=e,h=(0,sr.formatJsonRpcResult)(s,a),d=l&&"u">typeof(null==global?void 0:global.Linking);try{let e=d?ih:il;t=await this.client.core.crypto.encode(n,h,og(op({},c||{}),{encoding:e}))}catch(e){throw await this.cleanup(),this.client.logger.error(`sendResult() -> core.crypto.encode() for topic ${n} failed`),e}try{let e=(r=await this.client.core.history.get(n,s)).request;try{this.shouldSetTVF(e.method,e.params)&&(i=this.getTVFParams(s,e.params,a))}catch(e){this.client.logger.warn("sendResult() -> getTVFParams() failed",e)}}catch(e){throw this.client.logger.error(`sendResult() -> history.get(${n}, ${s}) failed`),e}if(d){let e=iO(l,n,t);await global.Linking.openURL(e,this.client.name)}else{let e=a7[r.request.method].res;e.tvf=og(op({},i),{correlationId:s}),o?(e.internal=og(op({},e.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,t,e)):this.client.core.relayer.publish(n,t,e).catch(e=>this.client.logger.error(e))}await this.client.core.history.resolve(h)}),of(this,"sendError",async e=>{let t,r;let{id:i,topic:s,error:n,encodeOpts:a,rpcOpts:o,appLink:c}=e,l=(0,sr.formatJsonRpcError)(i,n),h=c&&"u">typeof(null==global?void 0:global.Linking);try{let e=h?ih:il;t=await this.client.core.crypto.encode(s,l,og(op({},a||{}),{encoding:e}))}catch(e){throw await this.cleanup(),this.client.logger.error(`sendError() -> core.crypto.encode() for topic ${s} failed`),e}try{r=await this.client.core.history.get(s,i)}catch(e){throw this.client.logger.error(`sendError() -> history.get(${s}, ${i}) failed`),e}if(h){let e=iO(c,s,t);await global.Linking.openURL(e,this.client.name)}else{let e=r.request.method,i=o||a7[e].res;this.client.core.relayer.publish(s,t,i)}await this.client.core.history.resolve(l)}),of(this,"cleanup",async()=>{let e=[],t=[];this.client.session.getAll().forEach(t=>{let r=!1;eg(t.expiry)&&(r=!0),this.client.core.crypto.keychain.has(t.topic)||(r=!0),r&&e.push(t.topic)}),this.client.proposal.getAll().forEach(e=>{eg(e.expiryTimestamp)&&t.push(e.id)}),await Promise.all([...e.map(e=>this.deleteSession({topic:e})),...t.map(e=>this.deleteProposal(e))])}),of(this,"onProviderMessageEvent",async e=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(e):await this.onRelayMessage(e)}),of(this,"onRelayEventRequest",async e=>{this.requestQueue.queue.push(e),await this.processRequestsQueue()}),of(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===ot.active){this.client.logger.info("Request queue already active, skipping...");return}for(this.client.logger.info(`Request queue starting with ${this.requestQueue.queue.length} requests`);this.requestQueue.queue.length>0;){this.requestQueue.state=ot.active;let e=this.requestQueue.queue.shift();if(e)try{await this.processRequest(e)}catch(e){this.client.logger.warn(e)}}this.requestQueue.state=ot.idle}),of(this,"processRequest",async e=>{let{topic:t,payload:r,attestation:i,transportType:s,encryptedId:n}=e,a=r.method;if(!this.shouldIgnorePairingRequest({topic:t,requestMethod:a}))switch(a){case"wc_sessionPropose":return await this.onSessionProposeRequest({topic:t,payload:r,attestation:i,encryptedId:n});case"wc_sessionSettle":return await this.onSessionSettleRequest(t,r);case"wc_sessionUpdate":return await this.onSessionUpdateRequest(t,r);case"wc_sessionExtend":return await this.onSessionExtendRequest(t,r);case"wc_sessionPing":return await this.onSessionPingRequest(t,r);case"wc_sessionDelete":return await this.onSessionDeleteRequest(t,r);case"wc_sessionRequest":return await this.onSessionRequest({topic:t,payload:r,attestation:i,encryptedId:n,transportType:s});case"wc_sessionEvent":return await this.onSessionEventRequest(t,r);case"wc_sessionAuthenticate":return await this.onSessionAuthenticateRequest({topic:t,payload:r,attestation:i,encryptedId:n,transportType:s});default:return this.client.logger.info(`Unsupported request method ${a}`)}}),of(this,"onRelayEventResponse",async e=>{let{topic:t,payload:r,transportType:i}=e,s=(await this.client.core.history.get(t,r.id)).request.method;switch(s){case"wc_sessionPropose":return this.onSessionProposeResponse(t,r,i);case"wc_sessionSettle":return this.onSessionSettleResponse(t,r);case"wc_sessionUpdate":return this.onSessionUpdateResponse(t,r);case"wc_sessionExtend":return this.onSessionExtendResponse(t,r);case"wc_sessionPing":return this.onSessionPingResponse(t,r);case"wc_sessionRequest":return this.onSessionRequestResponse(t,r);case"wc_sessionAuthenticate":return this.onSessionAuthenticateResponse(t,r);default:return this.client.logger.info(`Unsupported response method ${s}`)}}),of(this,"onRelayEventUnknownPayload",e=>{let{topic:t}=e,{message:r}=iV("MISSING_OR_INVALID",`Decoded payload on topic ${t} is not identifiable as a JSON-RPC request or a response.`);throw Error(r)}),of(this,"shouldIgnorePairingRequest",e=>{let{topic:t,requestMethod:r}=e,i=this.expectedPairingMethodMap.get(t);return!(!i||i.includes(r))&&!!(i.includes("wc_sessionAuthenticate")&&this.client.events.listenerCount("session_authenticate")>0)}),of(this,"onSessionProposeRequest",async e=>{let{topic:t,payload:r,attestation:i,encryptedId:s}=e,{params:n,id:a}=r;try{let e=this.client.core.eventClient.getEvent({topic:t});0===this.client.events.listenerCount("session_proposal")&&(console.warn("No listener for session_proposal event"),e?.setError(sS.proposal_listener_not_found)),this.isValidConnect(op({},r.params));let o=n.expiryTimestamp||ep(a7.wc_sessionPropose.req.ttl),c=op({id:a,pairingTopic:t,expiryTimestamp:o},n);await this.setProposal(a,c);let l=await this.getVerifyContext({attestationId:i,hash:ig(JSON.stringify(r)),encryptedId:s,metadata:c.proposer.metadata});e?.addTrace(s_.emit_session_proposal),this.client.events.emit("session_proposal",{id:a,params:c,verifyContext:l})}catch(e){await this.sendError({id:a,topic:t,error:e,rpcOpts:a7.wc_sessionPropose.autoReject}),this.client.logger.error(e)}}),of(this,"onSessionProposeResponse",async(e,t,r)=>{let{id:i}=t;if((0,sr.isJsonRpcResult)(t)){let{result:s}=t;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",result:s});let n=this.client.proposal.get(i);this.client.logger.trace({type:"method",method:"onSessionProposeResponse",proposal:n});let a=n.proposer.publicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",selfPublicKey:a});let o=s.responderPublicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",peerPublicKey:o});let c=await this.client.core.crypto.generateSharedKey(a,o);this.pendingSessions.set(i,{sessionTopic:c,pairingTopic:e,proposalId:i,publicKey:a});let l=await this.client.core.relayer.subscribe(c,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:l}),await this.client.core.pairing.activate({topic:e})}else if((0,sr.isJsonRpcError)(t)){await this.client.proposal.delete(i,iz("USER_DISCONNECTED"));let e=ef("session_connect",i);if(0===this.events.listenerCount(e))throw Error(`emitting ${e} without any listeners, 954`);this.events.emit(e,{error:t.error})}}),of(this,"onSessionSettleRequest",async(e,t)=>{let{id:r,params:i}=t;try{this.isValidSessionSettleRequest(i);let{relay:r,controller:s,expiry:n,namespaces:a,sessionProperties:o,scopedProperties:c,sessionConfig:l}=t.params,h=[...this.pendingSessions.values()].find(t=>t.sessionTopic===e);if(!h)return this.client.logger.error(`Pending session not found for topic ${e}`);let d=this.client.proposal.get(h.proposalId),u=og(op(op(op({topic:e,relay:r,expiry:n,namespaces:a,acknowledged:!0,pairingTopic:h.pairingTopic,requiredNamespaces:d.requiredNamespaces,optionalNamespaces:d.optionalNamespaces,controller:s.publicKey,self:{publicKey:h.publicKey,metadata:this.client.metadata},peer:{publicKey:s.publicKey,metadata:s.metadata}},o&&{sessionProperties:o}),c&&{scopedProperties:c}),l&&{sessionConfig:l}),{transportType:sf.relay});await this.client.session.set(u.topic,u),await this.setExpiry(u.topic,u.expiry),await this.client.core.pairing.updateMetadata({topic:h.pairingTopic,metadata:u.peer.metadata}),this.client.events.emit("session_connect",{session:u}),this.events.emit(ef("session_connect",h.proposalId),{session:u}),this.pendingSessions.delete(h.proposalId),this.deleteProposal(h.proposalId,!1),this.cleanupDuplicatePairings(u),await this.sendResult({id:t.id,topic:e,result:!0,throwOnFailedPublish:!0})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionSettleResponse",async(e,t)=>{let{id:r}=t;(0,sr.isJsonRpcResult)(t)?(await this.client.session.update(e,{acknowledged:!0}),this.events.emit(ef("session_approve",r),{})):(0,sr.isJsonRpcError)(t)&&(await this.client.session.delete(e,iz("USER_DISCONNECTED")),this.events.emit(ef("session_approve",r),{error:t.error}))}),of(this,"onSessionUpdateRequest",async(e,t)=>{let{params:r,id:i}=t;try{let t=`${e}_session_update`,s=se.get(t);if(s&&this.isRequestOutOfSync(s,i)){this.client.logger.warn(`Discarding out of sync request - ${i}`),this.sendError({id:i,topic:e,error:iz("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(op({topic:e},r));try{se.set(t,i),await this.client.session.update(e,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:e,result:!0,throwOnFailedPublish:!0})}catch(e){throw se.delete(t),e}this.client.events.emit("session_update",{id:i,topic:e,params:r})}catch(t){await this.sendError({id:i,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"isRequestOutOfSync",(e,t)=>t.toString().slice(0,-3)<e.toString().slice(0,-3)),of(this,"onSessionUpdateResponse",(e,t)=>{let{id:r}=t,i=ef("session_update",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_update",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_update",r),{error:t.error})}),of(this,"onSessionExtendRequest",async(e,t)=>{let{id:r}=t;try{this.isValidExtend({topic:e}),await this.setExpiry(e,ep(a9)),await this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_extend",{id:r,topic:e})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionExtendResponse",(e,t)=>{let{id:r}=t,i=ef("session_extend",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_extend",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_extend",r),{error:t.error})}),of(this,"onSessionPingRequest",async(e,t)=>{let{id:r}=t;try{this.isValidPing({topic:e}),await this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_ping",{id:r,topic:e})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionPingResponse",(e,t)=>{let{id:r}=t,i=ef("session_ping",r);setTimeout(()=>{if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners 2176`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_ping",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_ping",r),{error:t.error})},500)}),of(this,"onSessionDeleteRequest",async(e,t)=>{let{id:r}=t;try{this.isValidDisconnect({topic:e,reason:t.params}),Promise.all([new Promise(t=>{this.client.core.relayer.once(su.publish,async()=>{t(await this.deleteSession({topic:e,id:r}))})}),this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.cleanupPendingSentRequestsForTopic({topic:e,error:iz("USER_DISCONNECTED")})]).catch(e=>this.client.logger.error(e))}catch(e){this.client.logger.error(e)}}),of(this,"onSessionRequest",async e=>{var t,r,i;let{topic:s,payload:n,attestation:a,encryptedId:o,transportType:c}=e,{id:l,params:h}=n;try{await this.isValidRequest(op({topic:s},h));let e=this.client.session.get(s),n=await this.getVerifyContext({attestationId:a,hash:ig(JSON.stringify((0,sr.formatJsonRpcRequest)("wc_sessionRequest",h,l))),encryptedId:o,metadata:e.peer.metadata,transportType:c}),d={id:l,topic:s,params:h,verifyContext:n};await this.setPendingSessionRequest(d),c===sf.link_mode&&null!=(t=e.peer.metadata.redirect)&&t.universal&&this.client.core.addLinkModeSupportedApp(null==(r=e.peer.metadata.redirect)?void 0:r.universal),null!=(i=this.client.signConfig)&&i.disableRequestQueue?this.emitSessionRequest(d):(this.addSessionRequestToSessionRequestQueue(d),this.processSessionRequestQueue())}catch(e){await this.sendError({id:l,topic:s,error:e}),this.client.logger.error(e)}}),of(this,"onSessionRequestResponse",(e,t)=>{let{id:r}=t,i=ef("session_request",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_request",r),{result:t.result}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_request",r),{error:t.error})}),of(this,"onSessionEventRequest",async(e,t)=>{let{id:r,params:i}=t;try{let t=`${e}_session_event_${i.event.name}`,s=se.get(t);if(s&&this.isRequestOutOfSync(s,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(op({topic:e},i)),this.client.events.emit("session_event",{id:r,topic:e,params:i}),se.set(t,r)}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionAuthenticateResponse",(e,t)=>{let{id:r}=t;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:e,payload:t}),(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_request",r),{result:t.result}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_request",r),{error:t.error})}),of(this,"onSessionAuthenticateRequest",async e=>{var t;let{topic:r,payload:i,attestation:s,encryptedId:n,transportType:a}=e;try{let{requester:e,authPayload:o,expiryTimestamp:c}=i.params,l=await this.getVerifyContext({attestationId:s,hash:ig(JSON.stringify(i)),encryptedId:n,metadata:e.metadata,transportType:a}),h={requester:e,pairingTopic:r,id:i.id,authPayload:o,verifyContext:l,expiryTimestamp:c};await this.setAuthRequest(i.id,{request:h,pairingTopic:r,transportType:a}),a===sf.link_mode&&null!=(t=e.metadata.redirect)&&t.universal&&this.client.core.addLinkModeSupportedApp(e.metadata.redirect.universal),this.client.events.emit("session_authenticate",{topic:r,params:i.params,id:i.id,verifyContext:l})}catch(n){this.client.logger.error(n);let e=i.params.requester.publicKey,t=await this.client.core.crypto.generateKeyPair(),s=this.getAppLinkIfEnabled(i.params.requester.metadata,a);await this.sendError({id:i.id,topic:r,error:n,encodeOpts:{type:1,receiverPublicKey:e,senderPublicKey:t},rpcOpts:a7.wc_sessionAuthenticate.autoReject,appLink:s})}}),of(this,"addSessionRequestToSessionRequestQueue",e=>{this.sessionRequestQueue.queue.push(e)}),of(this,"cleanupAfterResponse",e=>{this.deletePendingSessionRequest(e.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=ot.idle,this.processSessionRequestQueue()},(0,R.toMiliseconds)(this.requestQueueDelay))}),of(this,"cleanupPendingSentRequestsForTopic",({topic:e,error:t})=>{let r=this.client.core.history.pending;r.length>0&&r.filter(t=>t.topic===e&&"wc_sessionRequest"===t.request.method).forEach(e=>{let r=ef("session_request",e.request.id);if(0===this.events.listenerCount(r))throw Error(`emitting ${r} without any listeners`);this.events.emit(ef("session_request",e.request.id),{error:t})})}),of(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===ot.active){this.client.logger.info("session request queue is already active.");return}let e=this.sessionRequestQueue.queue[0];if(!e){this.client.logger.info("session request queue is empty.");return}try{this.sessionRequestQueue.state=ot.active,this.emitSessionRequest(e)}catch(e){this.client.logger.error(e)}}),of(this,"emitSessionRequest",e=>{this.client.events.emit("session_request",e)}),of(this,"onPairingCreated",e=>{if(e.methods&&this.expectedPairingMethodMap.set(e.topic,e.methods),e.active)return;let t=this.client.proposal.getAll().find(t=>t.pairingTopic===e.topic);t&&this.onSessionProposeRequest({topic:e.topic,payload:(0,sr.formatJsonRpcRequest)("wc_sessionPropose",og(op({},t),{requiredNamespaces:t.requiredNamespaces,optionalNamespaces:t.optionalNamespaces,relays:t.relays,proposer:t.proposer,sessionProperties:t.sessionProperties,scopedProperties:t.scopedProperties}),t.id)})}),of(this,"isValidConnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`connect() params: ${JSON.stringify(e)}`);throw Error(t)}let{pairingTopic:t,requiredNamespaces:r,optionalNamespaces:i,sessionProperties:s,scopedProperties:n,relays:a}=e;if(iG(t)||await this.isValidPairingTopic(t),!function(e,t){let r=!1;return t&&!e?r=!0:e&&iK(e)&&e.length&&e.forEach(e=>{r=i2(e)}),r}(a,!0)){let{message:e}=iV("MISSING_OR_INVALID",`connect() relays: ${a}`);throw Error(e)}if(!iG(r)&&0!==iJ(r)){let e="requiredNamespaces are deprecated and are automatically assigned to optionalNamespaces";["fatal","error","silent"].includes(this.client.logger.level)?console.warn(e):this.client.logger.warn(e),this.validateNamespaces(r,"requiredNamespaces")}if(iG(i)||0===iJ(i)||this.validateNamespaces(i,"optionalNamespaces"),iG(s)||this.validateSessionProps(s,"sessionProperties"),!iG(n)){this.validateSessionProps(n,"scopedProperties");let e=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(n).every(t=>e.includes(t)))throw Error(`Scoped properties must be a subset of required/optional namespaces, received: ${JSON.stringify(n)}, required/optional namespaces: ${JSON.stringify(e)}`)}}),of(this,"validateNamespaces",(e,t)=>{let r=function(e,t,r){let i=null;if(e&&iJ(e)){let s;let n=i0(e,t);n&&(i=n);let a=(s=null,Object.entries(e).forEach(([e,i])=>{var n,a;let o;if(s)return;let c=(n=F(e,i),a=`${t} ${r}`,o=null,iK(n)&&n.length?n.forEach(e=>{o||iZ(e)||(o=iz("UNSUPPORTED_CHAINS",`${a}, chain ${e} should be a string and conform to "namespace:chainId" format`))}):iZ(e)||(o=iz("UNSUPPORTED_CHAINS",`${a}, chains must be defined as "namespace:chainId" e.g. "eip155:1": {...} in the namespace key OR as an array of CAIP-2 chainIds e.g. eip155: { chains: ["eip155:1", "eip155:5"] }`)),o);c&&(s=c)}),s);a&&(i=a)}else i=iV("MISSING_OR_INVALID",`${t}, ${r} should be an object with data`);return i}(e,"connect()",t);if(r)throw Error(r.message)}),of(this,"isValidApprove",async e=>{if(!i5(e))throw Error(iV("MISSING_OR_INVALID",`approve() params: ${e}`).message);let{id:t,namespaces:r,relayProtocol:i,sessionProperties:s,scopedProperties:n}=e;this.checkRecentlyDeleted(t),await this.isValidProposalId(t);let a=this.client.proposal.get(t),o=i1(r,"approve()");if(o)throw Error(o.message);let c=i4(a.requiredNamespaces,r,"approve()");if(c)throw Error(c.message);if(!iY(i,!0)){let{message:e}=iV("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw Error(e)}if(iG(s)||this.validateSessionProps(s,"sessionProperties"),!iG(n)){this.validateSessionProps(n,"scopedProperties");let e=new Set(Object.keys(r));if(!Object.keys(n).every(t=>e.has(t)))throw Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(n)}, approved namespaces: ${Array.from(e).join(", ")}`)}}),of(this,"isValidReject",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`reject() params: ${e}`);throw Error(t)}let{id:t,reason:r}=e;if(this.checkRecentlyDeleted(t),await this.isValidProposalId(t),!function(e){return!(!e||"object"!=typeof e||!e.code||!iX(e.code,!1)||!e.message||!iY(e.message,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw Error(e)}}),of(this,"isValidSessionSettleRequest",e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${e}`);throw Error(t)}let{relay:t,controller:r,namespaces:i,expiry:s}=e;if(!i2(t)){let{message:e}=iV("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw Error(e)}let n=function(e,t){let r=null;return iY(e?.publicKey,!1)||(r=iV("MISSING_OR_INVALID",`${t} controller public key should be a string`)),r}(r,"onSessionSettleRequest()");if(n)throw Error(n.message);let a=i1(i,"onSessionSettleRequest()");if(a)throw Error(a.message);if(eg(s)){let{message:e}=iV("EXPIRED","onSessionSettleRequest()");throw Error(e)}}),of(this,"isValidUpdate",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`update() params: ${e}`);throw Error(t)}let{topic:t,namespaces:r}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t);let i=this.client.session.get(t),s=i1(r,"update()");if(s)throw Error(s.message);let n=i4(i.requiredNamespaces,r,"update()");if(n)throw Error(n.message)}),of(this,"isValidExtend",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`extend() params: ${e}`);throw Error(t)}let{topic:t}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t)}),of(this,"isValidRequest",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`request() params: ${e}`);throw Error(t)}let{topic:t,request:r,chainId:i,expiry:s}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t);let{namespaces:n}=this.client.session.get(t);if(!i3(n,i)){let{message:e}=iV("MISSING_OR_INVALID",`request() chainId: ${i}`);throw Error(e)}if(!function(e){return!(iG(e)||!iY(e.method,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw Error(e)}if(!function(e,t,r){return!!iY(r,!1)&&(function(e,t){let r=[];return Object.values(e).forEach(e=>{iL(e.accounts).includes(t)&&r.push(...e.methods)}),r})(e,t).includes(r)}(n,i,r.method)){let{message:e}=iV("MISSING_OR_INVALID",`request() method: ${r.method}`);throw Error(e)}if(s&&!function(e,t){return iX(e,!1)&&e<=t.max&&e>=t.min}(s,oe)){let{message:e}=iV("MISSING_OR_INVALID",`request() expiry: ${s}. Expiry must be a number (in seconds) between ${oe.min} and ${oe.max}`);throw Error(e)}}),of(this,"isValidRespond",async e=>{var t;if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`respond() params: ${e}`);throw Error(t)}let{topic:r,response:i}=e;try{await this.isValidSessionTopic(r)}catch(r){throw null!=(t=e?.response)&&t.id&&this.cleanupAfterResponse(e),r}if(!function(e){return!(iG(e)||iG(e.result)&&iG(e.error)||!iX(e.id,!1)||!iY(e.jsonrpc,!1))}(i)){let{message:e}=iV("MISSING_OR_INVALID",`respond() response: ${JSON.stringify(i)}`);throw Error(e)}}),of(this,"isValidPing",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`ping() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidSessionOrPairingTopic(t)}),of(this,"isValidEmit",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`emit() params: ${e}`);throw Error(t)}let{topic:t,event:r,chainId:i}=e;await this.isValidSessionTopic(t);let{namespaces:s}=this.client.session.get(t);if(!i3(s,i)){let{message:e}=iV("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw Error(e)}if(!function(e){return!(iG(e)||!iY(e.name,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw Error(e)}if(!function(e,t,r){return!!iY(r,!1)&&(function(e,t){let r=[];return Object.values(e).forEach(e=>{iL(e.accounts).includes(t)&&r.push(...e.events)}),r})(e,t).includes(r)}(s,i,r.name)){let{message:e}=iV("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw Error(e)}}),of(this,"isValidDisconnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`disconnect() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidSessionOrPairingTopic(t)}),of(this,"isValidAuthenticate",e=>{let{chains:t,uri:r,domain:i,nonce:s}=e;if(!Array.isArray(t)||0===t.length)throw Error("chains is required and must be a non-empty array");if(!iY(r,!1))throw Error("uri is required parameter");if(!iY(i,!1))throw Error("domain is required parameter");if(!iY(s,!1))throw Error("nonce is required parameter");if([...new Set(t.map(e=>B(e).namespace))].length>1)throw Error("Multi-namespace requests are not supported. Please request single namespace only.");let{namespace:n}=B(t[0]);if("eip155"!==n)throw Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),of(this,"getVerifyContext",async e=>{let{attestationId:t,hash:r,encryptedId:i,metadata:s,transportType:n}=e,a={verified:{verifyUrl:s.verifyUrl||sN,validation:"UNKNOWN",origin:s.url||""}};try{if(n===sf.link_mode){let e=this.getAppLinkIfEnabled(s,n);return a.verified.validation=e&&new URL(e).origin===new URL(s.url).origin?"VALID":"INVALID",a}let e=await this.client.core.verify.resolve({attestationId:t,hash:r,encryptedId:i,verifyUrl:s.verifyUrl});e&&(a.verified.origin=e.origin,a.verified.isScam=e.isScam,a.verified.validation=e.origin===new URL(s.url).origin?"VALID":"INVALID")}catch(e){this.client.logger.warn(e)}return this.client.logger.debug(`Verify context: ${JSON.stringify(a)}`),a}),of(this,"validateSessionProps",(e,t)=>{Object.values(e).forEach((r,i)=>{if(null==r){let{message:s}=iV("MISSING_OR_INVALID",`${t} must contain an existing value for each key. Received: ${r} for key ${Object.keys(e)[i]}`);throw Error(s)}})}),of(this,"getPendingAuthRequest",e=>{let t=this.client.auth.requests.get(e);return"object"==typeof t?t:void 0}),of(this,"addToRecentlyDeleted",(e,t)=>{if(this.recentlyDeletedMap.set(e,t),this.recentlyDeletedMap.size>=this.recentlyDeletedLimit){let e=0,t=this.recentlyDeletedLimit/2;for(let r of this.recentlyDeletedMap.keys()){if(e++>=t)break;this.recentlyDeletedMap.delete(r)}}}),of(this,"checkRecentlyDeleted",e=>{let t=this.recentlyDeletedMap.get(e);if(t){let{message:r}=iV("MISSING_OR_INVALID",`Record was recently deleted - ${t}: ${e}`);throw Error(r)}}),of(this,"isLinkModeEnabled",(e,t)=>{var r,i,s,n,a,o,c,l,h;return!!e&&t===sf.link_mode&&(null==(i=null==(r=this.client.metadata)?void 0:r.redirect)?void 0:i.linkMode)===!0&&(null==(n=null==(s=this.client.metadata)?void 0:s.redirect)?void 0:n.universal)!==void 0&&(null==(o=null==(a=this.client.metadata)?void 0:a.redirect)?void 0:o.universal)!==""&&(null==(c=e?.redirect)?void 0:c.universal)!==void 0&&(null==(l=e?.redirect)?void 0:l.universal)!==""&&(null==(h=e?.redirect)?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(e.redirect.universal)&&"u">typeof(null==global?void 0:global.Linking)}),of(this,"getAppLinkIfEnabled",(e,t)=>{var r;return this.isLinkModeEnabled(e,t)?null==(r=e?.redirect)?void 0:r.universal:void 0}),of(this,"handleLinkModeMessage",({url:e})=>{if(!e||!e.includes("wc_ev")||!e.includes("topic"))return;let t=eb(e,"topic")||"",r=decodeURIComponent(eb(e,"wc_ev")||""),i=this.client.session.keys.includes(t);i&&this.client.session.update(t,{transportType:sf.link_mode}),this.client.core.dispatchEnvelope({topic:t,message:r,sessionExists:i})}),of(this,"registerLinkModeListeners",async()=>{var e;if(eC()||ee()&&null!=(e=this.client.metadata.redirect)&&e.linkMode){let e=null==global?void 0:global.Linking;if("u">typeof e){e.addEventListener("url",this.handleLinkModeMessage,this.client.name);let t=await e.getInitialURL();t&&setTimeout(()=>{this.handleLinkModeMessage({url:t})},50)}}}),of(this,"shouldSetTVF",(e,t)=>{if(!t||"wc_sessionRequest"!==e)return!1;let{request:r}=t;return Object.keys(or).includes(r.method)}),of(this,"getTVFParams",(e,t,r)=>{var i,s;try{let n=t.request.method,a=this.extractTxHashesFromResult(n,r);return og(op({correlationId:e,rpcMethods:[n],chainId:t.chainId},this.isValidContractData(t.request.params)&&{contractAddresses:[null==(s=null==(i=t.request.params)?void 0:i[0])?void 0:s.to]}),{txHashes:a})}catch(e){this.client.logger.warn("Error getting TVF params",e)}return{}}),of(this,"isValidContractData",e=>{var t;if(!e)return!1;try{let r=e?.data||(null==(t=e?.[0])?void 0:t.data);if(!r.startsWith("0x"))return!1;let i=r.slice(2);return!!/^[0-9a-fA-F]*$/.test(i)&&i.length%2==0}catch{}return!1}),of(this,"extractTxHashesFromResult",(e,t)=>{try{let r=or[e];if("string"==typeof t)return[t];let i=t[r.key];if(iK(i))return"solana_signAllTransactions"===e?i.map(e=>(function(e){let t=atob(e),r=new Uint8Array(t.length);for(let e=0;e<t.length;e++)r[e]=t.charCodeAt(e);let i=r[0];if(0===i)throw Error("No signatures found");if(r.length<1+64*i)throw Error("Transaction data too short for claimed signature count");if(r.length<100)throw Error("Transaction too short");let s=Buffer.from(e,"base64").slice(1,65);return L.Z.encode(s)})(e)):i;if("string"==typeof i)return[i]}catch(e){this.client.logger.warn("Error extracting tx hashes from result",e)}return[]})}async processPendingMessageEvents(){try{let e=this.client.session.keys,t=this.client.core.relayer.messages.getWithoutAck(e);for(let[e,r]of Object.entries(t))for(let t of r)try{await this.onProviderMessageEvent({topic:e,message:t,publishedAt:Date.now()})}catch{this.client.logger.warn(`Error processing pending message event for topic: ${e}, message: ${t}`)}}catch(e){this.client.logger.warn("processPendingMessageEvents failed",e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(su.message,e=>{this.onProviderMessageEvent(e)})}async onRelayMessage(e){let{topic:t,message:r,attestation:i,transportType:s}=e,{publicKey:n}=this.client.auth.authKeys.keys.includes(on)?this.client.auth.authKeys.get(on):{responseTopic:void 0,publicKey:void 0};try{let e=await this.client.core.crypto.decode(t,r,{receiverPublicKey:n,encoding:s===sf.link_mode?ih:il});(0,sr.isJsonRpcRequest)(e)?(this.client.core.history.set(t,e),await this.onRelayEventRequest({topic:t,payload:e,attestation:i,transportType:s,encryptedId:ig(r)})):(0,sr.isJsonRpcResponse)(e)?(await this.client.core.history.resolve(e),await this.onRelayEventResponse({topic:t,payload:e,transportType:s}),this.client.core.history.delete(t,e.id)):await this.onRelayEventUnknownPayload({topic:t,payload:e,transportType:s}),await this.client.core.relayer.messages.ack(t,r)}catch(e){this.client.logger.error(e)}}registerExpirerEvents(){this.client.core.expirer.on(sE.expired,async e=>{let{topic:t,id:r}=eu(e.target);return r&&this.client.pendingRequest.keys.includes(r)?await this.deletePendingSessionRequest(r,iV("EXPIRED"),!0):r&&this.client.auth.requests.keys.includes(r)?await this.deletePendingAuthRequest(r,iV("EXPIRED"),!0):void(t?this.client.session.keys.includes(t)&&(await this.deleteSession({topic:t,expirerHasDeleted:!0}),this.client.events.emit("session_expire",{topic:t})):r&&(await this.deleteProposal(r,!0),this.client.events.emit("proposal_expire",{id:r})))})}registerPairingEvents(){this.client.core.pairing.events.on(sv.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(sv.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw Error(t)}if(!this.client.core.pairing.pairings.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.core.pairing.pairings.get(e).expiry)){let{message:t}=iV("EXPIRED",`pairing topic: ${e}`);throw Error(t)}}async isValidSessionTopic(e){if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`session topic should be a string: ${e}`);throw Error(t)}if(this.checkRecentlyDeleted(e),!this.client.session.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});let{message:t}=iV("EXPIRED",`session topic: ${e}`);throw Error(t)}if(!this.client.core.crypto.keychain.has(e)){let{message:t}=iV("MISSING_OR_INVALID",`session topic does not exist in keychain: ${e}`);throw await this.deleteSession({topic:e}),Error(t)}}async isValidSessionOrPairingTopic(e){if(this.checkRecentlyDeleted(e),this.client.session.keys.includes(e))await this.isValidSessionTopic(e);else if(this.client.core.pairing.pairings.keys.includes(e))this.isValidPairingTopic(e);else if(iY(e,!1)){let{message:t}=iV("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw Error(t)}else{let{message:t}=iV("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw Error(t)}}async isValidProposalId(e){if("number"!=typeof e){let{message:t}=iV("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw Error(t)}if(!this.client.proposal.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);let{message:t}=iV("EXPIRED",`proposal id: ${e}`);throw Error(t)}}}class ow extends av{constructor(e,t){super(e,t,"proposal",a3),this.core=e,this.logger=t}}class oy extends av{constructor(e,t){super(e,t,"session",a3),this.core=e,this.logger=t}}class ob extends av{constructor(e,t){super(e,t,"request",a3,e=>e.id),this.core=e,this.logger=t}}class ov extends av{constructor(e,t){super(e,t,"authKeys",os,()=>on),this.core=e,this.logger=t}}class oC extends av{constructor(e,t){super(e,t,"pairingTopics",os),this.core=e,this.logger=t}}class oE extends av{constructor(e,t){super(e,t,"requests",os,e=>e.id),this.core=e,this.logger=t}}var oN=Object.defineProperty,oI=(e,t,r)=>t in e?oN(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,oA=(e,t,r)=>oI(e,"symbol"!=typeof t?t+"":t,r);class o_{constructor(e,t){this.core=e,this.logger=t,oA(this,"authKeys"),oA(this,"pairingTopics"),oA(this,"requests"),this.authKeys=new ov(this.core,this.logger),this.pairingTopics=new oC(this.core,this.logger),this.requests=new oE(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var oS=Object.defineProperty,oO=(e,t,r)=>t in e?oS(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,oP=(e,t,r)=>oO(e,"symbol"!=typeof t?t+"":t,r);class oT extends P{constructor(e){super(e),oP(this,"protocol","wc"),oP(this,"version",2),oP(this,"name",a4.name),oP(this,"metadata"),oP(this,"core"),oP(this,"logger"),oP(this,"events",new i.EventEmitter),oP(this,"engine"),oP(this,"session"),oP(this,"proposal"),oP(this,"pendingRequest"),oP(this,"auth"),oP(this,"signConfig"),oP(this,"on",(e,t)=>this.events.on(e,t)),oP(this,"once",(e,t)=>this.events.once(e,t)),oP(this,"off",(e,t)=>this.events.off(e,t)),oP(this,"removeListener",(e,t)=>this.events.removeListener(e,t)),oP(this,"removeAllListeners",e=>this.events.removeAllListeners(e)),oP(this,"connect",async e=>{try{return await this.engine.connect(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"pair",async e=>{try{return await this.engine.pair(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"approve",async e=>{try{return await this.engine.approve(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"reject",async e=>{try{return await this.engine.reject(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"update",async e=>{try{return await this.engine.update(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"extend",async e=>{try{return await this.engine.extend(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"request",async e=>{try{return await this.engine.request(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"respond",async e=>{try{return await this.engine.respond(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"ping",async e=>{try{return await this.engine.ping(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"emit",async e=>{try{return await this.engine.emit(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"disconnect",async e=>{try{return await this.engine.disconnect(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"find",e=>{try{return this.engine.find(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(e){throw this.logger.error(e.message),e}}),oP(this,"authenticate",async(e,t)=>{try{return await this.engine.authenticate(e,t)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"formatAuthMessage",e=>{try{return this.engine.formatAuthMessage(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"approveSessionAuthenticate",async e=>{try{return await this.engine.approveSessionAuthenticate(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"rejectSessionAuthenticate",async e=>{try{return await this.engine.rejectSessionAuthenticate(e)}catch(e){throw this.logger.error(e.message),e}}),this.name=e?.name||a4.name,this.metadata=function(e){var t,r;let i=es();try{return null!=e&&e.url&&i.url&&new URL(e.url).host!==new URL(i.url).host&&(console.warn(`The configured WalletConnect 'metadata.url':${e.url} differs from the actual page url:${i.url}. This is probably unintended and can lead to issues.`),e.url=i.url),null!=(t=e?.icons)&&t.length&&e.icons.length>0&&(e.icons=e.icons.filter(e=>""!==e)),X(Y(Y({},i),e),{url:e?.url||i.url,name:e?.name||i.name,description:e?.description||i.description,icons:null!=(r=e?.icons)&&r.length&&e.icons.length>0?e.icons:i.icons})}catch(t){return console.warn("Error populating app metadata",t),e||i}}(e?.metadata),this.signConfig=e?.signConfig;let t="u">typeof e?.logger&&"string"!=typeof e?.logger?e.logger:(0,o.gw)((0,o.jI)({level:e?.logger||a4.logger}));this.core=e?.core||new a2(e),this.logger=(0,o.Ep)(t,this.name),this.session=new oy(this.core,this.logger),this.proposal=new ow(this.core,this.logger),this.pendingRequest=new ob(this.core,this.logger),this.engine=new om(this),this.auth=new o_(this.core,this.logger)}static async init(e){let t=new oT(e);return await t.initialize(),t}get context(){return(0,o.Fd)(this.logger)}get pairing(){return this.core.pairing.pairings}async initialize(){this.logger.trace("Initialized");try{await this.core.start(),await this.session.init(),await this.proposal.init(),await this.pendingRequest.init(),await this.auth.init(),await this.engine.init(),this.logger.info("SignClient Initialization Success"),setTimeout(()=>{this.engine.processRelayMessageCache()},(0,R.toMiliseconds)(R.ONE_SECOND))}catch(e){throw this.logger.info("SignClient Initialization Failure"),this.logger.error(e.message),e}}}var oR=r(60467);let ok="error",ox="wc@2:universal_provider:",oU="https://rpc.walletconnect.org/v1/",oD="generic",o$=`${oU}bundler`,oM={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};function oL(){}function oj(e){return null==e||"object"!=typeof e&&"function"!=typeof e}function oq(e){return ArrayBuffer.isView(e)&&!(e instanceof DataView)}function oB(e){return"object"==typeof e&&null!==e}function oF(e){return Object.getOwnPropertySymbols(e).filter(t=>Object.prototype.propertyIsEnumerable.call(e,t))}function oH(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":Object.prototype.toString.call(e)}let oW="[object String]",oV="[object Number]",oz="[object Boolean]",oK="[object Arguments]";function oJ(e,t,r,i=new Map,s){let n=s?.(e,t,r,i);if(null!=n)return n;if(oj(e))return e;if(i.has(e))return i.get(e);if(Array.isArray(e)){let t=Array(e.length);i.set(e,t);for(let n=0;n<e.length;n++)t[n]=oJ(e[n],n,r,i,s);return Object.hasOwn(e,"index")&&(t.index=e.index),Object.hasOwn(e,"input")&&(t.input=e.input),t}if(e instanceof Date)return new Date(e.getTime());if(e instanceof RegExp){let t=new RegExp(e.source,e.flags);return t.lastIndex=e.lastIndex,t}if(e instanceof Map){let t=new Map;for(let[n,a]of(i.set(e,t),e))t.set(n,oJ(a,n,r,i,s));return t}if(e instanceof Set){let t=new Set;for(let n of(i.set(e,t),e))t.add(oJ(n,void 0,r,i,s));return t}if("u">typeof Buffer&&Buffer.isBuffer(e))return e.subarray();if(oq(e)){let t=new(Object.getPrototypeOf(e)).constructor(e.length);i.set(e,t);for(let n=0;n<e.length;n++)t[n]=oJ(e[n],n,r,i,s);return t}if(e instanceof ArrayBuffer||"u">typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer)return e.slice(0);if(e instanceof DataView){let t=new DataView(e.buffer.slice(0),e.byteOffset,e.byteLength);return i.set(e,t),oG(t,e,r,i,s),t}if("u">typeof File&&e instanceof File){let t=new File([e],e.name,{type:e.type});return i.set(e,t),oG(t,e,r,i,s),t}if(e instanceof Blob){let t=new Blob([e],{type:e.type});return i.set(e,t),oG(t,e,r,i,s),t}if(e instanceof Error){let t=new e.constructor;return i.set(e,t),t.message=e.message,t.name=e.name,t.stack=e.stack,t.cause=e.cause,oG(t,e,r,i,s),t}if("object"==typeof e&&function(e){switch(oH(e)){case oK:case"[object Array]":case"[object ArrayBuffer]":case"[object DataView]":case oz:case"[object Date]":case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Map]":case oV:case"[object Object]":case"[object RegExp]":case"[object Set]":case oW:case"[object Symbol]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return!0;default:return!1}}(e)){let t=Object.create(Object.getPrototypeOf(e));return i.set(e,t),oG(t,e,r,i,s),t}return e}function oG(e,t,r=e,i,s){let n=[...Object.keys(t),...oF(t)];for(let a=0;a<n.length;a++){let o=n[a],c=Object.getOwnPropertyDescriptor(e,o);(null==c||c.writable)&&(e[o]=oJ(t[o],o,r,i,s))}}function oY(e){var t;return t=(t,r,i,s)=>{let n=void 0;if(null!=n)return n;if("object"==typeof e)switch(Object.prototype.toString.call(e)){case oV:case oW:case oz:{let t=new e.constructor(e?.valueOf());return oG(t,e),t}case oK:{let t={};return oG(t,e),t.length=e.length,t[Symbol.iterator]=e[Symbol.iterator],t}default:return}},oJ(e,void 0,e,new Map,t)}function oX(e){return null!==e&&"object"==typeof e&&"[object Arguments]"===oH(e)}var oZ=Object.defineProperty,oQ=Object.defineProperties,o0=Object.getOwnPropertyDescriptors,o1=Object.getOwnPropertySymbols,o2=Object.prototype.hasOwnProperty,o5=Object.prototype.propertyIsEnumerable,o3=(e,t,r)=>t in e?oZ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,o4=(e,t)=>{for(var r in t||(t={}))o2.call(t,r)&&o3(e,r,t[r]);if(o1)for(var r of o1(t))o5.call(t,r)&&o3(e,r,t[r]);return e},o8=(e,t)=>oQ(e,o0(t));function o6(e,t,r){var i;let s=B(e);return(null==(i=t.rpcMap)?void 0:i[s.reference])||`${oU}?chainId=${s.namespace}:${s.reference}&projectId=${r}`}function o9(e){return e.includes(":")?e.split(":")[1]:e}function o7(e){return e.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function ce(e={},t={}){return function(e,...t){return function(e,...t){let r=t.slice(0,-1),i=t[t.length-1],s=e;for(let e=0;e<r.length;e++)s=function e(t,r,i,s){if(oj(t)&&(t=Object(t)),null==r||"object"!=typeof r)return t;if(s.has(r))return function(e){if(oj(e))return e;if(Array.isArray(e)||oq(e)||e instanceof ArrayBuffer||"u">typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer)return e.slice(0);let t=Object.getPrototypeOf(e),r=t.constructor;if(e instanceof Date||e instanceof Map||e instanceof Set)return new r(e);if(e instanceof RegExp){let t=new r(e);return t.lastIndex=e.lastIndex,t}if(e instanceof DataView)return new r(e.buffer.slice(0));if(e instanceof Error){let t=new r(e.message);return t.stack=e.stack,t.name=e.name,t.cause=e.cause,t}return"u">typeof File&&e instanceof File?new r([e],e.name,{type:e.type,lastModified:e.lastModified}):"object"==typeof e?Object.assign(Object.create(t),e):e}(s.get(r));if(s.set(r,t),Array.isArray(r)){r=r.slice();for(let e=0;e<r.length;e++)r[e]=r[e]??void 0}let n=[...Object.keys(r),...oF(r)];for(let a=0;a<n.length;a++){let o=n[a],c=r[o],l=t[o];if(oX(c)&&(c={...c}),oX(l)&&(l={...l}),"u">typeof Buffer&&Buffer.isBuffer(c)&&(c=oY(c)),Array.isArray(c)){if("object"==typeof l&&null!=l){let e=[],t=Reflect.ownKeys(l);for(let r=0;r<t.length;r++){let i=t[r];e[i]=l[i]}l=e}else l=[]}let h=i(l,c,o,t,r,s);null!=h?t[o]=h:Array.isArray(c)||oB(l)&&oB(c)?t[o]=e(l,c,i,s):null==l&&function(e){if("object"!=typeof e||null==e)return!1;if(null===Object.getPrototypeOf(e))return!0;if("[object Object]"!==Object.prototype.toString.call(e)){let t=e[Symbol.toStringTag];return!!(null!=t&&Object.getOwnPropertyDescriptor(e,Symbol.toStringTag)?.writable)&&e.toString()===`[object ${t}]`}let t=e;for(;null!==Object.getPrototypeOf(t);)t=Object.getPrototypeOf(t);return Object.getPrototypeOf(e)===t}(c)?t[o]=e({},c,i,s):null==l&&oq(c)?t[o]=oY(c):(void 0===l||void 0!==c)&&(t[o]=c)}return t}(s,r[e],i,new Map);return s}(e,...t,oL)}(ct(e),ct(t))}function ct(e){var t,r,i,s,n;let a={};if(!iJ(e))return a;for(let[o,c]of Object.entries(e)){let e=ij(o)?[o]:c.chains,l=c.methods||[],h=c.events||[],d=c.rpcMap||{},u=iq(o);a[u]=o8(o4(o4({},a[u]),c),{chains:em(e,null==(t=a[u])?void 0:t.chains),methods:em(l,null==(r=a[u])?void 0:r.methods),events:em(h,null==(i=a[u])?void 0:i.events)}),(iJ(d)||iJ((null==(s=a[u])?void 0:s.rpcMap)||{}))&&(a[u].rpcMap=o4(o4({},d),null==(n=a[u])?void 0:n.rpcMap))}return a}function cr(e){return e.includes(":")?e.split(":")[2]:e}function ci(e){let t={};for(let[r,i]of Object.entries(e)){let e=i.methods||[],s=i.events||[],n=i.accounts||[],a=ij(r)?[r]:i.chains?i.chains:o7(i.accounts);t[r]={chains:a,methods:e,events:s,accounts:n}}return t}function cs(e){return"number"==typeof e?e:e.includes("0x")?parseInt(e,16):isNaN(Number(e=e.includes(":")?e.split(":")[1]:e))?e:Number(e)}let cn={},ca=e=>cn[e],co=(e,t)=>{cn[e]=t};var cc=Object.defineProperty,cl=(e,t,r)=>t in e?cc(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,ch=(e,t,r)=>cl(e,"symbol"!=typeof t?t+"":t,r);class cd{constructor(e){ch(this,"name","polkadot"),ch(this,"client"),ch(this,"httpProviders"),ch(this,"events"),ch(this,"namespace"),ch(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cu=Object.defineProperty,cp=Object.defineProperties,cg=Object.getOwnPropertyDescriptors,cf=Object.getOwnPropertySymbols,cm=Object.prototype.hasOwnProperty,cw=Object.prototype.propertyIsEnumerable,cy=(e,t,r)=>t in e?cu(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cb=(e,t)=>{for(var r in t||(t={}))cm.call(t,r)&&cy(e,r,t[r]);if(cf)for(var r of cf(t))cw.call(t,r)&&cy(e,r,t[r]);return e},cv=(e,t)=>cp(e,cg(t)),cC=(e,t,r)=>cy(e,"symbol"!=typeof t?t+"":t,r);class cE{constructor(e){cC(this,"name","eip155"),cC(this,"client"),cC(this,"chainId"),cC(this,"namespace"),cC(this,"httpProviders"),cC(this,"events"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain())}async request(e){switch(e.request.method){case"eth_requestAccounts":case"eth_accounts":return this.getAccounts();case"wallet_switchEthereumChain":return await this.handleSwitchChain(e);case"eth_chainId":return parseInt(this.getDefaultChain());case"wallet_getCapabilities":return await this.getCapabilities(e);case"wallet_getCallsStatus":return await this.getCallStatus(e)}return this.namespace.methods.includes(e.request.method)?await this.client.request(e):this.getHttpProvider().request(e.request)}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(parseInt(e),t),this.chainId=parseInt(e),this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId.toString();if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}createHttpProvider(e,t){let r=t||o6(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.k(r,ca("disableProviderPing")))}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=parseInt(o9(t));e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}getHttpProvider(){let e=this.chainId,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}async handleSwitchChain(e){var t,r;let i=e.request.params?null==(t=e.request.params[0])?void 0:t.chainId:"0x0",s=parseInt(i=i.startsWith("0x")?i:`0x${i}`,16);if(this.isChainApproved(s))this.setDefaultChain(`${s}`);else if(this.namespace.methods.includes("wallet_switchEthereumChain"))await this.client.request({topic:e.topic,request:{method:e.request.method,params:[{chainId:i}]},chainId:null==(r=this.namespace.chains)?void 0:r[0]}),this.setDefaultChain(`${s}`);else throw Error(`Failed to switch to chain 'eip155:${s}'. The chain is not approved or the wallet does not support 'wallet_switchEthereumChain' method.`);return null}isChainApproved(e){return this.namespace.chains.includes(`${this.name}:${e}`)}async getCapabilities(e){var t,r,i,s,n;let a=null==(r=null==(t=e.request)?void 0:t.params)?void 0:r[0],o=(null==(s=null==(i=e.request)?void 0:i.params)?void 0:s[1])||[],c=`${a}${o.join(",")}`;if(!a)throw Error("Missing address parameter in `wallet_getCapabilities` request");let l=this.client.session.get(e.topic),h=(null==(n=l?.sessionProperties)?void 0:n.capabilities)||{};if(null!=h&&h[c])return h?.[c];let d=await this.client.request(e);try{await this.client.session.update(e.topic,{sessionProperties:cv(cb({},l.sessionProperties||{}),{capabilities:cv(cb({},h||{}),{[c]:d})})})}catch(e){console.warn("Failed to update session with capabilities",e)}return d}async getCallStatus(e){var t,r;let i=this.client.session.get(e.topic),s=null==(t=i.sessionProperties)?void 0:t.bundler_name;if(s){let t=this.getBundlerUrl(e.chainId,s);try{return await this.getUserOperationReceipt(t,e)}catch(e){console.warn("Failed to fetch call status from bundler",e,t)}}let n=null==(r=i.sessionProperties)?void 0:r.bundler_url;if(n)try{return await this.getUserOperationReceipt(n,e)}catch(e){console.warn("Failed to fetch call status from custom bundler",e,n)}if(this.namespace.methods.includes(e.request.method))return await this.client.request(e);throw Error("Fetching call status not approved by the wallet.")}async getUserOperationReceipt(e,t){var r;let i=new URL(e),s=await fetch(i,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify((0,sr.formatJsonRpcRequest)("eth_getUserOperationReceipt",[null==(r=t.request.params)?void 0:r[0]]))});if(!s.ok)throw Error(`Failed to fetch user operation receipt - ${s.status}`);return await s.json()}getBundlerUrl(e,t){return`${o$}?projectId=${this.client.core.projectId}&chainId=${e}&bundler=${t}`}}var cN=Object.defineProperty,cI=(e,t,r)=>t in e?cN(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cA=(e,t,r)=>cI(e,"symbol"!=typeof t?t+"":t,r);class c_{constructor(e){cA(this,"name","solana"),cA(this,"client"),cA(this,"httpProviders"),cA(this,"events"),cA(this,"namespace"),cA(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cS=Object.defineProperty,cO=(e,t,r)=>t in e?cS(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cP=(e,t,r)=>cO(e,"symbol"!=typeof t?t+"":t,r);class cT{constructor(e){cP(this,"name","cosmos"),cP(this,"client"),cP(this,"httpProviders"),cP(this,"events"),cP(this,"namespace"),cP(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cR=Object.defineProperty,ck=(e,t,r)=>t in e?cR(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cx=(e,t,r)=>ck(e,"symbol"!=typeof t?t+"":t,r);class cU{constructor(e){cx(this,"name","algorand"),cx(this,"client"),cx(this,"httpProviders"),cx(this,"events"),cx(this,"namespace"),cx(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;e[t]=this.createHttpProvider(t,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);return typeof r>"u"?void 0:new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cD=Object.defineProperty,c$=(e,t,r)=>t in e?cD(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cM=(e,t,r)=>c$(e,"symbol"!=typeof t?t+"":t,r);class cL{constructor(e){cM(this,"name","cip34"),cM(this,"client"),cM(this,"httpProviders"),cM(this,"events"),cM(this,"namespace"),cM(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{let r=this.getCardanoRPCUrl(t),i=o9(t);e[i]=this.createHttpProvider(i,r)}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}getCardanoRPCUrl(e){let t=this.namespace.rpcMap;if(t)return t[e]}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||this.getCardanoRPCUrl(e);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cj=Object.defineProperty,cq=(e,t,r)=>t in e?cj(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cB=(e,t,r)=>cq(e,"symbol"!=typeof t?t+"":t,r);class cF{constructor(e){cB(this,"name","elrond"),cB(this,"client"),cB(this,"httpProviders"),cB(this,"events"),cB(this,"namespace"),cB(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cH=Object.defineProperty,cW=(e,t,r)=>t in e?cH(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cV=(e,t,r)=>cW(e,"symbol"!=typeof t?t+"":t,r);class cz{constructor(e){cV(this,"name","multiversx"),cV(this,"client"),cV(this,"httpProviders"),cV(this,"events"),cV(this,"namespace"),cV(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cK=Object.defineProperty,cJ=(e,t,r)=>t in e?cK(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cG=(e,t,r)=>cJ(e,"symbol"!=typeof t?t+"":t,r);class cY{constructor(e){cG(this,"name","near"),cG(this,"client"),cG(this,"httpProviders"),cG(this,"events"),cG(this,"namespace"),cG(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(this.chainId=e,!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;e[t]=this.createHttpProvider(t,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace);return typeof r>"u"?void 0:new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cX=Object.defineProperty,cZ=(e,t,r)=>t in e?cX(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cQ=(e,t,r)=>cZ(e,"symbol"!=typeof t?t+"":t,r);class c0{constructor(e){cQ(this,"name","tezos"),cQ(this,"client"),cQ(this,"httpProviders"),cQ(this,"events"),cQ(this,"namespace"),cQ(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(this.chainId=e,!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{e[t]=this.createHttpProvider(t)}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace);return typeof r>"u"?void 0:new st.r(new oR.Z(r))}}var c1=Object.defineProperty,c2=(e,t,r)=>t in e?c1(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,c5=(e,t,r)=>c2(e,"symbol"!=typeof t?t+"":t,r);class c3{constructor(e){c5(this,"name",oD),c5(this,"client"),c5(this,"httpProviders"),c5(this,"events"),c5(this,"namespace"),c5(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace.chains=[...new Set((this.namespace.chains||[]).concat(e.chains||[]))],this.namespace.accounts=[...new Set((this.namespace.accounts||[]).concat(e.accounts||[]))],this.namespace.methods=[...new Set((this.namespace.methods||[]).concat(e.methods||[]))],this.namespace.events=[...new Set((this.namespace.events||[]).concat(e.events||[]))],this.httpProviders=this.createHttpProviders()}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider(e.chainId).request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){var e,t;let r={};return null==(t=null==(e=this.namespace)?void 0:e.accounts)||t.forEach(e=>{let t=B(e);r[`${t.namespace}:${t.reference}`]=this.createHttpProvider(e)}),r}getHttpProvider(e){let t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var c4=Object.defineProperty,c8=Object.defineProperties,c6=Object.getOwnPropertyDescriptors,c9=Object.getOwnPropertySymbols,c7=Object.prototype.hasOwnProperty,le=Object.prototype.propertyIsEnumerable,lt=(e,t,r)=>t in e?c4(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,lr=(e,t)=>{for(var r in t||(t={}))c7.call(t,r)&&lt(e,r,t[r]);if(c9)for(var r of c9(t))le.call(t,r)&&lt(e,r,t[r]);return e},li=(e,t)=>c8(e,c6(t)),ls=(e,t,r)=>lt(e,"symbol"!=typeof t?t+"":t,r);class ln{constructor(e){ls(this,"client"),ls(this,"namespaces"),ls(this,"optionalNamespaces"),ls(this,"sessionProperties"),ls(this,"scopedProperties"),ls(this,"events",new(s())),ls(this,"rpcProviders",{}),ls(this,"session"),ls(this,"providerOpts"),ls(this,"logger"),ls(this,"uri"),ls(this,"disableProviderPing",!1),this.providerOpts=e,this.logger="u">typeof e?.logger&&"string"!=typeof e?.logger?e.logger:(0,o.gw)((0,o.jI)({level:e?.logger||ok})),this.disableProviderPing=e?.disableProviderPing||!1}static async init(e){let t=new ln(e);return await t.initialize(),t}async request(e,t,r){let[i,s]=this.validateChain(t);if(!this.session)throw Error("Please call connect() before request()");return await this.getProvider(i).request({request:lr({},e),chainId:`${i}:${s}`,topic:this.session.topic,expiry:r})}sendAsync(e,t,r,i){let s=new Date().getTime();this.request(e,r,i).then(e=>t(null,(0,sr.formatJsonRpcResult)(s,e))).catch(e=>t(e,void 0))}async enable(){if(!this.client)throw Error("Sign Client not initialized");return this.session||await this.connect({namespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties}),await this.requestAccounts()}async disconnect(){var e;if(!this.session)throw Error("Please call connect() before enable()");await this.client.disconnect({topic:null==(e=this.session)?void 0:e.topic,reason:iz("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw Error("Sign Client not initialized");if(this.setNamespaces(e),await this.cleanupPendingPairings(),!e.skipPairing)return await this.pair(e.pairingTopic)}async authenticate(e,t){if(!this.client)throw Error("Sign Client not initialized");this.setNamespaces(e),await this.cleanupPendingPairings();let{uri:r,response:i}=await this.client.authenticate(e,t);r&&(this.uri=r,this.events.emit("display_uri",r));let s=await i();if(this.session=s.session,this.session){let e=ci(this.session.namespaces);this.namespaces=ce(this.namespaces,e),await this.persist("namespaces",this.namespaces),this.onConnect()}return s}on(e,t){this.events.on(e,t)}once(e,t){this.events.once(e,t)}removeListener(e,t){this.events.removeListener(e,t)}off(e,t){this.events.off(e,t)}get isWalletConnect(){return!0}async pair(e){let{uri:t,approval:r}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties});t&&(this.uri=t,this.events.emit("display_uri",t));let i=await r();this.session=i;let s=ci(i.namespaces);return this.namespaces=ce(this.namespaces,s),await this.persist("namespaces",this.namespaces),await this.persist("optionalNamespaces",this.optionalNamespaces),this.onConnect(),this.session}setDefaultChain(e,t){try{if(!this.session)return;let[r,i]=this.validateChain(e),s=this.getProvider(r);s.name===oD?s.setDefaultChain(`${r}:${i}`,t):s.setDefaultChain(i,t)}catch(e){if(!/Please call connect/.test(e.message))throw e}}async cleanupPendingPairings(e={}){this.logger.info("Cleaning up inactive pairings...");let t=this.client.pairing.getAll();if(iK(t)){for(let r of t)e.deletePairings?this.client.core.expirer.set(r.topic,0):await this.client.core.relayer.subscriber.unsubscribe(r.topic);this.logger.info(`Inactive pairings cleared: ${t.length}`)}}abortPairingAttempt(){this.logger.warn("abortPairingAttempt is deprecated. This is now a no-op.")}async checkStorage(){this.namespaces=await this.getFromStore("namespaces")||{},this.optionalNamespaces=await this.getFromStore("optionalNamespaces")||{},this.session&&this.createProviders()}async initialize(){this.logger.trace("Initialized"),await this.createClient(),await this.checkStorage(),this.registerEventListeners()}async createClient(){var e,t;if(this.client=this.providerOpts.client||await oT.init({core:this.providerOpts.core,logger:this.providerOpts.logger||ok,relayUrl:this.providerOpts.relayUrl||"wss://relay.walletconnect.org",projectId:this.providerOpts.projectId,metadata:this.providerOpts.metadata,storageOptions:this.providerOpts.storageOptions,storage:this.providerOpts.storage,name:this.providerOpts.name,customStoragePrefix:this.providerOpts.customStoragePrefix,telemetryEnabled:this.providerOpts.telemetryEnabled}),this.providerOpts.session)try{this.session=this.client.session.get(this.providerOpts.session.topic)}catch(r){throw this.logger.error("Failed to get session",r),Error(`The provided session: ${null==(t=null==(e=this.providerOpts)?void 0:e.session)?void 0:t.topic} doesn't exist in the Sign client`)}else{let e=this.client.session.getAll();this.session=e[0]}this.logger.trace("SignClient Initialized")}createProviders(){if(!this.client)throw Error("Sign Client not initialized");if(!this.session)throw Error("Session not initialized. Please call connect() before enable()");let e=[...new Set(Object.keys(this.session.namespaces).map(e=>iq(e)))];co("client",this.client),co("events",this.events),co("disableProviderPing",this.disableProviderPing),e.forEach(e=>{if(!this.session)return;let t=function(e,t){let r=Object.keys(t.namespaces).filter(t=>t.includes(e));if(!r.length)return[];let i=[];return r.forEach(e=>{let r=t.namespaces[e].accounts;i.push(...r)}),i}(e,this.session),r=o7(t),i=li(lr({},ce(this.namespaces,this.optionalNamespaces)[e]),{accounts:t,chains:r});switch(e){case"eip155":this.rpcProviders[e]=new cE({namespace:i});break;case"algorand":this.rpcProviders[e]=new cU({namespace:i});break;case"solana":this.rpcProviders[e]=new c_({namespace:i});break;case"cosmos":this.rpcProviders[e]=new cT({namespace:i});break;case"polkadot":this.rpcProviders[e]=new cd({namespace:i});break;case"cip34":this.rpcProviders[e]=new cL({namespace:i});break;case"elrond":this.rpcProviders[e]=new cF({namespace:i});break;case"multiversx":this.rpcProviders[e]=new cz({namespace:i});break;case"near":this.rpcProviders[e]=new cY({namespace:i});break;case"tezos":this.rpcProviders[e]=new c0({namespace:i});break;default:this.rpcProviders[oD]?this.rpcProviders[oD].updateNamespace(i):this.rpcProviders[oD]=new c3({namespace:i})}})}registerEventListeners(){if(typeof this.client>"u")throw Error("Sign Client is not initialized");this.client.on("session_ping",e=>{var t;let{topic:r}=e;r===(null==(t=this.session)?void 0:t.topic)&&this.events.emit("session_ping",e)}),this.client.on("session_event",e=>{var t;let{params:r,topic:i}=e;if(i!==(null==(t=this.session)?void 0:t.topic))return;let{event:s}=r;if("accountsChanged"===s.name){let e=s.data;e&&iK(e)&&this.events.emit("accountsChanged",e.map(cr))}else if("chainChanged"===s.name){let e=r.chainId,t=r.event.data,i=iq(e),s=cs(e)!==cs(t)?`${i}:${cs(t)}`:e;this.onChainChanged(s)}else this.events.emit(s.name,s.data);this.events.emit("session_event",e)}),this.client.on("session_update",({topic:e,params:t})=>{var r,i;if(e!==(null==(r=this.session)?void 0:r.topic))return;let{namespaces:s}=t,n=null==(i=this.client)?void 0:i.session.get(e);this.session=li(lr({},n),{namespaces:s}),this.onSessionUpdate(),this.events.emit("session_update",{topic:e,params:t})}),this.client.on("session_delete",async e=>{var t;e.topic===(null==(t=this.session)?void 0:t.topic)&&(await this.cleanup(),this.events.emit("session_delete",e),this.events.emit("disconnect",li(lr({},iz("USER_DISCONNECTED")),{data:e.topic})))}),this.on(oM.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(e,!0)})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[oD]}onSessionUpdate(){Object.keys(this.rpcProviders).forEach(e=>{var t;this.getProvider(e).updateNamespace(null==(t=this.session)?void 0:t.namespaces[e])})}setNamespaces(e){let{namespaces:t={},optionalNamespaces:r={},sessionProperties:i,scopedProperties:s}=e;this.optionalNamespaces=ce(t,r),this.sessionProperties=i,this.scopedProperties=s}validateChain(e){let[t,r]=e?.split(":")||["",""];if(!this.namespaces||!Object.keys(this.namespaces).length)return[t,r];if(t&&!Object.keys(this.namespaces||{}).map(e=>iq(e)).includes(t))throw Error(`Namespace '${t}' is not configured. Please call connect() first with namespace config.`);if(t&&r)return[t,r];let i=iq(Object.keys(this.namespaces)[0]),s=this.rpcProviders[i].getDefaultChain();return[i,s]}async requestAccounts(){let[e]=this.validateChain();return await this.getProvider(e).requestAccounts()}async onChainChanged(e,t=!1){if(!this.namespaces)return;let[r,i]=this.validateChain(e);if(!i)return;this.updateNamespaceChain(r,i),this.events.emit("chainChanged",i);let s=this.getProvider(r).getDefaultChain();t||this.getProvider(r).setDefaultChain(i),this.emitAccountsChangedOnChainChange({namespace:r,previousChainId:s,newChainId:e}),await this.persist("namespaces",this.namespaces)}emitAccountsChangedOnChainChange({namespace:e,previousChainId:t,newChainId:r}){var i,s;try{if(t===r)return;let n=null==(s=null==(i=this.session)?void 0:i.namespaces[e])?void 0:s.accounts;if(!n)return;let a=n.filter(e=>e.includes(`${r}:`)).map(cr);if(!iK(a))return;this.events.emit("accountsChanged",a)}catch(e){this.logger.warn("Failed to emit accountsChanged on chain change",e)}}updateNamespaceChain(e,t){if(!this.namespaces)return;let r=this.namespaces[e]?e:`${e}:${t}`;this.namespaces[r]?this.namespaces[r]&&(this.namespaces[r].defaultChain=t):this.namespaces[r]={chains:[],methods:[],events:[],defaultChain:t}}onConnect(){this.createProviders(),this.events.emit("connect",{session:this.session})}async cleanup(){this.namespaces=void 0,this.optionalNamespaces=void 0,this.sessionProperties=void 0,await this.deleteFromStore("namespaces"),await this.deleteFromStore("optionalNamespaces"),await this.deleteFromStore("sessionProperties"),this.session=void 0,await this.cleanupPendingPairings({deletePairings:!0}),await this.cleanupStorage()}async persist(e,t){var r;let i=(null==(r=this.session)?void 0:r.topic)||"";await this.client.core.storage.setItem(`${ox}/${e}${i}`,t)}async getFromStore(e){var t;let r=(null==(t=this.session)?void 0:t.topic)||"";return await this.client.core.storage.getItem(`${ox}/${e}${r}`)}async deleteFromStore(e){var t;let r=(null==(t=this.session)?void 0:t.topic)||"";await this.client.core.storage.removeItem(`${ox}/${e}${r}`)}async cleanupStorage(){var e;try{if((null==(e=this.client)?void 0:e.session.length)>0)return;for(let e of(await this.client.core.storage.getKeys()))e.startsWith(ox)&&await this.client.core.storage.removeItem(e)}catch(e){this.logger.warn("Failed to cleanup storage",e)}}}},24811:function(e){var t;t=function(){"use strict";var e="millisecond",t="second",r="minute",i="hour",s="week",n="month",a="quarter",o="year",c="date",l="Invalid Date",h=/^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/,d=/\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,u=function(e,t,r){var i=String(e);return!i||i.length>=t?e:""+Array(t+1-i.length).join(r)+e},p="en",g={};g[p]={name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],r=e%100;return"["+e+(t[(r-20)%10]||t[r]||"th")+"]"}};var f="$isDayjsObject",m=function(e){return e instanceof v||!(!e||!e[f])},w=function e(t,r,i){var s;if(!t)return p;if("string"==typeof t){var n=t.toLowerCase();g[n]&&(s=n),r&&(g[n]=r,s=n);var a=t.split("-");if(!s&&a.length>1)return e(a[0])}else{var o=t.name;g[o]=t,s=o}return!i&&s&&(p=s),s||!i&&p},y=function(e,t){if(m(e))return e.clone();var r="object"==typeof t?t:{};return r.date=e,r.args=arguments,new v(r)},b={s:u,z:function(e){var t=-e.utcOffset(),r=Math.abs(t);return(t<=0?"+":"-")+u(Math.floor(r/60),2,"0")+":"+u(r%60,2,"0")},m:function e(t,r){if(t.date()<r.date())return-e(r,t);var i=12*(r.year()-t.year())+(r.month()-t.month()),s=t.clone().add(i,n),a=r-s<0,o=t.clone().add(i+(a?-1:1),n);return+(-(i+(r-s)/(a?s-o:o-s))||0)},a:function(e){return e<0?Math.ceil(e)||0:Math.floor(e)},p:function(l){return({M:n,y:o,w:s,d:"day",D:c,h:i,m:r,s:t,ms:e,Q:a})[l]||String(l||"").toLowerCase().replace(/s$/,"")},u:function(e){return void 0===e}};b.l=w,b.i=m,b.w=function(e,t){return y(e,{locale:t.$L,utc:t.$u,x:t.$x,$offset:t.$offset})};var v=function(){function u(e){this.$L=w(e.locale,null,!0),this.parse(e),this.$x=this.$x||e.x||{},this[f]=!0}var p=u.prototype;return p.parse=function(e){this.$d=function(e){var t=e.date,r=e.utc;if(null===t)return new Date(NaN);if(b.u(t))return new Date;if(t instanceof Date)return new Date(t);if("string"==typeof t&&!/Z$/i.test(t)){var i=t.match(h);if(i){var s=i[2]-1||0,n=(i[7]||"0").substring(0,3);return r?new Date(Date.UTC(i[1],s,i[3]||1,i[4]||0,i[5]||0,i[6]||0,n)):new Date(i[1],s,i[3]||1,i[4]||0,i[5]||0,i[6]||0,n)}}return new Date(t)}(e),this.init()},p.init=function(){var e=this.$d;this.$y=e.getFullYear(),this.$M=e.getMonth(),this.$D=e.getDate(),this.$W=e.getDay(),this.$H=e.getHours(),this.$m=e.getMinutes(),this.$s=e.getSeconds(),this.$ms=e.getMilliseconds()},p.$utils=function(){return b},p.isValid=function(){return this.$d.toString()!==l},p.isSame=function(e,t){var r=y(e);return this.startOf(t)<=r&&r<=this.endOf(t)},p.isAfter=function(e,t){return y(e)<this.startOf(t)},p.isBefore=function(e,t){return this.endOf(t)<y(e)},p.$g=function(e,t,r){return b.u(e)?this[t]:this.set(r,e)},p.unix=function(){return Math.floor(this.valueOf()/1e3)},p.valueOf=function(){return this.$d.getTime()},p.startOf=function(e,a){var l=this,h=!!b.u(a)||a,d=b.p(e),u=function(e,t){var r=b.w(l.$u?Date.UTC(l.$y,t,e):new Date(l.$y,t,e),l);return h?r:r.endOf("day")},p=function(e,t){return b.w(l.toDate()[e].apply(l.toDate("s"),(h?[0,0,0,0]:[23,59,59,999]).slice(t)),l)},g=this.$W,f=this.$M,m=this.$D,w="set"+(this.$u?"UTC":"");switch(d){case o:return h?u(1,0):u(31,11);case n:return h?u(1,f):u(0,f+1);case s:var y=this.$locale().weekStart||0,v=(g<y?g+7:g)-y;return u(h?m-v:m+(6-v),f);case"day":case c:return p(w+"Hours",0);case i:return p(w+"Minutes",1);case r:return p(w+"Seconds",2);case t:return p(w+"Milliseconds",3);default:return this.clone()}},p.endOf=function(e){return this.startOf(e,!1)},p.$set=function(s,a){var l,h=b.p(s),d="set"+(this.$u?"UTC":""),u=((l={}).day=d+"Date",l[c]=d+"Date",l[n]=d+"Month",l[o]=d+"FullYear",l[i]=d+"Hours",l[r]=d+"Minutes",l[t]=d+"Seconds",l[e]=d+"Milliseconds",l)[h],p="day"===h?this.$D+(a-this.$W):a;if(h===n||h===o){var g=this.clone().set(c,1);g.$d[u](p),g.init(),this.$d=g.set(c,Math.min(this.$D,g.daysInMonth())).$d}else u&&this.$d[u](p);return this.init(),this},p.set=function(e,t){return this.clone().$set(e,t)},p.get=function(e){return this[b.p(e)]()},p.add=function(e,a){var c,l=this;e=Number(e);var h=b.p(a),d=function(t){var r=y(l);return b.w(r.date(r.date()+Math.round(t*e)),l)};if(h===n)return this.set(n,this.$M+e);if(h===o)return this.set(o,this.$y+e);if("day"===h)return d(1);if(h===s)return d(7);var u=((c={})[r]=6e4,c[i]=36e5,c[t]=1e3,c)[h]||1,p=this.$d.getTime()+e*u;return b.w(p,this)},p.subtract=function(e,t){return this.add(-1*e,t)},p.format=function(e){var t=this,r=this.$locale();if(!this.isValid())return r.invalidDate||l;var i=e||"YYYY-MM-DDTHH:mm:ssZ",s=b.z(this),n=this.$H,a=this.$m,o=this.$M,c=r.weekdays,h=r.months,u=r.meridiem,p=function(e,r,s,n){return e&&(e[r]||e(t,i))||s[r].slice(0,n)},g=function(e){return b.s(n%12||12,e,"0")},f=u||function(e,t,r){var i=e<12?"AM":"PM";return r?i.toLowerCase():i};return i.replace(d,function(e,i){return i||function(e){switch(e){case"YY":return String(t.$y).slice(-2);case"YYYY":return b.s(t.$y,4,"0");case"M":return o+1;case"MM":return b.s(o+1,2,"0");case"MMM":return p(r.monthsShort,o,h,3);case"MMMM":return p(h,o);case"D":return t.$D;case"DD":return b.s(t.$D,2,"0");case"d":return String(t.$W);case"dd":return p(r.weekdaysMin,t.$W,c,2);case"ddd":return p(r.weekdaysShort,t.$W,c,3);case"dddd":return c[t.$W];case"H":return String(n);case"HH":return b.s(n,2,"0");case"h":return g(1);case"hh":return g(2);case"a":return f(n,a,!0);case"A":return f(n,a,!1);case"m":return String(a);case"mm":return b.s(a,2,"0");case"s":return String(t.$s);case"ss":return b.s(t.$s,2,"0");case"SSS":return b.s(t.$ms,3,"0");case"Z":return s}return null}(e)||s.replace(":","")})},p.utcOffset=function(){return-(15*Math.round(this.$d.getTimezoneOffset()/15))},p.diff=function(e,c,l){var h,d=this,u=b.p(c),p=y(e),g=(p.utcOffset()-this.utcOffset())*6e4,f=this-p,m=function(){return b.m(d,p)};switch(u){case o:h=m()/12;break;case n:h=m();break;case a:h=m()/3;break;case s:h=(f-g)/6048e5;break;case"day":h=(f-g)/864e5;break;case i:h=f/36e5;break;case r:h=f/6e4;break;case t:h=f/1e3;break;default:h=f}return l?h:b.a(h)},p.daysInMonth=function(){return this.endOf(n).$D},p.$locale=function(){return g[this.$L]},p.locale=function(e,t){if(!e)return this.$L;var r=this.clone(),i=w(e,t,!0);return i&&(r.$L=i),r},p.clone=function(){return b.w(this.$d,this)},p.toDate=function(){return new Date(this.valueOf())},p.toJSON=function(){return this.isValid()?this.toISOString():null},p.toISOString=function(){return this.$d.toISOString()},p.toString=function(){return this.$d.toUTCString()},u}(),C=v.prototype;return y.prototype=C,[["$ms",e],["$s",t],["$m",r],["$H",i],["$W","day"],["$M",n],["$y",o],["$D",c]].forEach(function(e){C[e[1]]=function(t){return this.$g(t,e[0],e[1])}}),y.extend=function(e,t){return e.$i||(e(t,v,y),e.$i=!0),y},y.locale=w,y.isDayjs=m,y.unix=function(e){return y(1e3*e)},y.en=g[p],y.Ls=g,y.p={},y},e.exports=t()},76676:function(e){var t;t=function(){return{name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],r=e%100;return"["+e+(t[(r-20)%10]||t[r]||"th")+"]"}}},e.exports=t()},48233:function(e){var t;t=function(){return function(e,t,r){e=e||{};var i=t.prototype,s={future:"in %s",past:"%s ago",s:"a few seconds",m:"a minute",mm:"%d minutes",h:"an hour",hh:"%d hours",d:"a day",dd:"%d days",M:"a month",MM:"%d months",y:"a year",yy:"%d years"};function n(e,t,r,s){return i.fromToBase(e,t,r,s)}r.en.relativeTime=s,i.fromToBase=function(t,i,n,a,o){for(var c,l,h,d=n.$locale().relativeTime||s,u=e.thresholds||[{l:"s",r:44,d:"second"},{l:"m",r:89},{l:"mm",r:44,d:"minute"},{l:"h",r:89},{l:"hh",r:21,d:"hour"},{l:"d",r:35},{l:"dd",r:25,d:"day"},{l:"M",r:45},{l:"MM",r:10,d:"month"},{l:"y",r:17},{l:"yy",d:"year"}],p=u.length,g=0;g<p;g+=1){var f=u[g];f.d&&(c=a?r(t).diff(n,f.d,!0):n.diff(t,f.d,!0));var m=(e.rounding||Math.round)(Math.abs(c));if(h=c>0,m<=f.r||!f.r){m<=1&&g>0&&(f=u[g-1]);var w=d[f.l];o&&(m=o(""+m)),l="string"==typeof w?w.replace("%d",m):w(m,i,f.l,h);break}}if(i)return l;var y=h?d.future:d.past;return"function"==typeof y?y(l):y.replace("%s",l)},i.to=function(e,t){return n(e,t,this,!0)},i.from=function(e,t){return n(e,t,this)};var a=function(e){return e.$u?r.utc():r()};i.toNow=function(e){return this.to(a(this),e)},i.fromNow=function(e){return this.from(a(this),e)}}},e.exports=t()},57209:function(e){var t;t=function(){return function(e,t,r){r.updateLocale=function(e,t){var i=r.Ls[e];if(i)return(t?Object.keys(t):[]).forEach(function(e){i[e]=t[e]}),i}}},e.exports=t()},35862:(e,t,r)=>{"use strict";r.d(t,{fl:()=>k,iv:()=>f,Ts:()=>P,Qu:()=>T,$m:()=>g});let i=class{get shadowRoot(){return this.__host.__shadowRoot}constructor(e){this.ariaAtomic="",this.ariaAutoComplete="",this.ariaBrailleLabel="",this.ariaBrailleRoleDescription="",this.ariaBusy="",this.ariaChecked="",this.ariaColCount="",this.ariaColIndex="",this.ariaColSpan="",this.ariaCurrent="",this.ariaDescription="",this.ariaDisabled="",this.ariaExpanded="",this.ariaHasPopup="",this.ariaHidden="",this.ariaInvalid="",this.ariaKeyShortcuts="",this.ariaLabel="",this.ariaLevel="",this.ariaLive="",this.ariaModal="",this.ariaMultiLine="",this.ariaMultiSelectable="",this.ariaOrientation="",this.ariaPlaceholder="",this.ariaPosInSet="",this.ariaPressed="",this.ariaReadOnly="",this.ariaRequired="",this.ariaRoleDescription="",this.ariaRowCount="",this.ariaRowIndex="",this.ariaRowSpan="",this.ariaSelected="",this.ariaSetSize="",this.ariaSort="",this.ariaValueMax="",this.ariaValueMin="",this.ariaValueNow="",this.ariaValueText="",this.role="",this.form=null,this.labels=[],this.states=new Set,this.validationMessage="",this.validity={},this.willValidate=!0,this.__host=e}checkValidity(){return console.warn("`ElementInternals.checkValidity()` was called on the server.This method always returns true."),!0}reportValidity(){return!0}setFormValue(){}setValidity(){}},s=new WeakMap,n=e=>{let t=s.get(e);return void 0===t&&s.set(e,t=new Map),t},a=class{constructor(){this.__shadowRootMode=null,this.__shadowRoot=null,this.__internals=null}get attributes(){return Array.from(n(this)).map(([e,t])=>({name:e,value:t}))}get shadowRoot(){return"closed"===this.__shadowRootMode?null:this.__shadowRoot}get localName(){return this.constructor.__localName}get tagName(){return this.localName?.toUpperCase()}setAttribute(e,t){n(this).set(e,String(t))}removeAttribute(e){n(this).delete(e)}toggleAttribute(e,t){if(this.hasAttribute(e)){if(void 0===t||!t)return this.removeAttribute(e),!1}else{if(void 0!==t&&!t)return!1;this.setAttribute(e,"")}return!0}hasAttribute(e){return n(this).has(e)}attachShadow(e){let t={host:this};return this.__shadowRootMode=e.mode,e&&"open"===e.mode&&(this.__shadowRoot=t),t}attachInternals(){if(null!==this.__internals)throw Error("Failed to execute 'attachInternals' on 'HTMLElement': ElementInternals for the specified element was already attached.");let e=new i(this);return this.__internals=e,e}getAttribute(e){return n(this).get(e)??null}},o=class extends a{},c=new class{constructor(){this.__definitions=new Map}define(e,t){if(this.__definitions.has(e))throw Error(`Failed to execute 'define' on 'CustomElementRegistry': the name "${e}" has already been used with this registry`);t.__localName=e,this.__definitions.set(e,{ctor:t,observedAttributes:t.observedAttributes??[]})}get(e){let t=this.__definitions.get(e);return t?.ctor}},l=globalThis,h=l.ShadowRoot&&(void 0===l.ShadyCSS||l.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,d=Symbol(),u=new WeakMap;class p{constructor(e,t,r){if(this._$cssResult$=!0,r!==d)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o,t=this.t;if(h&&void 0===e){let r=void 0!==t&&1===t.length;r&&(e=u.get(t)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),r&&u.set(t,e))}return e}toString(){return this.cssText}}let g=e=>new p("string"==typeof e?e:e+"",void 0,d),f=(e,...t)=>new p(1===e.length?e[0]:t.reduce((t,r,i)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(r)+e[i+1],e[0]),e,d),m=(e,t)=>{if(h)e.adoptedStyleSheets=t.map(e=>e instanceof CSSStyleSheet?e:e.styleSheet);else for(let r of t){let t=document.createElement("style"),i=l.litNonce;void 0!==i&&t.setAttribute("nonce",i),t.textContent=r.cssText,e.appendChild(t)}},w=h||void 0===l.CSSStyleSheet?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(let r of e.cssRules)t+=r.cssText;return g(t)})(e):e,{is:y,defineProperty:b,getOwnPropertyDescriptor:v,getOwnPropertyNames:C,getOwnPropertySymbols:E,getPrototypeOf:N}=Object,I=globalThis;I.customElements??=c;let A=I.trustedTypes,_=A?A.emptyScript:"",S=I.reactiveElementPolyfillSupport,O=(e,t)=>e,P={toAttribute(e,t){switch(t){case Boolean:e=e?_:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let r=e;switch(t){case Boolean:r=null!==e;break;case Number:r=null===e?null:Number(e);break;case Object:case Array:try{r=JSON.parse(e)}catch(e){r=null}}return r}},T=(e,t)=>!y(e,t),R={attribute:!0,type:String,converter:P,reflect:!1,useDefault:!1,hasChanged:T};Symbol.metadata??=Symbol("metadata"),I.litPropertyMetadata??=new WeakMap;class k extends(globalThis.HTMLElement??o){static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=R){if(t.state&&(t.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(e)&&((t=Object.create(t)).wrapped=!0),this.elementProperties.set(e,t),!t.noAccessor){let r=Symbol(),i=this.getPropertyDescriptor(e,r,t);void 0!==i&&b(this.prototype,e,i)}}static getPropertyDescriptor(e,t,r){let{get:i,set:s}=v(this.prototype,e)??{get(){return this[t]},set(e){this[t]=e}};return{get:i,set(t){let n=i?.call(this);s?.call(this,t),this.requestUpdate(e,n,r)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??R}static _$Ei(){if(this.hasOwnProperty(O("elementProperties")))return;let e=N(this);e.finalize(),void 0!==e.l&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(O("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(O("properties"))){let e=this.properties;for(let t of[...C(e),...E(e)])this.createProperty(t,e[t])}let e=this[Symbol.metadata];if(null!==e){let t=litPropertyMetadata.get(e);if(void 0!==t)for(let[e,r]of t)this.elementProperties.set(e,r)}for(let[e,t]of(this._$Eh=new Map,this.elementProperties)){let r=this._$Eu(e,t);void 0!==r&&this._$Eh.set(r,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){let t=[];if(Array.isArray(e))for(let r of new Set(e.flat(1/0).reverse()))t.unshift(w(r));else void 0!==e&&t.push(w(e));return t}static _$Eu(e,t){let r=t.attribute;return!1===r?void 0:"string"==typeof r?r:"string"==typeof e?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise(e=>this.enableUpdating=e),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach(e=>e(this))}addController(e){(this._$EO??=new Set).add(e),void 0!==this.renderRoot&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){let e=new Map;for(let t of this.constructor.elementProperties.keys())this.hasOwnProperty(t)&&(e.set(t,this[t]),delete this[t]);e.size>0&&(this._$Ep=e)}createRenderRoot(){let e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return m(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach(e=>e.hostConnected?.())}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach(e=>e.hostDisconnected?.())}attributeChangedCallback(e,t,r){this._$AK(e,r)}_$ET(e,t){let r=this.constructor.elementProperties.get(e),i=this.constructor._$Eu(e,r);if(void 0!==i&&!0===r.reflect){let s=(void 0!==r.converter?.toAttribute?r.converter:P).toAttribute(t,r.type);this._$Em=e,null==s?this.removeAttribute(i):this.setAttribute(i,s),this._$Em=null}}_$AK(e,t){let r=this.constructor,i=r._$Eh.get(e);if(void 0!==i&&this._$Em!==i){let e=r.getPropertyOptions(i),s="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==e.converter?.fromAttribute?e.converter:P;this._$Em=i,this[i]=s.fromAttribute(t,e.type)??this._$Ej?.get(i)??null,this._$Em=null}}requestUpdate(e,t,r){if(void 0!==e){let i=this.constructor,s=this[e];if(!(((r??=i.getPropertyOptions(e)).hasChanged??T)(s,t)||r.useDefault&&r.reflect&&s===this._$Ej?.get(e)&&!this.hasAttribute(i._$Eu(e,r))))return;this.C(e,t,r)}!1===this.isUpdatePending&&(this._$ES=this._$EP())}C(e,t,{useDefault:r,reflect:i,wrapped:s},n){r&&!(this._$Ej??=new Map).has(e)&&(this._$Ej.set(e,n??t??this[e]),!0!==s||void 0!==n)||(this._$AL.has(e)||(this.hasUpdated||r||(t=void 0),this._$AL.set(e,t)),!0===i&&this._$Em!==e&&(this._$Eq??=new Set).add(e))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}let e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(let[e,t]of this._$Ep)this[e]=t;this._$Ep=void 0}let e=this.constructor.elementProperties;if(e.size>0)for(let[t,r]of e){let{wrapped:e}=r,i=this[t];!0!==e||this._$AL.has(t)||void 0===i||this.C(t,void 0,r,i)}}let e=!1,t=this._$AL;try{(e=this.shouldUpdate(t))?(this.willUpdate(t),this._$EO?.forEach(e=>e.hostUpdate?.()),this.update(t)):this._$EM()}catch(t){throw e=!1,this._$EM(),t}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach(e=>e.hostUpdated?.()),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Eq&&=this._$Eq.forEach(e=>this._$ET(e,this[e])),this._$EM()}updated(e){}firstUpdated(e){}}k.elementStyles=[],k.shadowRootOptions={mode:"open"},k[O("elementProperties")]=new Map,k[O("finalized")]=new Map,S?.({ReactiveElement:k}),(I.reactiveElementVersions??=[]).push("2.1.0")},82324:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={WC_NAME_SUFFIX:".reown.id",WC_NAME_SUFFIX_LEGACY:".wcn.id",BLOCKCHAIN_API_RPC_URL:"https://rpc.walletconnect.org",PULSE_API_URL:"https://pulse.walletconnect.org",W3M_API_URL:"https://api.web3modal.org",CONNECTOR_ID:{WALLET_CONNECT:"walletConnect",INJECTED:"injected",WALLET_STANDARD:"announced",COINBASE:"coinbaseWallet",COINBASE_SDK:"coinbaseWalletSDK",SAFE:"safe",LEDGER:"ledger",OKX:"okx",EIP6963:"eip6963",AUTH:"ID_AUTH"},CONNECTOR_NAMES:{AUTH:"Auth"},AUTH_CONNECTOR_SUPPORTED_CHAINS:["eip155","solana"],LIMITS:{PENDING_TRANSACTIONS:99},CHAIN:{EVM:"eip155",SOLANA:"solana",POLKADOT:"polkadot",BITCOIN:"bip122"},CHAIN_NAME_MAP:{eip155:"EVM Networks",solana:"Solana",polkadot:"Polkadot",bip122:"Bitcoin",cosmos:"Cosmos"},ADAPTER_TYPES:{BITCOIN:"bitcoin",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5"},USDT_CONTRACT_ADDRESSES:["0xdac17f958d2ee523a2206206994597c13d831ec7","0xc2132d05d31c914a87c6611c10748aeb04b58e8f","0x9702230a8ea53601f5cd2dc00fdbc13d4df4a8c7","0x919C1c267BC06a7039e03fcc2eF738525769109c","0x48065fbBE25f71C9282ddf5e1cD6D6A887483D5e","0x55d398326f99059fF775485246999027B3197955","0xfd086bc7cd5c481dcc9c85ebe478a1c0b69fcbb9"],HTTP_STATUS_CODES:{SERVICE_UNAVAILABLE:503,FORBIDDEN:403},UNSUPPORTED_NETWORK_NAME:"Unknown Network",SECURE_SITE_SDK_ORIGIN:("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org"}},47588:(e,t,r)=>{"use strict";r.d(t,{p:()=>s});var i=r(82324);let s={caipNetworkIdToNumber:e=>e?Number(e.split(":")[1]):void 0,parseEvmChainId(e){return"string"==typeof e?this.caipNetworkIdToNumber(e):e},getNetworksByNamespace:(e,t)=>e?.filter(e=>e.chainNamespace===t)||[],getFirstNetworkByNamespace(e,t){return this.getNetworksByNamespace(e,t)[0]},getNetworkNameByCaipNetworkId(e,t){if(!t)return;let r=e.find(e=>e.caipNetworkId===t);if(r)return r.name;let[s]=t.split(":");return i.b.CHAIN_NAME_MAP?.[s]||void 0}}},6347:(e,t,r)=>{"use strict";r.d(t,{$U:()=>a,Vk:()=>s,mr:()=>n,uJ:()=>i});let i={WALLET_ID:"@appkit/wallet_id",WALLET_NAME:"@appkit/wallet_name",SOLANA_WALLET:"@appkit/solana_wallet",SOLANA_CAIP_CHAIN:"@appkit/solana_caip_chain",ACTIVE_CAIP_NETWORK_ID:"@appkit/active_caip_network_id",CONNECTED_SOCIAL:"@appkit/connected_social",CONNECTED_SOCIAL_USERNAME:"@appkit-wallet/SOCIAL_USERNAME",RECENT_WALLETS:"@appkit/recent_wallets",DEEPLINK_CHOICE:"WALLETCONNECT_DEEPLINK_CHOICE",ACTIVE_NAMESPACE:"@appkit/active_namespace",CONNECTED_NAMESPACES:"@appkit/connected_namespaces",CONNECTION_STATUS:"@appkit/connection_status",SIWX_AUTH_TOKEN:"@appkit/siwx-auth-token",SIWX_NONCE_TOKEN:"@appkit/siwx-nonce-token",TELEGRAM_SOCIAL_PROVIDER:"@appkit/social_provider",NATIVE_BALANCE_CACHE:"@appkit/native_balance_cache",PORTFOLIO_CACHE:"@appkit/portfolio_cache",ENS_CACHE:"@appkit/ens_cache",IDENTITY_CACHE:"@appkit/identity_cache",PREFERRED_ACCOUNT_TYPES:"@appkit/preferred_account_types",CONNECTIONS:"@appkit/connections"};function s(e){if(!e)throw Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${e}:connected_connector_id`}let n={setItem(e,t){a()&&void 0!==t&&localStorage.setItem(e,t)},getItem(e){if(a())return localStorage.getItem(e)||void 0},removeItem(e){a()&&localStorage.removeItem(e)},clear(){a()&&localStorage.clear()}};function a(){return"undefined"!=typeof window&&"undefined"!=typeof localStorage}},75393:(e,t,r)=>{"use strict";function i(e,t){return"light"===t?{"--w3m-accent":e?.["--w3m-accent"]||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":e?.["--w3m-accent"]||"hsla(230, 100%, 67%, 1)","--w3m-background":"#121313"}}r.d(t,{t:()=>i})},12259:(e,t,r)=>{"use strict";r.d(t,{N:()=>d});var i=r(43892),s=r(63422),n=r(39308),a=r(37786),o=r(97441),c=r(55254),l=r(93746);let h=(0,i.sj)({currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,allAccounts:[]}),d=(0,a.P)({state:h,replaceState(e){e&&Object.assign(h,(0,i.iH)(e))},subscribe:e=>c.R.subscribeChainProp("accountState",t=>{if(t)return e(t)}),subscribeKey(e,t,r){let i;return c.R.subscribeChainProp("accountState",r=>{if(r){let s=r[e];i!==s&&(i=s,t(s))}},r)},setStatus(e,t){c.R.setAccountProp("status",e,t)},getCaipAddress:e=>c.R.getAccountProp("caipAddress",e),setCaipAddress(e,t){let r=e?n.j.getPlainAddress(e):void 0;t===c.R.state.activeChain&&(c.R.state.activeCaipAddress=e),c.R.setAccountProp("caipAddress",e,t),c.R.setAccountProp("address",r,t)},setBalance(e,t,r){c.R.setAccountProp("balance",e,r),c.R.setAccountProp("balanceSymbol",t,r)},setProfileName(e,t){c.R.setAccountProp("profileName",e,t)},setProfileImage(e,t){c.R.setAccountProp("profileImage",e,t)},setUser(e,t){c.R.setAccountProp("user",e,t)},setAddressExplorerUrl(e,t){c.R.setAccountProp("addressExplorerUrl",e,t)},setSmartAccountDeployed(e,t){c.R.setAccountProp("smartAccountDeployed",e,t)},setCurrentTab(e){c.R.setAccountProp("currentTab",e,c.R.state.activeChain)},setTokenBalance(e,t){e&&c.R.setAccountProp("tokenBalance",e,t)},setShouldUpdateToAddress(e,t){c.R.setAccountProp("shouldUpdateToAddress",e,t)},setAllAccounts(e,t){c.R.setAccountProp("allAccounts",e,t)},addAddressLabel(e,t,r){let i=c.R.getAccountProp("addressLabels",r)||new Map;i.set(e,t),c.R.setAccountProp("addressLabels",i,r)},removeAddressLabel(e,t){let r=c.R.getAccountProp("addressLabels",t)||new Map;r.delete(e),c.R.setAccountProp("addressLabels",r,t)},setConnectedWalletInfo(e,t){c.R.setAccountProp("connectedWalletInfo",e,t,!1)},setPreferredAccountType(e,t){c.R.setAccountProp("preferredAccountTypes",{...h.preferredAccountTypes,[t]:e},t)},setPreferredAccountTypes(e){h.preferredAccountTypes=e},setSocialProvider(e,t){e&&c.R.setAccountProp("socialProvider",e,t)},setSocialWindow(e,t){c.R.setAccountProp("socialWindow",e?(0,i.iH)(e):void 0,t)},setFarcasterUrl(e,t){c.R.setAccountProp("farcasterUrl",e,t)},async fetchTokenBalance(e){h.balanceLoading=!0;let t=c.R.state.activeCaipNetwork?.caipNetworkId,r=c.R.state.activeCaipNetwork?.chainNamespace,i=c.R.state.activeCaipAddress,a=i?n.j.getPlainAddress(i):void 0;if(h.lastRetry&&!n.j.isAllowedRetry(h.lastRetry,30*s.bq.ONE_SEC_MS))return h.balanceLoading=!1,[];try{if(a&&t&&r){let e=(await o.L.getBalance(a,t)).balances.filter(e=>"0"!==e.quantity.decimals);return d.setTokenBalance(e,r),h.lastRetry=void 0,h.balanceLoading=!1,e}}catch(t){h.lastRetry=Date.now(),e?.(t),l.SnackController.showError("Token Balance Unavailable")}finally{h.balanceLoading=!1}return[]},resetAccount(e){c.R.resetAccount(e)}})},75836:(e,t,r)=>{"use strict";r.d(t,{AlertController:()=>c});var i=r(43892),s=r(95502),n=r(37786),a=r(24474);let o=(0,i.sj)({message:"",variant:"info",open:!1}),c=(0,n.P)({state:o,subscribeKey:(e,t)=>(0,s.VW)(o,e,t),open(e,t){let{debug:r}=a.OptionsController.state,{shortMessage:i,longMessage:s}=e;r&&(o.message=i,o.variant=t,o.open=!0),s&&console.error("function"==typeof s?s():s)},close(){o.open=!1,o.message="",o.variant="info"}})},36241:(e,t,r)=>{"use strict";r.d(t,{ApiController:()=>y});var i=r(43892),s=r(95502),n=r(96684),a=r(39308),o=r(13847),c=r(11357),l=r(9302),h=r(14105),d=r(55254),u=r(21307),p=r(57703),g=r(24474);let f=a.j.getApiUrl(),m=new o.V({baseUrl:f,clientId:null}),w=(0,i.sj)({promises:{},page:1,count:0,featured:[],allFeatured:[],recommended:[],allRecommended:[],wallets:[],filteredWallets:[],search:[],isAnalyticsEnabled:!1,excludedWallets:[],isFetchingRecommendedWallets:!1}),y={state:w,subscribeKey:(e,t)=>(0,s.VW)(w,e,t),_getSdkProperties(){let{projectId:e,sdkType:t,sdkVersion:r}=g.OptionsController.state;return{projectId:e,st:t||"appkit",sv:r||"html-wagmi-4.2.2"}},_filterOutExtensions:e=>g.OptionsController.state.isUniversalProvider?e.filter(e=>!!(e.mobile_link||e.desktop_link||e.webapp_link)):e,async _fetchWalletImage(e){let t=`${m.baseUrl}/getWalletImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setWalletImage(e,URL.createObjectURL(r))},async _fetchNetworkImage(e){let t=`${m.baseUrl}/public/getAssetImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setNetworkImage(e,URL.createObjectURL(r))},async _fetchConnectorImage(e){let t=`${m.baseUrl}/public/getAssetImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setConnectorImage(e,URL.createObjectURL(r))},async _fetchCurrencyImage(e){let t=`${m.baseUrl}/public/getCurrencyImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setCurrencyImage(e,URL.createObjectURL(r))},async _fetchTokenImage(e){let t=`${m.baseUrl}/public/getTokenImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setTokenImage(e,URL.createObjectURL(r))},_filterWalletsByPlatform:e=>a.j.isMobile()?e?.filter(e=>!!e.mobile_link||e.id===c.m.COINBASE.id||"solana"===d.R.state.activeChain&&(e.id===c.m.SOLFLARE.id||e.id===c.m.PHANTOM.id)):e,fetchProjectConfig:async()=>(await m.get({path:"/appkit/v1/config",params:y._getSdkProperties()})).features,async fetchAllowedOrigins(){try{let{allowedOrigins:e}=await m.get({path:"/projects/v1/origins",params:y._getSdkProperties()});return e}catch(e){return[]}},async fetchNetworkImages(){let e=d.R.getAllRequestedCaipNetworks(),t=e?.map(({assets:e})=>e?.imageId).filter(Boolean).filter(e=>!n.f.getNetworkImageById(e));t&&await Promise.allSettled(t.map(e=>y._fetchNetworkImage(e)))},async fetchConnectorImages(){let{connectors:e}=u.ConnectorController.state,t=e.map(({imageId:e})=>e).filter(Boolean);await Promise.allSettled(t.map(e=>y._fetchConnectorImage(e)))},async fetchCurrencyImages(e=[]){await Promise.allSettled(e.map(e=>y._fetchCurrencyImage(e)))},async fetchTokenImages(e=[]){await Promise.allSettled(e.map(e=>y._fetchTokenImage(e)))},async fetchWallets(e){let t=e.exclude??[];y._getSdkProperties().sv.startsWith("html-core-")&&t.push(...Object.values(c.m).map(e=>e.id));let r=await m.get({path:"/getWallets",params:{...y._getSdkProperties(),...e,page:String(e.page),entries:String(e.entries),include:e.include?.join(","),exclude:t.join(",")}});return{data:y._filterWalletsByPlatform(r?.data)||[],count:r?.count}},async fetchFeaturedWallets(){let{featuredWalletIds:e}=g.OptionsController.state;if(e?.length){let t={...y._getSdkProperties(),page:1,entries:e?.length??4,include:e},{data:r}=await y.fetchWallets(t),i=[...r].sort((t,r)=>e.indexOf(t.id)-e.indexOf(r.id)),s=i.map(e=>e.image_id).filter(Boolean);await Promise.allSettled(s.map(e=>y._fetchWalletImage(e))),w.featured=i,w.allFeatured=i}},async fetchRecommendedWallets(){try{w.isFetchingRecommendedWallets=!0;let{includeWalletIds:e,excludeWalletIds:t,featuredWalletIds:r}=g.OptionsController.state,i=[...t??[],...r??[]].filter(Boolean),s=d.R.getRequestedCaipNetworkIds().join(","),{data:n,count:a}=await y.fetchWallets({page:1,entries:4,include:e,exclude:i,chains:s}),o=l.M.getRecentWallets(),c=n.map(e=>e.image_id).filter(Boolean),h=o.map(e=>e.image_id).filter(Boolean);await Promise.allSettled([...c,...h].map(e=>y._fetchWalletImage(e))),w.recommended=n,w.allRecommended=n,w.count=a??0}catch{}finally{w.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:e}){let{includeWalletIds:t,excludeWalletIds:r,featuredWalletIds:i}=g.OptionsController.state,s=d.R.getRequestedCaipNetworkIds().join(","),n=[...w.recommended.map(({id:e})=>e),...r??[],...i??[]].filter(Boolean),{data:o,count:c}=await y.fetchWallets({page:e,entries:40,include:t,exclude:n,chains:s}),l=o.slice(0,20).map(e=>e.image_id).filter(Boolean);await Promise.allSettled(l.map(e=>y._fetchWalletImage(e))),w.wallets=a.j.uniqueBy([...w.wallets,...y._filterOutExtensions(o)],"id").filter(e=>e.chains?.some(e=>s.includes(e))),w.count=c>w.count?c:w.count,w.page=e},async initializeExcludedWallets({ids:e}){let t={page:1,entries:e.length,include:e},{data:r}=await y.fetchWallets(t);r&&r.forEach(e=>{w.excludedWallets.push({rdns:e.rdns,name:e.name})})},async searchWallet({search:e,badge:t}){let{includeWalletIds:r,excludeWalletIds:i}=g.OptionsController.state,s=d.R.getRequestedCaipNetworkIds().join(",");w.search=[];let n={page:1,entries:100,search:e?.trim(),badge_type:t,include:r,exclude:i,chains:s},{data:o}=await y.fetchWallets(n);p.X.sendEvent({type:"track",event:"SEARCH_WALLET",properties:{badge:t??"",search:e??""}});let c=o.map(e=>e.image_id).filter(Boolean);await Promise.allSettled([...c.map(e=>y._fetchWalletImage(e)),a.j.wait(300)]),w.search=y._filterOutExtensions(o)},initPromise:(e,t)=>w.promises[e]||(w.promises[e]=t()),prefetch:({fetchConnectorImages:e=!0,fetchFeaturedWallets:t=!0,fetchRecommendedWallets:r=!0,fetchNetworkImages:i=!0}={})=>Promise.allSettled([e&&y.initPromise("connectorImages",y.fetchConnectorImages),t&&y.initPromise("featuredWallets",y.fetchFeaturedWallets),r&&y.initPromise("recommendedWallets",y.fetchRecommendedWallets),i&&y.initPromise("networkImages",y.fetchNetworkImages)].filter(Boolean)),prefetchAnalyticsConfig(){g.OptionsController.state.features?.analytics&&y.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{let{isAnalyticsEnabled:e}=await m.get({path:"/getAnalyticsConfig",params:y._getSdkProperties()});g.OptionsController.setFeatures({analytics:e})}catch(e){g.OptionsController.setFeatures({analytics:!1})}},filterByNamespaces(e){if(!e?.length){w.featured=w.allFeatured,w.recommended=w.allRecommended;return}let t=d.R.getRequestedCaipNetworkIds().join(",");w.featured=w.allFeatured.filter(e=>e.chains?.some(e=>t.includes(e))),w.recommended=w.allRecommended.filter(e=>e.chains?.some(e=>t.includes(e))),w.filteredWallets=w.wallets.filter(e=>e.chains?.some(e=>t.includes(e)))},clearFilterByNamespaces(){w.filteredWallets=[]},setFilterByNamespace(e){if(!e){w.featured=w.allFeatured,w.recommended=w.allRecommended;return}let t=d.R.getRequestedCaipNetworkIds().join(",");w.featured=w.allFeatured.filter(e=>e.chains?.some(e=>t.includes(e))),w.recommended=w.allRecommended.filter(e=>e.chains?.some(e=>t.includes(e))),w.filteredWallets=w.wallets.filter(e=>e.chains?.some(e=>t.includes(e)))}}},14105:(e,t,r)=>{"use strict";r.d(t,{W:()=>o});var i=r(43892),s=r(95502),n=r(37786);let a=(0,i.sj)({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),o=(0,n.P)({state:a,subscribeNetworkImages:e=>(0,i.Ld)(a.networkImages,()=>e(a.networkImages)),subscribeKey:(e,t)=>(0,s.VW)(a,e,t),subscribe:e=>(0,i.Ld)(a,()=>e(a)),setWalletImage(e,t){a.walletImages[e]=t},setNetworkImage(e,t){a.networkImages[e]=t},setChainImage(e,t){a.chainImages[e]=t},setConnectorImage(e,t){a.connectorImages={...a.connectorImages,[e]:t}},setTokenImage(e,t){a.tokenImages[e]=t},setCurrencyImage(e,t){a.currencyImages[e]=t}})},97441:(e,t,r)=>{"use strict";r.d(t,{L:()=>f});var i=r(43892),s=r(63422),n=r(39308),a=r(13847),o=r(9302),c=r(12259),l=r(55254),h=r(24474),d=r(93746);let u={purchaseCurrencies:[{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"Ether",symbol:"ETH",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]}],paymentCurrencies:[{id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},{id:"EUR",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]}]},p=n.j.getBlockchainApiUrl(),g=(0,i.sj)({clientId:null,api:new a.V({baseUrl:p,clientId:null}),supportedChains:{http:[],ws:[]}}),f={state:g,async get(e){let{st:t,sv:r}=f.getSdkProperties(),i=h.OptionsController.state.projectId,s={...e.params||{},st:t,sv:r,projectId:i};return g.api.get({...e,params:s})},getSdkProperties(){let{sdkType:e,sdkVersion:t}=h.OptionsController.state;return{st:e||"unknown",sv:t||"unknown"}},async isNetworkSupported(e){if(!e)return!1;try{g.supportedChains.http.length||await f.getSupportedNetworks()}catch(e){return!1}return g.supportedChains.http.includes(e)},async getSupportedNetworks(){try{let e=await f.get({path:"v1/supported-chains"});return g.supportedChains=e,e}catch{return g.supportedChains}},async fetchIdentity({address:e,caipNetworkId:t}){if(!await f.isNetworkSupported(t))return{avatar:"",name:""};let r=o.M.getIdentityFromCacheForAddress(e);if(r)return r;let i=await f.get({path:`/v1/identity/${e}`,params:{sender:l.R.state.activeCaipAddress?n.j.getPlainAddress(l.R.state.activeCaipAddress):void 0}});return o.M.updateIdentityCache({address:e,identity:i,timestamp:Date.now()}),i},fetchTransactions:async({account:e,cursor:t,onramp:r,signal:i,cache:s,chainId:n})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/account/${e}/history`,params:{cursor:t,onramp:r,chainId:n},signal:i,cache:s}):{data:[],next:void 0},fetchSwapQuote:async({amount:e,userAddress:t,from:r,to:i,gasPrice:s})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/quotes",headers:{"Content-Type":"application/json"},params:{amount:e,userAddress:t,from:r,to:i,gasPrice:s}}):{quotes:[]},fetchSwapTokens:async({chainId:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/tokens",params:{chainId:e}}):{tokens:[]},fetchTokenPrice:async({addresses:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:"/v1/fungible/price",body:{currency:"usd",addresses:e,projectId:h.OptionsController.state.projectId},headers:{"Content-Type":"application/json"}}):{fungibles:[]},fetchSwapAllowance:async({tokenAddress:e,userAddress:t})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/allowance",params:{tokenAddress:e,userAddress:t},headers:{"Content-Type":"application/json"}}):{allowance:"0"},async fetchGasPrice({chainId:e}){let{st:t,sv:r}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Gas Price");return f.get({path:"/v1/convert/gas-price",headers:{"Content-Type":"application/json"},params:{chainId:e,st:t,sv:r}})},async generateSwapCalldata({amount:e,from:t,to:r,userAddress:i,disableEstimate:n}){if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Swaps");return g.api.post({path:"/v1/convert/build-transaction",headers:{"Content-Type":"application/json"},body:{amount:e,eip155:{slippage:s.bq.CONVERT_SLIPPAGE_TOLERANCE},projectId:h.OptionsController.state.projectId,from:t,to:r,userAddress:i,disableEstimate:n}})},async generateApproveCalldata({from:e,to:t,userAddress:r}){let{st:i,sv:s}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Swaps");return f.get({path:"/v1/convert/build-approve",headers:{"Content-Type":"application/json"},params:{userAddress:r,from:e,to:t,st:i,sv:s}})},async getBalance(e,t,r){let{st:i,sv:s}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return d.SnackController.showError("Token Balance Unavailable"),{balances:[]};let n=`${t}:${e}`,a=o.M.getBalanceCacheForCaipAddress(n);if(a)return a;let c=await f.get({path:`/v1/account/${e}/balance`,params:{currency:"usd",chainId:t,forceUpdate:r,st:i,sv:s}});return o.M.updateBalanceCache({caipAddress:n,balance:c,timestamp:Date.now()}),c},lookupEnsName:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/account/${e}`,params:{apiVersion:"2"}}):{addresses:{},attributes:[]},reverseLookupEnsName:async({address:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/reverse/${e}`,params:{sender:c.N.state.address,apiVersion:"2"}}):[],getEnsNameSuggestions:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/suggestions/${e}`,params:{zone:"reown.id"}}):{suggestions:[]},registerEnsName:async({coinType:e,address:t,message:r,signature:i})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:"/v1/profile/account",body:{coin_type:e,address:t,message:r,signature:i},headers:{"Content-Type":"application/json"}}):{success:!1},generateOnRampURL:async({destinationWallets:e,partnerUserId:t,defaultNetwork:r,purchaseAmount:i,paymentAmount:s})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?(await g.api.post({path:"/v1/generators/onrampurl",params:{projectId:h.OptionsController.state.projectId},body:{destinationWallets:e,defaultNetwork:r,partnerUserId:t,defaultExperience:"buy",presetCryptoAmount:i,presetFiatAmount:s}})).url:"",async getOnrampOptions(){if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return{paymentCurrencies:[],purchaseCurrencies:[]};try{return await f.get({path:"/v1/onramp/options"})}catch(e){return u}},async getOnrampQuote({purchaseCurrency:e,paymentCurrency:t,amount:r,network:i}){try{if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return null;return await g.api.post({path:"/v1/onramp/quote",params:{projectId:h.OptionsController.state.projectId},body:{purchaseCurrency:e,paymentCurrency:t,amount:r,network:i}})}catch(e){return{coinbaseFee:{amount:r,currency:t.id},networkFee:{amount:r,currency:t.id},paymentSubtotal:{amount:r,currency:t.id},paymentTotal:{amount:r,currency:t.id},purchaseAmount:{amount:r,currency:t.id},quoteId:"mocked-quote-id"}}},getSmartSessions:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/sessions/${e}`}):[],revokeSmartSession:async(e,t,r)=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:`/v1/sessions/${e}/revoke`,params:{projectId:h.OptionsController.state.projectId},body:{pci:t,signature:r}}):{success:!1},setClientId(e){g.clientId=e,g.api=new a.V({baseUrl:p,clientId:e})}}},55254:(e,t,r)=>{"use strict";r.d(t,{R:()=>N});var i=r(43892),s=r(95502),n=r(47588),a=r(82324),o=r(63422),c=r(39308),l=r(9302),h=r(37786),d=r(12259),u=r(31965),p=r(21307),g=r(57703),f=r(80568),m=r(24474),w=r(18413),y=r(53892),b=r(53391);let v={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,allAccounts:[],user:void 0},C={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},E=(0,i.sj)({chains:(0,s.Yr)(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{networkControllerClient:void 0,connectionControllerClient:void 0},isSwitchingNamespace:!1}),N=(0,h.P)({state:E,subscribe:e=>(0,i.Ld)(E,()=>{e(E)}),subscribeKey:(e,t)=>(0,s.VW)(E,e,t),subscribeChainProp(e,t,r){let s;return(0,i.Ld)(E.chains,()=>{let i=r||E.activeChain;if(i){let r=E.chains.get(i)?.[e];s!==r&&(s=r,t(r))}})},initialize(e,t,r){let{chainId:s,namespace:n}=l.M.getActiveNetworkProps(),a=t?.find(e=>e.id.toString()===s?.toString()),o=e.find(e=>e?.namespace===n)||e?.[0],c=e.map(e=>e.namespace).filter(e=>void 0!==e),h=new Set(m.OptionsController.state.enableEmbedded?[...c]:[...t?.map(e=>e.chainNamespace)??[]]);e?.length!==0&&o||(E.noAdapters=!0),!E.noAdapters&&(E.activeChain=o?.namespace,E.activeCaipNetwork=a,N.setChainNetworkData(o?.namespace,{caipNetwork:a}),E.activeChain&&w.I.set({activeChain:o?.namespace})),h.forEach(e=>{let s=t?.filter(t=>t.chainNamespace===e);N.state.chains.set(e,{namespace:e,networkState:(0,i.sj)({...C,caipNetwork:s?.[0]}),accountState:(0,i.sj)(v),caipNetworks:s??[],...r}),N.setRequestedCaipNetworks(s??[],e)})},removeAdapter(e){if(E.activeChain===e){let t=Array.from(E.chains.entries()).find(([t])=>t!==e);if(t){let e=t[1]?.caipNetworks?.[0];e&&N.setActiveCaipNetwork(e)}}E.chains.delete(e)},addAdapter(e,{networkControllerClient:t,connectionControllerClient:r},i){E.chains.set(e.namespace,{namespace:e.namespace,networkState:{...C,caipNetwork:i[0]},accountState:v,caipNetworks:i,connectionControllerClient:r,networkControllerClient:t}),N.setRequestedCaipNetworks(i?.filter(t=>t.chainNamespace===e.namespace)??[],e.namespace)},addNetwork(e){let t=E.chains.get(e.chainNamespace);if(t){let r=[...t.caipNetworks||[]];t.caipNetworks?.find(t=>t.id===e.id)||r.push(e),E.chains.set(e.chainNamespace,{...t,caipNetworks:r}),N.setRequestedCaipNetworks(r,e.chainNamespace),p.ConnectorController.filterByNamespace(e.chainNamespace,!0)}},removeNetwork(e,t){let r=E.chains.get(e);if(r){let i=E.activeCaipNetwork?.id===t,s=[...r.caipNetworks?.filter(e=>e.id!==t)||[]];i&&r?.caipNetworks?.[0]&&N.setActiveCaipNetwork(r.caipNetworks[0]),E.chains.set(e,{...r,caipNetworks:s}),N.setRequestedCaipNetworks(s||[],e),0===s.length&&p.ConnectorController.filterByNamespace(e,!1)}},setAdapterNetworkState(e,t){let r=E.chains.get(e);r&&(r.networkState={...r.networkState||C,...t},E.chains.set(e,r))},setChainAccountData(e,t,r=!0){if(!e)throw Error("Chain is required to update chain account data");let i=E.chains.get(e);if(i){let r={...i.accountState||v,...t};E.chains.set(e,{...i,accountState:r}),(1===E.chains.size||E.activeChain===e)&&(t.caipAddress&&(E.activeCaipAddress=t.caipAddress),d.N.replaceState(r))}},setChainNetworkData(e,t){if(!e)return;let r=E.chains.get(e);if(r){let i={...r.networkState||C,...t};E.chains.set(e,{...r,networkState:i})}},setAccountProp(e,t,r,i=!0){N.setChainAccountData(r,{[e]:t},i),"status"===e&&"disconnected"===t&&r&&p.ConnectorController.removeConnectorId(r)},setActiveNamespace(e){E.activeChain=e;let t=e?E.chains.get(e):void 0,r=t?.networkState?.caipNetwork;r?.id&&e&&(E.activeCaipAddress=t?.accountState?.caipAddress,E.activeCaipNetwork=r,N.setChainNetworkData(e,{caipNetwork:r}),l.M.setActiveCaipNetworkId(r?.caipNetworkId),w.I.set({activeChain:e,selectedNetworkId:r?.caipNetworkId}))},setActiveCaipNetwork(e){if(!e)return;E.activeChain!==e.chainNamespace&&N.setIsSwitchingNamespace(!0);let t=E.chains.get(e.chainNamespace);E.activeChain=e.chainNamespace,E.activeCaipNetwork=e,N.setChainNetworkData(e.chainNamespace,{caipNetwork:e}),t?.accountState?.address?E.activeCaipAddress=`${e.chainNamespace}:${e.id}:${t?.accountState?.address}`:E.activeCaipAddress=void 0,N.setAccountProp("caipAddress",E.activeCaipAddress,e.chainNamespace),t&&d.N.replaceState(t.accountState),b.S.resetSend(),w.I.set({activeChain:E.activeChain,selectedNetworkId:E.activeCaipNetwork?.caipNetworkId}),l.M.setActiveCaipNetworkId(e.caipNetworkId),N.checkIfSupportedNetwork(e.chainNamespace)||!m.OptionsController.state.enableNetworkSwitch||m.OptionsController.state.allowUnsupportedChain||u.ConnectionController.state.wcBasic||N.showUnsupportedChainUI()},addCaipNetwork(e){if(!e)return;let t=E.chains.get(e.chainNamespace);t&&t?.caipNetworks?.push(e)},async switchActiveNamespace(e){if(!e)return;let t=e!==N.state.activeChain,r=N.getNetworkData(e)?.caipNetwork,i=N.getCaipNetworkByNamespace(e,r?.id);t&&i&&await N.switchActiveNetwork(i)},async switchActiveNetwork(e){let t=N.state.chains.get(N.state.activeChain),r=!t?.caipNetworks?.some(e=>e.id===E.activeCaipNetwork?.id),i=N.getNetworkControllerClient(e.chainNamespace);if(i){try{await i.switchCaipNetwork(e),r&&f.I.close()}catch(e){y.RouterController.goBack()}g.X.sendEvent({type:"track",event:"SWITCH_NETWORK",properties:{network:e.caipNetworkId}})}},getNetworkControllerClient(e){let t=e||E.activeChain,r=E.chains.get(t);if(!r)throw Error("Chain adapter not found");if(!r.networkControllerClient)throw Error("NetworkController client not set");return r.networkControllerClient},getConnectionControllerClient(e){let t=e||E.activeChain;if(!t)throw Error("Chain is required to get connection controller client");let r=E.chains.get(t);if(!r?.connectionControllerClient)throw Error("ConnectionController client not set");return r.connectionControllerClient},getAccountProp(e,t){let r=E.activeChain;if(t&&(r=t),!r)return;let i=E.chains.get(r)?.accountState;if(i)return i[e]},getNetworkProp(e,t){let r=E.chains.get(t)?.networkState;if(r)return r[e]},getRequestedCaipNetworks(e){let t=E.chains.get(e),{approvedCaipNetworkIds:r=[],requestedCaipNetworks:i=[]}=t?.networkState||{};return c.j.sortRequestedNetworks(r,i)},getAllRequestedCaipNetworks(){let e=[];return E.chains.forEach(t=>{let r=N.getRequestedCaipNetworks(t.namespace);e.push(...r)}),e},setRequestedCaipNetworks(e,t){N.setAdapterNetworkState(t,{requestedCaipNetworks:e});let r=Array.from(new Set(N.getAllRequestedCaipNetworks().map(e=>e.chainNamespace)));p.ConnectorController.filterByNamespaces(r)},getAllApprovedCaipNetworkIds(){let e=[];return E.chains.forEach(t=>{let r=N.getApprovedCaipNetworkIds(t.namespace);e.push(...r)}),e},getActiveCaipNetwork:()=>E.activeCaipNetwork,getActiveCaipAddress:()=>E.activeCaipAddress,getApprovedCaipNetworkIds(e){let t=E.chains.get(e);return t?.networkState?.approvedCaipNetworkIds||[]},async setApprovedCaipNetworksData(e){let t=N.getNetworkControllerClient(),r=await t?.getApprovedCaipNetworksData();N.setAdapterNetworkState(e,{approvedCaipNetworkIds:r?.approvedCaipNetworkIds,supportsAllNetworks:r?.supportsAllNetworks})},checkIfSupportedNetwork(e,t){let r=t||E.activeCaipNetwork,i=N.getRequestedCaipNetworks(e);return!i.length||i?.some(e=>e.id===r?.id)},checkIfSupportedChainId(e){if(!E.activeChain)return!0;let t=N.getRequestedCaipNetworks(E.activeChain);return t?.some(t=>t.id===e)},setSmartAccountEnabledNetworks(e,t){N.setAdapterNetworkState(t,{smartAccountEnabledNetworks:e})},checkIfSmartAccountEnabled(){let e=n.p.caipNetworkIdToNumber(E.activeCaipNetwork?.caipNetworkId),t=E.activeChain;if(!t||!e)return!1;let r=N.getNetworkProp("smartAccountEnabledNetworks",t);return!!r?.includes(Number(e))},getActiveNetworkTokenAddress(){let e=E.activeCaipNetwork?.chainNamespace||"eip155",t=E.activeCaipNetwork?.id||1,r=o.bq.NATIVE_TOKEN_ADDRESS[e];return`${e}:${t}:${r}`},showUnsupportedChainUI(){f.I.open({view:"UnsupportedChain"})},checkIfNamesSupported(){let e=E.activeCaipNetwork;return!!(e?.chainNamespace&&o.bq.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(e.chainNamespace))},resetNetwork(e){N.setAdapterNetworkState(e,{approvedCaipNetworkIds:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]})},resetAccount(e){if(!e)throw Error("Chain is required to set account prop");E.activeCaipAddress=void 0,N.setChainAccountData(e,{smartAccountDeployed:!1,currentTab:0,caipAddress:void 0,address:void 0,balance:void 0,balanceSymbol:void 0,profileName:void 0,profileImage:void 0,addressExplorerUrl:void 0,tokenBalance:[],connectedWalletInfo:void 0,preferredAccountTypes:void 0,socialProvider:void 0,socialWindow:void 0,farcasterUrl:void 0,allAccounts:[],user:void 0,status:"disconnected"}),p.ConnectorController.removeConnectorId(e)},setIsSwitchingNamespace(e){E.isSwitchingNamespace=e},getFirstCaipNetworkSupportsAuthConnector(){let e=[];if(E.chains.forEach(t=>{a.b.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(e=>e===t.namespace)&&t.namespace&&e.push(t.namespace)}),e.length>0){let t=e[0];return t?E.chains.get(t)?.caipNetworks?.[0]:void 0}},getAccountData:e=>e?N.state.chains.get(e)?.accountState:d.N.state,getNetworkData(e){let t=e||E.activeChain;if(t)return N.state.chains.get(t)?.networkState},getCaipNetworkByNamespace(e,t){if(!e)return;let r=N.state.chains.get(e);return r?.caipNetworks?.find(e=>e.id===t)||r?.networkState?.caipNetwork||r?.caipNetworks?.[0]},getRequestedCaipNetworkIds(){let e=p.ConnectorController.state.filterByNamespace;return(e?[E.chains.get(e)]:Array.from(E.chains.values())).flatMap(e=>e?.caipNetworks||[]).map(e=>e.caipNetworkId)},getCaipNetworks:e=>e?N.getRequestedCaipNetworks(e):N.getAllRequestedCaipNetworks()})},31965:(e,t,r)=>{"use strict";let i;r.d(t,{ConnectionController:()=>E});var s=r(43892),n=r(95502),a=r(39308),o=r(9302),c=r(37786),l=r(12259),h=r(55254),d=r(21307),u=r(57703),p=r(80568),g=r(53892),f=r(3577),m=r(97441),w=r(24474),y=r(93746);let b=(0,s.sj)({transactions:[],coinbaseTransactions:{},transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),v=(0,c.P)({state:b,subscribe:e=>(0,s.Ld)(b,()=>e(b)),setLastNetworkInView(e){b.lastNetworkInView=e},async fetchTransactions(e,t){if(!e)throw Error("Transactions can't be fetched without an accountAddress");b.loading=!0;try{let r=await m.L.fetchTransactions({account:e,cursor:b.next,onramp:t,cache:"coinbase"===t?"no-cache":void 0,chainId:h.R.state.activeCaipNetwork?.caipNetworkId}),i=v.filterSpamTransactions(r.data),s=v.filterByConnectedChain(i),n=[...b.transactions,...s];b.loading=!1,"coinbase"===t?b.coinbaseTransactions=v.groupTransactionsByYearAndMonth(b.coinbaseTransactions,r.data):(b.transactions=n,b.transactionsByYear=v.groupTransactionsByYearAndMonth(b.transactionsByYear,s)),b.empty=0===n.length,b.next=r.next?r.next:void 0}catch(r){let t=h.R.state.activeChain;u.X.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:e,projectId:w.OptionsController.state.projectId,cursor:b.next,isSmartAccount:l.N.state.preferredAccountTypes?.[t]===f.y_.ACCOUNT_TYPES.SMART_ACCOUNT}}),y.SnackController.showError("Failed to fetch transactions"),b.loading=!1,b.empty=!0,b.next=void 0}},groupTransactionsByYearAndMonth:(e={},t=[])=>(t.forEach(t=>{let r=new Date(t.metadata.minedAt).getFullYear(),i=new Date(t.metadata.minedAt).getMonth(),s=e[r]??{},n=(s[i]??[]).filter(e=>e.id!==t.id);e[r]={...s,[i]:[...n,t].sort((e,t)=>new Date(t.metadata.minedAt).getTime()-new Date(e.metadata.minedAt).getTime())}}),e),filterSpamTransactions:e=>e.filter(e=>!e.transfers.every(e=>e.nft_info?.flags.is_spam===!0)),filterByConnectedChain(e){let t=h.R.state.activeCaipNetwork?.caipNetworkId;return e.filter(e=>e.metadata.chain===t)},clearCursor(){b.next=void 0},resetTransactions(){b.transactions=[],b.transactionsByYear={},b.lastNetworkInView=void 0,b.loading=!1,b.empty=!1,b.next=void 0}},"API_ERROR"),C=(0,s.sj)({connections:new Map,wcError:!1,buffering:!1,status:"disconnected"}),E=(0,c.P)({state:C,subscribeKey:(e,t)=>(0,n.VW)(C,e,t),_getClient:()=>C._client,setClient(e){C._client=(0,s.iH)(e)},async connectWalletConnect(){if(a.j.isTelegram()||a.j.isSafari()&&a.j.isIos()){if(i){await i,i=void 0;return}if(!a.j.isPairingExpired(C?.wcPairingExpiry)){let e=C.wcUri;C.wcUri=e;return}i=E._getClient()?.connectWalletConnect?.().catch(()=>void 0),E.state.status="connecting",await i,i=void 0,C.wcPairingExpiry=void 0,E.state.status="connected"}else await E._getClient()?.connectWalletConnect?.()},async connectExternal(e,t,r=!0){await E._getClient()?.connectExternal?.(e),r&&h.R.setActiveNamespace(t)},async reconnectExternal(e){await E._getClient()?.reconnectExternal?.(e);let t=e.chain||h.R.state.activeChain;t&&d.ConnectorController.setConnectorId(e.id,t)},async setPreferredAccountType(e,t){p.I.setLoading(!0,h.R.state.activeChain);let r=d.ConnectorController.getAuthConnector();r&&(l.N.setPreferredAccountType(e,t),await r.provider.setPreferredAccount(e),o.M.setPreferredAccountTypes(l.N.state.preferredAccountTypes??{[t]:e}),await E.reconnectExternal(r),p.I.setLoading(!1,h.R.state.activeChain),u.X.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:e,network:h.R.state.activeCaipNetwork?.caipNetworkId||""}}))},signMessage:async e=>E._getClient()?.signMessage(e),parseUnits:(e,t)=>E._getClient()?.parseUnits(e,t),formatUnits:(e,t)=>E._getClient()?.formatUnits(e,t),sendTransaction:async e=>E._getClient()?.sendTransaction(e),getCapabilities:async e=>E._getClient()?.getCapabilities(e),grantPermissions:async e=>E._getClient()?.grantPermissions(e),walletGetAssets:async e=>E._getClient()?.walletGetAssets(e)??{},estimateGas:async e=>E._getClient()?.estimateGas(e),writeContract:async e=>E._getClient()?.writeContract(e),getEnsAddress:async e=>E._getClient()?.getEnsAddress(e),getEnsAvatar:async e=>E._getClient()?.getEnsAvatar(e),checkInstalled:e=>E._getClient()?.checkInstalled?.(e)||!1,resetWcConnection(){C.wcUri=void 0,C.wcPairingExpiry=void 0,C.wcLinking=void 0,C.recentWallet=void 0,C.status="disconnected",v.resetTransactions(),o.M.deleteWalletConnectDeepLink()},resetUri(){C.wcUri=void 0,C.wcPairingExpiry=void 0,i=void 0},finalizeWcConnection(){let{wcLinking:e,recentWallet:t}=E.state;e&&o.M.setWalletConnectDeepLink(e),t&&o.M.setAppKitRecent(t),u.X.sendEvent({type:"track",event:"CONNECT_SUCCESS",properties:{method:e?"mobile":"qrcode",name:g.RouterController.state.data?.wallet?.name||"Unknown"}})},setWcBasic(e){C.wcBasic=e},setUri(e){C.wcUri=e,C.wcPairingExpiry=a.j.getPairingExpiry()},setWcLinking(e){C.wcLinking=e},setWcError(e){C.wcError=e,C.buffering=!1},setRecentWallet(e){C.recentWallet=e},setBuffering(e){C.buffering=e},setStatus(e){C.status=e},async disconnect(e){try{await E._getClient()?.disconnect(e)}catch(e){throw new c.g("Failed to disconnect","INTERNAL_SDK_ERROR",e)}},setConnections(e,t){C.connections.set(t,e)},switchAccount({connection:e,address:t,namespace:r}){if(d.ConnectorController.state.activeConnectorIds[r]===e.connectorId){let e=h.R.state.activeCaipNetwork;if(e){let i=`${r}:${e.id}:${t}`;l.N.setCaipAddress(i,r)}else console.warn(`No current network found for namespace "${r}"`)}else{let t=d.ConnectorController.getConnector(e.connectorId);t?E.connectExternal(t,r):console.warn(`No connector found for namespace "${r}"`)}}})},21307:(e,t,r)=>{"use strict";r.d(t,{ConnectorController:()=>w});var i=r(43892),s=r(95502),n=r(82324),a=r(75393),o=r(11357),c=r(9302),l=r(37786),h=r(36241),d=r(55254),u=r(24474),p=r(53892),g=r(13770);let f={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0},m=(0,i.sj)({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:{...f},filterByNamespaceMap:{eip155:!0,solana:!0,polkadot:!0,bip122:!0,cosmos:!0}}),w=(0,l.P)({state:m,subscribe:e=>(0,i.Ld)(m,()=>{e(m)}),subscribeKey:(e,t)=>(0,s.VW)(m,e,t),initialize(e){e.forEach(e=>{let t=c.M.getConnectedConnectorId(e);t&&w.setConnectorId(t,e)})},setActiveConnector(e){e&&(m.activeConnector=(0,i.iH)(e))},setConnectors(e){e.filter(e=>!m.allConnectors.some(t=>t.id===e.id&&w.getConnectorName(t.name)===w.getConnectorName(e.name)&&t.chain===e.chain)).forEach(e=>{"MULTI_CHAIN"!==e.type&&m.allConnectors.push((0,i.iH)(e))});let t=w.getEnabledNamespaces(),r=w.getEnabledConnectors(t);m.connectors=w.mergeMultiChainConnectors(r)},filterByNamespaces(e){Object.keys(m.filterByNamespaceMap).forEach(e=>{m.filterByNamespaceMap[e]=!1}),e.forEach(e=>{m.filterByNamespaceMap[e]=!0}),w.updateConnectorsForEnabledNamespaces()},filterByNamespace(e,t){m.filterByNamespaceMap[e]=t,w.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){let e=w.getEnabledNamespaces(),t=w.getEnabledConnectors(e),r=w.areAllNamespacesEnabled();m.connectors=w.mergeMultiChainConnectors(t),r?h.ApiController.clearFilterByNamespaces():h.ApiController.filterByNamespaces(e)},getEnabledNamespaces:()=>Object.entries(m.filterByNamespaceMap).filter(([e,t])=>t).map(([e])=>e),getEnabledConnectors:e=>m.allConnectors.filter(t=>e.includes(t.chain)),areAllNamespacesEnabled:()=>Object.values(m.filterByNamespaceMap).every(e=>e),mergeMultiChainConnectors(e){let t=w.generateConnectorMapByName(e),r=[];return t.forEach(e=>{let t=e[0],i=t?.id===n.b.CONNECTOR_ID.AUTH;e.length>1&&t?r.push({name:t.name,imageUrl:t.imageUrl,imageId:t.imageId,connectors:[...e],type:i?"AUTH":"MULTI_CHAIN",chain:"eip155",id:t?.id||""}):t&&r.push(t)}),r},generateConnectorMapByName(e){let t=new Map;return e.forEach(e=>{let{name:r}=e,i=w.getConnectorName(r);if(!i)return;let s=t.get(i)||[];s.find(t=>t.chain===e.chain)||s.push(e),t.set(i,s)}),t},getConnectorName:e=>e&&({"Trust Wallet":"Trust"})[e]||e,getUniqueConnectorsByName(e){let t=[];return e.forEach(e=>{t.find(t=>t.chain===e.chain)||t.push(e)}),t},addConnector(e){if(e.id===n.b.CONNECTOR_ID.AUTH){let t=(0,i.CO)(u.OptionsController.state),r=g.ThemeController.getSnapshot().themeMode,s=g.ThemeController.getSnapshot().themeVariables;e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,projectId:t.projectId,sdkType:t.sdkType}),e?.provider?.syncTheme({themeMode:r,themeVariables:s,w3mThemeVariables:a.t(s,r)}),w.setConnectors([e])}else w.setConnectors([e])},getAuthConnector(e){let t=e||d.R.state.activeChain,r=m.connectors.find(e=>e.id===n.b.CONNECTOR_ID.AUTH);return r?r?.connectors?.length?r.connectors.find(e=>e.chain===t):r:void 0},getAnnouncedConnectorRdns:()=>m.connectors.filter(e=>"ANNOUNCED"===e.type).map(e=>e.info?.rdns),getConnectorById:e=>m.allConnectors.find(t=>t.id===e),getConnector:(e,t)=>m.allConnectors.filter(e=>e.chain===d.R.state.activeChain).find(r=>r.explorerId===e||r.info?.rdns===t),syncIfAuthConnector(e){if("ID_AUTH"!==e.id)return;let t=(0,i.CO)(u.OptionsController.state),r=g.ThemeController.getSnapshot().themeMode,s=g.ThemeController.getSnapshot().themeVariables;e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,sdkType:t.sdkType,projectId:t.projectId}),e.provider.syncTheme({themeMode:r,themeVariables:s,w3mThemeVariables:(0,a.t)(s,r)})},getConnectorsByNamespace(e){let t=m.allConnectors.filter(t=>t.chain===e);return w.mergeMultiChainConnectors(t)},selectWalletConnector(e){let t=w.getConnector(e.id,e.rdns),r=d.R.state.activeChain;o.R.handleMobileDeeplinkRedirect(t?.explorerId||e.id,r),t?p.RouterController.push("ConnectingExternal",{connector:t}):p.RouterController.push("ConnectingWalletConnect",{wallet:e})},getConnectors:e=>e?w.getConnectorsByNamespace(e):w.mergeMultiChainConnectors(m.allConnectors),setFilterByNamespace(e){m.filterByNamespace=e,m.connectors=w.getConnectors(e),h.ApiController.setFilterByNamespace(e)},setConnectorId(e,t){e&&(m.activeConnectorIds={...m.activeConnectorIds,[t]:e},c.M.setConnectedConnectorId(t,e))},removeConnectorId(e){m.activeConnectorIds={...m.activeConnectorIds,[e]:void 0},c.M.deleteConnectedConnectorId(e)},getConnectorId(e){if(e)return m.activeConnectorIds[e]},isConnected:e=>e?!!m.activeConnectorIds[e]:Object.values(m.activeConnectorIds).some(e=>!!e),resetConnectorIds(){m.activeConnectorIds={...f}}})},57703:(e,t,r)=>{"use strict";r.d(t,{X:()=>f});var i=r(43892),s=r(82324),n=r(6347),a=r(39308),o=r(13847),c=r(12259),l=r(75836),h=r(24474);let d=a.j.getAnalyticsUrl(),u=new o.V({baseUrl:d,clientId:null}),p=["MODAL_CREATED"],g=(0,i.sj)({timestamp:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"}}),f={state:g,subscribe:e=>(0,i.Ld)(g,()=>e(g)),getSdkProperties(){let{projectId:e,sdkType:t,sdkVersion:r}=h.OptionsController.state;return{projectId:e,st:t,sv:r||"html-wagmi-4.2.2"}},async _sendAnalyticsEvent(e){try{let t=c.N.state.address;if(p.includes(e.data.event)||"undefined"==typeof window)return;await u.post({path:"/e",params:f.getSdkProperties(),body:{eventId:a.j.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:e.timestamp,props:{...e.data,address:t}}}),g.reportedErrors.FORBIDDEN=!1}catch(e){e instanceof Error&&e.cause instanceof Response&&e.cause.status===s.b.HTTP_STATUS_CODES.FORBIDDEN&&!g.reportedErrors.FORBIDDEN&&(l.AlertController.open({shortMessage:"Invalid App Configuration",longMessage:`Origin ${(0,n.$U)()?window.origin:"uknown"} not found on Allowlist - update configuration on cloud.reown.com`},"error"),g.reportedErrors.FORBIDDEN=!0)}},sendEvent(e){g.timestamp=Date.now(),g.data=e,h.OptionsController.state.features?.analytics&&f._sendAnalyticsEvent(g)}}},80568:(e,t,r)=>{"use strict";r.d(t,{I:()=>b});var i=r(43892),s=r(95502),n=r(39308),a=r(82324),o=r(12259),c=r(55254),l=r(21307),h=r(53892);let d={onSwitchNetwork({network:e,ignoreSwitchConfirmation:t=!1}){let r=c.R.state.activeCaipNetwork,i=h.RouterController.state.data;if(e.id===r?.id)return;let s=o.N.getCaipAddress(c.R.state.activeChain),n=e.chainNamespace!==c.R.state.activeChain,d=o.N.getCaipAddress(e.chainNamespace),u=l.ConnectorController.getConnectorId(c.R.state.activeChain)===a.b.CONNECTOR_ID.AUTH,p=a.b.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(t=>t===e.chainNamespace);t||u&&p?h.RouterController.push("SwitchNetwork",{...i,network:e}):s&&n&&!d?h.RouterController.push("SwitchActiveChain",{switchToChain:e.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:e}):h.RouterController.push("SwitchNetwork",{...i,network:e})}};var u=r(37786),p=r(36241),g=r(31965),f=r(57703),m=r(24474),w=r(18413);let y=(0,i.sj)({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),b=(0,u.P)({state:y,subscribe:e=>(0,i.Ld)(y,()=>e(y)),subscribeKey:(e,t)=>(0,s.VW)(y,e,t),async open(e){let t="connected"===o.N.state.status,r=e?.namespace,i=c.R.state.activeChain,s=r&&r!==i,a=c.R.getAccountData(e?.namespace)?.caipAddress;if(g.ConnectionController.state.wcBasic?p.ApiController.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1}):await p.ApiController.prefetch({fetchConnectorImages:!t,fetchFeaturedWallets:!t,fetchRecommendedWallets:!t}),l.ConnectorController.setFilterByNamespace(e?.namespace),b.setLoading(!0,r),r&&s){let e=c.R.getNetworkData(r)?.caipNetwork||c.R.getRequestedCaipNetworks(r)[0];e&&d.onSwitchNetwork({network:e,ignoreSwitchConfirmation:!0})}else{let t=c.R.state.noAdapters;m.OptionsController.state.manualWCControl||t&&!a?n.j.isMobile()?h.RouterController.reset("AllWallets"):h.RouterController.reset("ConnectingWalletConnectBasic"):e?.view?h.RouterController.reset(e.view,e.data):a?h.RouterController.reset("Account"):h.RouterController.reset("Connect")}y.open=!0,w.I.set({open:!0}),f.X.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!a}})},close(){let e=m.OptionsController.state.enableEmbedded,t=!!c.R.state.activeCaipAddress;y.open&&f.X.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:t}}),y.open=!1,h.RouterController.reset("Connect"),b.clearLoading(),e?t?h.RouterController.replace("Account"):h.RouterController.push("Connect"):w.I.set({open:!1}),g.ConnectionController.resetUri()},setLoading(e,t){t&&y.loadingNamespaceMap.set(t,e),y.loading=e,w.I.set({loading:e})},clearLoading(){y.loadingNamespaceMap.clear(),y.loading=!1},shake(){y.shake||(y.shake=!0,setTimeout(()=>{y.shake=!1},500))}})},24474:(e,t,r)=>{"use strict";r.d(t,{OptionsController:()=>l});var i=r(43892),s=r(95502),n=r(63422),a=r(39308);let o={getFeatureValue(e,t){let r=t?.[e];return void 0===r?n.bq.DEFAULT_FEATURES[e]:r},filterSocialsByPlatform(e){if(!e||!e.length)return e;if(a.j.isTelegram()){if(a.j.isIos())return e.filter(e=>"google"!==e);if(a.j.isMac())return e.filter(e=>"x"!==e);if(a.j.isAndroid())return e.filter(e=>!["facebook","x"].includes(e))}return e}},c=(0,i.sj)({features:n.bq.DEFAULT_FEATURES,projectId:"",sdkType:"appkit",sdkVersion:"html-wagmi-undefined",defaultAccountTypes:n.bq.DEFAULT_ACCOUNT_TYPES,enableNetworkSwitch:!0,experimental_preferUniversalLinks:!1,remoteFeatures:{}}),l={state:c,subscribeKey:(e,t)=>(0,s.VW)(c,e,t),setOptions(e){Object.assign(c,e)},setRemoteFeatures(e){if(!e)return;let t={...c.remoteFeatures,...e};c.remoteFeatures=t,c.remoteFeatures?.socials&&(c.remoteFeatures.socials=o.filterSocialsByPlatform(c.remoteFeatures.socials))},setFeatures(e){if(!e)return;c.features||(c.features=n.bq.DEFAULT_FEATURES);let t={...c.features,...e};c.features=t},setProjectId(e){c.projectId=e},setCustomRpcUrls(e){c.customRpcUrls=e},setAllWallets(e){c.allWallets=e},setIncludeWalletIds(e){c.includeWalletIds=e},setExcludeWalletIds(e){c.excludeWalletIds=e},setFeaturedWalletIds(e){c.featuredWalletIds=e},setTokens(e){c.tokens=e},setTermsConditionsUrl(e){c.termsConditionsUrl=e},setPrivacyPolicyUrl(e){c.privacyPolicyUrl=e},setCustomWallets(e){c.customWallets=e},setIsSiweEnabled(e){c.isSiweEnabled=e},setIsUniversalProvider(e){c.isUniversalProvider=e},setSdkVersion(e){c.sdkVersion=e},setMetadata(e){c.metadata=e},setDisableAppend(e){c.disableAppend=e},setEIP6963Enabled(e){c.enableEIP6963=e},setDebug(e){c.debug=e},setEnableWalletConnect(e){c.enableWalletConnect=e},setEnableWalletGuide(e){c.enableWalletGuide=e},setEnableAuthLogger(e){c.enableAuthLogger=e},setEnableWallets(e){c.enableWallets=e},setPreferUniversalLinks(e){c.experimental_preferUniversalLinks=e},setHasMultipleAddresses(e){c.hasMultipleAddresses=e},setSIWX(e){c.siwx=e},setConnectMethodsOrder(e){c.features={...c.features,connectMethodsOrder:e}},setWalletFeaturesOrder(e){c.features={...c.features,walletFeaturesOrder:e}},setSocialsOrder(e){c.remoteFeatures={...c.remoteFeatures,socials:e}},setCollapseWallets(e){c.features={...c.features,collapseWallets:e}},setEnableEmbedded(e){c.enableEmbedded=e},setAllowUnsupportedChain(e){c.allowUnsupportedChain=e},setManualWCControl(e){c.manualWCControl=e},setEnableNetworkSwitch(e){c.enableNetworkSwitch=e},setDefaultAccountTypes(e={}){Object.entries(e).forEach(([e,t])=>{t&&(c.defaultAccountTypes[e]=t)})},setUniversalProviderConfigOverride(e){c.universalProviderConfigOverride=e},getUniversalProviderConfigOverride:()=>c.universalProviderConfigOverride,getSnapshot:()=>(0,i.CO)(c)}},18413:(e,t,r)=>{"use strict";r.d(t,{I:()=>a});var i=r(43892),s=r(95502);let n=(0,i.sj)({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1}),a={state:n,subscribe:e=>(0,i.Ld)(n,()=>e(n)),subscribeOpen:e=>(0,s.VW)(n,"open",e),set(e){Object.assign(n,{...n,...e})}}},53892:(e,t,r)=>{"use strict";r.d(t,{RouterController:()=>u});var i=r(43892),s=r(95502),n=r(37786),a=r(12259),o=r(55254),c=r(21307),l=r(80568),h=r(24474);let d=(0,i.sj)({view:"Connect",history:["Connect"],transactionStack:[]}),u=(0,n.P)({state:d,subscribeKey:(e,t)=>(0,s.VW)(d,e,t),pushTransactionStack(e){d.transactionStack.push(e)},popTransactionStack(e){let t=d.transactionStack.pop();if(!t)return;let{onSuccess:r,onError:i,onCancel:s}=t;switch(e){case"success":r?.();break;case"error":i?.(),u.goBack();break;case"cancel":s?.(),u.goBack()}},push(e,t){e!==d.view&&(d.view=e,d.history.push(e),d.data=t)},reset(e,t){d.view=e,d.history=[e],d.data=t},replace(e,t){d.history.at(-1)!==e&&(d.view=e,d.history[d.history.length-1]=e,d.data=t)},goBack(){let e=o.R.state.activeCaipAddress,t="ConnectingFarcaster"===u.state.view,r=!e&&t;if(d.history.length>1){d.history.pop();let[t]=d.history.slice(-1);t&&(e&&"Connect"===t?d.view="Account":d.view=t)}else l.I.close();d.data?.wallet&&(d.data.wallet=void 0),setTimeout(()=>{if(r){a.N.setFarcasterUrl(void 0,o.R.state.activeChain);let e=c.ConnectorController.getAuthConnector();e?.provider?.reload();let t=(0,i.CO)(h.OptionsController.state);e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,projectId:t.projectId,sdkType:t.sdkType})}},100)},goBackToIndex(e){if(d.history.length>1){d.history=d.history.slice(0,e+1);let[t]=d.history.slice(-1);t&&(d.view=t)}},goBackOrCloseModal(){u.state.history.length>1?u.goBack():l.I.close()}})},53391:(e,t,r)=>{"use strict";r.d(t,{S:()=>$});var i=r(43892),s=r(95502),n="[big.js] ",a=n+"Invalid ",o=a+"decimal places",c=a+"rounding mode",l=n+"Division by zero",h={},d=void 0,u=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function p(e,t,r,i){var s=e.c;if(r===d&&(r=e.constructor.RM),0!==r&&1!==r&&2!==r&&3!==r)throw Error(c);if(t<1)i=3===r&&(i||!!s[0])||0===t&&(1===r&&s[0]>=5||2===r&&(s[0]>5||5===s[0]&&(i||s[1]!==d))),s.length=1,i?(e.e=e.e-t+1,s[0]=1):s[0]=e.e=0;else if(t<s.length){if(i=1===r&&s[t]>=5||2===r&&(s[t]>5||5===s[t]&&(i||s[t+1]!==d||1&s[t-1]))||3===r&&(i||!!s[0]),s.length=t,i){for(;++s[--t]>9;)if(s[t]=0,0===t){++e.e,s.unshift(1);break}}for(t=s.length;!s[--t];)s.pop()}return e}function g(e,t,r){var i=e.e,s=e.c.join(""),n=s.length;if(t)s=s.charAt(0)+(n>1?"."+s.slice(1):"")+(i<0?"e":"e+")+i;else if(i<0){for(;++i;)s="0"+s;s="0."+s}else if(i>0){if(++i>n)for(i-=n;i--;)s+="0";else i<n&&(s=s.slice(0,i)+"."+s.slice(i))}else n>1&&(s=s.charAt(0)+"."+s.slice(1));return e.s<0&&r?"-"+s:s}h.abs=function(){var e=new this.constructor(this);return e.s=1,e},h.cmp=function(e){var t,r=this.c,i=(e=new this.constructor(e)).c,s=this.s,n=e.s,a=this.e,o=e.e;if(!r[0]||!i[0])return r[0]?s:i[0]?-n:0;if(s!=n)return s;if(t=s<0,a!=o)return a>o^t?1:-1;for(s=-1,n=(a=r.length)<(o=i.length)?a:o;++s<n;)if(r[s]!=i[s])return r[s]>i[s]^t?1:-1;return a==o?0:a>o^t?1:-1},h.div=function(e){var t=this.constructor,r=this.c,i=(e=new t(e)).c,s=this.s==e.s?1:-1,n=t.DP;if(n!==~~n||n<0||n>1e6)throw Error(o);if(!i[0])throw Error(l);if(!r[0])return e.s=s,e.c=[e.e=0],e;var a,c,h,u,g,f=i.slice(),m=a=i.length,w=r.length,y=r.slice(0,a),b=y.length,v=e,C=v.c=[],E=0,N=n+(v.e=this.e-e.e)+1;for(v.s=s,s=N<0?0:N,f.unshift(0);b++<a;)y.push(0);do{for(h=0;h<10;h++){if(a!=(b=y.length))u=a>b?1:-1;else for(g=-1,u=0;++g<a;)if(i[g]!=y[g]){u=i[g]>y[g]?1:-1;break}if(u<0){for(c=b==a?i:f;b;){if(y[--b]<c[b]){for(g=b;g&&!y[--g];)y[g]=9;--y[g],y[b]+=10}y[b]-=c[b]}for(;!y[0];)y.shift()}else break}C[E++]=u?h:++h,y[0]&&u?y[b]=r[m]||0:y=[r[m]]}while((m++<w||y[0]!==d)&&s--);return!C[0]&&1!=E&&(C.shift(),v.e--,N--),E>N&&p(v,N,t.RM,y[0]!==d),v},h.eq=function(e){return 0===this.cmp(e)},h.gt=function(e){return this.cmp(e)>0},h.gte=function(e){return this.cmp(e)>-1},h.lt=function(e){return 0>this.cmp(e)},h.lte=function(e){return 1>this.cmp(e)},h.minus=h.sub=function(e){var t,r,i,s,n=this.constructor,a=this.s,o=(e=new n(e)).s;if(a!=o)return e.s=-o,this.plus(e);var c=this.c.slice(),l=this.e,h=e.c,d=e.e;if(!c[0]||!h[0])return h[0]?e.s=-o:c[0]?e=new n(this):e.s=1,e;if(a=l-d){for((s=a<0)?(a=-a,i=c):(d=l,i=h),i.reverse(),o=a;o--;)i.push(0);i.reverse()}else for(r=((s=c.length<h.length)?c:h).length,a=o=0;o<r;o++)if(c[o]!=h[o]){s=c[o]<h[o];break}if(s&&(i=c,c=h,h=i,e.s=-e.s),(o=(r=h.length)-(t=c.length))>0)for(;o--;)c[t++]=0;for(o=t;r>a;){if(c[--r]<h[r]){for(t=r;t&&!c[--t];)c[t]=9;--c[t],c[r]+=10}c[r]-=h[r]}for(;0===c[--o];)c.pop();for(;0===c[0];)c.shift(),--d;return c[0]||(e.s=1,c=[d=0]),e.c=c,e.e=d,e},h.mod=function(e){var t,r=this,i=r.constructor,s=r.s,n=(e=new i(e)).s;if(!e.c[0])throw Error(l);return(r.s=e.s=1,t=1==e.cmp(r),r.s=s,e.s=n,t)?new i(r):(s=i.DP,n=i.RM,i.DP=i.RM=0,r=r.div(e),i.DP=s,i.RM=n,this.minus(r.times(e)))},h.neg=function(){var e=new this.constructor(this);return e.s=-e.s,e},h.plus=h.add=function(e){var t,r,i,s=this.constructor;if(e=new s(e),this.s!=e.s)return e.s=-e.s,this.minus(e);var n=this.e,a=this.c,o=e.e,c=e.c;if(!a[0]||!c[0])return c[0]||(a[0]?e=new s(this):e.s=this.s),e;if(a=a.slice(),t=n-o){for(t>0?(o=n,i=c):(t=-t,i=a),i.reverse();t--;)i.push(0);i.reverse()}for(a.length-c.length<0&&(i=c,c=a,a=i),t=c.length,r=0;t;a[t]%=10)r=(a[--t]=a[t]+c[t]+r)/10|0;for(r&&(a.unshift(r),++o),t=a.length;0===a[--t];)a.pop();return e.c=a,e.e=o,e},h.pow=function(e){var t=this,r=new t.constructor("1"),i=r,s=e<0;if(e!==~~e||e<-1e6||e>1e6)throw Error(a+"exponent");for(s&&(e=-e);1&e&&(i=i.times(t)),e>>=1;)t=t.times(t);return s?r.div(i):i},h.prec=function(e,t){if(e!==~~e||e<1||e>1e6)throw Error(a+"precision");return p(new this.constructor(this),e,t)},h.round=function(e,t){if(e===d)e=0;else if(e!==~~e||e<-1e6||e>1e6)throw Error(o);return p(new this.constructor(this),e+this.e+1,t)},h.sqrt=function(){var e,t,r,i=this.constructor,s=this.s,a=this.e,o=new i("0.5");if(!this.c[0])return new i(this);if(s<0)throw Error(n+"No square root");0===(s=Math.sqrt(+g(this,!0,!0)))||s===1/0?((t=this.c.join("")).length+a&1||(t+="0"),a=((a+1)/2|0)-(a<0||1&a),e=new i(((s=Math.sqrt(t))==1/0?"5e":(s=s.toExponential()).slice(0,s.indexOf("e")+1))+a)):e=new i(s+""),a=e.e+(i.DP+=4);do r=e,e=o.times(r.plus(this.div(r)));while(r.c.slice(0,a).join("")!==e.c.slice(0,a).join(""));return p(e,(i.DP-=4)+e.e+1,i.RM)},h.times=h.mul=function(e){var t,r=this.constructor,i=this.c,s=(e=new r(e)).c,n=i.length,a=s.length,o=this.e,c=e.e;if(e.s=this.s==e.s?1:-1,!i[0]||!s[0])return e.c=[e.e=0],e;for(e.e=o+c,n<a&&(t=i,i=s,s=t,c=n,n=a,a=c),t=Array(c=n+a);c--;)t[c]=0;for(o=a;o--;){for(a=0,c=n+o;c>o;)a=t[c]+s[o]*i[c-o-1]+a,t[c--]=a%10,a=a/10|0;t[c]=a}for(a?++e.e:t.shift(),o=t.length;!t[--o];)t.pop();return e.c=t,e},h.toExponential=function(e,t){var r=this,i=r.c[0];if(e!==d){if(e!==~~e||e<0||e>1e6)throw Error(o);for(r=p(new r.constructor(r),++e,t);r.c.length<e;)r.c.push(0)}return g(r,!0,!!i)},h.toFixed=function(e,t){var r=this,i=r.c[0];if(e!==d){if(e!==~~e||e<0||e>1e6)throw Error(o);for(r=p(new r.constructor(r),e+r.e+1,t),e=e+r.e+1;r.c.length<e;)r.c.push(0)}return g(r,!1,!!i)},h[Symbol.for("nodejs.util.inspect.custom")]=h.toJSON=h.toString=function(){var e=this.constructor;return g(this,this.e<=e.NE||this.e>=e.PE,!!this.c[0])},h.toNumber=function(){var e=+g(this,!0,!0);if(!0===this.constructor.strict&&!this.eq(e.toString()))throw Error(n+"Imprecise conversion");return e},h.toPrecision=function(e,t){var r=this,i=r.constructor,s=r.c[0];if(e!==d){if(e!==~~e||e<1||e>1e6)throw Error(a+"precision");for(r=p(new i(r),e,t);r.c.length<e;)r.c.push(0)}return g(r,e<=r.e||r.e<=i.NE||r.e>=i.PE,!!s)},h.valueOf=function(){var e=this.constructor;if(!0===e.strict)throw Error(n+"valueOf disallowed");return g(this,this.e<=e.NE||this.e>=e.PE,!0)};var f=function e(){function t(r){if(!(this instanceof t))return r===d?e():new t(r);if(r instanceof t)this.s=r.s,this.e=r.e,this.c=r.c.slice();else{if("string"!=typeof r){if(!0===t.strict&&"bigint"!=typeof r)throw TypeError(a+"value");r=0===r&&1/r<0?"-0":String(r)}(function(e,t){var r,i,s;if(!u.test(t))throw Error(a+"number");for(e.s="-"==t.charAt(0)?(t=t.slice(1),-1):1,(r=t.indexOf("."))>-1&&(t=t.replace(".","")),(i=t.search(/e/i))>0?(r<0&&(r=i),r+=+t.slice(i+1),t=t.substring(0,i)):r<0&&(r=t.length),s=t.length,i=0;i<s&&"0"==t.charAt(i);)++i;if(i==s)e.c=[e.e=0];else{for(;s>0&&"0"==t.charAt(--s););for(e.e=r-i-1,e.c=[],r=0;i<=s;)e.c[r++]=+t.charAt(i++)}})(this,r)}this.constructor=t}return t.prototype=h,t.DP=20,t.RM=1,t.NE=-7,t.PE=21,t.strict=!1,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}();let m={bigNumber:e=>new f(e||0),multiply(e,t){if(void 0===e||void 0===t)return new f(0);let r=new f(e),i=new f(t);return r.times(i)},formatNumberToLocalString:(e,t=2)=>void 0===e?"0.00":"number"==typeof e?e.toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}):parseFloat(e).toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}),parseLocalStringToNumber:e=>void 0===e?0:parseFloat(e.replace(/,/gu,""))},w=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],y=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"sender",type:"address"},{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{name:"",type:"bool"}]}];var b=r(82324);let v={getERC20Abi:e=>b.b.USDT_CONTRACT_ADDRESSES.includes(e)?y:w};var C=r(3577),E=r(63422),N=r(39308),I=r(12259),A=r(97441),_=r(55254),S=r(31965),O=r(73262);let P={createBalance(e,t){let r={name:e.metadata.name||"",symbol:e.metadata.symbol||"",decimals:e.metadata.decimals||0,value:e.metadata.value||0,price:e.metadata.price||0,iconUrl:e.metadata.iconUrl||""};return{name:r.name,symbol:r.symbol,chainId:t,address:"native"===e.address?void 0:this.convertAddressToCAIP10Address(e.address,t),value:r.value,price:r.price,quantity:{decimals:r.decimals.toString(),numeric:this.convertHexToBalance({hex:e.balance,decimals:r.decimals})},iconUrl:r.iconUrl}},convertHexToBalance:({hex:e,decimals:t})=>(0,O.b)(BigInt(e),t),convertAddressToCAIP10Address:(e,t)=>`${t}:${e}`,createCAIP2ChainId:(e,t)=>`${t}:${parseInt(e,16)}`,getChainIdHexFromCAIP2ChainId(e){let t=e.split(":");if(t.length<2||!t[1])return"0x0";let r=parseInt(t[1],10);return isNaN(r)?"0x0":`0x${r.toString(16)}`},isWalletGetAssetsResponse(e){return"object"==typeof e&&null!==e&&Object.values(e).every(e=>Array.isArray(e)&&e.every(e=>this.isValidAsset(e)))},isValidAsset:e=>"object"==typeof e&&null!==e&&"string"==typeof e.address&&"string"==typeof e.balance&&("ERC20"===e.type||"NATIVE"===e.type)&&"object"==typeof e.metadata&&null!==e.metadata&&"string"==typeof e.metadata.name&&"string"==typeof e.metadata.symbol&&"number"==typeof e.metadata.decimals&&"number"==typeof e.metadata.price&&"string"==typeof e.metadata.iconUrl},T={async getMyTokensWithBalance(e){let t=I.N.state.address,r=_.R.state.activeCaipNetwork;if(!t||!r)return[];if("eip155"===r.chainNamespace){let e=await this.getEIP155Balances(t,r);if(e)return this.filterLowQualityTokens(e)}let i=await A.L.getBalance(t,r.caipNetworkId,e);return this.filterLowQualityTokens(i.balances)},async getEIP155Balances(e,t){try{let r=P.getChainIdHexFromCAIP2ChainId(t.caipNetworkId),i=await S.ConnectionController.getCapabilities(e);if(!i?.[r]?.assetDiscovery?.supported)return null;let s=await S.ConnectionController.walletGetAssets({account:e,chainFilter:[r]});if(!P.isWalletGetAssetsResponse(s))return null;return(s[r]||[]).map(e=>P.createBalance(e,t.caipNetworkId))}catch(e){return null}},filterLowQualityTokens:e=>e.filter(e=>"0"!==e.quantity.decimals),mapBalancesToSwapTokens:e=>e?.map(e=>({...e,address:e?.address?e.address:_.R.getActiveNetworkTokenAddress(),decimals:parseInt(e.quantity.decimals,10),logoUri:e.iconUrl,eip2612:!1}))||[]};var R=r(37786),k=r(57703),x=r(53892),U=r(93746);let D=(0,i.sj)({tokenBalances:[],loading:!1}),$=(0,R.P)({state:D,subscribe:e=>(0,i.Ld)(D,()=>e(D)),subscribeKey:(e,t)=>(0,s.VW)(D,e,t),setToken(e){e&&(D.token=(0,i.iH)(e))},setTokenAmount(e){D.sendTokenAmount=e},setReceiverAddress(e){D.receiverAddress=e},setReceiverProfileImageUrl(e){D.receiverProfileImageUrl=e},setReceiverProfileName(e){D.receiverProfileName=e},setNetworkBalanceInUsd(e){D.networkBalanceInUSD=e},setLoading(e){D.loading=e},async sendToken(){try{switch($.setLoading(!0),_.R.state.activeCaipNetwork?.chainNamespace){case"eip155":await $.sendEvmToken();return;case"solana":await $.sendSolanaToken();return;default:throw Error("Unsupported chain")}}finally{$.setLoading(!1)}},async sendEvmToken(){let e=_.R.state.activeChain,t=I.N.state.preferredAccountTypes?.[e];if(!$.state.sendTokenAmount||!$.state.receiverAddress)throw Error("An amount and receiver address are required");if(!$.state.token)throw Error("A token is required");$.state.token?.address?(k.X.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:t===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token.address,amount:$.state.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),await $.sendERC20Token({receiverAddress:$.state.receiverAddress,tokenAddress:$.state.token.address,sendTokenAmount:$.state.sendTokenAmount,decimals:$.state.token.quantity.decimals})):(k.X.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:t===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token.symbol||"",amount:$.state.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),await $.sendNativeToken({receiverAddress:$.state.receiverAddress,sendTokenAmount:$.state.sendTokenAmount,decimals:$.state.token.quantity.decimals}))},async fetchTokenBalance(e){D.loading=!0;let t=_.R.state.activeCaipNetwork?.caipNetworkId,r=_.R.state.activeCaipNetwork?.chainNamespace,i=_.R.state.activeCaipAddress,s=i?N.j.getPlainAddress(i):void 0;if(D.lastRetry&&!N.j.isAllowedRetry(D.lastRetry,30*E.bq.ONE_SEC_MS))return D.loading=!1,[];try{if(s&&t&&r){let e=await T.getMyTokensWithBalance();return D.tokenBalances=e,D.lastRetry=void 0,e}}catch(t){D.lastRetry=Date.now(),e?.(t),U.SnackController.showError("Token Balance Unavailable")}finally{D.loading=!1}return[]},fetchNetworkBalance(){if(0===D.tokenBalances.length)return;let e=T.mapBalancesToSwapTokens(D.tokenBalances);if(!e)return;let t=e.find(e=>e.address===_.R.getActiveNetworkTokenAddress());t&&(D.networkBalanceInUSD=t?m.multiply(t.quantity.numeric,t.price).toString():"0")},async sendNativeToken(e){x.RouterController.pushTransactionStack({});let t=e.receiverAddress,r=I.N.state.address,i=S.ConnectionController.parseUnits(e.sendTokenAmount.toString(),Number(e.decimals));await S.ConnectionController.sendTransaction({chainNamespace:"eip155",to:t,address:r,data:"0x",value:i??BigInt(0)}),k.X.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:I.N.state.preferredAccountTypes?.eip155===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token?.symbol||"",amount:e.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),S.ConnectionController._getClient()?.updateBalance("eip155"),$.resetSend()},async sendERC20Token(e){x.RouterController.pushTransactionStack({onSuccess(){x.RouterController.replace("Account")}});let t=S.ConnectionController.parseUnits(e.sendTokenAmount.toString(),Number(e.decimals));if(I.N.state.address&&e.sendTokenAmount&&e.receiverAddress&&e.tokenAddress){let r=N.j.getPlainAddress(e.tokenAddress);await S.ConnectionController.writeContract({fromAddress:I.N.state.address,tokenAddress:r,args:[e.receiverAddress,t??BigInt(0)],method:"transfer",abi:v.getERC20Abi(r),chainNamespace:"eip155"}),$.resetSend()}},async sendSolanaToken(){if(!$.state.sendTokenAmount||!$.state.receiverAddress)throw Error("An amount and receiver address are required");x.RouterController.pushTransactionStack({onSuccess(){x.RouterController.replace("Account")}}),await S.ConnectionController.sendTransaction({chainNamespace:"solana",to:$.state.receiverAddress,value:$.state.sendTokenAmount}),S.ConnectionController._getClient()?.updateBalance("solana"),$.resetSend()},resetSend(){D.token=void 0,D.sendTokenAmount=void 0,D.receiverAddress=void 0,D.receiverProfileImageUrl=void 0,D.receiverProfileName=void 0,D.loading=!1,D.tokenBalances=[]}})},93746:(e,t,r)=>{"use strict";r.d(t,{SnackController:()=>c});var i=r(43892),s=r(95502),n=r(39308);let a=Object.freeze({message:"",variant:"success",svg:void 0,open:!1,autoClose:!0}),o=(0,i.sj)({...a}),c={state:o,subscribeKey:(e,t)=>(0,s.VW)(o,e,t),showLoading(e,t={}){this._showMessage({message:e,variant:"loading",...t})},showSuccess(e){this._showMessage({message:e,variant:"success"})},showSvg(e,t){this._showMessage({message:e,svg:t})},showError(e){let t=n.j.parseError(e);this._showMessage({message:t,variant:"error"})},hide(){o.message=a.message,o.variant=a.variant,o.svg=a.svg,o.open=a.open,o.autoClose=a.autoClose},_showMessage({message:e,svg:t,variant:r="success",autoClose:i=a.autoClose}){o.open?(o.open=!1,setTimeout(()=>{o.message=e,o.variant=r,o.svg=t,o.open=!0,o.autoClose=i},150)):(o.message=e,o.variant=r,o.svg=t,o.open=!0,o.autoClose=i)}}},13770:(e,t,r)=>{"use strict";r.d(t,{ThemeController:()=>l});var i=r(43892),s=r(75393),n=r(37786),a=r(21307);let o=(0,i.sj)({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),c={state:o,subscribe:e=>(0,i.Ld)(o,()=>e(o)),setThemeMode(e){o.themeMode=e;try{let t=a.ConnectorController.getAuthConnector();if(t){let r=c.getSnapshot().themeVariables;t.provider.syncTheme({themeMode:e,themeVariables:r,w3mThemeVariables:(0,s.t)(r,e)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(e){o.themeVariables={...o.themeVariables,...e};try{let e=a.ConnectorController.getAuthConnector();if(e){let t=c.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:t,w3mThemeVariables:(0,s.t)(o.themeVariables,o.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot:()=>(0,i.CO)(o)},l=(0,n.P)(c)},96684:(e,t,r)=>{"use strict";r.d(t,{f:()=>c});var i=r(43892),s=r(36241),n=r(14105);let a={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:""},o=(0,i.sj)({networkImagePromises:{}}),c={async fetchWalletImage(e){if(e)return await s.ApiController._fetchWalletImage(e),this.getWalletImageById(e)},async fetchNetworkImage(e){if(e)return this.getNetworkImageById(e)||(o.networkImagePromises[e]||(o.networkImagePromises[e]=s.ApiController._fetchNetworkImage(e)),await o.networkImagePromises[e],this.getNetworkImageById(e))},getWalletImageById(e){if(e)return n.W.state.walletImages[e]},getWalletImage:e=>e?.image_url?e?.image_url:e?.image_id?n.W.state.walletImages[e.image_id]:void 0,getNetworkImage:e=>e?.assets?.imageUrl?e?.assets?.imageUrl:e?.assets?.imageId?n.W.state.networkImages[e.assets.imageId]:void 0,getNetworkImageById(e){if(e)return n.W.state.networkImages[e]},getConnectorImage:e=>e?.imageUrl?e.imageUrl:e?.imageId?n.W.state.connectorImages[e.imageId]:void 0,getChainImage:e=>n.W.state.networkImages[a[e]]}},63422:(e,t,r)=>{"use strict";r.d(t,{a$:()=>n,bq:()=>a,gy:()=>s});let i=("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",s=[{label:"Coinbase",name:"coinbase",feeRange:"1-2%",url:"",supportedChains:["eip155"]},{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],n="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",a={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:i,SECURE_SITE_DASHBOARD:`${i}/dashboard`,SECURE_SITE_FAVICON:`${i}/images/favicon.png`,RESTRICTED_TIMEZONES:["ASIA/SHANGHAI","ASIA/URUMQI","ASIA/CHONGQING","ASIA/HARBIN","ASIA/KASHGAR","ASIA/MACAU","ASIA/HONG_KONG","ASIA/MACAO","ASIA/BEIJING","ASIA/HARBIN"],WC_COINBASE_PAY_SDK_CHAINS:["ethereum","arbitrum","polygon","berachain","avalanche-c-chain","optimism","celo","base"],WC_COINBASE_PAY_SDK_FALLBACK_CHAIN:"ethereum",WC_COINBASE_PAY_SDK_CHAIN_NAME_MAP:{Ethereum:"ethereum","Arbitrum One":"arbitrum",Polygon:"polygon",Berachain:"berachain",Avalanche:"avalanche-c-chain","OP Mainnet":"optimism",Celo:"celo",Base:"base"},WC_COINBASE_ONRAMP_APP_ID:"bf18c88d-495a-463b-b249-0b9d3656cf5e",SWAP_SUGGESTED_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP"],SWAP_POPULAR_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP","METAL","DAI","CHAMP","WOLF","SALE","BAL","BUSD","MUST","BTCpx","ROUTE","HEX","WELT","amDAI","VSQ","VISION","AURUM","pSP","SNX","VC","LINK","CHP","amUSDT","SPHERE","FOX","GIDDY","GFC","OMEN","OX_OLD","DE","WNT"],BALANCE_SUPPORTED_CHAINS:["eip155","solana"],SWAP_SUPPORTED_NETWORKS:["eip155:1","eip155:42161","eip155:10","eip155:324","eip155:8453","eip155:56","eip155:137","eip155:100","eip155:43114","eip155:250","eip155:8217","eip155:1313161554"],NAMES_SUPPORTED_CHAIN_NAMESPACES:["eip155"],ONRAMP_SUPPORTED_CHAIN_NAMESPACES:["eip155","solana"],ACTIVITY_ENABLED_CHAIN_NAMESPACES:["eip155"],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x"},CONVERT_SLIPPAGE_TOLERANCE:1,CONNECT_LABELS:{MOBILE:"Open and continue in the wallet app",WEB:"Open and continue in the wallet app"},SEND_SUPPORTED_NAMESPACES:["eip155","solana"],DEFAULT_REMOTE_FEATURES:{swaps:["1inch"],onramp:["coinbase","meld"],email:!0,socials:["google","x","discord","farcaster","github","apple","facebook"],activity:!0,reownBranding:!0},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1},DEFAULT_FEATURES:{receive:!0,send:!0,emailShowWallets:!0,connectorTypeOrder:["walletConnect","recent","injected","featured","custom","external","recommended"],analytics:!0,allWallets:!0,legalCheckbox:!1,smartSessions:!1,collapseWallets:!1,walletFeaturesOrder:["onramp","swaps","receive","send"],connectMethodsOrder:void 0,pay:!1},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"}}},39308:(e,t,r)=>{"use strict";r.d(t,{j:()=>a});var i=r(82324),s=r(63422),n=r(9302);let a={isMobile(){return!!this.isClient()&&!!("function"==typeof window?.matchMedia&&window?.matchMedia("(pointer:coarse)")?.matches||/Android|webOS|iPhone|iPad|iPod|BlackBerry|Opera Mini/u.test(navigator.userAgent))},checkCaipNetwork:(e,t="")=>e?.caipNetworkId.toLocaleLowerCase().includes(t.toLowerCase()),isAndroid(){if(!this.isMobile())return!1;let e=window?.navigator.userAgent.toLowerCase();return a.isMobile()&&e.includes("android")},isIos(){if(!this.isMobile())return!1;let e=window?.navigator.userAgent.toLowerCase();return e.includes("iphone")||e.includes("ipad")},isSafari(){return!!this.isClient()&&(window?.navigator.userAgent.toLowerCase()).includes("safari")},isClient:()=>"undefined"!=typeof window,isPairingExpired:e=>!e||e-Date.now()<=s.bq.TEN_SEC_MS,isAllowedRetry:(e,t=s.bq.ONE_SEC_MS)=>Date.now()-e>=t,copyToClopboard(e){navigator.clipboard.writeText(e)},isIframe(){try{return window?.self!==window?.top}catch(e){return!1}},isSafeApp(){if(a.isClient()&&window.self!==window.top)try{let e=window?.location?.ancestorOrigins?.[0];if(e){let t=new URL(e),r=new URL("https://app.safe.global");return t.hostname===r.hostname}}catch{}return!1},getPairingExpiry:()=>Date.now()+s.bq.FOUR_MINUTES_MS,getNetworkId:e=>e?.split(":")[1],getPlainAddress:e=>e?.split(":")[2],wait:async e=>new Promise(t=>{setTimeout(t,e)}),debounce(e,t=500){let r;return(...i)=>{r&&clearTimeout(r),r=setTimeout(function(){e(...i)},t)}},isHttpUrl:e=>e.startsWith("http://")||e.startsWith("https://"),formatNativeUrl(e,t,r=null){if(a.isHttpUrl(e))return this.formatUniversalUrl(e,t);let i=e,s=r;i.includes("://")||(i=e.replaceAll("/","").replaceAll(":",""),i=`${i}://`),i.endsWith("/")||(i=`${i}/`),s&&!s?.endsWith("/")&&(s=`${s}/`),this.isTelegram()&&this.isAndroid()&&(t=encodeURIComponent(t));let n=encodeURIComponent(t);return{redirect:`${i}wc?uri=${n}`,redirectUniversalLink:s?`${s}wc?uri=${n}`:void 0,href:i}},formatUniversalUrl(e,t){if(!a.isHttpUrl(e))return this.formatNativeUrl(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let i=encodeURIComponent(t);return{redirect:`${r}wc?uri=${i}`,href:r}},getOpenTargetForPlatform(e){return"popupWindow"===e?e:this.isTelegram()?n.M.getTelegramSocialProvider()?"_top":"_blank":e},openHref(e,t,r){window?.open(e,this.getOpenTargetForPlatform(t),r||"noreferrer noopener")},returnOpenHref(e,t,r){return window?.open(e,this.getOpenTargetForPlatform(t),r||"noreferrer noopener")},isTelegram:()=>"undefined"!=typeof window&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto),isPWA(){if("undefined"==typeof window)return!1;let e=window.matchMedia?.("(display-mode: standalone)")?.matches,t=window?.navigator?.standalone;return!!(e||t)},preloadImage:async e=>Promise.race([new Promise((t,r)=>{let i=new Image;i.onload=t,i.onerror=r,i.crossOrigin="anonymous",i.src=e}),a.wait(2e3)]),formatBalance(e,t){let r="0.000";if("string"==typeof e){let t=Number(e);if(t){let e=Math.floor(1e3*t)/1e3;e&&(r=e.toString())}}return`${r}${t?` ${t}`:""}`},formatBalance2(e,t){let r;if("0"===e)r="0";else if("string"==typeof e){let t=Number(e);t&&(r=t.toString().match(/^-?\d+(?:\.\d{0,3})?/u)?.[0])}return{value:r??"0",rest:"0"===r?"000":"",symbol:t}},getApiUrl:()=>i.b.W3M_API_URL,getBlockchainApiUrl:()=>i.b.BLOCKCHAIN_API_RPC_URL,getAnalyticsUrl:()=>i.b.PULSE_API_URL,getUUID:()=>crypto?.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,e=>{let t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}),parseError:e=>"string"==typeof e?e:"string"==typeof e?.issues?.[0]?.message?e.issues[0].message:e instanceof Error?e.message:"Unknown error",sortRequestedNetworks(e,t=[]){let r={};return t&&e&&(e.forEach((e,t)=>{r[e]=t}),t.sort((e,t)=>{let i=r[e.id],s=r[t.id];return void 0!==i&&void 0!==s?i-s:void 0!==i?-1:void 0!==s?1:0})),t},calculateBalance(e){let t=0;for(let r of e)t+=r.value??0;return t},formatTokenBalance(e){let[t,r]=e.toFixed(2).split(".");return{dollars:t,pennies:r}},isAddress(e,t="eip155"){switch(t){case"eip155":if(/^(?:0x)?[0-9a-f]{40}$/iu.test(e)&&(/^(?:0x)?[0-9a-f]{40}$/iu.test(e)||/^(?:0x)?[0-9A-F]{40}$/iu.test(e)))return!0;return!1;case"solana":return/[1-9A-HJ-NP-Za-km-z]{32,44}$/iu.test(e);default:return!1}},uniqueBy(e,t){let r=new Set;return e.filter(e=>{let i=e[t];return!r.has(i)&&(r.add(i),!0)})},generateSdkVersion(e,t,r){let i=0===e.length?s.bq.ADAPTER_TYPES.UNIVERSAL:e.map(e=>e.adapterType).join(",");return`${t}-${i}-${r}`},createAccount:(e,t,r,i,s)=>({namespace:e,address:t,type:r,publicKey:i,path:s}),isCaipAddress(e){if("string"!=typeof e)return!1;let t=e.split(":"),r=t[0];return 3===t.filter(Boolean).length&&r in i.b.CHAIN_NAME_MAP},isMac(){let e=window?.navigator.userAgent.toLowerCase();return e.includes("macintosh")&&!e.includes("safari")},formatTelegramSocialLoginUrl(e){let t=`--${encodeURIComponent(window?.location.href)}`,r="state=";if("auth.magic.link"===new URL(e).host){let i="provider_authorization_url=",s=e.substring(e.indexOf(i)+i.length),n=this.injectIntoUrl(decodeURIComponent(s),r,t);return e.replace(s,encodeURIComponent(n))}return this.injectIntoUrl(e,r,t)},injectIntoUrl(e,t,r){let i=e.indexOf(t);if(-1===i)throw Error(`${t} parameter not found in the URL: ${e}`);let s=e.indexOf("&",i),n=t.length,a=-1!==s?s:e.length,o=e.substring(0,i+n);return o+(e.substring(i+n,a)+r)+e.substring(s)}}},13847:(e,t,r)=>{"use strict";async function i(...e){let t=await fetch(...e);if(!t.ok)throw Error(`HTTP status code: ${t.status}`,{cause:t});return t}r.d(t,{V:()=>s});class s{constructor({baseUrl:e,clientId:t}){this.baseUrl=e,this.clientId=t}async get({headers:e,signal:t,cache:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"GET",headers:e,signal:t,cache:r})).json()}async getBlob({headers:e,signal:t,...r}){let s=this.createUrl(r);return(await i(s,{method:"GET",headers:e,signal:t})).blob()}async post({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"POST",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}async put({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"PUT",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}async delete({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"DELETE",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}createUrl({path:e,params:t}){let r=new URL(e,this.baseUrl);return t&&Object.entries(t).forEach(([e,t])=>{t&&r.searchParams.append(e,t)}),this.clientId&&r.searchParams.append("clientId",this.clientId),r}}},11357:(e,t,r)=>{"use strict";r.d(t,{R:()=>n,m:()=>s});var i=r(82324);let s={PHANTOM:{id:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",url:"https://phantom.app"},SOLFLARE:{id:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",url:"https://solflare.com"},COINBASE:{id:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",url:"https://go.cb-w.com"}},n={handleMobileDeeplinkRedirect(e,t){let r=window.location.href,n=encodeURIComponent(r);if(e===s.PHANTOM.id&&!("phantom"in window)){let e=r.startsWith("https")?"https":"http",t=r.split("/")[2],i=encodeURIComponent(`${e}://${t}`);window.location.href=`${s.PHANTOM.url}/ul/browse/${n}?ref=${i}`}e!==s.SOLFLARE.id||"solflare"in window||(window.location.href=`${s.SOLFLARE.url}/ul/v1/browse/${n}?ref=${n}`),t!==i.b.CHAIN.SOLANA||e!==s.COINBASE.id||"coinbaseSolana"in window||(window.location.href=`${s.COINBASE.url}/dapp?cb_url=${n}`)}}},15017:(e,t,r)=>{"use strict";r.d(t,{w:()=>f}),r(50691);var i=r(82324),s=r(3577),n=r(12259),a=r(55254),o=r(31965),c=r(21307),l=r(57703),h=r(80568),d=r(24474),u=r(53892),p=r(93746),g=r(39308);let f={getSIWX:()=>d.OptionsController.state.siwx,async initializeIfEnabled(){let e=d.OptionsController.state.siwx,t=a.R.getActiveCaipAddress();if(!(e&&t))return;let[r,i,s]=t.split(":");if(a.R.checkIfSupportedNetwork(r))try{if((await e.getSessions(`${r}:${i}`,s)).length)return;await h.I.open({view:"SIWXSignMessage"})}catch(e){console.error("SIWXUtil:initializeIfEnabled",e),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties()}),await o.ConnectionController._getClient()?.disconnect().catch(console.error),u.RouterController.reset("Connect"),p.SnackController.showError("A problem occurred while trying initialize authentication")}},async requestSignMessage(){let e=d.OptionsController.state.siwx,t=g.j.getPlainAddress(a.R.getActiveCaipAddress()),r=a.R.getActiveCaipNetwork(),s=o.ConnectionController._getClient();if(!e)throw Error("SIWX is not enabled");if(!t)throw Error("No ActiveCaipAddress found");if(!r)throw Error("No ActiveCaipNetwork or client found");if(!s)throw Error("No ConnectionController client found");try{let n=await e.createMessage({chainId:r.caipNetworkId,accountAddress:t}),a=n.toString();c.ConnectorController.getConnectorId(r.chainNamespace)===i.b.CONNECTOR_ID.AUTH&&u.RouterController.pushTransactionStack({});let o=await s.signMessage(a);await e.addSession({data:n,message:a,signature:o}),h.I.close(),l.X.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(t){let e=this.getSIWXEventProperties();h.I.state.open&&"ApproveTransaction"!==u.RouterController.state.view||await h.I.open({view:"SIWXSignMessage"}),e.isSmartAccount?p.SnackController.showError("This application might not support Smart Accounts"):p.SnackController.showError("Signature declined"),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:e}),console.error("SWIXUtil:requestSignMessage",t)}},async cancelSignMessage(){try{let e=this.getSIWX();e?.getRequired?.()?await o.ConnectionController.disconnect():h.I.close(),u.RouterController.reset("Connect"),l.X.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getSessions(){let e=d.OptionsController.state.siwx,t=g.j.getPlainAddress(a.R.getActiveCaipAddress()),r=a.R.getActiveCaipNetwork();return e&&t&&r?e.getSessions(r.caipNetworkId,t):[]},async isSIWXCloseDisabled(){let e=this.getSIWX();if(e){let t="ApproveTransaction"===u.RouterController.state.view,r="SIWXSignMessage"===u.RouterController.state.view;if(t||r)return e.getRequired?.()&&0===(await this.getSessions()).length}return!1},async universalProviderAuthenticate({universalProvider:e,chains:t,methods:r}){let i=f.getSIWX(),s=new Set(t.map(e=>e.split(":")[0]));if(!i||1!==s.size||!s.has("eip155"))return!1;let o=await i.createMessage({chainId:a.R.getActiveCaipNetwork()?.caipNetworkId||"",accountAddress:""}),c=await e.authenticate({nonce:o.nonce,domain:o.domain,uri:o.uri,exp:o.expirationTime,iat:o.issuedAt,nbf:o.notBefore,requestId:o.requestId,version:o.version,resources:o.resources,statement:o.statement,chainId:o.chainId,methods:r,chains:[o.chainId,...t.filter(e=>e!==o.chainId)]});if(p.SnackController.showLoading("Authenticating...",{autoClose:!1}),n.N.setConnectedWalletInfo({...c.session.peer.metadata,name:c.session.peer.metadata.name,icon:c.session.peer.metadata.icons?.[0],type:"WALLET_CONNECT"},Array.from(s)[0]),c?.auths?.length){let t=c.auths.map(t=>{let r=e.client.formatAuthMessage({request:t.p,iss:t.p.iss});return{data:{...t.p,accountAddress:t.p.iss.split(":").slice(-1).join(""),chainId:t.p.iss.split(":").slice(2,4).join(":"),uri:t.p.aud,version:t.p.version||o.version,expirationTime:t.p.exp,issuedAt:t.p.iat,notBefore:t.p.nbf},message:r,signature:t.s.s,cacao:t}});try{await i.setSessions(t),l.X.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:f.getSIWXEventProperties()})}catch(t){throw console.error("SIWX:universalProviderAuth - failed to set sessions",t),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:f.getSIWXEventProperties()}),await e.disconnect().catch(console.error),t}finally{p.SnackController.hide()}}return!0},getSIWXEventProperties(){let e=a.R.state.activeChain;return{network:a.R.state.activeCaipNetwork?.caipNetworkId||"",isSmartAccount:n.N.state.preferredAccountTypes?.[e]===s.y_.ACCOUNT_TYPES.SMART_ACCOUNT}},async clearSessions(){let e=this.getSIWX();e&&await e.setSessions([])}}},9302:(e,t,r)=>{"use strict";r.d(t,{M:()=>s});var i=r(6347);let s={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5},isCacheExpired:(e,t)=>Date.now()-e>t,getActiveNetworkProps(){let e=s.getActiveNamespace(),t=s.getActiveCaipNetworkId(),r=t?t.split(":")[1]:void 0;return{namespace:e,caipNetworkId:t,chainId:r?isNaN(Number(r))?r:Number(r):void 0}},setWalletConnectDeepLink({name:e,href:t}){try{i.mr.setItem(i.uJ.DEEPLINK_CHOICE,JSON.stringify({href:t,name:e}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{let e=i.mr.getItem(i.uJ.DEEPLINK_CHOICE);if(e)return JSON.parse(e)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{i.mr.removeItem(i.uJ.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(e){try{i.mr.setItem(i.uJ.ACTIVE_NAMESPACE,e)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(e){try{i.mr.setItem(i.uJ.ACTIVE_CAIP_NETWORK_ID,e),s.setActiveNamespace(e.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return i.mr.getItem(i.uJ.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{i.mr.removeItem(i.uJ.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(e){try{let t=(0,i.Vk)(e);i.mr.removeItem(t)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(e){try{let t=s.getRecentWallets();t.find(t=>t.id===e.id)||(t.unshift(e),t.length>2&&t.pop(),i.mr.setItem(i.uJ.RECENT_WALLETS,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{let e=i.mr.getItem(i.uJ.RECENT_WALLETS);return e?JSON.parse(e):[]}catch{console.info("Unable to get AppKit recent")}return[]},setConnectedConnectorId(e,t){try{let r=(0,i.Vk)(e);i.mr.setItem(r,t)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return i.mr.getItem(i.uJ.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(e){if(e)try{let t=(0,i.Vk)(e);return i.mr.getItem(t)}catch(t){console.info("Unable to get connected connector id in namespace ",e)}},setConnectedSocialProvider(e){try{i.mr.setItem(i.uJ.CONNECTED_SOCIAL,e)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return i.mr.getItem(i.uJ.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{i.mr.removeItem(i.uJ.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return i.mr.getItem(i.uJ.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){let e=i.mr.getItem(i.uJ.ACTIVE_CAIP_NETWORK_ID);return e?.split(":")?.[1]},setConnectionStatus(e){try{i.mr.setItem(i.uJ.CONNECTION_STATUS,e)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return i.mr.getItem(i.uJ.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{let e=i.mr.getItem(i.uJ.CONNECTED_NAMESPACES);if(!e?.length)return[];return e.split(",")}catch{return[]}},setConnectedNamespaces(e){try{let t=Array.from(new Set(e));i.mr.setItem(i.uJ.CONNECTED_NAMESPACES,t.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(e){try{let t=s.getConnectedNamespaces();t.includes(e)||(t.push(e),s.setConnectedNamespaces(t))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(e){try{let t=s.getConnectedNamespaces(),r=t.indexOf(e);r>-1&&(t.splice(r,1),s.setConnectedNamespaces(t))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return i.mr.getItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(e){try{i.mr.setItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER,e)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{i.mr.removeItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let e={};try{let t=i.mr.getItem(i.uJ.PORTFOLIO_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get balance cache")}return e},removeAddressFromBalanceCache(e){try{let t=s.getBalanceCache();i.mr.setItem(i.uJ.PORTFOLIO_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove address from balance cache",e)}},getBalanceCacheForCaipAddress(e){try{let t=s.getBalanceCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.portfolio))return t.balance;s.removeAddressFromBalanceCache(e)}catch{console.info("Unable to get balance cache for address",e)}},updateBalanceCache(e){try{let t=s.getBalanceCache();t[e.caipAddress]=e,i.mr.setItem(i.uJ.PORTFOLIO_CACHE,JSON.stringify(t))}catch{console.info("Unable to update balance cache",e)}},getNativeBalanceCache(){let e={};try{let t=i.mr.getItem(i.uJ.NATIVE_BALANCE_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get balance cache")}return e},removeAddressFromNativeBalanceCache(e){try{let t=s.getBalanceCache();i.mr.setItem(i.uJ.NATIVE_BALANCE_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove address from balance cache",e)}},getNativeBalanceCacheForCaipAddress(e){try{let t=s.getNativeBalanceCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.nativeBalance))return t;console.info("Discarding cache for address",e),s.removeAddressFromBalanceCache(e)}catch{console.info("Unable to get balance cache for address",e)}},updateNativeBalanceCache(e){try{let t=s.getNativeBalanceCache();t[e.caipAddress]=e,i.mr.setItem(i.uJ.NATIVE_BALANCE_CACHE,JSON.stringify(t))}catch{console.info("Unable to update balance cache",e)}},getEnsCache(){let e={};try{let t=i.mr.getItem(i.uJ.ENS_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get ens name cache")}return e},getEnsFromCacheForAddress(e){try{let t=s.getEnsCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.ens))return t.ens;s.removeEnsFromCache(e)}catch{console.info("Unable to get ens name from cache",e)}},updateEnsCache(e){try{let t=s.getEnsCache();t[e.address]=e,i.mr.setItem(i.uJ.ENS_CACHE,JSON.stringify(t))}catch{console.info("Unable to update ens name cache",e)}},removeEnsFromCache(e){try{let t=s.getEnsCache();i.mr.setItem(i.uJ.ENS_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove ens name from cache",e)}},getIdentityCache(){let e={};try{let t=i.mr.getItem(i.uJ.IDENTITY_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get identity cache")}return e},getIdentityFromCacheForAddress(e){try{let t=s.getIdentityCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.identity))return t.identity;s.removeIdentityFromCache(e)}catch{console.info("Unable to get identity from cache",e)}},updateIdentityCache(e){try{let t=s.getIdentityCache();t[e.address]={identity:e.identity,timestamp:e.timestamp},i.mr.setItem(i.uJ.IDENTITY_CACHE,JSON.stringify(t))}catch{console.info("Unable to update identity cache",e)}},removeIdentityFromCache(e){try{let t=s.getIdentityCache();i.mr.setItem(i.uJ.IDENTITY_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove identity from cache",e)}},clearAddressCache(){try{i.mr.removeItem(i.uJ.PORTFOLIO_CACHE),i.mr.removeItem(i.uJ.NATIVE_BALANCE_CACHE),i.mr.removeItem(i.uJ.ENS_CACHE),i.mr.removeItem(i.uJ.IDENTITY_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(e){try{i.mr.setItem(i.uJ.PREFERRED_ACCOUNT_TYPES,JSON.stringify(e))}catch{console.info("Unable to set preferred account types",e)}},getPreferredAccountTypes(){try{let e=i.mr.getItem(i.uJ.PREFERRED_ACCOUNT_TYPES);if(!e)return{};return JSON.parse(e)}catch{console.info("Unable to get preferred account types")}return{}},setConnections(e,t){try{let r={...s.getConnections(),[t]:e};i.mr.setItem(i.uJ.CONNECTIONS,JSON.stringify(r))}catch(e){console.error("Unable to sync connections to storage",e)}},getConnections(){try{let e=i.mr.getItem(i.uJ.CONNECTIONS);if(!e)return{};return JSON.parse(e)}catch(e){return console.error("Unable to get connections from storage",e),{}}}}},37786:(e,t,r)=>{"use strict";r.d(t,{g:()=>u,P:()=>g});var i=r(43892),s=r(95502),n=r(39308),a=r(13847),o=r(24474);let c=Object.freeze({enabled:!0,events:[]}),l=new a.V({baseUrl:n.j.getAnalyticsUrl(),clientId:null}),h=(0,i.sj)({...c}),d={state:h,subscribeKey:(e,t)=>(0,s.VW)(h,e,t),async sendError(e,t){if(!h.enabled)return;let r=Date.now();if(h.events.filter(e=>r-new Date(e.properties.timestamp||"").getTime()<6e4).length>=5)return;let i={type:"error",event:t,properties:{errorType:e.name,errorMessage:e.message,stackTrace:e.stack,timestamp:new Date().toISOString()}};h.events.push(i);try{if("undefined"==typeof window)return;let{projectId:r,sdkType:i,sdkVersion:s}=o.OptionsController.state;await l.post({path:"/e",params:{projectId:r,st:i,sv:s||"html-wagmi-4.2.2"},body:{eventId:n.j.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:new Date().toISOString(),props:{type:"error",event:t,errorType:e.name,errorMessage:e.message,stackTrace:e.stack}}})}catch{}},enable(){h.enabled=!0},disable(){h.enabled=!1},clearEvents(){h.events=[]}};class u extends Error{constructor(e,t,r){super(e),this.name="AppKitError",this.category=t,this.originalError=r,Object.setPrototypeOf(this,u.prototype);let i=!1;if(r instanceof Error&&"string"==typeof r.stack&&r.stack){let e=r.stack,t=e.indexOf("\n");if(t>-1){let r=e.substring(t+1);this.stack=`${this.name}: ${this.message}
11
- ${r}`,i=!0}}i||(Error.captureStackTrace?Error.captureStackTrace(this,u):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function p(e,t){let r=e instanceof u?e:new u(e instanceof Error?e.message:String(e),t,e);throw d.sendError(r,r.category),r}function g(e,t="INTERNAL_SDK_ERROR"){let r={};return Object.keys(e).forEach(i=>{let s=e[i];if("function"==typeof s){let e=s;e="AsyncFunction"===s.constructor.name?async(...e)=>{try{return await s(...e)}catch(e){return p(e,t)}}:(...e)=>{try{return s(...e)}catch(e){return p(e,t)}},r[i]=e}else r[i]=s}),r}},41363:(e,t,r)=>{"use strict";r.d(t,{C:()=>p});var i=r(82324),s=r(24474),n=r(9302),a=r(36241),o=r(39308),c=r(31965),l=r(55254),h=r(21307),d=r(45487),u=r(74030);let p={getConnectorsByType(e,t,r){let{customWallets:i}=s.OptionsController.state,a=n.M.getRecentWallets(),o=u.J.filterOutDuplicateWallets(t),c=u.J.filterOutDuplicateWallets(r),l=e.filter(e=>"MULTI_CHAIN"===e.type),h=e.filter(e=>"ANNOUNCED"===e.type),d=e.filter(e=>"INJECTED"===e.type);return{custom:i,recent:a,external:e.filter(e=>"EXTERNAL"===e.type),multiChain:l,announced:h,injected:d,recommended:o,featured:c}},showConnector(e){let t=e.info?.rdns,r=!!t&&a.ApiController.state.excludedWallets.some(e=>!!e.rdns&&e.rdns===t),i=!!e.name&&a.ApiController.state.excludedWallets.some(t=>d.g.isLowerCaseMatch(t.name,e.name));return!("INJECTED"===e.type&&("Browser Wallet"===e.name&&(!o.j.isMobile()||o.j.isMobile()&&!t&&!c.ConnectionController.checkInstalled())||r||i))&&("ANNOUNCED"!==e.type&&"EXTERNAL"!==e.type||!r&&!i)},getIsConnectedWithWC:()=>Array.from(l.R.state.chains.values()).some(e=>h.ConnectorController.getConnectorId(e.namespace)===i.b.CONNECTOR_ID.WALLET_CONNECT),getConnectorTypeOrder({recommended:e,featured:t,custom:r,recent:i,announced:n,injected:a,multiChain:o,external:c,overriddenConnectors:l=s.OptionsController.state.features?.connectorTypeOrder??[]}){let h=p.getIsConnectedWithWC(),d=[{type:"walletConnect",isEnabled:s.OptionsController.state.enableWalletConnect&&!h},{type:"recent",isEnabled:i.length>0},{type:"injected",isEnabled:[...a,...n,...o].length>0},{type:"featured",isEnabled:t.length>0},{type:"custom",isEnabled:r&&r.length>0},{type:"external",isEnabled:c.length>0},{type:"recommended",isEnabled:e.length>0}].filter(e=>e.isEnabled),u=new Set(d.map(e=>e.type)),g=l.filter(e=>u.has(e)).map(e=>({type:e,isEnabled:!0})),f=d.filter(({type:e})=>!g.some(({type:t})=>t===e));return Array.from(new Set([...g,...f].map(({type:e})=>e)))}}},3379:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={ACCOUNT_TABS:[{label:"Tokens"},{label:"NFTs"},{label:"Activity"}],SECURE_SITE_ORIGIN:("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",VIEW_DIRECTION:{Next:"next",Prev:"prev"},DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"],ANIMATION_DURATIONS:{HeaderText:120,ModalHeight:150,ViewTransition:150}}},74030:(e,t,r)=>{"use strict";r.d(t,{J:()=>d});var i=r(24474),s=r(21307),n=r(9302),a=r(39308),o=r(36241),c=r(45487),l=r(41363),h=r(3379);let d={filterOutDuplicatesByRDNS(e){let t=i.OptionsController.state.enableEIP6963?s.ConnectorController.state.connectors:[],r=n.M.getRecentWallets(),o=t.map(e=>e.info?.rdns).filter(Boolean),c=r.map(e=>e.rdns).filter(Boolean),l=o.concat(c);if(l.includes("io.metamask.mobile")&&a.j.isMobile()){let e=l.indexOf("io.metamask.mobile");l[e]="io.metamask"}return e.filter(e=>!l.includes(String(e?.rdns)))},filterOutDuplicatesByIds(e){let t=s.ConnectorController.state.connectors.filter(e=>"ANNOUNCED"===e.type||"INJECTED"===e.type),r=n.M.getRecentWallets(),i=t.map(e=>e.explorerId),a=r.map(e=>e.id),o=i.concat(a);return e.filter(e=>!o.includes(e?.id))},filterOutDuplicateWallets(e){let t=this.filterOutDuplicatesByRDNS(e);return this.filterOutDuplicatesByIds(t)},markWalletsAsInstalled(e){let{connectors:t}=s.ConnectorController.state,{featuredWalletIds:r}=i.OptionsController.state,n=t.filter(e=>"ANNOUNCED"===e.type).reduce((e,t)=>(t.info?.rdns&&(e[t.info.rdns]=!0),e),{});return e.map(e=>({...e,installed:!!e.rdns&&!!n[e.rdns??""]})).sort((e,t)=>{let i=Number(t.installed)-Number(e.installed);if(0!==i)return i;if(r?.length){let i=r.indexOf(e.id),s=r.indexOf(t.id);if(-1!==i&&-1!==s)return i-s;if(-1!==i)return -1;if(-1!==s)return 1}return 0})},getConnectOrderMethod(e,t){let r=e?.connectMethodsOrder||i.OptionsController.state.features?.connectMethodsOrder,n=t||s.ConnectorController.state.connectors;if(r)return r;let{injected:a,announced:c}=l.C.getConnectorsByType(n,o.ApiController.state.recommended,o.ApiController.state.featured),d=a.filter(l.C.showConnector),u=c.filter(l.C.showConnector);return d.length||u.length?["wallet","email","social"]:h.b.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(e){let t=!!e.rdns&&o.ApiController.state.excludedWallets.some(t=>t.rdns===e.rdns),r=!!e.name&&o.ApiController.state.excludedWallets.some(t=>c.g.isLowerCaseMatch(t.name,e.name));return t||r}}},91592:(e,t,r)=>{"use strict";r.d(t,{Hg:()=>s.H,Mo:()=>h.M,n:()=>i.n,Hs:()=>i.Hs,R:()=>i.R});var i=r(6888),s=r(58004),n=r(24811),a=r(76676),o=r(48233),c=r(57209);n.extend(o),n.extend(c);let l={...a,name:"en-web3-modal",relativeTime:{future:"in %s",past:"%s ago",s:"%d sec",m:"1 min",mm:"%d min",h:"1 hr",hh:"%d hrs",d:"1 d",dd:"%d d",M:"1 mo",MM:"%d mo",y:"1 yr",yy:"%d yr"}};n.locale("en-web3-modal",l);var h=r(27420)},6888:(e,t,r)=>{"use strict";let i,s,n;r.d(t,{Bp:()=>g,ET:()=>u,Hs:()=>l,R:()=>h,ZM:()=>p,n:()=>c});var a=r(83722),o=r(75393);function c(e,t){i=document.createElement("style"),s=document.createElement("style"),n=document.createElement("style"),i.textContent=d(e).core.cssText,s.textContent=d(e).dark.cssText,n.textContent=d(e).light.cssText,document.head.appendChild(i),document.head.appendChild(s),document.head.appendChild(n),l(t)}function l(e){s&&n&&("light"===e?(s.removeAttribute("media"),n.media="enabled"):(n.removeAttribute("media"),s.media="enabled"))}function h(e){i&&s&&n&&(i.textContent=d(e).core.cssText,s.textContent=d(e).dark.cssText,n.textContent=d(e).light.cssText)}function d(e){return{core:(0,a.iv)`
10
+ Approved: ${s.toString()}`))}),a.forEach(e=>{i||(ea(s[e].methods,n[e].methods)?ea(s[e].events,n[e].events)||(i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces events don't satisfy namespace events for ${e}`)):i=iV("NON_CONFORMING_NAMESPACES",`${r} namespaces methods don't satisfy namespace methods for ${e}`))}),i}function i4(e){return[...new Set(e.map(e=>e.includes(":")?e.split(":")[0]:e))]}function i6(){let e=er();return new Promise(t=>{switch(e){case Z.browser:t(et()&&navigator?.onLine);break;case Z.reactNative:t(i9());break;case Z.node:default:t(!0)}})}async function i9(){if(ee()&&"u">typeof global&&null!=global&&global.NetInfo){let e=await (null==global?void 0:global.NetInfo.fetch());return e?.isConnected}return!0}let i7={};class se{static get(e){return i7[e]}static set(e,t){i7[e]=t}static delete(e){delete i7[e]}}var st=r(44926),sr=r(26560),si=r(76755);let ss="core",sn=`wc@2:${ss}:`,sa={logger:"error"},so={database:":memory:"},sc="client_ed25519_seed",sl=R.ONE_DAY,sh=R.SIX_HOURS,sd="wss://relay.walletconnect.org",su={message:"relayer_message",message_ack:"relayer_message_ack",connect:"relayer_connect",disconnect:"relayer_disconnect",error:"relayer_error",connection_stalled:"relayer_connection_stalled",publish:"relayer_publish"},sp={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},sg="2.21.0",sf={link_mode:"link_mode",relay:"relay"},sm={inbound:"inbound",outbound:"outbound"},sw="WALLETCONNECT_LINK_MODE_APPS",sy={created:"subscription_created",deleted:"subscription_deleted",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},sb=(R.FIVE_SECONDS,{wc_pairingDelete:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:R.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:R.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:R.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:R.ONE_DAY,prompt:!1,tag:0},res:{ttl:R.ONE_DAY,prompt:!1,tag:0}}}),sv={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},sC={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},sE={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},sN="https://verify.walletconnect.org",sI=`${sN}/v3`,sA=["https://verify.walletconnect.com",sN],s_={pairing_started:"pairing_started",pairing_uri_validation_success:"pairing_uri_validation_success",pairing_uri_not_expired:"pairing_uri_not_expired",store_new_pairing:"store_new_pairing",subscribing_pairing_topic:"subscribing_pairing_topic",subscribe_pairing_topic_success:"subscribe_pairing_topic_success",existing_pairing:"existing_pairing",pairing_not_expired:"pairing_not_expired",emit_inactive_pairing:"emit_inactive_pairing",emit_session_proposal:"emit_session_proposal"},sS={no_internet_connection:"no_internet_connection",malformed_pairing_uri:"malformed_pairing_uri",active_pairing_already_exists:"active_pairing_already_exists",subscribe_pairing_topic_failure:"subscribe_pairing_topic_failure",pairing_expired:"pairing_expired",proposal_listener_not_found:"proposal_listener_not_found"},sO={session_approve_started:"session_approve_started",session_namespaces_validation_success:"session_namespaces_validation_success",subscribing_session_topic:"subscribing_session_topic",subscribe_session_topic_success:"subscribe_session_topic_success",publishing_session_approve:"publishing_session_approve",session_approve_publish_success:"session_approve_publish_success",store_session:"store_session",publishing_session_settle:"publishing_session_settle",session_settle_publish_success:"session_settle_publish_success"},sP={no_internet_connection:"no_internet_connection",proposal_expired:"proposal_expired",subscribe_session_topic_failure:"subscribe_session_topic_failure",session_approve_publish_failure:"session_approve_publish_failure",session_settle_publish_failure:"session_settle_publish_failure",session_approve_namespace_validation_failure:"session_approve_namespace_validation_failure",proposal_not_found:"proposal_not_found"},sT={authenticated_session_approve_started:"authenticated_session_approve_started",create_authenticated_session_topic:"create_authenticated_session_topic",cacaos_verified:"cacaos_verified",store_authenticated_session:"store_authenticated_session",subscribing_authenticated_session_topic:"subscribing_authenticated_session_topic",subscribe_authenticated_session_topic_success:"subscribe_authenticated_session_topic_success",publishing_authenticated_session_approve:"publishing_authenticated_session_approve"},sR={no_internet_connection:"no_internet_connection",invalid_cacao:"invalid_cacao",subscribe_authenticated_session_topic_failure:"subscribe_authenticated_session_topic_failure",authenticated_session_approve_publish_failure:"authenticated_session_approve_publish_failure",authenticated_session_pending_request_not_found:"authenticated_session_pending_request_not_found"};var sk=function(e,t){if(e.length>=255)throw TypeError("Alphabet too long");for(var r=new Uint8Array(256),i=0;i<r.length;i++)r[i]=255;for(var s=0;s<e.length;s++){var n=e.charAt(s),a=n.charCodeAt(0);if(255!==r[a])throw TypeError(n+" is ambiguous");r[a]=s}var o=e.length,c=e.charAt(0),l=Math.log(o)/Math.log(256),h=Math.log(256)/Math.log(o);function d(e){if("string"!=typeof e)throw TypeError("Expected String");if(0===e.length)return new Uint8Array;var t=0;if(" "!==e[0]){for(var i=0,s=0;e[t]===c;)i++,t++;for(var n=(e.length-t)*l+1>>>0,a=new Uint8Array(n);e[t];){var h=r[e.charCodeAt(t)];if(255===h)return;for(var d=0,u=n-1;(0!==h||d<s)&&-1!==u;u--,d++)h+=o*a[u]>>>0,a[u]=h%256>>>0,h=h/256>>>0;if(0!==h)throw Error("Non-zero carry");s=d,t++}if(" "!==e[t]){for(var p=n-s;p!==n&&0===a[p];)p++;for(var g=new Uint8Array(i+(n-p)),f=i;p!==n;)g[f++]=a[p++];return g}}}return{encode:function(t){if(t instanceof Uint8Array||(ArrayBuffer.isView(t)?t=new Uint8Array(t.buffer,t.byteOffset,t.byteLength):Array.isArray(t)&&(t=Uint8Array.from(t))),!(t instanceof Uint8Array))throw TypeError("Expected Uint8Array");if(0===t.length)return"";for(var r=0,i=0,s=0,n=t.length;s!==n&&0===t[s];)s++,r++;for(var a=(n-s)*h+1>>>0,l=new Uint8Array(a);s!==n;){for(var d=t[s],u=0,p=a-1;(0!==d||u<i)&&-1!==p;p--,u++)d+=256*l[p]>>>0,l[p]=d%o>>>0,d=d/o>>>0;if(0!==d)throw Error("Non-zero carry");i=u,s++}for(var g=a-i;g!==a&&0===l[g];)g++;for(var f=c.repeat(r);g<a;++g)f+=e.charAt(l[g]);return f},decodeUnsafe:d,decode:function(e){var r=d(e);if(r)return r;throw Error(`Non-${t} character`)}}};let sx=e=>{if(e instanceof Uint8Array&&"Uint8Array"===e.constructor.name)return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw Error("Unknown type, must be binary type")},sU=e=>new TextEncoder().encode(e),sD=e=>new TextDecoder().decode(e);class s${constructor(e,t,r){this.name=e,this.prefix=t,this.baseEncode=r}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class sM{constructor(e,t,r){if(this.name=e,this.prefix=t,void 0===t.codePointAt(0))throw Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=r}decode(e){if("string"==typeof e){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}throw Error("Can only multibase decode strings")}or(e){return sj(this,e)}}class sL{constructor(e){this.decoders=e}or(e){return sj(this,e)}decode(e){let t=e[0],r=this.decoders[t];if(r)return r.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}let sj=(e,t)=>new sL({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}});class sq{constructor(e,t,r,i){this.name=e,this.prefix=t,this.baseEncode=r,this.baseDecode=i,this.encoder=new s$(e,t,r),this.decoder=new sM(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}let sB=({name:e,prefix:t,encode:r,decode:i})=>new sq(e,t,r,i),sF=({prefix:e,name:t,alphabet:r})=>{let{encode:i,decode:s}=sk(r,t);return sB({prefix:e,name:t,encode:i,decode:e=>sx(s(e))})},sH=(e,t,r,i)=>{let s={};for(let e=0;e<t.length;++e)s[t[e]]=e;let n=e.length;for(;"="===e[n-1];)--n;let a=new Uint8Array(n*r/8|0),o=0,c=0,l=0;for(let t=0;t<n;++t){let n=s[e[t]];if(void 0===n)throw SyntaxError(`Non-${i} character`);c=c<<r|n,(o+=r)>=8&&(o-=8,a[l++]=255&c>>o)}if(o>=r||255&c<<8-o)throw SyntaxError("Unexpected end of data");return a},sW=(e,t,r)=>{let i="="===t[t.length-1],s=(1<<r)-1,n="",a=0,o=0;for(let i=0;i<e.length;++i)for(o=o<<8|e[i],a+=8;a>r;)a-=r,n+=t[s&o>>a];if(a&&(n+=t[s&o<<r-a]),i)for(;n.length*r&7;)n+="=";return n},sV=({name:e,prefix:t,bitsPerChar:r,alphabet:i})=>sB({prefix:t,name:e,encode:e=>sW(e,i,r),decode:t=>sH(t,i,r,e)});var sz=Object.freeze({__proto__:null,identity:sB({prefix:"\0",name:"identity",encode:e=>sD(e),decode:e=>sU(e)})}),sK=Object.freeze({__proto__:null,base2:sV({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1})}),sJ=Object.freeze({__proto__:null,base8:sV({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3})}),sG=Object.freeze({__proto__:null,base10:sF({prefix:"9",name:"base10",alphabet:"0123456789"})}),sY=Object.freeze({__proto__:null,base16:sV({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),base16upper:sV({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4})});let sX=sV({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sZ=sV({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),sQ=sV({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),s0=sV({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),s1=sV({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),s2=sV({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5});var s5=Object.freeze({__proto__:null,base32:sX,base32upper:sZ,base32pad:sQ,base32padupper:s0,base32hex:s1,base32hexupper:s2,base32hexpad:sV({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),base32hexpadupper:sV({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),base32z:sV({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5})}),s3=Object.freeze({__proto__:null,base36:sF({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),base36upper:sF({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"})}),s8=Object.freeze({__proto__:null,base58btc:sF({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),base58flickr:sF({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"})});let s4=sV({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6});var s6=Object.freeze({__proto__:null,base64:s4,base64pad:sV({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),base64url:sV({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),base64urlpad:sV({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6})});let s9=Array.from("\uD83D\uDE80\uD83E\uDE90☄\uD83D\uDEF0\uD83C\uDF0C\uD83C\uDF11\uD83C\uDF12\uD83C\uDF13\uD83C\uDF14\uD83C\uDF15\uD83C\uDF16\uD83C\uDF17\uD83C\uDF18\uD83C\uDF0D\uD83C\uDF0F\uD83C\uDF0E\uD83D\uDC09☀\uD83D\uDCBB\uD83D\uDDA5\uD83D\uDCBE\uD83D\uDCBF\uD83D\uDE02❤\uD83D\uDE0D\uD83E\uDD23\uD83D\uDE0A\uD83D\uDE4F\uD83D\uDC95\uD83D\uDE2D\uD83D\uDE18\uD83D\uDC4D\uD83D\uDE05\uD83D\uDC4F\uD83D\uDE01\uD83D\uDD25\uD83E\uDD70\uD83D\uDC94\uD83D\uDC96\uD83D\uDC99\uD83D\uDE22\uD83E\uDD14\uD83D\uDE06\uD83D\uDE44\uD83D\uDCAA\uD83D\uDE09☺\uD83D\uDC4C\uD83E\uDD17\uD83D\uDC9C\uD83D\uDE14\uD83D\uDE0E\uD83D\uDE07\uD83C\uDF39\uD83E\uDD26\uD83C\uDF89\uD83D\uDC9E✌✨\uD83E\uDD37\uD83D\uDE31\uD83D\uDE0C\uD83C\uDF38\uD83D\uDE4C\uD83D\uDE0B\uD83D\uDC97\uD83D\uDC9A\uD83D\uDE0F\uD83D\uDC9B\uD83D\uDE42\uD83D\uDC93\uD83E\uDD29\uD83D\uDE04\uD83D\uDE00\uD83D\uDDA4\uD83D\uDE03\uD83D\uDCAF\uD83D\uDE48\uD83D\uDC47\uD83C\uDFB6\uD83D\uDE12\uD83E\uDD2D❣\uD83D\uDE1C\uD83D\uDC8B\uD83D\uDC40\uD83D\uDE2A\uD83D\uDE11\uD83D\uDCA5\uD83D\uDE4B\uD83D\uDE1E\uD83D\uDE29\uD83D\uDE21\uD83E\uDD2A\uD83D\uDC4A\uD83E\uDD73\uD83D\uDE25\uD83E\uDD24\uD83D\uDC49\uD83D\uDC83\uD83D\uDE33✋\uD83D\uDE1A\uD83D\uDE1D\uD83D\uDE34\uD83C\uDF1F\uD83D\uDE2C\uD83D\uDE43\uD83C\uDF40\uD83C\uDF37\uD83D\uDE3B\uD83D\uDE13⭐✅\uD83E\uDD7A\uD83C\uDF08\uD83D\uDE08\uD83E\uDD18\uD83D\uDCA6✔\uD83D\uDE23\uD83C\uDFC3\uD83D\uDC90☹\uD83C\uDF8A\uD83D\uDC98\uD83D\uDE20☝\uD83D\uDE15\uD83C\uDF3A\uD83C\uDF82\uD83C\uDF3B\uD83D\uDE10\uD83D\uDD95\uD83D\uDC9D\uD83D\uDE4A\uD83D\uDE39\uD83D\uDDE3\uD83D\uDCAB\uD83D\uDC80\uD83D\uDC51\uD83C\uDFB5\uD83E\uDD1E\uD83D\uDE1B\uD83D\uDD34\uD83D\uDE24\uD83C\uDF3C\uD83D\uDE2B⚽\uD83E\uDD19☕\uD83C\uDFC6\uD83E\uDD2B\uD83D\uDC48\uD83D\uDE2E\uD83D\uDE46\uD83C\uDF7B\uD83C\uDF43\uD83D\uDC36\uD83D\uDC81\uD83D\uDE32\uD83C\uDF3F\uD83E\uDDE1\uD83C\uDF81⚡\uD83C\uDF1E\uD83C\uDF88❌✊\uD83D\uDC4B\uD83D\uDE30\uD83E\uDD28\uD83D\uDE36\uD83E\uDD1D\uD83D\uDEB6\uD83D\uDCB0\uD83C\uDF53\uD83D\uDCA2\uD83E\uDD1F\uD83D\uDE41\uD83D\uDEA8\uD83D\uDCA8\uD83E\uDD2C✈\uD83C\uDF80\uD83C\uDF7A\uD83E\uDD13\uD83D\uDE19\uD83D\uDC9F\uD83C\uDF31\uD83D\uDE16\uD83D\uDC76\uD83E\uDD74▶➡❓\uD83D\uDC8E\uD83D\uDCB8⬇\uD83D\uDE28\uD83C\uDF1A\uD83E\uDD8B\uD83D\uDE37\uD83D\uDD7A⚠\uD83D\uDE45\uD83D\uDE1F\uD83D\uDE35\uD83D\uDC4E\uD83E\uDD32\uD83E\uDD20\uD83E\uDD27\uD83D\uDCCC\uD83D\uDD35\uD83D\uDC85\uD83E\uDDD0\uD83D\uDC3E\uD83C\uDF52\uD83D\uDE17\uD83E\uDD11\uD83C\uDF0A\uD83E\uDD2F\uD83D\uDC37☎\uD83D\uDCA7\uD83D\uDE2F\uD83D\uDC86\uD83D\uDC46\uD83C\uDFA4\uD83D\uDE47\uD83C\uDF51❄\uD83C\uDF34\uD83D\uDCA3\uD83D\uDC38\uD83D\uDC8C\uD83D\uDCCD\uD83E\uDD40\uD83E\uDD22\uD83D\uDC45\uD83D\uDCA1\uD83D\uDCA9\uD83D\uDC50\uD83D\uDCF8\uD83D\uDC7B\uD83E\uDD10\uD83E\uDD2E\uD83C\uDFBC\uD83E\uDD75\uD83D\uDEA9\uD83C\uDF4E\uD83C\uDF4A\uD83D\uDC7C\uD83D\uDC8D\uD83D\uDCE3\uD83E\uDD42"),s7=s9.reduce((e,t,r)=>(e[r]=t,e),[]),ne=s9.reduce((e,t,r)=>(e[t.codePointAt(0)]=r,e),[]);var nt=Object.freeze({__proto__:null,base256emoji:sB({prefix:"\uD83D\uDE80",name:"base256emoji",encode:function(e){return e.reduce((e,t)=>e+=s7[t],"")},decode:function(e){let t=[];for(let r of e){let e=ne[r.codePointAt(0)];if(void 0===e)throw Error(`Non-base256emoji character: ${r}`);t.push(e)}return new Uint8Array(t)}})});function nr(e,t){var r,i=0,t=t||0,s=0,n=t,a=e.length;do{if(n>=a)throw nr.bytes=0,RangeError("Could not decode varint");r=e[n++],i+=s<28?(127&r)<<s:(127&r)*Math.pow(2,s),s+=7}while(r>=128);return nr.bytes=n-t,i}var ni={encode:function e(t,r,i){r=r||[],i=i||0;for(var s=i;t>=2147483648;)r[i++]=255&t|128,t/=128;for(;-128&t;)r[i++]=255&t|128,t>>>=7;return r[i]=0|t,e.bytes=i-s+1,r},encodingLength:function(e){return e<128?1:e<16384?2:e<2097152?3:e<268435456?4:e<34359738368?5:e<4398046511104?6:e<562949953421312?7:e<72057594037927940?8:e<0x7fffffffffffffff?9:10}};let ns=(e,t,r=0)=>(ni.encode(e,t,r),t),nn=e=>ni.encodingLength(e),na=(e,t)=>{let r=t.byteLength,i=nn(e),s=i+nn(r),n=new Uint8Array(s+r);return ns(e,n,0),ns(r,n,i),n.set(t,s),new no(e,r,t,n)};class no{constructor(e,t,r,i){this.code=e,this.size=t,this.digest=r,this.bytes=i}}let nc=({name:e,code:t,encode:r})=>new nl(e,t,r);class nl{constructor(e,t,r){this.name=e,this.code=t,this.encode=r}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?na(this.code,t):t.then(e=>na(this.code,e))}throw Error("Unknown type, must be binary type")}}let nh=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t));var nd=Object.freeze({__proto__:null,sha256:nc({name:"sha2-256",code:18,encode:nh("SHA-256")}),sha512:nc({name:"sha2-512",code:19,encode:nh("SHA-512")})}),nu=Object.freeze({__proto__:null,identity:{code:0,name:"identity",encode:sx,digest:e=>na(0,sx(e))}});new TextEncoder,new TextDecoder;let np={...sz,...sK,...sJ,...sG,...sY,...s5,...s3,...s8,...s6,...nt};function ng(e,t,r,i){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:i}}}({...nd,...nu});let nf=ng("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),nm=ng("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{let t=function(e=0){return null!=globalThis.Buffer&&null!=globalThis.Buffer.allocUnsafe?globalThis.Buffer.allocUnsafe(e):new Uint8Array(e)}((e=e.substring(1)).length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),nw={utf8:nf,"utf-8":nf,hex:np.base16,latin1:nm,ascii:nm,binary:nm,...np};var ny=Object.defineProperty,nb=(e,t,r)=>t in e?ny(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nv=(e,t,r)=>nb(e,"symbol"!=typeof t?t+"":t,r);class nC{constructor(e,t){this.core=e,this.logger=t,nv(this,"keychain",new Map),nv(this,"name","keychain"),nv(this,"version","0.3"),nv(this,"initialized",!1),nv(this,"storagePrefix",sn),nv(this,"init",async()=>{if(!this.initialized){let e=await this.getKeyChain();"u">typeof e&&(this.keychain=e),this.initialized=!0}}),nv(this,"has",e=>(this.isInitialized(),this.keychain.has(e))),nv(this,"set",async(e,t)=>{this.isInitialized(),this.keychain.set(e,t),await this.persist()}),nv(this,"get",e=>{this.isInitialized();let t=this.keychain.get(e);if(typeof t>"u"){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}),nv(this,"del",async e=>{this.isInitialized(),this.keychain.delete(e),await this.persist()}),this.core=e,this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,eo(e))}async getKeyChain(){let e=await this.core.storage.getItem(this.storageKey);return"u">typeof e?ec(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var nE=Object.defineProperty,nN=(e,t,r)=>t in e?nE(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nI=(e,t,r)=>nN(e,"symbol"!=typeof t?t+"":t,r);class nA{constructor(e,t,r){this.core=e,this.logger=t,nI(this,"name","crypto"),nI(this,"keychain"),nI(this,"randomSessionIdentifier",iu()),nI(this,"initialized",!1),nI(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),nI(this,"hasKeys",e=>(this.isInitialized(),this.keychain.has(e))),nI(this,"getClientId",async()=>{this.isInitialized();let e=await this.getClientSeed(),t=x.Au(e);return x.bG(t.publicKey)}),nI(this,"generateKeyPair",()=>{this.isInitialized();let e=function(){let e=r8.utils.randomPrivateKey(),t=r8.getPublicKey(e);return{privateKey:(0,j.BB)(e,ic),publicKey:(0,j.BB)(t,ic)}}();return this.setPrivateKey(e.publicKey,e.privateKey)}),nI(this,"signJWT",async e=>{this.isInitialized();let t=await this.getClientSeed(),r=x.Au(t),i=this.randomSessionIdentifier;return await x.vf(i,e,sl,r)}),nI(this,"generateSharedKey",(e,t,r)=>{this.isInitialized();let i=function(e,t){let r=tQ(t8,r8.getSharedSecret((0,j.mL)(e,ic),(0,j.mL)(t,ic)),void 0,void 0,32);return(0,j.BB)(r,ic)}(this.getPrivateKey(e),t);return this.setSymKey(i,r)}),nI(this,"setSymKey",async(e,t)=>{this.isInitialized();let r=t||ip(e);return await this.keychain.set(r,e),r}),nI(this,"deleteKeyPair",async e=>{this.isInitialized(),await this.keychain.del(e)}),nI(this,"deleteSymKey",async e=>{this.isInitialized(),await this.keychain.del(e)}),nI(this,"encode",async(e,t,r)=>{this.isInitialized();let i=iE(r),s=(0,k.u)(t);if(2===i.type)return function(e,t){let r=im(2),i=eF(12),s=iv({type:r,sealed:(0,j.mL)(e,id),iv:i});return t===ih?iy(s):s}(s,r?.encoding);if(iN(i)){let t=i.senderPublicKey,r=i.receiverPublicKey;e=await this.generateSharedKey(t,r)}let n=this.getSymKey(e),{type:a,senderPublicKey:o}=i;return function(e){let t=im("u">typeof e.type?e.type:0);if(1===iw(t)&&typeof e.senderPublicKey>"u")throw Error("Missing sender public key for type 1 envelope");let r="u">typeof e.senderPublicKey?(0,j.mL)(e.senderPublicKey,ic):void 0,i="u">typeof e.iv?(0,j.mL)(e.iv,ic):eF(12),s=iv({type:t,sealed:tJ((0,j.mL)(e.symKey,ic),i).encrypt((0,j.mL)(e.message,id)),iv:i,senderPublicKey:r});return e.encoding===ih?iy(s):s}({type:a,symKey:n,message:s,senderPublicKey:o,encoding:r?.encoding})}),nI(this,"decode",async(e,t,r)=>{this.isInitialized();let i=function(e,t){let r=iC({encoded:e,encoding:t?.encoding});return iE({type:iw(r.type),senderPublicKey:"u">typeof r.senderPublicKey?(0,j.BB)(r.senderPublicKey,ic):void 0,receiverPublicKey:t?.receiverPublicKey})}(t,r);if(2===i.type){let e=function(e,t){let{sealed:r}=iC({encoded:e,encoding:t});return(0,j.BB)(r,id)}(t,r?.encoding);return(0,k.D)(e)}if(iN(i)){let t=i.receiverPublicKey,r=i.senderPublicKey;e=await this.generateSharedKey(t,r)}try{let i=this.getSymKey(e),s=function(e){let t=(0,j.mL)(e.symKey,ic),{sealed:r,iv:i}=iC({encoded:e.encoded,encoding:e.encoding}),s=tJ(t,i).decrypt(r);if(null===s)throw Error("Failed to decrypt");return(0,j.BB)(s,id)}({symKey:i,encoded:t,encoding:r?.encoding});return(0,k.D)(s)}catch(t){this.logger.error(`Failed to decode message from topic: '${e}', clientId: '${await this.getClientId()}'`),this.logger.error(t)}}),nI(this,"getPayloadType",(e,t=il)=>iw(iC({encoded:e,encoding:t}).type)),nI(this,"getPayloadSenderPublicKey",(e,t=il)=>{let r=iC({encoded:e,encoding:t});return r.senderPublicKey?(0,j.BB)(r.senderPublicKey,ic):void 0}),this.core=e,this.logger=(0,o.Ep)(t,this.name),this.keychain=r||new nC(this.core,this.logger)}get context(){return(0,o.Fd)(this.logger)}async setPrivateKey(e,t){return await this.keychain.set(e,t),e}getPrivateKey(e){return this.keychain.get(e)}async getClientSeed(){let e="";try{e=this.keychain.get(sc)}catch{e=iu(),await this.keychain.set(sc,e)}return function(e,t="utf8"){let r=nw[t];if(!r)throw Error(`Unsupported encoding "${t}"`);return("utf8"===t||"utf-8"===t)&&null!=globalThis.Buffer&&null!=globalThis.Buffer.from?globalThis.Buffer.from(e,"utf8"):r.decoder.decode(`${r.prefix}${e}`)}(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var n_=Object.defineProperty,nS=Object.defineProperties,nO=Object.getOwnPropertyDescriptors,nP=Object.getOwnPropertySymbols,nT=Object.prototype.hasOwnProperty,nR=Object.prototype.propertyIsEnumerable,nk=(e,t,r)=>t in e?n_(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nx=(e,t)=>{for(var r in t||(t={}))nT.call(t,r)&&nk(e,r,t[r]);if(nP)for(var r of nP(t))nR.call(t,r)&&nk(e,r,t[r]);return e},nU=(e,t)=>nS(e,nO(t)),nD=(e,t,r)=>nk(e,"symbol"!=typeof t?t+"":t,r);class n$ extends w{constructor(e,t){super(e,t),this.logger=e,this.core=t,nD(this,"messages",new Map),nD(this,"messagesWithoutClientAck",new Map),nD(this,"name","messages"),nD(this,"version","0.3"),nD(this,"initialized",!1),nD(this,"storagePrefix",sn),nD(this,"init",async()=>{if(!this.initialized){this.logger.trace("Initialized");try{let e=await this.getRelayerMessages();"u">typeof e&&(this.messages=e);let t=await this.getRelayerMessagesWithoutClientAck();"u">typeof t&&(this.messagesWithoutClientAck=t),this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",size:this.messages.size})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}finally{this.initialized=!0}}}),nD(this,"set",async(e,t,r)=>{this.isInitialized();let i=ig(t),s=this.messages.get(e);if(typeof s>"u"&&(s={}),"u">typeof s[i])return i;if(s[i]=t,this.messages.set(e,s),r===sm.inbound){let r=this.messagesWithoutClientAck.get(e)||{};this.messagesWithoutClientAck.set(e,nU(nx({},r),{[i]:t}))}return await this.persist(),i}),nD(this,"get",e=>{this.isInitialized();let t=this.messages.get(e);return typeof t>"u"&&(t={}),t}),nD(this,"getWithoutAck",e=>{this.isInitialized();let t={};for(let r of e){let e=this.messagesWithoutClientAck.get(r)||{};t[r]=Object.values(e)}return t}),nD(this,"has",(e,t)=>(this.isInitialized(),"u">typeof this.get(e)[ig(t)])),nD(this,"ack",async(e,t)=>{this.isInitialized();let r=this.messagesWithoutClientAck.get(e);if(typeof r>"u")return;let i=ig(t);delete r[i],0===Object.keys(r).length?this.messagesWithoutClientAck.delete(e):this.messagesWithoutClientAck.set(e,r),await this.persist()}),nD(this,"del",async e=>{this.isInitialized(),this.messages.delete(e),this.messagesWithoutClientAck.delete(e),await this.persist()}),this.logger=(0,o.Ep)(e,this.name),this.core=t}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get storageKeyWithoutClientAck(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name+"_withoutClientAck"}async setRelayerMessages(e){await this.core.storage.setItem(this.storageKey,eo(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,eo(e))}async getRelayerMessages(){let e=await this.core.storage.getItem(this.storageKey);return"u">typeof e?ec(e):void 0}async getRelayerMessagesWithoutClientAck(){let e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return"u">typeof e?ec(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var nM=Object.defineProperty,nL=Object.defineProperties,nj=Object.getOwnPropertyDescriptors,nq=Object.getOwnPropertySymbols,nB=Object.prototype.hasOwnProperty,nF=Object.prototype.propertyIsEnumerable,nH=(e,t,r)=>t in e?nM(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nW=(e,t)=>{for(var r in t||(t={}))nB.call(t,r)&&nH(e,r,t[r]);if(nq)for(var r of nq(t))nF.call(t,r)&&nH(e,r,t[r]);return e},nV=(e,t)=>nL(e,nj(t)),nz=(e,t,r)=>nH(e,"symbol"!=typeof t?t+"":t,r);class nK extends y{constructor(e,t){super(e,t),this.relayer=e,this.logger=t,nz(this,"events",new i.EventEmitter),nz(this,"name","publisher"),nz(this,"queue",new Map),nz(this,"publishTimeout",(0,R.toMiliseconds)(R.ONE_MINUTE)),nz(this,"initialPublishTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),nz(this,"needsTransportRestart",!1),nz(this,"publish",async(e,t,r)=>{var i;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:e,message:t,opts:r}});let s=r?.ttl||sh,n=iI(r),a=r?.prompt||!1,o=r?.tag||0,c=r?.id||(0,sr.getBigIntRpcId)().toString(),l={topic:e,message:t,opts:{ttl:s,relay:n,prompt:a,tag:o,id:c,attestation:r?.attestation,tvf:r?.tvf}},h=`Failed to publish payload, please try again. id:${c} tag:${o}`;try{let i=new Promise(async i=>{let n=({id:e})=>{l.opts.id===e&&(this.removeRequestFromQueue(e),this.relayer.events.removeListener(su.publish,n),i(l))};this.relayer.events.on(su.publish,n);let h=eh(new Promise((i,n)=>{this.rpcPublish({topic:e,message:t,ttl:s,prompt:a,tag:o,id:c,attestation:r?.attestation,tvf:r?.tvf}).then(i).catch(e=>{this.logger.warn(e,e?.message),n(e)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${c} tag:${o}`);try{await h,this.events.removeListener(su.publish,n)}catch(e){this.queue.set(c,nV(nW({},l),{attempt:1})),this.logger.warn(e,e?.message)}});this.logger.trace({type:"method",method:"publish",params:{id:c,topic:e,message:t,opts:r}}),await eh(i,this.publishTimeout,h)}catch(e){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(e),null!=(i=r?.internal)&&i.throwOnFailedPublish)throw e}finally{this.queue.delete(c)}}),nz(this,"on",(e,t)=>{this.events.on(e,t)}),nz(this,"once",(e,t)=>{this.events.once(e,t)}),nz(this,"off",(e,t)=>{this.events.off(e,t)}),nz(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.relayer=e,this.logger=(0,o.Ep)(t,this.name),this.registerEventListeners()}get context(){return(0,o.Fd)(this.logger)}async rpcPublish(e){var t,r,i,s;let{topic:n,message:a,ttl:o=sh,prompt:c,tag:l,id:h,attestation:d,tvf:u}=e,p={method:iA(iI().protocol).publish,params:nW({topic:n,message:a,ttl:o,prompt:c,tag:l,attestation:d},u),id:h};iG(null==(t=p.params)?void 0:t.prompt)&&(null==(r=p.params)||delete r.prompt),iG(null==(i=p.params)?void 0:i.tag)&&(null==(s=p.params)||delete s.tag),this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"message",direction:"outgoing",request:p});let g=await this.relayer.request(p);return this.relayer.events.emit(su.publish,e),this.logger.debug("Successfully Published Payload"),g}removeRequestFromQueue(e){this.queue.delete(e)}checkQueue(){this.queue.forEach(async(e,t)=>{let r=e.attempt+1;this.queue.set(t,nV(nW({},e),{attempt:r}));let{topic:i,message:s,opts:n,attestation:a}=e;this.logger.warn({},`Publisher: queue->publishing: ${e.opts.id}, tag: ${e.opts.tag}, attempt: ${r}`),await this.rpcPublish(nV(nW({},e),{topic:i,message:s,ttl:n.ttl,prompt:n.prompt,tag:n.tag,id:n.id,attestation:a,tvf:n.tvf})),this.logger.warn({},`Publisher: queue->published: ${e.opts.id}`)})}registerEventListeners(){this.relayer.core.heartbeat.on(n.Lx.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(su.connection_stalled);return}this.checkQueue()}),this.relayer.on(su.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var nJ=Object.defineProperty,nG=(e,t,r)=>t in e?nJ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,nY=(e,t,r)=>nG(e,"symbol"!=typeof t?t+"":t,r);class nX{constructor(){nY(this,"map",new Map),nY(this,"set",(e,t)=>{let r=this.get(e);this.exists(e,t)||this.map.set(e,[...r,t])}),nY(this,"get",e=>this.map.get(e)||[]),nY(this,"exists",(e,t)=>this.get(e).includes(t)),nY(this,"delete",(e,t)=>{if(typeof t>"u"){this.map.delete(e);return}if(!this.map.has(e))return;let r=this.get(e);if(!this.exists(e,t))return;let i=r.filter(e=>e!==t);if(!i.length){this.map.delete(e);return}this.map.set(e,i)}),nY(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var nZ=Object.defineProperty,nQ=Object.defineProperties,n0=Object.getOwnPropertyDescriptors,n1=Object.getOwnPropertySymbols,n2=Object.prototype.hasOwnProperty,n5=Object.prototype.propertyIsEnumerable,n3=(e,t,r)=>t in e?nZ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,n8=(e,t)=>{for(var r in t||(t={}))n2.call(t,r)&&n3(e,r,t[r]);if(n1)for(var r of n1(t))n5.call(t,r)&&n3(e,r,t[r]);return e},n4=(e,t)=>nQ(e,n0(t)),n6=(e,t,r)=>n3(e,"symbol"!=typeof t?t+"":t,r);class n9 extends C{constructor(e,t){super(e,t),this.relayer=e,this.logger=t,n6(this,"subscriptions",new Map),n6(this,"topicMap",new nX),n6(this,"events",new i.EventEmitter),n6(this,"name","subscription"),n6(this,"version","0.3"),n6(this,"pending",new Map),n6(this,"cached",[]),n6(this,"initialized",!1),n6(this,"storagePrefix",sn),n6(this,"subscribeTimeout",(0,R.toMiliseconds)(R.ONE_MINUTE)),n6(this,"initialSubscribeTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),n6(this,"clientId"),n6(this,"batchSubscribeTopicsLimit",500),n6(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),n6(this,"subscribe",async(e,t)=>{this.isInitialized(),this.logger.debug("Subscribing Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:e,opts:t}});try{let r=iI(t),i={topic:e,relay:r,transportType:t?.transportType};this.pending.set(e,i);let s=await this.rpcSubscribe(e,r,t);return"string"==typeof s&&(this.onSubscribe(s,i),this.logger.debug("Successfully Subscribed Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:e,opts:t}})),s}catch(e){throw this.logger.debug("Failed to Subscribe Topic"),this.logger.error(e),e}}),n6(this,"unsubscribe",async(e,t)=>{this.isInitialized(),"u">typeof t?.id?await this.unsubscribeById(e,t.id,t):await this.unsubscribeByTopic(e,t)}),n6(this,"isSubscribed",e=>new Promise(t=>{t(this.topicMap.topics.includes(e))})),n6(this,"isKnownTopic",e=>new Promise(t=>{t(this.topicMap.topics.includes(e)||this.pending.has(e)||this.cached.some(t=>t.topic===e))})),n6(this,"on",(e,t)=>{this.events.on(e,t)}),n6(this,"once",(e,t)=>{this.events.once(e,t)}),n6(this,"off",(e,t)=>{this.events.off(e,t)}),n6(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),n6(this,"start",async()=>{await this.onConnect()}),n6(this,"stop",async()=>{await this.onDisconnect()}),n6(this,"restart",async()=>{await this.restore(),await this.onRestart()}),n6(this,"checkPending",async()=>{if(0===this.pending.size&&(!this.initialized||!this.relayer.connected))return;let e=[];this.pending.forEach(t=>{e.push(t)}),await this.batchSubscribe(e)}),n6(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(n.Lx.pulse,async()=>{await this.checkPending()}),this.events.on(sy.created,async e=>{let t=sy.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),await this.persist()}),this.events.on(sy.deleted,async e=>{let t=sy.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),await this.persist()})}),this.relayer=e,this.logger=(0,o.Ep)(t,this.name),this.clientId=""}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.relayer.core.customStoragePrefix+"//"+this.name}get length(){return this.subscriptions.size}get ids(){return Array.from(this.subscriptions.keys())}get values(){return Array.from(this.subscriptions.values())}get topics(){return this.topicMap.topics}get hasAnyTopics(){return this.topicMap.topics.length>0||this.pending.size>0||this.cached.length>0||this.subscriptions.size>0}hasSubscription(e,t){let r=!1;try{r=this.getSubscription(e).topic===t}catch{}return r}reset(){this.cached=[],this.initialized=!0}onDisable(){this.values.length>0&&(this.cached=this.values),this.subscriptions.clear(),this.topicMap.clear()}async unsubscribeByTopic(e,t){let r=this.topicMap.get(e);await Promise.all(r.map(async r=>await this.unsubscribeById(e,r,t)))}async unsubscribeById(e,t,r){this.logger.debug("Unsubscribing Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:t,opts:r}});try{let i=iI(r);await this.restartToComplete({topic:e,id:t,relay:i}),await this.rpcUnsubscribe(e,t,i);let s=iz("USER_DISCONNECTED",`${this.name}, ${e}`);await this.onUnsubscribe(e,t,s),this.logger.debug("Successfully Unsubscribed Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:t,opts:r}})}catch(e){throw this.logger.debug("Failed to Unsubscribe Topic"),this.logger.error(e),e}}async rpcSubscribe(e,t,r){var i;r&&r?.transportType!==sf.relay||await this.restartToComplete({topic:e,id:e,relay:t});let s={method:iA(t.protocol).subscribe,params:{topic:e}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:s});let n=null==(i=r?.internal)?void 0:i.throwOnFailedPublish;try{let t=await this.getSubscriptionId(e);if(r?.transportType===sf.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(s).catch(e=>this.logger.warn(e))},(0,R.toMiliseconds)(R.ONE_SECOND)),t;let i=new Promise(async t=>{let r=i=>{i.topic===e&&(this.events.removeListener(sy.created,r),t(i.id))};this.events.on(sy.created,r);try{let i=await eh(new Promise((e,t)=>{this.relayer.request(s).catch(e=>{this.logger.warn(e,e?.message),t(e)}).then(e)}),this.initialSubscribeTimeout,`Subscribing to ${e} failed, please try again`);this.events.removeListener(sy.created,r),t(i)}catch{}}),a=await eh(i,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!a&&n)throw Error(`Subscribing to ${e} failed, please try again`);return a?t:null}catch(e){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(su.connection_stalled),n)throw e}return null}async rpcBatchSubscribe(e){if(!e.length)return;let t={method:iA(e[0].relay.protocol).batchSubscribe,params:{topics:e.map(e=>e.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:t});try{await await eh(new Promise(e=>{this.relayer.request(t).catch(e=>this.logger.warn(e)).then(e)}),this.subscribeTimeout,"rpcBatchSubscribe failed, please try again")}catch{this.relayer.events.emit(su.connection_stalled)}}async rpcBatchFetchMessages(e){let t;if(!e.length)return;let r={method:iA(e[0].relay.protocol).batchFetchMessages,params:{topics:e.map(e=>e.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:r});try{t=await await eh(new Promise((e,t)=>{this.relayer.request(r).catch(e=>{this.logger.warn(e),t(e)}).then(e)}),this.subscribeTimeout,"rpcBatchFetchMessages failed, please try again")}catch{this.relayer.events.emit(su.connection_stalled)}return t}rpcUnsubscribe(e,t,r){let i={method:iA(r.protocol).unsubscribe,params:{topic:e,id:t}};return this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:i}),this.relayer.request(i)}onSubscribe(e,t){this.setSubscription(e,n4(n8({},t),{id:e})),this.pending.delete(t.topic)}onBatchSubscribe(e){e.length&&e.forEach(e=>{this.setSubscription(e.id,n8({},e)),this.pending.delete(e.topic)})}async onUnsubscribe(e,t,r){this.events.removeAllListeners(t),this.hasSubscription(t,e)&&this.deleteSubscription(t,r),await this.relayer.messages.del(e)}async setRelayerSubscriptions(e){await this.relayer.core.storage.setItem(this.storageKey,e)}async getRelayerSubscriptions(){return await this.relayer.core.storage.getItem(this.storageKey)}setSubscription(e,t){this.logger.debug("Setting subscription"),this.logger.trace({type:"method",method:"setSubscription",id:e,subscription:t}),this.addSubscription(e,t)}addSubscription(e,t){this.subscriptions.set(e,n8({},t)),this.topicMap.set(t.topic,e),this.events.emit(sy.created,t)}getSubscription(e){this.logger.debug("Getting subscription"),this.logger.trace({type:"method",method:"getSubscription",id:e});let t=this.subscriptions.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}deleteSubscription(e,t){this.logger.debug("Deleting subscription"),this.logger.trace({type:"method",method:"deleteSubscription",id:e,reason:t});let r=this.getSubscription(e);this.subscriptions.delete(e),this.topicMap.delete(r.topic,e),this.events.emit(sy.deleted,n4(n8({},r),{reason:t}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(sy.sync)}async onRestart(){if(this.cached.length){let e=[...this.cached],t=Math.ceil(this.cached.length/this.batchSubscribeTopicsLimit);for(let r=0;r<t;r++){let t=e.splice(0,this.batchSubscribeTopicsLimit);await this.batchSubscribe(t)}}this.events.emit(sy.resubscribed)}async restore(){try{let e=await this.getRelayerSubscriptions();if(typeof e>"u"||!e.length)return;if(this.subscriptions.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),this.logger.error(`${this.name}: ${JSON.stringify(this.values)}`),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored subscriptions for ${this.name}`),this.logger.trace({type:"method",method:"restore",subscriptions:this.values})}catch(e){this.logger.debug(`Failed to Restore subscriptions for ${this.name}`),this.logger.error(e)}}async batchSubscribe(e){e.length&&(await this.rpcBatchSubscribe(e),this.onBatchSubscribe(await Promise.all(e.map(async e=>n4(n8({},e),{id:await this.getSubscriptionId(e.topic)})))))}async batchFetchMessages(e){var t;if(!e.length)return;this.logger.trace(`Fetching batch messages for ${e.length} subscriptions`);let r=await this.rpcBatchFetchMessages(e);r&&r.messages&&(await (t=(0,R.toMiliseconds)(R.ONE_SECOND),new Promise(e=>setTimeout(e,t))),await this.relayer.handleBatchMessageEvents(r.messages))}async onConnect(){await this.restart(),this.reset()}onDisconnect(){this.onDisable()}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async restartToComplete(e){this.relayer.connected||this.relayer.connecting||(this.cached.push(e),await this.relayer.transportOpen())}async getClientId(){return this.clientId||(this.clientId=await this.relayer.core.crypto.getClientId()),this.clientId}async getSubscriptionId(e){return ig(e+await this.getClientId())}}var n7=Object.defineProperty,ae=Object.getOwnPropertySymbols,at=Object.prototype.hasOwnProperty,ar=Object.prototype.propertyIsEnumerable,ai=(e,t,r)=>t in e?n7(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,as=(e,t)=>{for(var r in t||(t={}))at.call(t,r)&&ai(e,r,t[r]);if(ae)for(var r of ae(t))ar.call(t,r)&&ai(e,r,t[r]);return e},an=(e,t,r)=>ai(e,"symbol"!=typeof t?t+"":t,r);class aa extends b{constructor(e){super(e),an(this,"protocol","wc"),an(this,"version",2),an(this,"core"),an(this,"logger"),an(this,"events",new i.EventEmitter),an(this,"provider"),an(this,"messages"),an(this,"subscriber"),an(this,"publisher"),an(this,"name","relayer"),an(this,"transportExplicitlyClosed",!1),an(this,"initialized",!1),an(this,"connectionAttemptInProgress",!1),an(this,"relayUrl"),an(this,"projectId"),an(this,"packageName"),an(this,"bundleId"),an(this,"hasExperiencedNetworkDisruption",!1),an(this,"pingTimeout"),an(this,"heartBeatTimeout",(0,R.toMiliseconds)(R.THIRTY_SECONDS+R.FIVE_SECONDS)),an(this,"reconnectTimeout"),an(this,"connectPromise"),an(this,"reconnectInProgress",!1),an(this,"requestsInFlight",[]),an(this,"connectTimeout",(0,R.toMiliseconds)(15*R.ONE_SECOND)),an(this,"request",async e=>{var t,r;this.logger.debug("Publishing Request Payload");let i=e.id||(0,sr.getBigIntRpcId)().toString();await this.toEstablishConnection();try{this.logger.trace({id:i,method:e.method,topic:null==(t=e.params)?void 0:t.topic},"relayer.request - publishing...");let s=`${i}:${(null==(r=e.params)?void 0:r.tag)||""}`;this.requestsInFlight.push(s);let n=await this.provider.request(e);return this.requestsInFlight=this.requestsInFlight.filter(e=>e!==s),n}catch(e){throw this.logger.debug(`Failed to Publish Request: ${i}`),e}}),an(this,"resetPingTimeout",()=>{Q()&&(clearTimeout(this.pingTimeout),this.pingTimeout=setTimeout(()=>{var e,t,r,i;try{this.logger.debug({},"pingTimeout: Connection stalled, terminating..."),null==(i=null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.terminate)||i.call(r)}catch(e){this.logger.warn(e,e?.message)}},this.heartBeatTimeout))}),an(this,"onPayloadHandler",e=>{this.onProviderPayload(e),this.resetPingTimeout()}),an(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected \uD83D\uDEDC"),this.startPingTimeout(),this.events.emit(su.connect)}),an(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected \uD83D\uDED1"),this.requestsInFlight=[],this.onProviderDisconnect()}),an(this,"onProviderErrorHandler",e=>{this.logger.fatal(`Fatal socket error: ${e.message}`),this.events.emit(su.error,e),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),an(this,"registerProviderListeners",()=>{this.provider.on(sp.payload,this.onPayloadHandler),this.provider.on(sp.connect,this.onConnectHandler),this.provider.on(sp.disconnect,this.onDisconnectHandler),this.provider.on(sp.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger="u">typeof e.logger&&"string"!=typeof e.logger?(0,o.Ep)(e.logger,this.name):(0,o.gw)((0,o.jI)({level:e.logger||"error"})),this.messages=new n$(this.logger,e.core),this.subscriber=new n9(this,this.logger),this.publisher=new nK(this,this.logger),this.relayUrl=e?.relayUrl||sd,this.projectId=e.projectId,ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)&&(null==global?void 0:global.Platform.OS)==="android"?this.packageName=ei():ee()&&"u">typeof global&&"u">typeof(null==global?void 0:global.Platform)&&(null==global?void 0:global.Platform.OS)==="ios"&&(this.bundleId=ei()),this.provider={}}async init(){if(this.logger.trace("Initialized"),this.registerEventListeners(),await Promise.all([this.messages.init(),this.subscriber.init()]),this.initialized=!0,this.subscriber.hasAnyTopics)try{await this.transportOpen()}catch(e){this.logger.warn(e,e?.message)}}get context(){return(0,o.Fd)(this.logger)}get connected(){var e,t,r;return(null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.readyState)===1}get connecting(){var e,t,r;return(null==(r=null==(t=null==(e=this.provider)?void 0:e.connection)?void 0:t.socket)?void 0:r.readyState)===0||void 0!==this.connectPromise}async publish(e,t,r){this.isInitialized(),await this.publisher.publish(e,t,r),await this.recordMessageEvent({topic:e,message:t,publishedAt:Date.now(),transportType:sf.relay},sm.outbound)}async subscribe(e,t){var r,i,s;this.isInitialized(),null!=t&&t.transportType&&t?.transportType!=="relay"||await this.toEstablishConnection();let n=typeof(null==(r=t?.internal)?void 0:r.throwOnFailedPublish)>"u"||(null==(i=t?.internal)?void 0:i.throwOnFailedPublish),a=(null==(s=this.subscriber.topicMap.get(e))?void 0:s[0])||"",o,c=t=>{t.topic===e&&(this.subscriber.off(sy.created,c),o())};return await Promise.all([new Promise(e=>{o=e,this.subscriber.on(sy.created,c)}),new Promise(async(r,i)=>{a=await this.subscriber.subscribe(e,as({internal:{throwOnFailedPublish:n}},t)).catch(e=>{n&&i(e)})||a,r()})]),a}async unsubscribe(e,t){this.isInitialized(),await this.subscriber.unsubscribe(e,t)}on(e,t){this.events.on(e,t)}once(e,t){this.events.once(e,t)}off(e,t){this.events.off(e,t)}removeListener(e,t){this.events.removeListener(e,t)}async transportDisconnect(){this.provider.disconnect&&(this.hasExperiencedNetworkDisruption||this.connected)?await eh(this.provider.disconnect(),2e3,"provider.disconnect()").catch(()=>this.onProviderDisconnect()):this.onProviderDisconnect()}async transportClose(){this.transportExplicitlyClosed=!0,await this.transportDisconnect()}async transportOpen(e){if(!this.subscriber.hasAnyTopics){this.logger.warn("Starting WS connection skipped because the client has no topics to work with.");return}if(this.connectPromise?(this.logger.debug({},"Waiting for existing connection attempt to resolve..."),await this.connectPromise,this.logger.debug({},"Existing connection attempt resolved")):(this.connectPromise=new Promise(async(t,r)=>{await this.connect(e).then(t).catch(r).finally(()=>{this.connectPromise=void 0})}),await this.connectPromise),!this.connected)throw Error(`Couldn't establish socket connection to the relay server: ${this.relayUrl}`)}async restartTransport(e){this.logger.debug({},"Restarting transport..."),this.connectionAttemptInProgress||(this.relayUrl=e||this.relayUrl,await this.confirmOnlineStateOrThrow(),await this.transportClose(),await this.transportOpen())}async confirmOnlineStateOrThrow(){if(!await i6())throw Error("No internet connection detected. Please restart your network and try again.")}async handleBatchMessageEvents(e){if(e?.length===0){this.logger.trace("Batch message events is empty. Ignoring...");return}let t=e.sort((e,t)=>e.publishedAt-t.publishedAt);for(let e of(this.logger.debug(`Batch of ${t.length} message events sorted`),t))try{await this.onMessageEvent(e)}catch(e){this.logger.warn(e,"Error while processing batch message event: "+e?.message)}this.logger.trace(`Batch of ${t.length} message events processed`)}async onLinkMessageEvent(e,t){let{topic:r}=e;if(!t.sessionExists){let e=ep(R.FIVE_MINUTES);await this.core.pairing.pairings.set(r,{topic:r,expiry:e,relay:{protocol:"irn"},active:!1})}this.events.emit(su.message,e),await this.recordMessageEvent(e,sm.inbound)}async connect(e){await this.confirmOnlineStateOrThrow(),e&&e!==this.relayUrl&&(this.relayUrl=e,await this.transportDisconnect()),this.connectionAttemptInProgress=!0,this.transportExplicitlyClosed=!1;let t=1;for(;t<6;){try{if(this.transportExplicitlyClosed)break;this.logger.debug({},`Connecting to ${this.relayUrl}, attempt: ${t}...`),await this.createProvider(),await new Promise(async(e,t)=>{let r=()=>{t(Error("Connection interrupted while trying to subscribe"))};this.provider.once(sp.disconnect,r),await eh(new Promise((e,t)=>{this.provider.connect().then(e).catch(t)}),this.connectTimeout,`Socket stalled when trying to connect to ${this.relayUrl}`).catch(e=>{t(e)}).finally(()=>{this.provider.off(sp.disconnect,r),clearTimeout(this.reconnectTimeout)}),await new Promise(async(e,t)=>{let r=()=>{t(Error("Connection interrupted while trying to subscribe"))};this.provider.once(sp.disconnect,r),await this.subscriber.start().then(e).catch(t).finally(()=>{this.provider.off(sp.disconnect,r)})}),this.hasExperiencedNetworkDisruption=!1,e()})}catch(e){await this.subscriber.stop(),this.logger.warn({},e.message),this.hasExperiencedNetworkDisruption=!0}finally{this.connectionAttemptInProgress=!1}if(this.connected){this.logger.debug({},`Connected to ${this.relayUrl} successfully on attempt: ${t}`);break}await new Promise(e=>setTimeout(e,(0,R.toMiliseconds)(1*t))),t++}}startPingTimeout(){var e,t,r,i,s;if(Q())try{null!=(t=null==(e=this.provider)?void 0:e.connection)&&t.socket&&(null==(s=null==(i=null==(r=this.provider)?void 0:r.connection)?void 0:i.socket)||s.on("ping",()=>{this.resetPingTimeout()})),this.resetPingTimeout()}catch(e){this.logger.warn(e,e?.message)}}async createProvider(){this.provider.connection&&this.unregisterProviderListeners();let e=await this.core.crypto.signJWT(this.relayUrl);this.provider=new st.r(new si.Z(function({protocol:e,version:t,relayUrl:r,sdkVersion:i,auth:s,projectId:n,useOnCloseEvent:a,bundleId:o,packageName:c}){let l=r.split("?"),h=en(e,t,i),d=function(e,t){let r=new URLSearchParams(e);for(let e of Object.keys(t).sort())if(t.hasOwnProperty(e)){let i=t[e];void 0!==i&&r.set(e,i)}return r.toString()}(l[1]||"",{auth:s,ua:h,projectId:n,useOnCloseEvent:a||void 0,packageName:c||void 0,bundleId:o||void 0});return l[0]+"?"+d}({sdkVersion:sg,protocol:this.protocol,version:this.version,relayUrl:this.relayUrl,projectId:this.projectId,auth:e,useOnCloseEvent:!0,bundleId:this.bundleId,packageName:this.packageName}))),this.registerProviderListeners()}async recordMessageEvent(e,t){let{topic:r,message:i}=e;await this.messages.set(r,i,t)}async shouldIgnoreMessageEvent(e){let{topic:t,message:r}=e;if(!r||0===r.length)return this.logger.warn(`Ignoring invalid/empty message: ${r}`),!0;if(!await this.subscriber.isKnownTopic(t))return this.logger.warn(`Ignoring message for unknown topic ${t}`),!0;let i=this.messages.has(t,r);return i&&this.logger.warn(`Ignoring duplicate message: ${r}`),i}async onProviderPayload(e){if(this.logger.debug("Incoming Relay Payload"),this.logger.trace({type:"payload",direction:"incoming",payload:e}),(0,sr.isJsonRpcRequest)(e)){if(!e.method.endsWith("_subscription"))return;let t=e.params,{topic:r,message:i,publishedAt:s,attestation:n}=t.data,a={topic:r,message:i,publishedAt:s,transportType:sf.relay,attestation:n};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(as({type:"event",event:t.id},a)),this.events.emit(t.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else(0,sr.isJsonRpcResponse)(e)&&this.events.emit(su.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,sm.inbound),this.events.emit(su.message,e))}async acknowledgePayload(e){let t=(0,sr.formatJsonRpcResult)(e.id,!0);await this.provider.connection.send(t)}unregisterProviderListeners(){this.provider.off(sp.payload,this.onPayloadHandler),this.provider.off(sp.connect,this.onConnectHandler),this.provider.off(sp.disconnect,this.onDisconnectHandler),this.provider.off(sp.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await i6();(function(e){switch(er()){case Z.browser:!ee()&&et()&&(window.addEventListener("online",()=>e(!0)),window.addEventListener("offline",()=>e(!1)));break;case Z.reactNative:ee()&&"u">typeof global&&null!=global&&global.NetInfo&&global?.NetInfo.addEventListener(t=>e(t?.isConnected));case Z.node:}})(async t=>{e!==t&&(e=t,t?await this.transportOpen().catch(e=>this.logger.error(e,e?.message)):(this.hasExperiencedNetworkDisruption=!0,await this.transportDisconnect(),this.transportExplicitlyClosed=!1))}),this.core.heartbeat.on(n.Lx.pulse,async()=>{var e;if(!this.transportExplicitlyClosed&&!this.connected&&(!(et()&&(0,D.getDocument)())||(null==(e=(0,D.getDocument)())?void 0:e.visibilityState)==="visible"))try{await this.confirmOnlineStateOrThrow(),await this.transportOpen()}catch(e){this.logger.warn(e,e?.message)}})}async onProviderDisconnect(){clearTimeout(this.pingTimeout),this.events.emit(su.disconnect),this.connectionAttemptInProgress=!1,!this.reconnectInProgress&&(this.reconnectInProgress=!0,await this.subscriber.stop(),this.subscriber.hasAnyTopics&&(this.transportExplicitlyClosed||(this.reconnectTimeout=setTimeout(async()=>{await this.transportOpen().catch(e=>this.logger.error(e,e?.message)),this.reconnectTimeout=void 0,this.reconnectInProgress=!1},(0,R.toMiliseconds)(.1)))))}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async toEstablishConnection(){if(await this.confirmOnlineStateOrThrow(),!this.connected){if(this.connectPromise){await this.connectPromise;return}await this.connect()}}}function ao(){}function ac(e){if(!e||"object"!=typeof e)return!1;let t=Object.getPrototypeOf(e);return(null===t||t===Object.prototype||null===Object.getPrototypeOf(t))&&"[object Object]"===Object.prototype.toString.call(e)}function al(e){return Object.getOwnPropertySymbols(e).filter(t=>Object.prototype.propertyIsEnumerable.call(e,t))}function ah(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":Object.prototype.toString.call(e)}let ad="[object Arguments]",au="[object Object]";var ap=Object.defineProperty,ag=Object.getOwnPropertySymbols,af=Object.prototype.hasOwnProperty,am=Object.prototype.propertyIsEnumerable,aw=(e,t,r)=>t in e?ap(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,ay=(e,t)=>{for(var r in t||(t={}))af.call(t,r)&&aw(e,r,t[r]);if(ag)for(var r of ag(t))am.call(t,r)&&aw(e,r,t[r]);return e},ab=(e,t,r)=>aw(e,"symbol"!=typeof t?t+"":t,r);class av extends v{constructor(e,t,r,i=sn,s){super(e,t,r,i),this.core=e,this.logger=t,this.name=r,ab(this,"map",new Map),ab(this,"version","0.3"),ab(this,"cached",[]),ab(this,"initialized",!1),ab(this,"getKey"),ab(this,"storagePrefix",sn),ab(this,"recentlyDeleted",[]),ab(this,"recentlyDeletedLimit",200),ab(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>{this.getKey&&null!==e&&!iG(e)?this.map.set(this.getKey(e),e):function(e){var t;return null==(t=e?.proposer)?void 0:t.publicKey}(e)?this.map.set(e.id,e):e?.topic&&this.map.set(e.topic,e)}),this.cached=[],this.initialized=!0)}),ab(this,"set",async(e,t)=>{this.isInitialized(),this.map.has(e)?await this.update(e,t):(this.logger.debug("Setting value"),this.logger.trace({type:"method",method:"set",key:e,value:t}),this.map.set(e,t),await this.persist())}),ab(this,"get",e=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:e}),this.getData(e))),ab(this,"getAll",e=>(this.isInitialized(),e?this.values.filter(t=>Object.keys(e).every(r=>(function e(t,r,i,s,n,a,o){let c=o(t,r,i,s,n,a);if(void 0!==c)return c;if(typeof t==typeof r)switch(typeof t){case"bigint":case"string":case"boolean":case"symbol":case"undefined":case"function":return t===r;case"number":return t===r||Object.is(t,r)}return function t(r,i,s,n){if(Object.is(r,i))return!0;let a=ah(r),o=ah(i);if(a===ad&&(a=au),o===ad&&(o=au),a!==o)return!1;switch(a){case"[object String]":return r.toString()===i.toString();case"[object Number]":{let e=r.valueOf(),t=i.valueOf();return e===t||Number.isNaN(e)&&Number.isNaN(t)}case"[object Boolean]":case"[object Date]":case"[object Symbol]":return Object.is(r.valueOf(),i.valueOf());case"[object RegExp]":return r.source===i.source&&r.flags===i.flags;case"[object Function]":return r===i}let c=(s=s??new Map).get(r),l=s.get(i);if(null!=c&&null!=l)return c===i;s.set(r,i),s.set(i,r);try{switch(a){case"[object Map]":if(r.size!==i.size)return!1;for(let[t,a]of r.entries())if(!i.has(t)||!e(a,i.get(t),t,r,i,s,n))return!1;return!0;case"[object Set]":{if(r.size!==i.size)return!1;let t=Array.from(r.values()),a=Array.from(i.values());for(let o=0;o<t.length;o++){let c=t[o],l=a.findIndex(t=>e(c,t,void 0,r,i,s,n));if(-1===l)return!1;a.splice(l,1)}return!0}case"[object Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":case"[object BigUint64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object BigInt64Array]":case"[object Float32Array]":case"[object Float64Array]":if("u">typeof Buffer&&Buffer.isBuffer(r)!==Buffer.isBuffer(i)||r.length!==i.length)return!1;for(let t=0;t<r.length;t++)if(!e(r[t],i[t],t,r,i,s,n))return!1;return!0;case"[object ArrayBuffer]":return r.byteLength===i.byteLength&&t(new Uint8Array(r),new Uint8Array(i),s,n);case"[object DataView]":return r.byteLength===i.byteLength&&r.byteOffset===i.byteOffset&&t(new Uint8Array(r),new Uint8Array(i),s,n);case"[object Error]":return r.name===i.name&&r.message===i.message;case au:{if(!(t(r.constructor,i.constructor,s,n)||ac(r)&&ac(i)))return!1;let a=[...Object.keys(r),...al(r)],o=[...Object.keys(i),...al(i)];if(a.length!==o.length)return!1;for(let t=0;t<a.length;t++){let o=a[t],c=r[o];if(!Object.hasOwn(i,o))return!1;let l=i[o];if(!e(c,l,o,r,i,s,n))return!1}return!0}default:return!1}}finally{s.delete(r),s.delete(i)}}(t,r,a,o)})(t[r],e[r],void 0,void 0,void 0,void 0,ao))):this.values)),ab(this,"update",async(e,t)=>{this.isInitialized(),this.logger.debug("Updating value"),this.logger.trace({type:"method",method:"update",key:e,update:t});let r=ay(ay({},this.getData(e)),t);this.map.set(e,r),await this.persist()}),ab(this,"delete",async(e,t)=>{this.isInitialized(),this.map.has(e)&&(this.logger.debug("Deleting value"),this.logger.trace({type:"method",method:"delete",key:e,reason:t}),this.map.delete(e),this.addToRecentlyDeleted(e),await this.persist())}),this.logger=(0,o.Ep)(t,this.name),this.storagePrefix=i,this.getKey=s}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.map.size}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}addToRecentlyDeleted(e){this.recentlyDeleted.push(e),this.recentlyDeleted.length>=this.recentlyDeletedLimit&&this.recentlyDeleted.splice(0,this.recentlyDeletedLimit/2)}async setDataStore(e){await this.core.storage.setItem(this.storageKey,e)}async getDataStore(){return await this.core.storage.getItem(this.storageKey)}getData(e){let t=this.map.get(e);if(!t){if(this.recentlyDeleted.includes(e)){let{message:t}=iV("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(t),Error(t)}let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.error(t),Error(t)}return t}async persist(){await this.setDataStore(this.values)}async restore(){try{let e=await this.getDataStore();if(typeof e>"u"||!e.length)return;if(this.map.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored value for ${this.name}`),this.logger.trace({type:"method",method:"restore",value:this.values})}catch(e){this.logger.debug(`Failed to Restore value for ${this.name}`),this.logger.error(e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var aC=Object.defineProperty,aE=(e,t,r)=>t in e?aC(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aN=(e,t,r)=>aE(e,"symbol"!=typeof t?t+"":t,r);class aI{constructor(e,t){this.core=e,this.logger=t,aN(this,"name","pairing"),aN(this,"version","0.3"),aN(this,"events",new(s())),aN(this,"pairings"),aN(this,"initialized",!1),aN(this,"storagePrefix",sn),aN(this,"ignoredPayloadTypes",[1]),aN(this,"registeredMethods",[]),aN(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),aN(this,"register",({methods:e})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...e])]}),aN(this,"create",async e=>{this.isInitialized();let t=iu(),r=await this.core.crypto.setSymKey(t),i=ep(R.FIVE_MINUTES),s={protocol:"irn"},n={topic:r,expiry:i,relay:s,active:!1,methods:e?.methods},a=iS({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:t,relay:s,expiryTimestamp:i,methods:e?.methods});return this.events.emit(sv.create,n),this.core.expirer.set(r,i),await this.pairings.set(r,n),await this.core.relayer.subscribe(r,{transportType:e?.transportType}),{topic:r,uri:a}}),aN(this,"pair",async e=>{let t;this.isInitialized();let r=this.core.eventClient.createEvent({properties:{topic:e?.uri,trace:[s_.pairing_started]}});this.isValidPair(e,r);let{topic:i,symKey:s,relay:n,expiryTimestamp:a,methods:o}=i_(e.uri);if(r.props.properties.topic=i,r.addTrace(s_.pairing_uri_validation_success),r.addTrace(s_.pairing_uri_not_expired),this.pairings.keys.includes(i)){if(t=this.pairings.get(i),r.addTrace(s_.existing_pairing),t.active)throw r.setError(sS.active_pairing_already_exists),Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(s_.pairing_not_expired)}let c=a||ep(R.FIVE_MINUTES),l={topic:i,relay:n,expiry:c,active:!1,methods:o};this.core.expirer.set(i,c),await this.pairings.set(i,l),r.addTrace(s_.store_new_pairing),e.activatePairing&&await this.activate({topic:i}),this.events.emit(sv.create,l),r.addTrace(s_.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(s,i),r.addTrace(s_.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(sS.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:n})}catch(e){throw r.setError(sS.subscribe_pairing_topic_failure),e}return r.addTrace(s_.subscribe_pairing_topic_success),l}),aN(this,"activate",async({topic:e})=>{this.isInitialized();let t=ep(R.FIVE_MINUTES);this.core.expirer.set(e,t),await this.pairings.update(e,{active:!0,expiry:t})}),aN(this,"ping",async e=>{this.isInitialized(),await this.isValidPing(e),this.logger.warn("ping() is deprecated and will be removed in the next major release.");let{topic:t}=e;if(this.pairings.keys.includes(t)){let e=await this.sendRequest(t,"wc_pairingPing",{}),{done:r,resolve:i,reject:s}=el();this.events.once(ef("pairing_ping",e),({error:e})=>{e?s(e):i()}),await r()}}),aN(this,"updateExpiry",async({topic:e,expiry:t})=>{this.isInitialized(),await this.pairings.update(e,{expiry:t})}),aN(this,"updateMetadata",async({topic:e,metadata:t})=>{this.isInitialized(),await this.pairings.update(e,{peerMetadata:t})}),aN(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),aN(this,"disconnect",async e=>{this.isInitialized(),await this.isValidDisconnect(e);let{topic:t}=e;this.pairings.keys.includes(t)&&(await this.sendRequest(t,"wc_pairingDelete",iz("USER_DISCONNECTED")),await this.deletePairing(t))}),aN(this,"formatUriFromPairing",e=>{this.isInitialized();let{topic:t,relay:r,expiry:i,methods:s}=e,n=this.core.crypto.keychain.get(t);return iS({protocol:this.core.protocol,version:this.core.version,topic:t,symKey:n,relay:r,expiryTimestamp:i,methods:s})}),aN(this,"sendRequest",async(e,t,r)=>{let i=(0,sr.formatJsonRpcRequest)(t,r),s=await this.core.crypto.encode(e,i),n=sb[t].req;return this.core.history.set(e,i),this.core.relayer.publish(e,s,n),i.id}),aN(this,"sendResult",async(e,t,r)=>{let i=(0,sr.formatJsonRpcResult)(e,r),s=await this.core.crypto.encode(t,i),n=sb[(await this.core.history.get(t,e)).request.method].res;await this.core.relayer.publish(t,s,n),await this.core.history.resolve(i)}),aN(this,"sendError",async(e,t,r)=>{let i=(0,sr.formatJsonRpcError)(e,r),s=await this.core.crypto.encode(t,i),n=(await this.core.history.get(t,e)).request.method,a=sb[n]?sb[n].res:sb.unregistered_method.res;await this.core.relayer.publish(t,s,a),await this.core.history.resolve(i)}),aN(this,"deletePairing",async(e,t)=>{await this.core.relayer.unsubscribe(e),await Promise.all([this.pairings.delete(e,iz("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(e),t?Promise.resolve():this.core.expirer.del(e)])}),aN(this,"cleanup",async()=>{let e=this.pairings.getAll().filter(e=>eg(e.expiry));await Promise.all(e.map(e=>this.deletePairing(e.topic)))}),aN(this,"onRelayEventRequest",async e=>{let{topic:t,payload:r}=e;switch(r.method){case"wc_pairingPing":return await this.onPairingPingRequest(t,r);case"wc_pairingDelete":return await this.onPairingDeleteRequest(t,r);default:return await this.onUnknownRpcMethodRequest(t,r)}}),aN(this,"onRelayEventResponse",async e=>{let{topic:t,payload:r}=e,i=(await this.core.history.get(t,r.id)).request.method;return"wc_pairingPing"===i?this.onPairingPingResponse(t,r):this.onUnknownRpcMethodResponse(i)}),aN(this,"onPairingPingRequest",async(e,t)=>{let{id:r}=t;try{this.isValidPing({topic:e}),await this.sendResult(r,e,!0),this.events.emit(sv.ping,{id:r,topic:e})}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onPairingPingResponse",(e,t)=>{let{id:r}=t;setTimeout(()=>{(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("pairing_ping",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("pairing_ping",r),{error:t.error})},500)}),aN(this,"onPairingDeleteRequest",async(e,t)=>{let{id:r}=t;try{this.isValidDisconnect({topic:e}),await this.deletePairing(e),this.events.emit(sv.delete,{id:r,topic:e})}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onUnknownRpcMethodRequest",async(e,t)=>{let{id:r,method:i}=t;try{if(this.registeredMethods.includes(i))return;let t=iz("WC_METHOD_UNSUPPORTED",i);await this.sendError(r,e,t),this.logger.error(t)}catch(t){await this.sendError(r,e,t),this.logger.error(t)}}),aN(this,"onUnknownRpcMethodResponse",e=>{this.registeredMethods.includes(e)||this.logger.error(iz("WC_METHOD_UNSUPPORTED",e))}),aN(this,"isValidPair",(e,t)=>{var r;if(!i5(e)){let{message:r}=iV("MISSING_OR_INVALID",`pair() params: ${e}`);throw t.setError(sS.malformed_pairing_uri),Error(r)}if(!function(e){function t(e){try{return"u">typeof new URL(e)}catch{return!1}}try{if(iY(e,!1)){if(t(e))return!0;let r=eE(e);return t(r)}}catch{}return!1}(e.uri)){let{message:r}=iV("MISSING_OR_INVALID",`pair() uri: ${e.uri}`);throw t.setError(sS.malformed_pairing_uri),Error(r)}let i=i_(e?.uri);if(!(null!=(r=i?.relay)&&r.protocol)){let{message:e}=iV("MISSING_OR_INVALID","pair() uri#relay-protocol");throw t.setError(sS.malformed_pairing_uri),Error(e)}if(!(null!=i&&i.symKey)){let{message:e}=iV("MISSING_OR_INVALID","pair() uri#symKey");throw t.setError(sS.malformed_pairing_uri),Error(e)}if(null!=i&&i.expiryTimestamp&&(0,R.toMiliseconds)(i?.expiryTimestamp)<Date.now()){t.setError(sS.pairing_expired);let{message:e}=iV("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw Error(e)}}),aN(this,"isValidPing",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`ping() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidPairingTopic(t)}),aN(this,"isValidDisconnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`disconnect() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidPairingTopic(t)}),aN(this,"isValidPairingTopic",async e=>{if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw Error(t)}if(!this.pairings.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.pairings.get(e).expiry)){await this.deletePairing(e);let{message:t}=iV("EXPIRED",`pairing topic: ${e}`);throw Error(t)}}),this.core=e,this.logger=(0,o.Ep)(t,this.name),this.pairings=new av(this.core,this.logger,this.name,this.storagePrefix)}get context(){return(0,o.Fd)(this.logger)}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}registerRelayerEvents(){this.core.relayer.on(su.message,async e=>{let{topic:t,message:r,transportType:i}=e;if(this.pairings.keys.includes(t)&&i!==sf.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(r)))try{let e=await this.core.crypto.decode(t,r);(0,sr.isJsonRpcRequest)(e)?(this.core.history.set(t,e),await this.onRelayEventRequest({topic:t,payload:e})):(0,sr.isJsonRpcResponse)(e)&&(await this.core.history.resolve(e),await this.onRelayEventResponse({topic:t,payload:e}),this.core.history.delete(t,e.id)),await this.core.relayer.messages.ack(t,r)}catch(e){this.logger.error(e)}})}registerExpirerEvents(){this.core.expirer.on(sE.expired,async e=>{let{topic:t}=eu(e.target);t&&this.pairings.keys.includes(t)&&(await this.deletePairing(t,!0),this.events.emit(sv.expire,{topic:t}))})}}var aA=Object.defineProperty,a_=(e,t,r)=>t in e?aA(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aS=(e,t,r)=>a_(e,"symbol"!=typeof t?t+"":t,r);class aO extends m{constructor(e,t){super(e,t),this.core=e,this.logger=t,aS(this,"records",new Map),aS(this,"events",new i.EventEmitter),aS(this,"name","history"),aS(this,"version","0.3"),aS(this,"cached",[]),aS(this,"initialized",!1),aS(this,"storagePrefix",sn),aS(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>this.records.set(e.id,e)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),aS(this,"set",(e,t,r)=>{if(this.isInitialized(),this.logger.debug("Setting JSON-RPC request history record"),this.logger.trace({type:"method",method:"set",topic:e,request:t,chainId:r}),this.records.has(t.id))return;let i={id:t.id,topic:e,request:{method:t.method,params:t.params||null},chainId:r,expiry:ep(R.THIRTY_DAYS)};this.records.set(i.id,i),this.persist(),this.events.emit(sC.created,i)}),aS(this,"resolve",async e=>{if(this.isInitialized(),this.logger.debug("Updating JSON-RPC response history record"),this.logger.trace({type:"method",method:"update",response:e}),!this.records.has(e.id))return;let t=await this.getRecord(e.id);typeof t.response>"u"&&(t.response=(0,sr.isJsonRpcError)(e)?{error:e.error}:{result:e.result},this.records.set(t.id,t),this.persist(),this.events.emit(sC.updated,t))}),aS(this,"get",async(e,t)=>(this.isInitialized(),this.logger.debug("Getting record"),this.logger.trace({type:"method",method:"get",topic:e,id:t}),await this.getRecord(t))),aS(this,"delete",(e,t)=>{this.isInitialized(),this.logger.debug("Deleting record"),this.logger.trace({type:"method",method:"delete",id:t}),this.values.forEach(r=>{r.topic!==e||"u">typeof t&&r.id!==t||(this.records.delete(r.id),this.events.emit(sC.deleted,r))}),this.persist()}),aS(this,"exists",async(e,t)=>(this.isInitialized(),!!this.records.has(t)&&(await this.getRecord(t)).topic===e)),aS(this,"on",(e,t)=>{this.events.on(e,t)}),aS(this,"once",(e,t)=>{this.events.once(e,t)}),aS(this,"off",(e,t)=>{this.events.off(e,t)}),aS(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get size(){return this.records.size}get keys(){return Array.from(this.records.keys())}get values(){return Array.from(this.records.values())}get pending(){let e=[];return this.values.forEach(t=>{if("u">typeof t.response)return;let r={topic:t.topic,request:(0,sr.formatJsonRpcRequest)(t.request.method,t.request.params,t.id),chainId:t.chainId};return e.push(r)}),e}async setJsonRpcRecords(e){await this.core.storage.setItem(this.storageKey,e)}async getJsonRpcRecords(){return await this.core.storage.getItem(this.storageKey)}getRecord(e){this.isInitialized();let t=this.records.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw Error(t)}return t}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(sC.sync)}async restore(){try{let e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",records:this.values})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}}registerEventListeners(){this.events.on(sC.created,e=>{let t=sC.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.events.on(sC.updated,e=>{let t=sC.updated;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.events.on(sC.deleted,e=>{let t=sC.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,record:e})}),this.core.heartbeat.on(n.Lx.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(t=>{(0,R.toMiliseconds)(t.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${t.id}`),this.records.delete(t.id),this.events.emit(sC.deleted,t,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var aP=Object.defineProperty,aT=(e,t,r)=>t in e?aP(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aR=(e,t,r)=>aT(e,"symbol"!=typeof t?t+"":t,r);class ak extends E{constructor(e,t){super(e,t),this.core=e,this.logger=t,aR(this,"expirations",new Map),aR(this,"events",new i.EventEmitter),aR(this,"name","expirer"),aR(this,"version","0.3"),aR(this,"cached",[]),aR(this,"initialized",!1),aR(this,"storagePrefix",sn),aR(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(e=>this.expirations.set(e.target,e)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),aR(this,"has",e=>{try{let t=this.formatTarget(e);return"u">typeof this.getExpiration(t)}catch{return!1}}),aR(this,"set",(e,t)=>{this.isInitialized();let r=this.formatTarget(e),i={target:r,expiry:t};this.expirations.set(r,i),this.checkExpiry(r,i),this.events.emit(sE.created,{target:r,expiration:i})}),aR(this,"get",e=>{this.isInitialized();let t=this.formatTarget(e);return this.getExpiration(t)}),aR(this,"del",e=>{if(this.isInitialized(),this.has(e)){let t=this.formatTarget(e),r=this.getExpiration(t);this.expirations.delete(t),this.events.emit(sE.deleted,{target:t,expiration:r})}}),aR(this,"on",(e,t)=>{this.events.on(e,t)}),aR(this,"once",(e,t)=>{this.events.once(e,t)}),aR(this,"off",(e,t)=>{this.events.off(e,t)}),aR(this,"removeListener",(e,t)=>{this.events.removeListener(e,t)}),this.logger=(0,o.Ep)(t,this.name)}get context(){return(0,o.Fd)(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.expirations.size}get keys(){return Array.from(this.expirations.keys())}get values(){return Array.from(this.expirations.values())}formatTarget(e){if("string"==typeof e)return ed("topic",e);if("number"==typeof e)return ed("id",e);let{message:t}=iV("UNKNOWN_TYPE",`Target type: ${typeof e}`);throw Error(t)}async setExpirations(e){await this.core.storage.setItem(this.storageKey,e)}async getExpirations(){return await this.core.storage.getItem(this.storageKey)}async persist(){await this.setExpirations(this.values),this.events.emit(sE.sync)}async restore(){try{let e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){let{message:e}=iV("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(e),Error(e)}this.cached=e,this.logger.debug(`Successfully Restored expirations for ${this.name}`),this.logger.trace({type:"method",method:"restore",expirations:this.values})}catch(e){this.logger.debug(`Failed to Restore expirations for ${this.name}`),this.logger.error(e)}}getExpiration(e){let t=this.expirations.get(e);if(!t){let{message:t}=iV("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(t),Error(t)}return t}checkExpiry(e,t){let{expiry:r}=t;(0,R.toMiliseconds)(r)-Date.now()<=0&&this.expire(e,t)}expire(e,t){this.expirations.delete(e),this.events.emit(sE.expired,{target:e,expiration:t})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,t)=>this.checkExpiry(t,e))}registerEventListeners(){this.core.heartbeat.on(n.Lx.pulse,()=>this.checkExpirations()),this.events.on(sE.created,e=>{let t=sE.created;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()}),this.events.on(sE.expired,e=>{let t=sE.expired;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()}),this.events.on(sE.deleted,e=>{let t=sE.deleted;this.logger.info(`Emitting ${t}`),this.logger.debug({type:"event",event:t,data:e}),this.persist()})}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}}var ax=Object.defineProperty,aU=(e,t,r)=>t in e?ax(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aD=(e,t,r)=>aU(e,"symbol"!=typeof t?t+"":t,r);class a$ extends N{constructor(e,t,r){super(e,t,r),this.core=e,this.logger=t,this.store=r,aD(this,"name","verify-api"),aD(this,"abortController"),aD(this,"isDevEnv"),aD(this,"verifyUrlV3",sI),aD(this,"storagePrefix",sn),aD(this,"version",2),aD(this,"publicKey"),aD(this,"fetchPromise"),aD(this,"init",async()=>{var e;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&(0,R.toMiliseconds)(null==(e=this.publicKey)?void 0:e.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),aD(this,"register",async e=>{if(!et()||this.isDevEnv)return;let t=window.location.origin,{id:r,decryptedId:i}=e,s=`${this.verifyUrlV3}/attestation?projectId=${this.core.projectId}&origin=${t}&id=${r}&decryptedId=${i}`;try{let e=(0,D.getDocument)(),t=this.startAbortTimer(5*R.ONE_SECOND),i=await new Promise((i,n)=>{let a=()=>{window.removeEventListener("message",c),e.body.removeChild(o),n("attestation aborted")};this.abortController.signal.addEventListener("abort",a);let o=e.createElement("iframe");o.src=s,o.style.display="none",o.addEventListener("error",a,{signal:this.abortController.signal});let c=s=>{if(s.data&&"string"==typeof s.data)try{let n=JSON.parse(s.data);if("verify_attestation"===n.type){if((0,x.xp)(n.attestation).payload.id!==r)return;clearInterval(t),e.body.removeChild(o),this.abortController.signal.removeEventListener("abort",a),window.removeEventListener("message",c),i(null===n.attestation?"":n.attestation)}}catch(e){this.logger.warn(e)}};e.body.appendChild(o),window.addEventListener("message",c,{signal:this.abortController.signal})});return this.logger.debug("jwt attestation",i),i}catch(e){this.logger.warn(e)}return""}),aD(this,"resolve",async e=>{if(this.isDevEnv)return"";let{attestationId:t,hash:r,encryptedId:i}=e;if(""===t){this.logger.debug("resolve: attestationId is empty, skipping");return}if(t){if((0,x.xp)(t).payload.id!==i)return;let e=await this.isValidJwtAttestation(t);if(e){if(!e.isVerified){this.logger.warn("resolve: jwt attestation: origin url not verified");return}return e}}if(!r)return;let s=this.getVerifyUrl(e?.verifyUrl);return this.fetchAttestation(r,s)}),aD(this,"fetchAttestation",async(e,t)=>{this.logger.debug(`resolving attestation: ${e} from url: ${t}`);let r=this.startAbortTimer(5*R.ONE_SECOND),i=await fetch(`${t}/attestation/${e}?v2Supported=true`,{signal:this.abortController.signal});return clearTimeout(r),200===i.status?await i.json():void 0}),aD(this,"getVerifyUrl",e=>{let t=e||sN;return sA.includes(t)||(this.logger.info(`verify url: ${t}, not included in trusted list, assigning default: ${sN}`),t=sN),t}),aD(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);let e=this.startAbortTimer(R.FIVE_SECONDS),t=await fetch(`${this.verifyUrlV3}/public-key`,{signal:this.abortController.signal});return clearTimeout(e),await t.json()}catch(e){this.logger.warn(e)}}),aD(this,"persistPublicKey",async e=>{this.logger.debug("persisting public key to local storage",e),await this.store.setItem(this.storeKey,e),this.publicKey=e}),aD(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),aD(this,"isValidJwtAttestation",async e=>{let t=await this.getPublicKey();try{if(t)return this.validateAttestation(e,t)}catch(e){this.logger.error(e),this.logger.warn("error validating attestation")}let r=await this.fetchAndPersistPublicKey();try{if(r)return this.validateAttestation(e,r)}catch(e){this.logger.error(e),this.logger.warn("error validating attestation")}}),aD(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),aD(this,"fetchAndPersistPublicKey",async()=>{if(this.fetchPromise)return await this.fetchPromise,this.publicKey;this.fetchPromise=new Promise(async e=>{let t=await this.fetchPublicKey();t&&(await this.persistPublicKey(t),e(t))});let e=await this.fetchPromise;return this.fetchPromise=void 0,e}),aD(this,"validateAttestation",(e,t)=>{let r=function(e,t){let[r,i,s]=e.split("."),n=Buffer.from(ib(s),"base64");if(64!==n.length)throw Error("Invalid signature length");let a=n.slice(0,32),o=n.slice(32,64),c=t8(`${r}.${i}`),l=function(e){let t=Buffer.from(e.x,"base64"),r=Buffer.from(e.y,"base64");return(0,j.zo)([new Uint8Array([4]),t,r])}(t);if(!ia.verify((0,j.zo)([a,o]),c,l))throw Error("Invalid signature");return(0,x.xp)(e).payload}(e,t.publicKey),i={hasExpired:(0,R.toMiliseconds)(r.exp)<Date.now(),payload:r};if(i.hasExpired)throw this.logger.warn("resolve: jwt attestation expired"),Error("JWT attestation expired");return{origin:i.payload.origin,isScam:i.payload.isScam,isVerified:i.payload.isVerified}}),this.logger=(0,o.Ep)(t,this.name),this.abortController=new AbortController,this.isDevEnv=eC(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return(0,o.Fd)(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),(0,R.toMiliseconds)(e))}}var aM=Object.defineProperty,aL=(e,t,r)=>t in e?aM(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,aj=(e,t,r)=>aL(e,"symbol"!=typeof t?t+"":t,r);class aq extends I{constructor(e,t){super(e,t),this.projectId=e,this.logger=t,aj(this,"context","echo"),aj(this,"registerDeviceToken",async e=>{let{clientId:t,token:r,notificationType:i,enableEncrypted:s=!1}=e,n=`https://echo.walletconnect.com/${this.projectId}/clients`;await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_id:t,type:i,token:r,always_raw:s})})}),this.logger=(0,o.Ep)(t,this.context)}}var aB=Object.defineProperty,aF=Object.getOwnPropertySymbols,aH=Object.prototype.hasOwnProperty,aW=Object.prototype.propertyIsEnumerable,aV=(e,t,r)=>t in e?aB(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,az=(e,t)=>{for(var r in t||(t={}))aH.call(t,r)&&aV(e,r,t[r]);if(aF)for(var r of aF(t))aW.call(t,r)&&aV(e,r,t[r]);return e},aK=(e,t,r)=>aV(e,"symbol"!=typeof t?t+"":t,r);class aJ extends A{constructor(e,t,r=!0){super(e,t,r),this.core=e,this.logger=t,aK(this,"context","event-client"),aK(this,"storagePrefix",sn),aK(this,"storageVersion",.1),aK(this,"events",new Map),aK(this,"shouldPersist",!1),aK(this,"init",async()=>{if(!eC())try{let e={eventId:ev(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:en(this.core.relayer.protocol,this.core.relayer.version,sg)}}};await this.sendEvent([e])}catch(e){this.logger.warn(e)}}),aK(this,"createEvent",e=>{let{event:t="ERROR",type:r="",properties:{topic:i,trace:s}}=e,n=ev(),a=this.core.projectId||"",o=az({eventId:n,timestamp:Date.now(),props:{event:t,type:r,properties:{topic:i,trace:s}},bundleId:a,domain:this.getAppDomain()},this.setMethods(n));return this.telemetryEnabled&&(this.events.set(n,o),this.shouldPersist=!0),o}),aK(this,"getEvent",e=>{let{eventId:t,topic:r}=e;if(t)return this.events.get(t);let i=Array.from(this.events.values()).find(e=>e.props.properties.topic===r);if(i)return az(az({},i),this.setMethods(i.eventId))}),aK(this,"deleteEvent",e=>{let{eventId:t}=e;this.events.delete(t),this.shouldPersist=!0}),aK(this,"setEventListeners",()=>{this.core.heartbeat.on(n.Lx.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(e=>{(0,R.fromMiliseconds)(Date.now())-(0,R.fromMiliseconds)(e.timestamp)>86400&&(this.events.delete(e.eventId),this.shouldPersist=!0)})})}),aK(this,"setMethods",e=>({addTrace:t=>this.addTrace(e,t),setError:t=>this.setError(e,t)})),aK(this,"addTrace",(e,t)=>{let r=this.events.get(e);r&&(r.props.properties.trace.push(t),this.events.set(e,r),this.shouldPersist=!0)}),aK(this,"setError",(e,t)=>{let r=this.events.get(e);r&&(r.props.type=t,r.timestamp=Date.now(),this.events.set(e,r),this.shouldPersist=!0)}),aK(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),aK(this,"restore",async()=>{try{let e=await this.core.storage.getItem(this.storageKey)||[];if(!e.length)return;e.forEach(e=>{this.events.set(e.eventId,az(az({},e),this.setMethods(e.eventId)))})}catch(e){this.logger.warn(e)}}),aK(this,"submit",async()=>{if(!this.telemetryEnabled||0===this.events.size)return;let e=[];for(let[t,r]of this.events)r.props.type&&e.push(r);if(0!==e.length)try{if((await this.sendEvent(e)).ok)for(let t of e)this.events.delete(t.eventId),this.shouldPersist=!0}catch(e){this.logger.warn(e)}}),aK(this,"sendEvent",async e=>{let t=this.getAppDomain()?"":"&sp=desktop";return await fetch(`https://pulse.walletconnect.org/batch?projectId=${this.core.projectId}&st=events_sdk&sv=js-${sg}${t}`,{method:"POST",body:JSON.stringify(e)})}),aK(this,"getAppDomain",()=>es().url),this.logger=(0,o.Ep)(t,this.context),this.telemetryEnabled=r,r?this.restore().then(async()=>{await this.submit(),this.setEventListeners()}):this.persist()}get storageKey(){return this.storagePrefix+this.storageVersion+this.core.customStoragePrefix+"//"+this.context}}var aG=Object.defineProperty,aY=Object.getOwnPropertySymbols,aX=Object.prototype.hasOwnProperty,aZ=Object.prototype.propertyIsEnumerable,aQ=(e,t,r)=>t in e?aG(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,a0=(e,t)=>{for(var r in t||(t={}))aX.call(t,r)&&aQ(e,r,t[r]);if(aY)for(var r of aY(t))aZ.call(t,r)&&aQ(e,r,t[r]);return e},a1=(e,t,r)=>aQ(e,"symbol"!=typeof t?t+"":t,r);class a2 extends u{constructor(e){var t;super(e),a1(this,"protocol","wc"),a1(this,"version",2),a1(this,"name",ss),a1(this,"relayUrl"),a1(this,"projectId"),a1(this,"customStoragePrefix"),a1(this,"events",new i.EventEmitter),a1(this,"logger"),a1(this,"heartbeat"),a1(this,"relayer"),a1(this,"crypto"),a1(this,"storage"),a1(this,"history"),a1(this,"expirer"),a1(this,"pairing"),a1(this,"verify"),a1(this,"echoClient"),a1(this,"linkModeSupportedApps"),a1(this,"eventClient"),a1(this,"initialized",!1),a1(this,"logChunkController"),a1(this,"on",(e,t)=>this.events.on(e,t)),a1(this,"once",(e,t)=>this.events.once(e,t)),a1(this,"off",(e,t)=>this.events.off(e,t)),a1(this,"removeListener",(e,t)=>this.events.removeListener(e,t)),a1(this,"dispatchEnvelope",({topic:e,message:t,sessionExists:r})=>{if(!e||!t)return;let i={topic:e,message:t,publishedAt:Date.now(),transportType:sf.link_mode};this.relayer.onLinkMessageEvent(i,{sessionExists:r})});let r=this.getGlobalCore(e?.customStoragePrefix);if(r)try{return this.customStoragePrefix=r.customStoragePrefix,this.logger=r.logger,this.heartbeat=r.heartbeat,this.crypto=r.crypto,this.history=r.history,this.expirer=r.expirer,this.storage=r.storage,this.relayer=r.relayer,this.pairing=r.pairing,this.verify=r.verify,this.echoClient=r.echoClient,this.linkModeSupportedApps=r.linkModeSupportedApps,this.eventClient=r.eventClient,this.initialized=r.initialized,this.logChunkController=r.logChunkController,r}catch(e){console.warn("Failed to copy global core",e)}this.projectId=e?.projectId,this.relayUrl=e?.relayUrl||sd,this.customStoragePrefix=null!=e&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";let s=(0,o.jI)({level:"string"==typeof e?.logger&&e.logger?e.logger:sa.logger,name:ss}),{logger:c,chunkLoggerController:l}=(0,o.Rt)({opts:s,maxSizeInBytes:e?.maxLogBlobSizeInBytes,loggerOverride:e?.logger});this.logChunkController=l,null!=(t=this.logChunkController)&&t.downloadLogsBlobInBrowser&&(window.downloadLogsBlobInBrowser=async()=>{var e,t;null!=(e=this.logChunkController)&&e.downloadLogsBlobInBrowser&&(null==(t=this.logChunkController)||t.downloadLogsBlobInBrowser({clientId:await this.crypto.getClientId()}))}),this.logger=(0,o.Ep)(c,this.name),this.heartbeat=new n.C$,this.crypto=new nA(this,this.logger,e?.keychain),this.history=new aO(this,this.logger),this.expirer=new ak(this,this.logger),this.storage=null!=e&&e.storage?e.storage:new a.Z(a0(a0({},so),e?.storageOptions)),this.relayer=new aa({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new aI(this,this.logger),this.verify=new a$(this,this.logger,this.storage),this.echoClient=new aq(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new aJ(this,this.logger,e?.telemetryEnabled),this.setGlobalCore(this)}static async init(e){let t=new a2(e);await t.initialize();let r=await t.crypto.getClientId();return await t.storage.setItem("WALLETCONNECT_CLIENT_ID",r),t}get context(){return(0,o.Fd)(this.logger)}async start(){this.initialized||await this.initialize()}async getLogsBlob(){var e;return null==(e=this.logChunkController)?void 0:e.logsToBlob({clientId:await this.crypto.getClientId()})}async addLinkModeSupportedApp(e){this.linkModeSupportedApps.includes(e)||(this.linkModeSupportedApps.push(e),await this.storage.setItem(sw,this.linkModeSupportedApps))}async initialize(){this.logger.trace("Initialized");try{await this.crypto.init(),await this.history.init(),await this.expirer.init(),await this.relayer.init(),await this.heartbeat.init(),await this.pairing.init(),this.linkModeSupportedApps=await this.storage.getItem(sw)||[],this.initialized=!0,this.logger.info("Core Initialization Success")}catch(e){throw this.logger.warn(`Core Initialization Failure at epoch ${Date.now()}`,e),this.logger.error(e.message),e}}getGlobalCore(e=""){try{if(this.isGlobalCoreDisabled())return;let t=`_walletConnectCore_${e}`,r=`${t}_count`;return globalThis[r]=(globalThis[r]||0)+1,globalThis[r]>1&&console.warn(`WalletConnect Core is already initialized. This is probably a mistake and can lead to unexpected behavior. Init() was called ${globalThis[r]} times.`),globalThis[t]}catch(e){console.warn("Failed to get global WalletConnect core",e);return}}setGlobalCore(e){var t;try{if(this.isGlobalCoreDisabled())return;let r=`_walletConnectCore_${(null==(t=e.opts)?void 0:t.customStoragePrefix)||""}`;globalThis[r]=e}catch(e){console.warn("Failed to set global WalletConnect core",e)}}isGlobalCoreDisabled(){try{return"u">typeof process&&"true"===process.env.DISABLE_GLOBAL_CORE}catch{return!0}}}let a5="client",a3=`wc@2:${a5}:`,a8={name:a5,logger:"error"},a4="WALLETCONNECT_DEEPLINK_CHOICE",a6="Proposal expired",a9=R.SEVEN_DAYS,a7={wc_sessionPropose:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1104},res:{ttl:R.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1106},res:{ttl:R.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:R.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1112},res:{ttl:R.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:R.ONE_DAY,prompt:!1,tag:1114},res:{ttl:R.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:R.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:R.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:R.FIVE_MINUTES,prompt:!1,tag:1119}}},oe={min:R.FIVE_MINUTES,max:R.SEVEN_DAYS},ot={idle:"IDLE",active:"ACTIVE"},or={eth_sendTransaction:{key:""},eth_sendRawTransaction:{key:""},wallet_sendCalls:{key:""},solana_signTransaction:{key:"signature"},solana_signAllTransactions:{key:"transactions"},solana_signAndSendTransaction:{key:"signature"}},oi=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],os="wc@1.5:auth:",on=`${os}:PUB_KEY`;var oa=Object.defineProperty,oo=Object.defineProperties,oc=Object.getOwnPropertyDescriptors,ol=Object.getOwnPropertySymbols,oh=Object.prototype.hasOwnProperty,od=Object.prototype.propertyIsEnumerable,ou=(e,t,r)=>t in e?oa(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,op=(e,t)=>{for(var r in t||(t={}))oh.call(t,r)&&ou(e,r,t[r]);if(ol)for(var r of ol(t))od.call(t,r)&&ou(e,r,t[r]);return e},og=(e,t)=>oo(e,oc(t)),of=(e,t,r)=>ou(e,"symbol"!=typeof t?t+"":t,r);class om extends T{constructor(e){super(e),of(this,"name","engine"),of(this,"events",new(s())),of(this,"initialized",!1),of(this,"requestQueue",{state:ot.idle,queue:[]}),of(this,"sessionRequestQueue",{state:ot.idle,queue:[]}),of(this,"requestQueueDelay",R.ONE_SECOND),of(this,"expectedPairingMethodMap",new Map),of(this,"recentlyDeletedMap",new Map),of(this,"recentlyDeletedLimit",200),of(this,"relayMessageCache",[]),of(this,"pendingSessions",new Map),of(this,"init",async()=>{this.initialized||(await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.registerPairingEvents(),await this.registerLinkModeListeners(),this.client.core.pairing.register({methods:Object.keys(a7)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},(0,R.toMiliseconds)(this.requestQueueDelay)))}),of(this,"connect",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();let t=og(op({},e),{requiredNamespaces:e.requiredNamespaces||{},optionalNamespaces:e.optionalNamespaces||{}});await this.isValidConnect(t),t.optionalNamespaces=function(e,t){var r,i,s,n,a,o;let c=iB(e),l=iB(t),h={};for(let e of Object.keys(c).concat(Object.keys(l)))h[e]={chains:em(null==(r=c[e])?void 0:r.chains,null==(i=l[e])?void 0:i.chains),methods:em(null==(s=c[e])?void 0:s.methods,null==(n=l[e])?void 0:n.methods),events:em(null==(a=c[e])?void 0:a.events,null==(o=l[e])?void 0:o.events)};return h}(t.requiredNamespaces,t.optionalNamespaces),t.requiredNamespaces={};let{pairingTopic:r,requiredNamespaces:i,optionalNamespaces:s,sessionProperties:n,scopedProperties:a,relays:o}=t,c=r,l,h=!1;try{if(c){let e=this.client.core.pairing.pairings.get(c);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),h=e.active}}catch(e){throw this.client.logger.error(`connect() -> pairing.get(${c}) failed`),e}if(!c||!h){let{topic:e,uri:t}=await this.client.core.pairing.create();c=e,l=t}if(!c){let{message:e}=iV("NO_MATCHING_KEY",`connect() pairing topic: ${c}`);throw Error(e)}let d=await this.client.core.crypto.generateKeyPair(),u=a7.wc_sessionPropose.req.ttl||R.FIVE_MINUTES,p=ep(u),g=og(op(op({requiredNamespaces:i,optionalNamespaces:s,relays:o??[{protocol:"irn"}],proposer:{publicKey:d,metadata:this.client.metadata},expiryTimestamp:p,pairingTopic:c},n&&{sessionProperties:n}),a&&{scopedProperties:a}),{id:(0,sr.payloadId)()}),f=ef("session_connect",g.id),{reject:m,resolve:w,done:y}=el(u,a6),b=({id:e})=>{e===g.id&&(this.client.events.off("proposal_expire",b),this.pendingSessions.delete(g.id),this.events.emit(f,{error:{message:a6,code:0}}))};return this.client.events.on("proposal_expire",b),this.events.once(f,({error:e,session:t})=>{this.client.events.off("proposal_expire",b),e?m(e):t&&w(t)}),await this.sendRequest({topic:c,method:"wc_sessionPropose",params:g,throwOnFailedPublish:!0,clientRpcId:g.id}),await this.setProposal(g.id,g),{uri:l,approval:y}}),of(this,"pair",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{return await this.client.core.pairing.pair(e)}catch(e){throw this.client.logger.error("pair() failed"),e}}),of(this,"approve",async e=>{var t,r,i;let s=this.client.core.eventClient.createEvent({properties:{topic:null==(t=e?.id)?void 0:t.toString(),trace:[sO.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(e){throw s.setError(sP.no_internet_connection),e}try{await this.isValidProposalId(e?.id)}catch(t){throw this.client.logger.error(`approve() -> proposal.get(${e?.id}) failed`),s.setError(sP.proposal_not_found),t}try{await this.isValidApprove(e)}catch(e){throw this.client.logger.error("approve() -> isValidApprove() failed"),s.setError(sP.session_approve_namespace_validation_failure),e}let{id:n,relayProtocol:a,namespaces:o,sessionProperties:c,scopedProperties:l,sessionConfig:h}=e,d=this.client.proposal.get(n);this.client.core.eventClient.deleteEvent({eventId:s.eventId});let{pairingTopic:u,proposer:p,requiredNamespaces:g,optionalNamespaces:f}=d,m=null==(r=this.client.core.eventClient)?void 0:r.getEvent({topic:u});m||(m=null==(i=this.client.core.eventClient)?void 0:i.createEvent({type:sO.session_approve_started,properties:{topic:u,trace:[sO.session_approve_started,sO.session_namespaces_validation_success]}}));let w=await this.client.core.crypto.generateKeyPair(),y=p.publicKey,b=await this.client.core.crypto.generateSharedKey(w,y),v=op(op(op({relay:{protocol:a??"irn"},namespaces:o,controller:{publicKey:w,metadata:this.client.metadata},expiry:ep(a9)},c&&{sessionProperties:c}),l&&{scopedProperties:l}),h&&{sessionConfig:h}),C=sf.relay;m.addTrace(sO.subscribing_session_topic);try{await this.client.core.relayer.subscribe(b,{transportType:C})}catch(e){throw m.setError(sP.subscribe_session_topic_failure),e}m.addTrace(sO.subscribe_session_topic_success);let E=og(op({},v),{topic:b,requiredNamespaces:g,optionalNamespaces:f,pairingTopic:u,acknowledged:!1,self:v.controller,peer:{publicKey:p.publicKey,metadata:p.metadata},controller:w,transportType:sf.relay});await this.client.session.set(b,E),m.addTrace(sO.store_session);try{m.addTrace(sO.publishing_session_settle),await this.sendRequest({topic:b,method:"wc_sessionSettle",params:v,throwOnFailedPublish:!0}).catch(e=>{throw m?.setError(sP.session_settle_publish_failure),e}),m.addTrace(sO.session_settle_publish_success),m.addTrace(sO.publishing_session_approve),await this.sendResult({id:n,topic:u,result:{relay:{protocol:a??"irn"},responderPublicKey:w},throwOnFailedPublish:!0}).catch(e=>{throw m?.setError(sP.session_approve_publish_failure),e}),m.addTrace(sO.session_approve_publish_success)}catch(e){throw this.client.logger.error(e),this.client.session.delete(b,iz("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(b),e}return this.client.core.eventClient.deleteEvent({eventId:m.eventId}),await this.client.core.pairing.updateMetadata({topic:u,metadata:p.metadata}),await this.client.proposal.delete(n,iz("USER_DISCONNECTED")),await this.client.core.pairing.activate({topic:u}),await this.setExpiry(b,ep(a9)),{topic:b,acknowledged:()=>Promise.resolve(this.client.session.get(b))}}),of(this,"reject",async e=>{let t;this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidReject(e)}catch(e){throw this.client.logger.error("reject() -> isValidReject() failed"),e}let{id:r,reason:i}=e;try{t=this.client.proposal.get(r).pairingTopic}catch(e){throw this.client.logger.error(`reject() -> proposal.get(${r}) failed`),e}t&&(await this.sendError({id:r,topic:t,error:i,rpcOpts:a7.wc_sessionPropose.reject}),await this.client.proposal.delete(r,iz("USER_DISCONNECTED")))}),of(this,"update",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(e)}catch(e){throw this.client.logger.error("update() -> isValidUpdate() failed"),e}let{topic:t,namespaces:r}=e,{done:i,resolve:s,reject:n}=el(),a=(0,sr.payloadId)(),o=(0,sr.getBigIntRpcId)().toString(),c=this.client.session.get(t).namespaces;return this.events.once(ef("session_update",a),({error:e})=>{e?n(e):s()}),await this.client.session.update(t,{namespaces:r}),await this.sendRequest({topic:t,method:"wc_sessionUpdate",params:{namespaces:r},throwOnFailedPublish:!0,clientRpcId:a,relayRpcId:o}).catch(e=>{this.client.logger.error(e),this.client.session.update(t,{namespaces:c}),n(e)}),{acknowledged:i}}),of(this,"extend",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidExtend(e)}catch(e){throw this.client.logger.error("extend() -> isValidExtend() failed"),e}let{topic:t}=e,r=(0,sr.payloadId)(),{done:i,resolve:s,reject:n}=el();return this.events.once(ef("session_extend",r),({error:e})=>{e?n(e):s()}),await this.setExpiry(t,ep(a9)),this.sendRequest({topic:t,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(e=>{n(e)}),{acknowledged:i}}),of(this,"request",async e=>{this.isInitialized();try{await this.isValidRequest(e)}catch(e){throw this.client.logger.error("request() -> isValidRequest() failed"),e}let{chainId:t,request:r,topic:i,expiry:s=a7.wc_sessionRequest.req.ttl}=e,n=this.client.session.get(i);n?.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let a=(0,sr.payloadId)(),o=(0,sr.getBigIntRpcId)().toString(),{done:c,resolve:l,reject:h}=el(s,"Request expired. Please try again.");this.events.once(ef("session_request",a),({error:e,result:t})=>{e?h(e):l(t)});let d="wc_sessionRequest",u=this.getAppLinkIfEnabled(n.peer.metadata,n.transportType);if(u)return await this.sendRequest({clientRpcId:a,relayRpcId:o,topic:i,method:d,params:{request:og(op({},r),{expiryTimestamp:ep(s)}),chainId:t},expiry:s,throwOnFailedPublish:!0,appLink:u}).catch(e=>h(e)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:t,id:a}),await c();let p={request:og(op({},r),{expiryTimestamp:ep(s)}),chainId:t},g=this.shouldSetTVF(d,p);return await Promise.all([new Promise(async e=>{await this.sendRequest(op({clientRpcId:a,relayRpcId:o,topic:i,method:d,params:p,expiry:s,throwOnFailedPublish:!0},g&&{tvf:this.getTVFParams(a,p)})).catch(e=>h(e)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:t,id:a}),e()}),new Promise(async e=>{var t;if(!(null!=(t=n.sessionConfig)&&t.disableDeepLink)){let e=await ey(this.client.core.storage,a4);await ew({id:a,topic:i,wcDeepLink:e})}e()}),c()]).then(e=>e[2])}),of(this,"respond",async e=>{this.isInitialized(),await this.isValidRespond(e);let{topic:t,response:r}=e,{id:i}=r,s=this.client.session.get(t);s.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let n=this.getAppLinkIfEnabled(s.peer.metadata,s.transportType);(0,sr.isJsonRpcResult)(r)?await this.sendResult({id:i,topic:t,result:r.result,throwOnFailedPublish:!0,appLink:n}):(0,sr.isJsonRpcError)(r)&&await this.sendError({id:i,topic:t,error:r.error,appLink:n}),this.cleanupAfterResponse(e)}),of(this,"ping",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidPing(e)}catch(e){throw this.client.logger.error("ping() -> isValidPing() failed"),e}let{topic:t}=e;if(this.client.session.keys.includes(t)){let e=(0,sr.payloadId)(),r=(0,sr.getBigIntRpcId)().toString(),{done:i,resolve:s,reject:n}=el();this.events.once(ef("session_ping",e),({error:e})=>{e?n(e):s()}),await Promise.all([this.sendRequest({topic:t,method:"wc_sessionPing",params:{},throwOnFailedPublish:!0,clientRpcId:e,relayRpcId:r}),i()])}else this.client.core.pairing.pairings.keys.includes(t)&&(this.client.logger.warn("ping() on pairing topic is deprecated and will be removed in the next major release."),await this.client.core.pairing.ping({topic:t}))}),of(this,"emit",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(e);let{topic:t,event:r,chainId:i}=e,s=(0,sr.getBigIntRpcId)().toString(),n=(0,sr.payloadId)();await this.sendRequest({topic:t,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:s,clientRpcId:n})}),of(this,"disconnect",async e=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidDisconnect(e);let{topic:t}=e;if(this.client.session.keys.includes(t))await this.sendRequest({topic:t,method:"wc_sessionDelete",params:iz("USER_DISCONNECTED"),throwOnFailedPublish:!0}),await this.deleteSession({topic:t,emitEvent:!1});else if(this.client.core.pairing.pairings.keys.includes(t))await this.client.core.pairing.disconnect({topic:t});else{let{message:e}=iV("MISMATCHED_TOPIC",`Session or pairing topic not found: ${t}`);throw Error(e)}}),of(this,"find",e=>(this.isInitialized(),this.client.session.getAll().filter(t=>(function(e,t){let{requiredNamespaces:r}=t,i=Object.keys(e.namespaces),s=Object.keys(r),n=!0;return!!ea(s,i)&&(i.forEach(t=>{let{accounts:i,methods:s,events:a}=e.namespaces[t],o=iL(i),c=r[t];ea(F(t,c),o)&&ea(c.methods,s)&&ea(c.events,a)||(n=!1)}),n)})(t,e)))),of(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),of(this,"authenticate",async(e,t)=>{var r,i,s;let n;this.isInitialized(),this.isValidAuthenticate(e);let a=t&&this.client.core.linkModeSupportedApps.includes(t)&&(null==(r=this.client.metadata.redirect)?void 0:r.linkMode),o=a?sf.link_mode:sf.relay;o===sf.relay&&await this.confirmOnlineStateOrThrow();let{chains:c,statement:l="",uri:h,domain:d,nonce:u,type:p,exp:g,nbf:f,methods:m=[],expiry:w}=e,y=[...e.resources||[]],{topic:b,uri:v}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:b,uri:v}});let C=await this.client.core.crypto.generateKeyPair(),E=ip(C);if(await Promise.all([this.client.auth.authKeys.set(on,{responseTopic:E,publicKey:C}),this.client.auth.pairingTopics.set(E,{topic:E,pairingTopic:b})]),await this.client.core.relayer.subscribe(E,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${b}`),m.length>0){let{namespace:e}=B(c[0]),t=tg(function(e,t,r,i={}){return r?.sort((e,t)=>e.localeCompare(t)),{att:{[e]:function(e,t,r={}){return Object.assign({},...(t=t?.sort((e,t)=>e.localeCompare(t))).map(t=>({[`${e}/${t}`]:[r]})))}(t,r,i)}}}(e,"request",m));ty(y)&&(i=t,s=y.pop(),t=tg(function(e,t){tp(e),tp(t);let r=Object.keys(e.att).concat(Object.keys(t.att)).sort((e,t)=>e.localeCompare(t)),i={att:{}};return r.forEach(r=>{var s,n;Object.keys((null==(s=e.att)?void 0:s[r])||{}).concat(Object.keys((null==(n=t.att)?void 0:n[r])||{})).sort((e,t)=>e.localeCompare(t)).forEach(s=>{var n,a;i.att[r]=ta(tn({},i.att[r]),{[s]:(null==(n=e.att[r])?void 0:n[s])||(null==(a=t.att[r])?void 0:a[s])})})}),i}(tf(i),tf(s)))),y.push(t)}let N=w&&w>a7.wc_sessionAuthenticate.req.ttl?w:a7.wc_sessionAuthenticate.req.ttl,I={authPayload:{type:p??"caip122",chains:c,statement:l,aud:h,domain:d,version:"1",nonce:u,iat:new Date().toISOString(),exp:g,nbf:f,resources:y},requester:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:ep(N)},A={requiredNamespaces:{},optionalNamespaces:{eip155:{chains:c,methods:[...new Set(["personal_sign",...m])],events:["chainChanged","accountsChanged"]}},relays:[{protocol:"irn"}],pairingTopic:b,proposer:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:ep(a7.wc_sessionPropose.req.ttl),id:(0,sr.payloadId)()},{done:_,resolve:S,reject:O}=el(N,"Request expired"),P=(0,sr.payloadId)(),T=ef("session_connect",A.id),R=ef("session_request",P),k=async({error:e,session:t})=>{this.events.off(R,x),e?O(e):t&&S({session:t})},x=async e=>{var r,i,s;let n;if(await this.deletePendingAuthRequest(P,{message:"fulfilled",code:0}),e.error){let t=iz("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return e.error.code===t.code?void 0:(this.events.off(T,k),O(e.error.message))}await this.deleteProposal(A.id),this.events.off(T,k);let{cacaos:a,responder:c}=e.result,l=[],h=[];for(let e of a){await td({cacao:e,projectId:this.client.core.projectId})||(this.client.logger.error(e,"Signature verification failed"),O(iz("SESSION_SETTLEMENT_FAILED","Signature verification failed")));let{p:t}=e,r=ty(t.resources),i=[tl(t.iss)],s=th(t.iss);if(r){let e=tm(r),t=tw(r);l.push(...e),i.push(...t)}for(let e of i)h.push(`${e}:${s}`)}let d=await this.client.core.crypto.generateSharedKey(C,c.publicKey);l.length>0&&(n={topic:d,acknowledged:!0,self:{publicKey:C,metadata:this.client.metadata},peer:c,controller:c.publicKey,expiry:ep(a9),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:b,namespaces:iF([...new Set(l)],[...new Set(h)]),transportType:o},await this.client.core.relayer.subscribe(d,{transportType:o}),await this.client.session.set(d,n),b&&await this.client.core.pairing.updateMetadata({topic:b,metadata:c.metadata}),n=this.client.session.get(d)),null!=(r=this.client.metadata.redirect)&&r.linkMode&&null!=(i=c.metadata.redirect)&&i.linkMode&&null!=(s=c.metadata.redirect)&&s.universal&&t&&(this.client.core.addLinkModeSupportedApp(c.metadata.redirect.universal),this.client.session.update(d,{transportType:sf.link_mode})),S({auths:a,session:n})};this.events.once(T,k),this.events.once(R,x);try{if(a){let e=(0,sr.formatJsonRpcRequest)("wc_sessionAuthenticate",I,P);this.client.core.history.set(b,e);let r=await this.client.core.crypto.encode("",e,{type:2,encoding:ih});n=iO(t,b,r)}else await Promise.all([this.sendRequest({topic:b,method:"wc_sessionAuthenticate",params:I,expiry:e.expiry,throwOnFailedPublish:!0,clientRpcId:P}),this.sendRequest({topic:b,method:"wc_sessionPropose",params:A,expiry:a7.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:A.id})])}catch(e){throw this.events.off(T,k),this.events.off(R,x),e}return await this.setProposal(A.id,A),await this.setAuthRequest(P,{request:og(op({},I),{verifyContext:{}}),pairingTopic:b,transportType:o}),{uri:n??v,response:_}}),of(this,"approveSessionAuthenticate",async e=>{let t;let{id:r,auths:i}=e,s=this.client.core.eventClient.createEvent({properties:{topic:r.toString(),trace:[sT.authenticated_session_approve_started]}});try{this.isInitialized()}catch(e){throw s.setError(sR.no_internet_connection),e}let n=this.getPendingAuthRequest(r);if(!n)throw s.setError(sR.authenticated_session_pending_request_not_found),Error(`Could not find pending auth request with id ${r}`);let a=n.transportType||sf.relay;a===sf.relay&&await this.confirmOnlineStateOrThrow();let o=n.requester.publicKey,c=await this.client.core.crypto.generateKeyPair(),l=ip(o),h={type:1,receiverPublicKey:o,senderPublicKey:c},d=[],u=[];for(let e of i){if(!await td({cacao:e,projectId:this.client.core.projectId})){s.setError(sR.invalid_cacao);let e=iz("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:r,topic:l,error:e,encodeOpts:h}),Error(e.message)}s.addTrace(sT.cacaos_verified);let{p:t}=e,i=ty(t.resources),n=[tl(t.iss)],a=th(t.iss);if(i){let e=tm(i),t=tw(i);d.push(...e),n.push(...t)}for(let e of n)u.push(`${e}:${a}`)}let p=await this.client.core.crypto.generateSharedKey(c,o);if(s.addTrace(sT.create_authenticated_session_topic),d?.length>0){t={topic:p,acknowledged:!0,self:{publicKey:c,metadata:this.client.metadata},peer:{publicKey:o,metadata:n.requester.metadata},controller:o,expiry:ep(a9),authentication:i,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:n.pairingTopic,namespaces:iF([...new Set(d)],[...new Set(u)]),transportType:a},s.addTrace(sT.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(p,{transportType:a})}catch(e){throw s.setError(sR.subscribe_authenticated_session_topic_failure),e}s.addTrace(sT.subscribe_authenticated_session_topic_success),await this.client.session.set(p,t),s.addTrace(sT.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:n.pairingTopic,metadata:n.requester.metadata})}s.addTrace(sT.publishing_authenticated_session_approve);try{await this.sendResult({topic:l,id:r,result:{cacaos:i,responder:{publicKey:c,metadata:this.client.metadata}},encodeOpts:h,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(n.requester.metadata,a)})}catch(e){throw s.setError(sR.authenticated_session_approve_publish_failure),e}return await this.client.auth.requests.delete(r,{message:"fulfilled",code:0}),await this.client.core.pairing.activate({topic:n.pairingTopic}),this.client.core.eventClient.deleteEvent({eventId:s.eventId}),{session:t}}),of(this,"rejectSessionAuthenticate",async e=>{this.isInitialized();let{id:t,reason:r}=e,i=this.getPendingAuthRequest(t);if(!i)throw Error(`Could not find pending auth request with id ${t}`);i.transportType===sf.relay&&await this.confirmOnlineStateOrThrow();let s=i.requester.publicKey,n=await this.client.core.crypto.generateKeyPair(),a=ip(s);await this.sendError({id:t,topic:a,error:r,encodeOpts:{type:1,receiverPublicKey:s,senderPublicKey:n},rpcOpts:a7.wc_sessionAuthenticate.reject,appLink:this.getAppLinkIfEnabled(i.requester.metadata,i.transportType)}),await this.client.auth.requests.delete(t,{message:"rejected",code:0}),await this.client.proposal.delete(t,iz("USER_DISCONNECTED"))}),of(this,"formatAuthMessage",e=>{this.isInitialized();let{request:t,iss:r}=e;return tu(t,r)}),of(this,"processRelayMessageCache",()=>{setTimeout(async()=>{if(0!==this.relayMessageCache.length)for(;this.relayMessageCache.length>0;)try{let e=this.relayMessageCache.shift();e&&await this.onRelayMessage(e)}catch(e){this.client.logger.error(e)}},50)}),of(this,"cleanupDuplicatePairings",async e=>{if(e.pairingTopic)try{let t=this.client.core.pairing.pairings.get(e.pairingTopic),r=this.client.core.pairing.pairings.getAll().filter(r=>{var i,s;return(null==(i=r.peerMetadata)?void 0:i.url)&&(null==(s=r.peerMetadata)?void 0:s.url)===e.peer.metadata.url&&r.topic&&r.topic!==t.topic});if(0===r.length)return;this.client.logger.info(`Cleaning up ${r.length} duplicate pairing(s)`),await Promise.all(r.map(e=>this.client.core.pairing.disconnect({topic:e.topic}))),this.client.logger.info("Duplicate pairings clean up finished")}catch(e){this.client.logger.error(e)}}),of(this,"deleteSession",async e=>{var t;let{topic:r,expirerHasDeleted:i=!1,emitEvent:s=!0,id:n=0}=e,{self:a}=this.client.session.get(r);await this.client.core.relayer.unsubscribe(r),await this.client.session.delete(r,iz("USER_DISCONNECTED")),this.addToRecentlyDeleted(r,"session"),this.client.core.crypto.keychain.has(a.publicKey)&&await this.client.core.crypto.deleteKeyPair(a.publicKey),this.client.core.crypto.keychain.has(r)&&await this.client.core.crypto.deleteSymKey(r),i||this.client.core.expirer.del(r),this.client.core.storage.removeItem(a4).catch(e=>this.client.logger.warn(e)),this.getPendingSessionRequests().forEach(e=>{e.topic===r&&this.deletePendingSessionRequest(e.id,iz("USER_DISCONNECTED"))}),r===(null==(t=this.sessionRequestQueue.queue[0])?void 0:t.topic)&&(this.sessionRequestQueue.state=ot.idle),s&&this.client.events.emit("session_delete",{id:n,topic:r})}),of(this,"deleteProposal",async(e,t)=>{if(t)try{let t=this.client.proposal.get(e),r=this.client.core.eventClient.getEvent({topic:t.pairingTopic});r?.setError(sP.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(e,iz("USER_DISCONNECTED")),t?Promise.resolve():this.client.core.expirer.del(e)]),this.addToRecentlyDeleted(e,"proposal")}),of(this,"deletePendingSessionRequest",async(e,t,r=!1)=>{await Promise.all([this.client.pendingRequest.delete(e,t),r?Promise.resolve():this.client.core.expirer.del(e)]),this.addToRecentlyDeleted(e,"request"),this.sessionRequestQueue.queue=this.sessionRequestQueue.queue.filter(t=>t.id!==e),r&&(this.sessionRequestQueue.state=ot.idle,this.client.events.emit("session_request_expire",{id:e}))}),of(this,"deletePendingAuthRequest",async(e,t,r=!1)=>{await Promise.all([this.client.auth.requests.delete(e,t),r?Promise.resolve():this.client.core.expirer.del(e)])}),of(this,"setExpiry",async(e,t)=>{this.client.session.keys.includes(e)&&(this.client.core.expirer.set(e,t),await this.client.session.update(e,{expiry:t}))}),of(this,"setProposal",async(e,t)=>{this.client.core.expirer.set(e,ep(a7.wc_sessionPropose.req.ttl)),await this.client.proposal.set(e,t)}),of(this,"setAuthRequest",async(e,t)=>{let{request:r,pairingTopic:i,transportType:s=sf.relay}=t;this.client.core.expirer.set(e,r.expiryTimestamp),await this.client.auth.requests.set(e,{authPayload:r.authPayload,requester:r.requester,expiryTimestamp:r.expiryTimestamp,id:e,pairingTopic:i,verifyContext:r.verifyContext,transportType:s})}),of(this,"setPendingSessionRequest",async e=>{let{id:t,topic:r,params:i,verifyContext:s}=e,n=i.request.expiryTimestamp||ep(a7.wc_sessionRequest.req.ttl);this.client.core.expirer.set(t,n),await this.client.pendingRequest.set(t,{id:t,topic:r,params:i,verifyContext:s})}),of(this,"sendRequest",async e=>{let t,r;let{topic:i,method:s,params:n,expiry:a,relayRpcId:o,clientRpcId:c,throwOnFailedPublish:l,appLink:h,tvf:d}=e,u=(0,sr.formatJsonRpcRequest)(s,n,c),p=!!h;try{let e=p?ih:il;t=await this.client.core.crypto.encode(i,u,{encoding:e})}catch(e){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${i} failed`),e}if(oi.includes(s)){let e=ig(JSON.stringify(u)),i=ig(t);r=await this.client.core.verify.register({id:i,decryptedId:e})}let g=a7[s].req;if(g.attestation=r,a&&(g.ttl=a),o&&(g.id=o),this.client.core.history.set(i,u),p){let e=iO(h,i,t);await global.Linking.openURL(e,this.client.name)}else{let e=a7[s].req;a&&(e.ttl=a),o&&(e.id=o),e.tvf=og(op({},d),{correlationId:u.id}),l?(e.internal=og(op({},e.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(i,t,e)):this.client.core.relayer.publish(i,t,e).catch(e=>this.client.logger.error(e))}return u.id}),of(this,"sendResult",async e=>{let t,r,i;let{id:s,topic:n,result:a,throwOnFailedPublish:o,encodeOpts:c,appLink:l}=e,h=(0,sr.formatJsonRpcResult)(s,a),d=l&&"u">typeof(null==global?void 0:global.Linking);try{let e=d?ih:il;t=await this.client.core.crypto.encode(n,h,og(op({},c||{}),{encoding:e}))}catch(e){throw await this.cleanup(),this.client.logger.error(`sendResult() -> core.crypto.encode() for topic ${n} failed`),e}try{let e=(r=await this.client.core.history.get(n,s)).request;try{this.shouldSetTVF(e.method,e.params)&&(i=this.getTVFParams(s,e.params,a))}catch(e){this.client.logger.warn("sendResult() -> getTVFParams() failed",e)}}catch(e){throw this.client.logger.error(`sendResult() -> history.get(${n}, ${s}) failed`),e}if(d){let e=iO(l,n,t);await global.Linking.openURL(e,this.client.name)}else{let e=a7[r.request.method].res;e.tvf=og(op({},i),{correlationId:s}),o?(e.internal=og(op({},e.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,t,e)):this.client.core.relayer.publish(n,t,e).catch(e=>this.client.logger.error(e))}await this.client.core.history.resolve(h)}),of(this,"sendError",async e=>{let t,r;let{id:i,topic:s,error:n,encodeOpts:a,rpcOpts:o,appLink:c}=e,l=(0,sr.formatJsonRpcError)(i,n),h=c&&"u">typeof(null==global?void 0:global.Linking);try{let e=h?ih:il;t=await this.client.core.crypto.encode(s,l,og(op({},a||{}),{encoding:e}))}catch(e){throw await this.cleanup(),this.client.logger.error(`sendError() -> core.crypto.encode() for topic ${s} failed`),e}try{r=await this.client.core.history.get(s,i)}catch(e){throw this.client.logger.error(`sendError() -> history.get(${s}, ${i}) failed`),e}if(h){let e=iO(c,s,t);await global.Linking.openURL(e,this.client.name)}else{let e=r.request.method,i=o||a7[e].res;this.client.core.relayer.publish(s,t,i)}await this.client.core.history.resolve(l)}),of(this,"cleanup",async()=>{let e=[],t=[];this.client.session.getAll().forEach(t=>{let r=!1;eg(t.expiry)&&(r=!0),this.client.core.crypto.keychain.has(t.topic)||(r=!0),r&&e.push(t.topic)}),this.client.proposal.getAll().forEach(e=>{eg(e.expiryTimestamp)&&t.push(e.id)}),await Promise.all([...e.map(e=>this.deleteSession({topic:e})),...t.map(e=>this.deleteProposal(e))])}),of(this,"onProviderMessageEvent",async e=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(e):await this.onRelayMessage(e)}),of(this,"onRelayEventRequest",async e=>{this.requestQueue.queue.push(e),await this.processRequestsQueue()}),of(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===ot.active){this.client.logger.info("Request queue already active, skipping...");return}for(this.client.logger.info(`Request queue starting with ${this.requestQueue.queue.length} requests`);this.requestQueue.queue.length>0;){this.requestQueue.state=ot.active;let e=this.requestQueue.queue.shift();if(e)try{await this.processRequest(e)}catch(e){this.client.logger.warn(e)}}this.requestQueue.state=ot.idle}),of(this,"processRequest",async e=>{let{topic:t,payload:r,attestation:i,transportType:s,encryptedId:n}=e,a=r.method;if(!this.shouldIgnorePairingRequest({topic:t,requestMethod:a}))switch(a){case"wc_sessionPropose":return await this.onSessionProposeRequest({topic:t,payload:r,attestation:i,encryptedId:n});case"wc_sessionSettle":return await this.onSessionSettleRequest(t,r);case"wc_sessionUpdate":return await this.onSessionUpdateRequest(t,r);case"wc_sessionExtend":return await this.onSessionExtendRequest(t,r);case"wc_sessionPing":return await this.onSessionPingRequest(t,r);case"wc_sessionDelete":return await this.onSessionDeleteRequest(t,r);case"wc_sessionRequest":return await this.onSessionRequest({topic:t,payload:r,attestation:i,encryptedId:n,transportType:s});case"wc_sessionEvent":return await this.onSessionEventRequest(t,r);case"wc_sessionAuthenticate":return await this.onSessionAuthenticateRequest({topic:t,payload:r,attestation:i,encryptedId:n,transportType:s});default:return this.client.logger.info(`Unsupported request method ${a}`)}}),of(this,"onRelayEventResponse",async e=>{let{topic:t,payload:r,transportType:i}=e,s=(await this.client.core.history.get(t,r.id)).request.method;switch(s){case"wc_sessionPropose":return this.onSessionProposeResponse(t,r,i);case"wc_sessionSettle":return this.onSessionSettleResponse(t,r);case"wc_sessionUpdate":return this.onSessionUpdateResponse(t,r);case"wc_sessionExtend":return this.onSessionExtendResponse(t,r);case"wc_sessionPing":return this.onSessionPingResponse(t,r);case"wc_sessionRequest":return this.onSessionRequestResponse(t,r);case"wc_sessionAuthenticate":return this.onSessionAuthenticateResponse(t,r);default:return this.client.logger.info(`Unsupported response method ${s}`)}}),of(this,"onRelayEventUnknownPayload",e=>{let{topic:t}=e,{message:r}=iV("MISSING_OR_INVALID",`Decoded payload on topic ${t} is not identifiable as a JSON-RPC request or a response.`);throw Error(r)}),of(this,"shouldIgnorePairingRequest",e=>{let{topic:t,requestMethod:r}=e,i=this.expectedPairingMethodMap.get(t);return!(!i||i.includes(r))&&!!(i.includes("wc_sessionAuthenticate")&&this.client.events.listenerCount("session_authenticate")>0)}),of(this,"onSessionProposeRequest",async e=>{let{topic:t,payload:r,attestation:i,encryptedId:s}=e,{params:n,id:a}=r;try{let e=this.client.core.eventClient.getEvent({topic:t});0===this.client.events.listenerCount("session_proposal")&&(console.warn("No listener for session_proposal event"),e?.setError(sS.proposal_listener_not_found)),this.isValidConnect(op({},r.params));let o=n.expiryTimestamp||ep(a7.wc_sessionPropose.req.ttl),c=op({id:a,pairingTopic:t,expiryTimestamp:o},n);await this.setProposal(a,c);let l=await this.getVerifyContext({attestationId:i,hash:ig(JSON.stringify(r)),encryptedId:s,metadata:c.proposer.metadata});e?.addTrace(s_.emit_session_proposal),this.client.events.emit("session_proposal",{id:a,params:c,verifyContext:l})}catch(e){await this.sendError({id:a,topic:t,error:e,rpcOpts:a7.wc_sessionPropose.autoReject}),this.client.logger.error(e)}}),of(this,"onSessionProposeResponse",async(e,t,r)=>{let{id:i}=t;if((0,sr.isJsonRpcResult)(t)){let{result:s}=t;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",result:s});let n=this.client.proposal.get(i);this.client.logger.trace({type:"method",method:"onSessionProposeResponse",proposal:n});let a=n.proposer.publicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",selfPublicKey:a});let o=s.responderPublicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",peerPublicKey:o});let c=await this.client.core.crypto.generateSharedKey(a,o);this.pendingSessions.set(i,{sessionTopic:c,pairingTopic:e,proposalId:i,publicKey:a});let l=await this.client.core.relayer.subscribe(c,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:l}),await this.client.core.pairing.activate({topic:e})}else if((0,sr.isJsonRpcError)(t)){await this.client.proposal.delete(i,iz("USER_DISCONNECTED"));let e=ef("session_connect",i);if(0===this.events.listenerCount(e))throw Error(`emitting ${e} without any listeners, 954`);this.events.emit(e,{error:t.error})}}),of(this,"onSessionSettleRequest",async(e,t)=>{let{id:r,params:i}=t;try{this.isValidSessionSettleRequest(i);let{relay:r,controller:s,expiry:n,namespaces:a,sessionProperties:o,scopedProperties:c,sessionConfig:l}=t.params,h=[...this.pendingSessions.values()].find(t=>t.sessionTopic===e);if(!h)return this.client.logger.error(`Pending session not found for topic ${e}`);let d=this.client.proposal.get(h.proposalId),u=og(op(op(op({topic:e,relay:r,expiry:n,namespaces:a,acknowledged:!0,pairingTopic:h.pairingTopic,requiredNamespaces:d.requiredNamespaces,optionalNamespaces:d.optionalNamespaces,controller:s.publicKey,self:{publicKey:h.publicKey,metadata:this.client.metadata},peer:{publicKey:s.publicKey,metadata:s.metadata}},o&&{sessionProperties:o}),c&&{scopedProperties:c}),l&&{sessionConfig:l}),{transportType:sf.relay});await this.client.session.set(u.topic,u),await this.setExpiry(u.topic,u.expiry),await this.client.core.pairing.updateMetadata({topic:h.pairingTopic,metadata:u.peer.metadata}),this.client.events.emit("session_connect",{session:u}),this.events.emit(ef("session_connect",h.proposalId),{session:u}),this.pendingSessions.delete(h.proposalId),this.deleteProposal(h.proposalId,!1),this.cleanupDuplicatePairings(u),await this.sendResult({id:t.id,topic:e,result:!0,throwOnFailedPublish:!0})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionSettleResponse",async(e,t)=>{let{id:r}=t;(0,sr.isJsonRpcResult)(t)?(await this.client.session.update(e,{acknowledged:!0}),this.events.emit(ef("session_approve",r),{})):(0,sr.isJsonRpcError)(t)&&(await this.client.session.delete(e,iz("USER_DISCONNECTED")),this.events.emit(ef("session_approve",r),{error:t.error}))}),of(this,"onSessionUpdateRequest",async(e,t)=>{let{params:r,id:i}=t;try{let t=`${e}_session_update`,s=se.get(t);if(s&&this.isRequestOutOfSync(s,i)){this.client.logger.warn(`Discarding out of sync request - ${i}`),this.sendError({id:i,topic:e,error:iz("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(op({topic:e},r));try{se.set(t,i),await this.client.session.update(e,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:e,result:!0,throwOnFailedPublish:!0})}catch(e){throw se.delete(t),e}this.client.events.emit("session_update",{id:i,topic:e,params:r})}catch(t){await this.sendError({id:i,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"isRequestOutOfSync",(e,t)=>t.toString().slice(0,-3)<e.toString().slice(0,-3)),of(this,"onSessionUpdateResponse",(e,t)=>{let{id:r}=t,i=ef("session_update",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_update",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_update",r),{error:t.error})}),of(this,"onSessionExtendRequest",async(e,t)=>{let{id:r}=t;try{this.isValidExtend({topic:e}),await this.setExpiry(e,ep(a9)),await this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_extend",{id:r,topic:e})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionExtendResponse",(e,t)=>{let{id:r}=t,i=ef("session_extend",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_extend",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_extend",r),{error:t.error})}),of(this,"onSessionPingRequest",async(e,t)=>{let{id:r}=t;try{this.isValidPing({topic:e}),await this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_ping",{id:r,topic:e})}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionPingResponse",(e,t)=>{let{id:r}=t,i=ef("session_ping",r);setTimeout(()=>{if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners 2176`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_ping",r),{}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_ping",r),{error:t.error})},500)}),of(this,"onSessionDeleteRequest",async(e,t)=>{let{id:r}=t;try{this.isValidDisconnect({topic:e,reason:t.params}),Promise.all([new Promise(t=>{this.client.core.relayer.once(su.publish,async()=>{t(await this.deleteSession({topic:e,id:r}))})}),this.sendResult({id:r,topic:e,result:!0,throwOnFailedPublish:!0}),this.cleanupPendingSentRequestsForTopic({topic:e,error:iz("USER_DISCONNECTED")})]).catch(e=>this.client.logger.error(e))}catch(e){this.client.logger.error(e)}}),of(this,"onSessionRequest",async e=>{var t,r,i;let{topic:s,payload:n,attestation:a,encryptedId:o,transportType:c}=e,{id:l,params:h}=n;try{await this.isValidRequest(op({topic:s},h));let e=this.client.session.get(s),n=await this.getVerifyContext({attestationId:a,hash:ig(JSON.stringify((0,sr.formatJsonRpcRequest)("wc_sessionRequest",h,l))),encryptedId:o,metadata:e.peer.metadata,transportType:c}),d={id:l,topic:s,params:h,verifyContext:n};await this.setPendingSessionRequest(d),c===sf.link_mode&&null!=(t=e.peer.metadata.redirect)&&t.universal&&this.client.core.addLinkModeSupportedApp(null==(r=e.peer.metadata.redirect)?void 0:r.universal),null!=(i=this.client.signConfig)&&i.disableRequestQueue?this.emitSessionRequest(d):(this.addSessionRequestToSessionRequestQueue(d),this.processSessionRequestQueue())}catch(e){await this.sendError({id:l,topic:s,error:e}),this.client.logger.error(e)}}),of(this,"onSessionRequestResponse",(e,t)=>{let{id:r}=t,i=ef("session_request",r);if(0===this.events.listenerCount(i))throw Error(`emitting ${i} without any listeners`);(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_request",r),{result:t.result}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_request",r),{error:t.error})}),of(this,"onSessionEventRequest",async(e,t)=>{let{id:r,params:i}=t;try{let t=`${e}_session_event_${i.event.name}`,s=se.get(t);if(s&&this.isRequestOutOfSync(s,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(op({topic:e},i)),this.client.events.emit("session_event",{id:r,topic:e,params:i}),se.set(t,r)}catch(t){await this.sendError({id:r,topic:e,error:t}),this.client.logger.error(t)}}),of(this,"onSessionAuthenticateResponse",(e,t)=>{let{id:r}=t;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:e,payload:t}),(0,sr.isJsonRpcResult)(t)?this.events.emit(ef("session_request",r),{result:t.result}):(0,sr.isJsonRpcError)(t)&&this.events.emit(ef("session_request",r),{error:t.error})}),of(this,"onSessionAuthenticateRequest",async e=>{var t;let{topic:r,payload:i,attestation:s,encryptedId:n,transportType:a}=e;try{let{requester:e,authPayload:o,expiryTimestamp:c}=i.params,l=await this.getVerifyContext({attestationId:s,hash:ig(JSON.stringify(i)),encryptedId:n,metadata:e.metadata,transportType:a}),h={requester:e,pairingTopic:r,id:i.id,authPayload:o,verifyContext:l,expiryTimestamp:c};await this.setAuthRequest(i.id,{request:h,pairingTopic:r,transportType:a}),a===sf.link_mode&&null!=(t=e.metadata.redirect)&&t.universal&&this.client.core.addLinkModeSupportedApp(e.metadata.redirect.universal),this.client.events.emit("session_authenticate",{topic:r,params:i.params,id:i.id,verifyContext:l})}catch(n){this.client.logger.error(n);let e=i.params.requester.publicKey,t=await this.client.core.crypto.generateKeyPair(),s=this.getAppLinkIfEnabled(i.params.requester.metadata,a);await this.sendError({id:i.id,topic:r,error:n,encodeOpts:{type:1,receiverPublicKey:e,senderPublicKey:t},rpcOpts:a7.wc_sessionAuthenticate.autoReject,appLink:s})}}),of(this,"addSessionRequestToSessionRequestQueue",e=>{this.sessionRequestQueue.queue.push(e)}),of(this,"cleanupAfterResponse",e=>{this.deletePendingSessionRequest(e.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=ot.idle,this.processSessionRequestQueue()},(0,R.toMiliseconds)(this.requestQueueDelay))}),of(this,"cleanupPendingSentRequestsForTopic",({topic:e,error:t})=>{let r=this.client.core.history.pending;r.length>0&&r.filter(t=>t.topic===e&&"wc_sessionRequest"===t.request.method).forEach(e=>{let r=ef("session_request",e.request.id);if(0===this.events.listenerCount(r))throw Error(`emitting ${r} without any listeners`);this.events.emit(ef("session_request",e.request.id),{error:t})})}),of(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===ot.active){this.client.logger.info("session request queue is already active.");return}let e=this.sessionRequestQueue.queue[0];if(!e){this.client.logger.info("session request queue is empty.");return}try{this.sessionRequestQueue.state=ot.active,this.emitSessionRequest(e)}catch(e){this.client.logger.error(e)}}),of(this,"emitSessionRequest",e=>{this.client.events.emit("session_request",e)}),of(this,"onPairingCreated",e=>{if(e.methods&&this.expectedPairingMethodMap.set(e.topic,e.methods),e.active)return;let t=this.client.proposal.getAll().find(t=>t.pairingTopic===e.topic);t&&this.onSessionProposeRequest({topic:e.topic,payload:(0,sr.formatJsonRpcRequest)("wc_sessionPropose",og(op({},t),{requiredNamespaces:t.requiredNamespaces,optionalNamespaces:t.optionalNamespaces,relays:t.relays,proposer:t.proposer,sessionProperties:t.sessionProperties,scopedProperties:t.scopedProperties}),t.id)})}),of(this,"isValidConnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`connect() params: ${JSON.stringify(e)}`);throw Error(t)}let{pairingTopic:t,requiredNamespaces:r,optionalNamespaces:i,sessionProperties:s,scopedProperties:n,relays:a}=e;if(iG(t)||await this.isValidPairingTopic(t),!function(e,t){let r=!1;return t&&!e?r=!0:e&&iK(e)&&e.length&&e.forEach(e=>{r=i2(e)}),r}(a,!0)){let{message:e}=iV("MISSING_OR_INVALID",`connect() relays: ${a}`);throw Error(e)}if(!iG(r)&&0!==iJ(r)){let e="requiredNamespaces are deprecated and are automatically assigned to optionalNamespaces";["fatal","error","silent"].includes(this.client.logger.level)?console.warn(e):this.client.logger.warn(e),this.validateNamespaces(r,"requiredNamespaces")}if(iG(i)||0===iJ(i)||this.validateNamespaces(i,"optionalNamespaces"),iG(s)||this.validateSessionProps(s,"sessionProperties"),!iG(n)){this.validateSessionProps(n,"scopedProperties");let e=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(n).every(t=>e.includes(t)))throw Error(`Scoped properties must be a subset of required/optional namespaces, received: ${JSON.stringify(n)}, required/optional namespaces: ${JSON.stringify(e)}`)}}),of(this,"validateNamespaces",(e,t)=>{let r=function(e,t,r){let i=null;if(e&&iJ(e)){let s;let n=i0(e,t);n&&(i=n);let a=(s=null,Object.entries(e).forEach(([e,i])=>{var n,a;let o;if(s)return;let c=(n=F(e,i),a=`${t} ${r}`,o=null,iK(n)&&n.length?n.forEach(e=>{o||iZ(e)||(o=iz("UNSUPPORTED_CHAINS",`${a}, chain ${e} should be a string and conform to "namespace:chainId" format`))}):iZ(e)||(o=iz("UNSUPPORTED_CHAINS",`${a}, chains must be defined as "namespace:chainId" e.g. "eip155:1": {...} in the namespace key OR as an array of CAIP-2 chainIds e.g. eip155: { chains: ["eip155:1", "eip155:5"] }`)),o);c&&(s=c)}),s);a&&(i=a)}else i=iV("MISSING_OR_INVALID",`${t}, ${r} should be an object with data`);return i}(e,"connect()",t);if(r)throw Error(r.message)}),of(this,"isValidApprove",async e=>{if(!i5(e))throw Error(iV("MISSING_OR_INVALID",`approve() params: ${e}`).message);let{id:t,namespaces:r,relayProtocol:i,sessionProperties:s,scopedProperties:n}=e;this.checkRecentlyDeleted(t),await this.isValidProposalId(t);let a=this.client.proposal.get(t),o=i1(r,"approve()");if(o)throw Error(o.message);let c=i8(a.requiredNamespaces,r,"approve()");if(c)throw Error(c.message);if(!iY(i,!0)){let{message:e}=iV("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw Error(e)}if(iG(s)||this.validateSessionProps(s,"sessionProperties"),!iG(n)){this.validateSessionProps(n,"scopedProperties");let e=new Set(Object.keys(r));if(!Object.keys(n).every(t=>e.has(t)))throw Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(n)}, approved namespaces: ${Array.from(e).join(", ")}`)}}),of(this,"isValidReject",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`reject() params: ${e}`);throw Error(t)}let{id:t,reason:r}=e;if(this.checkRecentlyDeleted(t),await this.isValidProposalId(t),!function(e){return!(!e||"object"!=typeof e||!e.code||!iX(e.code,!1)||!e.message||!iY(e.message,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw Error(e)}}),of(this,"isValidSessionSettleRequest",e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${e}`);throw Error(t)}let{relay:t,controller:r,namespaces:i,expiry:s}=e;if(!i2(t)){let{message:e}=iV("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw Error(e)}let n=function(e,t){let r=null;return iY(e?.publicKey,!1)||(r=iV("MISSING_OR_INVALID",`${t} controller public key should be a string`)),r}(r,"onSessionSettleRequest()");if(n)throw Error(n.message);let a=i1(i,"onSessionSettleRequest()");if(a)throw Error(a.message);if(eg(s)){let{message:e}=iV("EXPIRED","onSessionSettleRequest()");throw Error(e)}}),of(this,"isValidUpdate",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`update() params: ${e}`);throw Error(t)}let{topic:t,namespaces:r}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t);let i=this.client.session.get(t),s=i1(r,"update()");if(s)throw Error(s.message);let n=i8(i.requiredNamespaces,r,"update()");if(n)throw Error(n.message)}),of(this,"isValidExtend",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`extend() params: ${e}`);throw Error(t)}let{topic:t}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t)}),of(this,"isValidRequest",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`request() params: ${e}`);throw Error(t)}let{topic:t,request:r,chainId:i,expiry:s}=e;this.checkRecentlyDeleted(t),await this.isValidSessionTopic(t);let{namespaces:n}=this.client.session.get(t);if(!i3(n,i)){let{message:e}=iV("MISSING_OR_INVALID",`request() chainId: ${i}`);throw Error(e)}if(!function(e){return!(iG(e)||!iY(e.method,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw Error(e)}if(!function(e,t,r){return!!iY(r,!1)&&(function(e,t){let r=[];return Object.values(e).forEach(e=>{iL(e.accounts).includes(t)&&r.push(...e.methods)}),r})(e,t).includes(r)}(n,i,r.method)){let{message:e}=iV("MISSING_OR_INVALID",`request() method: ${r.method}`);throw Error(e)}if(s&&!function(e,t){return iX(e,!1)&&e<=t.max&&e>=t.min}(s,oe)){let{message:e}=iV("MISSING_OR_INVALID",`request() expiry: ${s}. Expiry must be a number (in seconds) between ${oe.min} and ${oe.max}`);throw Error(e)}}),of(this,"isValidRespond",async e=>{var t;if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`respond() params: ${e}`);throw Error(t)}let{topic:r,response:i}=e;try{await this.isValidSessionTopic(r)}catch(r){throw null!=(t=e?.response)&&t.id&&this.cleanupAfterResponse(e),r}if(!function(e){return!(iG(e)||iG(e.result)&&iG(e.error)||!iX(e.id,!1)||!iY(e.jsonrpc,!1))}(i)){let{message:e}=iV("MISSING_OR_INVALID",`respond() response: ${JSON.stringify(i)}`);throw Error(e)}}),of(this,"isValidPing",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`ping() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidSessionOrPairingTopic(t)}),of(this,"isValidEmit",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`emit() params: ${e}`);throw Error(t)}let{topic:t,event:r,chainId:i}=e;await this.isValidSessionTopic(t);let{namespaces:s}=this.client.session.get(t);if(!i3(s,i)){let{message:e}=iV("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw Error(e)}if(!function(e){return!(iG(e)||!iY(e.name,!1))}(r)){let{message:e}=iV("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw Error(e)}if(!function(e,t,r){return!!iY(r,!1)&&(function(e,t){let r=[];return Object.values(e).forEach(e=>{iL(e.accounts).includes(t)&&r.push(...e.events)}),r})(e,t).includes(r)}(s,i,r.name)){let{message:e}=iV("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw Error(e)}}),of(this,"isValidDisconnect",async e=>{if(!i5(e)){let{message:t}=iV("MISSING_OR_INVALID",`disconnect() params: ${e}`);throw Error(t)}let{topic:t}=e;await this.isValidSessionOrPairingTopic(t)}),of(this,"isValidAuthenticate",e=>{let{chains:t,uri:r,domain:i,nonce:s}=e;if(!Array.isArray(t)||0===t.length)throw Error("chains is required and must be a non-empty array");if(!iY(r,!1))throw Error("uri is required parameter");if(!iY(i,!1))throw Error("domain is required parameter");if(!iY(s,!1))throw Error("nonce is required parameter");if([...new Set(t.map(e=>B(e).namespace))].length>1)throw Error("Multi-namespace requests are not supported. Please request single namespace only.");let{namespace:n}=B(t[0]);if("eip155"!==n)throw Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),of(this,"getVerifyContext",async e=>{let{attestationId:t,hash:r,encryptedId:i,metadata:s,transportType:n}=e,a={verified:{verifyUrl:s.verifyUrl||sN,validation:"UNKNOWN",origin:s.url||""}};try{if(n===sf.link_mode){let e=this.getAppLinkIfEnabled(s,n);return a.verified.validation=e&&new URL(e).origin===new URL(s.url).origin?"VALID":"INVALID",a}let e=await this.client.core.verify.resolve({attestationId:t,hash:r,encryptedId:i,verifyUrl:s.verifyUrl});e&&(a.verified.origin=e.origin,a.verified.isScam=e.isScam,a.verified.validation=e.origin===new URL(s.url).origin?"VALID":"INVALID")}catch(e){this.client.logger.warn(e)}return this.client.logger.debug(`Verify context: ${JSON.stringify(a)}`),a}),of(this,"validateSessionProps",(e,t)=>{Object.values(e).forEach((r,i)=>{if(null==r){let{message:s}=iV("MISSING_OR_INVALID",`${t} must contain an existing value for each key. Received: ${r} for key ${Object.keys(e)[i]}`);throw Error(s)}})}),of(this,"getPendingAuthRequest",e=>{let t=this.client.auth.requests.get(e);return"object"==typeof t?t:void 0}),of(this,"addToRecentlyDeleted",(e,t)=>{if(this.recentlyDeletedMap.set(e,t),this.recentlyDeletedMap.size>=this.recentlyDeletedLimit){let e=0,t=this.recentlyDeletedLimit/2;for(let r of this.recentlyDeletedMap.keys()){if(e++>=t)break;this.recentlyDeletedMap.delete(r)}}}),of(this,"checkRecentlyDeleted",e=>{let t=this.recentlyDeletedMap.get(e);if(t){let{message:r}=iV("MISSING_OR_INVALID",`Record was recently deleted - ${t}: ${e}`);throw Error(r)}}),of(this,"isLinkModeEnabled",(e,t)=>{var r,i,s,n,a,o,c,l,h;return!!e&&t===sf.link_mode&&(null==(i=null==(r=this.client.metadata)?void 0:r.redirect)?void 0:i.linkMode)===!0&&(null==(n=null==(s=this.client.metadata)?void 0:s.redirect)?void 0:n.universal)!==void 0&&(null==(o=null==(a=this.client.metadata)?void 0:a.redirect)?void 0:o.universal)!==""&&(null==(c=e?.redirect)?void 0:c.universal)!==void 0&&(null==(l=e?.redirect)?void 0:l.universal)!==""&&(null==(h=e?.redirect)?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(e.redirect.universal)&&"u">typeof(null==global?void 0:global.Linking)}),of(this,"getAppLinkIfEnabled",(e,t)=>{var r;return this.isLinkModeEnabled(e,t)?null==(r=e?.redirect)?void 0:r.universal:void 0}),of(this,"handleLinkModeMessage",({url:e})=>{if(!e||!e.includes("wc_ev")||!e.includes("topic"))return;let t=eb(e,"topic")||"",r=decodeURIComponent(eb(e,"wc_ev")||""),i=this.client.session.keys.includes(t);i&&this.client.session.update(t,{transportType:sf.link_mode}),this.client.core.dispatchEnvelope({topic:t,message:r,sessionExists:i})}),of(this,"registerLinkModeListeners",async()=>{var e;if(eC()||ee()&&null!=(e=this.client.metadata.redirect)&&e.linkMode){let e=null==global?void 0:global.Linking;if("u">typeof e){e.addEventListener("url",this.handleLinkModeMessage,this.client.name);let t=await e.getInitialURL();t&&setTimeout(()=>{this.handleLinkModeMessage({url:t})},50)}}}),of(this,"shouldSetTVF",(e,t)=>{if(!t||"wc_sessionRequest"!==e)return!1;let{request:r}=t;return Object.keys(or).includes(r.method)}),of(this,"getTVFParams",(e,t,r)=>{var i,s;try{let n=t.request.method,a=this.extractTxHashesFromResult(n,r);return og(op({correlationId:e,rpcMethods:[n],chainId:t.chainId},this.isValidContractData(t.request.params)&&{contractAddresses:[null==(s=null==(i=t.request.params)?void 0:i[0])?void 0:s.to]}),{txHashes:a})}catch(e){this.client.logger.warn("Error getting TVF params",e)}return{}}),of(this,"isValidContractData",e=>{var t;if(!e)return!1;try{let r=e?.data||(null==(t=e?.[0])?void 0:t.data);if(!r.startsWith("0x"))return!1;let i=r.slice(2);return!!/^[0-9a-fA-F]*$/.test(i)&&i.length%2==0}catch{}return!1}),of(this,"extractTxHashesFromResult",(e,t)=>{try{let r=or[e];if("string"==typeof t)return[t];let i=t[r.key];if(iK(i))return"solana_signAllTransactions"===e?i.map(e=>(function(e){let t=atob(e),r=new Uint8Array(t.length);for(let e=0;e<t.length;e++)r[e]=t.charCodeAt(e);let i=r[0];if(0===i)throw Error("No signatures found");if(r.length<1+64*i)throw Error("Transaction data too short for claimed signature count");if(r.length<100)throw Error("Transaction too short");let s=Buffer.from(e,"base64").slice(1,65);return L.Z.encode(s)})(e)):i;if("string"==typeof i)return[i]}catch(e){this.client.logger.warn("Error extracting tx hashes from result",e)}return[]})}async processPendingMessageEvents(){try{let e=this.client.session.keys,t=this.client.core.relayer.messages.getWithoutAck(e);for(let[e,r]of Object.entries(t))for(let t of r)try{await this.onProviderMessageEvent({topic:e,message:t,publishedAt:Date.now()})}catch{this.client.logger.warn(`Error processing pending message event for topic: ${e}, message: ${t}`)}}catch(e){this.client.logger.warn("processPendingMessageEvents failed",e)}}isInitialized(){if(!this.initialized){let{message:e}=iV("NOT_INITIALIZED",this.name);throw Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(su.message,e=>{this.onProviderMessageEvent(e)})}async onRelayMessage(e){let{topic:t,message:r,attestation:i,transportType:s}=e,{publicKey:n}=this.client.auth.authKeys.keys.includes(on)?this.client.auth.authKeys.get(on):{responseTopic:void 0,publicKey:void 0};try{let e=await this.client.core.crypto.decode(t,r,{receiverPublicKey:n,encoding:s===sf.link_mode?ih:il});(0,sr.isJsonRpcRequest)(e)?(this.client.core.history.set(t,e),await this.onRelayEventRequest({topic:t,payload:e,attestation:i,transportType:s,encryptedId:ig(r)})):(0,sr.isJsonRpcResponse)(e)?(await this.client.core.history.resolve(e),await this.onRelayEventResponse({topic:t,payload:e,transportType:s}),this.client.core.history.delete(t,e.id)):await this.onRelayEventUnknownPayload({topic:t,payload:e,transportType:s}),await this.client.core.relayer.messages.ack(t,r)}catch(e){this.client.logger.error(e)}}registerExpirerEvents(){this.client.core.expirer.on(sE.expired,async e=>{let{topic:t,id:r}=eu(e.target);return r&&this.client.pendingRequest.keys.includes(r)?await this.deletePendingSessionRequest(r,iV("EXPIRED"),!0):r&&this.client.auth.requests.keys.includes(r)?await this.deletePendingAuthRequest(r,iV("EXPIRED"),!0):void(t?this.client.session.keys.includes(t)&&(await this.deleteSession({topic:t,expirerHasDeleted:!0}),this.client.events.emit("session_expire",{topic:t})):r&&(await this.deleteProposal(r,!0),this.client.events.emit("proposal_expire",{id:r})))})}registerPairingEvents(){this.client.core.pairing.events.on(sv.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(sv.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw Error(t)}if(!this.client.core.pairing.pairings.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.core.pairing.pairings.get(e).expiry)){let{message:t}=iV("EXPIRED",`pairing topic: ${e}`);throw Error(t)}}async isValidSessionTopic(e){if(!iY(e,!1)){let{message:t}=iV("MISSING_OR_INVALID",`session topic should be a string: ${e}`);throw Error(t)}if(this.checkRecentlyDeleted(e),!this.client.session.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});let{message:t}=iV("EXPIRED",`session topic: ${e}`);throw Error(t)}if(!this.client.core.crypto.keychain.has(e)){let{message:t}=iV("MISSING_OR_INVALID",`session topic does not exist in keychain: ${e}`);throw await this.deleteSession({topic:e}),Error(t)}}async isValidSessionOrPairingTopic(e){if(this.checkRecentlyDeleted(e),this.client.session.keys.includes(e))await this.isValidSessionTopic(e);else if(this.client.core.pairing.pairings.keys.includes(e))this.isValidPairingTopic(e);else if(iY(e,!1)){let{message:t}=iV("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw Error(t)}else{let{message:t}=iV("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw Error(t)}}async isValidProposalId(e){if("number"!=typeof e){let{message:t}=iV("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw Error(t)}if(!this.client.proposal.keys.includes(e)){let{message:t}=iV("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw Error(t)}if(eg(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);let{message:t}=iV("EXPIRED",`proposal id: ${e}`);throw Error(t)}}}class ow extends av{constructor(e,t){super(e,t,"proposal",a3),this.core=e,this.logger=t}}class oy extends av{constructor(e,t){super(e,t,"session",a3),this.core=e,this.logger=t}}class ob extends av{constructor(e,t){super(e,t,"request",a3,e=>e.id),this.core=e,this.logger=t}}class ov extends av{constructor(e,t){super(e,t,"authKeys",os,()=>on),this.core=e,this.logger=t}}class oC extends av{constructor(e,t){super(e,t,"pairingTopics",os),this.core=e,this.logger=t}}class oE extends av{constructor(e,t){super(e,t,"requests",os,e=>e.id),this.core=e,this.logger=t}}var oN=Object.defineProperty,oI=(e,t,r)=>t in e?oN(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,oA=(e,t,r)=>oI(e,"symbol"!=typeof t?t+"":t,r);class o_{constructor(e,t){this.core=e,this.logger=t,oA(this,"authKeys"),oA(this,"pairingTopics"),oA(this,"requests"),this.authKeys=new ov(this.core,this.logger),this.pairingTopics=new oC(this.core,this.logger),this.requests=new oE(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var oS=Object.defineProperty,oO=(e,t,r)=>t in e?oS(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,oP=(e,t,r)=>oO(e,"symbol"!=typeof t?t+"":t,r);class oT extends P{constructor(e){super(e),oP(this,"protocol","wc"),oP(this,"version",2),oP(this,"name",a8.name),oP(this,"metadata"),oP(this,"core"),oP(this,"logger"),oP(this,"events",new i.EventEmitter),oP(this,"engine"),oP(this,"session"),oP(this,"proposal"),oP(this,"pendingRequest"),oP(this,"auth"),oP(this,"signConfig"),oP(this,"on",(e,t)=>this.events.on(e,t)),oP(this,"once",(e,t)=>this.events.once(e,t)),oP(this,"off",(e,t)=>this.events.off(e,t)),oP(this,"removeListener",(e,t)=>this.events.removeListener(e,t)),oP(this,"removeAllListeners",e=>this.events.removeAllListeners(e)),oP(this,"connect",async e=>{try{return await this.engine.connect(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"pair",async e=>{try{return await this.engine.pair(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"approve",async e=>{try{return await this.engine.approve(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"reject",async e=>{try{return await this.engine.reject(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"update",async e=>{try{return await this.engine.update(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"extend",async e=>{try{return await this.engine.extend(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"request",async e=>{try{return await this.engine.request(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"respond",async e=>{try{return await this.engine.respond(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"ping",async e=>{try{return await this.engine.ping(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"emit",async e=>{try{return await this.engine.emit(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"disconnect",async e=>{try{return await this.engine.disconnect(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"find",e=>{try{return this.engine.find(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(e){throw this.logger.error(e.message),e}}),oP(this,"authenticate",async(e,t)=>{try{return await this.engine.authenticate(e,t)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"formatAuthMessage",e=>{try{return this.engine.formatAuthMessage(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"approveSessionAuthenticate",async e=>{try{return await this.engine.approveSessionAuthenticate(e)}catch(e){throw this.logger.error(e.message),e}}),oP(this,"rejectSessionAuthenticate",async e=>{try{return await this.engine.rejectSessionAuthenticate(e)}catch(e){throw this.logger.error(e.message),e}}),this.name=e?.name||a8.name,this.metadata=function(e){var t,r;let i=es();try{return null!=e&&e.url&&i.url&&new URL(e.url).host!==new URL(i.url).host&&(console.warn(`The configured WalletConnect 'metadata.url':${e.url} differs from the actual page url:${i.url}. This is probably unintended and can lead to issues.`),e.url=i.url),null!=(t=e?.icons)&&t.length&&e.icons.length>0&&(e.icons=e.icons.filter(e=>""!==e)),X(Y(Y({},i),e),{url:e?.url||i.url,name:e?.name||i.name,description:e?.description||i.description,icons:null!=(r=e?.icons)&&r.length&&e.icons.length>0?e.icons:i.icons})}catch(t){return console.warn("Error populating app metadata",t),e||i}}(e?.metadata),this.signConfig=e?.signConfig;let t="u">typeof e?.logger&&"string"!=typeof e?.logger?e.logger:(0,o.gw)((0,o.jI)({level:e?.logger||a8.logger}));this.core=e?.core||new a2(e),this.logger=(0,o.Ep)(t,this.name),this.session=new oy(this.core,this.logger),this.proposal=new ow(this.core,this.logger),this.pendingRequest=new ob(this.core,this.logger),this.engine=new om(this),this.auth=new o_(this.core,this.logger)}static async init(e){let t=new oT(e);return await t.initialize(),t}get context(){return(0,o.Fd)(this.logger)}get pairing(){return this.core.pairing.pairings}async initialize(){this.logger.trace("Initialized");try{await this.core.start(),await this.session.init(),await this.proposal.init(),await this.pendingRequest.init(),await this.auth.init(),await this.engine.init(),this.logger.info("SignClient Initialization Success"),setTimeout(()=>{this.engine.processRelayMessageCache()},(0,R.toMiliseconds)(R.ONE_SECOND))}catch(e){throw this.logger.info("SignClient Initialization Failure"),this.logger.error(e.message),e}}}var oR=r(60467);let ok="error",ox="wc@2:universal_provider:",oU="https://rpc.walletconnect.org/v1/",oD="generic",o$=`${oU}bundler`,oM={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};function oL(){}function oj(e){return null==e||"object"!=typeof e&&"function"!=typeof e}function oq(e){return ArrayBuffer.isView(e)&&!(e instanceof DataView)}function oB(e){return"object"==typeof e&&null!==e}function oF(e){return Object.getOwnPropertySymbols(e).filter(t=>Object.prototype.propertyIsEnumerable.call(e,t))}function oH(e){return null==e?void 0===e?"[object Undefined]":"[object Null]":Object.prototype.toString.call(e)}let oW="[object String]",oV="[object Number]",oz="[object Boolean]",oK="[object Arguments]";function oJ(e,t,r,i=new Map,s){let n=s?.(e,t,r,i);if(null!=n)return n;if(oj(e))return e;if(i.has(e))return i.get(e);if(Array.isArray(e)){let t=Array(e.length);i.set(e,t);for(let n=0;n<e.length;n++)t[n]=oJ(e[n],n,r,i,s);return Object.hasOwn(e,"index")&&(t.index=e.index),Object.hasOwn(e,"input")&&(t.input=e.input),t}if(e instanceof Date)return new Date(e.getTime());if(e instanceof RegExp){let t=new RegExp(e.source,e.flags);return t.lastIndex=e.lastIndex,t}if(e instanceof Map){let t=new Map;for(let[n,a]of(i.set(e,t),e))t.set(n,oJ(a,n,r,i,s));return t}if(e instanceof Set){let t=new Set;for(let n of(i.set(e,t),e))t.add(oJ(n,void 0,r,i,s));return t}if("u">typeof Buffer&&Buffer.isBuffer(e))return e.subarray();if(oq(e)){let t=new(Object.getPrototypeOf(e)).constructor(e.length);i.set(e,t);for(let n=0;n<e.length;n++)t[n]=oJ(e[n],n,r,i,s);return t}if(e instanceof ArrayBuffer||"u">typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer)return e.slice(0);if(e instanceof DataView){let t=new DataView(e.buffer.slice(0),e.byteOffset,e.byteLength);return i.set(e,t),oG(t,e,r,i,s),t}if("u">typeof File&&e instanceof File){let t=new File([e],e.name,{type:e.type});return i.set(e,t),oG(t,e,r,i,s),t}if(e instanceof Blob){let t=new Blob([e],{type:e.type});return i.set(e,t),oG(t,e,r,i,s),t}if(e instanceof Error){let t=new e.constructor;return i.set(e,t),t.message=e.message,t.name=e.name,t.stack=e.stack,t.cause=e.cause,oG(t,e,r,i,s),t}if("object"==typeof e&&function(e){switch(oH(e)){case oK:case"[object Array]":case"[object ArrayBuffer]":case"[object DataView]":case oz:case"[object Date]":case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Map]":case oV:case"[object Object]":case"[object RegExp]":case"[object Set]":case oW:case"[object Symbol]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return!0;default:return!1}}(e)){let t=Object.create(Object.getPrototypeOf(e));return i.set(e,t),oG(t,e,r,i,s),t}return e}function oG(e,t,r=e,i,s){let n=[...Object.keys(t),...oF(t)];for(let a=0;a<n.length;a++){let o=n[a],c=Object.getOwnPropertyDescriptor(e,o);(null==c||c.writable)&&(e[o]=oJ(t[o],o,r,i,s))}}function oY(e){var t;return t=(t,r,i,s)=>{let n=void 0;if(null!=n)return n;if("object"==typeof e)switch(Object.prototype.toString.call(e)){case oV:case oW:case oz:{let t=new e.constructor(e?.valueOf());return oG(t,e),t}case oK:{let t={};return oG(t,e),t.length=e.length,t[Symbol.iterator]=e[Symbol.iterator],t}default:return}},oJ(e,void 0,e,new Map,t)}function oX(e){return null!==e&&"object"==typeof e&&"[object Arguments]"===oH(e)}var oZ=Object.defineProperty,oQ=Object.defineProperties,o0=Object.getOwnPropertyDescriptors,o1=Object.getOwnPropertySymbols,o2=Object.prototype.hasOwnProperty,o5=Object.prototype.propertyIsEnumerable,o3=(e,t,r)=>t in e?oZ(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,o8=(e,t)=>{for(var r in t||(t={}))o2.call(t,r)&&o3(e,r,t[r]);if(o1)for(var r of o1(t))o5.call(t,r)&&o3(e,r,t[r]);return e},o4=(e,t)=>oQ(e,o0(t));function o6(e,t,r){var i;let s=B(e);return(null==(i=t.rpcMap)?void 0:i[s.reference])||`${oU}?chainId=${s.namespace}:${s.reference}&projectId=${r}`}function o9(e){return e.includes(":")?e.split(":")[1]:e}function o7(e){return e.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function ce(e={},t={}){return function(e,...t){return function(e,...t){let r=t.slice(0,-1),i=t[t.length-1],s=e;for(let e=0;e<r.length;e++)s=function e(t,r,i,s){if(oj(t)&&(t=Object(t)),null==r||"object"!=typeof r)return t;if(s.has(r))return function(e){if(oj(e))return e;if(Array.isArray(e)||oq(e)||e instanceof ArrayBuffer||"u">typeof SharedArrayBuffer&&e instanceof SharedArrayBuffer)return e.slice(0);let t=Object.getPrototypeOf(e),r=t.constructor;if(e instanceof Date||e instanceof Map||e instanceof Set)return new r(e);if(e instanceof RegExp){let t=new r(e);return t.lastIndex=e.lastIndex,t}if(e instanceof DataView)return new r(e.buffer.slice(0));if(e instanceof Error){let t=new r(e.message);return t.stack=e.stack,t.name=e.name,t.cause=e.cause,t}return"u">typeof File&&e instanceof File?new r([e],e.name,{type:e.type,lastModified:e.lastModified}):"object"==typeof e?Object.assign(Object.create(t),e):e}(s.get(r));if(s.set(r,t),Array.isArray(r)){r=r.slice();for(let e=0;e<r.length;e++)r[e]=r[e]??void 0}let n=[...Object.keys(r),...oF(r)];for(let a=0;a<n.length;a++){let o=n[a],c=r[o],l=t[o];if(oX(c)&&(c={...c}),oX(l)&&(l={...l}),"u">typeof Buffer&&Buffer.isBuffer(c)&&(c=oY(c)),Array.isArray(c)){if("object"==typeof l&&null!=l){let e=[],t=Reflect.ownKeys(l);for(let r=0;r<t.length;r++){let i=t[r];e[i]=l[i]}l=e}else l=[]}let h=i(l,c,o,t,r,s);null!=h?t[o]=h:Array.isArray(c)||oB(l)&&oB(c)?t[o]=e(l,c,i,s):null==l&&function(e){if("object"!=typeof e||null==e)return!1;if(null===Object.getPrototypeOf(e))return!0;if("[object Object]"!==Object.prototype.toString.call(e)){let t=e[Symbol.toStringTag];return!!(null!=t&&Object.getOwnPropertyDescriptor(e,Symbol.toStringTag)?.writable)&&e.toString()===`[object ${t}]`}let t=e;for(;null!==Object.getPrototypeOf(t);)t=Object.getPrototypeOf(t);return Object.getPrototypeOf(e)===t}(c)?t[o]=e({},c,i,s):null==l&&oq(c)?t[o]=oY(c):(void 0===l||void 0!==c)&&(t[o]=c)}return t}(s,r[e],i,new Map);return s}(e,...t,oL)}(ct(e),ct(t))}function ct(e){var t,r,i,s,n;let a={};if(!iJ(e))return a;for(let[o,c]of Object.entries(e)){let e=ij(o)?[o]:c.chains,l=c.methods||[],h=c.events||[],d=c.rpcMap||{},u=iq(o);a[u]=o4(o8(o8({},a[u]),c),{chains:em(e,null==(t=a[u])?void 0:t.chains),methods:em(l,null==(r=a[u])?void 0:r.methods),events:em(h,null==(i=a[u])?void 0:i.events)}),(iJ(d)||iJ((null==(s=a[u])?void 0:s.rpcMap)||{}))&&(a[u].rpcMap=o8(o8({},d),null==(n=a[u])?void 0:n.rpcMap))}return a}function cr(e){return e.includes(":")?e.split(":")[2]:e}function ci(e){let t={};for(let[r,i]of Object.entries(e)){let e=i.methods||[],s=i.events||[],n=i.accounts||[],a=ij(r)?[r]:i.chains?i.chains:o7(i.accounts);t[r]={chains:a,methods:e,events:s,accounts:n}}return t}function cs(e){return"number"==typeof e?e:e.includes("0x")?parseInt(e,16):isNaN(Number(e=e.includes(":")?e.split(":")[1]:e))?e:Number(e)}let cn={},ca=e=>cn[e],co=(e,t)=>{cn[e]=t};var cc=Object.defineProperty,cl=(e,t,r)=>t in e?cc(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,ch=(e,t,r)=>cl(e,"symbol"!=typeof t?t+"":t,r);class cd{constructor(e){ch(this,"name","polkadot"),ch(this,"client"),ch(this,"httpProviders"),ch(this,"events"),ch(this,"namespace"),ch(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cu=Object.defineProperty,cp=Object.defineProperties,cg=Object.getOwnPropertyDescriptors,cf=Object.getOwnPropertySymbols,cm=Object.prototype.hasOwnProperty,cw=Object.prototype.propertyIsEnumerable,cy=(e,t,r)=>t in e?cu(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cb=(e,t)=>{for(var r in t||(t={}))cm.call(t,r)&&cy(e,r,t[r]);if(cf)for(var r of cf(t))cw.call(t,r)&&cy(e,r,t[r]);return e},cv=(e,t)=>cp(e,cg(t)),cC=(e,t,r)=>cy(e,"symbol"!=typeof t?t+"":t,r);class cE{constructor(e){cC(this,"name","eip155"),cC(this,"client"),cC(this,"chainId"),cC(this,"namespace"),cC(this,"httpProviders"),cC(this,"events"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain())}async request(e){switch(e.request.method){case"eth_requestAccounts":case"eth_accounts":return this.getAccounts();case"wallet_switchEthereumChain":return await this.handleSwitchChain(e);case"eth_chainId":return parseInt(this.getDefaultChain());case"wallet_getCapabilities":return await this.getCapabilities(e);case"wallet_getCallsStatus":return await this.getCallStatus(e)}return this.namespace.methods.includes(e.request.method)?await this.client.request(e):this.getHttpProvider().request(e.request)}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(parseInt(e),t),this.chainId=parseInt(e),this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId.toString();if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}createHttpProvider(e,t){let r=t||o6(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.k(r,ca("disableProviderPing")))}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=parseInt(o9(t));e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}getHttpProvider(){let e=this.chainId,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}async handleSwitchChain(e){var t,r;let i=e.request.params?null==(t=e.request.params[0])?void 0:t.chainId:"0x0",s=parseInt(i=i.startsWith("0x")?i:`0x${i}`,16);if(this.isChainApproved(s))this.setDefaultChain(`${s}`);else if(this.namespace.methods.includes("wallet_switchEthereumChain"))await this.client.request({topic:e.topic,request:{method:e.request.method,params:[{chainId:i}]},chainId:null==(r=this.namespace.chains)?void 0:r[0]}),this.setDefaultChain(`${s}`);else throw Error(`Failed to switch to chain 'eip155:${s}'. The chain is not approved or the wallet does not support 'wallet_switchEthereumChain' method.`);return null}isChainApproved(e){return this.namespace.chains.includes(`${this.name}:${e}`)}async getCapabilities(e){var t,r,i,s,n;let a=null==(r=null==(t=e.request)?void 0:t.params)?void 0:r[0],o=(null==(s=null==(i=e.request)?void 0:i.params)?void 0:s[1])||[],c=`${a}${o.join(",")}`;if(!a)throw Error("Missing address parameter in `wallet_getCapabilities` request");let l=this.client.session.get(e.topic),h=(null==(n=l?.sessionProperties)?void 0:n.capabilities)||{};if(null!=h&&h[c])return h?.[c];let d=await this.client.request(e);try{await this.client.session.update(e.topic,{sessionProperties:cv(cb({},l.sessionProperties||{}),{capabilities:cv(cb({},h||{}),{[c]:d})})})}catch(e){console.warn("Failed to update session with capabilities",e)}return d}async getCallStatus(e){var t,r;let i=this.client.session.get(e.topic),s=null==(t=i.sessionProperties)?void 0:t.bundler_name;if(s){let t=this.getBundlerUrl(e.chainId,s);try{return await this.getUserOperationReceipt(t,e)}catch(e){console.warn("Failed to fetch call status from bundler",e,t)}}let n=null==(r=i.sessionProperties)?void 0:r.bundler_url;if(n)try{return await this.getUserOperationReceipt(n,e)}catch(e){console.warn("Failed to fetch call status from custom bundler",e,n)}if(this.namespace.methods.includes(e.request.method))return await this.client.request(e);throw Error("Fetching call status not approved by the wallet.")}async getUserOperationReceipt(e,t){var r;let i=new URL(e),s=await fetch(i,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify((0,sr.formatJsonRpcRequest)("eth_getUserOperationReceipt",[null==(r=t.request.params)?void 0:r[0]]))});if(!s.ok)throw Error(`Failed to fetch user operation receipt - ${s.status}`);return await s.json()}getBundlerUrl(e,t){return`${o$}?projectId=${this.client.core.projectId}&chainId=${e}&bundler=${t}`}}var cN=Object.defineProperty,cI=(e,t,r)=>t in e?cN(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cA=(e,t,r)=>cI(e,"symbol"!=typeof t?t+"":t,r);class c_{constructor(e){cA(this,"name","solana"),cA(this,"client"),cA(this,"httpProviders"),cA(this,"events"),cA(this,"namespace"),cA(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cS=Object.defineProperty,cO=(e,t,r)=>t in e?cS(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cP=(e,t,r)=>cO(e,"symbol"!=typeof t?t+"":t,r);class cT{constructor(e){cP(this,"name","cosmos"),cP(this,"client"),cP(this,"httpProviders"),cP(this,"events"),cP(this,"namespace"),cP(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cR=Object.defineProperty,ck=(e,t,r)=>t in e?cR(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cx=(e,t,r)=>ck(e,"symbol"!=typeof t?t+"":t,r);class cU{constructor(e){cx(this,"name","algorand"),cx(this,"client"),cx(this,"httpProviders"),cx(this,"events"),cx(this,"namespace"),cx(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;e[t]=this.createHttpProvider(t,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);return typeof r>"u"?void 0:new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cD=Object.defineProperty,c$=(e,t,r)=>t in e?cD(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cM=(e,t,r)=>c$(e,"symbol"!=typeof t?t+"":t,r);class cL{constructor(e){cM(this,"name","cip34"),cM(this,"client"),cM(this,"httpProviders"),cM(this,"events"),cM(this,"namespace"),cM(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{let r=this.getCardanoRPCUrl(t),i=o9(t);e[i]=this.createHttpProvider(i,r)}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}getCardanoRPCUrl(e){let t=this.namespace.rpcMap;if(t)return t[e]}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||this.getCardanoRPCUrl(e);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cj=Object.defineProperty,cq=(e,t,r)=>t in e?cj(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cB=(e,t,r)=>cq(e,"symbol"!=typeof t?t+"":t,r);class cF{constructor(e){cB(this,"name","elrond"),cB(this,"client"),cB(this,"httpProviders"),cB(this,"events"),cB(this,"namespace"),cB(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cH=Object.defineProperty,cW=(e,t,r)=>t in e?cH(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cV=(e,t,r)=>cW(e,"symbol"!=typeof t?t+"":t,r);class cz{constructor(e){cV(this,"name","multiversx"),cV(this,"client"),cV(this,"httpProviders"),cV(this,"events"),cV(this,"namespace"),cV(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;let i=o9(t);e[i]=this.createHttpProvider(i,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cK=Object.defineProperty,cJ=(e,t,r)=>t in e?cK(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cG=(e,t,r)=>cJ(e,"symbol"!=typeof t?t+"":t,r);class cY{constructor(e){cG(this,"name","near"),cG(this,"client"),cG(this,"httpProviders"),cG(this,"events"),cG(this,"namespace"),cG(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(this.chainId=e,!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{var r;e[t]=this.createHttpProvider(t,null==(r=this.namespace.rpcMap)?void 0:r[t])}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace);return typeof r>"u"?void 0:new st.r(new oR.Z(r,ca("disableProviderPing")))}}var cX=Object.defineProperty,cZ=(e,t,r)=>t in e?cX(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,cQ=(e,t,r)=>cZ(e,"symbol"!=typeof t?t+"":t,r);class c0{constructor(e){cQ(this,"name","tezos"),cQ(this,"client"),cQ(this,"httpProviders"),cQ(this,"events"),cQ(this,"namespace"),cQ(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider().request(e.request)}setDefaultChain(e,t){if(this.chainId=e,!this.httpProviders[e]){let r=t||o6(`${this.name}:${e}`,this.namespace);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);this.setHttpProvider(e,r)}this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${this.chainId}`)}getAccounts(){let e=this.namespace.accounts;return e&&e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2])||[]}createHttpProviders(){let e={};return this.namespace.chains.forEach(t=>{e[t]=this.createHttpProvider(t)}),e}getHttpProvider(){let e=`${this.name}:${this.chainId}`,t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace);return typeof r>"u"?void 0:new st.r(new oR.Z(r))}}var c1=Object.defineProperty,c2=(e,t,r)=>t in e?c1(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,c5=(e,t,r)=>c2(e,"symbol"!=typeof t?t+"":t,r);class c3{constructor(e){c5(this,"name",oD),c5(this,"client"),c5(this,"httpProviders"),c5(this,"events"),c5(this,"namespace"),c5(this,"chainId"),this.namespace=e.namespace,this.events=ca("events"),this.client=ca("client"),this.chainId=this.getDefaultChain(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace.chains=[...new Set((this.namespace.chains||[]).concat(e.chains||[]))],this.namespace.accounts=[...new Set((this.namespace.accounts||[]).concat(e.accounts||[]))],this.namespace.methods=[...new Set((this.namespace.methods||[]).concat(e.methods||[]))],this.namespace.events=[...new Set((this.namespace.events||[]).concat(e.events||[]))],this.httpProviders=this.createHttpProviders()}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider(e.chainId).request(e.request)}setDefaultChain(e,t){this.httpProviders[e]||this.setHttpProvider(e,t),this.chainId=e,this.events.emit(oM.DEFAULT_CHAIN_CHANGED,`${this.name}:${e}`)}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;let e=this.namespace.chains[0];if(!e)throw Error("ChainId not found");return e.split(":")[1]}getAccounts(){let e=this.namespace.accounts;return e?[...new Set(e.filter(e=>e.split(":")[1]===this.chainId.toString()).map(e=>e.split(":")[2]))]:[]}createHttpProviders(){var e,t;let r={};return null==(t=null==(e=this.namespace)?void 0:e.accounts)||t.forEach(e=>{let t=B(e);r[`${t.namespace}:${t.reference}`]=this.createHttpProvider(e)}),r}getHttpProvider(e){let t=this.httpProviders[e];if(typeof t>"u")throw Error(`JSON-RPC provider for ${e} not found`);return t}setHttpProvider(e,t){let r=this.createHttpProvider(e,t);r&&(this.httpProviders[e]=r)}createHttpProvider(e,t){let r=t||o6(e,this.namespace,this.client.core.projectId);if(!r)throw Error(`No RPC url provided for chainId: ${e}`);return new st.r(new oR.Z(r,ca("disableProviderPing")))}}var c8=Object.defineProperty,c4=Object.defineProperties,c6=Object.getOwnPropertyDescriptors,c9=Object.getOwnPropertySymbols,c7=Object.prototype.hasOwnProperty,le=Object.prototype.propertyIsEnumerable,lt=(e,t,r)=>t in e?c8(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,lr=(e,t)=>{for(var r in t||(t={}))c7.call(t,r)&&lt(e,r,t[r]);if(c9)for(var r of c9(t))le.call(t,r)&&lt(e,r,t[r]);return e},li=(e,t)=>c4(e,c6(t)),ls=(e,t,r)=>lt(e,"symbol"!=typeof t?t+"":t,r);class ln{constructor(e){ls(this,"client"),ls(this,"namespaces"),ls(this,"optionalNamespaces"),ls(this,"sessionProperties"),ls(this,"scopedProperties"),ls(this,"events",new(s())),ls(this,"rpcProviders",{}),ls(this,"session"),ls(this,"providerOpts"),ls(this,"logger"),ls(this,"uri"),ls(this,"disableProviderPing",!1),this.providerOpts=e,this.logger="u">typeof e?.logger&&"string"!=typeof e?.logger?e.logger:(0,o.gw)((0,o.jI)({level:e?.logger||ok})),this.disableProviderPing=e?.disableProviderPing||!1}static async init(e){let t=new ln(e);return await t.initialize(),t}async request(e,t,r){let[i,s]=this.validateChain(t);if(!this.session)throw Error("Please call connect() before request()");return await this.getProvider(i).request({request:lr({},e),chainId:`${i}:${s}`,topic:this.session.topic,expiry:r})}sendAsync(e,t,r,i){let s=new Date().getTime();this.request(e,r,i).then(e=>t(null,(0,sr.formatJsonRpcResult)(s,e))).catch(e=>t(e,void 0))}async enable(){if(!this.client)throw Error("Sign Client not initialized");return this.session||await this.connect({namespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties}),await this.requestAccounts()}async disconnect(){var e;if(!this.session)throw Error("Please call connect() before enable()");await this.client.disconnect({topic:null==(e=this.session)?void 0:e.topic,reason:iz("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw Error("Sign Client not initialized");if(this.setNamespaces(e),await this.cleanupPendingPairings(),!e.skipPairing)return await this.pair(e.pairingTopic)}async authenticate(e,t){if(!this.client)throw Error("Sign Client not initialized");this.setNamespaces(e),await this.cleanupPendingPairings();let{uri:r,response:i}=await this.client.authenticate(e,t);r&&(this.uri=r,this.events.emit("display_uri",r));let s=await i();if(this.session=s.session,this.session){let e=ci(this.session.namespaces);this.namespaces=ce(this.namespaces,e),await this.persist("namespaces",this.namespaces),this.onConnect()}return s}on(e,t){this.events.on(e,t)}once(e,t){this.events.once(e,t)}removeListener(e,t){this.events.removeListener(e,t)}off(e,t){this.events.off(e,t)}get isWalletConnect(){return!0}async pair(e){let{uri:t,approval:r}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties});t&&(this.uri=t,this.events.emit("display_uri",t));let i=await r();this.session=i;let s=ci(i.namespaces);return this.namespaces=ce(this.namespaces,s),await this.persist("namespaces",this.namespaces),await this.persist("optionalNamespaces",this.optionalNamespaces),this.onConnect(),this.session}setDefaultChain(e,t){try{if(!this.session)return;let[r,i]=this.validateChain(e),s=this.getProvider(r);s.name===oD?s.setDefaultChain(`${r}:${i}`,t):s.setDefaultChain(i,t)}catch(e){if(!/Please call connect/.test(e.message))throw e}}async cleanupPendingPairings(e={}){this.logger.info("Cleaning up inactive pairings...");let t=this.client.pairing.getAll();if(iK(t)){for(let r of t)e.deletePairings?this.client.core.expirer.set(r.topic,0):await this.client.core.relayer.subscriber.unsubscribe(r.topic);this.logger.info(`Inactive pairings cleared: ${t.length}`)}}abortPairingAttempt(){this.logger.warn("abortPairingAttempt is deprecated. This is now a no-op.")}async checkStorage(){this.namespaces=await this.getFromStore("namespaces")||{},this.optionalNamespaces=await this.getFromStore("optionalNamespaces")||{},this.session&&this.createProviders()}async initialize(){this.logger.trace("Initialized"),await this.createClient(),await this.checkStorage(),this.registerEventListeners()}async createClient(){var e,t;if(this.client=this.providerOpts.client||await oT.init({core:this.providerOpts.core,logger:this.providerOpts.logger||ok,relayUrl:this.providerOpts.relayUrl||"wss://relay.walletconnect.org",projectId:this.providerOpts.projectId,metadata:this.providerOpts.metadata,storageOptions:this.providerOpts.storageOptions,storage:this.providerOpts.storage,name:this.providerOpts.name,customStoragePrefix:this.providerOpts.customStoragePrefix,telemetryEnabled:this.providerOpts.telemetryEnabled}),this.providerOpts.session)try{this.session=this.client.session.get(this.providerOpts.session.topic)}catch(r){throw this.logger.error("Failed to get session",r),Error(`The provided session: ${null==(t=null==(e=this.providerOpts)?void 0:e.session)?void 0:t.topic} doesn't exist in the Sign client`)}else{let e=this.client.session.getAll();this.session=e[0]}this.logger.trace("SignClient Initialized")}createProviders(){if(!this.client)throw Error("Sign Client not initialized");if(!this.session)throw Error("Session not initialized. Please call connect() before enable()");let e=[...new Set(Object.keys(this.session.namespaces).map(e=>iq(e)))];co("client",this.client),co("events",this.events),co("disableProviderPing",this.disableProviderPing),e.forEach(e=>{if(!this.session)return;let t=function(e,t){let r=Object.keys(t.namespaces).filter(t=>t.includes(e));if(!r.length)return[];let i=[];return r.forEach(e=>{let r=t.namespaces[e].accounts;i.push(...r)}),i}(e,this.session),r=o7(t),i=li(lr({},ce(this.namespaces,this.optionalNamespaces)[e]),{accounts:t,chains:r});switch(e){case"eip155":this.rpcProviders[e]=new cE({namespace:i});break;case"algorand":this.rpcProviders[e]=new cU({namespace:i});break;case"solana":this.rpcProviders[e]=new c_({namespace:i});break;case"cosmos":this.rpcProviders[e]=new cT({namespace:i});break;case"polkadot":this.rpcProviders[e]=new cd({namespace:i});break;case"cip34":this.rpcProviders[e]=new cL({namespace:i});break;case"elrond":this.rpcProviders[e]=new cF({namespace:i});break;case"multiversx":this.rpcProviders[e]=new cz({namespace:i});break;case"near":this.rpcProviders[e]=new cY({namespace:i});break;case"tezos":this.rpcProviders[e]=new c0({namespace:i});break;default:this.rpcProviders[oD]?this.rpcProviders[oD].updateNamespace(i):this.rpcProviders[oD]=new c3({namespace:i})}})}registerEventListeners(){if(typeof this.client>"u")throw Error("Sign Client is not initialized");this.client.on("session_ping",e=>{var t;let{topic:r}=e;r===(null==(t=this.session)?void 0:t.topic)&&this.events.emit("session_ping",e)}),this.client.on("session_event",e=>{var t;let{params:r,topic:i}=e;if(i!==(null==(t=this.session)?void 0:t.topic))return;let{event:s}=r;if("accountsChanged"===s.name){let e=s.data;e&&iK(e)&&this.events.emit("accountsChanged",e.map(cr))}else if("chainChanged"===s.name){let e=r.chainId,t=r.event.data,i=iq(e),s=cs(e)!==cs(t)?`${i}:${cs(t)}`:e;this.onChainChanged(s)}else this.events.emit(s.name,s.data);this.events.emit("session_event",e)}),this.client.on("session_update",({topic:e,params:t})=>{var r,i;if(e!==(null==(r=this.session)?void 0:r.topic))return;let{namespaces:s}=t,n=null==(i=this.client)?void 0:i.session.get(e);this.session=li(lr({},n),{namespaces:s}),this.onSessionUpdate(),this.events.emit("session_update",{topic:e,params:t})}),this.client.on("session_delete",async e=>{var t;e.topic===(null==(t=this.session)?void 0:t.topic)&&(await this.cleanup(),this.events.emit("session_delete",e),this.events.emit("disconnect",li(lr({},iz("USER_DISCONNECTED")),{data:e.topic})))}),this.on(oM.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(e,!0)})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[oD]}onSessionUpdate(){Object.keys(this.rpcProviders).forEach(e=>{var t;this.getProvider(e).updateNamespace(null==(t=this.session)?void 0:t.namespaces[e])})}setNamespaces(e){let{namespaces:t={},optionalNamespaces:r={},sessionProperties:i,scopedProperties:s}=e;this.optionalNamespaces=ce(t,r),this.sessionProperties=i,this.scopedProperties=s}validateChain(e){let[t,r]=e?.split(":")||["",""];if(!this.namespaces||!Object.keys(this.namespaces).length)return[t,r];if(t&&!Object.keys(this.namespaces||{}).map(e=>iq(e)).includes(t))throw Error(`Namespace '${t}' is not configured. Please call connect() first with namespace config.`);if(t&&r)return[t,r];let i=iq(Object.keys(this.namespaces)[0]),s=this.rpcProviders[i].getDefaultChain();return[i,s]}async requestAccounts(){let[e]=this.validateChain();return await this.getProvider(e).requestAccounts()}async onChainChanged(e,t=!1){if(!this.namespaces)return;let[r,i]=this.validateChain(e);if(!i)return;this.updateNamespaceChain(r,i),this.events.emit("chainChanged",i);let s=this.getProvider(r).getDefaultChain();t||this.getProvider(r).setDefaultChain(i),this.emitAccountsChangedOnChainChange({namespace:r,previousChainId:s,newChainId:e}),await this.persist("namespaces",this.namespaces)}emitAccountsChangedOnChainChange({namespace:e,previousChainId:t,newChainId:r}){var i,s;try{if(t===r)return;let n=null==(s=null==(i=this.session)?void 0:i.namespaces[e])?void 0:s.accounts;if(!n)return;let a=n.filter(e=>e.includes(`${r}:`)).map(cr);if(!iK(a))return;this.events.emit("accountsChanged",a)}catch(e){this.logger.warn("Failed to emit accountsChanged on chain change",e)}}updateNamespaceChain(e,t){if(!this.namespaces)return;let r=this.namespaces[e]?e:`${e}:${t}`;this.namespaces[r]?this.namespaces[r]&&(this.namespaces[r].defaultChain=t):this.namespaces[r]={chains:[],methods:[],events:[],defaultChain:t}}onConnect(){this.createProviders(),this.events.emit("connect",{session:this.session})}async cleanup(){this.namespaces=void 0,this.optionalNamespaces=void 0,this.sessionProperties=void 0,await this.deleteFromStore("namespaces"),await this.deleteFromStore("optionalNamespaces"),await this.deleteFromStore("sessionProperties"),this.session=void 0,await this.cleanupPendingPairings({deletePairings:!0}),await this.cleanupStorage()}async persist(e,t){var r;let i=(null==(r=this.session)?void 0:r.topic)||"";await this.client.core.storage.setItem(`${ox}/${e}${i}`,t)}async getFromStore(e){var t;let r=(null==(t=this.session)?void 0:t.topic)||"";return await this.client.core.storage.getItem(`${ox}/${e}${r}`)}async deleteFromStore(e){var t;let r=(null==(t=this.session)?void 0:t.topic)||"";await this.client.core.storage.removeItem(`${ox}/${e}${r}`)}async cleanupStorage(){var e;try{if((null==(e=this.client)?void 0:e.session.length)>0)return;for(let e of(await this.client.core.storage.getKeys()))e.startsWith(ox)&&await this.client.core.storage.removeItem(e)}catch(e){this.logger.warn("Failed to cleanup storage",e)}}}},24811:function(e){var t;t=function(){"use strict";var e="millisecond",t="second",r="minute",i="hour",s="week",n="month",a="quarter",o="year",c="date",l="Invalid Date",h=/^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/,d=/\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,u=function(e,t,r){var i=String(e);return!i||i.length>=t?e:""+Array(t+1-i.length).join(r)+e},p="en",g={};g[p]={name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],r=e%100;return"["+e+(t[(r-20)%10]||t[r]||"th")+"]"}};var f="$isDayjsObject",m=function(e){return e instanceof v||!(!e||!e[f])},w=function e(t,r,i){var s;if(!t)return p;if("string"==typeof t){var n=t.toLowerCase();g[n]&&(s=n),r&&(g[n]=r,s=n);var a=t.split("-");if(!s&&a.length>1)return e(a[0])}else{var o=t.name;g[o]=t,s=o}return!i&&s&&(p=s),s||!i&&p},y=function(e,t){if(m(e))return e.clone();var r="object"==typeof t?t:{};return r.date=e,r.args=arguments,new v(r)},b={s:u,z:function(e){var t=-e.utcOffset(),r=Math.abs(t);return(t<=0?"+":"-")+u(Math.floor(r/60),2,"0")+":"+u(r%60,2,"0")},m:function e(t,r){if(t.date()<r.date())return-e(r,t);var i=12*(r.year()-t.year())+(r.month()-t.month()),s=t.clone().add(i,n),a=r-s<0,o=t.clone().add(i+(a?-1:1),n);return+(-(i+(r-s)/(a?s-o:o-s))||0)},a:function(e){return e<0?Math.ceil(e)||0:Math.floor(e)},p:function(l){return({M:n,y:o,w:s,d:"day",D:c,h:i,m:r,s:t,ms:e,Q:a})[l]||String(l||"").toLowerCase().replace(/s$/,"")},u:function(e){return void 0===e}};b.l=w,b.i=m,b.w=function(e,t){return y(e,{locale:t.$L,utc:t.$u,x:t.$x,$offset:t.$offset})};var v=function(){function u(e){this.$L=w(e.locale,null,!0),this.parse(e),this.$x=this.$x||e.x||{},this[f]=!0}var p=u.prototype;return p.parse=function(e){this.$d=function(e){var t=e.date,r=e.utc;if(null===t)return new Date(NaN);if(b.u(t))return new Date;if(t instanceof Date)return new Date(t);if("string"==typeof t&&!/Z$/i.test(t)){var i=t.match(h);if(i){var s=i[2]-1||0,n=(i[7]||"0").substring(0,3);return r?new Date(Date.UTC(i[1],s,i[3]||1,i[4]||0,i[5]||0,i[6]||0,n)):new Date(i[1],s,i[3]||1,i[4]||0,i[5]||0,i[6]||0,n)}}return new Date(t)}(e),this.init()},p.init=function(){var e=this.$d;this.$y=e.getFullYear(),this.$M=e.getMonth(),this.$D=e.getDate(),this.$W=e.getDay(),this.$H=e.getHours(),this.$m=e.getMinutes(),this.$s=e.getSeconds(),this.$ms=e.getMilliseconds()},p.$utils=function(){return b},p.isValid=function(){return this.$d.toString()!==l},p.isSame=function(e,t){var r=y(e);return this.startOf(t)<=r&&r<=this.endOf(t)},p.isAfter=function(e,t){return y(e)<this.startOf(t)},p.isBefore=function(e,t){return this.endOf(t)<y(e)},p.$g=function(e,t,r){return b.u(e)?this[t]:this.set(r,e)},p.unix=function(){return Math.floor(this.valueOf()/1e3)},p.valueOf=function(){return this.$d.getTime()},p.startOf=function(e,a){var l=this,h=!!b.u(a)||a,d=b.p(e),u=function(e,t){var r=b.w(l.$u?Date.UTC(l.$y,t,e):new Date(l.$y,t,e),l);return h?r:r.endOf("day")},p=function(e,t){return b.w(l.toDate()[e].apply(l.toDate("s"),(h?[0,0,0,0]:[23,59,59,999]).slice(t)),l)},g=this.$W,f=this.$M,m=this.$D,w="set"+(this.$u?"UTC":"");switch(d){case o:return h?u(1,0):u(31,11);case n:return h?u(1,f):u(0,f+1);case s:var y=this.$locale().weekStart||0,v=(g<y?g+7:g)-y;return u(h?m-v:m+(6-v),f);case"day":case c:return p(w+"Hours",0);case i:return p(w+"Minutes",1);case r:return p(w+"Seconds",2);case t:return p(w+"Milliseconds",3);default:return this.clone()}},p.endOf=function(e){return this.startOf(e,!1)},p.$set=function(s,a){var l,h=b.p(s),d="set"+(this.$u?"UTC":""),u=((l={}).day=d+"Date",l[c]=d+"Date",l[n]=d+"Month",l[o]=d+"FullYear",l[i]=d+"Hours",l[r]=d+"Minutes",l[t]=d+"Seconds",l[e]=d+"Milliseconds",l)[h],p="day"===h?this.$D+(a-this.$W):a;if(h===n||h===o){var g=this.clone().set(c,1);g.$d[u](p),g.init(),this.$d=g.set(c,Math.min(this.$D,g.daysInMonth())).$d}else u&&this.$d[u](p);return this.init(),this},p.set=function(e,t){return this.clone().$set(e,t)},p.get=function(e){return this[b.p(e)]()},p.add=function(e,a){var c,l=this;e=Number(e);var h=b.p(a),d=function(t){var r=y(l);return b.w(r.date(r.date()+Math.round(t*e)),l)};if(h===n)return this.set(n,this.$M+e);if(h===o)return this.set(o,this.$y+e);if("day"===h)return d(1);if(h===s)return d(7);var u=((c={})[r]=6e4,c[i]=36e5,c[t]=1e3,c)[h]||1,p=this.$d.getTime()+e*u;return b.w(p,this)},p.subtract=function(e,t){return this.add(-1*e,t)},p.format=function(e){var t=this,r=this.$locale();if(!this.isValid())return r.invalidDate||l;var i=e||"YYYY-MM-DDTHH:mm:ssZ",s=b.z(this),n=this.$H,a=this.$m,o=this.$M,c=r.weekdays,h=r.months,u=r.meridiem,p=function(e,r,s,n){return e&&(e[r]||e(t,i))||s[r].slice(0,n)},g=function(e){return b.s(n%12||12,e,"0")},f=u||function(e,t,r){var i=e<12?"AM":"PM";return r?i.toLowerCase():i};return i.replace(d,function(e,i){return i||function(e){switch(e){case"YY":return String(t.$y).slice(-2);case"YYYY":return b.s(t.$y,4,"0");case"M":return o+1;case"MM":return b.s(o+1,2,"0");case"MMM":return p(r.monthsShort,o,h,3);case"MMMM":return p(h,o);case"D":return t.$D;case"DD":return b.s(t.$D,2,"0");case"d":return String(t.$W);case"dd":return p(r.weekdaysMin,t.$W,c,2);case"ddd":return p(r.weekdaysShort,t.$W,c,3);case"dddd":return c[t.$W];case"H":return String(n);case"HH":return b.s(n,2,"0");case"h":return g(1);case"hh":return g(2);case"a":return f(n,a,!0);case"A":return f(n,a,!1);case"m":return String(a);case"mm":return b.s(a,2,"0");case"s":return String(t.$s);case"ss":return b.s(t.$s,2,"0");case"SSS":return b.s(t.$ms,3,"0");case"Z":return s}return null}(e)||s.replace(":","")})},p.utcOffset=function(){return-(15*Math.round(this.$d.getTimezoneOffset()/15))},p.diff=function(e,c,l){var h,d=this,u=b.p(c),p=y(e),g=(p.utcOffset()-this.utcOffset())*6e4,f=this-p,m=function(){return b.m(d,p)};switch(u){case o:h=m()/12;break;case n:h=m();break;case a:h=m()/3;break;case s:h=(f-g)/6048e5;break;case"day":h=(f-g)/864e5;break;case i:h=f/36e5;break;case r:h=f/6e4;break;case t:h=f/1e3;break;default:h=f}return l?h:b.a(h)},p.daysInMonth=function(){return this.endOf(n).$D},p.$locale=function(){return g[this.$L]},p.locale=function(e,t){if(!e)return this.$L;var r=this.clone(),i=w(e,t,!0);return i&&(r.$L=i),r},p.clone=function(){return b.w(this.$d,this)},p.toDate=function(){return new Date(this.valueOf())},p.toJSON=function(){return this.isValid()?this.toISOString():null},p.toISOString=function(){return this.$d.toISOString()},p.toString=function(){return this.$d.toUTCString()},u}(),C=v.prototype;return y.prototype=C,[["$ms",e],["$s",t],["$m",r],["$H",i],["$W","day"],["$M",n],["$y",o],["$D",c]].forEach(function(e){C[e[1]]=function(t){return this.$g(t,e[0],e[1])}}),y.extend=function(e,t){return e.$i||(e(t,v,y),e.$i=!0),y},y.locale=w,y.isDayjs=m,y.unix=function(e){return y(1e3*e)},y.en=g[p],y.Ls=g,y.p={},y},e.exports=t()},76676:function(e){var t;t=function(){return{name:"en",weekdays:"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),months:"January_February_March_April_May_June_July_August_September_October_November_December".split("_"),ordinal:function(e){var t=["th","st","nd","rd"],r=e%100;return"["+e+(t[(r-20)%10]||t[r]||"th")+"]"}}},e.exports=t()},48233:function(e){var t;t=function(){return function(e,t,r){e=e||{};var i=t.prototype,s={future:"in %s",past:"%s ago",s:"a few seconds",m:"a minute",mm:"%d minutes",h:"an hour",hh:"%d hours",d:"a day",dd:"%d days",M:"a month",MM:"%d months",y:"a year",yy:"%d years"};function n(e,t,r,s){return i.fromToBase(e,t,r,s)}r.en.relativeTime=s,i.fromToBase=function(t,i,n,a,o){for(var c,l,h,d=n.$locale().relativeTime||s,u=e.thresholds||[{l:"s",r:44,d:"second"},{l:"m",r:89},{l:"mm",r:44,d:"minute"},{l:"h",r:89},{l:"hh",r:21,d:"hour"},{l:"d",r:35},{l:"dd",r:25,d:"day"},{l:"M",r:45},{l:"MM",r:10,d:"month"},{l:"y",r:17},{l:"yy",d:"year"}],p=u.length,g=0;g<p;g+=1){var f=u[g];f.d&&(c=a?r(t).diff(n,f.d,!0):n.diff(t,f.d,!0));var m=(e.rounding||Math.round)(Math.abs(c));if(h=c>0,m<=f.r||!f.r){m<=1&&g>0&&(f=u[g-1]);var w=d[f.l];o&&(m=o(""+m)),l="string"==typeof w?w.replace("%d",m):w(m,i,f.l,h);break}}if(i)return l;var y=h?d.future:d.past;return"function"==typeof y?y(l):y.replace("%s",l)},i.to=function(e,t){return n(e,t,this,!0)},i.from=function(e,t){return n(e,t,this)};var a=function(e){return e.$u?r.utc():r()};i.toNow=function(e){return this.to(a(this),e)},i.fromNow=function(e){return this.from(a(this),e)}}},e.exports=t()},57209:function(e){var t;t=function(){return function(e,t,r){r.updateLocale=function(e,t){var i=r.Ls[e];if(i)return(t?Object.keys(t):[]).forEach(function(e){i[e]=t[e]}),i}}},e.exports=t()},35862:(e,t,r)=>{"use strict";r.d(t,{fl:()=>k,iv:()=>f,Ts:()=>P,Qu:()=>T,$m:()=>g});let i=class{get shadowRoot(){return this.__host.__shadowRoot}constructor(e){this.ariaAtomic="",this.ariaAutoComplete="",this.ariaBrailleLabel="",this.ariaBrailleRoleDescription="",this.ariaBusy="",this.ariaChecked="",this.ariaColCount="",this.ariaColIndex="",this.ariaColSpan="",this.ariaCurrent="",this.ariaDescription="",this.ariaDisabled="",this.ariaExpanded="",this.ariaHasPopup="",this.ariaHidden="",this.ariaInvalid="",this.ariaKeyShortcuts="",this.ariaLabel="",this.ariaLevel="",this.ariaLive="",this.ariaModal="",this.ariaMultiLine="",this.ariaMultiSelectable="",this.ariaOrientation="",this.ariaPlaceholder="",this.ariaPosInSet="",this.ariaPressed="",this.ariaReadOnly="",this.ariaRequired="",this.ariaRoleDescription="",this.ariaRowCount="",this.ariaRowIndex="",this.ariaRowSpan="",this.ariaSelected="",this.ariaSetSize="",this.ariaSort="",this.ariaValueMax="",this.ariaValueMin="",this.ariaValueNow="",this.ariaValueText="",this.role="",this.form=null,this.labels=[],this.states=new Set,this.validationMessage="",this.validity={},this.willValidate=!0,this.__host=e}checkValidity(){return console.warn("`ElementInternals.checkValidity()` was called on the server.This method always returns true."),!0}reportValidity(){return!0}setFormValue(){}setValidity(){}},s=new WeakMap,n=e=>{let t=s.get(e);return void 0===t&&s.set(e,t=new Map),t},a=class{constructor(){this.__shadowRootMode=null,this.__shadowRoot=null,this.__internals=null}get attributes(){return Array.from(n(this)).map(([e,t])=>({name:e,value:t}))}get shadowRoot(){return"closed"===this.__shadowRootMode?null:this.__shadowRoot}get localName(){return this.constructor.__localName}get tagName(){return this.localName?.toUpperCase()}setAttribute(e,t){n(this).set(e,String(t))}removeAttribute(e){n(this).delete(e)}toggleAttribute(e,t){if(this.hasAttribute(e)){if(void 0===t||!t)return this.removeAttribute(e),!1}else{if(void 0!==t&&!t)return!1;this.setAttribute(e,"")}return!0}hasAttribute(e){return n(this).has(e)}attachShadow(e){let t={host:this};return this.__shadowRootMode=e.mode,e&&"open"===e.mode&&(this.__shadowRoot=t),t}attachInternals(){if(null!==this.__internals)throw Error("Failed to execute 'attachInternals' on 'HTMLElement': ElementInternals for the specified element was already attached.");let e=new i(this);return this.__internals=e,e}getAttribute(e){return n(this).get(e)??null}},o=class extends a{},c=new class{constructor(){this.__definitions=new Map}define(e,t){if(this.__definitions.has(e))throw Error(`Failed to execute 'define' on 'CustomElementRegistry': the name "${e}" has already been used with this registry`);t.__localName=e,this.__definitions.set(e,{ctor:t,observedAttributes:t.observedAttributes??[]})}get(e){let t=this.__definitions.get(e);return t?.ctor}},l=globalThis,h=l.ShadowRoot&&(void 0===l.ShadyCSS||l.ShadyCSS.nativeShadow)&&"adoptedStyleSheets"in Document.prototype&&"replace"in CSSStyleSheet.prototype,d=Symbol(),u=new WeakMap;class p{constructor(e,t,r){if(this._$cssResult$=!0,r!==d)throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");this.cssText=e,this.t=t}get styleSheet(){let e=this.o,t=this.t;if(h&&void 0===e){let r=void 0!==t&&1===t.length;r&&(e=u.get(t)),void 0===e&&((this.o=e=new CSSStyleSheet).replaceSync(this.cssText),r&&u.set(t,e))}return e}toString(){return this.cssText}}let g=e=>new p("string"==typeof e?e:e+"",void 0,d),f=(e,...t)=>new p(1===e.length?e[0]:t.reduce((t,r,i)=>t+(e=>{if(!0===e._$cssResult$)return e.cssText;if("number"==typeof e)return e;throw Error("Value passed to 'css' function must be a 'css' function result: "+e+". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.")})(r)+e[i+1],e[0]),e,d),m=(e,t)=>{if(h)e.adoptedStyleSheets=t.map(e=>e instanceof CSSStyleSheet?e:e.styleSheet);else for(let r of t){let t=document.createElement("style"),i=l.litNonce;void 0!==i&&t.setAttribute("nonce",i),t.textContent=r.cssText,e.appendChild(t)}},w=h||void 0===l.CSSStyleSheet?e=>e:e=>e instanceof CSSStyleSheet?(e=>{let t="";for(let r of e.cssRules)t+=r.cssText;return g(t)})(e):e,{is:y,defineProperty:b,getOwnPropertyDescriptor:v,getOwnPropertyNames:C,getOwnPropertySymbols:E,getPrototypeOf:N}=Object,I=globalThis;I.customElements??=c;let A=I.trustedTypes,_=A?A.emptyScript:"",S=I.reactiveElementPolyfillSupport,O=(e,t)=>e,P={toAttribute(e,t){switch(t){case Boolean:e=e?_:null;break;case Object:case Array:e=null==e?e:JSON.stringify(e)}return e},fromAttribute(e,t){let r=e;switch(t){case Boolean:r=null!==e;break;case Number:r=null===e?null:Number(e);break;case Object:case Array:try{r=JSON.parse(e)}catch(e){r=null}}return r}},T=(e,t)=>!y(e,t),R={attribute:!0,type:String,converter:P,reflect:!1,useDefault:!1,hasChanged:T};Symbol.metadata??=Symbol("metadata"),I.litPropertyMetadata??=new WeakMap;class k extends(globalThis.HTMLElement??o){static addInitializer(e){this._$Ei(),(this.l??=[]).push(e)}static get observedAttributes(){return this.finalize(),this._$Eh&&[...this._$Eh.keys()]}static createProperty(e,t=R){if(t.state&&(t.attribute=!1),this._$Ei(),this.prototype.hasOwnProperty(e)&&((t=Object.create(t)).wrapped=!0),this.elementProperties.set(e,t),!t.noAccessor){let r=Symbol(),i=this.getPropertyDescriptor(e,r,t);void 0!==i&&b(this.prototype,e,i)}}static getPropertyDescriptor(e,t,r){let{get:i,set:s}=v(this.prototype,e)??{get(){return this[t]},set(e){this[t]=e}};return{get:i,set(t){let n=i?.call(this);s?.call(this,t),this.requestUpdate(e,n,r)},configurable:!0,enumerable:!0}}static getPropertyOptions(e){return this.elementProperties.get(e)??R}static _$Ei(){if(this.hasOwnProperty(O("elementProperties")))return;let e=N(this);e.finalize(),void 0!==e.l&&(this.l=[...e.l]),this.elementProperties=new Map(e.elementProperties)}static finalize(){if(this.hasOwnProperty(O("finalized")))return;if(this.finalized=!0,this._$Ei(),this.hasOwnProperty(O("properties"))){let e=this.properties;for(let t of[...C(e),...E(e)])this.createProperty(t,e[t])}let e=this[Symbol.metadata];if(null!==e){let t=litPropertyMetadata.get(e);if(void 0!==t)for(let[e,r]of t)this.elementProperties.set(e,r)}for(let[e,t]of(this._$Eh=new Map,this.elementProperties)){let r=this._$Eu(e,t);void 0!==r&&this._$Eh.set(r,e)}this.elementStyles=this.finalizeStyles(this.styles)}static finalizeStyles(e){let t=[];if(Array.isArray(e))for(let r of new Set(e.flat(1/0).reverse()))t.unshift(w(r));else void 0!==e&&t.push(w(e));return t}static _$Eu(e,t){let r=t.attribute;return!1===r?void 0:"string"==typeof r?r:"string"==typeof e?e.toLowerCase():void 0}constructor(){super(),this._$Ep=void 0,this.isUpdatePending=!1,this.hasUpdated=!1,this._$Em=null,this._$Ev()}_$Ev(){this._$ES=new Promise(e=>this.enableUpdating=e),this._$AL=new Map,this._$E_(),this.requestUpdate(),this.constructor.l?.forEach(e=>e(this))}addController(e){(this._$EO??=new Set).add(e),void 0!==this.renderRoot&&this.isConnected&&e.hostConnected?.()}removeController(e){this._$EO?.delete(e)}_$E_(){let e=new Map;for(let t of this.constructor.elementProperties.keys())this.hasOwnProperty(t)&&(e.set(t,this[t]),delete this[t]);e.size>0&&(this._$Ep=e)}createRenderRoot(){let e=this.shadowRoot??this.attachShadow(this.constructor.shadowRootOptions);return m(e,this.constructor.elementStyles),e}connectedCallback(){this.renderRoot??=this.createRenderRoot(),this.enableUpdating(!0),this._$EO?.forEach(e=>e.hostConnected?.())}enableUpdating(e){}disconnectedCallback(){this._$EO?.forEach(e=>e.hostDisconnected?.())}attributeChangedCallback(e,t,r){this._$AK(e,r)}_$ET(e,t){let r=this.constructor.elementProperties.get(e),i=this.constructor._$Eu(e,r);if(void 0!==i&&!0===r.reflect){let s=(void 0!==r.converter?.toAttribute?r.converter:P).toAttribute(t,r.type);this._$Em=e,null==s?this.removeAttribute(i):this.setAttribute(i,s),this._$Em=null}}_$AK(e,t){let r=this.constructor,i=r._$Eh.get(e);if(void 0!==i&&this._$Em!==i){let e=r.getPropertyOptions(i),s="function"==typeof e.converter?{fromAttribute:e.converter}:void 0!==e.converter?.fromAttribute?e.converter:P;this._$Em=i,this[i]=s.fromAttribute(t,e.type)??this._$Ej?.get(i)??null,this._$Em=null}}requestUpdate(e,t,r){if(void 0!==e){let i=this.constructor,s=this[e];if(!(((r??=i.getPropertyOptions(e)).hasChanged??T)(s,t)||r.useDefault&&r.reflect&&s===this._$Ej?.get(e)&&!this.hasAttribute(i._$Eu(e,r))))return;this.C(e,t,r)}!1===this.isUpdatePending&&(this._$ES=this._$EP())}C(e,t,{useDefault:r,reflect:i,wrapped:s},n){r&&!(this._$Ej??=new Map).has(e)&&(this._$Ej.set(e,n??t??this[e]),!0!==s||void 0!==n)||(this._$AL.has(e)||(this.hasUpdated||r||(t=void 0),this._$AL.set(e,t)),!0===i&&this._$Em!==e&&(this._$Eq??=new Set).add(e))}async _$EP(){this.isUpdatePending=!0;try{await this._$ES}catch(e){Promise.reject(e)}let e=this.scheduleUpdate();return null!=e&&await e,!this.isUpdatePending}scheduleUpdate(){return this.performUpdate()}performUpdate(){if(!this.isUpdatePending)return;if(!this.hasUpdated){if(this.renderRoot??=this.createRenderRoot(),this._$Ep){for(let[e,t]of this._$Ep)this[e]=t;this._$Ep=void 0}let e=this.constructor.elementProperties;if(e.size>0)for(let[t,r]of e){let{wrapped:e}=r,i=this[t];!0!==e||this._$AL.has(t)||void 0===i||this.C(t,void 0,r,i)}}let e=!1,t=this._$AL;try{(e=this.shouldUpdate(t))?(this.willUpdate(t),this._$EO?.forEach(e=>e.hostUpdate?.()),this.update(t)):this._$EM()}catch(t){throw e=!1,this._$EM(),t}e&&this._$AE(t)}willUpdate(e){}_$AE(e){this._$EO?.forEach(e=>e.hostUpdated?.()),this.hasUpdated||(this.hasUpdated=!0,this.firstUpdated(e)),this.updated(e)}_$EM(){this._$AL=new Map,this.isUpdatePending=!1}get updateComplete(){return this.getUpdateComplete()}getUpdateComplete(){return this._$ES}shouldUpdate(e){return!0}update(e){this._$Eq&&=this._$Eq.forEach(e=>this._$ET(e,this[e])),this._$EM()}updated(e){}firstUpdated(e){}}k.elementStyles=[],k.shadowRootOptions={mode:"open"},k[O("elementProperties")]=new Map,k[O("finalized")]=new Map,S?.({ReactiveElement:k}),(I.reactiveElementVersions??=[]).push("2.1.0")},82324:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={WC_NAME_SUFFIX:".reown.id",WC_NAME_SUFFIX_LEGACY:".wcn.id",BLOCKCHAIN_API_RPC_URL:"https://rpc.walletconnect.org",PULSE_API_URL:"https://pulse.walletconnect.org",W3M_API_URL:"https://api.web3modal.org",CONNECTOR_ID:{WALLET_CONNECT:"walletConnect",INJECTED:"injected",WALLET_STANDARD:"announced",COINBASE:"coinbaseWallet",COINBASE_SDK:"coinbaseWalletSDK",SAFE:"safe",LEDGER:"ledger",OKX:"okx",EIP6963:"eip6963",AUTH:"ID_AUTH"},CONNECTOR_NAMES:{AUTH:"Auth"},AUTH_CONNECTOR_SUPPORTED_CHAINS:["eip155","solana"],LIMITS:{PENDING_TRANSACTIONS:99},CHAIN:{EVM:"eip155",SOLANA:"solana",POLKADOT:"polkadot",BITCOIN:"bip122"},CHAIN_NAME_MAP:{eip155:"EVM Networks",solana:"Solana",polkadot:"Polkadot",bip122:"Bitcoin",cosmos:"Cosmos"},ADAPTER_TYPES:{BITCOIN:"bitcoin",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5"},USDT_CONTRACT_ADDRESSES:["0xdac17f958d2ee523a2206206994597c13d831ec7","0xc2132d05d31c914a87c6611c10748aeb04b58e8f","0x9702230a8ea53601f5cd2dc00fdbc13d4df4a8c7","0x919C1c267BC06a7039e03fcc2eF738525769109c","0x48065fbBE25f71C9282ddf5e1cD6D6A887483D5e","0x55d398326f99059fF775485246999027B3197955","0xfd086bc7cd5c481dcc9c85ebe478a1c0b69fcbb9"],HTTP_STATUS_CODES:{SERVICE_UNAVAILABLE:503,FORBIDDEN:403},UNSUPPORTED_NETWORK_NAME:"Unknown Network",SECURE_SITE_SDK_ORIGIN:("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org"}},47588:(e,t,r)=>{"use strict";r.d(t,{p:()=>s});var i=r(82324);let s={caipNetworkIdToNumber:e=>e?Number(e.split(":")[1]):void 0,parseEvmChainId(e){return"string"==typeof e?this.caipNetworkIdToNumber(e):e},getNetworksByNamespace:(e,t)=>e?.filter(e=>e.chainNamespace===t)||[],getFirstNetworkByNamespace(e,t){return this.getNetworksByNamespace(e,t)[0]},getNetworkNameByCaipNetworkId(e,t){if(!t)return;let r=e.find(e=>e.caipNetworkId===t);if(r)return r.name;let[s]=t.split(":");return i.b.CHAIN_NAME_MAP?.[s]||void 0}}},6347:(e,t,r)=>{"use strict";r.d(t,{$U:()=>a,Vk:()=>s,mr:()=>n,uJ:()=>i});let i={WALLET_ID:"@appkit/wallet_id",WALLET_NAME:"@appkit/wallet_name",SOLANA_WALLET:"@appkit/solana_wallet",SOLANA_CAIP_CHAIN:"@appkit/solana_caip_chain",ACTIVE_CAIP_NETWORK_ID:"@appkit/active_caip_network_id",CONNECTED_SOCIAL:"@appkit/connected_social",CONNECTED_SOCIAL_USERNAME:"@appkit-wallet/SOCIAL_USERNAME",RECENT_WALLETS:"@appkit/recent_wallets",DEEPLINK_CHOICE:"WALLETCONNECT_DEEPLINK_CHOICE",ACTIVE_NAMESPACE:"@appkit/active_namespace",CONNECTED_NAMESPACES:"@appkit/connected_namespaces",CONNECTION_STATUS:"@appkit/connection_status",SIWX_AUTH_TOKEN:"@appkit/siwx-auth-token",SIWX_NONCE_TOKEN:"@appkit/siwx-nonce-token",TELEGRAM_SOCIAL_PROVIDER:"@appkit/social_provider",NATIVE_BALANCE_CACHE:"@appkit/native_balance_cache",PORTFOLIO_CACHE:"@appkit/portfolio_cache",ENS_CACHE:"@appkit/ens_cache",IDENTITY_CACHE:"@appkit/identity_cache",PREFERRED_ACCOUNT_TYPES:"@appkit/preferred_account_types",CONNECTIONS:"@appkit/connections"};function s(e){if(!e)throw Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${e}:connected_connector_id`}let n={setItem(e,t){a()&&void 0!==t&&localStorage.setItem(e,t)},getItem(e){if(a())return localStorage.getItem(e)||void 0},removeItem(e){a()&&localStorage.removeItem(e)},clear(){a()&&localStorage.clear()}};function a(){return"undefined"!=typeof window&&"undefined"!=typeof localStorage}},75393:(e,t,r)=>{"use strict";function i(e,t){return"light"===t?{"--w3m-accent":e?.["--w3m-accent"]||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":e?.["--w3m-accent"]||"hsla(230, 100%, 67%, 1)","--w3m-background":"#121313"}}r.d(t,{t:()=>i})},10081:(e,t,r)=>{"use strict";r.d(t,{N:()=>d});var i=r(43892),s=r(2201),n=r(53556),a=r(34534),o=r(27052),c=r(1326),l=r(99674);let h=(0,i.sj)({currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,allAccounts:[]}),d=(0,a.P)({state:h,replaceState(e){e&&Object.assign(h,(0,i.iH)(e))},subscribe:e=>c.R.subscribeChainProp("accountState",t=>{if(t)return e(t)}),subscribeKey(e,t,r){let i;return c.R.subscribeChainProp("accountState",r=>{if(r){let s=r[e];i!==s&&(i=s,t(s))}},r)},setStatus(e,t){c.R.setAccountProp("status",e,t)},getCaipAddress:e=>c.R.getAccountProp("caipAddress",e),setCaipAddress(e,t){let r=e?n.j.getPlainAddress(e):void 0;t===c.R.state.activeChain&&(c.R.state.activeCaipAddress=e),c.R.setAccountProp("caipAddress",e,t),c.R.setAccountProp("address",r,t)},setBalance(e,t,r){c.R.setAccountProp("balance",e,r),c.R.setAccountProp("balanceSymbol",t,r)},setProfileName(e,t){c.R.setAccountProp("profileName",e,t)},setProfileImage(e,t){c.R.setAccountProp("profileImage",e,t)},setUser(e,t){c.R.setAccountProp("user",e,t)},setAddressExplorerUrl(e,t){c.R.setAccountProp("addressExplorerUrl",e,t)},setSmartAccountDeployed(e,t){c.R.setAccountProp("smartAccountDeployed",e,t)},setCurrentTab(e){c.R.setAccountProp("currentTab",e,c.R.state.activeChain)},setTokenBalance(e,t){e&&c.R.setAccountProp("tokenBalance",e,t)},setShouldUpdateToAddress(e,t){c.R.setAccountProp("shouldUpdateToAddress",e,t)},setAllAccounts(e,t){c.R.setAccountProp("allAccounts",e,t)},addAddressLabel(e,t,r){let i=c.R.getAccountProp("addressLabels",r)||new Map;i.set(e,t),c.R.setAccountProp("addressLabels",i,r)},removeAddressLabel(e,t){let r=c.R.getAccountProp("addressLabels",t)||new Map;r.delete(e),c.R.setAccountProp("addressLabels",r,t)},setConnectedWalletInfo(e,t){c.R.setAccountProp("connectedWalletInfo",e,t,!1)},setPreferredAccountType(e,t){c.R.setAccountProp("preferredAccountTypes",{...h.preferredAccountTypes,[t]:e},t)},setPreferredAccountTypes(e){h.preferredAccountTypes=e},setSocialProvider(e,t){e&&c.R.setAccountProp("socialProvider",e,t)},setSocialWindow(e,t){c.R.setAccountProp("socialWindow",e?(0,i.iH)(e):void 0,t)},setFarcasterUrl(e,t){c.R.setAccountProp("farcasterUrl",e,t)},async fetchTokenBalance(e){h.balanceLoading=!0;let t=c.R.state.activeCaipNetwork?.caipNetworkId,r=c.R.state.activeCaipNetwork?.chainNamespace,i=c.R.state.activeCaipAddress,a=i?n.j.getPlainAddress(i):void 0;if(h.lastRetry&&!n.j.isAllowedRetry(h.lastRetry,30*s.bq.ONE_SEC_MS))return h.balanceLoading=!1,[];try{if(a&&t&&r){let e=(await o.L.getBalance(a,t)).balances.filter(e=>"0"!==e.quantity.decimals);return d.setTokenBalance(e,r),h.lastRetry=void 0,h.balanceLoading=!1,e}}catch(t){h.lastRetry=Date.now(),e?.(t),l.SnackController.showError("Token Balance Unavailable")}finally{h.balanceLoading=!1}return[]},resetAccount(e){c.R.resetAccount(e)}})},51693:(e,t,r)=>{"use strict";r.d(t,{AlertController:()=>c});var i=r(43892),s=r(95502),n=r(34534),a=r(7787);let o=(0,i.sj)({message:"",variant:"info",open:!1}),c=(0,n.P)({state:o,subscribeKey:(e,t)=>(0,s.VW)(o,e,t),open(e,t){let{debug:r}=a.OptionsController.state,{shortMessage:i,longMessage:s}=e;r&&(o.message=i,o.variant=t,o.open=!0),s&&console.error("function"==typeof s?s():s)},close(){o.open=!1,o.message="",o.variant="info"}})},65279:(e,t,r)=>{"use strict";r.d(t,{ApiController:()=>y});var i=r(43892),s=r(95502),n=r(44750),a=r(53556),o=r(64433),c=r(26818),l=r(25350),h=r(52943),d=r(1326),u=r(75257),p=r(50001),g=r(7787);let f=a.j.getApiUrl(),m=new o.V({baseUrl:f,clientId:null}),w=(0,i.sj)({promises:{},page:1,count:0,featured:[],allFeatured:[],recommended:[],allRecommended:[],wallets:[],filteredWallets:[],search:[],isAnalyticsEnabled:!1,excludedWallets:[],isFetchingRecommendedWallets:!1}),y={state:w,subscribeKey:(e,t)=>(0,s.VW)(w,e,t),_getSdkProperties(){let{projectId:e,sdkType:t,sdkVersion:r}=g.OptionsController.state;return{projectId:e,st:t||"appkit",sv:r||"html-wagmi-4.2.2"}},_filterOutExtensions:e=>g.OptionsController.state.isUniversalProvider?e.filter(e=>!!(e.mobile_link||e.desktop_link||e.webapp_link)):e,async _fetchWalletImage(e){let t=`${m.baseUrl}/getWalletImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setWalletImage(e,URL.createObjectURL(r))},async _fetchNetworkImage(e){let t=`${m.baseUrl}/public/getAssetImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setNetworkImage(e,URL.createObjectURL(r))},async _fetchConnectorImage(e){let t=`${m.baseUrl}/public/getAssetImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setConnectorImage(e,URL.createObjectURL(r))},async _fetchCurrencyImage(e){let t=`${m.baseUrl}/public/getCurrencyImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setCurrencyImage(e,URL.createObjectURL(r))},async _fetchTokenImage(e){let t=`${m.baseUrl}/public/getTokenImage/${e}`,r=await m.getBlob({path:t,params:y._getSdkProperties()});h.W.setTokenImage(e,URL.createObjectURL(r))},_filterWalletsByPlatform:e=>a.j.isMobile()?e?.filter(e=>!!e.mobile_link||e.id===c.m.COINBASE.id||"solana"===d.R.state.activeChain&&(e.id===c.m.SOLFLARE.id||e.id===c.m.PHANTOM.id)):e,fetchProjectConfig:async()=>(await m.get({path:"/appkit/v1/config",params:y._getSdkProperties()})).features,async fetchAllowedOrigins(){try{let{allowedOrigins:e}=await m.get({path:"/projects/v1/origins",params:y._getSdkProperties()});return e}catch(e){return[]}},async fetchNetworkImages(){let e=d.R.getAllRequestedCaipNetworks(),t=e?.map(({assets:e})=>e?.imageId).filter(Boolean).filter(e=>!n.f.getNetworkImageById(e));t&&await Promise.allSettled(t.map(e=>y._fetchNetworkImage(e)))},async fetchConnectorImages(){let{connectors:e}=u.ConnectorController.state,t=e.map(({imageId:e})=>e).filter(Boolean);await Promise.allSettled(t.map(e=>y._fetchConnectorImage(e)))},async fetchCurrencyImages(e=[]){await Promise.allSettled(e.map(e=>y._fetchCurrencyImage(e)))},async fetchTokenImages(e=[]){await Promise.allSettled(e.map(e=>y._fetchTokenImage(e)))},async fetchWallets(e){let t=e.exclude??[];y._getSdkProperties().sv.startsWith("html-core-")&&t.push(...Object.values(c.m).map(e=>e.id));let r=await m.get({path:"/getWallets",params:{...y._getSdkProperties(),...e,page:String(e.page),entries:String(e.entries),include:e.include?.join(","),exclude:t.join(",")}});return{data:y._filterWalletsByPlatform(r?.data)||[],count:r?.count}},async fetchFeaturedWallets(){let{featuredWalletIds:e}=g.OptionsController.state;if(e?.length){let t={...y._getSdkProperties(),page:1,entries:e?.length??4,include:e},{data:r}=await y.fetchWallets(t),i=[...r].sort((t,r)=>e.indexOf(t.id)-e.indexOf(r.id)),s=i.map(e=>e.image_id).filter(Boolean);await Promise.allSettled(s.map(e=>y._fetchWalletImage(e))),w.featured=i,w.allFeatured=i}},async fetchRecommendedWallets(){try{w.isFetchingRecommendedWallets=!0;let{includeWalletIds:e,excludeWalletIds:t,featuredWalletIds:r}=g.OptionsController.state,i=[...t??[],...r??[]].filter(Boolean),s=d.R.getRequestedCaipNetworkIds().join(","),{data:n,count:a}=await y.fetchWallets({page:1,entries:4,include:e,exclude:i,chains:s}),o=l.M.getRecentWallets(),c=n.map(e=>e.image_id).filter(Boolean),h=o.map(e=>e.image_id).filter(Boolean);await Promise.allSettled([...c,...h].map(e=>y._fetchWalletImage(e))),w.recommended=n,w.allRecommended=n,w.count=a??0}catch{}finally{w.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:e}){let{includeWalletIds:t,excludeWalletIds:r,featuredWalletIds:i}=g.OptionsController.state,s=d.R.getRequestedCaipNetworkIds().join(","),n=[...w.recommended.map(({id:e})=>e),...r??[],...i??[]].filter(Boolean),{data:o,count:c}=await y.fetchWallets({page:e,entries:40,include:t,exclude:n,chains:s}),l=o.slice(0,20).map(e=>e.image_id).filter(Boolean);await Promise.allSettled(l.map(e=>y._fetchWalletImage(e))),w.wallets=a.j.uniqueBy([...w.wallets,...y._filterOutExtensions(o)],"id").filter(e=>e.chains?.some(e=>s.includes(e))),w.count=c>w.count?c:w.count,w.page=e},async initializeExcludedWallets({ids:e}){let t={page:1,entries:e.length,include:e},{data:r}=await y.fetchWallets(t);r&&r.forEach(e=>{w.excludedWallets.push({rdns:e.rdns,name:e.name})})},async searchWallet({search:e,badge:t}){let{includeWalletIds:r,excludeWalletIds:i}=g.OptionsController.state,s=d.R.getRequestedCaipNetworkIds().join(",");w.search=[];let n={page:1,entries:100,search:e?.trim(),badge_type:t,include:r,exclude:i,chains:s},{data:o}=await y.fetchWallets(n);p.X.sendEvent({type:"track",event:"SEARCH_WALLET",properties:{badge:t??"",search:e??""}});let c=o.map(e=>e.image_id).filter(Boolean);await Promise.allSettled([...c.map(e=>y._fetchWalletImage(e)),a.j.wait(300)]),w.search=y._filterOutExtensions(o)},initPromise:(e,t)=>w.promises[e]||(w.promises[e]=t()),prefetch:({fetchConnectorImages:e=!0,fetchFeaturedWallets:t=!0,fetchRecommendedWallets:r=!0,fetchNetworkImages:i=!0}={})=>Promise.allSettled([e&&y.initPromise("connectorImages",y.fetchConnectorImages),t&&y.initPromise("featuredWallets",y.fetchFeaturedWallets),r&&y.initPromise("recommendedWallets",y.fetchRecommendedWallets),i&&y.initPromise("networkImages",y.fetchNetworkImages)].filter(Boolean)),prefetchAnalyticsConfig(){g.OptionsController.state.features?.analytics&&y.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{let{isAnalyticsEnabled:e}=await m.get({path:"/getAnalyticsConfig",params:y._getSdkProperties()});g.OptionsController.setFeatures({analytics:e})}catch(e){g.OptionsController.setFeatures({analytics:!1})}},filterByNamespaces(e){if(!e?.length){w.featured=w.allFeatured,w.recommended=w.allRecommended;return}let t=d.R.getRequestedCaipNetworkIds().join(",");w.featured=w.allFeatured.filter(e=>e.chains?.some(e=>t.includes(e))),w.recommended=w.allRecommended.filter(e=>e.chains?.some(e=>t.includes(e))),w.filteredWallets=w.wallets.filter(e=>e.chains?.some(e=>t.includes(e)))},clearFilterByNamespaces(){w.filteredWallets=[]},setFilterByNamespace(e){if(!e){w.featured=w.allFeatured,w.recommended=w.allRecommended;return}let t=d.R.getRequestedCaipNetworkIds().join(",");w.featured=w.allFeatured.filter(e=>e.chains?.some(e=>t.includes(e))),w.recommended=w.allRecommended.filter(e=>e.chains?.some(e=>t.includes(e))),w.filteredWallets=w.wallets.filter(e=>e.chains?.some(e=>t.includes(e)))}}},52943:(e,t,r)=>{"use strict";r.d(t,{W:()=>o});var i=r(43892),s=r(95502),n=r(34534);let a=(0,i.sj)({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),o=(0,n.P)({state:a,subscribeNetworkImages:e=>(0,i.Ld)(a.networkImages,()=>e(a.networkImages)),subscribeKey:(e,t)=>(0,s.VW)(a,e,t),subscribe:e=>(0,i.Ld)(a,()=>e(a)),setWalletImage(e,t){a.walletImages[e]=t},setNetworkImage(e,t){a.networkImages[e]=t},setChainImage(e,t){a.chainImages[e]=t},setConnectorImage(e,t){a.connectorImages={...a.connectorImages,[e]:t}},setTokenImage(e,t){a.tokenImages[e]=t},setCurrencyImage(e,t){a.currencyImages[e]=t}})},27052:(e,t,r)=>{"use strict";r.d(t,{L:()=>f});var i=r(43892),s=r(2201),n=r(53556),a=r(64433),o=r(25350),c=r(10081),l=r(1326),h=r(7787),d=r(99674);let u={purchaseCurrencies:[{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"Ether",symbol:"ETH",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]}],paymentCurrencies:[{id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},{id:"EUR",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]}]},p=n.j.getBlockchainApiUrl(),g=(0,i.sj)({clientId:null,api:new a.V({baseUrl:p,clientId:null}),supportedChains:{http:[],ws:[]}}),f={state:g,async get(e){let{st:t,sv:r}=f.getSdkProperties(),i=h.OptionsController.state.projectId,s={...e.params||{},st:t,sv:r,projectId:i};return g.api.get({...e,params:s})},getSdkProperties(){let{sdkType:e,sdkVersion:t}=h.OptionsController.state;return{st:e||"unknown",sv:t||"unknown"}},async isNetworkSupported(e){if(!e)return!1;try{g.supportedChains.http.length||await f.getSupportedNetworks()}catch(e){return!1}return g.supportedChains.http.includes(e)},async getSupportedNetworks(){try{let e=await f.get({path:"v1/supported-chains"});return g.supportedChains=e,e}catch{return g.supportedChains}},async fetchIdentity({address:e,caipNetworkId:t}){if(!await f.isNetworkSupported(t))return{avatar:"",name:""};let r=o.M.getIdentityFromCacheForAddress(e);if(r)return r;let i=await f.get({path:`/v1/identity/${e}`,params:{sender:l.R.state.activeCaipAddress?n.j.getPlainAddress(l.R.state.activeCaipAddress):void 0}});return o.M.updateIdentityCache({address:e,identity:i,timestamp:Date.now()}),i},fetchTransactions:async({account:e,cursor:t,onramp:r,signal:i,cache:s,chainId:n})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/account/${e}/history`,params:{cursor:t,onramp:r,chainId:n},signal:i,cache:s}):{data:[],next:void 0},fetchSwapQuote:async({amount:e,userAddress:t,from:r,to:i,gasPrice:s})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/quotes",headers:{"Content-Type":"application/json"},params:{amount:e,userAddress:t,from:r,to:i,gasPrice:s}}):{quotes:[]},fetchSwapTokens:async({chainId:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/tokens",params:{chainId:e}}):{tokens:[]},fetchTokenPrice:async({addresses:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:"/v1/fungible/price",body:{currency:"usd",addresses:e,projectId:h.OptionsController.state.projectId},headers:{"Content-Type":"application/json"}}):{fungibles:[]},fetchSwapAllowance:async({tokenAddress:e,userAddress:t})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:"/v1/convert/allowance",params:{tokenAddress:e,userAddress:t},headers:{"Content-Type":"application/json"}}):{allowance:"0"},async fetchGasPrice({chainId:e}){let{st:t,sv:r}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Gas Price");return f.get({path:"/v1/convert/gas-price",headers:{"Content-Type":"application/json"},params:{chainId:e,st:t,sv:r}})},async generateSwapCalldata({amount:e,from:t,to:r,userAddress:i,disableEstimate:n}){if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Swaps");return g.api.post({path:"/v1/convert/build-transaction",headers:{"Content-Type":"application/json"},body:{amount:e,eip155:{slippage:s.bq.CONVERT_SLIPPAGE_TOLERANCE},projectId:h.OptionsController.state.projectId,from:t,to:r,userAddress:i,disableEstimate:n}})},async generateApproveCalldata({from:e,to:t,userAddress:r}){let{st:i,sv:s}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))throw Error("Network not supported for Swaps");return f.get({path:"/v1/convert/build-approve",headers:{"Content-Type":"application/json"},params:{userAddress:r,from:e,to:t,st:i,sv:s}})},async getBalance(e,t,r){let{st:i,sv:s}=f.getSdkProperties();if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return d.SnackController.showError("Token Balance Unavailable"),{balances:[]};let n=`${t}:${e}`,a=o.M.getBalanceCacheForCaipAddress(n);if(a)return a;let c=await f.get({path:`/v1/account/${e}/balance`,params:{currency:"usd",chainId:t,forceUpdate:r,st:i,sv:s}});return o.M.updateBalanceCache({caipAddress:n,balance:c,timestamp:Date.now()}),c},lookupEnsName:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/account/${e}`,params:{apiVersion:"2"}}):{addresses:{},attributes:[]},reverseLookupEnsName:async({address:e})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/reverse/${e}`,params:{sender:c.N.state.address,apiVersion:"2"}}):[],getEnsNameSuggestions:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/profile/suggestions/${e}`,params:{zone:"reown.id"}}):{suggestions:[]},registerEnsName:async({coinType:e,address:t,message:r,signature:i})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:"/v1/profile/account",body:{coin_type:e,address:t,message:r,signature:i},headers:{"Content-Type":"application/json"}}):{success:!1},generateOnRampURL:async({destinationWallets:e,partnerUserId:t,defaultNetwork:r,purchaseAmount:i,paymentAmount:s})=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?(await g.api.post({path:"/v1/generators/onrampurl",params:{projectId:h.OptionsController.state.projectId},body:{destinationWallets:e,defaultNetwork:r,partnerUserId:t,defaultExperience:"buy",presetCryptoAmount:i,presetFiatAmount:s}})).url:"",async getOnrampOptions(){if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return{paymentCurrencies:[],purchaseCurrencies:[]};try{return await f.get({path:"/v1/onramp/options"})}catch(e){return u}},async getOnrampQuote({purchaseCurrency:e,paymentCurrency:t,amount:r,network:i}){try{if(!await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId))return null;return await g.api.post({path:"/v1/onramp/quote",params:{projectId:h.OptionsController.state.projectId},body:{purchaseCurrency:e,paymentCurrency:t,amount:r,network:i}})}catch(e){return{coinbaseFee:{amount:r,currency:t.id},networkFee:{amount:r,currency:t.id},paymentSubtotal:{amount:r,currency:t.id},paymentTotal:{amount:r,currency:t.id},purchaseAmount:{amount:r,currency:t.id},quoteId:"mocked-quote-id"}}},getSmartSessions:async e=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?f.get({path:`/v1/sessions/${e}`}):[],revokeSmartSession:async(e,t,r)=>await f.isNetworkSupported(l.R.state.activeCaipNetwork?.caipNetworkId)?g.api.post({path:`/v1/sessions/${e}/revoke`,params:{projectId:h.OptionsController.state.projectId},body:{pci:t,signature:r}}):{success:!1},setClientId(e){g.clientId=e,g.api=new a.V({baseUrl:p,clientId:e})}}},1326:(e,t,r)=>{"use strict";r.d(t,{R:()=>N});var i=r(43892),s=r(95502),n=r(47588),a=r(82324),o=r(2201),c=r(53556),l=r(25350),h=r(34534),d=r(10081),u=r(1528),p=r(75257),g=r(50001),f=r(52705),m=r(7787),w=r(14253),y=r(60892),b=r(18166);let v={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,allAccounts:[],user:void 0},C={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},E=(0,i.sj)({chains:(0,s.Yr)(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{networkControllerClient:void 0,connectionControllerClient:void 0},isSwitchingNamespace:!1}),N=(0,h.P)({state:E,subscribe:e=>(0,i.Ld)(E,()=>{e(E)}),subscribeKey:(e,t)=>(0,s.VW)(E,e,t),subscribeChainProp(e,t,r){let s;return(0,i.Ld)(E.chains,()=>{let i=r||E.activeChain;if(i){let r=E.chains.get(i)?.[e];s!==r&&(s=r,t(r))}})},initialize(e,t,r){let{chainId:s,namespace:n}=l.M.getActiveNetworkProps(),a=t?.find(e=>e.id.toString()===s?.toString()),o=e.find(e=>e?.namespace===n)||e?.[0],c=e.map(e=>e.namespace).filter(e=>void 0!==e),h=new Set(m.OptionsController.state.enableEmbedded?[...c]:[...t?.map(e=>e.chainNamespace)??[]]);e?.length!==0&&o||(E.noAdapters=!0),!E.noAdapters&&(E.activeChain=o?.namespace,E.activeCaipNetwork=a,N.setChainNetworkData(o?.namespace,{caipNetwork:a}),E.activeChain&&w.I.set({activeChain:o?.namespace})),h.forEach(e=>{let s=t?.filter(t=>t.chainNamespace===e);N.state.chains.set(e,{namespace:e,networkState:(0,i.sj)({...C,caipNetwork:s?.[0]}),accountState:(0,i.sj)(v),caipNetworks:s??[],...r}),N.setRequestedCaipNetworks(s??[],e)})},removeAdapter(e){if(E.activeChain===e){let t=Array.from(E.chains.entries()).find(([t])=>t!==e);if(t){let e=t[1]?.caipNetworks?.[0];e&&N.setActiveCaipNetwork(e)}}E.chains.delete(e)},addAdapter(e,{networkControllerClient:t,connectionControllerClient:r},i){E.chains.set(e.namespace,{namespace:e.namespace,networkState:{...C,caipNetwork:i[0]},accountState:v,caipNetworks:i,connectionControllerClient:r,networkControllerClient:t}),N.setRequestedCaipNetworks(i?.filter(t=>t.chainNamespace===e.namespace)??[],e.namespace)},addNetwork(e){let t=E.chains.get(e.chainNamespace);if(t){let r=[...t.caipNetworks||[]];t.caipNetworks?.find(t=>t.id===e.id)||r.push(e),E.chains.set(e.chainNamespace,{...t,caipNetworks:r}),N.setRequestedCaipNetworks(r,e.chainNamespace),p.ConnectorController.filterByNamespace(e.chainNamespace,!0)}},removeNetwork(e,t){let r=E.chains.get(e);if(r){let i=E.activeCaipNetwork?.id===t,s=[...r.caipNetworks?.filter(e=>e.id!==t)||[]];i&&r?.caipNetworks?.[0]&&N.setActiveCaipNetwork(r.caipNetworks[0]),E.chains.set(e,{...r,caipNetworks:s}),N.setRequestedCaipNetworks(s||[],e),0===s.length&&p.ConnectorController.filterByNamespace(e,!1)}},setAdapterNetworkState(e,t){let r=E.chains.get(e);r&&(r.networkState={...r.networkState||C,...t},E.chains.set(e,r))},setChainAccountData(e,t,r=!0){if(!e)throw Error("Chain is required to update chain account data");let i=E.chains.get(e);if(i){let r={...i.accountState||v,...t};E.chains.set(e,{...i,accountState:r}),(1===E.chains.size||E.activeChain===e)&&(t.caipAddress&&(E.activeCaipAddress=t.caipAddress),d.N.replaceState(r))}},setChainNetworkData(e,t){if(!e)return;let r=E.chains.get(e);if(r){let i={...r.networkState||C,...t};E.chains.set(e,{...r,networkState:i})}},setAccountProp(e,t,r,i=!0){N.setChainAccountData(r,{[e]:t},i),"status"===e&&"disconnected"===t&&r&&p.ConnectorController.removeConnectorId(r)},setActiveNamespace(e){E.activeChain=e;let t=e?E.chains.get(e):void 0,r=t?.networkState?.caipNetwork;r?.id&&e&&(E.activeCaipAddress=t?.accountState?.caipAddress,E.activeCaipNetwork=r,N.setChainNetworkData(e,{caipNetwork:r}),l.M.setActiveCaipNetworkId(r?.caipNetworkId),w.I.set({activeChain:e,selectedNetworkId:r?.caipNetworkId}))},setActiveCaipNetwork(e){if(!e)return;E.activeChain!==e.chainNamespace&&N.setIsSwitchingNamespace(!0);let t=E.chains.get(e.chainNamespace);E.activeChain=e.chainNamespace,E.activeCaipNetwork=e,N.setChainNetworkData(e.chainNamespace,{caipNetwork:e}),t?.accountState?.address?E.activeCaipAddress=`${e.chainNamespace}:${e.id}:${t?.accountState?.address}`:E.activeCaipAddress=void 0,N.setAccountProp("caipAddress",E.activeCaipAddress,e.chainNamespace),t&&d.N.replaceState(t.accountState),b.S.resetSend(),w.I.set({activeChain:E.activeChain,selectedNetworkId:E.activeCaipNetwork?.caipNetworkId}),l.M.setActiveCaipNetworkId(e.caipNetworkId),N.checkIfSupportedNetwork(e.chainNamespace)||!m.OptionsController.state.enableNetworkSwitch||m.OptionsController.state.allowUnsupportedChain||u.ConnectionController.state.wcBasic||N.showUnsupportedChainUI()},addCaipNetwork(e){if(!e)return;let t=E.chains.get(e.chainNamespace);t&&t?.caipNetworks?.push(e)},async switchActiveNamespace(e){if(!e)return;let t=e!==N.state.activeChain,r=N.getNetworkData(e)?.caipNetwork,i=N.getCaipNetworkByNamespace(e,r?.id);t&&i&&await N.switchActiveNetwork(i)},async switchActiveNetwork(e){let t=N.state.chains.get(N.state.activeChain),r=!t?.caipNetworks?.some(e=>e.id===E.activeCaipNetwork?.id),i=N.getNetworkControllerClient(e.chainNamespace);if(i){try{await i.switchCaipNetwork(e),r&&f.I.close()}catch(e){y.RouterController.goBack()}g.X.sendEvent({type:"track",event:"SWITCH_NETWORK",properties:{network:e.caipNetworkId}})}},getNetworkControllerClient(e){let t=e||E.activeChain,r=E.chains.get(t);if(!r)throw Error("Chain adapter not found");if(!r.networkControllerClient)throw Error("NetworkController client not set");return r.networkControllerClient},getConnectionControllerClient(e){let t=e||E.activeChain;if(!t)throw Error("Chain is required to get connection controller client");let r=E.chains.get(t);if(!r?.connectionControllerClient)throw Error("ConnectionController client not set");return r.connectionControllerClient},getAccountProp(e,t){let r=E.activeChain;if(t&&(r=t),!r)return;let i=E.chains.get(r)?.accountState;if(i)return i[e]},getNetworkProp(e,t){let r=E.chains.get(t)?.networkState;if(r)return r[e]},getRequestedCaipNetworks(e){let t=E.chains.get(e),{approvedCaipNetworkIds:r=[],requestedCaipNetworks:i=[]}=t?.networkState||{};return c.j.sortRequestedNetworks(r,i)},getAllRequestedCaipNetworks(){let e=[];return E.chains.forEach(t=>{let r=N.getRequestedCaipNetworks(t.namespace);e.push(...r)}),e},setRequestedCaipNetworks(e,t){N.setAdapterNetworkState(t,{requestedCaipNetworks:e});let r=Array.from(new Set(N.getAllRequestedCaipNetworks().map(e=>e.chainNamespace)));p.ConnectorController.filterByNamespaces(r)},getAllApprovedCaipNetworkIds(){let e=[];return E.chains.forEach(t=>{let r=N.getApprovedCaipNetworkIds(t.namespace);e.push(...r)}),e},getActiveCaipNetwork:()=>E.activeCaipNetwork,getActiveCaipAddress:()=>E.activeCaipAddress,getApprovedCaipNetworkIds(e){let t=E.chains.get(e);return t?.networkState?.approvedCaipNetworkIds||[]},async setApprovedCaipNetworksData(e){let t=N.getNetworkControllerClient(),r=await t?.getApprovedCaipNetworksData();N.setAdapterNetworkState(e,{approvedCaipNetworkIds:r?.approvedCaipNetworkIds,supportsAllNetworks:r?.supportsAllNetworks})},checkIfSupportedNetwork(e,t){let r=t||E.activeCaipNetwork,i=N.getRequestedCaipNetworks(e);return!i.length||i?.some(e=>e.id===r?.id)},checkIfSupportedChainId(e){if(!E.activeChain)return!0;let t=N.getRequestedCaipNetworks(E.activeChain);return t?.some(t=>t.id===e)},setSmartAccountEnabledNetworks(e,t){N.setAdapterNetworkState(t,{smartAccountEnabledNetworks:e})},checkIfSmartAccountEnabled(){let e=n.p.caipNetworkIdToNumber(E.activeCaipNetwork?.caipNetworkId),t=E.activeChain;if(!t||!e)return!1;let r=N.getNetworkProp("smartAccountEnabledNetworks",t);return!!r?.includes(Number(e))},getActiveNetworkTokenAddress(){let e=E.activeCaipNetwork?.chainNamespace||"eip155",t=E.activeCaipNetwork?.id||1,r=o.bq.NATIVE_TOKEN_ADDRESS[e];return`${e}:${t}:${r}`},showUnsupportedChainUI(){f.I.open({view:"UnsupportedChain"})},checkIfNamesSupported(){let e=E.activeCaipNetwork;return!!(e?.chainNamespace&&o.bq.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(e.chainNamespace))},resetNetwork(e){N.setAdapterNetworkState(e,{approvedCaipNetworkIds:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]})},resetAccount(e){if(!e)throw Error("Chain is required to set account prop");E.activeCaipAddress=void 0,N.setChainAccountData(e,{smartAccountDeployed:!1,currentTab:0,caipAddress:void 0,address:void 0,balance:void 0,balanceSymbol:void 0,profileName:void 0,profileImage:void 0,addressExplorerUrl:void 0,tokenBalance:[],connectedWalletInfo:void 0,preferredAccountTypes:void 0,socialProvider:void 0,socialWindow:void 0,farcasterUrl:void 0,allAccounts:[],user:void 0,status:"disconnected"}),p.ConnectorController.removeConnectorId(e)},setIsSwitchingNamespace(e){E.isSwitchingNamespace=e},getFirstCaipNetworkSupportsAuthConnector(){let e=[];if(E.chains.forEach(t=>{a.b.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(e=>e===t.namespace)&&t.namespace&&e.push(t.namespace)}),e.length>0){let t=e[0];return t?E.chains.get(t)?.caipNetworks?.[0]:void 0}},getAccountData:e=>e?N.state.chains.get(e)?.accountState:d.N.state,getNetworkData(e){let t=e||E.activeChain;if(t)return N.state.chains.get(t)?.networkState},getCaipNetworkByNamespace(e,t){if(!e)return;let r=N.state.chains.get(e);return r?.caipNetworks?.find(e=>e.id===t)||r?.networkState?.caipNetwork||r?.caipNetworks?.[0]},getRequestedCaipNetworkIds(){let e=p.ConnectorController.state.filterByNamespace;return(e?[E.chains.get(e)]:Array.from(E.chains.values())).flatMap(e=>e?.caipNetworks||[]).map(e=>e.caipNetworkId)},getCaipNetworks:e=>e?N.getRequestedCaipNetworks(e):N.getAllRequestedCaipNetworks()})},1528:(e,t,r)=>{"use strict";let i;r.d(t,{ConnectionController:()=>E});var s=r(43892),n=r(95502),a=r(53556),o=r(25350),c=r(34534),l=r(10081),h=r(1326),d=r(75257),u=r(50001),p=r(52705),g=r(60892),f=r(3577),m=r(27052),w=r(7787),y=r(99674);let b=(0,s.sj)({transactions:[],coinbaseTransactions:{},transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),v=(0,c.P)({state:b,subscribe:e=>(0,s.Ld)(b,()=>e(b)),setLastNetworkInView(e){b.lastNetworkInView=e},async fetchTransactions(e,t){if(!e)throw Error("Transactions can't be fetched without an accountAddress");b.loading=!0;try{let r=await m.L.fetchTransactions({account:e,cursor:b.next,onramp:t,cache:"coinbase"===t?"no-cache":void 0,chainId:h.R.state.activeCaipNetwork?.caipNetworkId}),i=v.filterSpamTransactions(r.data),s=v.filterByConnectedChain(i),n=[...b.transactions,...s];b.loading=!1,"coinbase"===t?b.coinbaseTransactions=v.groupTransactionsByYearAndMonth(b.coinbaseTransactions,r.data):(b.transactions=n,b.transactionsByYear=v.groupTransactionsByYearAndMonth(b.transactionsByYear,s)),b.empty=0===n.length,b.next=r.next?r.next:void 0}catch(r){let t=h.R.state.activeChain;u.X.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:e,projectId:w.OptionsController.state.projectId,cursor:b.next,isSmartAccount:l.N.state.preferredAccountTypes?.[t]===f.y_.ACCOUNT_TYPES.SMART_ACCOUNT}}),y.SnackController.showError("Failed to fetch transactions"),b.loading=!1,b.empty=!0,b.next=void 0}},groupTransactionsByYearAndMonth:(e={},t=[])=>(t.forEach(t=>{let r=new Date(t.metadata.minedAt).getFullYear(),i=new Date(t.metadata.minedAt).getMonth(),s=e[r]??{},n=(s[i]??[]).filter(e=>e.id!==t.id);e[r]={...s,[i]:[...n,t].sort((e,t)=>new Date(t.metadata.minedAt).getTime()-new Date(e.metadata.minedAt).getTime())}}),e),filterSpamTransactions:e=>e.filter(e=>!e.transfers.every(e=>e.nft_info?.flags.is_spam===!0)),filterByConnectedChain(e){let t=h.R.state.activeCaipNetwork?.caipNetworkId;return e.filter(e=>e.metadata.chain===t)},clearCursor(){b.next=void 0},resetTransactions(){b.transactions=[],b.transactionsByYear={},b.lastNetworkInView=void 0,b.loading=!1,b.empty=!1,b.next=void 0}},"API_ERROR"),C=(0,s.sj)({connections:new Map,wcError:!1,buffering:!1,status:"disconnected"}),E=(0,c.P)({state:C,subscribeKey:(e,t)=>(0,n.VW)(C,e,t),_getClient:()=>C._client,setClient(e){C._client=(0,s.iH)(e)},async connectWalletConnect(){if(a.j.isTelegram()||a.j.isSafari()&&a.j.isIos()){if(i){await i,i=void 0;return}if(!a.j.isPairingExpired(C?.wcPairingExpiry)){let e=C.wcUri;C.wcUri=e;return}i=E._getClient()?.connectWalletConnect?.().catch(()=>void 0),E.state.status="connecting",await i,i=void 0,C.wcPairingExpiry=void 0,E.state.status="connected"}else await E._getClient()?.connectWalletConnect?.()},async connectExternal(e,t,r=!0){await E._getClient()?.connectExternal?.(e),r&&h.R.setActiveNamespace(t)},async reconnectExternal(e){await E._getClient()?.reconnectExternal?.(e);let t=e.chain||h.R.state.activeChain;t&&d.ConnectorController.setConnectorId(e.id,t)},async setPreferredAccountType(e,t){p.I.setLoading(!0,h.R.state.activeChain);let r=d.ConnectorController.getAuthConnector();r&&(l.N.setPreferredAccountType(e,t),await r.provider.setPreferredAccount(e),o.M.setPreferredAccountTypes(l.N.state.preferredAccountTypes??{[t]:e}),await E.reconnectExternal(r),p.I.setLoading(!1,h.R.state.activeChain),u.X.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:e,network:h.R.state.activeCaipNetwork?.caipNetworkId||""}}))},signMessage:async e=>E._getClient()?.signMessage(e),parseUnits:(e,t)=>E._getClient()?.parseUnits(e,t),formatUnits:(e,t)=>E._getClient()?.formatUnits(e,t),sendTransaction:async e=>E._getClient()?.sendTransaction(e),getCapabilities:async e=>E._getClient()?.getCapabilities(e),grantPermissions:async e=>E._getClient()?.grantPermissions(e),walletGetAssets:async e=>E._getClient()?.walletGetAssets(e)??{},estimateGas:async e=>E._getClient()?.estimateGas(e),writeContract:async e=>E._getClient()?.writeContract(e),getEnsAddress:async e=>E._getClient()?.getEnsAddress(e),getEnsAvatar:async e=>E._getClient()?.getEnsAvatar(e),checkInstalled:e=>E._getClient()?.checkInstalled?.(e)||!1,resetWcConnection(){C.wcUri=void 0,C.wcPairingExpiry=void 0,C.wcLinking=void 0,C.recentWallet=void 0,C.status="disconnected",v.resetTransactions(),o.M.deleteWalletConnectDeepLink()},resetUri(){C.wcUri=void 0,C.wcPairingExpiry=void 0,i=void 0},finalizeWcConnection(){let{wcLinking:e,recentWallet:t}=E.state;e&&o.M.setWalletConnectDeepLink(e),t&&o.M.setAppKitRecent(t),u.X.sendEvent({type:"track",event:"CONNECT_SUCCESS",properties:{method:e?"mobile":"qrcode",name:g.RouterController.state.data?.wallet?.name||"Unknown"}})},setWcBasic(e){C.wcBasic=e},setUri(e){C.wcUri=e,C.wcPairingExpiry=a.j.getPairingExpiry()},setWcLinking(e){C.wcLinking=e},setWcError(e){C.wcError=e,C.buffering=!1},setRecentWallet(e){C.recentWallet=e},setBuffering(e){C.buffering=e},setStatus(e){C.status=e},async disconnect(e){try{await E._getClient()?.disconnect(e)}catch(e){throw new c.g("Failed to disconnect","INTERNAL_SDK_ERROR",e)}},setConnections(e,t){C.connections.set(t,e)},switchAccount({connection:e,address:t,namespace:r}){if(d.ConnectorController.state.activeConnectorIds[r]===e.connectorId){let e=h.R.state.activeCaipNetwork;if(e){let i=`${r}:${e.id}:${t}`;l.N.setCaipAddress(i,r)}else console.warn(`No current network found for namespace "${r}"`)}else{let t=d.ConnectorController.getConnector(e.connectorId);t?E.connectExternal(t,r):console.warn(`No connector found for namespace "${r}"`)}}})},75257:(e,t,r)=>{"use strict";r.d(t,{ConnectorController:()=>w});var i=r(43892),s=r(95502),n=r(82324),a=r(75393),o=r(26818),c=r(25350),l=r(34534),h=r(65279),d=r(1326),u=r(7787),p=r(60892),g=r(11986);let f={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0},m=(0,i.sj)({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:{...f},filterByNamespaceMap:{eip155:!0,solana:!0,polkadot:!0,bip122:!0,cosmos:!0}}),w=(0,l.P)({state:m,subscribe:e=>(0,i.Ld)(m,()=>{e(m)}),subscribeKey:(e,t)=>(0,s.VW)(m,e,t),initialize(e){e.forEach(e=>{let t=c.M.getConnectedConnectorId(e);t&&w.setConnectorId(t,e)})},setActiveConnector(e){e&&(m.activeConnector=(0,i.iH)(e))},setConnectors(e){e.filter(e=>!m.allConnectors.some(t=>t.id===e.id&&w.getConnectorName(t.name)===w.getConnectorName(e.name)&&t.chain===e.chain)).forEach(e=>{"MULTI_CHAIN"!==e.type&&m.allConnectors.push((0,i.iH)(e))});let t=w.getEnabledNamespaces(),r=w.getEnabledConnectors(t);m.connectors=w.mergeMultiChainConnectors(r)},filterByNamespaces(e){Object.keys(m.filterByNamespaceMap).forEach(e=>{m.filterByNamespaceMap[e]=!1}),e.forEach(e=>{m.filterByNamespaceMap[e]=!0}),w.updateConnectorsForEnabledNamespaces()},filterByNamespace(e,t){m.filterByNamespaceMap[e]=t,w.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){let e=w.getEnabledNamespaces(),t=w.getEnabledConnectors(e),r=w.areAllNamespacesEnabled();m.connectors=w.mergeMultiChainConnectors(t),r?h.ApiController.clearFilterByNamespaces():h.ApiController.filterByNamespaces(e)},getEnabledNamespaces:()=>Object.entries(m.filterByNamespaceMap).filter(([e,t])=>t).map(([e])=>e),getEnabledConnectors:e=>m.allConnectors.filter(t=>e.includes(t.chain)),areAllNamespacesEnabled:()=>Object.values(m.filterByNamespaceMap).every(e=>e),mergeMultiChainConnectors(e){let t=w.generateConnectorMapByName(e),r=[];return t.forEach(e=>{let t=e[0],i=t?.id===n.b.CONNECTOR_ID.AUTH;e.length>1&&t?r.push({name:t.name,imageUrl:t.imageUrl,imageId:t.imageId,connectors:[...e],type:i?"AUTH":"MULTI_CHAIN",chain:"eip155",id:t?.id||""}):t&&r.push(t)}),r},generateConnectorMapByName(e){let t=new Map;return e.forEach(e=>{let{name:r}=e,i=w.getConnectorName(r);if(!i)return;let s=t.get(i)||[];s.find(t=>t.chain===e.chain)||s.push(e),t.set(i,s)}),t},getConnectorName:e=>e&&({"Trust Wallet":"Trust"})[e]||e,getUniqueConnectorsByName(e){let t=[];return e.forEach(e=>{t.find(t=>t.chain===e.chain)||t.push(e)}),t},addConnector(e){if(e.id===n.b.CONNECTOR_ID.AUTH){let t=(0,i.CO)(u.OptionsController.state),r=g.ThemeController.getSnapshot().themeMode,s=g.ThemeController.getSnapshot().themeVariables;e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,projectId:t.projectId,sdkType:t.sdkType}),e?.provider?.syncTheme({themeMode:r,themeVariables:s,w3mThemeVariables:a.t(s,r)}),w.setConnectors([e])}else w.setConnectors([e])},getAuthConnector(e){let t=e||d.R.state.activeChain,r=m.connectors.find(e=>e.id===n.b.CONNECTOR_ID.AUTH);return r?r?.connectors?.length?r.connectors.find(e=>e.chain===t):r:void 0},getAnnouncedConnectorRdns:()=>m.connectors.filter(e=>"ANNOUNCED"===e.type).map(e=>e.info?.rdns),getConnectorById:e=>m.allConnectors.find(t=>t.id===e),getConnector:(e,t)=>m.allConnectors.filter(e=>e.chain===d.R.state.activeChain).find(r=>r.explorerId===e||r.info?.rdns===t),syncIfAuthConnector(e){if("ID_AUTH"!==e.id)return;let t=(0,i.CO)(u.OptionsController.state),r=g.ThemeController.getSnapshot().themeMode,s=g.ThemeController.getSnapshot().themeVariables;e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,sdkType:t.sdkType,projectId:t.projectId}),e.provider.syncTheme({themeMode:r,themeVariables:s,w3mThemeVariables:(0,a.t)(s,r)})},getConnectorsByNamespace(e){let t=m.allConnectors.filter(t=>t.chain===e);return w.mergeMultiChainConnectors(t)},selectWalletConnector(e){let t=w.getConnector(e.id,e.rdns),r=d.R.state.activeChain;o.R.handleMobileDeeplinkRedirect(t?.explorerId||e.id,r),t?p.RouterController.push("ConnectingExternal",{connector:t}):p.RouterController.push("ConnectingWalletConnect",{wallet:e})},getConnectors:e=>e?w.getConnectorsByNamespace(e):w.mergeMultiChainConnectors(m.allConnectors),setFilterByNamespace(e){m.filterByNamespace=e,m.connectors=w.getConnectors(e),h.ApiController.setFilterByNamespace(e)},setConnectorId(e,t){e&&(m.activeConnectorIds={...m.activeConnectorIds,[t]:e},c.M.setConnectedConnectorId(t,e))},removeConnectorId(e){m.activeConnectorIds={...m.activeConnectorIds,[e]:void 0},c.M.deleteConnectedConnectorId(e)},getConnectorId(e){if(e)return m.activeConnectorIds[e]},isConnected:e=>e?!!m.activeConnectorIds[e]:Object.values(m.activeConnectorIds).some(e=>!!e),resetConnectorIds(){m.activeConnectorIds={...f}}})},50001:(e,t,r)=>{"use strict";r.d(t,{X:()=>f});var i=r(43892),s=r(82324),n=r(6347),a=r(53556),o=r(64433),c=r(10081),l=r(51693),h=r(7787);let d=a.j.getAnalyticsUrl(),u=new o.V({baseUrl:d,clientId:null}),p=["MODAL_CREATED"],g=(0,i.sj)({timestamp:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"}}),f={state:g,subscribe:e=>(0,i.Ld)(g,()=>e(g)),getSdkProperties(){let{projectId:e,sdkType:t,sdkVersion:r}=h.OptionsController.state;return{projectId:e,st:t,sv:r||"html-wagmi-4.2.2"}},async _sendAnalyticsEvent(e){try{let t=c.N.state.address;if(p.includes(e.data.event)||"undefined"==typeof window)return;await u.post({path:"/e",params:f.getSdkProperties(),body:{eventId:a.j.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:e.timestamp,props:{...e.data,address:t}}}),g.reportedErrors.FORBIDDEN=!1}catch(e){e instanceof Error&&e.cause instanceof Response&&e.cause.status===s.b.HTTP_STATUS_CODES.FORBIDDEN&&!g.reportedErrors.FORBIDDEN&&(l.AlertController.open({shortMessage:"Invalid App Configuration",longMessage:`Origin ${(0,n.$U)()?window.origin:"uknown"} not found on Allowlist - update configuration on cloud.reown.com`},"error"),g.reportedErrors.FORBIDDEN=!0)}},sendEvent(e){g.timestamp=Date.now(),g.data=e,h.OptionsController.state.features?.analytics&&f._sendAnalyticsEvent(g)}}},52705:(e,t,r)=>{"use strict";r.d(t,{I:()=>b});var i=r(43892),s=r(95502),n=r(53556),a=r(82324),o=r(10081),c=r(1326),l=r(75257),h=r(60892);let d={onSwitchNetwork({network:e,ignoreSwitchConfirmation:t=!1}){let r=c.R.state.activeCaipNetwork,i=h.RouterController.state.data;if(e.id===r?.id)return;let s=o.N.getCaipAddress(c.R.state.activeChain),n=e.chainNamespace!==c.R.state.activeChain,d=o.N.getCaipAddress(e.chainNamespace),u=l.ConnectorController.getConnectorId(c.R.state.activeChain)===a.b.CONNECTOR_ID.AUTH,p=a.b.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(t=>t===e.chainNamespace);t||u&&p?h.RouterController.push("SwitchNetwork",{...i,network:e}):s&&n&&!d?h.RouterController.push("SwitchActiveChain",{switchToChain:e.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:e}):h.RouterController.push("SwitchNetwork",{...i,network:e})}};var u=r(34534),p=r(65279),g=r(1528),f=r(50001),m=r(7787),w=r(14253);let y=(0,i.sj)({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),b=(0,u.P)({state:y,subscribe:e=>(0,i.Ld)(y,()=>e(y)),subscribeKey:(e,t)=>(0,s.VW)(y,e,t),async open(e){let t="connected"===o.N.state.status,r=e?.namespace,i=c.R.state.activeChain,s=r&&r!==i,a=c.R.getAccountData(e?.namespace)?.caipAddress;if(g.ConnectionController.state.wcBasic?p.ApiController.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1}):await p.ApiController.prefetch({fetchConnectorImages:!t,fetchFeaturedWallets:!t,fetchRecommendedWallets:!t}),l.ConnectorController.setFilterByNamespace(e?.namespace),b.setLoading(!0,r),r&&s){let e=c.R.getNetworkData(r)?.caipNetwork||c.R.getRequestedCaipNetworks(r)[0];e&&d.onSwitchNetwork({network:e,ignoreSwitchConfirmation:!0})}else{let t=c.R.state.noAdapters;m.OptionsController.state.manualWCControl||t&&!a?n.j.isMobile()?h.RouterController.reset("AllWallets"):h.RouterController.reset("ConnectingWalletConnectBasic"):e?.view?h.RouterController.reset(e.view,e.data):a?h.RouterController.reset("Account"):h.RouterController.reset("Connect")}y.open=!0,w.I.set({open:!0}),f.X.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!a}})},close(){let e=m.OptionsController.state.enableEmbedded,t=!!c.R.state.activeCaipAddress;y.open&&f.X.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:t}}),y.open=!1,h.RouterController.reset("Connect"),b.clearLoading(),e?t?h.RouterController.replace("Account"):h.RouterController.push("Connect"):w.I.set({open:!1}),g.ConnectionController.resetUri()},setLoading(e,t){t&&y.loadingNamespaceMap.set(t,e),y.loading=e,w.I.set({loading:e})},clearLoading(){y.loadingNamespaceMap.clear(),y.loading=!1},shake(){y.shake||(y.shake=!0,setTimeout(()=>{y.shake=!1},500))}})},7787:(e,t,r)=>{"use strict";r.d(t,{OptionsController:()=>l});var i=r(43892),s=r(95502),n=r(2201),a=r(53556);let o={getFeatureValue(e,t){let r=t?.[e];return void 0===r?n.bq.DEFAULT_FEATURES[e]:r},filterSocialsByPlatform(e){if(!e||!e.length)return e;if(a.j.isTelegram()){if(a.j.isIos())return e.filter(e=>"google"!==e);if(a.j.isMac())return e.filter(e=>"x"!==e);if(a.j.isAndroid())return e.filter(e=>!["facebook","x"].includes(e))}return e}},c=(0,i.sj)({features:n.bq.DEFAULT_FEATURES,projectId:"",sdkType:"appkit",sdkVersion:"html-wagmi-undefined",defaultAccountTypes:n.bq.DEFAULT_ACCOUNT_TYPES,enableNetworkSwitch:!0,experimental_preferUniversalLinks:!1,remoteFeatures:{}}),l={state:c,subscribeKey:(e,t)=>(0,s.VW)(c,e,t),setOptions(e){Object.assign(c,e)},setRemoteFeatures(e){if(!e)return;let t={...c.remoteFeatures,...e};c.remoteFeatures=t,c.remoteFeatures?.socials&&(c.remoteFeatures.socials=o.filterSocialsByPlatform(c.remoteFeatures.socials))},setFeatures(e){if(!e)return;c.features||(c.features=n.bq.DEFAULT_FEATURES);let t={...c.features,...e};c.features=t},setProjectId(e){c.projectId=e},setCustomRpcUrls(e){c.customRpcUrls=e},setAllWallets(e){c.allWallets=e},setIncludeWalletIds(e){c.includeWalletIds=e},setExcludeWalletIds(e){c.excludeWalletIds=e},setFeaturedWalletIds(e){c.featuredWalletIds=e},setTokens(e){c.tokens=e},setTermsConditionsUrl(e){c.termsConditionsUrl=e},setPrivacyPolicyUrl(e){c.privacyPolicyUrl=e},setCustomWallets(e){c.customWallets=e},setIsSiweEnabled(e){c.isSiweEnabled=e},setIsUniversalProvider(e){c.isUniversalProvider=e},setSdkVersion(e){c.sdkVersion=e},setMetadata(e){c.metadata=e},setDisableAppend(e){c.disableAppend=e},setEIP6963Enabled(e){c.enableEIP6963=e},setDebug(e){c.debug=e},setEnableWalletConnect(e){c.enableWalletConnect=e},setEnableWalletGuide(e){c.enableWalletGuide=e},setEnableAuthLogger(e){c.enableAuthLogger=e},setEnableWallets(e){c.enableWallets=e},setPreferUniversalLinks(e){c.experimental_preferUniversalLinks=e},setHasMultipleAddresses(e){c.hasMultipleAddresses=e},setSIWX(e){c.siwx=e},setConnectMethodsOrder(e){c.features={...c.features,connectMethodsOrder:e}},setWalletFeaturesOrder(e){c.features={...c.features,walletFeaturesOrder:e}},setSocialsOrder(e){c.remoteFeatures={...c.remoteFeatures,socials:e}},setCollapseWallets(e){c.features={...c.features,collapseWallets:e}},setEnableEmbedded(e){c.enableEmbedded=e},setAllowUnsupportedChain(e){c.allowUnsupportedChain=e},setManualWCControl(e){c.manualWCControl=e},setEnableNetworkSwitch(e){c.enableNetworkSwitch=e},setDefaultAccountTypes(e={}){Object.entries(e).forEach(([e,t])=>{t&&(c.defaultAccountTypes[e]=t)})},setUniversalProviderConfigOverride(e){c.universalProviderConfigOverride=e},getUniversalProviderConfigOverride:()=>c.universalProviderConfigOverride,getSnapshot:()=>(0,i.CO)(c)}},14253:(e,t,r)=>{"use strict";r.d(t,{I:()=>a});var i=r(43892),s=r(95502);let n=(0,i.sj)({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1}),a={state:n,subscribe:e=>(0,i.Ld)(n,()=>e(n)),subscribeOpen:e=>(0,s.VW)(n,"open",e),set(e){Object.assign(n,{...n,...e})}}},60892:(e,t,r)=>{"use strict";r.d(t,{RouterController:()=>u});var i=r(43892),s=r(95502),n=r(34534),a=r(10081),o=r(1326),c=r(75257),l=r(52705),h=r(7787);let d=(0,i.sj)({view:"Connect",history:["Connect"],transactionStack:[]}),u=(0,n.P)({state:d,subscribeKey:(e,t)=>(0,s.VW)(d,e,t),pushTransactionStack(e){d.transactionStack.push(e)},popTransactionStack(e){let t=d.transactionStack.pop();if(!t)return;let{onSuccess:r,onError:i,onCancel:s}=t;switch(e){case"success":r?.();break;case"error":i?.(),u.goBack();break;case"cancel":s?.(),u.goBack()}},push(e,t){e!==d.view&&(d.view=e,d.history.push(e),d.data=t)},reset(e,t){d.view=e,d.history=[e],d.data=t},replace(e,t){d.history.at(-1)!==e&&(d.view=e,d.history[d.history.length-1]=e,d.data=t)},goBack(){let e=o.R.state.activeCaipAddress,t="ConnectingFarcaster"===u.state.view,r=!e&&t;if(d.history.length>1){d.history.pop();let[t]=d.history.slice(-1);t&&(e&&"Connect"===t?d.view="Account":d.view=t)}else l.I.close();d.data?.wallet&&(d.data.wallet=void 0),setTimeout(()=>{if(r){a.N.setFarcasterUrl(void 0,o.R.state.activeChain);let e=c.ConnectorController.getAuthConnector();e?.provider?.reload();let t=(0,i.CO)(h.OptionsController.state);e?.provider?.syncDappData?.({metadata:t.metadata,sdkVersion:t.sdkVersion,projectId:t.projectId,sdkType:t.sdkType})}},100)},goBackToIndex(e){if(d.history.length>1){d.history=d.history.slice(0,e+1);let[t]=d.history.slice(-1);t&&(d.view=t)}},goBackOrCloseModal(){u.state.history.length>1?u.goBack():l.I.close()}})},18166:(e,t,r)=>{"use strict";r.d(t,{S:()=>$});var i=r(43892),s=r(95502),n="[big.js] ",a=n+"Invalid ",o=a+"decimal places",c=a+"rounding mode",l=n+"Division by zero",h={},d=void 0,u=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function p(e,t,r,i){var s=e.c;if(r===d&&(r=e.constructor.RM),0!==r&&1!==r&&2!==r&&3!==r)throw Error(c);if(t<1)i=3===r&&(i||!!s[0])||0===t&&(1===r&&s[0]>=5||2===r&&(s[0]>5||5===s[0]&&(i||s[1]!==d))),s.length=1,i?(e.e=e.e-t+1,s[0]=1):s[0]=e.e=0;else if(t<s.length){if(i=1===r&&s[t]>=5||2===r&&(s[t]>5||5===s[t]&&(i||s[t+1]!==d||1&s[t-1]))||3===r&&(i||!!s[0]),s.length=t,i){for(;++s[--t]>9;)if(s[t]=0,0===t){++e.e,s.unshift(1);break}}for(t=s.length;!s[--t];)s.pop()}return e}function g(e,t,r){var i=e.e,s=e.c.join(""),n=s.length;if(t)s=s.charAt(0)+(n>1?"."+s.slice(1):"")+(i<0?"e":"e+")+i;else if(i<0){for(;++i;)s="0"+s;s="0."+s}else if(i>0){if(++i>n)for(i-=n;i--;)s+="0";else i<n&&(s=s.slice(0,i)+"."+s.slice(i))}else n>1&&(s=s.charAt(0)+"."+s.slice(1));return e.s<0&&r?"-"+s:s}h.abs=function(){var e=new this.constructor(this);return e.s=1,e},h.cmp=function(e){var t,r=this.c,i=(e=new this.constructor(e)).c,s=this.s,n=e.s,a=this.e,o=e.e;if(!r[0]||!i[0])return r[0]?s:i[0]?-n:0;if(s!=n)return s;if(t=s<0,a!=o)return a>o^t?1:-1;for(s=-1,n=(a=r.length)<(o=i.length)?a:o;++s<n;)if(r[s]!=i[s])return r[s]>i[s]^t?1:-1;return a==o?0:a>o^t?1:-1},h.div=function(e){var t=this.constructor,r=this.c,i=(e=new t(e)).c,s=this.s==e.s?1:-1,n=t.DP;if(n!==~~n||n<0||n>1e6)throw Error(o);if(!i[0])throw Error(l);if(!r[0])return e.s=s,e.c=[e.e=0],e;var a,c,h,u,g,f=i.slice(),m=a=i.length,w=r.length,y=r.slice(0,a),b=y.length,v=e,C=v.c=[],E=0,N=n+(v.e=this.e-e.e)+1;for(v.s=s,s=N<0?0:N,f.unshift(0);b++<a;)y.push(0);do{for(h=0;h<10;h++){if(a!=(b=y.length))u=a>b?1:-1;else for(g=-1,u=0;++g<a;)if(i[g]!=y[g]){u=i[g]>y[g]?1:-1;break}if(u<0){for(c=b==a?i:f;b;){if(y[--b]<c[b]){for(g=b;g&&!y[--g];)y[g]=9;--y[g],y[b]+=10}y[b]-=c[b]}for(;!y[0];)y.shift()}else break}C[E++]=u?h:++h,y[0]&&u?y[b]=r[m]||0:y=[r[m]]}while((m++<w||y[0]!==d)&&s--);return!C[0]&&1!=E&&(C.shift(),v.e--,N--),E>N&&p(v,N,t.RM,y[0]!==d),v},h.eq=function(e){return 0===this.cmp(e)},h.gt=function(e){return this.cmp(e)>0},h.gte=function(e){return this.cmp(e)>-1},h.lt=function(e){return 0>this.cmp(e)},h.lte=function(e){return 1>this.cmp(e)},h.minus=h.sub=function(e){var t,r,i,s,n=this.constructor,a=this.s,o=(e=new n(e)).s;if(a!=o)return e.s=-o,this.plus(e);var c=this.c.slice(),l=this.e,h=e.c,d=e.e;if(!c[0]||!h[0])return h[0]?e.s=-o:c[0]?e=new n(this):e.s=1,e;if(a=l-d){for((s=a<0)?(a=-a,i=c):(d=l,i=h),i.reverse(),o=a;o--;)i.push(0);i.reverse()}else for(r=((s=c.length<h.length)?c:h).length,a=o=0;o<r;o++)if(c[o]!=h[o]){s=c[o]<h[o];break}if(s&&(i=c,c=h,h=i,e.s=-e.s),(o=(r=h.length)-(t=c.length))>0)for(;o--;)c[t++]=0;for(o=t;r>a;){if(c[--r]<h[r]){for(t=r;t&&!c[--t];)c[t]=9;--c[t],c[r]+=10}c[r]-=h[r]}for(;0===c[--o];)c.pop();for(;0===c[0];)c.shift(),--d;return c[0]||(e.s=1,c=[d=0]),e.c=c,e.e=d,e},h.mod=function(e){var t,r=this,i=r.constructor,s=r.s,n=(e=new i(e)).s;if(!e.c[0])throw Error(l);return(r.s=e.s=1,t=1==e.cmp(r),r.s=s,e.s=n,t)?new i(r):(s=i.DP,n=i.RM,i.DP=i.RM=0,r=r.div(e),i.DP=s,i.RM=n,this.minus(r.times(e)))},h.neg=function(){var e=new this.constructor(this);return e.s=-e.s,e},h.plus=h.add=function(e){var t,r,i,s=this.constructor;if(e=new s(e),this.s!=e.s)return e.s=-e.s,this.minus(e);var n=this.e,a=this.c,o=e.e,c=e.c;if(!a[0]||!c[0])return c[0]||(a[0]?e=new s(this):e.s=this.s),e;if(a=a.slice(),t=n-o){for(t>0?(o=n,i=c):(t=-t,i=a),i.reverse();t--;)i.push(0);i.reverse()}for(a.length-c.length<0&&(i=c,c=a,a=i),t=c.length,r=0;t;a[t]%=10)r=(a[--t]=a[t]+c[t]+r)/10|0;for(r&&(a.unshift(r),++o),t=a.length;0===a[--t];)a.pop();return e.c=a,e.e=o,e},h.pow=function(e){var t=this,r=new t.constructor("1"),i=r,s=e<0;if(e!==~~e||e<-1e6||e>1e6)throw Error(a+"exponent");for(s&&(e=-e);1&e&&(i=i.times(t)),e>>=1;)t=t.times(t);return s?r.div(i):i},h.prec=function(e,t){if(e!==~~e||e<1||e>1e6)throw Error(a+"precision");return p(new this.constructor(this),e,t)},h.round=function(e,t){if(e===d)e=0;else if(e!==~~e||e<-1e6||e>1e6)throw Error(o);return p(new this.constructor(this),e+this.e+1,t)},h.sqrt=function(){var e,t,r,i=this.constructor,s=this.s,a=this.e,o=new i("0.5");if(!this.c[0])return new i(this);if(s<0)throw Error(n+"No square root");0===(s=Math.sqrt(+g(this,!0,!0)))||s===1/0?((t=this.c.join("")).length+a&1||(t+="0"),a=((a+1)/2|0)-(a<0||1&a),e=new i(((s=Math.sqrt(t))==1/0?"5e":(s=s.toExponential()).slice(0,s.indexOf("e")+1))+a)):e=new i(s+""),a=e.e+(i.DP+=4);do r=e,e=o.times(r.plus(this.div(r)));while(r.c.slice(0,a).join("")!==e.c.slice(0,a).join(""));return p(e,(i.DP-=4)+e.e+1,i.RM)},h.times=h.mul=function(e){var t,r=this.constructor,i=this.c,s=(e=new r(e)).c,n=i.length,a=s.length,o=this.e,c=e.e;if(e.s=this.s==e.s?1:-1,!i[0]||!s[0])return e.c=[e.e=0],e;for(e.e=o+c,n<a&&(t=i,i=s,s=t,c=n,n=a,a=c),t=Array(c=n+a);c--;)t[c]=0;for(o=a;o--;){for(a=0,c=n+o;c>o;)a=t[c]+s[o]*i[c-o-1]+a,t[c--]=a%10,a=a/10|0;t[c]=a}for(a?++e.e:t.shift(),o=t.length;!t[--o];)t.pop();return e.c=t,e},h.toExponential=function(e,t){var r=this,i=r.c[0];if(e!==d){if(e!==~~e||e<0||e>1e6)throw Error(o);for(r=p(new r.constructor(r),++e,t);r.c.length<e;)r.c.push(0)}return g(r,!0,!!i)},h.toFixed=function(e,t){var r=this,i=r.c[0];if(e!==d){if(e!==~~e||e<0||e>1e6)throw Error(o);for(r=p(new r.constructor(r),e+r.e+1,t),e=e+r.e+1;r.c.length<e;)r.c.push(0)}return g(r,!1,!!i)},h[Symbol.for("nodejs.util.inspect.custom")]=h.toJSON=h.toString=function(){var e=this.constructor;return g(this,this.e<=e.NE||this.e>=e.PE,!!this.c[0])},h.toNumber=function(){var e=+g(this,!0,!0);if(!0===this.constructor.strict&&!this.eq(e.toString()))throw Error(n+"Imprecise conversion");return e},h.toPrecision=function(e,t){var r=this,i=r.constructor,s=r.c[0];if(e!==d){if(e!==~~e||e<1||e>1e6)throw Error(a+"precision");for(r=p(new i(r),e,t);r.c.length<e;)r.c.push(0)}return g(r,e<=r.e||r.e<=i.NE||r.e>=i.PE,!!s)},h.valueOf=function(){var e=this.constructor;if(!0===e.strict)throw Error(n+"valueOf disallowed");return g(this,this.e<=e.NE||this.e>=e.PE,!0)};var f=function e(){function t(r){if(!(this instanceof t))return r===d?e():new t(r);if(r instanceof t)this.s=r.s,this.e=r.e,this.c=r.c.slice();else{if("string"!=typeof r){if(!0===t.strict&&"bigint"!=typeof r)throw TypeError(a+"value");r=0===r&&1/r<0?"-0":String(r)}(function(e,t){var r,i,s;if(!u.test(t))throw Error(a+"number");for(e.s="-"==t.charAt(0)?(t=t.slice(1),-1):1,(r=t.indexOf("."))>-1&&(t=t.replace(".","")),(i=t.search(/e/i))>0?(r<0&&(r=i),r+=+t.slice(i+1),t=t.substring(0,i)):r<0&&(r=t.length),s=t.length,i=0;i<s&&"0"==t.charAt(i);)++i;if(i==s)e.c=[e.e=0];else{for(;s>0&&"0"==t.charAt(--s););for(e.e=r-i-1,e.c=[],r=0;i<=s;)e.c[r++]=+t.charAt(i++)}})(this,r)}this.constructor=t}return t.prototype=h,t.DP=20,t.RM=1,t.NE=-7,t.PE=21,t.strict=!1,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}();let m={bigNumber:e=>new f(e||0),multiply(e,t){if(void 0===e||void 0===t)return new f(0);let r=new f(e),i=new f(t);return r.times(i)},formatNumberToLocalString:(e,t=2)=>void 0===e?"0.00":"number"==typeof e?e.toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}):parseFloat(e).toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}),parseLocalStringToNumber:e=>void 0===e?0:parseFloat(e.replace(/,/gu,""))},w=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],y=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"sender",type:"address"},{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{name:"",type:"bool"}]}];var b=r(82324);let v={getERC20Abi:e=>b.b.USDT_CONTRACT_ADDRESSES.includes(e)?y:w};var C=r(3577),E=r(2201),N=r(53556),I=r(10081),A=r(27052),_=r(1326),S=r(1528),O=r(73262);let P={createBalance(e,t){let r={name:e.metadata.name||"",symbol:e.metadata.symbol||"",decimals:e.metadata.decimals||0,value:e.metadata.value||0,price:e.metadata.price||0,iconUrl:e.metadata.iconUrl||""};return{name:r.name,symbol:r.symbol,chainId:t,address:"native"===e.address?void 0:this.convertAddressToCAIP10Address(e.address,t),value:r.value,price:r.price,quantity:{decimals:r.decimals.toString(),numeric:this.convertHexToBalance({hex:e.balance,decimals:r.decimals})},iconUrl:r.iconUrl}},convertHexToBalance:({hex:e,decimals:t})=>(0,O.b)(BigInt(e),t),convertAddressToCAIP10Address:(e,t)=>`${t}:${e}`,createCAIP2ChainId:(e,t)=>`${t}:${parseInt(e,16)}`,getChainIdHexFromCAIP2ChainId(e){let t=e.split(":");if(t.length<2||!t[1])return"0x0";let r=parseInt(t[1],10);return isNaN(r)?"0x0":`0x${r.toString(16)}`},isWalletGetAssetsResponse(e){return"object"==typeof e&&null!==e&&Object.values(e).every(e=>Array.isArray(e)&&e.every(e=>this.isValidAsset(e)))},isValidAsset:e=>"object"==typeof e&&null!==e&&"string"==typeof e.address&&"string"==typeof e.balance&&("ERC20"===e.type||"NATIVE"===e.type)&&"object"==typeof e.metadata&&null!==e.metadata&&"string"==typeof e.metadata.name&&"string"==typeof e.metadata.symbol&&"number"==typeof e.metadata.decimals&&"number"==typeof e.metadata.price&&"string"==typeof e.metadata.iconUrl},T={async getMyTokensWithBalance(e){let t=I.N.state.address,r=_.R.state.activeCaipNetwork;if(!t||!r)return[];if("eip155"===r.chainNamespace){let e=await this.getEIP155Balances(t,r);if(e)return this.filterLowQualityTokens(e)}let i=await A.L.getBalance(t,r.caipNetworkId,e);return this.filterLowQualityTokens(i.balances)},async getEIP155Balances(e,t){try{let r=P.getChainIdHexFromCAIP2ChainId(t.caipNetworkId),i=await S.ConnectionController.getCapabilities(e);if(!i?.[r]?.assetDiscovery?.supported)return null;let s=await S.ConnectionController.walletGetAssets({account:e,chainFilter:[r]});if(!P.isWalletGetAssetsResponse(s))return null;return(s[r]||[]).map(e=>P.createBalance(e,t.caipNetworkId))}catch(e){return null}},filterLowQualityTokens:e=>e.filter(e=>"0"!==e.quantity.decimals),mapBalancesToSwapTokens:e=>e?.map(e=>({...e,address:e?.address?e.address:_.R.getActiveNetworkTokenAddress(),decimals:parseInt(e.quantity.decimals,10),logoUri:e.iconUrl,eip2612:!1}))||[]};var R=r(34534),k=r(50001),x=r(60892),U=r(99674);let D=(0,i.sj)({tokenBalances:[],loading:!1}),$=(0,R.P)({state:D,subscribe:e=>(0,i.Ld)(D,()=>e(D)),subscribeKey:(e,t)=>(0,s.VW)(D,e,t),setToken(e){e&&(D.token=(0,i.iH)(e))},setTokenAmount(e){D.sendTokenAmount=e},setReceiverAddress(e){D.receiverAddress=e},setReceiverProfileImageUrl(e){D.receiverProfileImageUrl=e},setReceiverProfileName(e){D.receiverProfileName=e},setNetworkBalanceInUsd(e){D.networkBalanceInUSD=e},setLoading(e){D.loading=e},async sendToken(){try{switch($.setLoading(!0),_.R.state.activeCaipNetwork?.chainNamespace){case"eip155":await $.sendEvmToken();return;case"solana":await $.sendSolanaToken();return;default:throw Error("Unsupported chain")}}finally{$.setLoading(!1)}},async sendEvmToken(){let e=_.R.state.activeChain,t=I.N.state.preferredAccountTypes?.[e];if(!$.state.sendTokenAmount||!$.state.receiverAddress)throw Error("An amount and receiver address are required");if(!$.state.token)throw Error("A token is required");$.state.token?.address?(k.X.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:t===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token.address,amount:$.state.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),await $.sendERC20Token({receiverAddress:$.state.receiverAddress,tokenAddress:$.state.token.address,sendTokenAmount:$.state.sendTokenAmount,decimals:$.state.token.quantity.decimals})):(k.X.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:t===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token.symbol||"",amount:$.state.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),await $.sendNativeToken({receiverAddress:$.state.receiverAddress,sendTokenAmount:$.state.sendTokenAmount,decimals:$.state.token.quantity.decimals}))},async fetchTokenBalance(e){D.loading=!0;let t=_.R.state.activeCaipNetwork?.caipNetworkId,r=_.R.state.activeCaipNetwork?.chainNamespace,i=_.R.state.activeCaipAddress,s=i?N.j.getPlainAddress(i):void 0;if(D.lastRetry&&!N.j.isAllowedRetry(D.lastRetry,30*E.bq.ONE_SEC_MS))return D.loading=!1,[];try{if(s&&t&&r){let e=await T.getMyTokensWithBalance();return D.tokenBalances=e,D.lastRetry=void 0,e}}catch(t){D.lastRetry=Date.now(),e?.(t),U.SnackController.showError("Token Balance Unavailable")}finally{D.loading=!1}return[]},fetchNetworkBalance(){if(0===D.tokenBalances.length)return;let e=T.mapBalancesToSwapTokens(D.tokenBalances);if(!e)return;let t=e.find(e=>e.address===_.R.getActiveNetworkTokenAddress());t&&(D.networkBalanceInUSD=t?m.multiply(t.quantity.numeric,t.price).toString():"0")},async sendNativeToken(e){x.RouterController.pushTransactionStack({});let t=e.receiverAddress,r=I.N.state.address,i=S.ConnectionController.parseUnits(e.sendTokenAmount.toString(),Number(e.decimals));await S.ConnectionController.sendTransaction({chainNamespace:"eip155",to:t,address:r,data:"0x",value:i??BigInt(0)}),k.X.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:I.N.state.preferredAccountTypes?.eip155===C.y_.ACCOUNT_TYPES.SMART_ACCOUNT,token:$.state.token?.symbol||"",amount:e.sendTokenAmount,network:_.R.state.activeCaipNetwork?.caipNetworkId||""}}),S.ConnectionController._getClient()?.updateBalance("eip155"),$.resetSend()},async sendERC20Token(e){x.RouterController.pushTransactionStack({onSuccess(){x.RouterController.replace("Account")}});let t=S.ConnectionController.parseUnits(e.sendTokenAmount.toString(),Number(e.decimals));if(I.N.state.address&&e.sendTokenAmount&&e.receiverAddress&&e.tokenAddress){let r=N.j.getPlainAddress(e.tokenAddress);await S.ConnectionController.writeContract({fromAddress:I.N.state.address,tokenAddress:r,args:[e.receiverAddress,t??BigInt(0)],method:"transfer",abi:v.getERC20Abi(r),chainNamespace:"eip155"}),$.resetSend()}},async sendSolanaToken(){if(!$.state.sendTokenAmount||!$.state.receiverAddress)throw Error("An amount and receiver address are required");x.RouterController.pushTransactionStack({onSuccess(){x.RouterController.replace("Account")}}),await S.ConnectionController.sendTransaction({chainNamespace:"solana",to:$.state.receiverAddress,value:$.state.sendTokenAmount}),S.ConnectionController._getClient()?.updateBalance("solana"),$.resetSend()},resetSend(){D.token=void 0,D.sendTokenAmount=void 0,D.receiverAddress=void 0,D.receiverProfileImageUrl=void 0,D.receiverProfileName=void 0,D.loading=!1,D.tokenBalances=[]}})},99674:(e,t,r)=>{"use strict";r.d(t,{SnackController:()=>c});var i=r(43892),s=r(95502),n=r(53556);let a=Object.freeze({message:"",variant:"success",svg:void 0,open:!1,autoClose:!0}),o=(0,i.sj)({...a}),c={state:o,subscribeKey:(e,t)=>(0,s.VW)(o,e,t),showLoading(e,t={}){this._showMessage({message:e,variant:"loading",...t})},showSuccess(e){this._showMessage({message:e,variant:"success"})},showSvg(e,t){this._showMessage({message:e,svg:t})},showError(e){let t=n.j.parseError(e);this._showMessage({message:t,variant:"error"})},hide(){o.message=a.message,o.variant=a.variant,o.svg=a.svg,o.open=a.open,o.autoClose=a.autoClose},_showMessage({message:e,svg:t,variant:r="success",autoClose:i=a.autoClose}){o.open?(o.open=!1,setTimeout(()=>{o.message=e,o.variant=r,o.svg=t,o.open=!0,o.autoClose=i},150)):(o.message=e,o.variant=r,o.svg=t,o.open=!0,o.autoClose=i)}}},11986:(e,t,r)=>{"use strict";r.d(t,{ThemeController:()=>l});var i=r(43892),s=r(75393),n=r(34534),a=r(75257);let o=(0,i.sj)({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),c={state:o,subscribe:e=>(0,i.Ld)(o,()=>e(o)),setThemeMode(e){o.themeMode=e;try{let t=a.ConnectorController.getAuthConnector();if(t){let r=c.getSnapshot().themeVariables;t.provider.syncTheme({themeMode:e,themeVariables:r,w3mThemeVariables:(0,s.t)(r,e)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(e){o.themeVariables={...o.themeVariables,...e};try{let e=a.ConnectorController.getAuthConnector();if(e){let t=c.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:t,w3mThemeVariables:(0,s.t)(o.themeVariables,o.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot:()=>(0,i.CO)(o)},l=(0,n.P)(c)},44750:(e,t,r)=>{"use strict";r.d(t,{f:()=>c});var i=r(43892),s=r(65279),n=r(52943);let a={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:""},o=(0,i.sj)({networkImagePromises:{}}),c={async fetchWalletImage(e){if(e)return await s.ApiController._fetchWalletImage(e),this.getWalletImageById(e)},async fetchNetworkImage(e){if(e)return this.getNetworkImageById(e)||(o.networkImagePromises[e]||(o.networkImagePromises[e]=s.ApiController._fetchNetworkImage(e)),await o.networkImagePromises[e],this.getNetworkImageById(e))},getWalletImageById(e){if(e)return n.W.state.walletImages[e]},getWalletImage:e=>e?.image_url?e?.image_url:e?.image_id?n.W.state.walletImages[e.image_id]:void 0,getNetworkImage:e=>e?.assets?.imageUrl?e?.assets?.imageUrl:e?.assets?.imageId?n.W.state.networkImages[e.assets.imageId]:void 0,getNetworkImageById(e){if(e)return n.W.state.networkImages[e]},getConnectorImage:e=>e?.imageUrl?e.imageUrl:e?.imageId?n.W.state.connectorImages[e.imageId]:void 0,getChainImage:e=>n.W.state.networkImages[a[e]]}},2201:(e,t,r)=>{"use strict";r.d(t,{a$:()=>n,bq:()=>a,gy:()=>s});let i=("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",s=[{label:"Coinbase",name:"coinbase",feeRange:"1-2%",url:"",supportedChains:["eip155"]},{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],n="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",a={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:i,SECURE_SITE_DASHBOARD:`${i}/dashboard`,SECURE_SITE_FAVICON:`${i}/images/favicon.png`,RESTRICTED_TIMEZONES:["ASIA/SHANGHAI","ASIA/URUMQI","ASIA/CHONGQING","ASIA/HARBIN","ASIA/KASHGAR","ASIA/MACAU","ASIA/HONG_KONG","ASIA/MACAO","ASIA/BEIJING","ASIA/HARBIN"],WC_COINBASE_PAY_SDK_CHAINS:["ethereum","arbitrum","polygon","berachain","avalanche-c-chain","optimism","celo","base"],WC_COINBASE_PAY_SDK_FALLBACK_CHAIN:"ethereum",WC_COINBASE_PAY_SDK_CHAIN_NAME_MAP:{Ethereum:"ethereum","Arbitrum One":"arbitrum",Polygon:"polygon",Berachain:"berachain",Avalanche:"avalanche-c-chain","OP Mainnet":"optimism",Celo:"celo",Base:"base"},WC_COINBASE_ONRAMP_APP_ID:"bf18c88d-495a-463b-b249-0b9d3656cf5e",SWAP_SUGGESTED_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP"],SWAP_POPULAR_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP","METAL","DAI","CHAMP","WOLF","SALE","BAL","BUSD","MUST","BTCpx","ROUTE","HEX","WELT","amDAI","VSQ","VISION","AURUM","pSP","SNX","VC","LINK","CHP","amUSDT","SPHERE","FOX","GIDDY","GFC","OMEN","OX_OLD","DE","WNT"],BALANCE_SUPPORTED_CHAINS:["eip155","solana"],SWAP_SUPPORTED_NETWORKS:["eip155:1","eip155:42161","eip155:10","eip155:324","eip155:8453","eip155:56","eip155:137","eip155:100","eip155:43114","eip155:250","eip155:8217","eip155:1313161554"],NAMES_SUPPORTED_CHAIN_NAMESPACES:["eip155"],ONRAMP_SUPPORTED_CHAIN_NAMESPACES:["eip155","solana"],ACTIVITY_ENABLED_CHAIN_NAMESPACES:["eip155"],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x"},CONVERT_SLIPPAGE_TOLERANCE:1,CONNECT_LABELS:{MOBILE:"Open and continue in the wallet app",WEB:"Open and continue in the wallet app"},SEND_SUPPORTED_NAMESPACES:["eip155","solana"],DEFAULT_REMOTE_FEATURES:{swaps:["1inch"],onramp:["coinbase","meld"],email:!0,socials:["google","x","discord","farcaster","github","apple","facebook"],activity:!0,reownBranding:!0},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1},DEFAULT_FEATURES:{receive:!0,send:!0,emailShowWallets:!0,connectorTypeOrder:["walletConnect","recent","injected","featured","custom","external","recommended"],analytics:!0,allWallets:!0,legalCheckbox:!1,smartSessions:!1,collapseWallets:!1,walletFeaturesOrder:["onramp","swaps","receive","send"],connectMethodsOrder:void 0,pay:!1},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"}}},53556:(e,t,r)=>{"use strict";r.d(t,{j:()=>a});var i=r(82324),s=r(2201),n=r(25350);let a={isMobile(){return!!this.isClient()&&!!("function"==typeof window?.matchMedia&&window?.matchMedia("(pointer:coarse)")?.matches||/Android|webOS|iPhone|iPad|iPod|BlackBerry|Opera Mini/u.test(navigator.userAgent))},checkCaipNetwork:(e,t="")=>e?.caipNetworkId.toLocaleLowerCase().includes(t.toLowerCase()),isAndroid(){if(!this.isMobile())return!1;let e=window?.navigator.userAgent.toLowerCase();return a.isMobile()&&e.includes("android")},isIos(){if(!this.isMobile())return!1;let e=window?.navigator.userAgent.toLowerCase();return e.includes("iphone")||e.includes("ipad")},isSafari(){return!!this.isClient()&&(window?.navigator.userAgent.toLowerCase()).includes("safari")},isClient:()=>"undefined"!=typeof window,isPairingExpired:e=>!e||e-Date.now()<=s.bq.TEN_SEC_MS,isAllowedRetry:(e,t=s.bq.ONE_SEC_MS)=>Date.now()-e>=t,copyToClopboard(e){navigator.clipboard.writeText(e)},isIframe(){try{return window?.self!==window?.top}catch(e){return!1}},isSafeApp(){if(a.isClient()&&window.self!==window.top)try{let e=window?.location?.ancestorOrigins?.[0];if(e){let t=new URL(e),r=new URL("https://app.safe.global");return t.hostname===r.hostname}}catch{}return!1},getPairingExpiry:()=>Date.now()+s.bq.FOUR_MINUTES_MS,getNetworkId:e=>e?.split(":")[1],getPlainAddress:e=>e?.split(":")[2],wait:async e=>new Promise(t=>{setTimeout(t,e)}),debounce(e,t=500){let r;return(...i)=>{r&&clearTimeout(r),r=setTimeout(function(){e(...i)},t)}},isHttpUrl:e=>e.startsWith("http://")||e.startsWith("https://"),formatNativeUrl(e,t,r=null){if(a.isHttpUrl(e))return this.formatUniversalUrl(e,t);let i=e,s=r;i.includes("://")||(i=e.replaceAll("/","").replaceAll(":",""),i=`${i}://`),i.endsWith("/")||(i=`${i}/`),s&&!s?.endsWith("/")&&(s=`${s}/`),this.isTelegram()&&this.isAndroid()&&(t=encodeURIComponent(t));let n=encodeURIComponent(t);return{redirect:`${i}wc?uri=${n}`,redirectUniversalLink:s?`${s}wc?uri=${n}`:void 0,href:i}},formatUniversalUrl(e,t){if(!a.isHttpUrl(e))return this.formatNativeUrl(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let i=encodeURIComponent(t);return{redirect:`${r}wc?uri=${i}`,href:r}},getOpenTargetForPlatform(e){return"popupWindow"===e?e:this.isTelegram()?n.M.getTelegramSocialProvider()?"_top":"_blank":e},openHref(e,t,r){window?.open(e,this.getOpenTargetForPlatform(t),r||"noreferrer noopener")},returnOpenHref(e,t,r){return window?.open(e,this.getOpenTargetForPlatform(t),r||"noreferrer noopener")},isTelegram:()=>"undefined"!=typeof window&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto),isPWA(){if("undefined"==typeof window)return!1;let e=window.matchMedia?.("(display-mode: standalone)")?.matches,t=window?.navigator?.standalone;return!!(e||t)},preloadImage:async e=>Promise.race([new Promise((t,r)=>{let i=new Image;i.onload=t,i.onerror=r,i.crossOrigin="anonymous",i.src=e}),a.wait(2e3)]),formatBalance(e,t){let r="0.000";if("string"==typeof e){let t=Number(e);if(t){let e=Math.floor(1e3*t)/1e3;e&&(r=e.toString())}}return`${r}${t?` ${t}`:""}`},formatBalance2(e,t){let r;if("0"===e)r="0";else if("string"==typeof e){let t=Number(e);t&&(r=t.toString().match(/^-?\d+(?:\.\d{0,3})?/u)?.[0])}return{value:r??"0",rest:"0"===r?"000":"",symbol:t}},getApiUrl:()=>i.b.W3M_API_URL,getBlockchainApiUrl:()=>i.b.BLOCKCHAIN_API_RPC_URL,getAnalyticsUrl:()=>i.b.PULSE_API_URL,getUUID:()=>crypto?.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,e=>{let t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}),parseError:e=>"string"==typeof e?e:"string"==typeof e?.issues?.[0]?.message?e.issues[0].message:e instanceof Error?e.message:"Unknown error",sortRequestedNetworks(e,t=[]){let r={};return t&&e&&(e.forEach((e,t)=>{r[e]=t}),t.sort((e,t)=>{let i=r[e.id],s=r[t.id];return void 0!==i&&void 0!==s?i-s:void 0!==i?-1:void 0!==s?1:0})),t},calculateBalance(e){let t=0;for(let r of e)t+=r.value??0;return t},formatTokenBalance(e){let[t,r]=e.toFixed(2).split(".");return{dollars:t,pennies:r}},isAddress(e,t="eip155"){switch(t){case"eip155":if(/^(?:0x)?[0-9a-f]{40}$/iu.test(e)&&(/^(?:0x)?[0-9a-f]{40}$/iu.test(e)||/^(?:0x)?[0-9A-F]{40}$/iu.test(e)))return!0;return!1;case"solana":return/[1-9A-HJ-NP-Za-km-z]{32,44}$/iu.test(e);default:return!1}},uniqueBy(e,t){let r=new Set;return e.filter(e=>{let i=e[t];return!r.has(i)&&(r.add(i),!0)})},generateSdkVersion(e,t,r){let i=0===e.length?s.bq.ADAPTER_TYPES.UNIVERSAL:e.map(e=>e.adapterType).join(",");return`${t}-${i}-${r}`},createAccount:(e,t,r,i,s)=>({namespace:e,address:t,type:r,publicKey:i,path:s}),isCaipAddress(e){if("string"!=typeof e)return!1;let t=e.split(":"),r=t[0];return 3===t.filter(Boolean).length&&r in i.b.CHAIN_NAME_MAP},isMac(){let e=window?.navigator.userAgent.toLowerCase();return e.includes("macintosh")&&!e.includes("safari")},formatTelegramSocialLoginUrl(e){let t=`--${encodeURIComponent(window?.location.href)}`,r="state=";if("auth.magic.link"===new URL(e).host){let i="provider_authorization_url=",s=e.substring(e.indexOf(i)+i.length),n=this.injectIntoUrl(decodeURIComponent(s),r,t);return e.replace(s,encodeURIComponent(n))}return this.injectIntoUrl(e,r,t)},injectIntoUrl(e,t,r){let i=e.indexOf(t);if(-1===i)throw Error(`${t} parameter not found in the URL: ${e}`);let s=e.indexOf("&",i),n=t.length,a=-1!==s?s:e.length,o=e.substring(0,i+n);return o+(e.substring(i+n,a)+r)+e.substring(s)}}},64433:(e,t,r)=>{"use strict";async function i(...e){let t=await fetch(...e);if(!t.ok)throw Error(`HTTP status code: ${t.status}`,{cause:t});return t}r.d(t,{V:()=>s});class s{constructor({baseUrl:e,clientId:t}){this.baseUrl=e,this.clientId=t}async get({headers:e,signal:t,cache:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"GET",headers:e,signal:t,cache:r})).json()}async getBlob({headers:e,signal:t,...r}){let s=this.createUrl(r);return(await i(s,{method:"GET",headers:e,signal:t})).blob()}async post({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"POST",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}async put({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"PUT",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}async delete({body:e,headers:t,signal:r,...s}){let n=this.createUrl(s);return(await i(n,{method:"DELETE",headers:t,body:e?JSON.stringify(e):void 0,signal:r})).json()}createUrl({path:e,params:t}){let r=new URL(e,this.baseUrl);return t&&Object.entries(t).forEach(([e,t])=>{t&&r.searchParams.append(e,t)}),this.clientId&&r.searchParams.append("clientId",this.clientId),r}}},26818:(e,t,r)=>{"use strict";r.d(t,{R:()=>n,m:()=>s});var i=r(82324);let s={PHANTOM:{id:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",url:"https://phantom.app"},SOLFLARE:{id:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",url:"https://solflare.com"},COINBASE:{id:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",url:"https://go.cb-w.com"}},n={handleMobileDeeplinkRedirect(e,t){let r=window.location.href,n=encodeURIComponent(r);if(e===s.PHANTOM.id&&!("phantom"in window)){let e=r.startsWith("https")?"https":"http",t=r.split("/")[2],i=encodeURIComponent(`${e}://${t}`);window.location.href=`${s.PHANTOM.url}/ul/browse/${n}?ref=${i}`}e!==s.SOLFLARE.id||"solflare"in window||(window.location.href=`${s.SOLFLARE.url}/ul/v1/browse/${n}?ref=${n}`),t!==i.b.CHAIN.SOLANA||e!==s.COINBASE.id||"coinbaseSolana"in window||(window.location.href=`${s.COINBASE.url}/dapp?cb_url=${n}`)}}},90161:(e,t,r)=>{"use strict";r.d(t,{w:()=>f}),r(50691);var i=r(82324),s=r(3577),n=r(10081),a=r(1326),o=r(1528),c=r(75257),l=r(50001),h=r(52705),d=r(7787),u=r(60892),p=r(99674),g=r(53556);let f={getSIWX:()=>d.OptionsController.state.siwx,async initializeIfEnabled(){let e=d.OptionsController.state.siwx,t=a.R.getActiveCaipAddress();if(!(e&&t))return;let[r,i,s]=t.split(":");if(a.R.checkIfSupportedNetwork(r))try{if((await e.getSessions(`${r}:${i}`,s)).length)return;await h.I.open({view:"SIWXSignMessage"})}catch(e){console.error("SIWXUtil:initializeIfEnabled",e),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties()}),await o.ConnectionController._getClient()?.disconnect().catch(console.error),u.RouterController.reset("Connect"),p.SnackController.showError("A problem occurred while trying initialize authentication")}},async requestSignMessage(){let e=d.OptionsController.state.siwx,t=g.j.getPlainAddress(a.R.getActiveCaipAddress()),r=a.R.getActiveCaipNetwork(),s=o.ConnectionController._getClient();if(!e)throw Error("SIWX is not enabled");if(!t)throw Error("No ActiveCaipAddress found");if(!r)throw Error("No ActiveCaipNetwork or client found");if(!s)throw Error("No ConnectionController client found");try{let n=await e.createMessage({chainId:r.caipNetworkId,accountAddress:t}),a=n.toString();c.ConnectorController.getConnectorId(r.chainNamespace)===i.b.CONNECTOR_ID.AUTH&&u.RouterController.pushTransactionStack({});let o=await s.signMessage(a);await e.addSession({data:n,message:a,signature:o}),h.I.close(),l.X.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(t){let e=this.getSIWXEventProperties();h.I.state.open&&"ApproveTransaction"!==u.RouterController.state.view||await h.I.open({view:"SIWXSignMessage"}),e.isSmartAccount?p.SnackController.showError("This application might not support Smart Accounts"):p.SnackController.showError("Signature declined"),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:e}),console.error("SWIXUtil:requestSignMessage",t)}},async cancelSignMessage(){try{let e=this.getSIWX();e?.getRequired?.()?await o.ConnectionController.disconnect():h.I.close(),u.RouterController.reset("Connect"),l.X.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getSessions(){let e=d.OptionsController.state.siwx,t=g.j.getPlainAddress(a.R.getActiveCaipAddress()),r=a.R.getActiveCaipNetwork();return e&&t&&r?e.getSessions(r.caipNetworkId,t):[]},async isSIWXCloseDisabled(){let e=this.getSIWX();if(e){let t="ApproveTransaction"===u.RouterController.state.view,r="SIWXSignMessage"===u.RouterController.state.view;if(t||r)return e.getRequired?.()&&0===(await this.getSessions()).length}return!1},async universalProviderAuthenticate({universalProvider:e,chains:t,methods:r}){let i=f.getSIWX(),s=new Set(t.map(e=>e.split(":")[0]));if(!i||1!==s.size||!s.has("eip155"))return!1;let o=await i.createMessage({chainId:a.R.getActiveCaipNetwork()?.caipNetworkId||"",accountAddress:""}),c=await e.authenticate({nonce:o.nonce,domain:o.domain,uri:o.uri,exp:o.expirationTime,iat:o.issuedAt,nbf:o.notBefore,requestId:o.requestId,version:o.version,resources:o.resources,statement:o.statement,chainId:o.chainId,methods:r,chains:[o.chainId,...t.filter(e=>e!==o.chainId)]});if(p.SnackController.showLoading("Authenticating...",{autoClose:!1}),n.N.setConnectedWalletInfo({...c.session.peer.metadata,name:c.session.peer.metadata.name,icon:c.session.peer.metadata.icons?.[0],type:"WALLET_CONNECT"},Array.from(s)[0]),c?.auths?.length){let t=c.auths.map(t=>{let r=e.client.formatAuthMessage({request:t.p,iss:t.p.iss});return{data:{...t.p,accountAddress:t.p.iss.split(":").slice(-1).join(""),chainId:t.p.iss.split(":").slice(2,4).join(":"),uri:t.p.aud,version:t.p.version||o.version,expirationTime:t.p.exp,issuedAt:t.p.iat,notBefore:t.p.nbf},message:r,signature:t.s.s,cacao:t}});try{await i.setSessions(t),l.X.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:f.getSIWXEventProperties()})}catch(t){throw console.error("SIWX:universalProviderAuth - failed to set sessions",t),l.X.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:f.getSIWXEventProperties()}),await e.disconnect().catch(console.error),t}finally{p.SnackController.hide()}}return!0},getSIWXEventProperties(){let e=a.R.state.activeChain;return{network:a.R.state.activeCaipNetwork?.caipNetworkId||"",isSmartAccount:n.N.state.preferredAccountTypes?.[e]===s.y_.ACCOUNT_TYPES.SMART_ACCOUNT}},async clearSessions(){let e=this.getSIWX();e&&await e.setSessions([])}}},25350:(e,t,r)=>{"use strict";r.d(t,{M:()=>s});var i=r(6347);let s={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5},isCacheExpired:(e,t)=>Date.now()-e>t,getActiveNetworkProps(){let e=s.getActiveNamespace(),t=s.getActiveCaipNetworkId(),r=t?t.split(":")[1]:void 0;return{namespace:e,caipNetworkId:t,chainId:r?isNaN(Number(r))?r:Number(r):void 0}},setWalletConnectDeepLink({name:e,href:t}){try{i.mr.setItem(i.uJ.DEEPLINK_CHOICE,JSON.stringify({href:t,name:e}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{let e=i.mr.getItem(i.uJ.DEEPLINK_CHOICE);if(e)return JSON.parse(e)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{i.mr.removeItem(i.uJ.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(e){try{i.mr.setItem(i.uJ.ACTIVE_NAMESPACE,e)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(e){try{i.mr.setItem(i.uJ.ACTIVE_CAIP_NETWORK_ID,e),s.setActiveNamespace(e.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return i.mr.getItem(i.uJ.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{i.mr.removeItem(i.uJ.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(e){try{let t=(0,i.Vk)(e);i.mr.removeItem(t)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(e){try{let t=s.getRecentWallets();t.find(t=>t.id===e.id)||(t.unshift(e),t.length>2&&t.pop(),i.mr.setItem(i.uJ.RECENT_WALLETS,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{let e=i.mr.getItem(i.uJ.RECENT_WALLETS);return e?JSON.parse(e):[]}catch{console.info("Unable to get AppKit recent")}return[]},setConnectedConnectorId(e,t){try{let r=(0,i.Vk)(e);i.mr.setItem(r,t)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return i.mr.getItem(i.uJ.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(e){if(e)try{let t=(0,i.Vk)(e);return i.mr.getItem(t)}catch(t){console.info("Unable to get connected connector id in namespace ",e)}},setConnectedSocialProvider(e){try{i.mr.setItem(i.uJ.CONNECTED_SOCIAL,e)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return i.mr.getItem(i.uJ.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{i.mr.removeItem(i.uJ.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return i.mr.getItem(i.uJ.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){let e=i.mr.getItem(i.uJ.ACTIVE_CAIP_NETWORK_ID);return e?.split(":")?.[1]},setConnectionStatus(e){try{i.mr.setItem(i.uJ.CONNECTION_STATUS,e)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return i.mr.getItem(i.uJ.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{let e=i.mr.getItem(i.uJ.CONNECTED_NAMESPACES);if(!e?.length)return[];return e.split(",")}catch{return[]}},setConnectedNamespaces(e){try{let t=Array.from(new Set(e));i.mr.setItem(i.uJ.CONNECTED_NAMESPACES,t.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(e){try{let t=s.getConnectedNamespaces();t.includes(e)||(t.push(e),s.setConnectedNamespaces(t))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(e){try{let t=s.getConnectedNamespaces(),r=t.indexOf(e);r>-1&&(t.splice(r,1),s.setConnectedNamespaces(t))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return i.mr.getItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(e){try{i.mr.setItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER,e)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{i.mr.removeItem(i.uJ.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let e={};try{let t=i.mr.getItem(i.uJ.PORTFOLIO_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get balance cache")}return e},removeAddressFromBalanceCache(e){try{let t=s.getBalanceCache();i.mr.setItem(i.uJ.PORTFOLIO_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove address from balance cache",e)}},getBalanceCacheForCaipAddress(e){try{let t=s.getBalanceCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.portfolio))return t.balance;s.removeAddressFromBalanceCache(e)}catch{console.info("Unable to get balance cache for address",e)}},updateBalanceCache(e){try{let t=s.getBalanceCache();t[e.caipAddress]=e,i.mr.setItem(i.uJ.PORTFOLIO_CACHE,JSON.stringify(t))}catch{console.info("Unable to update balance cache",e)}},getNativeBalanceCache(){let e={};try{let t=i.mr.getItem(i.uJ.NATIVE_BALANCE_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get balance cache")}return e},removeAddressFromNativeBalanceCache(e){try{let t=s.getBalanceCache();i.mr.setItem(i.uJ.NATIVE_BALANCE_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove address from balance cache",e)}},getNativeBalanceCacheForCaipAddress(e){try{let t=s.getNativeBalanceCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.nativeBalance))return t;console.info("Discarding cache for address",e),s.removeAddressFromBalanceCache(e)}catch{console.info("Unable to get balance cache for address",e)}},updateNativeBalanceCache(e){try{let t=s.getNativeBalanceCache();t[e.caipAddress]=e,i.mr.setItem(i.uJ.NATIVE_BALANCE_CACHE,JSON.stringify(t))}catch{console.info("Unable to update balance cache",e)}},getEnsCache(){let e={};try{let t=i.mr.getItem(i.uJ.ENS_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get ens name cache")}return e},getEnsFromCacheForAddress(e){try{let t=s.getEnsCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.ens))return t.ens;s.removeEnsFromCache(e)}catch{console.info("Unable to get ens name from cache",e)}},updateEnsCache(e){try{let t=s.getEnsCache();t[e.address]=e,i.mr.setItem(i.uJ.ENS_CACHE,JSON.stringify(t))}catch{console.info("Unable to update ens name cache",e)}},removeEnsFromCache(e){try{let t=s.getEnsCache();i.mr.setItem(i.uJ.ENS_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove ens name from cache",e)}},getIdentityCache(){let e={};try{let t=i.mr.getItem(i.uJ.IDENTITY_CACHE);e=t?JSON.parse(t):{}}catch{console.info("Unable to get identity cache")}return e},getIdentityFromCacheForAddress(e){try{let t=s.getIdentityCache()[e];if(t&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.identity))return t.identity;s.removeIdentityFromCache(e)}catch{console.info("Unable to get identity from cache",e)}},updateIdentityCache(e){try{let t=s.getIdentityCache();t[e.address]={identity:e.identity,timestamp:e.timestamp},i.mr.setItem(i.uJ.IDENTITY_CACHE,JSON.stringify(t))}catch{console.info("Unable to update identity cache",e)}},removeIdentityFromCache(e){try{let t=s.getIdentityCache();i.mr.setItem(i.uJ.IDENTITY_CACHE,JSON.stringify({...t,[e]:void 0}))}catch{console.info("Unable to remove identity from cache",e)}},clearAddressCache(){try{i.mr.removeItem(i.uJ.PORTFOLIO_CACHE),i.mr.removeItem(i.uJ.NATIVE_BALANCE_CACHE),i.mr.removeItem(i.uJ.ENS_CACHE),i.mr.removeItem(i.uJ.IDENTITY_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(e){try{i.mr.setItem(i.uJ.PREFERRED_ACCOUNT_TYPES,JSON.stringify(e))}catch{console.info("Unable to set preferred account types",e)}},getPreferredAccountTypes(){try{let e=i.mr.getItem(i.uJ.PREFERRED_ACCOUNT_TYPES);if(!e)return{};return JSON.parse(e)}catch{console.info("Unable to get preferred account types")}return{}},setConnections(e,t){try{let r={...s.getConnections(),[t]:e};i.mr.setItem(i.uJ.CONNECTIONS,JSON.stringify(r))}catch(e){console.error("Unable to sync connections to storage",e)}},getConnections(){try{let e=i.mr.getItem(i.uJ.CONNECTIONS);if(!e)return{};return JSON.parse(e)}catch(e){return console.error("Unable to get connections from storage",e),{}}}}},34534:(e,t,r)=>{"use strict";r.d(t,{g:()=>u,P:()=>g});var i=r(43892),s=r(95502),n=r(53556),a=r(64433),o=r(7787);let c=Object.freeze({enabled:!0,events:[]}),l=new a.V({baseUrl:n.j.getAnalyticsUrl(),clientId:null}),h=(0,i.sj)({...c}),d={state:h,subscribeKey:(e,t)=>(0,s.VW)(h,e,t),async sendError(e,t){if(!h.enabled)return;let r=Date.now();if(h.events.filter(e=>r-new Date(e.properties.timestamp||"").getTime()<6e4).length>=5)return;let i={type:"error",event:t,properties:{errorType:e.name,errorMessage:e.message,stackTrace:e.stack,timestamp:new Date().toISOString()}};h.events.push(i);try{if("undefined"==typeof window)return;let{projectId:r,sdkType:i,sdkVersion:s}=o.OptionsController.state;await l.post({path:"/e",params:{projectId:r,st:i,sv:s||"html-wagmi-4.2.2"},body:{eventId:n.j.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:new Date().toISOString(),props:{type:"error",event:t,errorType:e.name,errorMessage:e.message,stackTrace:e.stack}}})}catch{}},enable(){h.enabled=!0},disable(){h.enabled=!1},clearEvents(){h.events=[]}};class u extends Error{constructor(e,t,r){super(e),this.name="AppKitError",this.category=t,this.originalError=r,Object.setPrototypeOf(this,u.prototype);let i=!1;if(r instanceof Error&&"string"==typeof r.stack&&r.stack){let e=r.stack,t=e.indexOf("\n");if(t>-1){let r=e.substring(t+1);this.stack=`${this.name}: ${this.message}
11
+ ${r}`,i=!0}}i||(Error.captureStackTrace?Error.captureStackTrace(this,u):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function p(e,t){let r=e instanceof u?e:new u(e instanceof Error?e.message:String(e),t,e);throw d.sendError(r,r.category),r}function g(e,t="INTERNAL_SDK_ERROR"){let r={};return Object.keys(e).forEach(i=>{let s=e[i];if("function"==typeof s){let e=s;e="AsyncFunction"===s.constructor.name?async(...e)=>{try{return await s(...e)}catch(e){return p(e,t)}}:(...e)=>{try{return s(...e)}catch(e){return p(e,t)}},r[i]=e}else r[i]=s}),r}},80981:(e,t,r)=>{"use strict";r.d(t,{C:()=>p});var i=r(82324),s=r(7787),n=r(25350),a=r(65279),o=r(53556),c=r(1528),l=r(1326),h=r(75257),d=r(31591),u=r(63794);let p={getConnectorsByType(e,t,r){let{customWallets:i}=s.OptionsController.state,a=n.M.getRecentWallets(),o=u.J.filterOutDuplicateWallets(t),c=u.J.filterOutDuplicateWallets(r),l=e.filter(e=>"MULTI_CHAIN"===e.type),h=e.filter(e=>"ANNOUNCED"===e.type),d=e.filter(e=>"INJECTED"===e.type);return{custom:i,recent:a,external:e.filter(e=>"EXTERNAL"===e.type),multiChain:l,announced:h,injected:d,recommended:o,featured:c}},showConnector(e){let t=e.info?.rdns,r=!!t&&a.ApiController.state.excludedWallets.some(e=>!!e.rdns&&e.rdns===t),i=!!e.name&&a.ApiController.state.excludedWallets.some(t=>d.g.isLowerCaseMatch(t.name,e.name));return!("INJECTED"===e.type&&("Browser Wallet"===e.name&&(!o.j.isMobile()||o.j.isMobile()&&!t&&!c.ConnectionController.checkInstalled())||r||i))&&("ANNOUNCED"!==e.type&&"EXTERNAL"!==e.type||!r&&!i)},getIsConnectedWithWC:()=>Array.from(l.R.state.chains.values()).some(e=>h.ConnectorController.getConnectorId(e.namespace)===i.b.CONNECTOR_ID.WALLET_CONNECT),getConnectorTypeOrder({recommended:e,featured:t,custom:r,recent:i,announced:n,injected:a,multiChain:o,external:c,overriddenConnectors:l=s.OptionsController.state.features?.connectorTypeOrder??[]}){let h=p.getIsConnectedWithWC(),d=[{type:"walletConnect",isEnabled:s.OptionsController.state.enableWalletConnect&&!h},{type:"recent",isEnabled:i.length>0},{type:"injected",isEnabled:[...a,...n,...o].length>0},{type:"featured",isEnabled:t.length>0},{type:"custom",isEnabled:r&&r.length>0},{type:"external",isEnabled:c.length>0},{type:"recommended",isEnabled:e.length>0}].filter(e=>e.isEnabled),u=new Set(d.map(e=>e.type)),g=l.filter(e=>u.has(e)).map(e=>({type:e,isEnabled:!0})),f=d.filter(({type:e})=>!g.some(({type:t})=>t===e));return Array.from(new Set([...g,...f].map(({type:e})=>e)))}}},21114:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={ACCOUNT_TABS:[{label:"Tokens"},{label:"NFTs"},{label:"Activity"}],SECURE_SITE_ORIGIN:("undefined"!=typeof process&&void 0!==process.env?process.env.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",VIEW_DIRECTION:{Next:"next",Prev:"prev"},DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"],ANIMATION_DURATIONS:{HeaderText:120,ModalHeight:150,ViewTransition:150}}},63794:(e,t,r)=>{"use strict";r.d(t,{J:()=>d});var i=r(7787),s=r(75257),n=r(25350),a=r(53556),o=r(65279),c=r(31591),l=r(80981),h=r(21114);let d={filterOutDuplicatesByRDNS(e){let t=i.OptionsController.state.enableEIP6963?s.ConnectorController.state.connectors:[],r=n.M.getRecentWallets(),o=t.map(e=>e.info?.rdns).filter(Boolean),c=r.map(e=>e.rdns).filter(Boolean),l=o.concat(c);if(l.includes("io.metamask.mobile")&&a.j.isMobile()){let e=l.indexOf("io.metamask.mobile");l[e]="io.metamask"}return e.filter(e=>!l.includes(String(e?.rdns)))},filterOutDuplicatesByIds(e){let t=s.ConnectorController.state.connectors.filter(e=>"ANNOUNCED"===e.type||"INJECTED"===e.type),r=n.M.getRecentWallets(),i=t.map(e=>e.explorerId),a=r.map(e=>e.id),o=i.concat(a);return e.filter(e=>!o.includes(e?.id))},filterOutDuplicateWallets(e){let t=this.filterOutDuplicatesByRDNS(e);return this.filterOutDuplicatesByIds(t)},markWalletsAsInstalled(e){let{connectors:t}=s.ConnectorController.state,{featuredWalletIds:r}=i.OptionsController.state,n=t.filter(e=>"ANNOUNCED"===e.type).reduce((e,t)=>(t.info?.rdns&&(e[t.info.rdns]=!0),e),{});return e.map(e=>({...e,installed:!!e.rdns&&!!n[e.rdns??""]})).sort((e,t)=>{let i=Number(t.installed)-Number(e.installed);if(0!==i)return i;if(r?.length){let i=r.indexOf(e.id),s=r.indexOf(t.id);if(-1!==i&&-1!==s)return i-s;if(-1!==i)return -1;if(-1!==s)return 1}return 0})},getConnectOrderMethod(e,t){let r=e?.connectMethodsOrder||i.OptionsController.state.features?.connectMethodsOrder,n=t||s.ConnectorController.state.connectors;if(r)return r;let{injected:a,announced:c}=l.C.getConnectorsByType(n,o.ApiController.state.recommended,o.ApiController.state.featured),d=a.filter(l.C.showConnector),u=c.filter(l.C.showConnector);return d.length||u.length?["wallet","email","social"]:h.b.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(e){let t=!!e.rdns&&o.ApiController.state.excludedWallets.some(t=>t.rdns===e.rdns),r=!!e.name&&o.ApiController.state.excludedWallets.some(t=>c.g.isLowerCaseMatch(t.name,e.name));return t||r}}},93619:(e,t,r)=>{"use strict";r.d(t,{Hg:()=>s.H,Mo:()=>h.M,n:()=>i.n,Hs:()=>i.Hs,R:()=>i.R});var i=r(13510),s=r(18304),n=r(24811),a=r(76676),o=r(48233),c=r(57209);n.extend(o),n.extend(c);let l={...a,name:"en-web3-modal",relativeTime:{future:"in %s",past:"%s ago",s:"%d sec",m:"1 min",mm:"%d min",h:"1 hr",hh:"%d hrs",d:"1 d",dd:"%d d",M:"1 mo",MM:"%d mo",y:"1 yr",yy:"%d yr"}};n.locale("en-web3-modal",l);var h=r(56917)},13510:(e,t,r)=>{"use strict";let i,s,n;r.d(t,{Bp:()=>g,ET:()=>u,Hs:()=>l,R:()=>h,ZM:()=>p,n:()=>c});var a=r(83722),o=r(75393);function c(e,t){i=document.createElement("style"),s=document.createElement("style"),n=document.createElement("style"),i.textContent=d(e).core.cssText,s.textContent=d(e).dark.cssText,n.textContent=d(e).light.cssText,document.head.appendChild(i),document.head.appendChild(s),document.head.appendChild(n),l(t)}function l(e){s&&n&&("light"===e?(s.removeAttribute("media"),n.media="enabled"):(n.removeAttribute("media"),s.media="enabled"))}function h(e){i&&s&&n&&(i.textContent=d(e).core.cssText,s.textContent=d(e).dark.cssText,n.textContent=d(e).light.cssText)}function d(e){return{core:(0,a.iv)`
12
12
  @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
13
13
  @keyframes w3m-shake {
14
14
  0% {
@@ -884,14 +884,14 @@ ${r}`,i=!0}}i||(Error.captureStackTrace?Error.captureStackTrace(this,u):this.sta
884
884
  .wui-color-fg-350 {
885
885
  background-color: var(--wui-color-fg-350);
886
886
  }
887
- `},58004:(e,t,r)=>{"use strict";r.d(t,{H:()=>i});let i={getSpacingStyles:(e,t)=>Array.isArray(e)?e[t]?`var(--wui-spacing-${e[t]})`:void 0:"string"==typeof e?`var(--wui-spacing-${e})`:void 0,getFormattedDate:e=>new Intl.DateTimeFormat("en-US",{month:"short",day:"numeric"}).format(e),getHostName(e){try{return new URL(e).hostname}catch(e){return""}},getTruncateString:({string:e,charsStart:t,charsEnd:r,truncate:i})=>e.length<=t+r?e:"end"===i?`${e.substring(0,t)}...`:"start"===i?`...${e.substring(e.length-r)}`:`${e.substring(0,Math.floor(t))}...${e.substring(e.length-Math.floor(r))}`,generateAvatarColors(e){let t=e.toLowerCase().replace(/^0x/iu,"").replace(/[^a-f0-9]/gu,"").substring(0,6).padEnd(6,"0"),r=this.hexToRgb(t),i=getComputedStyle(document.documentElement).getPropertyValue("--w3m-border-radius-master"),s=100-3*Number(i?.replace("px","")),n=`${s}% ${s}% at 65% 40%`,a=[];for(let e=0;e<5;e+=1){let t=this.tintColor(r,.15*e);a.push(`rgb(${t[0]}, ${t[1]}, ${t[2]})`)}return`
887
+ `},18304:(e,t,r)=>{"use strict";r.d(t,{H:()=>i});let i={getSpacingStyles:(e,t)=>Array.isArray(e)?e[t]?`var(--wui-spacing-${e[t]})`:void 0:"string"==typeof e?`var(--wui-spacing-${e})`:void 0,getFormattedDate:e=>new Intl.DateTimeFormat("en-US",{month:"short",day:"numeric"}).format(e),getHostName(e){try{return new URL(e).hostname}catch(e){return""}},getTruncateString:({string:e,charsStart:t,charsEnd:r,truncate:i})=>e.length<=t+r?e:"end"===i?`${e.substring(0,t)}...`:"start"===i?`...${e.substring(e.length-r)}`:`${e.substring(0,Math.floor(t))}...${e.substring(e.length-Math.floor(r))}`,generateAvatarColors(e){let t=e.toLowerCase().replace(/^0x/iu,"").replace(/[^a-f0-9]/gu,"").substring(0,6).padEnd(6,"0"),r=this.hexToRgb(t),i=getComputedStyle(document.documentElement).getPropertyValue("--w3m-border-radius-master"),s=100-3*Number(i?.replace("px","")),n=`${s}% ${s}% at 65% 40%`,a=[];for(let e=0;e<5;e+=1){let t=this.tintColor(r,.15*e);a.push(`rgb(${t[0]}, ${t[1]}, ${t[2]})`)}return`
888
888
  --local-color-1: ${a[0]};
889
889
  --local-color-2: ${a[1]};
890
890
  --local-color-3: ${a[2]};
891
891
  --local-color-4: ${a[3]};
892
892
  --local-color-5: ${a[4]};
893
893
  --local-radial-circle: ${n}
894
- `},hexToRgb(e){let t=parseInt(e,16);return[t>>16&255,t>>8&255,255&t]},tintColor(e,t){let[r,i,s]=e;return[Math.round(r+(255-r)*t),Math.round(i+(255-i)*t),Math.round(s+(255-s)*t)]},isNumber:e=>/^[0-9]+$/u.test(e),getColorTheme:e=>e||("undefined"!=typeof window&&window.matchMedia?window.matchMedia("(prefers-color-scheme: dark)")?.matches?"dark":"light":"dark"),splitBalance(e){let t=e.split(".");return 2===t.length?[t[0],t[1]]:["0","00"]},roundNumber:(e,t,r)=>e.toString().length>=t?Number(e).toFixed(r):e,formatNumberToLocalString:(e,t=2)=>void 0===e?"0.00":"number"==typeof e?e.toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}):parseFloat(e).toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t})}},27420:(e,t,r)=>{"use strict";function i(e){return function(t){return"function"==typeof t?(customElements.get(e)||customElements.define(e,t),t):function(e,t){let{kind:r,elements:i}=t;return{kind:r,elements:i,finisher(t){customElements.get(e)||customElements.define(e,t)}}}(e,t)}}r.d(t,{M:()=>i})},56295:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={METMASK_CONNECTOR_NAME:"MetaMask",TRUST_CONNECTOR_NAME:"Trust Wallet",SOLFLARE_CONNECTOR_NAME:"Solflare",PHANTOM_CONNECTOR_NAME:"Phantom",COIN98_CONNECTOR_NAME:"Coin98",MAGIC_EDEN_CONNECTOR_NAME:"Magic Eden",BACKPACK_CONNECTOR_NAME:"Backpack",BITGET_CONNECTOR_NAME:"Bitget Wallet",FRONTIER_CONNECTOR_NAME:"Frontier",XVERSE_CONNECTOR_NAME:"Xverse Wallet",LEATHER_CONNECTOR_NAME:"Leather",EIP155:"eip155",ADD_CHAIN_METHOD:"wallet_addEthereumChain",EIP6963_ANNOUNCE_EVENT:"eip6963:announceProvider",EIP6963_REQUEST_EVENT:"eip6963:requestProvider",CONNECTOR_RDNS_MAP:{coinbaseWallet:"com.coinbase.wallet",coinbaseWalletSDK:"com.coinbase.wallet"},CONNECTOR_TYPE_EXTERNAL:"EXTERNAL",CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH",CONNECTOR_TYPE_MULTI_CHAIN:"MULTI_CHAIN",CONNECTOR_TYPE_W3M_AUTH:"ID_AUTH"}},45487:(e,t,r)=>{"use strict";r.d(t,{g:()=>s});var i=r(56295);let s={getCaipTokens(e){if(!e)return;let t={};return Object.entries(e).forEach(([e,r])=>{t[`${i.b.EIP155}:${e}`]=r}),t},isLowerCaseMatch:(e,t)=>e?.toLowerCase()===t?.toLowerCase()}},3577:(e,t,r)=>{"use strict";r.d(t,{y_:()=>i}),"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_SECURE_SITE_SDK_URL,"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_DEFAULT_LOG_LEVEL,"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_SECURE_SITE_SDK_VERSION;let i={SAFE_RPC_METHODS:["eth_accounts","eth_blockNumber","eth_call","eth_chainId","eth_estimateGas","eth_feeHistory","eth_gasPrice","eth_getAccount","eth_getBalance","eth_getBlockByHash","eth_getBlockByNumber","eth_getBlockReceipts","eth_getBlockTransactionCountByHash","eth_getBlockTransactionCountByNumber","eth_getCode","eth_getFilterChanges","eth_getFilterLogs","eth_getLogs","eth_getProof","eth_getStorageAt","eth_getTransactionByBlockHashAndIndex","eth_getTransactionByBlockNumberAndIndex","eth_getTransactionByHash","eth_getTransactionCount","eth_getTransactionReceipt","eth_getUncleCountByBlockHash","eth_getUncleCountByBlockNumber","eth_maxPriorityFeePerGas","eth_newBlockFilter","eth_newFilter","eth_newPendingTransactionFilter","eth_sendRawTransaction","eth_syncing","eth_uninstallFilter","wallet_getCapabilities","wallet_getCallsStatus","eth_getUserOperationReceipt","eth_estimateUserOperationGas","eth_getUserOperationByHash","eth_supportedEntryPoints","wallet_getAssets"],NOT_SAFE_RPC_METHODS:["personal_sign","eth_signTypedData_v4","eth_sendTransaction","solana_signMessage","solana_signTransaction","solana_signAllTransactions","solana_signAndSendTransaction","wallet_sendCalls","wallet_grantPermissions","wallet_revokePermissions","eth_sendUserOperation"],GET_CHAIN_ID:"eth_chainId",RPC_METHOD_NOT_ALLOWED_MESSAGE:"Requested RPC call is not allowed",RPC_METHOD_NOT_ALLOWED_UI_MESSAGE:"Action not allowed",ACCOUNT_TYPES:{EOA:"eoa",SMART_ACCOUNT:"smartAccount"}}},327:(e,t,r)=>{"use strict";r.d(t,{createAppKit:()=>eb});var i=r(21307),s=r(31965),n=r(39308),a=r(24474),o=r(50691),c=r(82324);let l={validateCaipAddress(e){if(e.split(":")?.length!==3)throw Error("Invalid CAIP Address");return e},parseCaipAddress(e){let t=e.split(":");if(3!==t.length)throw Error(`Invalid CAIP-10 address: ${e}`);let[r,i,s]=t;if(!r||!i||!s)throw Error(`Invalid CAIP-10 address: ${e}`);return{chainNamespace:r,chainId:i,address:s}},parseCaipNetworkId(e){let t=e.split(":");if(2!==t.length)throw Error(`Invalid CAIP-2 network id: ${e}`);let[r,i]=t;if(!r||!i)throw Error(`Invalid CAIP-2 network id: ${e}`);return{chainNamespace:r,chainId:i}}};var h=r(47588),d=r(55254),u=r(97441),p=r(12259),g=r(9302),f=r(43892),m=r(95502);let w={convertEVMChainIdToCoinType(e){if(e>=2147483648)throw Error("Invalid chainId");return(2147483648|e)>>>0}};var y=r(37786),b=r(53892);let v=(0,f.sj)({suggestions:[],loading:!1}),C=(0,y.P)({state:v,subscribe:e=>(0,f.Ld)(v,()=>e(v)),subscribeKey:(e,t)=>(0,m.VW)(v,e,t),async resolveName(e){try{return await u.L.lookupEnsName(e)}catch(e){throw Error(e?.reasons?.[0]?.description||"Error resolving name")}},async isNameRegistered(e){try{return await u.L.lookupEnsName(e),!0}catch{return!1}},async getSuggestions(e){try{v.loading=!0,v.suggestions=[];let t=await u.L.getEnsNameSuggestions(e);return v.suggestions=t.suggestions.map(e=>({...e,name:e.name}))||[],v.suggestions}catch(e){throw Error(C.parseEnsApiError(e,"Error fetching name suggestions"))}finally{v.loading=!1}},async getNamesForAddress(e){try{if(!d.R.state.activeCaipNetwork)return[];let t=g.M.getEnsFromCacheForAddress(e);if(t)return t;let r=await u.L.reverseLookupEnsName({address:e});return g.M.updateEnsCache({address:e,ens:r,timestamp:Date.now()}),r}catch(e){throw Error(C.parseEnsApiError(e,"Error fetching names for address"))}},async registerName(e){let t=d.R.state.activeCaipNetwork;if(!t)throw Error("Network not found");let r=p.N.state.address,n=i.ConnectorController.getAuthConnector();if(!r||!n)throw Error("Address or auth connector not found");v.loading=!0;try{let i=JSON.stringify({name:e,attributes:{},timestamp:Math.floor(Date.now()/1e3)});b.RouterController.pushTransactionStack({onCancel(){b.RouterController.replace("RegisterAccountName")}});let n=await s.ConnectionController.signMessage(i);v.loading=!1;let a=t.id;if(!a)throw Error("Network not found");let o=w.convertEVMChainIdToCoinType(Number(a));await u.L.registerEnsName({coinType:o,address:r,signature:n,message:i}),p.N.setProfileName(e,t.chainNamespace),b.RouterController.replace("RegisterAccountNameSuccess")}catch(r){let t=C.parseEnsApiError(r,`Error registering name ${e}`);throw b.RouterController.replace("RegisterAccountName"),Error(t)}finally{v.loading=!1}},validateName:e=>/^[a-zA-Z0-9-]{4,}$/u.test(e),parseEnsApiError:(e,t)=>e?.reasons?.[0]?.description||t});var E=r(96684),N=r(63422),I=r(36241);let A={id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},_={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},S={providers:N.gy,selectedProvider:null,error:null,purchaseCurrency:A,paymentCurrency:_,purchaseCurrencies:[A],paymentCurrencies:[],quotesLoading:!1},O=(0,f.sj)(S),P=(0,y.P)({state:O,subscribe:e=>(0,f.Ld)(O,()=>e(O)),subscribeKey:(e,t)=>(0,m.VW)(O,e,t),setSelectedProvider(e){if(e&&"meld"===e.name){let t=d.R.state.activeChain===c.b.CHAIN.SOLANA?"SOL":"USDC",r=p.N.state.address??"",i=new URL(e.url);i.searchParams.append("publicKey",N.a$),i.searchParams.append("destinationCurrencyCode",t),i.searchParams.append("walletAddress",r),i.searchParams.append("externalCustomerId",a.OptionsController.state.projectId),O.selectedProvider={...e,url:i.toString()}}else O.selectedProvider=e},setOnrampProviders(e){if(Array.isArray(e)&&e.every(e=>"string"==typeof e)){let t=N.gy.filter(t=>e.includes(t.name));O.providers=t}else O.providers=[]},setPurchaseCurrency(e){O.purchaseCurrency=e},setPaymentCurrency(e){O.paymentCurrency=e},setPurchaseAmount(e){P.state.purchaseAmount=e},setPaymentAmount(e){P.state.paymentAmount=e},async getAvailableCurrencies(){let e=await u.L.getOnrampOptions();O.purchaseCurrencies=e.purchaseCurrencies,O.paymentCurrencies=e.paymentCurrencies,O.paymentCurrency=e.paymentCurrencies[0]||_,O.purchaseCurrency=e.purchaseCurrencies[0]||A,await I.ApiController.fetchCurrencyImages(e.paymentCurrencies.map(e=>e.id)),await I.ApiController.fetchTokenImages(e.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){O.quotesLoading=!0;try{let e=await u.L.getOnrampQuote({purchaseCurrency:O.purchaseCurrency,paymentCurrency:O.paymentCurrency,amount:O.paymentAmount?.toString()||"0",network:O.purchaseCurrency?.symbol});return O.quotesLoading=!1,O.purchaseAmount=Number(e?.purchaseAmount.amount),e}catch(e){return O.error=e.message,O.quotesLoading=!1,null}finally{O.quotesLoading=!1}},resetState(){O.selectedProvider=null,O.error=null,O.purchaseCurrency=A,O.paymentCurrency=_,O.purchaseCurrencies=[A],O.paymentCurrencies=[],O.paymentAmount=void 0,O.purchaseAmount=void 0,O.quotesLoading=!1}});var T=r(75836),R=r(57703),k=r(13770),x=r(53391),U=r(15017),D=r(80568),$=r(18413),M=r(93746);function L(e,t){return i.ConnectorController.getConnectorId(e)===t}r(41363),r(3379);var j=r(74030),q=r(91592);new AbortController;let B={UniversalProviderErrors:{UNAUTHORIZED_DOMAIN_NOT_ALLOWED:{message:"Unauthorized: origin not allowed",alertErrorKey:"INVALID_APP_CONFIGURATION"},JWT_VALIDATION_ERROR:{message:"JWT validation error: JWT Token is not yet valid",alertErrorKey:"JWT_TOKEN_NOT_VALID"},INVALID_KEY:{message:"Unauthorized: invalid key",alertErrorKey:"INVALID_PROJECT_ID"}},ALERT_ERRORS:{SWITCH_NETWORK_NOT_FOUND:{shortMessage:"Network Not Found",longMessage:"Network not found - please make sure it is included in 'networks' array in createAppKit function"},INVALID_APP_CONFIGURATION:{shortMessage:"Invalid App Configuration",longMessage:()=>`Origin ${"undefined"!=typeof window?window.origin:"unknown"} not found on Allowlist - update configuration on cloud.reown.com`},IFRAME_LOAD_FAILED:{shortMessage:"Network Error - Could not load embedded wallet",longMessage:()=>"There was an issue loading the embedded wallet. Please try again later."},IFRAME_REQUEST_TIMEOUT:{shortMessage:"Embedded Wallet Request Timed Out",longMessage:()=>"There was an issue doing the request to the embedded wallet. Please try again later."},UNVERIFIED_DOMAIN:{shortMessage:"Invalid App Configuration",longMessage:()=>"There was an issue loading the embedded wallet. Please verify that your domain is allowed at cloud.reown.com"},JWT_TOKEN_NOT_VALID:{shortMessage:"Session Expired",longMessage:"Invalid session found on UniversalProvider - please check your time settings and connect again"},INVALID_PROJECT_ID:{shortMessage:"Invalid App Configuration",longMessage:"Invalid Project ID - update configuration"},PROJECT_ID_NOT_CONFIGURED:{shortMessage:"Project ID Not Configured",longMessage:"Project ID Not Configured - update configuration on cloud.reown.com"}}};var F=r(87112),H=r(43567),W=r(56295);let V={ConnectorExplorerIds:{[c.b.CONNECTOR_ID.COINBASE]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[c.b.CONNECTOR_ID.COINBASE_SDK]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[c.b.CONNECTOR_ID.SAFE]:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",[c.b.CONNECTOR_ID.LEDGER]:"19177a98252e07ddfc9af2083ba8e07ef627cb6103467ffebb3f8f4205fd7927",[c.b.CONNECTOR_ID.OKX]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[W.b.METMASK_CONNECTOR_NAME]:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",[W.b.TRUST_CONNECTOR_NAME]:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",[W.b.SOLFLARE_CONNECTOR_NAME]:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",[W.b.PHANTOM_CONNECTOR_NAME]:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",[W.b.COIN98_CONNECTOR_NAME]:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",[W.b.MAGIC_EDEN_CONNECTOR_NAME]:"8b830a2b724a9c3fbab63af6f55ed29c9dfa8a55e732dc88c80a196a2ba136c6",[W.b.BACKPACK_CONNECTOR_NAME]:"2bd8c14e035c2d48f184aaa168559e86b0e3433228d3c4075900a221785019b0",[W.b.BITGET_CONNECTOR_NAME]:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",[W.b.FRONTIER_CONNECTOR_NAME]:"85db431492aa2e8672e93f4ea7acf10c88b97b867b0d373107af63dc4880f041",[W.b.XVERSE_CONNECTOR_NAME]:"2a87d74ae02e10bdd1f51f7ce6c4e1cc53cd5f2c0b6b5ad0d7b3007d2b13de7b",[W.b.LEATHER_CONNECTOR_NAME]:"483afe1df1df63daf313109971ff3ef8356ddf1cc4e45877d205eee0b7893a13"},NetworkImageIds:{1:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",42161:"3bff954d-5cb0-47a0-9a23-d20192e74600",43114:"30c46e53-e989-45fb-4549-be3bd4eb3b00",56:"93564157-2e8e-4ce7-81df-b264dbee9b00",250:"06b26297-fe0c-4733-5d6b-ffa5498aac00",10:"ab9c186a-c52f-464b-2906-ca59d760a400",137:"41d04d42-da3b-4453-8506-668cc0727900",5e3:"e86fae9b-b770-4eea-e520-150e12c81100",295:"6a97d510-cac8-4e58-c7ce-e8681b044c00",11155111:"e909ea0a-f92a-4512-c8fc-748044ea6800",84532:"a18a7ecd-e307-4360-4746-283182228e00",1301:"4eeea7ef-0014-4649-5d1d-07271a80f600",130:"2257980a-3463-48c6-cbac-a42d2a956e00",10143:"0a728e83-bacb-46db-7844-948f05434900",100:"02b53f6a-e3d4-479e-1cb4-21178987d100",9001:"f926ff41-260d-4028-635e-91913fc28e00",324:"b310f07f-4ef7-49f3-7073-2a0a39685800",314:"5a73b3dd-af74-424e-cae0-0de859ee9400",4689:"34e68754-e536-40da-c153-6ef2e7188a00",1088:"3897a66d-40b9-4833-162f-a2c90531c900",1284:"161038da-44ae-4ec7-1208-0ea569454b00",1285:"f1d73bb6-5450-4e18-38f7-fb6484264a00",7777777:"845c60df-d429-4991-e687-91ae45791600",42220:"ab781bbc-ccc6-418d-d32d-789b15da1f00",8453:"7289c336-3981-4081-c5f4-efc26ac64a00",1313161554:"3ff73439-a619-4894-9262-4470c773a100",2020:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",2021:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",80094:"e329c2c9-59b0-4a02-83e4-212ff3779900",2741:"fc2427d1-5af9-4a9c-8da5-6f94627cd900","5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":"a1b58899-f671-4276-6a5e-56ca5bd59700","4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z":"a1b58899-f671-4276-6a5e-56ca5bd59700",EtWTRABZaYq6iMfeYKouRu166VU2xqa1:"a1b58899-f671-4276-6a5e-56ca5bd59700","000000000019d6689c085ae165831e93":"0b4838db-0161-4ffe-022d-532bf03dba00","000000000933ea01ad0ee984209779ba":"39354064-d79b-420b-065d-f980c4b78200"},ConnectorImageIds:{[c.b.CONNECTOR_ID.COINBASE]:"0c2840c3-5b04-4c44-9661-fbd4b49e1800",[c.b.CONNECTOR_ID.COINBASE_SDK]:"0c2840c3-5b04-4c44-9661-fbd4b49e1800",[c.b.CONNECTOR_ID.SAFE]:"461db637-8616-43ce-035a-d89b8a1d5800",[c.b.CONNECTOR_ID.LEDGER]:"54a1aa77-d202-4f8d-0fb2-5d2bb6db0300",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"ef1a1fcf-7fe8-4d69-bd6d-fda1345b4400",[c.b.CONNECTOR_ID.INJECTED]:"07ba87ed-43aa-4adf-4540-9e6a2b9cae00"},ConnectorNamesMap:{[c.b.CONNECTOR_ID.INJECTED]:"Browser Wallet",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"WalletConnect",[c.b.CONNECTOR_ID.COINBASE]:"Coinbase",[c.b.CONNECTOR_ID.COINBASE_SDK]:"Coinbase",[c.b.CONNECTOR_ID.LEDGER]:"Ledger",[c.b.CONNECTOR_ID.SAFE]:"Safe"},ConnectorTypesMap:{[c.b.CONNECTOR_ID.INJECTED]:"INJECTED",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"WALLET_CONNECT",[c.b.CONNECTOR_ID.EIP6963]:"ANNOUNCED",[c.b.CONNECTOR_ID.AUTH]:"AUTH"},WalletConnectRpcChainIds:[1,5,11155111,10,420,42161,421613,137,80001,42220,1313161554,1313161555,56,97,43114,43113,100,8453,84531,7777777,999,324,280]};function z(e,t){let r=new URL("https://rpc.walletconnect.org/v1/");return r.searchParams.set("chainId",e),r.searchParams.set("projectId",t),r.toString()}let K=["near:mainnet","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","eip155:1101","eip155:56","eip155:42161","eip155:7777777","eip155:59144","eip155:324","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1","eip155:5000","solana:4sgjmw1sunhzsxgspuhpqldx6wiyjntz","eip155:80084","eip155:5003","eip155:100","eip155:8453","eip155:42220","eip155:1313161555","eip155:17000","eip155:1","eip155:300","eip155:1313161554","eip155:1329","eip155:84532","eip155:421614","eip155:11155111","eip155:8217","eip155:43114","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","eip155:999999999","eip155:11155420","eip155:80002","eip155:97","eip155:43113","eip155:137","eip155:10","eip155:1301","bip122:000000000019d6689c085ae165831e93","bip122:000000000933ea01ad0ee984209779ba"],J={extendRpcUrlWithProjectId(e,t){let r=!1;try{r="rpc.walletconnect.org"===new URL(e).host}catch(e){r=!1}if(r){let r=new URL(e);return r.searchParams.has("projectId")||r.searchParams.set("projectId",t),r.toString()}return e},isCaipNetwork:e=>"chainNamespace"in e&&"caipNetworkId"in e,getChainNamespace(e){return this.isCaipNetwork(e)?e.chainNamespace:c.b.CHAIN.EVM},getCaipNetworkId(e){return this.isCaipNetwork(e)?e.caipNetworkId:`${c.b.CHAIN.EVM}:${e.id}`},getDefaultRpcUrl(e,t,r){let i=e.rpcUrls?.default?.http?.[0];return K.includes(t)?z(t,r):i||""},extendCaipNetwork(e,{customNetworkImageUrls:t,projectId:r,customRpcUrls:i}){let s=this.getChainNamespace(e),n=this.getCaipNetworkId(e),a=e.rpcUrls.default.http?.[0],o=this.getDefaultRpcUrl(e,n,r),c=e?.rpcUrls?.chainDefault?.http?.[0]||a,l=i?.[n]?.map(e=>e.url)||[],h=[...l,o],d=[...l];return c&&!d.includes(c)&&d.push(c),{...e,chainNamespace:s,caipNetworkId:n,assets:{imageId:V.NetworkImageIds[e.id],imageUrl:t?.[e.id]},rpcUrls:{...e.rpcUrls,default:{http:h},chainDefault:{http:d}}}},extendCaipNetworks:(e,{customNetworkImageUrls:t,projectId:r,customRpcUrls:i})=>e.map(e=>J.extendCaipNetwork(e,{customNetworkImageUrls:t,customRpcUrls:i,projectId:r})),getViemTransport(e,t,r){let i=[];return r?.forEach(e=>{i.push(F.d(e.url,e.config))}),K.includes(e.caipNetworkId)&&i.push((0,F.d)(z(e.caipNetworkId,t),{fetchOptions:{headers:{"Content-Type":"text/plain"}}})),e?.rpcUrls?.default?.http?.forEach(e=>{i.push(F.d(e))}),(0,H.tv)(i)},extendWagmiTransports(e,t,r){if(K.includes(e.caipNetworkId)){let i=this.getDefaultRpcUrl(e,e.caipNetworkId,t);return(0,H.tv)([r,(0,F.d)(i)])}return r},getUnsupportedNetwork:e=>({id:e.split(":")[1],caipNetworkId:e,name:c.b.UNSUPPORTED_NETWORK_NAME,chainNamespace:e.split(":")[0],nativeCurrency:{name:"",decimals:0,symbol:""},rpcUrls:{default:{http:[]}}}),getCaipNetworkFromStorage(e){let t=g.M.getActiveCaipNetworkId(),r=d.R.getAllRequestedCaipNetworks(),i=Array.from(d.R.state.chains?.keys()||[]),s=t?.split(":")[0],n=!!s&&i.includes(s),a=r?.find(e=>e.caipNetworkId===t);return n&&!a&&t?this.getUnsupportedNetwork(t):a||e||r?.[0]}};var G=r(45487),Y=r(41434);let X={createLogger(e,t="error"){let r=(0,Y.jI)({level:t}),{logger:i}=(0,Y.Rt)({opts:r});return i.error=(...t)=>{for(let r of t)if(r instanceof Error){e(r,...t);return}e(void 0,...t)},i}},Z={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0},Q=(0,f.sj)({providers:{...Z},providerIds:{...Z}}),ee={state:Q,subscribeKey:(e,t)=>(0,m.VW)(Q,e,t),subscribe:e=>(0,f.Ld)(Q,()=>{e(Q)}),subscribeProviders:e=>(0,f.Ld)(Q.providers,()=>e(Q.providers)),setProvider(e,t){t&&(Q.providers[e]=(0,f.iH)(t))},getProvider:e=>Q.providers[e],setProviderId(e,t){t&&(Q.providerIds[e]=t)},getProviderId(e){if(e)return Q.providerIds[e]},reset(){Q.providers={...Z},Q.providerIds={...Z}},resetChain(e){Q.providers[e]=void 0,Q.providerIds[e]=void 0}};var et=r(48787),er=r(5191);let ei={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603,DEFAULT_ALLOWED_ANCESTORS:["http://localhost:*","https://*.pages.dev","https://*.vercel.app","https://*.ngrok-free.app","https://secure-mobile.walletconnect.com","https://secure-mobile.walletconnect.org"]};function es(e){return{formatters:void 0,fees:void 0,serializers:void 0,...e}}let en=es({id:"5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",name:"Solana",network:"solana-mainnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!1,chainNamespace:"solana",caipNetworkId:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",deprecatedCaipNetworkId:"solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ"}),ea=es({id:"EtWTRABZaYq6iMfeYKouRu166VU2xqa1",name:"Solana Devnet",network:"solana-devnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!0,chainNamespace:"solana",caipNetworkId:"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1",deprecatedCaipNetworkId:"solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K"});es({id:"4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z",name:"Solana Testnet",network:"solana-testnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!0,chainNamespace:"solana",caipNetworkId:"solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z"}),es({id:"000000000019d6689c085ae165831e93",caipNetworkId:"bip122:000000000019d6689c085ae165831e93",chainNamespace:"bip122",name:"Bitcoin",nativeCurrency:{name:"Bitcoin",symbol:"BTC",decimals:8},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}}}),es({id:"000000000933ea01ad0ee984209779ba",caipNetworkId:"bip122:000000000933ea01ad0ee984209779ba",chainNamespace:"bip122",name:"Bitcoin Testnet",nativeCurrency:{name:"Bitcoin",symbol:"BTC",decimals:8},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},testnet:!0});let eo={solana:["solana_signMessage","solana_signTransaction","solana_requestAccounts","solana_getAccounts","solana_signAllTransactions","solana_signAndSendTransaction"],eip155:["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_showCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],bip122:["sendTransfer","signMessage","signPsbt","getAccountAddresses"]},ec={getMethodsByChainNamespace:e=>eo[e]||[],createDefaultNamespace(e){return{methods:this.getMethodsByChainNamespace(e),events:["accountsChanged","chainChanged"],chains:[],rpcMap:{}}},applyNamespaceOverrides(e,t){if(!t)return{...e};let r={...e},i=new Set;if(t.methods&&Object.keys(t.methods).forEach(e=>i.add(e)),t.chains&&Object.keys(t.chains).forEach(e=>i.add(e)),t.events&&Object.keys(t.events).forEach(e=>i.add(e)),t.rpcMap&&Object.keys(t.rpcMap).forEach(e=>{let[t]=e.split(":");t&&i.add(t)}),i.forEach(e=>{r[e]||(r[e]=this.createDefaultNamespace(e))}),t.methods&&Object.entries(t.methods).forEach(([e,t])=>{r[e]&&(r[e].methods=t)}),t.chains&&Object.entries(t.chains).forEach(([e,t])=>{r[e]&&(r[e].chains=t)}),t.events&&Object.entries(t.events).forEach(([e,t])=>{r[e]&&(r[e].events=t)}),t.rpcMap){let e=new Set;Object.entries(t.rpcMap).forEach(([t,i])=>{let[s,n]=t.split(":");s&&n&&r[s]&&(r[s].rpcMap||(r[s].rpcMap={}),e.has(s)||(r[s].rpcMap={},e.add(s)),r[s].rpcMap[n]=i)})}return r},createNamespaces(e,t){let r=e.reduce((e,t)=>{let{id:r,chainNamespace:i,rpcUrls:s}=t,n=s.default.http[0];e[i]||(e[i]=this.createDefaultNamespace(i));let a=`${i}:${r}`,o=e[i];switch(o.chains.push(a),a){case en.caipNetworkId:o.chains.push(en.deprecatedCaipNetworkId);break;case ea.caipNetworkId:o.chains.push(ea.deprecatedCaipNetworkId)}return o?.rpcMap&&n&&(o.rpcMap[r]=n),e},{});return this.applyNamespaceOverrides(r,t)},resolveReownName:async e=>{let t=await C.resolveName(e),r=Object.values(t?.addresses)||[];return r[0]?.address||!1},getChainsFromNamespaces:(e={})=>Object.values(e).flatMap(e=>Array.from(new Set([...e.chains||[],...e.accounts.map(e=>{let[t,r]=e.split(":");return`${t}:${r}`})]))),isSessionEventData:e=>"object"==typeof e&&null!==e&&"id"in e&&"topic"in e&&"params"in e&&"object"==typeof e.params&&null!==e.params&&"chainId"in e.params&&"event"in e.params&&"object"==typeof e.params.event&&null!==e.params.event,isOriginAllowed(e,t,r){for(let i of[...t,...r])if(i.includes("*")){let t=i.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&");if(RegExp(`^${t.replace(/\\\*/gu,".*")}$`,"u").test(e))return!0}else try{if(new URL(i).origin===e)return!0}catch(t){if(i===e)return!0}return!1}};class el{constructor({provider:e,namespace:t}){this.id=c.b.CONNECTOR_ID.WALLET_CONNECT,this.name=V.ConnectorNamesMap[c.b.CONNECTOR_ID.WALLET_CONNECT],this.type="WALLET_CONNECT",this.imageId=V.ConnectorImageIds[c.b.CONNECTOR_ID.WALLET_CONNECT],this.getCaipNetworks=d.R.getCaipNetworks.bind(d.R),this.caipNetworks=this.getCaipNetworks(),this.provider=e,this.chain=t}get chains(){return this.getCaipNetworks()}async connectWalletConnect(){if(!await this.authenticate()){let e=this.getCaipNetworks(),t=a.OptionsController.state.universalProviderConfigOverride,r=ec.createNamespaces(e,t);await this.provider.connect({optionalNamespaces:r})}return{clientId:await this.provider.client.core.crypto.getClientId(),session:this.provider.session}}async disconnect(){await this.provider.disconnect()}async authenticate(){let e=this.chains.map(e=>e.caipNetworkId);return U.w.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:eh})}}let eh=["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"];class ed{constructor(e){this.availableConnectors=[],this.eventListeners=new Map,this.getCaipNetworks=e=>d.R.getCaipNetworks(e),e&&this.construct(e)}construct(e){this.projectId=e.projectId,this.namespace=e.namespace,this.adapterType=e.adapterType}get connectors(){return this.availableConnectors}get networks(){return this.getCaipNetworks(this.namespace)}setAuthProvider(e){this.addConnector({id:c.b.CONNECTOR_ID.AUTH,type:"AUTH",name:c.b.CONNECTOR_NAMES.AUTH,provider:e,imageId:V.ConnectorImageIds[c.b.CONNECTOR_ID.AUTH],chain:this.namespace,chains:[]})}addConnector(...e){let t=new Set;this.availableConnectors=[...e,...this.availableConnectors].filter(e=>!t.has(e.id)&&(t.add(e.id),!0)),this.emit("connectors",this.availableConnectors)}setStatus(e,t){p.N.setStatus(e,t)}on(e,t){this.eventListeners.has(e)||this.eventListeners.set(e,new Set),this.eventListeners.get(e)?.add(t)}off(e,t){let r=this.eventListeners.get(e);r&&r.delete(t)}removeAllEventListeners(){this.eventListeners.forEach(e=>{e.clear()})}emit(e,t){let r=this.eventListeners.get(e);r&&r.forEach(e=>e(t))}async connectWalletConnect(e){let t=this.getWalletConnectConnector();return{clientId:(await t.connectWalletConnect()).clientId}}async switchNetwork(e){let{caipNetwork:t,providerType:r}=e;if(!e.provider)return;let i="provider"in e.provider?e.provider.provider:e.provider;if("WALLET_CONNECT"===r){i.setDefaultChain(t.caipNetworkId);return}if(i&&"AUTH"===r){let e=p.N.state.preferredAccountTypes?.[t.chainNamespace];await i.switchNetwork(t.caipNetworkId);let r=await i.getUser({chainId:t.caipNetworkId,preferredAccountType:e});this.emit("switchNetwork",r)}}getWalletConnectConnector(){let e=this.connectors.find(e=>e instanceof el);if(!e)throw Error("WalletConnectConnector not found");return e}}class eu extends ed{setUniversalProvider(e){this.addConnector(new el({provider:e,caipNetworks:this.getCaipNetworks(),namespace:this.namespace}))}async connect(e){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:Number(e.chainId),provider:this.provider,address:""})}async disconnect(){try{let e=this.getWalletConnectConnector();await e.disconnect()}catch(e){console.warn("UniversalAdapter:disconnect - error",e)}}async getAccounts({namespace:e}){let t=this.provider;return Promise.resolve({accounts:(t?.session?.namespaces?.[e]?.accounts?.map(e=>{let[,,t]=e.split(":");return t}).filter((e,t,r)=>r.indexOf(e)===t)||[]).map(t=>n.j.createAccount(e,t,"bip122"===e?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){if(!(e.caipNetwork&&N.bq.BALANCE_SUPPORTED_CHAINS.includes(e.caipNetwork?.chainNamespace))||e.caipNetwork?.testnet)return{balance:"0.00",symbol:e.caipNetwork?.nativeCurrency.symbol||""};if(p.N.state.balanceLoading&&e.chainId===d.R.state.activeCaipNetwork?.id)return{balance:p.N.state.balance||"0.00",symbol:p.N.state.balanceSymbol||""};let t=(await p.N.fetchTokenBalance()).find(t=>t.chainId===`${e.caipNetwork?.chainNamespace}:${e.chainId}`&&t.symbol===e.caipNetwork?.nativeCurrency.symbol);return{balance:t?.quantity.numeric||"0.00",symbol:t?.symbol||e.caipNetwork?.nativeCurrency.symbol||""}}async signMessage(e){let{provider:t,message:r,address:i}=e;if(!t)throw Error("UniversalAdapter:signMessage - provider is undefined");return{signature:d.R.state.activeCaipNetwork?.chainNamespace===c.b.CHAIN.SOLANA?(await t.request({method:"solana_signMessage",params:{message:et.Z.encode(new TextEncoder().encode(r)),pubkey:i}},d.R.state.activeCaipNetwork?.caipNetworkId)).signature:await t.request({method:"personal_sign",params:[r,i]},d.R.state.activeCaipNetwork?.caipNetworkId)}}async estimateGas(){return Promise.resolve({gas:BigInt(0)})}async sendTransaction(){return Promise.resolve({hash:""})}walletGetAssets(e){return Promise.resolve({})}async writeContract(){return Promise.resolve({hash:""})}parseUnits(){return 0n}formatUnits(){return"0"}async getCapabilities(){return Promise.resolve({})}async grantPermissions(){return Promise.resolve({})}async revokePermissions(){return Promise.resolve("0x")}async syncConnection(){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:1,provider:this.provider,address:""})}async switchNetwork(e){let{caipNetwork:t}=e,r=this.getWalletConnectConnector();if(t.chainNamespace===c.b.CHAIN.EVM)try{await r.provider?.request({method:"wallet_switchEthereumChain",params:[{chainId:er.NC(t.id)}]})}catch(e){if(e.code===ei.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||e.code===ei.ERROR_INVALID_CHAIN_ID||e.code===ei.ERROR_CODE_DEFAULT||e?.data?.originalError?.code===ei.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await r.provider?.request({method:"wallet_addEthereumChain",params:[{chainId:er.NC(t.id),rpcUrls:[t?.rpcUrls.chainDefault?.http],chainName:t.name,nativeCurrency:t.nativeCurrency,blockExplorerUrls:[t.blockExplorers?.default.url]}]})}catch(e){throw Error("Chain is not supported")}}r.provider.setDefaultChain(t.caipNetworkId)}getWalletConnectProvider(){let e=this.connectors.find(e=>"WALLET_CONNECT"===e.type);return e?.provider}}let ep=["email","socials","swaps","onramp","activity","reownBranding"],eg={email:{apiFeatureName:"social_login",localFeatureName:"email",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.includes("email")},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.email:!!e},socials:{apiFeatureName:"social_login",localFeatureName:"socials",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t.filter(e=>"email"!==e)},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.socials:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.socials:e},swaps:{apiFeatureName:"swap",localFeatureName:"swaps",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.swaps:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.swaps:e},onramp:{apiFeatureName:"onramp",localFeatureName:"onramp",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.onramp:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.onramp:e},activity:{apiFeatureName:"activity",localFeatureName:"history",returnType:!1,isLegacy:!0,isAvailableOnBasic:!1,processApi:e=>!!e.isEnabled,processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.activity:!!e},reownBranding:{apiFeatureName:"reown_branding",localFeatureName:"reownBranding",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>!!e.isEnabled,processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.reownBranding:!!e}},ef={localSettingsOverridden:new Set,getApiConfig:(e,t)=>t?.find(t=>t.id===e),addWarning(e,t){if(void 0!==e){let e=eg[t],r=e.isLegacy?`"features.${e.localFeatureName}" (now "${t}")`:`"features.${t}"`;this.localSettingsOverridden.add(r)}},processFeature(e,t,r,i,s){let n=eg[e],a=t[n.localFeatureName];if(s&&!n.isAvailableOnBasic)return!1;if(i){let t=this.getApiConfig(n.apiFeatureName,r);return t?.config===null?this.processFallbackFeature(e,a):!!t?.config&&(void 0!==a&&this.addWarning(a,e),this.processApiFeature(e,t))}return this.processFallbackFeature(e,a)},processApiFeature:(e,t)=>eg[e].processApi(t),processFallbackFeature:(e,t)=>eg[e].processFallback(t),async fetchRemoteFeatures(e){let t=e.basic??!1,r=e.features||{};this.localSettingsOverridden.clear();let i=null,s=!1;try{s=null!=(i=await I.ApiController.fetchProjectConfig())}catch(e){console.warn("[Reown Config] Failed to fetch remote project configuration. Using local/default values.",e)}let n=s&&!t?N.bq.DEFAULT_REMOTE_FEATURES:N.bq.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(let e of ep){let a=this.processFeature(e,r,i,s,t);Object.assign(n,{[e]:a})}}catch(e){return console.warn("[Reown Config] Failed to process the configuration from Cloud. Using default values.",e),N.bq.DEFAULT_REMOTE_FEATURES}if(s&&this.localSettingsOverridden.size>0){let e=`Your local configuration for ${Array.from(this.localSettingsOverridden).join(", ")} was ignored because a remote configuration was successfully fetched. Please manage these features via your project dashboard on dashboard.reown.com.`;T.AlertController.open({shortMessage:"Local configuration ignored",longMessage:`[Reown Config Notice] ${e}`},"warning")}return n}};class em{constructor(e){this.chainNamespaces=[],this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(e,t)=>{if(e){let r=d.R.getNetworkData(e)?.requestedCaipNetworks?.find(e=>e.id===t);if(r)return r;let i=d.R.getNetworkData(e)?.caipNetwork;if(i)return i;let s=d.R.getRequestedCaipNetworks(e);return s.filter(t=>t.chainNamespace===e)?.[0]}return d.R.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{let e=this.getCaipNetwork();if(e)return e.id},this.getCaipNetworks=e=>d.R.getCaipNetworks(e),this.getActiveChainNamespace=()=>d.R.state.activeChain,this.setRequestedCaipNetworks=(e,t)=>{d.R.setRequestedCaipNetworks(e,t)},this.getApprovedCaipNetworkIds=()=>d.R.getAllApprovedCaipNetworkIds(),this.getCaipAddress=e=>d.R.state.activeChain!==e&&e?d.R.getAccountProp("caipAddress",e):d.R.state.activeCaipAddress,this.setClientId=e=>{u.L.setClientId(e)},this.getProvider=e=>ee.getProvider(e),this.getProviderType=e=>ee.getProviderId(e),this.getPreferredAccountType=e=>p.N.state.preferredAccountTypes?.[e],this.setCaipAddress=(e,t)=>{p.N.setCaipAddress(e,t),e&&a.OptionsController.state.enableEmbedded&&this.close()},this.setBalance=(e,t,r)=>{p.N.setBalance(e,t,r)},this.setProfileName=(e,t)=>{p.N.setProfileName(e,t)},this.setProfileImage=(e,t)=>{p.N.setProfileImage(e,t)},this.setUser=(e,t)=>{p.N.setUser(e,t)},this.resetAccount=e=>{p.N.resetAccount(e)},this.setCaipNetwork=e=>{d.R.setActiveCaipNetwork(e)},this.setCaipNetworkOfNamespace=(e,t)=>{d.R.setChainNetworkData(t,{caipNetwork:e})},this.setAllAccounts=(e,t)=>{p.N.setAllAccounts(e,t),a.OptionsController.setHasMultipleAddresses(e?.length>1)},this.setStatus=(e,t)=>{p.N.setStatus(e,t),i.ConnectorController.isConnected()?g.M.setConnectionStatus("connected"):g.M.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=e=>d.R.getAccountProp("address",e),this.setConnectors=e=>{let t=[...i.ConnectorController.state.allConnectors,...e];i.ConnectorController.setConnectors(t)},this.setConnections=(e,t)=>{s.ConnectionController.setConnections(e,t)},this.fetchIdentity=e=>u.L.fetchIdentity(e),this.getReownName=e=>C.getNamesForAddress(e),this.getConnectors=()=>i.ConnectorController.getConnectors(),this.getConnectorImage=e=>E.f.getConnectorImage(e),this.setConnectedWalletInfo=(e,t)=>{let r=ee.getProviderId(t),i=e?{...e,type:r}:void 0;p.N.setConnectedWalletInfo(i,t)},this.getIsConnectedState=()=>!!d.R.state.activeCaipAddress,this.addAddressLabel=(e,t,r)=>{p.N.addAddressLabel(e,t,r)},this.removeAddressLabel=(e,t)=>{p.N.removeAddressLabel(e,t)},this.getAddress=e=>d.R.state.activeChain!==e&&e?d.R.getAccountProp("address",e):p.N.state.address,this.setApprovedCaipNetworksData=e=>d.R.setApprovedCaipNetworksData(e),this.resetNetwork=e=>{d.R.resetNetwork(e)},this.addConnector=e=>{i.ConnectorController.addConnector(e)},this.resetWcConnection=()=>{s.ConnectionController.resetWcConnection()},this.setAddressExplorerUrl=(e,t)=>{p.N.setAddressExplorerUrl(e,t)},this.setSmartAccountDeployed=(e,t)=>{p.N.setSmartAccountDeployed(e,t)},this.setSmartAccountEnabledNetworks=(e,t)=>{d.R.setSmartAccountEnabledNetworks(e,t)},this.setPreferredAccountType=(e,t)=>{p.N.setPreferredAccountType(e,t)},this.setEIP6963Enabled=e=>{a.OptionsController.setEIP6963Enabled(e)},this.handleUnsafeRPCRequest=()=>{this.isOpen()?this.isTransactionStackEmpty()||this.redirect("ApproveTransaction"):this.open({view:"ApproveTransaction"})},this.options=e,this.version=e.sdkVersion,this.caipNetworks=this.extendCaipNetworks(e),this.chainNamespaces=this.getChainNamespacesSet(e.adapters,this.caipNetworks),this.defaultCaipNetwork=this.extendDefaultCaipNetwork(e),this.chainAdapters=this.createAdapters(e.adapters),this.readyPromise=this.initialize(e)}getChainNamespacesSet(e,t){let r=e?.map(e=>e.namespace).filter(e=>!!e);return r?.length?[...new Set(r)]:[...new Set(t?.map(e=>e.chainNamespace))]}async initialize(e){this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),await this.syncExistingConnection(),this.remoteFeatures=await ef.fetchRemoteFeatures(e),a.OptionsController.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&P.setOnrampProviders(this.remoteFeatures.onramp),(a.OptionsController.state.remoteFeatures?.email||Array.isArray(a.OptionsController.state.remoteFeatures?.socials)&&a.OptionsController.state.remoteFeatures?.socials.length>0)&&await this.checkAllowedOrigins()}async checkAllowedOrigins(){let e=await I.ApiController.fetchAllowedOrigins();if(e&&n.j.isClient()){let t=window.location.origin;ec.isOriginAllowed(t,e,ei.DEFAULT_ALLOWED_ANCESTORS)||T.AlertController.open(B.ALERT_ERRORS.INVALID_APP_CONFIGURATION,"error")}else T.AlertController.open(B.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error")}sendInitializeEvent(e){let{...t}=e;delete t.adapters,delete t.universalProvider,R.X.sendEvent({type:"track",event:"INITIALIZE",properties:{...t,networks:e.networks.map(e=>e.id),siweConfig:{options:e.siweConfig?.options||{}}}})}initControllers(e){this.initializeOptionsController(e),this.initializeChainController(e),this.initializeThemeController(e),this.initializeConnectionController(e),this.initializeConnectorController()}initializeThemeController(e){e.themeMode&&k.ThemeController.setThemeMode(e.themeMode),e.themeVariables&&k.ThemeController.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient||!this.networkControllerClient)throw Error("ConnectionControllerClient and NetworkControllerClient must be set");d.R.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient,networkControllerClient:this.networkControllerClient});let t=this.getDefaultNetwork();t&&d.R.setActiveCaipNetwork(t)}initializeConnectionController(e){s.ConnectionController.setWcBasic(e.basic??!1)}initializeConnectorController(){i.ConnectorController.initialize(this.chainNamespaces)}initializeProjectSettings(e){a.OptionsController.setProjectId(e.projectId),a.OptionsController.setSdkVersion(e.sdkVersion)}initializeOptionsController(e){a.OptionsController.setDebug(!1!==e.debug),a.OptionsController.setEnableWalletConnect(!1!==e.enableWalletConnect),a.OptionsController.setEnableWalletGuide(!1!==e.enableWalletGuide),a.OptionsController.setEnableWallets(!1!==e.enableWallets),a.OptionsController.setEIP6963Enabled(!1!==e.enableEIP6963),a.OptionsController.setEnableNetworkSwitch(!1!==e.enableNetworkSwitch),a.OptionsController.setEnableAuthLogger(!1!==e.enableAuthLogger),a.OptionsController.setCustomRpcUrls(e.customRpcUrls),a.OptionsController.setEnableEmbedded(e.enableEmbedded),a.OptionsController.setAllWallets(e.allWallets),a.OptionsController.setIncludeWalletIds(e.includeWalletIds),a.OptionsController.setExcludeWalletIds(e.excludeWalletIds),a.OptionsController.setFeaturedWalletIds(e.featuredWalletIds),a.OptionsController.setTokens(e.tokens),a.OptionsController.setTermsConditionsUrl(e.termsConditionsUrl),a.OptionsController.setPrivacyPolicyUrl(e.privacyPolicyUrl),a.OptionsController.setCustomWallets(e.customWallets),a.OptionsController.setFeatures(e.features),a.OptionsController.setAllowUnsupportedChain(e.allowUnsupportedChain),a.OptionsController.setUniversalProviderConfigOverride(e.universalProviderConfigOverride),a.OptionsController.setPreferUniversalLinks(e.experimental_preferUniversalLinks),a.OptionsController.setDefaultAccountTypes(e.defaultAccountTypes);let t=g.M.getPreferredAccountTypes()||{},r={...a.OptionsController.state.defaultAccountTypes,...t};p.N.setPreferredAccountTypes(r);let i=this.getDefaultMetaData();if(!e.metadata&&i&&(e.metadata=i),a.OptionsController.setMetadata(e.metadata),a.OptionsController.setDisableAppend(e.disableAppend),a.OptionsController.setEnableEmbedded(e.enableEmbedded),a.OptionsController.setSIWX(e.siwx),!e.projectId){T.AlertController.open(B.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error");return}if(e.adapters?.find(e=>e.namespace===c.b.CHAIN.EVM)&&e.siweConfig){if(e.siwx)throw Error("Cannot set both `siweConfig` and `siwx` options");a.OptionsController.setSIWX(e.siweConfig.mapToSIWX())}}getDefaultMetaData(){return n.j.isClient()?{name:document.getElementsByTagName("title")?.[0]?.textContent||"",description:document.querySelector('meta[property="og:description"]')?.content||"",url:window.location.origin,icons:[document.querySelector('link[rel~="icon"]')?.href||""]}:null}setUnsupportedNetwork(e){let t=this.getActiveChainNamespace();if(t){let r=J.getUnsupportedNetwork(`${t}:${e}`);d.R.setActiveCaipNetwork(r)}}getDefaultNetwork(){return J.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,t){return J.extendCaipNetwork(e,{customNetworkImageUrls:t.chainImages,projectId:t.projectId})}extendCaipNetworks(e){return J.extendCaipNetworks(e.networks,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId})}extendDefaultCaipNetwork(e){let t=e.networks.find(t=>t.id===e.defaultNetwork?.id);return t?J.extendCaipNetwork(t,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId}):void 0}async disconnectNamespace(e){try{let t=this.getAdapter(e),r=ee.getProvider(e),s=ee.getProviderId(e),{caipAddress:n}=d.R.getAccountData(e)||{};this.setLoading(!0,e),n&&t?.disconnect&&await t.disconnect({provider:r,providerType:s}),g.M.removeConnectedNamespace(e),ee.resetChain(e),this.setUser(void 0,e),this.setStatus("disconnected",e),this.setConnectedWalletInfo(void 0,e),i.ConnectorController.removeConnectorId(e),d.R.resetAccount(e),d.R.resetNetwork(e),this.setLoading(!1,e)}catch(t){throw this.setLoading(!1,e),Error(`Failed to disconnect chain ${e}: ${t.message}`)}}createClients(){this.connectionControllerClient={connectWalletConnect:async()=>{let e=d.R.state.activeChain,t=this.getAdapter(e),r=this.getCaipNetwork(e)?.id;if(!t)throw Error("Adapter not found");let s=await t.connectWalletConnect(r);this.close(),this.setClientId(s?.clientId||null),g.M.setConnectedNamespaces([...d.R.state.chains.keys()]),this.chainNamespaces.forEach(e=>{i.ConnectorController.setConnectorId(W.b.CONNECTOR_TYPE_WALLET_CONNECT,e)}),await this.syncWalletConnectAccount()},connectExternal:async({id:e,info:t,type:r,provider:i,chain:s,caipNetwork:n,socialUri:a})=>{let o=d.R.state.activeChain,c=s||o,l=this.getAdapter(c);if(s&&s!==o&&!n){let e=this.getCaipNetworks().find(e=>e.chainNamespace===s);e&&this.setCaipNetwork(e)}if(!l)throw Error("Adapter not found");let h=this.getCaipNetwork(c),u=await l.connect({id:e,info:t,type:r,provider:i,socialUri:a,chainId:n?.id||h?.id,rpcUrl:n?.rpcUrls?.default?.http?.[0]||h?.rpcUrls?.default?.http?.[0]});if(!u)return;g.M.addConnectedNamespace(c),this.syncProvider({...u,chainNamespace:c});let f=p.N.state.allAccounts,{accounts:m}=f?.length>0?{accounts:[...f]}:await l.getAccounts({namespace:c,id:e});this.setAllAccounts(m,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c)},reconnectExternal:async({id:e,info:t,type:r,provider:i})=>{let s=d.R.state.activeChain,n=this.getAdapter(s);n?.reconnect&&(await n?.reconnect({id:e,info:t,type:r,provider:i,chainId:this.getCaipNetwork()?.id}),g.M.addConnectedNamespace(s),this.syncConnectedWalletInfo(s))},disconnect:async e=>{let t=function(e){let t=Array.from(d.R.state.chains.keys()),r=[];return e?(r.push([e,d.R.state.chains.get(e)]),L(e,c.b.CONNECTOR_ID.WALLET_CONNECT)?t.forEach(t=>{t!==e&&L(t,c.b.CONNECTOR_ID.WALLET_CONNECT)&&r.push([t,d.R.state.chains.get(t)])}):L(e,c.b.CONNECTOR_ID.AUTH)&&t.forEach(t=>{t!==e&&L(t,c.b.CONNECTOR_ID.AUTH)&&r.push([t,d.R.state.chains.get(t)])})):r=Array.from(d.R.state.chains.entries()),r}(e);try{let r=await Promise.allSettled(t.map(async([e])=>this.disconnectNamespace(e)));x.S.resetSend(),s.ConnectionController.resetWcConnection(),await U.w.clearSessions(),i.ConnectorController.setFilterByNamespace(void 0);let n=r.filter(e=>"rejected"===e.status);if(n.length>0)throw Error(n.map(e=>e.reason.message).join(", "));g.M.deleteConnectedSocialProvider(),R.X.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:e||"all"}})}catch(e){throw Error(`Failed to disconnect chains: ${e.message}`)}},checkInstalled:e=>e?e.some(e=>!!window.ethereum?.[String(e)]):!!window.ethereum,signMessage:async e=>{let t=this.getAdapter(d.R.state.activeChain),r=await t?.signMessage({message:e,address:p.N.state.address,provider:ee.getProvider(d.R.state.activeChain)});return r?.signature||""},sendTransaction:async e=>{let t=e.chainNamespace;if(N.bq.SEND_SUPPORTED_NAMESPACES.includes(t)){let r=this.getAdapter(d.R.state.activeChain),i=ee.getProvider(t),s=await r?.sendTransaction({...e,caipNetwork:this.getCaipNetwork(),provider:i});return s?.hash||""}return""},estimateGas:async e=>{if(e.chainNamespace===c.b.CHAIN.EVM){let t=this.getAdapter(d.R.state.activeChain),r=ee.getProvider(d.R.state.activeChain),i=this.getCaipNetwork();if(!i)throw Error("CaipNetwork is undefined");let s=await t?.estimateGas({...e,provider:r,caipNetwork:i});return s?.gas||0n}return 0n},getEnsAvatar:async()=>(await this.syncIdentity({address:p.N.state.address,chainId:Number(this.getCaipNetwork()?.id),chainNamespace:d.R.state.activeChain}),p.N.state.profileImage||!1),getEnsAddress:async e=>await ec.resolveReownName(e),writeContract:async e=>{let t=this.getAdapter(d.R.state.activeChain),r=this.getCaipNetwork(),i=this.getCaipAddress(),s=ee.getProvider(d.R.state.activeChain);if(!r||!i)throw Error("CaipNetwork or CaipAddress is undefined");let n=await t?.writeContract({...e,caipNetwork:r,provider:s,caipAddress:i});return n?.hash},parseUnits:(e,t)=>{let r=this.getAdapter(d.R.state.activeChain);return r?.parseUnits({value:e,decimals:t})??0n},formatUnits:(e,t)=>{let r=this.getAdapter(d.R.state.activeChain);return r?.formatUnits({value:e,decimals:t})??"0"},getCapabilities:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.getCapabilities(e)},grantPermissions:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.grantPermissions(e)},revokePermissions:async e=>{let t=this.getAdapter(d.R.state.activeChain);return t?.revokePermissions?await t.revokePermissions(e):"0x"},walletGetAssets:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.walletGetAssets(e)??{}},updateBalance:e=>{let t=this.getCaipNetwork(e);t&&p.N.state.address&&this.updateNativeBalance(p.N.state.address,t?.id,e)}},this.networkControllerClient={switchCaipNetwork:async e=>await this.switchCaipNetwork(e),getApprovedCaipNetworksData:async()=>this.getApprovedCaipNetworksData()},s.ConnectionController.setClient(this.connectionControllerClient)}getApprovedCaipNetworksData(){if(ee.getProviderId(d.R.state.activeChain)===W.b.CONNECTOR_TYPE_WALLET_CONNECT){let e=this.universalProvider?.session?.namespaces;return{supportsAllNetworks:this.universalProvider?.session?.peer?.metadata.name==="MetaMask Wallet",approvedCaipNetworkIds:this.getChainsFromNamespaces(e)}}return{supportsAllNetworks:!0,approvedCaipNetworkIds:[]}}async switchCaipNetwork(e){if(!e)return;let t=e.chainNamespace;if(this.getAddressByChainNamespace(e.chainNamespace)){let r=ee.getProvider(t),i=ee.getProviderId(t);if(e.chainNamespace===d.R.state.activeChain){let s=this.getAdapter(t);await s?.switchNetwork({caipNetwork:e,provider:r,providerType:i})}else if(this.setCaipNetwork(e),i===W.b.CONNECTOR_TYPE_WALLET_CONNECT)this.syncWalletConnectAccount();else{let r=this.getAddressByChainNamespace(t);r&&this.syncAccount({address:r,chainId:e.id,chainNamespace:t})}}else this.setCaipNetwork(e)}getChainsFromNamespaces(e={}){return Object.values(e).flatMap(e=>Array.from(new Set([...e.chains||[],...e.accounts.map(e=>{let{chainId:t,chainNamespace:r}=l.parseCaipAddress(e);return`${r}:${t}`})])))}createAdapters(e){return this.createClients(),this.chainNamespaces.reduce((t,r)=>{let i=e?.find(e=>e.namespace===r);return i?(i.construct({namespace:r,projectId:this.options?.projectId,networks:this.getCaipNetworks()}),t[r]=i):t[r]=new eu({namespace:r,networks:this.getCaipNetworks()}),t},{})}async initChainAdapter(e){this.onConnectors(e),this.listenAdapter(e),await this.chainAdapters?.[e].syncConnectors(this.options,this),await this.createUniversalProviderForAdapter(e)}async initChainAdapters(){await Promise.all(this.chainNamespaces.map(async e=>{await this.initChainAdapter(e)}))}onConnectors(e){let t=this.getAdapter(e);t?.on("connectors",this.setConnectors.bind(this))}listenAdapter(e){let t=this.getAdapter(e);if(!t)return;let r=g.M.getConnectionStatus();"connected"===r?this.setStatus("connecting",e):("disconnected"===r&&g.M.clearAddressCache(),this.setStatus(r,e)),t.on("switchNetwork",({address:t,chainId:r})=>{let i=this.getCaipNetworks().find(e=>e.id===r||e.caipNetworkId===r),s=d.R.state.activeChain===e,n=d.R.getAccountProp("address",e);if(i){let r=s&&t?t:n;r&&this.syncAccount({address:r,chainId:i.id,chainNamespace:e})}else this.setUnsupportedNetwork(r)}),t.on("disconnect",this.disconnect.bind(this,e)),t.on("connections",t=>{this.setConnections(t,e)}),t.on("pendingTransactions",()=>{let e=p.N.state.address,t=d.R.state.activeCaipNetwork;e&&t?.id&&this.updateNativeBalance(e,t.id,t.chainNamespace)}),t.on("accountChanged",({address:t,chainId:r})=>{let i=d.R.state.activeChain===e;i&&r?this.syncAccount({address:t,chainId:r,chainNamespace:e}):i&&d.R.state.activeCaipNetwork?.id?this.syncAccount({address:t,chainId:d.R.state.activeCaipNetwork?.id,chainNamespace:e}):this.syncAccountInfo(t,r,e),this.syncAllAccounts(e)})}async createUniversalProviderForAdapter(e){await this.getUniversalProvider(),this.universalProvider&&this.chainAdapters?.[e]?.setUniversalProvider?.(this.universalProvider)}async syncExistingConnection(){await Promise.allSettled(this.chainNamespaces.map(e=>this.syncNamespaceConnection(e)))}async syncNamespaceConnection(e){try{e===c.b.CHAIN.EVM&&n.j.isSafeApp()&&i.ConnectorController.setConnectorId(c.b.CONNECTOR_ID.SAFE,e);let t=i.ConnectorController.getConnectorId(e);switch(this.setStatus("connecting",e),t){case c.b.CONNECTOR_ID.WALLET_CONNECT:await this.syncWalletConnectAccount();break;case c.b.CONNECTOR_ID.AUTH:break;default:await this.syncAdapterConnection(e)}}catch(t){console.warn("AppKit couldn't sync existing connection",t),this.setStatus("disconnected",e)}}async syncAdapterConnection(e){let t=this.getAdapter(e),r=i.ConnectorController.getConnectorId(e),s=this.getCaipNetwork(e),a=i.ConnectorController.getConnectors(e).find(e=>e.id===r);try{if(!t||!a)throw Error(`Adapter or connector not found for namespace ${e}`);if(!s?.id)throw Error("CaipNetwork not found");let r=await t?.syncConnection({namespace:e,id:a.id,chainId:s.id,rpcUrl:s?.rpcUrls?.default?.http?.[0]});if(r){let i=await t?.getAccounts({namespace:e,id:a.id});i&&i.accounts.length>0?this.setAllAccounts(i.accounts,e):this.setAllAccounts([n.j.createAccount(e,r.address,"eoa")],e),this.syncProvider({...r,chainNamespace:e}),await this.syncAccount({...r,chainNamespace:e}),this.setStatus("connected",e)}else this.setStatus("disconnected",e)}catch(t){this.setStatus("disconnected",e)}}async syncWalletConnectAccount(){let e=this.chainNamespaces.map(async e=>{let t=this.getAdapter(e),r=this.universalProvider?.session?.namespaces?.[e]?.accounts||[],s=d.R.state.activeCaipNetwork?.id,n=r.find(e=>{let{chainId:t}=l.parseCaipAddress(e);return t===s?.toString()})||r[0];if(n){let r=l.validateCaipAddress(n),{chainId:s,address:a}=l.parseCaipAddress(r);if(ee.setProviderId(e,W.b.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&d.R.state.activeCaipNetwork&&t?.namespace!==c.b.CHAIN.EVM){let r=t?.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:d.R.state.activeCaipNetwork});ee.setProvider(e,r)}else ee.setProvider(e,this.universalProvider);i.ConnectorController.setConnectorId(c.b.CONNECTOR_ID.WALLET_CONNECT,e),g.M.addConnectedNamespace(e),this.syncWalletConnectAccounts(e),await this.syncAccount({address:a,chainId:s,chainNamespace:e})}else this.setStatus("disconnected",e);this.syncConnectedWalletInfo(e),await d.R.setApprovedCaipNetworksData(e)});await Promise.all(e)}syncWalletConnectAccounts(e){let t=this.universalProvider?.session?.namespaces?.[e]?.accounts?.map(e=>{let{address:t}=l.parseCaipAddress(e);return t}).filter((e,t,r)=>r.indexOf(e)===t);t&&this.setAllAccounts(t.map(t=>n.j.createAccount(e,t,"bip122"===e?"payment":"eoa")),e)}syncProvider({type:e,provider:t,id:r,chainNamespace:s}){ee.setProviderId(s,e),ee.setProvider(s,t),i.ConnectorController.setConnectorId(r,s)}async syncAllAccounts(e){let t=i.ConnectorController.getConnectorId(e);if(!t)return;let r=this.getAdapter(e),s=await r?.getAccounts({namespace:e,id:t});s&&s.accounts.length>0&&this.setAllAccounts(s.accounts,e)}async syncAccount(e){let t=e.chainNamespace===d.R.state.activeChain,r=d.R.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:i,chainId:s,chainNamespace:n}=e,{chainId:o}=g.M.getActiveNetworkProps(),h=s||o,u=d.R.state.activeCaipNetwork?.name===c.b.UNSUPPORTED_NETWORK_NAME,f=d.R.getNetworkProp("supportsAllNetworks",n);if(this.setStatus("connected",n),(!u||f)&&h){let e=this.getCaipNetworks().find(e=>e.id.toString()===h.toString()),s=this.getCaipNetworks().find(e=>e.chainNamespace===n);if(!f&&!e&&!s){let t=this.getApprovedCaipNetworkIds()||[],r=t.find(e=>l.parseCaipNetworkId(e)?.chainId===h.toString()),i=t.find(e=>l.parseCaipNetworkId(e)?.chainNamespace===n);e=this.getCaipNetworks().find(e=>e.caipNetworkId===r),s=this.getCaipNetworks().find(e=>e.caipNetworkId===i||"deprecatedCaipNetworkId"in e&&e.deprecatedCaipNetworkId===i)}let o=e||s;o?.chainNamespace===d.R.state.activeChain?a.OptionsController.state.enableNetworkSwitch&&!a.OptionsController.state.allowUnsupportedChain&&d.R.state.activeCaipNetwork?.name===c.b.UNSUPPORTED_NETWORK_NAME?d.R.showUnsupportedChainUI():this.setCaipNetwork(o):!t&&r&&this.setCaipNetworkOfNamespace(r,n),this.syncConnectedWalletInfo(n),G.g.isLowerCaseMatch(i,p.N.state.address)||this.syncAccountInfo(i,o?.id,n),t?await this.syncBalance({address:i,chainId:o?.id,chainNamespace:n}):await this.syncBalance({address:i,chainId:r?.id,chainNamespace:n})}}async syncAccountInfo(e,t,r){let i=this.getCaipAddress(r),s=t||i?.split(":")[1];if(!s)return;let n=`${r}:${s}:${e}`;this.setCaipAddress(n,r),await this.syncIdentity({address:e,chainId:s,chainNamespace:r})}async syncReownName(e,t){try{let r=await this.getReownName(e);if(r[0]){let e=r[0];this.setProfileName(e.name,t)}else this.setProfileName(null,t)}catch{this.setProfileName(null,t)}}syncConnectedWalletInfo(e){let t=i.ConnectorController.getConnectorId(e),r=ee.getProviderId(e);if(r===W.b.CONNECTOR_TYPE_ANNOUNCED||r===W.b.CONNECTOR_TYPE_INJECTED){if(t){let r=this.getConnectors().find(e=>e.id===t);if(r){let{info:t,name:i,imageUrl:s}=r,n=s||this.getConnectorImage(r);this.setConnectedWalletInfo({name:i,icon:n,...t},e)}}}else if(r===W.b.CONNECTOR_TYPE_WALLET_CONNECT){let t=ee.getProvider(e);t?.session&&this.setConnectedWalletInfo({...t.session.peer.metadata,name:t.session.peer.metadata.name,icon:t.session.peer.metadata.icons?.[0]},e)}else if(t&&t===c.b.CONNECTOR_ID.COINBASE){let t=this.getConnectors().find(e=>e.id===c.b.CONNECTOR_ID.COINBASE);this.setConnectedWalletInfo({name:"Coinbase Wallet",icon:this.getConnectorImage(t)},e)}}async syncBalance(e){h.p.getNetworksByNamespace(this.getCaipNetworks(),e.chainNamespace).find(t=>t.id.toString()===e.chainId?.toString())&&e.chainId&&await this.updateNativeBalance(e.address,e.chainId,e.chainNamespace)}async ready(){await this.readyPromise}async updateNativeBalance(e,t,r){let i=this.getAdapter(r),s=d.R.getCaipNetworkByNamespace(r,t);if(i){let n=await i.getBalance({address:e,chainId:t,caipNetwork:s,tokens:this.options.tokens});return this.setBalance(n.balance,n.symbol,r),n}}async initializeUniversalAdapter(){let e=X.createLogger((e,...t)=>{e&&this.handleAlertError(e),console.error(...t)}),t={projectId:this.options?.projectId,metadata:{name:this.options?.metadata?this.options?.metadata.name:"",description:this.options?.metadata?this.options?.metadata.description:"",url:this.options?.metadata?this.options?.metadata.url:"",icons:this.options?.metadata?this.options?.metadata.icons:[""]},logger:e};a.OptionsController.setManualWCControl(!!this.options?.manualWCControl),this.universalProvider=this.options.universalProvider??await o.Z.init(t),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&(this.universalProvider.on("display_uri",e=>{s.ConnectionController.setUri(e)}),this.universalProvider.on("connect",s.ConnectionController.finalizeWcConnection),this.universalProvider.on("disconnect",()=>{this.chainNamespaces.forEach(e=>{this.resetAccount(e)}),s.ConnectionController.resetWcConnection()}),this.universalProvider.on("chainChanged",e=>{let t=this.getCaipNetworks().find(t=>t.id==e),r=this.getCaipNetwork();if(!t){this.setUnsupportedNetwork(e);return}r?.id!==t?.id&&this.setCaipNetwork(t)}),this.universalProvider.on("session_event",e=>{if(ec.isSessionEventData(e)){let{name:t,data:r}=e.params.event;"accountsChanged"===t&&Array.isArray(r)&&n.j.isCaipAddress(r[0])&&this.syncAccount(l.parseCaipAddress(r[0]))}}))}createUniversalProvider(){return!this.universalProviderInitPromise&&n.j.isClient()&&this.options?.projectId&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){R.X.sendEvent({type:"error",event:"INTERNAL_SDK_ERROR",properties:{errorType:"UniversalProviderInitError",errorMessage:e instanceof Error?e.message:"Unknown",uncaught:!1}}),console.error("AppKit:getUniversalProvider - Cannot create provider",e)}return this.universalProvider}handleAlertError(e){let[t,r]=Object.entries(B.UniversalProviderErrors).find(([,{message:t}])=>e.message.includes(t))??[],{message:i,alertErrorKey:s}=r??{};if(t&&i&&!this.reportedAlertErrors[t]){let e=B.ALERT_ERRORS[s];e&&(T.AlertController.open(e,"error"),this.reportedAlertErrors[t]=!0)}}getAdapter(e){if(e)return this.chainAdapters?.[e]}createAdapter(e){if(!e)return;let t=e.namespace;t&&(this.createClients(),e.namespace=t,e.construct({namespace:t,projectId:this.options?.projectId,networks:this.getCaipNetworks()}),this.chainNamespaces.includes(t)||this.chainNamespaces.push(t),this.chainAdapters&&(this.chainAdapters[t]=e))}async open(e){return(await this.injectModalUi(),e?.uri&&s.ConnectionController.setUri(e.uri),e?.arguments&&e?.view==="Swap")?D.I.open({...e,data:{swap:e.arguments}}):D.I.open(e)}async close(){await this.injectModalUi(),D.I.close()}setLoading(e,t){D.I.setLoading(e,t)}async disconnect(e){await s.ConnectionController.disconnect(e)}getSIWX(){return a.OptionsController.state.siwx}getError(){return""}getChainId(){return d.R.state.activeCaipNetwork?.id}async switchNetwork(e){let t=this.getCaipNetworks().find(t=>t.id===e.id);if(!t){T.AlertController.open(B.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await d.R.switchActiveNetwork(t)}getWalletProvider(){return d.R.state.activeChain?ee.state.providers[d.R.state.activeChain]:null}getWalletProviderType(){return ee.getProviderId(d.R.state.activeChain)}subscribeProviders(e){return ee.subscribeProviders(e)}getThemeMode(){return k.ThemeController.state.themeMode}getThemeVariables(){return k.ThemeController.state.themeVariables}setThemeMode(e){k.ThemeController.setThemeMode(e),(0,q.Hs)(k.ThemeController.state.themeMode)}setTermsConditionsUrl(e){a.OptionsController.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){a.OptionsController.setPrivacyPolicyUrl(e)}setThemeVariables(e){k.ThemeController.setThemeVariables(e),(0,q.R)(k.ThemeController.state.themeVariables)}subscribeTheme(e){return k.ThemeController.subscribe(e)}getWalletInfo(){return p.N.state.connectedWalletInfo}getAccount(e){let t=i.ConnectorController.getAuthConnector(e),r=d.R.getAccountData(e),s=d.R.state.activeChain,a=g.M.getConnectedConnectorId(e||s);if(r)return{allAccounts:r.allAccounts,caipAddress:r.caipAddress,address:n.j.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:t&&a===c.b.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:g.M.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:r.preferredAccountTypes?.[e||s],isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,t){let r=()=>{let r=this.getAccount(t);r&&e(r)};t?d.R.subscribeChainProp("accountState",r,t):d.R.subscribe(r),i.ConnectorController.subscribe(r)}subscribeNetwork(e){return d.R.subscribe(({activeCaipNetwork:t})=>{e({caipNetwork:t,chainId:t?.id,caipNetworkId:t?.caipNetworkId})})}subscribeWalletInfo(e){return p.N.subscribeKey("connectedWalletInfo",e)}subscribeShouldUpdateToAddress(e){p.N.subscribeKey("shouldUpdateToAddress",e)}subscribeCaipNetworkChange(e){d.R.subscribeKey("activeCaipNetwork",e)}getState(){return $.I.state}subscribeState(e){return $.I.subscribe(e)}showErrorMessage(e){M.SnackController.showError(e)}showSuccessMessage(e){M.SnackController.showSuccess(e)}getEvent(){return{...R.X.state}}subscribeEvents(e){return R.X.subscribe(e)}replace(e){b.RouterController.replace(e)}redirect(e){b.RouterController.push(e)}popTransactionStack(e){b.RouterController.popTransactionStack(e)}isOpen(){return D.I.state.open}isTransactionStackEmpty(){return 0===b.RouterController.state.transactionStack.length}static getInstance(){return this.instance}updateFeatures(e){a.OptionsController.setFeatures(e)}updateRemoteFeatures(e){a.OptionsController.setRemoteFeatures(e)}updateOptions(e){let t={...a.OptionsController.state||{},...e};a.OptionsController.setOptions(t)}setConnectMethodsOrder(e){a.OptionsController.setConnectMethodsOrder(e)}setWalletFeaturesOrder(e){a.OptionsController.setWalletFeaturesOrder(e)}setCollapseWallets(e){a.OptionsController.setCollapseWallets(e)}setSocialsOrder(e){a.OptionsController.setSocialsOrder(e)}getConnectMethodsOrder(){return j.J.getConnectOrderMethod(a.OptionsController.state.features,i.ConnectorController.getConnectors())}addNetwork(e,t){if(this.chainAdapters&&!this.chainAdapters[e])throw Error(`Adapter for namespace ${e} doesn't exist`);let r=this.extendCaipNetwork(t,this.options);this.getCaipNetworks().find(e=>e.id===r.id)||d.R.addNetwork(r)}removeNetwork(e,t){if(this.chainAdapters&&!this.chainAdapters[e])throw Error(`Adapter for namespace ${e} doesn't exist`);this.getCaipNetworks().find(e=>e.id===t)&&d.R.removeNetwork(e,t)}}let ew=!1;class ey extends em{async open(e){i.ConnectorController.isConnected()||await super.open(e)}async close(){await super.close(),this.options.manualWCControl&&s.ConnectionController.finalizeWcConnection()}async syncIdentity(e){return Promise.resolve()}async syncBalance(e){return Promise.resolve()}async injectModalUi(){if(!ew&&n.j.isClient()){if(await Promise.all([r.e(246),r.e(3896)]).then(r.bind(r,73896)),await Promise.all([r.e(246),r.e(8016)]).then(r.bind(r,8016)),!document.querySelector("w3m-modal")){let e=document.createElement("w3m-modal");a.OptionsController.state.disableAppend||a.OptionsController.state.enableEmbedded||document.body.insertAdjacentElement("beforeend",e)}ew=!0}}}function eb(e){return new ey({...e,basic:!0,sdkVersion:"html-core-1.7.8"})}},77934:(e,t,r)=>{"use strict";r.d(t,{Jb:()=>_,Ld:()=>S,YP:()=>A,_$LH:()=>B,dy:()=>I,sY:()=>H});/**
894
+ `},hexToRgb(e){let t=parseInt(e,16);return[t>>16&255,t>>8&255,255&t]},tintColor(e,t){let[r,i,s]=e;return[Math.round(r+(255-r)*t),Math.round(i+(255-i)*t),Math.round(s+(255-s)*t)]},isNumber:e=>/^[0-9]+$/u.test(e),getColorTheme:e=>e||("undefined"!=typeof window&&window.matchMedia?window.matchMedia("(prefers-color-scheme: dark)")?.matches?"dark":"light":"dark"),splitBalance(e){let t=e.split(".");return 2===t.length?[t[0],t[1]]:["0","00"]},roundNumber:(e,t,r)=>e.toString().length>=t?Number(e).toFixed(r):e,formatNumberToLocalString:(e,t=2)=>void 0===e?"0.00":"number"==typeof e?e.toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t}):parseFloat(e).toLocaleString("en-US",{maximumFractionDigits:t,minimumFractionDigits:t})}},56917:(e,t,r)=>{"use strict";function i(e){return function(t){return"function"==typeof t?(customElements.get(e)||customElements.define(e,t),t):function(e,t){let{kind:r,elements:i}=t;return{kind:r,elements:i,finisher(t){customElements.get(e)||customElements.define(e,t)}}}(e,t)}}r.d(t,{M:()=>i})},43515:(e,t,r)=>{"use strict";r.d(t,{b:()=>i});let i={METMASK_CONNECTOR_NAME:"MetaMask",TRUST_CONNECTOR_NAME:"Trust Wallet",SOLFLARE_CONNECTOR_NAME:"Solflare",PHANTOM_CONNECTOR_NAME:"Phantom",COIN98_CONNECTOR_NAME:"Coin98",MAGIC_EDEN_CONNECTOR_NAME:"Magic Eden",BACKPACK_CONNECTOR_NAME:"Backpack",BITGET_CONNECTOR_NAME:"Bitget Wallet",FRONTIER_CONNECTOR_NAME:"Frontier",XVERSE_CONNECTOR_NAME:"Xverse Wallet",LEATHER_CONNECTOR_NAME:"Leather",EIP155:"eip155",ADD_CHAIN_METHOD:"wallet_addEthereumChain",EIP6963_ANNOUNCE_EVENT:"eip6963:announceProvider",EIP6963_REQUEST_EVENT:"eip6963:requestProvider",CONNECTOR_RDNS_MAP:{coinbaseWallet:"com.coinbase.wallet",coinbaseWalletSDK:"com.coinbase.wallet"},CONNECTOR_TYPE_EXTERNAL:"EXTERNAL",CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH",CONNECTOR_TYPE_MULTI_CHAIN:"MULTI_CHAIN",CONNECTOR_TYPE_W3M_AUTH:"ID_AUTH"}},31591:(e,t,r)=>{"use strict";r.d(t,{g:()=>s});var i=r(43515);let s={getCaipTokens(e){if(!e)return;let t={};return Object.entries(e).forEach(([e,r])=>{t[`${i.b.EIP155}:${e}`]=r}),t},isLowerCaseMatch:(e,t)=>e?.toLowerCase()===t?.toLowerCase()}},3577:(e,t,r)=>{"use strict";r.d(t,{y_:()=>i}),"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_SECURE_SITE_SDK_URL,"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_DEFAULT_LOG_LEVEL,"undefined"!=typeof process&&void 0!==process.env&&process.env.NEXT_PUBLIC_SECURE_SITE_SDK_VERSION;let i={SAFE_RPC_METHODS:["eth_accounts","eth_blockNumber","eth_call","eth_chainId","eth_estimateGas","eth_feeHistory","eth_gasPrice","eth_getAccount","eth_getBalance","eth_getBlockByHash","eth_getBlockByNumber","eth_getBlockReceipts","eth_getBlockTransactionCountByHash","eth_getBlockTransactionCountByNumber","eth_getCode","eth_getFilterChanges","eth_getFilterLogs","eth_getLogs","eth_getProof","eth_getStorageAt","eth_getTransactionByBlockHashAndIndex","eth_getTransactionByBlockNumberAndIndex","eth_getTransactionByHash","eth_getTransactionCount","eth_getTransactionReceipt","eth_getUncleCountByBlockHash","eth_getUncleCountByBlockNumber","eth_maxPriorityFeePerGas","eth_newBlockFilter","eth_newFilter","eth_newPendingTransactionFilter","eth_sendRawTransaction","eth_syncing","eth_uninstallFilter","wallet_getCapabilities","wallet_getCallsStatus","eth_getUserOperationReceipt","eth_estimateUserOperationGas","eth_getUserOperationByHash","eth_supportedEntryPoints","wallet_getAssets"],NOT_SAFE_RPC_METHODS:["personal_sign","eth_signTypedData_v4","eth_sendTransaction","solana_signMessage","solana_signTransaction","solana_signAllTransactions","solana_signAndSendTransaction","wallet_sendCalls","wallet_grantPermissions","wallet_revokePermissions","eth_sendUserOperation"],GET_CHAIN_ID:"eth_chainId",RPC_METHOD_NOT_ALLOWED_MESSAGE:"Requested RPC call is not allowed",RPC_METHOD_NOT_ALLOWED_UI_MESSAGE:"Action not allowed",ACCOUNT_TYPES:{EOA:"eoa",SMART_ACCOUNT:"smartAccount"}}},21209:(e,t,r)=>{"use strict";r.d(t,{createAppKit:()=>eb});var i=r(75257),s=r(1528),n=r(53556),a=r(7787),o=r(50691),c=r(82324);let l={validateCaipAddress(e){if(e.split(":")?.length!==3)throw Error("Invalid CAIP Address");return e},parseCaipAddress(e){let t=e.split(":");if(3!==t.length)throw Error(`Invalid CAIP-10 address: ${e}`);let[r,i,s]=t;if(!r||!i||!s)throw Error(`Invalid CAIP-10 address: ${e}`);return{chainNamespace:r,chainId:i,address:s}},parseCaipNetworkId(e){let t=e.split(":");if(2!==t.length)throw Error(`Invalid CAIP-2 network id: ${e}`);let[r,i]=t;if(!r||!i)throw Error(`Invalid CAIP-2 network id: ${e}`);return{chainNamespace:r,chainId:i}}};var h=r(47588),d=r(1326),u=r(27052),p=r(10081),g=r(25350),f=r(43892),m=r(95502);let w={convertEVMChainIdToCoinType(e){if(e>=2147483648)throw Error("Invalid chainId");return(2147483648|e)>>>0}};var y=r(34534),b=r(60892);let v=(0,f.sj)({suggestions:[],loading:!1}),C=(0,y.P)({state:v,subscribe:e=>(0,f.Ld)(v,()=>e(v)),subscribeKey:(e,t)=>(0,m.VW)(v,e,t),async resolveName(e){try{return await u.L.lookupEnsName(e)}catch(e){throw Error(e?.reasons?.[0]?.description||"Error resolving name")}},async isNameRegistered(e){try{return await u.L.lookupEnsName(e),!0}catch{return!1}},async getSuggestions(e){try{v.loading=!0,v.suggestions=[];let t=await u.L.getEnsNameSuggestions(e);return v.suggestions=t.suggestions.map(e=>({...e,name:e.name}))||[],v.suggestions}catch(e){throw Error(C.parseEnsApiError(e,"Error fetching name suggestions"))}finally{v.loading=!1}},async getNamesForAddress(e){try{if(!d.R.state.activeCaipNetwork)return[];let t=g.M.getEnsFromCacheForAddress(e);if(t)return t;let r=await u.L.reverseLookupEnsName({address:e});return g.M.updateEnsCache({address:e,ens:r,timestamp:Date.now()}),r}catch(e){throw Error(C.parseEnsApiError(e,"Error fetching names for address"))}},async registerName(e){let t=d.R.state.activeCaipNetwork;if(!t)throw Error("Network not found");let r=p.N.state.address,n=i.ConnectorController.getAuthConnector();if(!r||!n)throw Error("Address or auth connector not found");v.loading=!0;try{let i=JSON.stringify({name:e,attributes:{},timestamp:Math.floor(Date.now()/1e3)});b.RouterController.pushTransactionStack({onCancel(){b.RouterController.replace("RegisterAccountName")}});let n=await s.ConnectionController.signMessage(i);v.loading=!1;let a=t.id;if(!a)throw Error("Network not found");let o=w.convertEVMChainIdToCoinType(Number(a));await u.L.registerEnsName({coinType:o,address:r,signature:n,message:i}),p.N.setProfileName(e,t.chainNamespace),b.RouterController.replace("RegisterAccountNameSuccess")}catch(r){let t=C.parseEnsApiError(r,`Error registering name ${e}`);throw b.RouterController.replace("RegisterAccountName"),Error(t)}finally{v.loading=!1}},validateName:e=>/^[a-zA-Z0-9-]{4,}$/u.test(e),parseEnsApiError:(e,t)=>e?.reasons?.[0]?.description||t});var E=r(44750),N=r(2201),I=r(65279);let A={id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},_={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},S={providers:N.gy,selectedProvider:null,error:null,purchaseCurrency:A,paymentCurrency:_,purchaseCurrencies:[A],paymentCurrencies:[],quotesLoading:!1},O=(0,f.sj)(S),P=(0,y.P)({state:O,subscribe:e=>(0,f.Ld)(O,()=>e(O)),subscribeKey:(e,t)=>(0,m.VW)(O,e,t),setSelectedProvider(e){if(e&&"meld"===e.name){let t=d.R.state.activeChain===c.b.CHAIN.SOLANA?"SOL":"USDC",r=p.N.state.address??"",i=new URL(e.url);i.searchParams.append("publicKey",N.a$),i.searchParams.append("destinationCurrencyCode",t),i.searchParams.append("walletAddress",r),i.searchParams.append("externalCustomerId",a.OptionsController.state.projectId),O.selectedProvider={...e,url:i.toString()}}else O.selectedProvider=e},setOnrampProviders(e){if(Array.isArray(e)&&e.every(e=>"string"==typeof e)){let t=N.gy.filter(t=>e.includes(t.name));O.providers=t}else O.providers=[]},setPurchaseCurrency(e){O.purchaseCurrency=e},setPaymentCurrency(e){O.paymentCurrency=e},setPurchaseAmount(e){P.state.purchaseAmount=e},setPaymentAmount(e){P.state.paymentAmount=e},async getAvailableCurrencies(){let e=await u.L.getOnrampOptions();O.purchaseCurrencies=e.purchaseCurrencies,O.paymentCurrencies=e.paymentCurrencies,O.paymentCurrency=e.paymentCurrencies[0]||_,O.purchaseCurrency=e.purchaseCurrencies[0]||A,await I.ApiController.fetchCurrencyImages(e.paymentCurrencies.map(e=>e.id)),await I.ApiController.fetchTokenImages(e.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){O.quotesLoading=!0;try{let e=await u.L.getOnrampQuote({purchaseCurrency:O.purchaseCurrency,paymentCurrency:O.paymentCurrency,amount:O.paymentAmount?.toString()||"0",network:O.purchaseCurrency?.symbol});return O.quotesLoading=!1,O.purchaseAmount=Number(e?.purchaseAmount.amount),e}catch(e){return O.error=e.message,O.quotesLoading=!1,null}finally{O.quotesLoading=!1}},resetState(){O.selectedProvider=null,O.error=null,O.purchaseCurrency=A,O.paymentCurrency=_,O.purchaseCurrencies=[A],O.paymentCurrencies=[],O.paymentAmount=void 0,O.purchaseAmount=void 0,O.quotesLoading=!1}});var T=r(51693),R=r(50001),k=r(11986),x=r(18166),U=r(90161),D=r(52705),$=r(14253),M=r(99674);function L(e,t){return i.ConnectorController.getConnectorId(e)===t}r(80981),r(21114);var j=r(63794),q=r(93619);new AbortController;let B={UniversalProviderErrors:{UNAUTHORIZED_DOMAIN_NOT_ALLOWED:{message:"Unauthorized: origin not allowed",alertErrorKey:"INVALID_APP_CONFIGURATION"},JWT_VALIDATION_ERROR:{message:"JWT validation error: JWT Token is not yet valid",alertErrorKey:"JWT_TOKEN_NOT_VALID"},INVALID_KEY:{message:"Unauthorized: invalid key",alertErrorKey:"INVALID_PROJECT_ID"}},ALERT_ERRORS:{SWITCH_NETWORK_NOT_FOUND:{shortMessage:"Network Not Found",longMessage:"Network not found - please make sure it is included in 'networks' array in createAppKit function"},INVALID_APP_CONFIGURATION:{shortMessage:"Invalid App Configuration",longMessage:()=>`Origin ${"undefined"!=typeof window?window.origin:"unknown"} not found on Allowlist - update configuration on cloud.reown.com`},IFRAME_LOAD_FAILED:{shortMessage:"Network Error - Could not load embedded wallet",longMessage:()=>"There was an issue loading the embedded wallet. Please try again later."},IFRAME_REQUEST_TIMEOUT:{shortMessage:"Embedded Wallet Request Timed Out",longMessage:()=>"There was an issue doing the request to the embedded wallet. Please try again later."},UNVERIFIED_DOMAIN:{shortMessage:"Invalid App Configuration",longMessage:()=>"There was an issue loading the embedded wallet. Please verify that your domain is allowed at cloud.reown.com"},JWT_TOKEN_NOT_VALID:{shortMessage:"Session Expired",longMessage:"Invalid session found on UniversalProvider - please check your time settings and connect again"},INVALID_PROJECT_ID:{shortMessage:"Invalid App Configuration",longMessage:"Invalid Project ID - update configuration"},PROJECT_ID_NOT_CONFIGURED:{shortMessage:"Project ID Not Configured",longMessage:"Project ID Not Configured - update configuration on cloud.reown.com"}}};var F=r(87112),H=r(43567),W=r(43515);let V={ConnectorExplorerIds:{[c.b.CONNECTOR_ID.COINBASE]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[c.b.CONNECTOR_ID.COINBASE_SDK]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[c.b.CONNECTOR_ID.SAFE]:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",[c.b.CONNECTOR_ID.LEDGER]:"19177a98252e07ddfc9af2083ba8e07ef627cb6103467ffebb3f8f4205fd7927",[c.b.CONNECTOR_ID.OKX]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[W.b.METMASK_CONNECTOR_NAME]:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",[W.b.TRUST_CONNECTOR_NAME]:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",[W.b.SOLFLARE_CONNECTOR_NAME]:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",[W.b.PHANTOM_CONNECTOR_NAME]:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",[W.b.COIN98_CONNECTOR_NAME]:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",[W.b.MAGIC_EDEN_CONNECTOR_NAME]:"8b830a2b724a9c3fbab63af6f55ed29c9dfa8a55e732dc88c80a196a2ba136c6",[W.b.BACKPACK_CONNECTOR_NAME]:"2bd8c14e035c2d48f184aaa168559e86b0e3433228d3c4075900a221785019b0",[W.b.BITGET_CONNECTOR_NAME]:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",[W.b.FRONTIER_CONNECTOR_NAME]:"85db431492aa2e8672e93f4ea7acf10c88b97b867b0d373107af63dc4880f041",[W.b.XVERSE_CONNECTOR_NAME]:"2a87d74ae02e10bdd1f51f7ce6c4e1cc53cd5f2c0b6b5ad0d7b3007d2b13de7b",[W.b.LEATHER_CONNECTOR_NAME]:"483afe1df1df63daf313109971ff3ef8356ddf1cc4e45877d205eee0b7893a13"},NetworkImageIds:{1:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",42161:"3bff954d-5cb0-47a0-9a23-d20192e74600",43114:"30c46e53-e989-45fb-4549-be3bd4eb3b00",56:"93564157-2e8e-4ce7-81df-b264dbee9b00",250:"06b26297-fe0c-4733-5d6b-ffa5498aac00",10:"ab9c186a-c52f-464b-2906-ca59d760a400",137:"41d04d42-da3b-4453-8506-668cc0727900",5e3:"e86fae9b-b770-4eea-e520-150e12c81100",295:"6a97d510-cac8-4e58-c7ce-e8681b044c00",11155111:"e909ea0a-f92a-4512-c8fc-748044ea6800",84532:"a18a7ecd-e307-4360-4746-283182228e00",1301:"4eeea7ef-0014-4649-5d1d-07271a80f600",130:"2257980a-3463-48c6-cbac-a42d2a956e00",10143:"0a728e83-bacb-46db-7844-948f05434900",100:"02b53f6a-e3d4-479e-1cb4-21178987d100",9001:"f926ff41-260d-4028-635e-91913fc28e00",324:"b310f07f-4ef7-49f3-7073-2a0a39685800",314:"5a73b3dd-af74-424e-cae0-0de859ee9400",4689:"34e68754-e536-40da-c153-6ef2e7188a00",1088:"3897a66d-40b9-4833-162f-a2c90531c900",1284:"161038da-44ae-4ec7-1208-0ea569454b00",1285:"f1d73bb6-5450-4e18-38f7-fb6484264a00",7777777:"845c60df-d429-4991-e687-91ae45791600",42220:"ab781bbc-ccc6-418d-d32d-789b15da1f00",8453:"7289c336-3981-4081-c5f4-efc26ac64a00",1313161554:"3ff73439-a619-4894-9262-4470c773a100",2020:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",2021:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",80094:"e329c2c9-59b0-4a02-83e4-212ff3779900",2741:"fc2427d1-5af9-4a9c-8da5-6f94627cd900","5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":"a1b58899-f671-4276-6a5e-56ca5bd59700","4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z":"a1b58899-f671-4276-6a5e-56ca5bd59700",EtWTRABZaYq6iMfeYKouRu166VU2xqa1:"a1b58899-f671-4276-6a5e-56ca5bd59700","000000000019d6689c085ae165831e93":"0b4838db-0161-4ffe-022d-532bf03dba00","000000000933ea01ad0ee984209779ba":"39354064-d79b-420b-065d-f980c4b78200"},ConnectorImageIds:{[c.b.CONNECTOR_ID.COINBASE]:"0c2840c3-5b04-4c44-9661-fbd4b49e1800",[c.b.CONNECTOR_ID.COINBASE_SDK]:"0c2840c3-5b04-4c44-9661-fbd4b49e1800",[c.b.CONNECTOR_ID.SAFE]:"461db637-8616-43ce-035a-d89b8a1d5800",[c.b.CONNECTOR_ID.LEDGER]:"54a1aa77-d202-4f8d-0fb2-5d2bb6db0300",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"ef1a1fcf-7fe8-4d69-bd6d-fda1345b4400",[c.b.CONNECTOR_ID.INJECTED]:"07ba87ed-43aa-4adf-4540-9e6a2b9cae00"},ConnectorNamesMap:{[c.b.CONNECTOR_ID.INJECTED]:"Browser Wallet",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"WalletConnect",[c.b.CONNECTOR_ID.COINBASE]:"Coinbase",[c.b.CONNECTOR_ID.COINBASE_SDK]:"Coinbase",[c.b.CONNECTOR_ID.LEDGER]:"Ledger",[c.b.CONNECTOR_ID.SAFE]:"Safe"},ConnectorTypesMap:{[c.b.CONNECTOR_ID.INJECTED]:"INJECTED",[c.b.CONNECTOR_ID.WALLET_CONNECT]:"WALLET_CONNECT",[c.b.CONNECTOR_ID.EIP6963]:"ANNOUNCED",[c.b.CONNECTOR_ID.AUTH]:"AUTH"},WalletConnectRpcChainIds:[1,5,11155111,10,420,42161,421613,137,80001,42220,1313161554,1313161555,56,97,43114,43113,100,8453,84531,7777777,999,324,280]};function z(e,t){let r=new URL("https://rpc.walletconnect.org/v1/");return r.searchParams.set("chainId",e),r.searchParams.set("projectId",t),r.toString()}let K=["near:mainnet","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","eip155:1101","eip155:56","eip155:42161","eip155:7777777","eip155:59144","eip155:324","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1","eip155:5000","solana:4sgjmw1sunhzsxgspuhpqldx6wiyjntz","eip155:80084","eip155:5003","eip155:100","eip155:8453","eip155:42220","eip155:1313161555","eip155:17000","eip155:1","eip155:300","eip155:1313161554","eip155:1329","eip155:84532","eip155:421614","eip155:11155111","eip155:8217","eip155:43114","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","eip155:999999999","eip155:11155420","eip155:80002","eip155:97","eip155:43113","eip155:137","eip155:10","eip155:1301","bip122:000000000019d6689c085ae165831e93","bip122:000000000933ea01ad0ee984209779ba"],J={extendRpcUrlWithProjectId(e,t){let r=!1;try{r="rpc.walletconnect.org"===new URL(e).host}catch(e){r=!1}if(r){let r=new URL(e);return r.searchParams.has("projectId")||r.searchParams.set("projectId",t),r.toString()}return e},isCaipNetwork:e=>"chainNamespace"in e&&"caipNetworkId"in e,getChainNamespace(e){return this.isCaipNetwork(e)?e.chainNamespace:c.b.CHAIN.EVM},getCaipNetworkId(e){return this.isCaipNetwork(e)?e.caipNetworkId:`${c.b.CHAIN.EVM}:${e.id}`},getDefaultRpcUrl(e,t,r){let i=e.rpcUrls?.default?.http?.[0];return K.includes(t)?z(t,r):i||""},extendCaipNetwork(e,{customNetworkImageUrls:t,projectId:r,customRpcUrls:i}){let s=this.getChainNamespace(e),n=this.getCaipNetworkId(e),a=e.rpcUrls.default.http?.[0],o=this.getDefaultRpcUrl(e,n,r),c=e?.rpcUrls?.chainDefault?.http?.[0]||a,l=i?.[n]?.map(e=>e.url)||[],h=[...l,o],d=[...l];return c&&!d.includes(c)&&d.push(c),{...e,chainNamespace:s,caipNetworkId:n,assets:{imageId:V.NetworkImageIds[e.id],imageUrl:t?.[e.id]},rpcUrls:{...e.rpcUrls,default:{http:h},chainDefault:{http:d}}}},extendCaipNetworks:(e,{customNetworkImageUrls:t,projectId:r,customRpcUrls:i})=>e.map(e=>J.extendCaipNetwork(e,{customNetworkImageUrls:t,customRpcUrls:i,projectId:r})),getViemTransport(e,t,r){let i=[];return r?.forEach(e=>{i.push(F.d(e.url,e.config))}),K.includes(e.caipNetworkId)&&i.push((0,F.d)(z(e.caipNetworkId,t),{fetchOptions:{headers:{"Content-Type":"text/plain"}}})),e?.rpcUrls?.default?.http?.forEach(e=>{i.push(F.d(e))}),(0,H.tv)(i)},extendWagmiTransports(e,t,r){if(K.includes(e.caipNetworkId)){let i=this.getDefaultRpcUrl(e,e.caipNetworkId,t);return(0,H.tv)([r,(0,F.d)(i)])}return r},getUnsupportedNetwork:e=>({id:e.split(":")[1],caipNetworkId:e,name:c.b.UNSUPPORTED_NETWORK_NAME,chainNamespace:e.split(":")[0],nativeCurrency:{name:"",decimals:0,symbol:""},rpcUrls:{default:{http:[]}}}),getCaipNetworkFromStorage(e){let t=g.M.getActiveCaipNetworkId(),r=d.R.getAllRequestedCaipNetworks(),i=Array.from(d.R.state.chains?.keys()||[]),s=t?.split(":")[0],n=!!s&&i.includes(s),a=r?.find(e=>e.caipNetworkId===t);return n&&!a&&t?this.getUnsupportedNetwork(t):a||e||r?.[0]}};var G=r(31591),Y=r(41434);let X={createLogger(e,t="error"){let r=(0,Y.jI)({level:t}),{logger:i}=(0,Y.Rt)({opts:r});return i.error=(...t)=>{for(let r of t)if(r instanceof Error){e(r,...t);return}e(void 0,...t)},i}},Z={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0},Q=(0,f.sj)({providers:{...Z},providerIds:{...Z}}),ee={state:Q,subscribeKey:(e,t)=>(0,m.VW)(Q,e,t),subscribe:e=>(0,f.Ld)(Q,()=>{e(Q)}),subscribeProviders:e=>(0,f.Ld)(Q.providers,()=>e(Q.providers)),setProvider(e,t){t&&(Q.providers[e]=(0,f.iH)(t))},getProvider:e=>Q.providers[e],setProviderId(e,t){t&&(Q.providerIds[e]=t)},getProviderId(e){if(e)return Q.providerIds[e]},reset(){Q.providers={...Z},Q.providerIds={...Z}},resetChain(e){Q.providers[e]=void 0,Q.providerIds[e]=void 0}};var et=r(48787),er=r(5191);let ei={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603,DEFAULT_ALLOWED_ANCESTORS:["http://localhost:*","https://*.pages.dev","https://*.vercel.app","https://*.ngrok-free.app","https://secure-mobile.walletconnect.com","https://secure-mobile.walletconnect.org"]};function es(e){return{formatters:void 0,fees:void 0,serializers:void 0,...e}}let en=es({id:"5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",name:"Solana",network:"solana-mainnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!1,chainNamespace:"solana",caipNetworkId:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",deprecatedCaipNetworkId:"solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ"}),ea=es({id:"EtWTRABZaYq6iMfeYKouRu166VU2xqa1",name:"Solana Devnet",network:"solana-devnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!0,chainNamespace:"solana",caipNetworkId:"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1",deprecatedCaipNetworkId:"solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K"});es({id:"4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z",name:"Solana Testnet",network:"solana-testnet",nativeCurrency:{name:"Solana",symbol:"SOL",decimals:9},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},blockExplorers:{default:{name:"Solscan",url:"https://solscan.io"}},testnet:!0,chainNamespace:"solana",caipNetworkId:"solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z"}),es({id:"000000000019d6689c085ae165831e93",caipNetworkId:"bip122:000000000019d6689c085ae165831e93",chainNamespace:"bip122",name:"Bitcoin",nativeCurrency:{name:"Bitcoin",symbol:"BTC",decimals:8},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}}}),es({id:"000000000933ea01ad0ee984209779ba",caipNetworkId:"bip122:000000000933ea01ad0ee984209779ba",chainNamespace:"bip122",name:"Bitcoin Testnet",nativeCurrency:{name:"Bitcoin",symbol:"BTC",decimals:8},rpcUrls:{default:{http:["https://rpc.walletconnect.org/v1"]}},testnet:!0});let eo={solana:["solana_signMessage","solana_signTransaction","solana_requestAccounts","solana_getAccounts","solana_signAllTransactions","solana_signAndSendTransaction"],eip155:["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_showCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],bip122:["sendTransfer","signMessage","signPsbt","getAccountAddresses"]},ec={getMethodsByChainNamespace:e=>eo[e]||[],createDefaultNamespace(e){return{methods:this.getMethodsByChainNamespace(e),events:["accountsChanged","chainChanged"],chains:[],rpcMap:{}}},applyNamespaceOverrides(e,t){if(!t)return{...e};let r={...e},i=new Set;if(t.methods&&Object.keys(t.methods).forEach(e=>i.add(e)),t.chains&&Object.keys(t.chains).forEach(e=>i.add(e)),t.events&&Object.keys(t.events).forEach(e=>i.add(e)),t.rpcMap&&Object.keys(t.rpcMap).forEach(e=>{let[t]=e.split(":");t&&i.add(t)}),i.forEach(e=>{r[e]||(r[e]=this.createDefaultNamespace(e))}),t.methods&&Object.entries(t.methods).forEach(([e,t])=>{r[e]&&(r[e].methods=t)}),t.chains&&Object.entries(t.chains).forEach(([e,t])=>{r[e]&&(r[e].chains=t)}),t.events&&Object.entries(t.events).forEach(([e,t])=>{r[e]&&(r[e].events=t)}),t.rpcMap){let e=new Set;Object.entries(t.rpcMap).forEach(([t,i])=>{let[s,n]=t.split(":");s&&n&&r[s]&&(r[s].rpcMap||(r[s].rpcMap={}),e.has(s)||(r[s].rpcMap={},e.add(s)),r[s].rpcMap[n]=i)})}return r},createNamespaces(e,t){let r=e.reduce((e,t)=>{let{id:r,chainNamespace:i,rpcUrls:s}=t,n=s.default.http[0];e[i]||(e[i]=this.createDefaultNamespace(i));let a=`${i}:${r}`,o=e[i];switch(o.chains.push(a),a){case en.caipNetworkId:o.chains.push(en.deprecatedCaipNetworkId);break;case ea.caipNetworkId:o.chains.push(ea.deprecatedCaipNetworkId)}return o?.rpcMap&&n&&(o.rpcMap[r]=n),e},{});return this.applyNamespaceOverrides(r,t)},resolveReownName:async e=>{let t=await C.resolveName(e),r=Object.values(t?.addresses)||[];return r[0]?.address||!1},getChainsFromNamespaces:(e={})=>Object.values(e).flatMap(e=>Array.from(new Set([...e.chains||[],...e.accounts.map(e=>{let[t,r]=e.split(":");return`${t}:${r}`})]))),isSessionEventData:e=>"object"==typeof e&&null!==e&&"id"in e&&"topic"in e&&"params"in e&&"object"==typeof e.params&&null!==e.params&&"chainId"in e.params&&"event"in e.params&&"object"==typeof e.params.event&&null!==e.params.event,isOriginAllowed(e,t,r){for(let i of[...t,...r])if(i.includes("*")){let t=i.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&");if(RegExp(`^${t.replace(/\\\*/gu,".*")}$`,"u").test(e))return!0}else try{if(new URL(i).origin===e)return!0}catch(t){if(i===e)return!0}return!1}};class el{constructor({provider:e,namespace:t}){this.id=c.b.CONNECTOR_ID.WALLET_CONNECT,this.name=V.ConnectorNamesMap[c.b.CONNECTOR_ID.WALLET_CONNECT],this.type="WALLET_CONNECT",this.imageId=V.ConnectorImageIds[c.b.CONNECTOR_ID.WALLET_CONNECT],this.getCaipNetworks=d.R.getCaipNetworks.bind(d.R),this.caipNetworks=this.getCaipNetworks(),this.provider=e,this.chain=t}get chains(){return this.getCaipNetworks()}async connectWalletConnect(){if(!await this.authenticate()){let e=this.getCaipNetworks(),t=a.OptionsController.state.universalProviderConfigOverride,r=ec.createNamespaces(e,t);await this.provider.connect({optionalNamespaces:r})}return{clientId:await this.provider.client.core.crypto.getClientId(),session:this.provider.session}}async disconnect(){await this.provider.disconnect()}async authenticate(){let e=this.chains.map(e=>e.caipNetworkId);return U.w.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:eh})}}let eh=["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"];class ed{constructor(e){this.availableConnectors=[],this.eventListeners=new Map,this.getCaipNetworks=e=>d.R.getCaipNetworks(e),e&&this.construct(e)}construct(e){this.projectId=e.projectId,this.namespace=e.namespace,this.adapterType=e.adapterType}get connectors(){return this.availableConnectors}get networks(){return this.getCaipNetworks(this.namespace)}setAuthProvider(e){this.addConnector({id:c.b.CONNECTOR_ID.AUTH,type:"AUTH",name:c.b.CONNECTOR_NAMES.AUTH,provider:e,imageId:V.ConnectorImageIds[c.b.CONNECTOR_ID.AUTH],chain:this.namespace,chains:[]})}addConnector(...e){let t=new Set;this.availableConnectors=[...e,...this.availableConnectors].filter(e=>!t.has(e.id)&&(t.add(e.id),!0)),this.emit("connectors",this.availableConnectors)}setStatus(e,t){p.N.setStatus(e,t)}on(e,t){this.eventListeners.has(e)||this.eventListeners.set(e,new Set),this.eventListeners.get(e)?.add(t)}off(e,t){let r=this.eventListeners.get(e);r&&r.delete(t)}removeAllEventListeners(){this.eventListeners.forEach(e=>{e.clear()})}emit(e,t){let r=this.eventListeners.get(e);r&&r.forEach(e=>e(t))}async connectWalletConnect(e){let t=this.getWalletConnectConnector();return{clientId:(await t.connectWalletConnect()).clientId}}async switchNetwork(e){let{caipNetwork:t,providerType:r}=e;if(!e.provider)return;let i="provider"in e.provider?e.provider.provider:e.provider;if("WALLET_CONNECT"===r){i.setDefaultChain(t.caipNetworkId);return}if(i&&"AUTH"===r){let e=p.N.state.preferredAccountTypes?.[t.chainNamespace];await i.switchNetwork(t.caipNetworkId);let r=await i.getUser({chainId:t.caipNetworkId,preferredAccountType:e});this.emit("switchNetwork",r)}}getWalletConnectConnector(){let e=this.connectors.find(e=>e instanceof el);if(!e)throw Error("WalletConnectConnector not found");return e}}class eu extends ed{setUniversalProvider(e){this.addConnector(new el({provider:e,caipNetworks:this.getCaipNetworks(),namespace:this.namespace}))}async connect(e){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:Number(e.chainId),provider:this.provider,address:""})}async disconnect(){try{let e=this.getWalletConnectConnector();await e.disconnect()}catch(e){console.warn("UniversalAdapter:disconnect - error",e)}}async getAccounts({namespace:e}){let t=this.provider;return Promise.resolve({accounts:(t?.session?.namespaces?.[e]?.accounts?.map(e=>{let[,,t]=e.split(":");return t}).filter((e,t,r)=>r.indexOf(e)===t)||[]).map(t=>n.j.createAccount(e,t,"bip122"===e?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){if(!(e.caipNetwork&&N.bq.BALANCE_SUPPORTED_CHAINS.includes(e.caipNetwork?.chainNamespace))||e.caipNetwork?.testnet)return{balance:"0.00",symbol:e.caipNetwork?.nativeCurrency.symbol||""};if(p.N.state.balanceLoading&&e.chainId===d.R.state.activeCaipNetwork?.id)return{balance:p.N.state.balance||"0.00",symbol:p.N.state.balanceSymbol||""};let t=(await p.N.fetchTokenBalance()).find(t=>t.chainId===`${e.caipNetwork?.chainNamespace}:${e.chainId}`&&t.symbol===e.caipNetwork?.nativeCurrency.symbol);return{balance:t?.quantity.numeric||"0.00",symbol:t?.symbol||e.caipNetwork?.nativeCurrency.symbol||""}}async signMessage(e){let{provider:t,message:r,address:i}=e;if(!t)throw Error("UniversalAdapter:signMessage - provider is undefined");return{signature:d.R.state.activeCaipNetwork?.chainNamespace===c.b.CHAIN.SOLANA?(await t.request({method:"solana_signMessage",params:{message:et.Z.encode(new TextEncoder().encode(r)),pubkey:i}},d.R.state.activeCaipNetwork?.caipNetworkId)).signature:await t.request({method:"personal_sign",params:[r,i]},d.R.state.activeCaipNetwork?.caipNetworkId)}}async estimateGas(){return Promise.resolve({gas:BigInt(0)})}async sendTransaction(){return Promise.resolve({hash:""})}walletGetAssets(e){return Promise.resolve({})}async writeContract(){return Promise.resolve({hash:""})}parseUnits(){return 0n}formatUnits(){return"0"}async getCapabilities(){return Promise.resolve({})}async grantPermissions(){return Promise.resolve({})}async revokePermissions(){return Promise.resolve("0x")}async syncConnection(){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:1,provider:this.provider,address:""})}async switchNetwork(e){let{caipNetwork:t}=e,r=this.getWalletConnectConnector();if(t.chainNamespace===c.b.CHAIN.EVM)try{await r.provider?.request({method:"wallet_switchEthereumChain",params:[{chainId:er.NC(t.id)}]})}catch(e){if(e.code===ei.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||e.code===ei.ERROR_INVALID_CHAIN_ID||e.code===ei.ERROR_CODE_DEFAULT||e?.data?.originalError?.code===ei.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await r.provider?.request({method:"wallet_addEthereumChain",params:[{chainId:er.NC(t.id),rpcUrls:[t?.rpcUrls.chainDefault?.http],chainName:t.name,nativeCurrency:t.nativeCurrency,blockExplorerUrls:[t.blockExplorers?.default.url]}]})}catch(e){throw Error("Chain is not supported")}}r.provider.setDefaultChain(t.caipNetworkId)}getWalletConnectProvider(){let e=this.connectors.find(e=>"WALLET_CONNECT"===e.type);return e?.provider}}let ep=["email","socials","swaps","onramp","activity","reownBranding"],eg={email:{apiFeatureName:"social_login",localFeatureName:"email",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.includes("email")},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.email:!!e},socials:{apiFeatureName:"social_login",localFeatureName:"socials",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t.filter(e=>"email"!==e)},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.socials:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.socials:e},swaps:{apiFeatureName:"swap",localFeatureName:"swaps",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.swaps:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.swaps:e},onramp:{apiFeatureName:"onramp",localFeatureName:"onramp",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>{if(!e?.config)return!1;let t=e.config;return!!e.isEnabled&&t.length>0&&t},processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.onramp:"boolean"==typeof e?!!e&&N.bq.DEFAULT_REMOTE_FEATURES.onramp:e},activity:{apiFeatureName:"activity",localFeatureName:"history",returnType:!1,isLegacy:!0,isAvailableOnBasic:!1,processApi:e=>!!e.isEnabled,processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.activity:!!e},reownBranding:{apiFeatureName:"reown_branding",localFeatureName:"reownBranding",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:e=>!!e.isEnabled,processFallback:e=>void 0===e?N.bq.DEFAULT_REMOTE_FEATURES.reownBranding:!!e}},ef={localSettingsOverridden:new Set,getApiConfig:(e,t)=>t?.find(t=>t.id===e),addWarning(e,t){if(void 0!==e){let e=eg[t],r=e.isLegacy?`"features.${e.localFeatureName}" (now "${t}")`:`"features.${t}"`;this.localSettingsOverridden.add(r)}},processFeature(e,t,r,i,s){let n=eg[e],a=t[n.localFeatureName];if(s&&!n.isAvailableOnBasic)return!1;if(i){let t=this.getApiConfig(n.apiFeatureName,r);return t?.config===null?this.processFallbackFeature(e,a):!!t?.config&&(void 0!==a&&this.addWarning(a,e),this.processApiFeature(e,t))}return this.processFallbackFeature(e,a)},processApiFeature:(e,t)=>eg[e].processApi(t),processFallbackFeature:(e,t)=>eg[e].processFallback(t),async fetchRemoteFeatures(e){let t=e.basic??!1,r=e.features||{};this.localSettingsOverridden.clear();let i=null,s=!1;try{s=null!=(i=await I.ApiController.fetchProjectConfig())}catch(e){console.warn("[Reown Config] Failed to fetch remote project configuration. Using local/default values.",e)}let n=s&&!t?N.bq.DEFAULT_REMOTE_FEATURES:N.bq.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(let e of ep){let a=this.processFeature(e,r,i,s,t);Object.assign(n,{[e]:a})}}catch(e){return console.warn("[Reown Config] Failed to process the configuration from Cloud. Using default values.",e),N.bq.DEFAULT_REMOTE_FEATURES}if(s&&this.localSettingsOverridden.size>0){let e=`Your local configuration for ${Array.from(this.localSettingsOverridden).join(", ")} was ignored because a remote configuration was successfully fetched. Please manage these features via your project dashboard on dashboard.reown.com.`;T.AlertController.open({shortMessage:"Local configuration ignored",longMessage:`[Reown Config Notice] ${e}`},"warning")}return n}};class em{constructor(e){this.chainNamespaces=[],this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(e,t)=>{if(e){let r=d.R.getNetworkData(e)?.requestedCaipNetworks?.find(e=>e.id===t);if(r)return r;let i=d.R.getNetworkData(e)?.caipNetwork;if(i)return i;let s=d.R.getRequestedCaipNetworks(e);return s.filter(t=>t.chainNamespace===e)?.[0]}return d.R.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{let e=this.getCaipNetwork();if(e)return e.id},this.getCaipNetworks=e=>d.R.getCaipNetworks(e),this.getActiveChainNamespace=()=>d.R.state.activeChain,this.setRequestedCaipNetworks=(e,t)=>{d.R.setRequestedCaipNetworks(e,t)},this.getApprovedCaipNetworkIds=()=>d.R.getAllApprovedCaipNetworkIds(),this.getCaipAddress=e=>d.R.state.activeChain!==e&&e?d.R.getAccountProp("caipAddress",e):d.R.state.activeCaipAddress,this.setClientId=e=>{u.L.setClientId(e)},this.getProvider=e=>ee.getProvider(e),this.getProviderType=e=>ee.getProviderId(e),this.getPreferredAccountType=e=>p.N.state.preferredAccountTypes?.[e],this.setCaipAddress=(e,t)=>{p.N.setCaipAddress(e,t),e&&a.OptionsController.state.enableEmbedded&&this.close()},this.setBalance=(e,t,r)=>{p.N.setBalance(e,t,r)},this.setProfileName=(e,t)=>{p.N.setProfileName(e,t)},this.setProfileImage=(e,t)=>{p.N.setProfileImage(e,t)},this.setUser=(e,t)=>{p.N.setUser(e,t)},this.resetAccount=e=>{p.N.resetAccount(e)},this.setCaipNetwork=e=>{d.R.setActiveCaipNetwork(e)},this.setCaipNetworkOfNamespace=(e,t)=>{d.R.setChainNetworkData(t,{caipNetwork:e})},this.setAllAccounts=(e,t)=>{p.N.setAllAccounts(e,t),a.OptionsController.setHasMultipleAddresses(e?.length>1)},this.setStatus=(e,t)=>{p.N.setStatus(e,t),i.ConnectorController.isConnected()?g.M.setConnectionStatus("connected"):g.M.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=e=>d.R.getAccountProp("address",e),this.setConnectors=e=>{let t=[...i.ConnectorController.state.allConnectors,...e];i.ConnectorController.setConnectors(t)},this.setConnections=(e,t)=>{s.ConnectionController.setConnections(e,t)},this.fetchIdentity=e=>u.L.fetchIdentity(e),this.getReownName=e=>C.getNamesForAddress(e),this.getConnectors=()=>i.ConnectorController.getConnectors(),this.getConnectorImage=e=>E.f.getConnectorImage(e),this.setConnectedWalletInfo=(e,t)=>{let r=ee.getProviderId(t),i=e?{...e,type:r}:void 0;p.N.setConnectedWalletInfo(i,t)},this.getIsConnectedState=()=>!!d.R.state.activeCaipAddress,this.addAddressLabel=(e,t,r)=>{p.N.addAddressLabel(e,t,r)},this.removeAddressLabel=(e,t)=>{p.N.removeAddressLabel(e,t)},this.getAddress=e=>d.R.state.activeChain!==e&&e?d.R.getAccountProp("address",e):p.N.state.address,this.setApprovedCaipNetworksData=e=>d.R.setApprovedCaipNetworksData(e),this.resetNetwork=e=>{d.R.resetNetwork(e)},this.addConnector=e=>{i.ConnectorController.addConnector(e)},this.resetWcConnection=()=>{s.ConnectionController.resetWcConnection()},this.setAddressExplorerUrl=(e,t)=>{p.N.setAddressExplorerUrl(e,t)},this.setSmartAccountDeployed=(e,t)=>{p.N.setSmartAccountDeployed(e,t)},this.setSmartAccountEnabledNetworks=(e,t)=>{d.R.setSmartAccountEnabledNetworks(e,t)},this.setPreferredAccountType=(e,t)=>{p.N.setPreferredAccountType(e,t)},this.setEIP6963Enabled=e=>{a.OptionsController.setEIP6963Enabled(e)},this.handleUnsafeRPCRequest=()=>{this.isOpen()?this.isTransactionStackEmpty()||this.redirect("ApproveTransaction"):this.open({view:"ApproveTransaction"})},this.options=e,this.version=e.sdkVersion,this.caipNetworks=this.extendCaipNetworks(e),this.chainNamespaces=this.getChainNamespacesSet(e.adapters,this.caipNetworks),this.defaultCaipNetwork=this.extendDefaultCaipNetwork(e),this.chainAdapters=this.createAdapters(e.adapters),this.readyPromise=this.initialize(e)}getChainNamespacesSet(e,t){let r=e?.map(e=>e.namespace).filter(e=>!!e);return r?.length?[...new Set(r)]:[...new Set(t?.map(e=>e.chainNamespace))]}async initialize(e){this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),await this.syncExistingConnection(),this.remoteFeatures=await ef.fetchRemoteFeatures(e),a.OptionsController.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&P.setOnrampProviders(this.remoteFeatures.onramp),(a.OptionsController.state.remoteFeatures?.email||Array.isArray(a.OptionsController.state.remoteFeatures?.socials)&&a.OptionsController.state.remoteFeatures?.socials.length>0)&&await this.checkAllowedOrigins()}async checkAllowedOrigins(){let e=await I.ApiController.fetchAllowedOrigins();if(e&&n.j.isClient()){let t=window.location.origin;ec.isOriginAllowed(t,e,ei.DEFAULT_ALLOWED_ANCESTORS)||T.AlertController.open(B.ALERT_ERRORS.INVALID_APP_CONFIGURATION,"error")}else T.AlertController.open(B.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error")}sendInitializeEvent(e){let{...t}=e;delete t.adapters,delete t.universalProvider,R.X.sendEvent({type:"track",event:"INITIALIZE",properties:{...t,networks:e.networks.map(e=>e.id),siweConfig:{options:e.siweConfig?.options||{}}}})}initControllers(e){this.initializeOptionsController(e),this.initializeChainController(e),this.initializeThemeController(e),this.initializeConnectionController(e),this.initializeConnectorController()}initializeThemeController(e){e.themeMode&&k.ThemeController.setThemeMode(e.themeMode),e.themeVariables&&k.ThemeController.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient||!this.networkControllerClient)throw Error("ConnectionControllerClient and NetworkControllerClient must be set");d.R.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient,networkControllerClient:this.networkControllerClient});let t=this.getDefaultNetwork();t&&d.R.setActiveCaipNetwork(t)}initializeConnectionController(e){s.ConnectionController.setWcBasic(e.basic??!1)}initializeConnectorController(){i.ConnectorController.initialize(this.chainNamespaces)}initializeProjectSettings(e){a.OptionsController.setProjectId(e.projectId),a.OptionsController.setSdkVersion(e.sdkVersion)}initializeOptionsController(e){a.OptionsController.setDebug(!1!==e.debug),a.OptionsController.setEnableWalletConnect(!1!==e.enableWalletConnect),a.OptionsController.setEnableWalletGuide(!1!==e.enableWalletGuide),a.OptionsController.setEnableWallets(!1!==e.enableWallets),a.OptionsController.setEIP6963Enabled(!1!==e.enableEIP6963),a.OptionsController.setEnableNetworkSwitch(!1!==e.enableNetworkSwitch),a.OptionsController.setEnableAuthLogger(!1!==e.enableAuthLogger),a.OptionsController.setCustomRpcUrls(e.customRpcUrls),a.OptionsController.setEnableEmbedded(e.enableEmbedded),a.OptionsController.setAllWallets(e.allWallets),a.OptionsController.setIncludeWalletIds(e.includeWalletIds),a.OptionsController.setExcludeWalletIds(e.excludeWalletIds),a.OptionsController.setFeaturedWalletIds(e.featuredWalletIds),a.OptionsController.setTokens(e.tokens),a.OptionsController.setTermsConditionsUrl(e.termsConditionsUrl),a.OptionsController.setPrivacyPolicyUrl(e.privacyPolicyUrl),a.OptionsController.setCustomWallets(e.customWallets),a.OptionsController.setFeatures(e.features),a.OptionsController.setAllowUnsupportedChain(e.allowUnsupportedChain),a.OptionsController.setUniversalProviderConfigOverride(e.universalProviderConfigOverride),a.OptionsController.setPreferUniversalLinks(e.experimental_preferUniversalLinks),a.OptionsController.setDefaultAccountTypes(e.defaultAccountTypes);let t=g.M.getPreferredAccountTypes()||{},r={...a.OptionsController.state.defaultAccountTypes,...t};p.N.setPreferredAccountTypes(r);let i=this.getDefaultMetaData();if(!e.metadata&&i&&(e.metadata=i),a.OptionsController.setMetadata(e.metadata),a.OptionsController.setDisableAppend(e.disableAppend),a.OptionsController.setEnableEmbedded(e.enableEmbedded),a.OptionsController.setSIWX(e.siwx),!e.projectId){T.AlertController.open(B.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error");return}if(e.adapters?.find(e=>e.namespace===c.b.CHAIN.EVM)&&e.siweConfig){if(e.siwx)throw Error("Cannot set both `siweConfig` and `siwx` options");a.OptionsController.setSIWX(e.siweConfig.mapToSIWX())}}getDefaultMetaData(){return n.j.isClient()?{name:document.getElementsByTagName("title")?.[0]?.textContent||"",description:document.querySelector('meta[property="og:description"]')?.content||"",url:window.location.origin,icons:[document.querySelector('link[rel~="icon"]')?.href||""]}:null}setUnsupportedNetwork(e){let t=this.getActiveChainNamespace();if(t){let r=J.getUnsupportedNetwork(`${t}:${e}`);d.R.setActiveCaipNetwork(r)}}getDefaultNetwork(){return J.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,t){return J.extendCaipNetwork(e,{customNetworkImageUrls:t.chainImages,projectId:t.projectId})}extendCaipNetworks(e){return J.extendCaipNetworks(e.networks,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId})}extendDefaultCaipNetwork(e){let t=e.networks.find(t=>t.id===e.defaultNetwork?.id);return t?J.extendCaipNetwork(t,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId}):void 0}async disconnectNamespace(e){try{let t=this.getAdapter(e),r=ee.getProvider(e),s=ee.getProviderId(e),{caipAddress:n}=d.R.getAccountData(e)||{};this.setLoading(!0,e),n&&t?.disconnect&&await t.disconnect({provider:r,providerType:s}),g.M.removeConnectedNamespace(e),ee.resetChain(e),this.setUser(void 0,e),this.setStatus("disconnected",e),this.setConnectedWalletInfo(void 0,e),i.ConnectorController.removeConnectorId(e),d.R.resetAccount(e),d.R.resetNetwork(e),this.setLoading(!1,e)}catch(t){throw this.setLoading(!1,e),Error(`Failed to disconnect chain ${e}: ${t.message}`)}}createClients(){this.connectionControllerClient={connectWalletConnect:async()=>{let e=d.R.state.activeChain,t=this.getAdapter(e),r=this.getCaipNetwork(e)?.id;if(!t)throw Error("Adapter not found");let s=await t.connectWalletConnect(r);this.close(),this.setClientId(s?.clientId||null),g.M.setConnectedNamespaces([...d.R.state.chains.keys()]),this.chainNamespaces.forEach(e=>{i.ConnectorController.setConnectorId(W.b.CONNECTOR_TYPE_WALLET_CONNECT,e)}),await this.syncWalletConnectAccount()},connectExternal:async({id:e,info:t,type:r,provider:i,chain:s,caipNetwork:n,socialUri:a})=>{let o=d.R.state.activeChain,c=s||o,l=this.getAdapter(c);if(s&&s!==o&&!n){let e=this.getCaipNetworks().find(e=>e.chainNamespace===s);e&&this.setCaipNetwork(e)}if(!l)throw Error("Adapter not found");let h=this.getCaipNetwork(c),u=await l.connect({id:e,info:t,type:r,provider:i,socialUri:a,chainId:n?.id||h?.id,rpcUrl:n?.rpcUrls?.default?.http?.[0]||h?.rpcUrls?.default?.http?.[0]});if(!u)return;g.M.addConnectedNamespace(c),this.syncProvider({...u,chainNamespace:c});let f=p.N.state.allAccounts,{accounts:m}=f?.length>0?{accounts:[...f]}:await l.getAccounts({namespace:c,id:e});this.setAllAccounts(m,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c)},reconnectExternal:async({id:e,info:t,type:r,provider:i})=>{let s=d.R.state.activeChain,n=this.getAdapter(s);n?.reconnect&&(await n?.reconnect({id:e,info:t,type:r,provider:i,chainId:this.getCaipNetwork()?.id}),g.M.addConnectedNamespace(s),this.syncConnectedWalletInfo(s))},disconnect:async e=>{let t=function(e){let t=Array.from(d.R.state.chains.keys()),r=[];return e?(r.push([e,d.R.state.chains.get(e)]),L(e,c.b.CONNECTOR_ID.WALLET_CONNECT)?t.forEach(t=>{t!==e&&L(t,c.b.CONNECTOR_ID.WALLET_CONNECT)&&r.push([t,d.R.state.chains.get(t)])}):L(e,c.b.CONNECTOR_ID.AUTH)&&t.forEach(t=>{t!==e&&L(t,c.b.CONNECTOR_ID.AUTH)&&r.push([t,d.R.state.chains.get(t)])})):r=Array.from(d.R.state.chains.entries()),r}(e);try{let r=await Promise.allSettled(t.map(async([e])=>this.disconnectNamespace(e)));x.S.resetSend(),s.ConnectionController.resetWcConnection(),await U.w.clearSessions(),i.ConnectorController.setFilterByNamespace(void 0);let n=r.filter(e=>"rejected"===e.status);if(n.length>0)throw Error(n.map(e=>e.reason.message).join(", "));g.M.deleteConnectedSocialProvider(),R.X.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:e||"all"}})}catch(e){throw Error(`Failed to disconnect chains: ${e.message}`)}},checkInstalled:e=>e?e.some(e=>!!window.ethereum?.[String(e)]):!!window.ethereum,signMessage:async e=>{let t=this.getAdapter(d.R.state.activeChain),r=await t?.signMessage({message:e,address:p.N.state.address,provider:ee.getProvider(d.R.state.activeChain)});return r?.signature||""},sendTransaction:async e=>{let t=e.chainNamespace;if(N.bq.SEND_SUPPORTED_NAMESPACES.includes(t)){let r=this.getAdapter(d.R.state.activeChain),i=ee.getProvider(t),s=await r?.sendTransaction({...e,caipNetwork:this.getCaipNetwork(),provider:i});return s?.hash||""}return""},estimateGas:async e=>{if(e.chainNamespace===c.b.CHAIN.EVM){let t=this.getAdapter(d.R.state.activeChain),r=ee.getProvider(d.R.state.activeChain),i=this.getCaipNetwork();if(!i)throw Error("CaipNetwork is undefined");let s=await t?.estimateGas({...e,provider:r,caipNetwork:i});return s?.gas||0n}return 0n},getEnsAvatar:async()=>(await this.syncIdentity({address:p.N.state.address,chainId:Number(this.getCaipNetwork()?.id),chainNamespace:d.R.state.activeChain}),p.N.state.profileImage||!1),getEnsAddress:async e=>await ec.resolveReownName(e),writeContract:async e=>{let t=this.getAdapter(d.R.state.activeChain),r=this.getCaipNetwork(),i=this.getCaipAddress(),s=ee.getProvider(d.R.state.activeChain);if(!r||!i)throw Error("CaipNetwork or CaipAddress is undefined");let n=await t?.writeContract({...e,caipNetwork:r,provider:s,caipAddress:i});return n?.hash},parseUnits:(e,t)=>{let r=this.getAdapter(d.R.state.activeChain);return r?.parseUnits({value:e,decimals:t})??0n},formatUnits:(e,t)=>{let r=this.getAdapter(d.R.state.activeChain);return r?.formatUnits({value:e,decimals:t})??"0"},getCapabilities:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.getCapabilities(e)},grantPermissions:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.grantPermissions(e)},revokePermissions:async e=>{let t=this.getAdapter(d.R.state.activeChain);return t?.revokePermissions?await t.revokePermissions(e):"0x"},walletGetAssets:async e=>{let t=this.getAdapter(d.R.state.activeChain);return await t?.walletGetAssets(e)??{}},updateBalance:e=>{let t=this.getCaipNetwork(e);t&&p.N.state.address&&this.updateNativeBalance(p.N.state.address,t?.id,e)}},this.networkControllerClient={switchCaipNetwork:async e=>await this.switchCaipNetwork(e),getApprovedCaipNetworksData:async()=>this.getApprovedCaipNetworksData()},s.ConnectionController.setClient(this.connectionControllerClient)}getApprovedCaipNetworksData(){if(ee.getProviderId(d.R.state.activeChain)===W.b.CONNECTOR_TYPE_WALLET_CONNECT){let e=this.universalProvider?.session?.namespaces;return{supportsAllNetworks:this.universalProvider?.session?.peer?.metadata.name==="MetaMask Wallet",approvedCaipNetworkIds:this.getChainsFromNamespaces(e)}}return{supportsAllNetworks:!0,approvedCaipNetworkIds:[]}}async switchCaipNetwork(e){if(!e)return;let t=e.chainNamespace;if(this.getAddressByChainNamespace(e.chainNamespace)){let r=ee.getProvider(t),i=ee.getProviderId(t);if(e.chainNamespace===d.R.state.activeChain){let s=this.getAdapter(t);await s?.switchNetwork({caipNetwork:e,provider:r,providerType:i})}else if(this.setCaipNetwork(e),i===W.b.CONNECTOR_TYPE_WALLET_CONNECT)this.syncWalletConnectAccount();else{let r=this.getAddressByChainNamespace(t);r&&this.syncAccount({address:r,chainId:e.id,chainNamespace:t})}}else this.setCaipNetwork(e)}getChainsFromNamespaces(e={}){return Object.values(e).flatMap(e=>Array.from(new Set([...e.chains||[],...e.accounts.map(e=>{let{chainId:t,chainNamespace:r}=l.parseCaipAddress(e);return`${r}:${t}`})])))}createAdapters(e){return this.createClients(),this.chainNamespaces.reduce((t,r)=>{let i=e?.find(e=>e.namespace===r);return i?(i.construct({namespace:r,projectId:this.options?.projectId,networks:this.getCaipNetworks()}),t[r]=i):t[r]=new eu({namespace:r,networks:this.getCaipNetworks()}),t},{})}async initChainAdapter(e){this.onConnectors(e),this.listenAdapter(e),await this.chainAdapters?.[e].syncConnectors(this.options,this),await this.createUniversalProviderForAdapter(e)}async initChainAdapters(){await Promise.all(this.chainNamespaces.map(async e=>{await this.initChainAdapter(e)}))}onConnectors(e){let t=this.getAdapter(e);t?.on("connectors",this.setConnectors.bind(this))}listenAdapter(e){let t=this.getAdapter(e);if(!t)return;let r=g.M.getConnectionStatus();"connected"===r?this.setStatus("connecting",e):("disconnected"===r&&g.M.clearAddressCache(),this.setStatus(r,e)),t.on("switchNetwork",({address:t,chainId:r})=>{let i=this.getCaipNetworks().find(e=>e.id===r||e.caipNetworkId===r),s=d.R.state.activeChain===e,n=d.R.getAccountProp("address",e);if(i){let r=s&&t?t:n;r&&this.syncAccount({address:r,chainId:i.id,chainNamespace:e})}else this.setUnsupportedNetwork(r)}),t.on("disconnect",this.disconnect.bind(this,e)),t.on("connections",t=>{this.setConnections(t,e)}),t.on("pendingTransactions",()=>{let e=p.N.state.address,t=d.R.state.activeCaipNetwork;e&&t?.id&&this.updateNativeBalance(e,t.id,t.chainNamespace)}),t.on("accountChanged",({address:t,chainId:r})=>{let i=d.R.state.activeChain===e;i&&r?this.syncAccount({address:t,chainId:r,chainNamespace:e}):i&&d.R.state.activeCaipNetwork?.id?this.syncAccount({address:t,chainId:d.R.state.activeCaipNetwork?.id,chainNamespace:e}):this.syncAccountInfo(t,r,e),this.syncAllAccounts(e)})}async createUniversalProviderForAdapter(e){await this.getUniversalProvider(),this.universalProvider&&this.chainAdapters?.[e]?.setUniversalProvider?.(this.universalProvider)}async syncExistingConnection(){await Promise.allSettled(this.chainNamespaces.map(e=>this.syncNamespaceConnection(e)))}async syncNamespaceConnection(e){try{e===c.b.CHAIN.EVM&&n.j.isSafeApp()&&i.ConnectorController.setConnectorId(c.b.CONNECTOR_ID.SAFE,e);let t=i.ConnectorController.getConnectorId(e);switch(this.setStatus("connecting",e),t){case c.b.CONNECTOR_ID.WALLET_CONNECT:await this.syncWalletConnectAccount();break;case c.b.CONNECTOR_ID.AUTH:break;default:await this.syncAdapterConnection(e)}}catch(t){console.warn("AppKit couldn't sync existing connection",t),this.setStatus("disconnected",e)}}async syncAdapterConnection(e){let t=this.getAdapter(e),r=i.ConnectorController.getConnectorId(e),s=this.getCaipNetwork(e),a=i.ConnectorController.getConnectors(e).find(e=>e.id===r);try{if(!t||!a)throw Error(`Adapter or connector not found for namespace ${e}`);if(!s?.id)throw Error("CaipNetwork not found");let r=await t?.syncConnection({namespace:e,id:a.id,chainId:s.id,rpcUrl:s?.rpcUrls?.default?.http?.[0]});if(r){let i=await t?.getAccounts({namespace:e,id:a.id});i&&i.accounts.length>0?this.setAllAccounts(i.accounts,e):this.setAllAccounts([n.j.createAccount(e,r.address,"eoa")],e),this.syncProvider({...r,chainNamespace:e}),await this.syncAccount({...r,chainNamespace:e}),this.setStatus("connected",e)}else this.setStatus("disconnected",e)}catch(t){this.setStatus("disconnected",e)}}async syncWalletConnectAccount(){let e=this.chainNamespaces.map(async e=>{let t=this.getAdapter(e),r=this.universalProvider?.session?.namespaces?.[e]?.accounts||[],s=d.R.state.activeCaipNetwork?.id,n=r.find(e=>{let{chainId:t}=l.parseCaipAddress(e);return t===s?.toString()})||r[0];if(n){let r=l.validateCaipAddress(n),{chainId:s,address:a}=l.parseCaipAddress(r);if(ee.setProviderId(e,W.b.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&d.R.state.activeCaipNetwork&&t?.namespace!==c.b.CHAIN.EVM){let r=t?.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:d.R.state.activeCaipNetwork});ee.setProvider(e,r)}else ee.setProvider(e,this.universalProvider);i.ConnectorController.setConnectorId(c.b.CONNECTOR_ID.WALLET_CONNECT,e),g.M.addConnectedNamespace(e),this.syncWalletConnectAccounts(e),await this.syncAccount({address:a,chainId:s,chainNamespace:e})}else this.setStatus("disconnected",e);this.syncConnectedWalletInfo(e),await d.R.setApprovedCaipNetworksData(e)});await Promise.all(e)}syncWalletConnectAccounts(e){let t=this.universalProvider?.session?.namespaces?.[e]?.accounts?.map(e=>{let{address:t}=l.parseCaipAddress(e);return t}).filter((e,t,r)=>r.indexOf(e)===t);t&&this.setAllAccounts(t.map(t=>n.j.createAccount(e,t,"bip122"===e?"payment":"eoa")),e)}syncProvider({type:e,provider:t,id:r,chainNamespace:s}){ee.setProviderId(s,e),ee.setProvider(s,t),i.ConnectorController.setConnectorId(r,s)}async syncAllAccounts(e){let t=i.ConnectorController.getConnectorId(e);if(!t)return;let r=this.getAdapter(e),s=await r?.getAccounts({namespace:e,id:t});s&&s.accounts.length>0&&this.setAllAccounts(s.accounts,e)}async syncAccount(e){let t=e.chainNamespace===d.R.state.activeChain,r=d.R.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:i,chainId:s,chainNamespace:n}=e,{chainId:o}=g.M.getActiveNetworkProps(),h=s||o,u=d.R.state.activeCaipNetwork?.name===c.b.UNSUPPORTED_NETWORK_NAME,f=d.R.getNetworkProp("supportsAllNetworks",n);if(this.setStatus("connected",n),(!u||f)&&h){let e=this.getCaipNetworks().find(e=>e.id.toString()===h.toString()),s=this.getCaipNetworks().find(e=>e.chainNamespace===n);if(!f&&!e&&!s){let t=this.getApprovedCaipNetworkIds()||[],r=t.find(e=>l.parseCaipNetworkId(e)?.chainId===h.toString()),i=t.find(e=>l.parseCaipNetworkId(e)?.chainNamespace===n);e=this.getCaipNetworks().find(e=>e.caipNetworkId===r),s=this.getCaipNetworks().find(e=>e.caipNetworkId===i||"deprecatedCaipNetworkId"in e&&e.deprecatedCaipNetworkId===i)}let o=e||s;o?.chainNamespace===d.R.state.activeChain?a.OptionsController.state.enableNetworkSwitch&&!a.OptionsController.state.allowUnsupportedChain&&d.R.state.activeCaipNetwork?.name===c.b.UNSUPPORTED_NETWORK_NAME?d.R.showUnsupportedChainUI():this.setCaipNetwork(o):!t&&r&&this.setCaipNetworkOfNamespace(r,n),this.syncConnectedWalletInfo(n),G.g.isLowerCaseMatch(i,p.N.state.address)||this.syncAccountInfo(i,o?.id,n),t?await this.syncBalance({address:i,chainId:o?.id,chainNamespace:n}):await this.syncBalance({address:i,chainId:r?.id,chainNamespace:n})}}async syncAccountInfo(e,t,r){let i=this.getCaipAddress(r),s=t||i?.split(":")[1];if(!s)return;let n=`${r}:${s}:${e}`;this.setCaipAddress(n,r),await this.syncIdentity({address:e,chainId:s,chainNamespace:r})}async syncReownName(e,t){try{let r=await this.getReownName(e);if(r[0]){let e=r[0];this.setProfileName(e.name,t)}else this.setProfileName(null,t)}catch{this.setProfileName(null,t)}}syncConnectedWalletInfo(e){let t=i.ConnectorController.getConnectorId(e),r=ee.getProviderId(e);if(r===W.b.CONNECTOR_TYPE_ANNOUNCED||r===W.b.CONNECTOR_TYPE_INJECTED){if(t){let r=this.getConnectors().find(e=>e.id===t);if(r){let{info:t,name:i,imageUrl:s}=r,n=s||this.getConnectorImage(r);this.setConnectedWalletInfo({name:i,icon:n,...t},e)}}}else if(r===W.b.CONNECTOR_TYPE_WALLET_CONNECT){let t=ee.getProvider(e);t?.session&&this.setConnectedWalletInfo({...t.session.peer.metadata,name:t.session.peer.metadata.name,icon:t.session.peer.metadata.icons?.[0]},e)}else if(t&&t===c.b.CONNECTOR_ID.COINBASE){let t=this.getConnectors().find(e=>e.id===c.b.CONNECTOR_ID.COINBASE);this.setConnectedWalletInfo({name:"Coinbase Wallet",icon:this.getConnectorImage(t)},e)}}async syncBalance(e){h.p.getNetworksByNamespace(this.getCaipNetworks(),e.chainNamespace).find(t=>t.id.toString()===e.chainId?.toString())&&e.chainId&&await this.updateNativeBalance(e.address,e.chainId,e.chainNamespace)}async ready(){await this.readyPromise}async updateNativeBalance(e,t,r){let i=this.getAdapter(r),s=d.R.getCaipNetworkByNamespace(r,t);if(i){let n=await i.getBalance({address:e,chainId:t,caipNetwork:s,tokens:this.options.tokens});return this.setBalance(n.balance,n.symbol,r),n}}async initializeUniversalAdapter(){let e=X.createLogger((e,...t)=>{e&&this.handleAlertError(e),console.error(...t)}),t={projectId:this.options?.projectId,metadata:{name:this.options?.metadata?this.options?.metadata.name:"",description:this.options?.metadata?this.options?.metadata.description:"",url:this.options?.metadata?this.options?.metadata.url:"",icons:this.options?.metadata?this.options?.metadata.icons:[""]},logger:e};a.OptionsController.setManualWCControl(!!this.options?.manualWCControl),this.universalProvider=this.options.universalProvider??await o.Z.init(t),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&(this.universalProvider.on("display_uri",e=>{s.ConnectionController.setUri(e)}),this.universalProvider.on("connect",s.ConnectionController.finalizeWcConnection),this.universalProvider.on("disconnect",()=>{this.chainNamespaces.forEach(e=>{this.resetAccount(e)}),s.ConnectionController.resetWcConnection()}),this.universalProvider.on("chainChanged",e=>{let t=this.getCaipNetworks().find(t=>t.id==e),r=this.getCaipNetwork();if(!t){this.setUnsupportedNetwork(e);return}r?.id!==t?.id&&this.setCaipNetwork(t)}),this.universalProvider.on("session_event",e=>{if(ec.isSessionEventData(e)){let{name:t,data:r}=e.params.event;"accountsChanged"===t&&Array.isArray(r)&&n.j.isCaipAddress(r[0])&&this.syncAccount(l.parseCaipAddress(r[0]))}}))}createUniversalProvider(){return!this.universalProviderInitPromise&&n.j.isClient()&&this.options?.projectId&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){R.X.sendEvent({type:"error",event:"INTERNAL_SDK_ERROR",properties:{errorType:"UniversalProviderInitError",errorMessage:e instanceof Error?e.message:"Unknown",uncaught:!1}}),console.error("AppKit:getUniversalProvider - Cannot create provider",e)}return this.universalProvider}handleAlertError(e){let[t,r]=Object.entries(B.UniversalProviderErrors).find(([,{message:t}])=>e.message.includes(t))??[],{message:i,alertErrorKey:s}=r??{};if(t&&i&&!this.reportedAlertErrors[t]){let e=B.ALERT_ERRORS[s];e&&(T.AlertController.open(e,"error"),this.reportedAlertErrors[t]=!0)}}getAdapter(e){if(e)return this.chainAdapters?.[e]}createAdapter(e){if(!e)return;let t=e.namespace;t&&(this.createClients(),e.namespace=t,e.construct({namespace:t,projectId:this.options?.projectId,networks:this.getCaipNetworks()}),this.chainNamespaces.includes(t)||this.chainNamespaces.push(t),this.chainAdapters&&(this.chainAdapters[t]=e))}async open(e){return(await this.injectModalUi(),e?.uri&&s.ConnectionController.setUri(e.uri),e?.arguments&&e?.view==="Swap")?D.I.open({...e,data:{swap:e.arguments}}):D.I.open(e)}async close(){await this.injectModalUi(),D.I.close()}setLoading(e,t){D.I.setLoading(e,t)}async disconnect(e){await s.ConnectionController.disconnect(e)}getSIWX(){return a.OptionsController.state.siwx}getError(){return""}getChainId(){return d.R.state.activeCaipNetwork?.id}async switchNetwork(e){let t=this.getCaipNetworks().find(t=>t.id===e.id);if(!t){T.AlertController.open(B.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await d.R.switchActiveNetwork(t)}getWalletProvider(){return d.R.state.activeChain?ee.state.providers[d.R.state.activeChain]:null}getWalletProviderType(){return ee.getProviderId(d.R.state.activeChain)}subscribeProviders(e){return ee.subscribeProviders(e)}getThemeMode(){return k.ThemeController.state.themeMode}getThemeVariables(){return k.ThemeController.state.themeVariables}setThemeMode(e){k.ThemeController.setThemeMode(e),(0,q.Hs)(k.ThemeController.state.themeMode)}setTermsConditionsUrl(e){a.OptionsController.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){a.OptionsController.setPrivacyPolicyUrl(e)}setThemeVariables(e){k.ThemeController.setThemeVariables(e),(0,q.R)(k.ThemeController.state.themeVariables)}subscribeTheme(e){return k.ThemeController.subscribe(e)}getWalletInfo(){return p.N.state.connectedWalletInfo}getAccount(e){let t=i.ConnectorController.getAuthConnector(e),r=d.R.getAccountData(e),s=d.R.state.activeChain,a=g.M.getConnectedConnectorId(e||s);if(r)return{allAccounts:r.allAccounts,caipAddress:r.caipAddress,address:n.j.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:t&&a===c.b.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:g.M.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:r.preferredAccountTypes?.[e||s],isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,t){let r=()=>{let r=this.getAccount(t);r&&e(r)};t?d.R.subscribeChainProp("accountState",r,t):d.R.subscribe(r),i.ConnectorController.subscribe(r)}subscribeNetwork(e){return d.R.subscribe(({activeCaipNetwork:t})=>{e({caipNetwork:t,chainId:t?.id,caipNetworkId:t?.caipNetworkId})})}subscribeWalletInfo(e){return p.N.subscribeKey("connectedWalletInfo",e)}subscribeShouldUpdateToAddress(e){p.N.subscribeKey("shouldUpdateToAddress",e)}subscribeCaipNetworkChange(e){d.R.subscribeKey("activeCaipNetwork",e)}getState(){return $.I.state}subscribeState(e){return $.I.subscribe(e)}showErrorMessage(e){M.SnackController.showError(e)}showSuccessMessage(e){M.SnackController.showSuccess(e)}getEvent(){return{...R.X.state}}subscribeEvents(e){return R.X.subscribe(e)}replace(e){b.RouterController.replace(e)}redirect(e){b.RouterController.push(e)}popTransactionStack(e){b.RouterController.popTransactionStack(e)}isOpen(){return D.I.state.open}isTransactionStackEmpty(){return 0===b.RouterController.state.transactionStack.length}static getInstance(){return this.instance}updateFeatures(e){a.OptionsController.setFeatures(e)}updateRemoteFeatures(e){a.OptionsController.setRemoteFeatures(e)}updateOptions(e){let t={...a.OptionsController.state||{},...e};a.OptionsController.setOptions(t)}setConnectMethodsOrder(e){a.OptionsController.setConnectMethodsOrder(e)}setWalletFeaturesOrder(e){a.OptionsController.setWalletFeaturesOrder(e)}setCollapseWallets(e){a.OptionsController.setCollapseWallets(e)}setSocialsOrder(e){a.OptionsController.setSocialsOrder(e)}getConnectMethodsOrder(){return j.J.getConnectOrderMethod(a.OptionsController.state.features,i.ConnectorController.getConnectors())}addNetwork(e,t){if(this.chainAdapters&&!this.chainAdapters[e])throw Error(`Adapter for namespace ${e} doesn't exist`);let r=this.extendCaipNetwork(t,this.options);this.getCaipNetworks().find(e=>e.id===r.id)||d.R.addNetwork(r)}removeNetwork(e,t){if(this.chainAdapters&&!this.chainAdapters[e])throw Error(`Adapter for namespace ${e} doesn't exist`);this.getCaipNetworks().find(e=>e.id===t)&&d.R.removeNetwork(e,t)}}let ew=!1;class ey extends em{async open(e){i.ConnectorController.isConnected()||await super.open(e)}async close(){await super.close(),this.options.manualWCControl&&s.ConnectionController.finalizeWcConnection()}async syncIdentity(e){return Promise.resolve()}async syncBalance(e){return Promise.resolve()}async injectModalUi(){if(!ew&&n.j.isClient()){if(await Promise.all([r.e(8125),r.e(4886)]).then(r.bind(r,54886)),await Promise.all([r.e(8125),r.e(5574)]).then(r.bind(r,65574)),!document.querySelector("w3m-modal")){let e=document.createElement("w3m-modal");a.OptionsController.state.disableAppend||a.OptionsController.state.enableEmbedded||document.body.insertAdjacentElement("beforeend",e)}ew=!0}}}function eb(e){return new ey({...e,basic:!0,sdkVersion:"html-core-1.7.8"})}},77934:(e,t,r)=>{"use strict";r.d(t,{Jb:()=>_,Ld:()=>S,YP:()=>A,_$LH:()=>B,dy:()=>I,sY:()=>H});/**
895
895
  * @license
896
896
  * Copyright 2017 Google LLC
897
897
  * SPDX-License-Identifier: BSD-3-Clause