wowok 1.8.2 → 2.1.9

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 (892) hide show
  1. package/README.md +4 -33
  2. package/dist/cjs/bcs/bcs.d.ts +1973 -0
  3. package/dist/cjs/bcs/bcs.js +327 -0
  4. package/dist/cjs/bcs/effects.d.ts +579 -0
  5. package/dist/cjs/bcs/effects.js +231 -0
  6. package/dist/cjs/bcs/index.d.ts +2589 -0
  7. package/dist/cjs/bcs/index.js +79 -0
  8. package/dist/cjs/bcs/pure.d.ts +22 -0
  9. package/dist/cjs/bcs/pure.js +62 -0
  10. package/dist/cjs/bcs/type-tag-serializer.d.ts +7 -0
  11. package/dist/cjs/bcs/type-tag-serializer.js +124 -0
  12. package/dist/cjs/bcs/types.d.ts +114 -0
  13. package/dist/cjs/bcs/types.js +26 -0
  14. package/dist/cjs/client/index.d.ts +5 -0
  15. package/dist/cjs/client/index.js +34 -0
  16. package/dist/cjs/client/network.d.ts +5 -0
  17. package/dist/cjs/client/network.js +43 -0
  18. package/dist/cjs/cryptography/index.d.ts +7 -0
  19. package/dist/cjs/cryptography/index.js +46 -0
  20. package/dist/cjs/cryptography/intent.d.ts +6 -0
  21. package/dist/cjs/cryptography/intent.js +34 -0
  22. package/dist/cjs/cryptography/keypair.d.ts +73 -0
  23. package/dist/cjs/cryptography/keypair.js +125 -0
  24. package/dist/cjs/cryptography/mnemonics.d.ts +27 -0
  25. package/dist/cjs/cryptography/mnemonics.js +50 -0
  26. package/dist/cjs/cryptography/publickey.d.ts +67 -0
  27. package/dist/cjs/cryptography/publickey.js +142 -0
  28. package/dist/cjs/cryptography/signature-scheme.d.ts +24 -0
  29. package/dist/cjs/cryptography/signature-scheme.js +47 -0
  30. package/dist/cjs/cryptography/signature.d.ts +62 -0
  31. package/dist/cjs/cryptography/signature.js +71 -0
  32. package/dist/cjs/experimental/cache.d.ts +12 -0
  33. package/dist/cjs/experimental/client.d.ts +12 -0
  34. package/dist/cjs/experimental/core.d.ts +33 -0
  35. package/dist/cjs/experimental/errors.d.ts +8 -0
  36. package/dist/cjs/experimental/index.d.ts +7 -0
  37. package/dist/cjs/experimental/persistent-storage.d.ts +134 -0
  38. package/dist/cjs/experimental/persistent-storage.test.d.ts +5 -0
  39. package/dist/cjs/experimental/transports/utils.d.ts +3 -0
  40. package/dist/cjs/experimental/types.d.ts +367 -0
  41. package/dist/cjs/faucet/faucet.d.ts +66 -0
  42. package/dist/cjs/faucet/faucet.js +138 -0
  43. package/dist/cjs/faucet/index.d.ts +1 -0
  44. package/dist/cjs/faucet/index.js +29 -0
  45. package/dist/cjs/graphql/client.js +98 -0
  46. package/dist/cjs/graphql/core.js +506 -0
  47. package/dist/cjs/graphql/generated/2024.1/tada-env.js +13141 -0
  48. package/dist/cjs/graphql/generated/2024.1/tsconfig.tada.js +11 -0
  49. package/dist/cjs/graphql/generated/2024.4/tada-env.js +13287 -0
  50. package/dist/cjs/graphql/generated/2024.4/tsconfig.tada.js +11 -0
  51. package/dist/cjs/graphql/generated/latest/tada-env.js +12925 -0
  52. package/dist/cjs/graphql/generated/latest/tsconfig.tada.js +11 -0
  53. package/dist/cjs/graphql/generated/queries.js +807 -0
  54. package/dist/cjs/graphql/index.js +25 -0
  55. package/dist/cjs/graphql/schemas/2024.1/index.js +28 -0
  56. package/dist/cjs/graphql/schemas/2024.4/index.js +28 -0
  57. package/dist/cjs/graphql/schemas/latest/index.js +28 -0
  58. package/dist/cjs/graphql/types.js +16 -0
  59. package/dist/cjs/grpc/client.d.ts +32 -0
  60. package/dist/cjs/grpc/client.js +64 -0
  61. package/dist/cjs/grpc/core.d.ts +28 -0
  62. package/dist/cjs/grpc/core.js +645 -0
  63. package/dist/cjs/grpc/index.d.ts +4 -0
  64. package/dist/cjs/grpc/index.js +26 -0
  65. package/dist/cjs/grpc/proto/google/protobuf/any.d.ts +173 -0
  66. package/dist/cjs/grpc/proto/google/protobuf/any.js +138 -0
  67. package/dist/cjs/grpc/proto/google/protobuf/duration.d.ts +104 -0
  68. package/dist/cjs/grpc/proto/google/protobuf/duration.js +94 -0
  69. package/dist/cjs/grpc/proto/google/protobuf/empty.d.ts +25 -0
  70. package/dist/cjs/grpc/proto/google/protobuf/empty.js +30 -0
  71. package/dist/cjs/grpc/proto/google/protobuf/field_mask.d.ts +231 -0
  72. package/dist/cjs/grpc/proto/google/protobuf/field_mask.js +77 -0
  73. package/dist/cjs/grpc/proto/google/protobuf/struct.d.ts +169 -0
  74. package/dist/cjs/grpc/proto/google/protobuf/struct.js +224 -0
  75. package/dist/cjs/grpc/proto/google/protobuf/timestamp.d.ts +145 -0
  76. package/dist/cjs/grpc/proto/google/protobuf/timestamp.js +134 -0
  77. package/dist/cjs/grpc/proto/google/rpc/error_details.d.ts +525 -0
  78. package/dist/cjs/grpc/proto/google/rpc/error_details.js +317 -0
  79. package/dist/cjs/grpc/proto/google/rpc/status.d.ts +46 -0
  80. package/dist/cjs/grpc/proto/google/rpc/status.js +52 -0
  81. package/dist/cjs/grpc/proto/sui/rpc/v2/argument.d.ts +66 -0
  82. package/dist/cjs/grpc/proto/sui/rpc/v2/argument.js +70 -0
  83. package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.d.ts +34 -0
  84. package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.js +52 -0
  85. package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.d.ts +30 -0
  86. package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.js +45 -0
  87. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.d.ts +68 -0
  88. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.js +77 -0
  89. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.d.ts +74 -0
  90. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.js +84 -0
  91. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.d.ts +195 -0
  92. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.js +170 -0
  93. package/dist/cjs/grpc/proto/sui/rpc/v2/effects.d.ts +338 -0
  94. package/dist/cjs/grpc/proto/sui/rpc/v2/effects.js +300 -0
  95. package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.d.ts +62 -0
  96. package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.js +87 -0
  97. package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.d.ts +17 -0
  98. package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.js +29 -0
  99. package/dist/cjs/grpc/proto/sui/rpc/v2/event.d.ts +88 -0
  100. package/dist/cjs/grpc/proto/sui/rpc/v2/event.js +86 -0
  101. package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.d.ts +80 -0
  102. package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.js +87 -0
  103. package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.d.ts +843 -0
  104. package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.js +519 -0
  105. package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.d.ts +41 -0
  106. package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.js +63 -0
  107. package/dist/cjs/grpc/proto/sui/rpc/v2/input.d.ts +98 -0
  108. package/dist/cjs/grpc/proto/sui/rpc/v2/input.js +85 -0
  109. package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.d.ts +70 -0
  110. package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.js +81 -0
  111. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.d.ts +95 -0
  112. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.js +122 -0
  113. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.d.ts +420 -0
  114. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.js +368 -0
  115. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.d.ts +579 -0
  116. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.js +485 -0
  117. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.d.ts +61 -0
  118. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.js +81 -0
  119. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.d.ts +229 -0
  120. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.js +241 -0
  121. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.d.ts +41 -0
  122. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.js +55 -0
  123. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.d.ts +144 -0
  124. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.js +141 -0
  125. package/dist/cjs/grpc/proto/sui/rpc/v2/object.d.ts +127 -0
  126. package/dist/cjs/grpc/proto/sui/rpc/v2/object.js +114 -0
  127. package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.d.ts +34 -0
  128. package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.js +53 -0
  129. package/dist/cjs/grpc/proto/sui/rpc/v2/owner.d.ts +61 -0
  130. package/dist/cjs/grpc/proto/sui/rpc/v2/owner.js +63 -0
  131. package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.d.ts +30 -0
  132. package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.js +61 -0
  133. package/dist/cjs/grpc/proto/sui/rpc/v2/signature.d.ts +630 -0
  134. package/dist/cjs/grpc/proto/sui/rpc/v2/signature.js +541 -0
  135. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.d.ts +40 -0
  136. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.js +33 -0
  137. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.d.ts +35 -0
  138. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +50 -0
  139. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.d.ts +79 -0
  140. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.js +90 -0
  141. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.d.ts +71 -0
  142. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.js +88 -0
  143. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.d.ts +690 -0
  144. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.js +546 -0
  145. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.d.ts +55 -0
  146. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.js +54 -0
  147. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.d.ts +57 -0
  148. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.js +65 -0
  149. package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.d.ts +684 -0
  150. package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.js +740 -0
  151. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.d.ts +1321 -0
  152. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.js +1005 -0
  153. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.d.ts +41 -0
  154. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +49 -0
  155. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.d.ts +184 -0
  156. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.js +177 -0
  157. package/dist/cjs/index.d.ts +25 -0
  158. package/dist/cjs/index.js +93 -0
  159. package/dist/cjs/jsonRpc/client.d.ts +261 -0
  160. package/dist/cjs/jsonRpc/client.js +747 -0
  161. package/dist/cjs/jsonRpc/core.d.ts +87 -0
  162. package/dist/cjs/jsonRpc/core.js +638 -0
  163. package/dist/cjs/jsonRpc/errors.d.ts +12 -0
  164. package/dist/cjs/jsonRpc/errors.js +65 -0
  165. package/dist/cjs/jsonRpc/http-transport.d.ts +42 -0
  166. package/dist/cjs/jsonRpc/http-transport.js +121 -0
  167. package/dist/cjs/jsonRpc/index.d.ts +4 -0
  168. package/dist/cjs/jsonRpc/index.js +31 -0
  169. package/dist/cjs/jsonRpc/json-rpc-resolver.d.ts +4 -0
  170. package/dist/cjs/jsonRpc/json-rpc-resolver.js +321 -0
  171. package/dist/cjs/jsonRpc/rpc-websocket-client.d.ts +43 -0
  172. package/dist/cjs/jsonRpc/rpc-websocket-client.js +220 -0
  173. package/dist/cjs/jsonRpc/types/chain.d.ts +99 -0
  174. package/dist/cjs/jsonRpc/types/chain.js +16 -0
  175. package/dist/cjs/jsonRpc/types/changes.d.ts +19 -0
  176. package/dist/cjs/jsonRpc/types/changes.js +16 -0
  177. package/dist/cjs/jsonRpc/types/coins.d.ts +6 -0
  178. package/dist/cjs/jsonRpc/types/coins.js +16 -0
  179. package/dist/cjs/jsonRpc/types/common.d.ts +2 -0
  180. package/dist/cjs/jsonRpc/types/common.js +16 -0
  181. package/dist/cjs/jsonRpc/types/generated.d.ts +1492 -0
  182. package/dist/cjs/jsonRpc/types/generated.js +16 -0
  183. package/dist/cjs/jsonRpc/types/index.d.ts +6 -0
  184. package/dist/cjs/jsonRpc/types/index.js +16 -0
  185. package/dist/cjs/jsonRpc/types/params.d.ts +656 -0
  186. package/dist/cjs/jsonRpc/types/params.js +16 -0
  187. package/dist/cjs/keypairs/ed25519/ed25519-hd-key.d.ts +8 -0
  188. package/dist/cjs/keypairs/ed25519/ed25519-hd-key.js +82 -0
  189. package/dist/cjs/keypairs/ed25519/index.d.ts +2 -0
  190. package/dist/cjs/keypairs/ed25519/index.js +27 -0
  191. package/dist/cjs/keypairs/ed25519/keypair.d.ts +74 -0
  192. package/dist/cjs/keypairs/ed25519/keypair.js +169 -0
  193. package/dist/cjs/keypairs/ed25519/publickey.d.ts +30 -0
  194. package/dist/cjs/keypairs/ed25519/publickey.js +90 -0
  195. package/dist/cjs/keypairs/index.d.ts +4 -0
  196. package/dist/cjs/keypairs/index.js +21 -0
  197. package/dist/cjs/keypairs/passkey/index.d.ts +3 -0
  198. package/dist/cjs/keypairs/passkey/index.js +28 -0
  199. package/dist/cjs/keypairs/passkey/keypair.d.ts +113 -0
  200. package/dist/cjs/keypairs/passkey/keypair.js +268 -0
  201. package/dist/cjs/keypairs/passkey/publickey.d.ts +72 -0
  202. package/dist/cjs/keypairs/passkey/publickey.js +175 -0
  203. package/dist/cjs/keypairs/passkey/types.d.ts +12 -0
  204. package/dist/cjs/keypairs/passkey/types.js +16 -0
  205. package/dist/cjs/keypairs/secp256k1/index.d.ts +2 -0
  206. package/dist/cjs/keypairs/secp256k1/index.js +27 -0
  207. package/dist/cjs/keypairs/secp256k1/keypair.d.ts +73 -0
  208. package/dist/cjs/keypairs/secp256k1/keypair.js +159 -0
  209. package/dist/cjs/keypairs/secp256k1/publickey.d.ts +30 -0
  210. package/dist/cjs/keypairs/secp256k1/publickey.js +95 -0
  211. package/dist/cjs/keypairs/secp256r1/index.d.ts +2 -0
  212. package/dist/cjs/keypairs/secp256r1/index.js +27 -0
  213. package/dist/cjs/keypairs/secp256r1/keypair.d.ts +73 -0
  214. package/dist/cjs/keypairs/secp256r1/keypair.js +155 -0
  215. package/dist/cjs/keypairs/secp256r1/publickey.d.ts +30 -0
  216. package/dist/cjs/keypairs/secp256r1/publickey.js +96 -0
  217. package/dist/cjs/multisig/index.d.ts +2 -0
  218. package/dist/cjs/multisig/index.js +27 -0
  219. package/dist/cjs/multisig/publickey.d.ts +79 -0
  220. package/dist/cjs/multisig/publickey.js +296 -0
  221. package/dist/cjs/multisig/signer.d.ts +20 -0
  222. package/dist/cjs/multisig/signer.js +114 -0
  223. package/dist/cjs/package.json +5 -0
  224. package/dist/cjs/transactions/Arguments.d.ts +57 -0
  225. package/dist/cjs/transactions/Arguments.js +36 -0
  226. package/dist/cjs/transactions/Commands.d.ts +57 -0
  227. package/dist/cjs/transactions/Commands.js +143 -0
  228. package/dist/cjs/transactions/Inputs.d.ts +22 -0
  229. package/dist/cjs/transactions/Inputs.js +87 -0
  230. package/dist/cjs/transactions/ObjectCache.d.ts +83 -0
  231. package/dist/cjs/transactions/ObjectCache.js +251 -0
  232. package/dist/cjs/transactions/Transaction.d.ts +710 -0
  233. package/dist/cjs/transactions/Transaction.js +742 -0
  234. package/dist/cjs/transactions/TransactionData.d.ts +73 -0
  235. package/dist/cjs/transactions/TransactionData.js +472 -0
  236. package/dist/cjs/transactions/__tests__/Transaction.test.d.ts +1 -0
  237. package/dist/cjs/transactions/__tests__/bcs.test.d.ts +1 -0
  238. package/dist/cjs/transactions/data/internal.d.ts +1010 -0
  239. package/dist/cjs/transactions/data/internal.js +230 -0
  240. package/dist/cjs/transactions/data/v1.d.ts +312 -0
  241. package/dist/cjs/transactions/data/v1.js +538 -0
  242. package/dist/cjs/transactions/data/v2.d.ts +153 -0
  243. package/dist/cjs/transactions/data/v2.js +124 -0
  244. package/dist/cjs/transactions/executor/caching.d.ts +31 -0
  245. package/dist/cjs/transactions/executor/caching.js +118 -0
  246. package/dist/cjs/transactions/executor/parallel.d.ts +37 -0
  247. package/dist/cjs/transactions/executor/parallel.js +395 -0
  248. package/dist/cjs/transactions/executor/queue.d.ts +11 -0
  249. package/dist/cjs/transactions/executor/queue.js +87 -0
  250. package/dist/cjs/transactions/executor/serial.d.ts +31 -0
  251. package/dist/cjs/transactions/executor/serial.js +136 -0
  252. package/dist/cjs/transactions/hash.d.ts +7 -0
  253. package/dist/cjs/transactions/hash.js +31 -0
  254. package/dist/cjs/transactions/index.d.ts +21 -0
  255. package/dist/cjs/transactions/index.js +50 -0
  256. package/dist/cjs/transactions/intents/CoinWithBalance.d.ts +9 -0
  257. package/dist/cjs/transactions/intents/CoinWithBalance.js +206 -0
  258. package/dist/cjs/transactions/object.d.ts +24 -0
  259. package/dist/cjs/transactions/object.js +116 -0
  260. package/dist/cjs/transactions/plugins/NamedPackagesPlugin.d.ts +31 -0
  261. package/dist/cjs/transactions/plugins/NamedPackagesPlugin.js +37 -0
  262. package/dist/cjs/transactions/pure.d.ts +20 -0
  263. package/dist/cjs/transactions/pure.js +64 -0
  264. package/dist/cjs/transactions/resolve.d.ts +13 -0
  265. package/dist/cjs/transactions/resolve.js +103 -0
  266. package/dist/cjs/transactions/serializer.d.ts +7 -0
  267. package/dist/cjs/transactions/serializer.js +189 -0
  268. package/dist/cjs/transactions/utils.d.ts +10 -0
  269. package/dist/cjs/transactions/utils.js +143 -0
  270. package/dist/cjs/utils/constants.d.ts +17 -0
  271. package/dist/cjs/utils/constants.js +57 -0
  272. package/dist/cjs/utils/derived-objects.d.ts +5 -0
  273. package/dist/cjs/utils/derived-objects.js +33 -0
  274. package/dist/cjs/utils/dynamic-fields.d.ts +2 -0
  275. package/dist/cjs/utils/dynamic-fields.js +40 -0
  276. package/dist/cjs/utils/format.d.ts +2 -0
  277. package/dist/cjs/utils/format.js +35 -0
  278. package/dist/cjs/utils/index.d.ts +8 -0
  279. package/dist/cjs/utils/index.js +65 -0
  280. package/dist/cjs/utils/move-registry.d.ts +6 -0
  281. package/dist/cjs/utils/move-registry.js +44 -0
  282. package/dist/cjs/utils/sui-types.d.ts +26 -0
  283. package/dist/cjs/utils/sui-types.js +90 -0
  284. package/dist/cjs/utils/suins.d.ts +2 -0
  285. package/dist/cjs/utils/suins.js +56 -0
  286. package/dist/cjs/verify/index.d.ts +1 -0
  287. package/dist/cjs/verify/index.js +28 -0
  288. package/dist/cjs/verify/verify.d.ts +16 -0
  289. package/dist/cjs/verify/verify.js +125 -0
  290. package/dist/cjs/version.d.ts +2 -0
  291. package/dist/cjs/version.js +26 -0
  292. package/dist/cjs/w/call/allocation.d.ts +35 -0
  293. package/dist/cjs/w/call/allocation.js +439 -0
  294. package/dist/cjs/w/call/arb.d.ts +17 -0
  295. package/dist/cjs/w/call/arb.js +149 -0
  296. package/dist/cjs/w/call/arbitration.d.ts +106 -0
  297. package/dist/cjs/w/call/arbitration.js +1623 -0
  298. package/dist/cjs/w/call/base.d.ts +42 -0
  299. package/dist/cjs/w/call/base.js +363 -0
  300. package/dist/cjs/w/call/contact.d.ts +45 -0
  301. package/dist/cjs/w/call/contact.js +479 -0
  302. package/dist/cjs/w/call/demand.d.ts +79 -0
  303. package/dist/cjs/w/call/demand.js +872 -0
  304. package/dist/cjs/w/call/entity.d.ts +33 -0
  305. package/dist/cjs/w/call/entity.js +230 -0
  306. package/dist/cjs/w/call/guard-ins.d.ts +31 -0
  307. package/dist/cjs/w/call/guard-ins.js +4391 -0
  308. package/dist/cjs/w/call/guard.d.ts +254 -0
  309. package/dist/cjs/w/call/guard.js +1210 -0
  310. package/dist/cjs/w/call/index.d.ts +37 -0
  311. package/dist/cjs/w/call/index.js +71 -0
  312. package/dist/cjs/w/call/machine.d.ts +124 -0
  313. package/dist/cjs/w/call/machine.js +1486 -0
  314. package/dist/cjs/w/call/order.d.ts +73 -0
  315. package/dist/cjs/w/call/order.js +485 -0
  316. package/dist/cjs/w/call/passport.d.ts +24 -0
  317. package/dist/cjs/w/call/passport.js +281 -0
  318. package/dist/cjs/w/call/payment.d.ts +27 -0
  319. package/dist/cjs/w/call/payment.js +241 -0
  320. package/dist/cjs/w/call/permission.d.ts +222 -0
  321. package/dist/cjs/w/call/permission.js +1368 -0
  322. package/dist/cjs/w/call/personal.d.ts +51 -0
  323. package/dist/cjs/w/call/personal.js +184 -0
  324. package/dist/cjs/w/call/progress.d.ts +94 -0
  325. package/dist/cjs/w/call/progress.js +833 -0
  326. package/dist/cjs/w/call/proof.d.ts +27 -0
  327. package/dist/cjs/w/call/proof.js +124 -0
  328. package/dist/cjs/w/call/repository.d.ts +97 -0
  329. package/dist/cjs/w/call/repository.js +1324 -0
  330. package/dist/cjs/w/call/resource.d.ts +27 -0
  331. package/dist/cjs/w/call/resource.js +149 -0
  332. package/dist/cjs/w/call/reward.d.ts +52 -0
  333. package/dist/cjs/w/call/reward.js +879 -0
  334. package/dist/cjs/w/call/service.d.ts +184 -0
  335. package/dist/cjs/w/call/service.js +2468 -0
  336. package/dist/cjs/w/call/treasury.d.ts +77 -0
  337. package/dist/cjs/w/call/treasury.js +1192 -0
  338. package/dist/cjs/w/call/util.d.ts +12 -0
  339. package/dist/cjs/w/call/util.js +661 -0
  340. package/dist/cjs/w/common.d.ts +359 -0
  341. package/dist/cjs/w/common.js +625 -0
  342. package/dist/cjs/w/exception.d.ts +82 -0
  343. package/dist/cjs/w/exception.js +604 -0
  344. package/dist/cjs/w/index.d.ts +8 -0
  345. package/dist/cjs/w/index.js +25 -0
  346. package/dist/cjs/w/local/.eslintrc.js +15 -0
  347. package/dist/cjs/w/local/account.d.ts +134 -0
  348. package/dist/cjs/w/local/account.js +770 -0
  349. package/dist/cjs/w/local/cache.d.ts +35 -0
  350. package/dist/cjs/w/local/cache.js +181 -0
  351. package/dist/cjs/w/local/config.d.ts +15 -0
  352. package/dist/cjs/w/local/config.js +83 -0
  353. package/dist/cjs/w/local/index.d.ts +193 -0
  354. package/dist/cjs/w/local/index.js +322 -0
  355. package/dist/cjs/w/local/local.d.ts +93 -0
  356. package/dist/cjs/w/local/local.js +673 -0
  357. package/dist/cjs/w/local/storage.d.ts +61 -0
  358. package/dist/cjs/w/local/storage.js +219 -0
  359. package/dist/cjs/w/local/token.d.ts +22 -0
  360. package/dist/cjs/w/local/token.js +182 -0
  361. package/dist/cjs/w/local/util.d.ts +5 -0
  362. package/dist/cjs/w/local/util.js +57 -0
  363. package/dist/cjs/w/local/wip.d.ts +218 -0
  364. package/dist/cjs/w/local/wip.js +911 -0
  365. package/dist/cjs/w/messenger/.eslintrc.js +15 -0
  366. package/dist/cjs/w/messenger/crypto.d.ts +269 -0
  367. package/dist/cjs/w/messenger/crypto.js +448 -0
  368. package/dist/cjs/w/messenger/index.d.ts +23 -0
  369. package/dist/cjs/w/messenger/index.js +37 -0
  370. package/dist/cjs/w/messenger/messenger-api.d.ts +225 -0
  371. package/dist/cjs/w/messenger/messenger-api.js +1247 -0
  372. package/dist/cjs/w/messenger/messenger-manager.d.ts +80 -0
  373. package/dist/cjs/w/messenger/messenger-manager.js +1143 -0
  374. package/dist/cjs/w/messenger/messenger.d.ts +231 -0
  375. package/dist/cjs/w/messenger/messenger.js +1512 -0
  376. package/dist/cjs/w/messenger/server.d.ts +134 -0
  377. package/dist/cjs/w/messenger/server.js +535 -0
  378. package/dist/cjs/w/messenger/session.d.ts +78 -0
  379. package/dist/cjs/w/messenger/session.js +418 -0
  380. package/dist/cjs/w/messenger/storage.d.ts +192 -0
  381. package/dist/cjs/w/messenger/storage.js +964 -0
  382. package/dist/cjs/w/messenger/types.d.ts +705 -0
  383. package/dist/cjs/w/messenger/types.js +107 -0
  384. package/dist/cjs/w/messenger/utils.d.ts +15 -0
  385. package/dist/cjs/w/messenger/utils.js +37 -0
  386. package/dist/cjs/w/query/bult-in.d.ts +73 -0
  387. package/dist/cjs/w/query/bult-in.js +121 -0
  388. package/dist/cjs/w/query/event.d.ts +82 -0
  389. package/dist/cjs/w/query/event.js +157 -0
  390. package/dist/cjs/w/query/index.d.ts +5 -0
  391. package/dist/cjs/w/query/index.js +22 -0
  392. package/dist/cjs/w/query/object.d.ts +658 -0
  393. package/dist/cjs/w/query/object.js +1671 -0
  394. package/dist/cjs/w/query/received.d.ts +34 -0
  395. package/dist/cjs/w/query/received.js +93 -0
  396. package/dist/cjs/w/query/util.d.ts +5 -0
  397. package/dist/cjs/w/query/util.js +82 -0
  398. package/dist/cjs/w/util.d.ts +19 -0
  399. package/dist/cjs/w/util.js +715 -0
  400. package/dist/cjs/zklogin/address.js +93 -0
  401. package/dist/cjs/zklogin/bcs.js +41 -0
  402. package/dist/cjs/zklogin/index.js +45 -0
  403. package/dist/cjs/zklogin/jwt-decode.js +88 -0
  404. package/dist/cjs/zklogin/jwt-utils.js +128 -0
  405. package/dist/cjs/zklogin/nonce.js +60 -0
  406. package/dist/cjs/zklogin/poseidon.js +64 -0
  407. package/dist/cjs/zklogin/publickey.js +281 -0
  408. package/dist/cjs/zklogin/signature.js +57 -0
  409. package/dist/cjs/zklogin/utils.js +98 -0
  410. package/dist/esm/bcs/bcs.d.ts +1973 -0
  411. package/dist/esm/bcs/bcs.js +319 -0
  412. package/dist/esm/bcs/effects.d.ts +579 -0
  413. package/dist/esm/bcs/effects.js +211 -0
  414. package/dist/esm/bcs/index.d.ts +2589 -0
  415. package/dist/esm/bcs/index.js +98 -0
  416. package/dist/esm/bcs/pure.d.ts +22 -0
  417. package/dist/esm/bcs/pure.js +42 -0
  418. package/dist/esm/bcs/type-tag-serializer.d.ts +7 -0
  419. package/dist/esm/bcs/type-tag-serializer.js +104 -0
  420. package/dist/esm/bcs/types.d.ts +114 -0
  421. package/dist/esm/bcs/types.js +6 -0
  422. package/dist/esm/client/index.d.ts +5 -0
  423. package/dist/esm/client/index.js +23 -0
  424. package/dist/esm/client/network.d.ts +5 -0
  425. package/dist/esm/client/network.js +23 -0
  426. package/dist/esm/cryptography/index.d.ts +7 -0
  427. package/dist/esm/cryptography/index.js +46 -0
  428. package/dist/esm/cryptography/intent.d.ts +6 -0
  429. package/dist/esm/cryptography/intent.js +14 -0
  430. package/dist/esm/cryptography/keypair.d.ts +73 -0
  431. package/dist/esm/cryptography/keypair.js +108 -0
  432. package/dist/esm/cryptography/mnemonics.d.ts +27 -0
  433. package/dist/esm/cryptography/mnemonics.js +30 -0
  434. package/dist/esm/cryptography/publickey.d.ts +67 -0
  435. package/dist/esm/cryptography/publickey.js +125 -0
  436. package/dist/esm/cryptography/signature-scheme.d.ts +24 -0
  437. package/dist/esm/cryptography/signature-scheme.js +27 -0
  438. package/dist/esm/cryptography/signature.d.ts +62 -0
  439. package/dist/esm/cryptography/signature.js +54 -0
  440. package/dist/esm/experimental/cache.d.ts +12 -0
  441. package/dist/esm/experimental/client.d.ts +12 -0
  442. package/dist/esm/experimental/core.d.ts +33 -0
  443. package/dist/esm/experimental/errors.d.ts +8 -0
  444. package/dist/esm/experimental/index.d.ts +7 -0
  445. package/dist/esm/experimental/persistent-storage.d.ts +134 -0
  446. package/dist/esm/experimental/persistent-storage.test.d.ts +5 -0
  447. package/dist/esm/experimental/transports/utils.d.ts +3 -0
  448. package/dist/esm/experimental/types.d.ts +367 -0
  449. package/dist/esm/faucet/faucet.d.ts +66 -0
  450. package/dist/esm/faucet/faucet.js +118 -0
  451. package/dist/esm/faucet/index.d.ts +1 -0
  452. package/dist/esm/faucet/index.js +16 -0
  453. package/dist/esm/graphql/client.js +79 -0
  454. package/dist/esm/graphql/core.js +505 -0
  455. package/dist/esm/graphql/generated/2024.1/tada-env.js +13121 -0
  456. package/dist/esm/graphql/generated/2024.1/tsconfig.tada.js +16 -0
  457. package/dist/esm/graphql/generated/2024.4/tada-env.js +13267 -0
  458. package/dist/esm/graphql/generated/2024.4/tsconfig.tada.js +16 -0
  459. package/dist/esm/graphql/generated/latest/tada-env.js +12905 -0
  460. package/dist/esm/graphql/generated/latest/tsconfig.tada.js +16 -0
  461. package/dist/esm/graphql/generated/queries.js +788 -0
  462. package/dist/esm/graphql/index.js +8 -0
  463. package/dist/esm/graphql/schemas/2024.1/index.js +8 -0
  464. package/dist/esm/graphql/schemas/2024.4/index.js +8 -0
  465. package/dist/esm/graphql/schemas/latest/index.js +8 -0
  466. package/dist/esm/graphql/types.js +0 -0
  467. package/dist/esm/grpc/client.d.ts +32 -0
  468. package/dist/esm/grpc/client.js +45 -0
  469. package/dist/esm/grpc/core.d.ts +28 -0
  470. package/dist/esm/grpc/core.js +634 -0
  471. package/dist/esm/grpc/index.d.ts +4 -0
  472. package/dist/esm/grpc/index.js +6 -0
  473. package/dist/esm/grpc/proto/google/protobuf/any.d.ts +173 -0
  474. package/dist/esm/grpc/proto/google/protobuf/any.js +118 -0
  475. package/dist/esm/grpc/proto/google/protobuf/duration.d.ts +104 -0
  476. package/dist/esm/grpc/proto/google/protobuf/duration.js +74 -0
  477. package/dist/esm/grpc/proto/google/protobuf/empty.d.ts +25 -0
  478. package/dist/esm/grpc/proto/google/protobuf/empty.js +10 -0
  479. package/dist/esm/grpc/proto/google/protobuf/field_mask.d.ts +231 -0
  480. package/dist/esm/grpc/proto/google/protobuf/field_mask.js +57 -0
  481. package/dist/esm/grpc/proto/google/protobuf/struct.d.ts +169 -0
  482. package/dist/esm/grpc/proto/google/protobuf/struct.js +204 -0
  483. package/dist/esm/grpc/proto/google/protobuf/timestamp.d.ts +145 -0
  484. package/dist/esm/grpc/proto/google/protobuf/timestamp.js +114 -0
  485. package/dist/esm/grpc/proto/google/rpc/error_details.d.ts +525 -0
  486. package/dist/esm/grpc/proto/google/rpc/error_details.js +297 -0
  487. package/dist/esm/grpc/proto/google/rpc/status.d.ts +46 -0
  488. package/dist/esm/grpc/proto/google/rpc/status.js +32 -0
  489. package/dist/esm/grpc/proto/sui/rpc/v2/argument.d.ts +66 -0
  490. package/dist/esm/grpc/proto/sui/rpc/v2/argument.js +50 -0
  491. package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.d.ts +34 -0
  492. package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.js +32 -0
  493. package/dist/esm/grpc/proto/sui/rpc/v2/bcs.d.ts +30 -0
  494. package/dist/esm/grpc/proto/sui/rpc/v2/bcs.js +25 -0
  495. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.d.ts +68 -0
  496. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.js +57 -0
  497. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.d.ts +74 -0
  498. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.js +64 -0
  499. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.d.ts +195 -0
  500. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.js +150 -0
  501. package/dist/esm/grpc/proto/sui/rpc/v2/effects.d.ts +338 -0
  502. package/dist/esm/grpc/proto/sui/rpc/v2/effects.js +280 -0
  503. package/dist/esm/grpc/proto/sui/rpc/v2/epoch.d.ts +62 -0
  504. package/dist/esm/grpc/proto/sui/rpc/v2/epoch.js +67 -0
  505. package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.d.ts +17 -0
  506. package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.js +9 -0
  507. package/dist/esm/grpc/proto/sui/rpc/v2/event.d.ts +88 -0
  508. package/dist/esm/grpc/proto/sui/rpc/v2/event.js +66 -0
  509. package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.d.ts +80 -0
  510. package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.js +67 -0
  511. package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.d.ts +843 -0
  512. package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.js +499 -0
  513. package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.d.ts +41 -0
  514. package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.js +43 -0
  515. package/dist/esm/grpc/proto/sui/rpc/v2/input.d.ts +98 -0
  516. package/dist/esm/grpc/proto/sui/rpc/v2/input.js +65 -0
  517. package/dist/esm/grpc/proto/sui/rpc/v2/jwk.d.ts +70 -0
  518. package/dist/esm/grpc/proto/sui/rpc/v2/jwk.js +61 -0
  519. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.d.ts +95 -0
  520. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.js +103 -0
  521. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.d.ts +420 -0
  522. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.js +348 -0
  523. package/dist/esm/grpc/proto/sui/rpc/v2/move_package.d.ts +579 -0
  524. package/dist/esm/grpc/proto/sui/rpc/v2/move_package.js +465 -0
  525. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.d.ts +61 -0
  526. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.js +62 -0
  527. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.d.ts +229 -0
  528. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.js +221 -0
  529. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.d.ts +41 -0
  530. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.js +36 -0
  531. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.d.ts +144 -0
  532. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.js +121 -0
  533. package/dist/esm/grpc/proto/sui/rpc/v2/object.d.ts +127 -0
  534. package/dist/esm/grpc/proto/sui/rpc/v2/object.js +94 -0
  535. package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.d.ts +34 -0
  536. package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.js +33 -0
  537. package/dist/esm/grpc/proto/sui/rpc/v2/owner.d.ts +61 -0
  538. package/dist/esm/grpc/proto/sui/rpc/v2/owner.js +43 -0
  539. package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.d.ts +30 -0
  540. package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.js +41 -0
  541. package/dist/esm/grpc/proto/sui/rpc/v2/signature.d.ts +630 -0
  542. package/dist/esm/grpc/proto/sui/rpc/v2/signature.js +521 -0
  543. package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.d.ts +40 -0
  544. package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.js +13 -0
  545. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.d.ts +35 -0
  546. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +31 -0
  547. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.d.ts +79 -0
  548. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.js +70 -0
  549. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.d.ts +71 -0
  550. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.js +69 -0
  551. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.d.ts +690 -0
  552. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.js +526 -0
  553. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.d.ts +55 -0
  554. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.js +35 -0
  555. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.d.ts +57 -0
  556. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.js +45 -0
  557. package/dist/esm/grpc/proto/sui/rpc/v2/system_state.d.ts +684 -0
  558. package/dist/esm/grpc/proto/sui/rpc/v2/system_state.js +720 -0
  559. package/dist/esm/grpc/proto/sui/rpc/v2/transaction.d.ts +1321 -0
  560. package/dist/esm/grpc/proto/sui/rpc/v2/transaction.js +985 -0
  561. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.d.ts +41 -0
  562. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +30 -0
  563. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.d.ts +184 -0
  564. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.js +157 -0
  565. package/dist/esm/index.d.ts +25 -0
  566. package/dist/esm/index.js +119 -0
  567. package/dist/esm/jsonRpc/client.d.ts +261 -0
  568. package/dist/esm/jsonRpc/client.js +734 -0
  569. package/dist/esm/jsonRpc/core.d.ts +87 -0
  570. package/dist/esm/jsonRpc/core.js +621 -0
  571. package/dist/esm/jsonRpc/errors.d.ts +12 -0
  572. package/dist/esm/jsonRpc/errors.js +46 -0
  573. package/dist/esm/jsonRpc/http-transport.d.ts +42 -0
  574. package/dist/esm/jsonRpc/http-transport.js +101 -0
  575. package/dist/esm/jsonRpc/index.d.ts +4 -0
  576. package/dist/esm/jsonRpc/index.js +20 -0
  577. package/dist/esm/jsonRpc/json-rpc-resolver.d.ts +4 -0
  578. package/dist/esm/jsonRpc/json-rpc-resolver.js +309 -0
  579. package/dist/esm/jsonRpc/rpc-websocket-client.d.ts +43 -0
  580. package/dist/esm/jsonRpc/rpc-websocket-client.js +201 -0
  581. package/dist/esm/jsonRpc/types/chain.d.ts +99 -0
  582. package/dist/esm/jsonRpc/types/chain.js +0 -0
  583. package/dist/esm/jsonRpc/types/changes.d.ts +19 -0
  584. package/dist/esm/jsonRpc/types/changes.js +0 -0
  585. package/dist/esm/jsonRpc/types/coins.d.ts +6 -0
  586. package/dist/esm/jsonRpc/types/coins.js +0 -0
  587. package/dist/esm/jsonRpc/types/common.d.ts +2 -0
  588. package/dist/esm/jsonRpc/types/common.js +0 -0
  589. package/dist/esm/jsonRpc/types/generated.d.ts +1492 -0
  590. package/dist/esm/jsonRpc/types/generated.js +0 -0
  591. package/dist/esm/jsonRpc/types/index.d.ts +6 -0
  592. package/dist/esm/jsonRpc/types/index.js +0 -0
  593. package/dist/esm/jsonRpc/types/params.d.ts +656 -0
  594. package/dist/esm/jsonRpc/types/params.js +0 -0
  595. package/dist/esm/keypairs/ed25519/ed25519-hd-key.d.ts +8 -0
  596. package/dist/esm/keypairs/ed25519/ed25519-hd-key.js +62 -0
  597. package/dist/esm/keypairs/ed25519/index.d.ts +2 -0
  598. package/dist/esm/keypairs/ed25519/index.js +10 -0
  599. package/dist/esm/keypairs/ed25519/keypair.d.ts +74 -0
  600. package/dist/esm/keypairs/ed25519/keypair.js +158 -0
  601. package/dist/esm/keypairs/ed25519/publickey.d.ts +30 -0
  602. package/dist/esm/keypairs/ed25519/publickey.js +75 -0
  603. package/dist/esm/keypairs/index.d.ts +4 -0
  604. package/dist/esm/keypairs/index.js +4 -0
  605. package/dist/esm/keypairs/passkey/index.d.ts +3 -0
  606. package/dist/esm/keypairs/passkey/index.js +12 -0
  607. package/dist/esm/keypairs/passkey/keypair.d.ts +113 -0
  608. package/dist/esm/keypairs/passkey/keypair.js +258 -0
  609. package/dist/esm/keypairs/passkey/publickey.d.ts +72 -0
  610. package/dist/esm/keypairs/passkey/publickey.js +156 -0
  611. package/dist/esm/keypairs/passkey/types.d.ts +12 -0
  612. package/dist/esm/keypairs/passkey/types.js +0 -0
  613. package/dist/esm/keypairs/secp256k1/index.d.ts +2 -0
  614. package/dist/esm/keypairs/secp256k1/index.js +10 -0
  615. package/dist/esm/keypairs/secp256k1/keypair.d.ts +73 -0
  616. package/dist/esm/keypairs/secp256k1/keypair.js +147 -0
  617. package/dist/esm/keypairs/secp256k1/publickey.d.ts +30 -0
  618. package/dist/esm/keypairs/secp256k1/publickey.js +80 -0
  619. package/dist/esm/keypairs/secp256r1/index.d.ts +2 -0
  620. package/dist/esm/keypairs/secp256r1/index.js +10 -0
  621. package/dist/esm/keypairs/secp256r1/keypair.d.ts +73 -0
  622. package/dist/esm/keypairs/secp256r1/keypair.js +143 -0
  623. package/dist/esm/keypairs/secp256r1/publickey.d.ts +30 -0
  624. package/dist/esm/keypairs/secp256r1/publickey.js +77 -0
  625. package/dist/esm/multisig/index.d.ts +2 -0
  626. package/dist/esm/multisig/index.js +10 -0
  627. package/dist/esm/multisig/publickey.d.ts +79 -0
  628. package/dist/esm/multisig/publickey.js +280 -0
  629. package/dist/esm/multisig/signer.d.ts +20 -0
  630. package/dist/esm/multisig/signer.js +94 -0
  631. package/dist/esm/package.json +5 -0
  632. package/dist/esm/transactions/Arguments.d.ts +57 -0
  633. package/dist/esm/transactions/Arguments.js +16 -0
  634. package/dist/esm/transactions/Commands.d.ts +57 -0
  635. package/dist/esm/transactions/Commands.js +123 -0
  636. package/dist/esm/transactions/Inputs.d.ts +22 -0
  637. package/dist/esm/transactions/Inputs.js +67 -0
  638. package/dist/esm/transactions/ObjectCache.d.ts +83 -0
  639. package/dist/esm/transactions/ObjectCache.js +231 -0
  640. package/dist/esm/transactions/Transaction.d.ts +710 -0
  641. package/dist/esm/transactions/Transaction.js +731 -0
  642. package/dist/esm/transactions/TransactionData.d.ts +73 -0
  643. package/dist/esm/transactions/TransactionData.js +453 -0
  644. package/dist/esm/transactions/__tests__/Transaction.test.d.ts +1 -0
  645. package/dist/esm/transactions/__tests__/bcs.test.d.ts +1 -0
  646. package/dist/esm/transactions/data/internal.d.ts +1010 -0
  647. package/dist/esm/transactions/data/internal.js +232 -0
  648. package/dist/esm/transactions/data/v1.d.ts +312 -0
  649. package/dist/esm/transactions/data/v1.js +542 -0
  650. package/dist/esm/transactions/data/v2.d.ts +153 -0
  651. package/dist/esm/transactions/data/v2.js +126 -0
  652. package/dist/esm/transactions/executor/caching.d.ts +31 -0
  653. package/dist/esm/transactions/executor/caching.js +99 -0
  654. package/dist/esm/transactions/executor/parallel.d.ts +37 -0
  655. package/dist/esm/transactions/executor/parallel.js +375 -0
  656. package/dist/esm/transactions/executor/queue.d.ts +11 -0
  657. package/dist/esm/transactions/executor/queue.js +68 -0
  658. package/dist/esm/transactions/executor/serial.d.ts +31 -0
  659. package/dist/esm/transactions/executor/serial.js +116 -0
  660. package/dist/esm/transactions/hash.d.ts +7 -0
  661. package/dist/esm/transactions/hash.js +11 -0
  662. package/dist/esm/transactions/index.d.ts +21 -0
  663. package/dist/esm/transactions/index.js +41 -0
  664. package/dist/esm/transactions/intents/CoinWithBalance.d.ts +9 -0
  665. package/dist/esm/transactions/intents/CoinWithBalance.js +186 -0
  666. package/dist/esm/transactions/object.d.ts +24 -0
  667. package/dist/esm/transactions/object.js +96 -0
  668. package/dist/esm/transactions/plugins/NamedPackagesPlugin.d.ts +31 -0
  669. package/dist/esm/transactions/plugins/NamedPackagesPlugin.js +17 -0
  670. package/dist/esm/transactions/pure.d.ts +20 -0
  671. package/dist/esm/transactions/pure.js +44 -0
  672. package/dist/esm/transactions/resolve.d.ts +13 -0
  673. package/dist/esm/transactions/resolve.js +83 -0
  674. package/dist/esm/transactions/serializer.d.ts +7 -0
  675. package/dist/esm/transactions/serializer.js +169 -0
  676. package/dist/esm/transactions/utils.d.ts +10 -0
  677. package/dist/esm/transactions/utils.js +123 -0
  678. package/dist/esm/utils/constants.d.ts +17 -0
  679. package/dist/esm/utils/constants.js +37 -0
  680. package/dist/esm/utils/derived-objects.d.ts +5 -0
  681. package/dist/esm/utils/derived-objects.js +13 -0
  682. package/dist/esm/utils/dynamic-fields.d.ts +2 -0
  683. package/dist/esm/utils/dynamic-fields.js +20 -0
  684. package/dist/esm/utils/format.d.ts +2 -0
  685. package/dist/esm/utils/format.js +15 -0
  686. package/dist/esm/utils/index.d.ts +8 -0
  687. package/dist/esm/utils/index.js +76 -0
  688. package/dist/esm/utils/move-registry.d.ts +6 -0
  689. package/dist/esm/utils/move-registry.js +24 -0
  690. package/dist/esm/utils/sui-types.d.ts +26 -0
  691. package/dist/esm/utils/sui-types.js +70 -0
  692. package/dist/esm/utils/suins.d.ts +2 -0
  693. package/dist/esm/utils/suins.js +36 -0
  694. package/dist/esm/verify/index.d.ts +1 -0
  695. package/dist/esm/verify/index.js +14 -0
  696. package/dist/esm/verify/verify.d.ts +16 -0
  697. package/dist/esm/verify/verify.js +108 -0
  698. package/dist/esm/version.d.ts +2 -0
  699. package/dist/esm/version.js +6 -0
  700. package/dist/esm/w/call/allocation.d.ts +35 -0
  701. package/dist/esm/w/call/allocation.js +433 -0
  702. package/dist/esm/w/call/arb.d.ts +17 -0
  703. package/dist/esm/w/call/arb.js +138 -0
  704. package/dist/esm/w/call/arbitration.d.ts +106 -0
  705. package/dist/esm/w/call/arbitration.js +1620 -0
  706. package/dist/esm/w/call/base.d.ts +42 -0
  707. package/dist/esm/w/call/base.js +350 -0
  708. package/dist/esm/w/call/contact.d.ts +45 -0
  709. package/dist/esm/w/call/contact.js +474 -0
  710. package/dist/esm/w/call/demand.d.ts +79 -0
  711. package/dist/esm/w/call/demand.js +869 -0
  712. package/dist/esm/w/call/entity.d.ts +33 -0
  713. package/dist/esm/w/call/entity.js +220 -0
  714. package/dist/esm/w/call/guard-ins.d.ts +31 -0
  715. package/dist/esm/w/call/guard-ins.js +4371 -0
  716. package/dist/esm/w/call/guard.d.ts +254 -0
  717. package/dist/esm/w/call/guard.js +1202 -0
  718. package/dist/esm/w/call/index.d.ts +37 -0
  719. package/dist/esm/w/call/index.js +57 -0
  720. package/dist/esm/w/call/machine.d.ts +124 -0
  721. package/dist/esm/w/call/machine.js +1492 -0
  722. package/dist/esm/w/call/order.d.ts +73 -0
  723. package/dist/esm/w/call/order.js +481 -0
  724. package/dist/esm/w/call/passport.d.ts +24 -0
  725. package/dist/esm/w/call/passport.js +266 -0
  726. package/dist/esm/w/call/payment.d.ts +27 -0
  727. package/dist/esm/w/call/payment.js +233 -0
  728. package/dist/esm/w/call/permission.d.ts +222 -0
  729. package/dist/esm/w/call/permission.js +1375 -0
  730. package/dist/esm/w/call/personal.d.ts +51 -0
  731. package/dist/esm/w/call/personal.js +177 -0
  732. package/dist/esm/w/call/progress.d.ts +94 -0
  733. package/dist/esm/w/call/progress.js +827 -0
  734. package/dist/esm/w/call/proof.d.ts +27 -0
  735. package/dist/esm/w/call/proof.js +110 -0
  736. package/dist/esm/w/call/repository.d.ts +97 -0
  737. package/dist/esm/w/call/repository.js +1325 -0
  738. package/dist/esm/w/call/resource.d.ts +27 -0
  739. package/dist/esm/w/call/resource.js +135 -0
  740. package/dist/esm/w/call/reward.d.ts +52 -0
  741. package/dist/esm/w/call/reward.js +874 -0
  742. package/dist/esm/w/call/service.d.ts +184 -0
  743. package/dist/esm/w/call/service.js +2472 -0
  744. package/dist/esm/w/call/treasury.d.ts +77 -0
  745. package/dist/esm/w/call/treasury.js +1186 -0
  746. package/dist/esm/w/call/util.d.ts +12 -0
  747. package/dist/esm/w/call/util.js +646 -0
  748. package/dist/esm/w/common.d.ts +359 -0
  749. package/dist/esm/w/common.js +605 -0
  750. package/dist/esm/w/exception.d.ts +82 -0
  751. package/dist/esm/w/exception.js +585 -0
  752. package/dist/esm/w/index.d.ts +8 -0
  753. package/dist/esm/w/index.js +8 -0
  754. package/dist/esm/w/local/.eslintrc.js +23 -0
  755. package/dist/esm/w/local/account.d.ts +134 -0
  756. package/dist/esm/w/local/account.js +746 -0
  757. package/dist/esm/w/local/cache.d.ts +35 -0
  758. package/dist/esm/w/local/cache.js +162 -0
  759. package/dist/esm/w/local/config.d.ts +15 -0
  760. package/dist/esm/w/local/config.js +64 -0
  761. package/dist/esm/w/local/index.d.ts +193 -0
  762. package/dist/esm/w/local/index.js +301 -0
  763. package/dist/esm/w/local/local.d.ts +93 -0
  764. package/dist/esm/w/local/local.js +654 -0
  765. package/dist/esm/w/local/storage.d.ts +61 -0
  766. package/dist/esm/w/local/storage.js +190 -0
  767. package/dist/esm/w/local/token.d.ts +22 -0
  768. package/dist/esm/w/local/token.js +163 -0
  769. package/dist/esm/w/local/util.d.ts +5 -0
  770. package/dist/esm/w/local/util.js +27 -0
  771. package/dist/esm/w/local/wip.d.ts +218 -0
  772. package/dist/esm/w/local/wip.js +882 -0
  773. package/dist/esm/w/messenger/.eslintrc.js +23 -0
  774. package/dist/esm/w/messenger/crypto.d.ts +269 -0
  775. package/dist/esm/w/messenger/crypto.js +428 -0
  776. package/dist/esm/w/messenger/index.d.ts +23 -0
  777. package/dist/esm/w/messenger/index.js +25 -0
  778. package/dist/esm/w/messenger/messenger-api.d.ts +225 -0
  779. package/dist/esm/w/messenger/messenger-api.js +1228 -0
  780. package/dist/esm/w/messenger/messenger-manager.d.ts +80 -0
  781. package/dist/esm/w/messenger/messenger-manager.js +1118 -0
  782. package/dist/esm/w/messenger/messenger.d.ts +231 -0
  783. package/dist/esm/w/messenger/messenger.js +1492 -0
  784. package/dist/esm/w/messenger/server.d.ts +134 -0
  785. package/dist/esm/w/messenger/server.js +520 -0
  786. package/dist/esm/w/messenger/session.d.ts +78 -0
  787. package/dist/esm/w/messenger/session.js +415 -0
  788. package/dist/esm/w/messenger/storage.d.ts +192 -0
  789. package/dist/esm/w/messenger/storage.js +935 -0
  790. package/dist/esm/w/messenger/types.d.ts +705 -0
  791. package/dist/esm/w/messenger/types.js +88 -0
  792. package/dist/esm/w/messenger/utils.d.ts +15 -0
  793. package/dist/esm/w/messenger/utils.js +17 -0
  794. package/dist/esm/w/query/bult-in.d.ts +73 -0
  795. package/dist/esm/w/query/bult-in.js +112 -0
  796. package/dist/esm/w/query/event.d.ts +82 -0
  797. package/dist/esm/w/query/event.js +137 -0
  798. package/dist/esm/w/query/index.d.ts +5 -0
  799. package/dist/esm/w/query/index.js +5 -0
  800. package/dist/esm/w/query/object.d.ts +658 -0
  801. package/dist/esm/w/query/object.js +1648 -0
  802. package/dist/esm/w/query/received.d.ts +34 -0
  803. package/dist/esm/w/query/received.js +73 -0
  804. package/dist/esm/w/query/util.d.ts +5 -0
  805. package/dist/esm/w/query/util.js +62 -0
  806. package/dist/esm/w/util.d.ts +19 -0
  807. package/dist/esm/w/util.js +710 -0
  808. package/dist/esm/zklogin/address.js +78 -0
  809. package/dist/esm/zklogin/bcs.js +21 -0
  810. package/dist/esm/zklogin/index.js +38 -0
  811. package/dist/esm/zklogin/jwt-decode.js +68 -0
  812. package/dist/esm/zklogin/jwt-utils.js +108 -0
  813. package/dist/esm/zklogin/nonce.js +40 -0
  814. package/dist/esm/zklogin/poseidon.js +61 -0
  815. package/dist/esm/zklogin/publickey.js +265 -0
  816. package/dist/esm/zklogin/signature.js +37 -0
  817. package/dist/esm/zklogin/utils.js +78 -0
  818. package/dist/tsconfig.esm.tsbuildinfo +1 -0
  819. package/dist/tsconfig.tsbuildinfo +1 -0
  820. package/package.json +295 -61
  821. package/dist/arbitration.d.ts +0 -65
  822. package/dist/arbitration.d.ts.map +0 -1
  823. package/dist/arbitration.js +0 -517
  824. package/dist/arbitration.js.map +0 -1
  825. package/dist/demand.d.ts +0 -27
  826. package/dist/demand.d.ts.map +0 -1
  827. package/dist/demand.js +0 -266
  828. package/dist/demand.js.map +0 -1
  829. package/dist/entity.d.ts +0 -46
  830. package/dist/entity.d.ts.map +0 -1
  831. package/dist/entity.js +0 -146
  832. package/dist/entity.js.map +0 -1
  833. package/dist/exception.d.ts +0 -37
  834. package/dist/exception.d.ts.map +0 -1
  835. package/dist/exception.js +0 -41
  836. package/dist/exception.js.map +0 -1
  837. package/dist/guard.d.ts +0 -110
  838. package/dist/guard.d.ts.map +0 -1
  839. package/dist/guard.js +0 -936
  840. package/dist/guard.js.map +0 -1
  841. package/dist/index.d.ts +0 -40
  842. package/dist/index.d.ts.map +0 -1
  843. package/dist/index.js +0 -28
  844. package/dist/index.js.map +0 -1
  845. package/dist/machine.d.ts +0 -68
  846. package/dist/machine.d.ts.map +0 -1
  847. package/dist/machine.js +0 -520
  848. package/dist/machine.js.map +0 -1
  849. package/dist/passport.d.ts +0 -129
  850. package/dist/passport.d.ts.map +0 -1
  851. package/dist/passport.js +0 -1233
  852. package/dist/passport.js.map +0 -1
  853. package/dist/payment.d.ts +0 -28
  854. package/dist/payment.d.ts.map +0 -1
  855. package/dist/payment.js +0 -60
  856. package/dist/payment.js.map +0 -1
  857. package/dist/permission.d.ts +0 -155
  858. package/dist/permission.d.ts.map +0 -1
  859. package/dist/permission.js +0 -462
  860. package/dist/permission.js.map +0 -1
  861. package/dist/progress.d.ts +0 -66
  862. package/dist/progress.d.ts.map +0 -1
  863. package/dist/progress.js +0 -311
  864. package/dist/progress.js.map +0 -1
  865. package/dist/protocol.d.ts +0 -247
  866. package/dist/protocol.d.ts.map +0 -1
  867. package/dist/protocol.js +0 -726
  868. package/dist/protocol.js.map +0 -1
  869. package/dist/repository.d.ts +0 -94
  870. package/dist/repository.d.ts.map +0 -1
  871. package/dist/repository.js +0 -783
  872. package/dist/repository.js.map +0 -1
  873. package/dist/resource.d.ts +0 -36
  874. package/dist/resource.d.ts.map +0 -1
  875. package/dist/resource.js +0 -129
  876. package/dist/resource.js.map +0 -1
  877. package/dist/service.d.ts +0 -144
  878. package/dist/service.d.ts.map +0 -1
  879. package/dist/service.js +0 -1303
  880. package/dist/service.js.map +0 -1
  881. package/dist/treasury.d.ts +0 -55
  882. package/dist/treasury.d.ts.map +0 -1
  883. package/dist/treasury.js +0 -393
  884. package/dist/treasury.js.map +0 -1
  885. package/dist/utils.d.ts +0 -94
  886. package/dist/utils.d.ts.map +0 -1
  887. package/dist/utils.js +0 -582
  888. package/dist/utils.js.map +0 -1
  889. package/dist/wowok.d.ts +0 -15
  890. package/dist/wowok.d.ts.map +0 -1
  891. package/dist/wowok.js +0 -66
  892. package/dist/wowok.js.map +0 -1
@@ -0,0 +1,1143 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
+ var __export = (target, all) => {
10
+ for (var name in all)
11
+ __defProp(target, name, { get: all[name], enumerable: true });
12
+ };
13
+ var __copyProps = (to, from, except, desc) => {
14
+ if (from && typeof from === "object" || typeof from === "function") {
15
+ for (let key of __getOwnPropNames(from))
16
+ if (!__hasOwnProp.call(to, key) && key !== except)
17
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
18
+ }
19
+ return to;
20
+ };
21
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
22
+ // If the importer is in node compatibility mode or this is not an ESM
23
+ // file that has been converted to a CommonJS file using a Babel-
24
+ // compatible transform (i.e. "__esModule" has not been set), then set
25
+ // "default" to the CommonJS "module.exports" for node compatibility.
26
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
27
+ mod
28
+ ));
29
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
30
+ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
31
+ var messenger_manager_exports = {};
32
+ __export(messenger_manager_exports, {
33
+ MessengerManager: () => MessengerManager
34
+ });
35
+ module.exports = __toCommonJS(messenger_manager_exports);
36
+ var import_messenger = require("./messenger.js");
37
+ var import_storage = require("./storage.js");
38
+ var import_storage2 = require("./storage.js");
39
+ var import_types = require("./types.js");
40
+ var import_types2 = require("./types.js");
41
+ var import_utils = require("./utils.js");
42
+ var import_account = require("../local/account.js");
43
+ var import_local = require("../local/index.js");
44
+ const MAX_ACCOUNTS = import_account.MAX_MESSENGER_ACCOUNTS;
45
+ class MessengerManager {
46
+ constructor(options) {
47
+ __publicField(this, "accounts", /* @__PURE__ */ new Map());
48
+ __publicField(this, "config");
49
+ __publicField(this, "messageListeners", /* @__PURE__ */ new Set());
50
+ __publicField(this, "pollingTimers", /* @__PURE__ */ new Map());
51
+ __publicField(this, "isWatching", false);
52
+ __publicField(this, "persistStorage");
53
+ __publicField(this, "instanceId");
54
+ __publicField(this, "accountRefreshTimer", null);
55
+ __publicField(this, "sseHeartbeatTimer", null);
56
+ __publicField(this, "sseLockedAccounts", /* @__PURE__ */ new Set());
57
+ this.config = {
58
+ ...import_types2.DEFAULT_MESSENGER_CONFIG,
59
+ ...options?.messengerConfig
60
+ };
61
+ this.instanceId = options?.instanceId || "default";
62
+ this.persistStorage = new import_storage2.MessengerPersistStorage();
63
+ }
64
+ findAccount(address) {
65
+ return this.accounts.get(address.toLowerCase());
66
+ }
67
+ getConfig() {
68
+ return this.config;
69
+ }
70
+ get_accounts() {
71
+ return Array.from(this.accounts.values()).map((acc) => acc.address);
72
+ }
73
+ async refresh_accounts() {
74
+ const { Account } = await import("../local/account.js");
75
+ const messengerAccounts = await Account.Instance().list_messenger_accounts();
76
+ const currentAddresses = new Set(this.accounts.keys());
77
+ const newAddresses = new Set(
78
+ messengerAccounts.map((a) => a.address.toLowerCase())
79
+ );
80
+ for (const address of currentAddresses) {
81
+ if (!newAddresses.has(address)) {
82
+ this.remove_account_internal(address);
83
+ }
84
+ }
85
+ for (const account of messengerAccounts) {
86
+ const addressLower = account.address.toLowerCase();
87
+ if (!this.accounts.has(addressLower)) {
88
+ await this.add_account_internal(account.address);
89
+ }
90
+ }
91
+ if (this.accounts.size > 0 && !this.isWatching) {
92
+ this.startPolling();
93
+ } else if (this.accounts.size === 0 && this.isWatching) {
94
+ this.stopPolling();
95
+ }
96
+ await this.syncAllContactLists();
97
+ }
98
+ async start() {
99
+ await this.refresh_accounts();
100
+ let hasSSEFailure = false;
101
+ for (const account of this.accounts.values()) {
102
+ if (!account.messenger.isEventSourceConnected()) {
103
+ try {
104
+ const hasLock = this.persistStorage.tryAcquireSSELock(
105
+ account.address,
106
+ this.instanceId
107
+ );
108
+ if (hasLock) {
109
+ this.sseLockedAccounts.add(
110
+ account.address.toLowerCase()
111
+ );
112
+ await account.messenger.connectEventSource(
113
+ (messages) => {
114
+ for (const listener of this.messageListeners) {
115
+ listener(messages);
116
+ }
117
+ }
118
+ );
119
+ } else {
120
+ console.debug(
121
+ `Another process holds SSE lock for ${account.address}, using polling`
122
+ );
123
+ hasSSEFailure = true;
124
+ }
125
+ } catch (err) {
126
+ console.warn(
127
+ `Failed to connect SSE for ${account.address}, falling back to polling:`,
128
+ err
129
+ );
130
+ hasSSEFailure = true;
131
+ this.persistStorage.releaseSSELock(
132
+ account.address,
133
+ this.instanceId
134
+ );
135
+ this.sseLockedAccounts.delete(
136
+ account.address.toLowerCase()
137
+ );
138
+ }
139
+ }
140
+ }
141
+ if (hasSSEFailure && !this.isWatching) {
142
+ this.startPolling();
143
+ }
144
+ this.startSSEHeartbeat();
145
+ if (this.accountRefreshTimer) {
146
+ clearInterval(this.accountRefreshTimer);
147
+ }
148
+ this.accountRefreshTimer = setInterval(() => {
149
+ this.refresh_accounts().catch((err) => {
150
+ console.error("Failed to refresh accounts:", err);
151
+ });
152
+ }, this.config.watch_interval_ms);
153
+ }
154
+ stop() {
155
+ if (this.accountRefreshTimer) {
156
+ clearInterval(this.accountRefreshTimer);
157
+ this.accountRefreshTimer = null;
158
+ }
159
+ this.stopSSEHeartbeat();
160
+ for (const accountAddress of this.sseLockedAccounts) {
161
+ this.persistStorage.releaseSSELock(accountAddress, this.instanceId);
162
+ }
163
+ this.sseLockedAccounts.clear();
164
+ this.stopPolling();
165
+ this.clear_accounts();
166
+ }
167
+ startSSEHeartbeat() {
168
+ if (this.sseHeartbeatTimer) {
169
+ clearInterval(this.sseHeartbeatTimer);
170
+ }
171
+ this.sseHeartbeatTimer = setInterval(() => {
172
+ for (const accountAddress of this.sseLockedAccounts) {
173
+ this.persistStorage.updateSSELockHeartbeat(
174
+ accountAddress,
175
+ this.instanceId
176
+ );
177
+ }
178
+ }, 5e3);
179
+ }
180
+ stopSSEHeartbeat() {
181
+ if (this.sseHeartbeatTimer) {
182
+ clearInterval(this.sseHeartbeatTimer);
183
+ this.sseHeartbeatTimer = null;
184
+ }
185
+ }
186
+ async add_account_internal(address) {
187
+ const addressLower = address.toLowerCase();
188
+ if (this.accounts.size >= MAX_ACCOUNTS) {
189
+ throw new import_types2.MessengerError(
190
+ import_types2.MessengerErrorCode.INVALID_INPUT,
191
+ `Maximum ${MAX_ACCOUNTS} accounts allowed`
192
+ );
193
+ }
194
+ const messenger = new import_messenger.Messenger(addressLower, this.config);
195
+ try {
196
+ await messenger.initialize();
197
+ } catch (error) {
198
+ throw new import_types2.MessengerError(
199
+ import_types2.MessengerErrorCode.SERVER_ERROR,
200
+ `Failed to initialize account ${addressLower}: ${error instanceof Error ? error.message : String(error)}`
201
+ );
202
+ }
203
+ const contactLists = {
204
+ friends: [],
205
+ guards: [],
206
+ lastUpdatedAt: 0
207
+ };
208
+ this.accounts.set(addressLower, {
209
+ address: addressLower,
210
+ messenger,
211
+ initialized: true,
212
+ contactLists
213
+ });
214
+ if (this.isWatching) {
215
+ this.startAccountPolling(addressLower);
216
+ }
217
+ }
218
+ remove_account_internal(address) {
219
+ const addressLower = address.toLowerCase();
220
+ const account = this.accounts.get(addressLower);
221
+ if (!account) return false;
222
+ if (account.initialized && account.messenger) {
223
+ account.messenger.disconnectEventSource();
224
+ account.messenger.disconnect();
225
+ }
226
+ const timer = this.pollingTimers.get(account.address);
227
+ if (timer) {
228
+ clearInterval(timer);
229
+ this.pollingTimers.delete(account.address);
230
+ }
231
+ this.persistStorage.releaseSSELock(addressLower, this.instanceId);
232
+ this.sseLockedAccounts.delete(addressLower);
233
+ return this.accounts.delete(addressLower);
234
+ }
235
+ clear_accounts() {
236
+ this.stopPolling();
237
+ for (const info of this.accounts.values()) {
238
+ info.messenger.disconnectEventSource();
239
+ info.messenger.disconnect();
240
+ }
241
+ this.accounts.clear();
242
+ }
243
+ async send(from, to, content, options) {
244
+ const { Account } = await import("../local/account.js");
245
+ let accountInfo = this.findAccount(from);
246
+ if (!accountInfo) {
247
+ const account = await Account.Instance().get(from, false);
248
+ if (!account) {
249
+ throw new import_types2.MessengerError(
250
+ import_types2.MessengerErrorCode.IDENTITY_NOT_FOUND,
251
+ `Account ${from} not found`
252
+ );
253
+ }
254
+ if (account.m == null) {
255
+ if (options?.new_messenger_name == null) {
256
+ throw new import_types2.MessengerError(
257
+ import_types2.MessengerErrorCode.ACCOUNT_MESSENGER_NOT_ENABLED,
258
+ `Account messenger name not set. Use new_messenger_name parameter to set it automatically.`
259
+ );
260
+ }
261
+ await Account.Instance().set_messenger(
262
+ from,
263
+ options.new_messenger_name
264
+ );
265
+ }
266
+ await this.refresh_accounts();
267
+ accountInfo = this.findAccount(from);
268
+ if (!accountInfo) {
269
+ throw new import_types2.MessengerError(
270
+ import_types2.MessengerErrorCode.SERVER_ERROR,
271
+ `Failed to add account ${from} to messenger manager`
272
+ );
273
+ }
274
+ }
275
+ if (options?.new_messenger_name != null) {
276
+ const account = await Account.Instance().get(from, false);
277
+ if (account && account.m !== options.new_messenger_name) {
278
+ await Account.Instance().set_messenger(
279
+ from,
280
+ options.new_messenger_name
281
+ );
282
+ }
283
+ }
284
+ return accountInfo.messenger.sendMessage(to, content, {
285
+ guardAddress: options?.guardAddress,
286
+ passportAddress: options?.passportAddress,
287
+ force: options?.force
288
+ });
289
+ }
290
+ async send_file(from, to, filePath, options) {
291
+ const { Account } = await import("../local/account.js");
292
+ let accountInfo = this.findAccount(from);
293
+ if (!accountInfo) {
294
+ const account = await Account.Instance().get(from, false);
295
+ if (!account) {
296
+ throw new import_types2.MessengerError(
297
+ import_types2.MessengerErrorCode.IDENTITY_NOT_FOUND,
298
+ `Account ${from} not found`
299
+ );
300
+ }
301
+ if (account.m == null) {
302
+ if (options?.new_messenger_name == null) {
303
+ throw new import_types2.MessengerError(
304
+ import_types2.MessengerErrorCode.ACCOUNT_MESSENGER_NOT_ENABLED,
305
+ `Account messenger name not set. Use new_messenger_name parameter to set it automatically.`
306
+ );
307
+ }
308
+ await Account.Instance().set_messenger(
309
+ from,
310
+ options.new_messenger_name
311
+ );
312
+ }
313
+ await this.refresh_accounts();
314
+ accountInfo = this.findAccount(from);
315
+ if (!accountInfo) {
316
+ throw new import_types2.MessengerError(
317
+ import_types2.MessengerErrorCode.SERVER_ERROR,
318
+ `Failed to add account ${from} to messenger manager`
319
+ );
320
+ }
321
+ }
322
+ if (options?.new_messenger_name != null) {
323
+ const account = await Account.Instance().get(from, false);
324
+ if (account && account.m !== options.new_messenger_name) {
325
+ await Account.Instance().set_messenger(
326
+ from,
327
+ options.new_messenger_name
328
+ );
329
+ }
330
+ }
331
+ return accountInfo.messenger.sendZipFile(to, filePath, {
332
+ fileName: options?.fileName,
333
+ contentType: options?.contentType,
334
+ guardAddress: options?.guardAddress,
335
+ passportAddress: options?.passportAddress,
336
+ force: options?.force
337
+ });
338
+ }
339
+ async watch(filter) {
340
+ let messages = [];
341
+ if (filter?.account) {
342
+ const address = filter.account.toLowerCase();
343
+ const messageStorage = new import_storage.MessageStorage(address);
344
+ messages = messageStorage.getAllMessages(address);
345
+ } else {
346
+ for (const account of this.accounts.values()) {
347
+ const messageStorage = new import_storage.MessageStorage(account.address);
348
+ const accountMessages = messageStorage.getAllMessages(
349
+ account.address
350
+ );
351
+ messages.push(...accountMessages);
352
+ }
353
+ }
354
+ if (filter) {
355
+ const peerAddress = filter.peerAddress ? await (0, import_local.GetAccountOrMark_Address)(filter.peerAddress) : void 0;
356
+ messages = messages.filter((msg) => {
357
+ if (filter.account) {
358
+ const accountLower = filter.account.toLowerCase();
359
+ const fromLower = msg.fromAddress.toLowerCase();
360
+ const toLower = msg.toAddress.toLowerCase();
361
+ if (fromLower !== accountLower && toLower !== accountLower) {
362
+ return false;
363
+ }
364
+ }
365
+ if (filter.direction && msg.direction !== filter.direction) {
366
+ return false;
367
+ }
368
+ if (filter.status && msg.status !== filter.status) {
369
+ return false;
370
+ }
371
+ if (filter.msgType !== void 0 && msg.msgType !== filter.msgType) {
372
+ return false;
373
+ }
374
+ if (filter.contentType) {
375
+ switch (filter.contentType) {
376
+ case "text":
377
+ if (msg.msgType !== import_types.MessageType.NORMAL_MESSAGE)
378
+ return false;
379
+ break;
380
+ case "zip":
381
+ if (!msg.zipMetadata) return false;
382
+ break;
383
+ case "wts":
384
+ if (!msg.zipMetadata || msg.zipMetadata?.contentType !== "wts") {
385
+ return false;
386
+ }
387
+ break;
388
+ case "wip":
389
+ if (!msg.zipMetadata || msg.zipMetadata?.contentType !== "wip") {
390
+ return false;
391
+ }
392
+ break;
393
+ }
394
+ }
395
+ if (filter.peerAddress && peerAddress) {
396
+ const peer = peerAddress.toLowerCase();
397
+ const from = msg.fromAddress.toLowerCase();
398
+ const to = msg.toAddress.toLowerCase();
399
+ if (from !== peer && to !== peer) {
400
+ return false;
401
+ }
402
+ }
403
+ const timeField = filter.timeField || "createdAt";
404
+ if (filter.startTime !== void 0 || filter.endTime !== void 0) {
405
+ const msgTime = msg[timeField];
406
+ if (msgTime !== void 0) {
407
+ if (filter.startTime !== void 0 && msgTime < filter.startTime) {
408
+ return false;
409
+ }
410
+ if (filter.endTime !== void 0 && msgTime > filter.endTime) {
411
+ return false;
412
+ }
413
+ }
414
+ }
415
+ if (filter.createdAtStart !== void 0 && msg.createdAt < filter.createdAtStart) {
416
+ return false;
417
+ }
418
+ if (filter.createdAtEnd !== void 0 && msg.createdAt > filter.createdAtEnd) {
419
+ return false;
420
+ }
421
+ if (filter.receivedAtStart !== void 0) {
422
+ if (msg.receivedAt === void 0 || msg.receivedAt < filter.receivedAtStart) {
423
+ return false;
424
+ }
425
+ }
426
+ if (filter.receivedAtEnd !== void 0) {
427
+ if (msg.receivedAt === void 0 || msg.receivedAt > filter.receivedAtEnd) {
428
+ return false;
429
+ }
430
+ }
431
+ if (filter.serverTimestampStart !== void 0) {
432
+ if (msg.serverTimestamp === void 0 || msg.serverTimestamp < filter.serverTimestampStart) {
433
+ return false;
434
+ }
435
+ }
436
+ if (filter.serverTimestampEnd !== void 0) {
437
+ if (msg.serverTimestamp === void 0 || msg.serverTimestamp > filter.serverTimestampEnd) {
438
+ return false;
439
+ }
440
+ }
441
+ if (filter.decryptedOnly && !msg.plaintext) {
442
+ return false;
443
+ }
444
+ if (filter.arkConfirmedOnly) {
445
+ if (!msg.arkConfirmed) {
446
+ return false;
447
+ }
448
+ }
449
+ if (filter.proofedOnly) {
450
+ if (!msg.proof) {
451
+ return false;
452
+ }
453
+ }
454
+ if (filter.arkTimestampStart !== void 0) {
455
+ if (msg.arkConfirmed === void 0 || msg.arkConfirmed.timestamp < filter.arkTimestampStart) {
456
+ return false;
457
+ }
458
+ }
459
+ if (filter.arkTimestampEnd !== void 0) {
460
+ if (msg.arkConfirmed === void 0 || msg.arkConfirmed.timestamp > filter.arkTimestampEnd) {
461
+ return false;
462
+ }
463
+ }
464
+ if (filter.hasLastReceivedIndexOnly) {
465
+ if (msg.lastReceivedLeafIndex === void 0 || msg.lastReceivedLeafIndex === null) {
466
+ return false;
467
+ }
468
+ }
469
+ if (filter.lastReceivedIndexMin !== void 0) {
470
+ if (msg.lastReceivedLeafIndex === void 0 || msg.lastReceivedLeafIndex < filter.lastReceivedIndexMin) {
471
+ return false;
472
+ }
473
+ }
474
+ if (filter.lastReceivedIndexMax !== void 0) {
475
+ if (msg.lastReceivedLeafIndex === void 0 || msg.lastReceivedLeafIndex > filter.lastReceivedIndexMax) {
476
+ return false;
477
+ }
478
+ }
479
+ if (filter.keyword && msg.plaintext) {
480
+ if (!msg.plaintext.toLowerCase().includes(filter.keyword.toLowerCase())) {
481
+ return false;
482
+ }
483
+ }
484
+ if (filter.listFilterMode && filter.listFilterMode !== "any") {
485
+ const msgAccount = this.findAccount(msg.toAddress);
486
+ if (!msgAccount) return false;
487
+ const senderAddress = msg.fromAddress.toLowerCase();
488
+ const lists = msgAccount.contactLists;
489
+ const friends = new Set(
490
+ lists.friends.map((a) => a.toLowerCase())
491
+ );
492
+ const guards = new Set(
493
+ lists.guards.map((g) => g.guardAddress.toLowerCase())
494
+ );
495
+ const inFriends = friends.has(senderAddress);
496
+ const inGuards = guards.has(senderAddress);
497
+ const isStranger = !inFriends && !inGuards;
498
+ switch (filter.listFilterMode) {
499
+ case "friends":
500
+ if (!inFriends) return false;
501
+ break;
502
+ case "guard":
503
+ if (!inGuards) return false;
504
+ break;
505
+ case "stranger":
506
+ if (!isStranger) return false;
507
+ break;
508
+ }
509
+ if (filter.customListFilter) {
510
+ const {
511
+ includeAddresses,
512
+ excludeAddresses,
513
+ relation = "union"
514
+ } = filter.customListFilter;
515
+ if (excludeAddresses) {
516
+ const excludeSet = new Set(
517
+ excludeAddresses.map((a) => a.toLowerCase())
518
+ );
519
+ if (excludeSet.has(senderAddress)) return false;
520
+ }
521
+ if (includeAddresses && includeAddresses.length > 0) {
522
+ const includeSet = new Set(
523
+ includeAddresses.map((a) => a.toLowerCase())
524
+ );
525
+ const inIncludeList = includeSet.has(senderAddress);
526
+ if (relation === "union") {
527
+ const modeMatch = filter.listFilterMode === "friends" && inFriends || filter.listFilterMode === "guard" && inGuards || filter.listFilterMode === "stranger" && isStranger;
528
+ if (!inIncludeList && !modeMatch) return false;
529
+ } else {
530
+ if (!inIncludeList) return false;
531
+ }
532
+ }
533
+ }
534
+ }
535
+ return true;
536
+ });
537
+ }
538
+ const sortOrder = filter?.sortOrder ?? "desc";
539
+ const sortField = filter?.timeField || "createdAt";
540
+ messages.sort((a, b) => {
541
+ const aTime = a[sortField] || 0;
542
+ const bTime = b[sortField] || 0;
543
+ return sortOrder === "asc" ? aTime - bTime : bTime - aTime;
544
+ });
545
+ const { MAX_QUERY_LIMIT } = await import("./types.js");
546
+ const defaultLimit = this.config.defaultQueryLimit ?? 50;
547
+ const limit = Math.min(filter?.limit ?? defaultLimit, MAX_QUERY_LIMIT);
548
+ const offset = filter?.offset ?? 0;
549
+ messages = messages.slice(offset, offset + limit);
550
+ return messages;
551
+ }
552
+ startPolling() {
553
+ if (this.isWatching) return;
554
+ this.isWatching = true;
555
+ for (const info of this.accounts.values()) {
556
+ const timer = setInterval(async () => {
557
+ try {
558
+ const messages = await info.messenger.pullMessages();
559
+ if (messages.length > 0) {
560
+ for (const listener of this.messageListeners) {
561
+ listener(messages);
562
+ }
563
+ }
564
+ } catch (error) {
565
+ console.error(
566
+ `Failed to poll messages for ${info.address}:`,
567
+ error
568
+ );
569
+ }
570
+ }, this.config.watch_interval_ms);
571
+ this.pollingTimers.set(info.address, timer);
572
+ }
573
+ }
574
+ startAccountPolling(address) {
575
+ const info = this.accounts.get(address.toLowerCase());
576
+ if (!info || !info.initialized) return;
577
+ const existingTimer = this.pollingTimers.get(info.address);
578
+ if (existingTimer) {
579
+ clearInterval(existingTimer);
580
+ }
581
+ const timer = setInterval(async () => {
582
+ try {
583
+ const messages = await info.messenger.pullMessages();
584
+ if (messages.length > 0) {
585
+ for (const listener of this.messageListeners) {
586
+ listener(messages);
587
+ }
588
+ }
589
+ } catch (error) {
590
+ console.error(
591
+ `Failed to poll messages for ${info.address}:`,
592
+ error
593
+ );
594
+ }
595
+ }, this.config.watch_interval_ms);
596
+ this.pollingTimers.set(info.address, timer);
597
+ }
598
+ stopPolling() {
599
+ for (const timer of this.pollingTimers.values()) {
600
+ clearInterval(timer);
601
+ }
602
+ this.pollingTimers.clear();
603
+ this.isWatching = false;
604
+ }
605
+ onMessage(listener) {
606
+ this.messageListeners.add(listener);
607
+ }
608
+ offMessage(listener) {
609
+ this.messageListeners.delete(listener);
610
+ }
611
+ destroy() {
612
+ this.stop();
613
+ this.messageListeners.clear();
614
+ }
615
+ async syncContactLists(account) {
616
+ const acc = this.findAccount(account);
617
+ if (!acc) {
618
+ return {
619
+ success: false,
620
+ friends: [],
621
+ guards: [],
622
+ error: `Account not found: ${account}`
623
+ };
624
+ }
625
+ try {
626
+ const { Account } = await import("../local/account.js");
627
+ const accountData = await Account.Instance().get(account, false);
628
+ if (!accountData?.address) {
629
+ return {
630
+ success: false,
631
+ friends: [],
632
+ guards: [],
633
+ error: `Account data not found: ${account}`
634
+ };
635
+ }
636
+ const address = accountData.address;
637
+ const [friends, guards] = await Promise.all([
638
+ this.fetchFriendsList(address),
639
+ this.fetchGuardList(address)
640
+ ]);
641
+ acc.contactLists = {
642
+ friends,
643
+ guards,
644
+ lastUpdatedAt: Date.now()
645
+ };
646
+ return {
647
+ success: true,
648
+ friends,
649
+ guards
650
+ };
651
+ } catch (error) {
652
+ console.error(
653
+ `Failed to sync contact lists for ${account}:`,
654
+ error
655
+ );
656
+ return {
657
+ success: false,
658
+ friends: acc.contactLists.friends,
659
+ guards: acc.contactLists.guards,
660
+ error: error instanceof Error ? error.message : String(error)
661
+ };
662
+ }
663
+ }
664
+ async syncAllContactLists() {
665
+ const results = /* @__PURE__ */ new Map();
666
+ for (const acc of this.accounts.values()) {
667
+ const result = await this.syncContactLists(acc.address);
668
+ results.set(acc.address, result);
669
+ }
670
+ return results;
671
+ }
672
+ getContactLists(account) {
673
+ const acc = this.findAccount(account);
674
+ return acc?.contactLists;
675
+ }
676
+ setContactLists(account, lists) {
677
+ const acc = this.findAccount(account);
678
+ if (!acc) return false;
679
+ acc.contactLists = {
680
+ ...acc.contactLists,
681
+ ...lists,
682
+ lastUpdatedAt: Date.now()
683
+ };
684
+ return true;
685
+ }
686
+ isStranger(account, senderAddress) {
687
+ const acc = this.findAccount(account);
688
+ if (!acc) return true;
689
+ const sender = senderAddress.toLowerCase();
690
+ const lists = acc.contactLists;
691
+ const inFriends = lists.friends.some((a) => a.toLowerCase() === sender);
692
+ const inGuards = lists.guards.some(
693
+ (g) => g.guardAddress.toLowerCase() === sender
694
+ );
695
+ return !inFriends && !inGuards;
696
+ }
697
+ recordGuardSender(account, guardAddress) {
698
+ const acc = this.findAccount(account);
699
+ if (!acc) return false;
700
+ const guardAddr = guardAddress.toLowerCase();
701
+ const exists = acc.contactLists.guards.some(
702
+ (g) => g.guardAddress.toLowerCase() === guardAddr
703
+ );
704
+ if (!exists) {
705
+ acc.contactLists.guards.push({
706
+ guardAddress,
707
+ passportValiditySeconds: 86400
708
+ });
709
+ acc.contactLists.lastUpdatedAt = Date.now();
710
+ }
711
+ return true;
712
+ }
713
+ async fetchFriendsList(address) {
714
+ try {
715
+ const response = await fetch(
716
+ `${this.config.serverUrl}/v1/spam-protection/${address}/friends-list`,
717
+ {
718
+ method: "POST",
719
+ headers: { "Content-Type": "application/json" },
720
+ body: JSON.stringify({
721
+ userAddress: address,
722
+ signature: "",
723
+ timestamp: Date.now(),
724
+ nonce: this.generateNonce()
725
+ })
726
+ }
727
+ );
728
+ if (!response.ok) {
729
+ throw new Error(`HTTP ${response.status}`);
730
+ }
731
+ return await response.json();
732
+ } catch (error) {
733
+ return [];
734
+ }
735
+ }
736
+ async fetchGuardList(address) {
737
+ try {
738
+ const response = await fetch(
739
+ `${this.config.serverUrl}/v1/spam-protection/${address}/guard-list`,
740
+ {
741
+ method: "POST",
742
+ headers: { "Content-Type": "application/json" },
743
+ body: JSON.stringify({
744
+ userAddress: address,
745
+ signature: "",
746
+ timestamp: Date.now(),
747
+ nonce: this.generateNonce()
748
+ })
749
+ }
750
+ );
751
+ if (!response.ok) {
752
+ throw new Error(`HTTP ${response.status}`);
753
+ }
754
+ return await response.json();
755
+ } catch (error) {
756
+ return [];
757
+ }
758
+ }
759
+ generateNonce() {
760
+ return Math.random().toString(36).substring(2, 15) + Math.random().toString(36).substring(2, 15);
761
+ }
762
+ async watch_paginated(filter) {
763
+ const { MAX_QUERY_LIMIT } = await import("./types.js");
764
+ const allMessages = await this.watch(filter);
765
+ const total = allMessages.length;
766
+ const defaultLimit = this.config.defaultQueryLimit ?? 50;
767
+ const limit = Math.min(filter?.limit ?? defaultLimit, MAX_QUERY_LIMIT);
768
+ const offset = filter?.offset ?? 0;
769
+ const messages = allMessages.slice(offset, offset + limit);
770
+ return {
771
+ messages,
772
+ total,
773
+ offset,
774
+ limit
775
+ };
776
+ }
777
+ async get_conversations(account) {
778
+ const filter = account ? { account } : void 0;
779
+ const allMessages = await this.watch(filter);
780
+ const conversations = /* @__PURE__ */ new Map();
781
+ for (const msg of allMessages) {
782
+ const myAddress = account?.toLowerCase();
783
+ const peerAddress = msg.fromAddress.toLowerCase() === myAddress ? msg.toAddress : msg.fromAddress;
784
+ if (!conversations.has(peerAddress)) {
785
+ conversations.set(peerAddress, {
786
+ peerAddress,
787
+ lastMessageAt: msg.createdAt,
788
+ messageCount: 0,
789
+ unreadCount: 0,
790
+ lastMessagePreview: msg.plaintext
791
+ });
792
+ }
793
+ const conv = conversations.get(peerAddress);
794
+ conv.messageCount++;
795
+ if (msg.createdAt > conv.lastMessageAt) {
796
+ conv.lastMessageAt = msg.createdAt;
797
+ conv.lastMessagePreview = msg.plaintext;
798
+ }
799
+ if (msg.status !== import_types.MessageStatus.READ && msg.toAddress.toLowerCase() === myAddress) {
800
+ conv.unreadCount++;
801
+ }
802
+ }
803
+ return Array.from(conversations.values()).sort(
804
+ (a, b) => b.lastMessageAt - a.lastMessageAt
805
+ );
806
+ }
807
+ async generate_wts(params) {
808
+ const fs = await import("fs");
809
+ const path = await import("path");
810
+ const myAddress = params.myAccount.toLowerCase();
811
+ const peerAddress = params.peerAccount.toLowerCase();
812
+ const messageStorage = new import_storage.MessageStorage(myAddress);
813
+ const myMessages = messageStorage.getAllMessages(myAddress);
814
+ let messages = myMessages.filter((msg) => {
815
+ const fromLower = msg.fromAddress.toLowerCase();
816
+ const toLower = msg.toAddress.toLowerCase();
817
+ const isBetween = fromLower === myAddress && toLower === peerAddress || fromLower === peerAddress && toLower === myAddress;
818
+ return isBetween;
819
+ });
820
+ messages = messages.filter(
821
+ (m) => m.leafIndex !== void 0 && m.serverTimestamp !== void 0
822
+ ).reduce((acc, msg) => {
823
+ const existing = acc.find((m) => m.messageId === msg.messageId);
824
+ if (!existing) {
825
+ acc.push(msg);
826
+ }
827
+ return acc;
828
+ }, []).sort((a, b) => {
829
+ return a.leafIndex - b.leafIndex;
830
+ });
831
+ const leafIndexMap = /* @__PURE__ */ new Map();
832
+ for (const msg of messages) {
833
+ const idx = msg.leafIndex;
834
+ if (!leafIndexMap.has(idx)) {
835
+ leafIndexMap.set(idx, []);
836
+ }
837
+ leafIndexMap.get(idx).push(msg);
838
+ }
839
+ const duplicates = Array.from(leafIndexMap.entries()).filter(
840
+ ([, msgs]) => msgs.length > 1
841
+ );
842
+ if (duplicates.length > 0) {
843
+ messages.sort(
844
+ (a, b) => (b.serverTimestamp || 0) - (a.serverTimestamp || 0)
845
+ );
846
+ const seenLeafIndices = /* @__PURE__ */ new Set();
847
+ const uniqueMessages = [];
848
+ for (const msg of messages) {
849
+ const idx = msg.leafIndex;
850
+ if (!seenLeafIndices.has(idx)) {
851
+ seenLeafIndices.add(idx);
852
+ uniqueMessages.push(msg);
853
+ }
854
+ }
855
+ messages = uniqueMessages.sort(
856
+ (a, b) => a.leafIndex - b.leafIndex
857
+ );
858
+ }
859
+ if (params.range) {
860
+ switch (params.range.type) {
861
+ case "time": {
862
+ const start = Math.min(
863
+ params.range.start,
864
+ params.range.end
865
+ );
866
+ const end = Math.max(params.range.start, params.range.end);
867
+ messages = messages.filter(
868
+ (m) => m.createdAt >= start && m.createdAt <= end
869
+ );
870
+ break;
871
+ }
872
+ case "messageId": {
873
+ const start = params.range.start;
874
+ const end = params.range.end;
875
+ messages = messages.filter(
876
+ (m) => m.messageId >= start && m.messageId <= end
877
+ );
878
+ break;
879
+ }
880
+ case "seqIndex": {
881
+ const start = Math.min(
882
+ params.range.start,
883
+ params.range.end
884
+ );
885
+ const end = Math.max(params.range.start, params.range.end);
886
+ messages = messages.filter(
887
+ (m) => m.leafIndex >= start && m.leafIndex <= end
888
+ );
889
+ break;
890
+ }
891
+ }
892
+ }
893
+ if (messages.length === 0) {
894
+ throw new import_types2.MessengerError(
895
+ import_types2.MessengerErrorCode.INVALID_INPUT,
896
+ "No messages found for the given criteria"
897
+ );
898
+ }
899
+ if (messages.length > import_types.WTS_MAX_MESSAGE_COUNT) {
900
+ throw new import_types2.MessengerError(
901
+ import_types2.MessengerErrorCode.INVALID_INPUT,
902
+ `Message count (${messages.length}) exceeds maximum allowed (${import_types.WTS_MAX_MESSAGE_COUNT})`
903
+ );
904
+ }
905
+ if (!fs.existsSync(params.outputDir)) {
906
+ fs.mkdirSync(params.outputDir, { recursive: true });
907
+ }
908
+ const sessionId = `${myAddress.slice(0, 6)}_${peerAddress.slice(0, 6)}`;
909
+ const groups = [messages];
910
+ const generatedFiles = [];
911
+ const startTime = messages[0].createdAt;
912
+ const endTime = messages[messages.length - 1].createdAt;
913
+ for (const group of groups) {
914
+ const leafIndices = group.map((m) => m.leafIndex).filter((i) => i !== void 0);
915
+ const startLeafIndex = Math.min(...leafIndices);
916
+ const endLeafIndex = Math.max(...leafIndices);
917
+ for (const msg of group) {
918
+ if (msg.serverTimestamp === void 0) {
919
+ throw new import_types2.MessengerError(
920
+ import_types2.MessengerErrorCode.INVALID_INPUT,
921
+ `Message ${msg.messageId} missing serverTimestamp`
922
+ );
923
+ }
924
+ if (msg.leafIndex === void 0) {
925
+ throw new import_types2.MessengerError(
926
+ import_types2.MessengerErrorCode.INVALID_INPUT,
927
+ `Message ${msg.messageId} missing leafIndex`
928
+ );
929
+ }
930
+ if (!msg.prevRoot) {
931
+ throw new import_types2.MessengerError(
932
+ import_types2.MessengerErrorCode.INVALID_INPUT,
933
+ `Message ${msg.messageId} missing prevRoot`
934
+ );
935
+ }
936
+ if (!msg.newRoot) {
937
+ throw new import_types2.MessengerError(
938
+ import_types2.MessengerErrorCode.INVALID_INPUT,
939
+ `Message ${msg.messageId} missing newRoot`
940
+ );
941
+ }
942
+ if (!msg.serverSignature) {
943
+ throw new import_types2.MessengerError(
944
+ import_types2.MessengerErrorCode.INVALID_INPUT,
945
+ `Message ${msg.messageId} missing serverSignature`
946
+ );
947
+ }
948
+ }
949
+ const wtsMessages = group.map((msg) => ({
950
+ id: msg.messageId,
951
+ from: msg.fromAddress,
952
+ to: msg.toAddress,
953
+ plaintext: params.excludePlaintext ? void 0 : msg.plaintext,
954
+ plaintextHash: msg.plaintextHash,
955
+ clientTimestamp: msg.createdAt,
956
+ timestamp: msg.serverTimestamp,
957
+ leafIndex: msg.leafIndex,
958
+ prevRoot: msg.prevRoot,
959
+ merkleRoot: msg.newRoot,
960
+ serverSignature: msg.serverSignature,
961
+ serverPublicKey: msg.serverPublicKey || "",
962
+ guardAddress: msg.guardAddress,
963
+ passportAddress: msg.passportAddress,
964
+ lastReceivedLeafIndex: msg.lastReceivedLeafIndex,
965
+ arkConfirmed: msg.arkConfirmed ? {
966
+ recipient: msg.arkConfirmed.recipient,
967
+ recipientPublicKey: msg.arkConfirmed.recipientPublicKey,
968
+ signature: msg.arkConfirmed.signature,
969
+ timestamp: msg.arkConfirmed.timestamp
970
+ } : void 0,
971
+ msgType: msg.msgType,
972
+ zipMetadata: msg.zipMetadata
973
+ }));
974
+ const addresses = [myAddress, peerAddress].sort();
975
+ const wtsSession = {
976
+ id: `${addresses[0]}:${addresses[1]}`,
977
+ participants: addresses
978
+ };
979
+ const payload = {
980
+ session: wtsSession,
981
+ messages: wtsMessages
982
+ };
983
+ const wtsMeta = {
984
+ type: "wts",
985
+ version: "1.0",
986
+ created: (/* @__PURE__ */ new Date()).toISOString(),
987
+ hash: "",
988
+ algorithm: "sha256",
989
+ startTime,
990
+ endTime,
991
+ messageCount: wtsMessages.length,
992
+ merkleRoot: wtsMessages[wtsMessages.length - 1].merkleRoot
993
+ };
994
+ const wtsFile = {
995
+ wts: (0, import_utils.canonicalizeJson)(wtsMeta),
996
+ payload,
997
+ meta: wtsMeta
998
+ };
999
+ const fileName = `${sessionId}_${startLeafIndex}-${endLeafIndex}.wts`;
1000
+ const filePath = path.join(params.outputDir, fileName);
1001
+ fs.writeFileSync(filePath, JSON.stringify(wtsFile, null, 2));
1002
+ generatedFiles.push(filePath);
1003
+ }
1004
+ return {
1005
+ files: generatedFiles,
1006
+ totalMessageCount: messages.length,
1007
+ timeRange: {
1008
+ start: startTime,
1009
+ end: endTime
1010
+ }
1011
+ };
1012
+ }
1013
+ async addToBlacklist(account, addresses) {
1014
+ const acc = this.findAccount(account);
1015
+ if (!acc) {
1016
+ throw new import_types2.MessengerError(
1017
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1018
+ `Account ${account} not in managed accounts`
1019
+ );
1020
+ }
1021
+ return acc.messenger.addToBlacklist(addresses);
1022
+ }
1023
+ async removeFromBlacklist(account, addresses) {
1024
+ const acc = this.findAccount(account);
1025
+ if (!acc) {
1026
+ throw new import_types2.MessengerError(
1027
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1028
+ `Account ${account} not in managed accounts`
1029
+ );
1030
+ }
1031
+ return acc.messenger.removeFromBlacklist(addresses);
1032
+ }
1033
+ async clearBlacklist(account) {
1034
+ const acc = this.findAccount(account);
1035
+ if (!acc) {
1036
+ throw new import_types2.MessengerError(
1037
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1038
+ `Account ${account} not in managed accounts`
1039
+ );
1040
+ }
1041
+ return acc.messenger.clearBlacklist();
1042
+ }
1043
+ async getBlacklist(account) {
1044
+ const acc = this.findAccount(account);
1045
+ if (!acc) {
1046
+ throw new import_types2.MessengerError(
1047
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1048
+ `Account ${account} not in managed accounts`
1049
+ );
1050
+ }
1051
+ return acc.messenger.getBlacklist();
1052
+ }
1053
+ async existInBlacklist(account, addresses) {
1054
+ const acc = this.findAccount(account);
1055
+ if (!acc) {
1056
+ throw new import_types2.MessengerError(
1057
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1058
+ `Account ${account} not in managed accounts`
1059
+ );
1060
+ }
1061
+ return acc.messenger.existInBlacklist(addresses);
1062
+ }
1063
+ async addToFriendsList(account, addresses) {
1064
+ const acc = this.findAccount(account);
1065
+ if (!acc) {
1066
+ throw new import_types2.MessengerError(
1067
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1068
+ `Account ${account} not in managed accounts`
1069
+ );
1070
+ }
1071
+ return acc.messenger.addToFriendsList(addresses);
1072
+ }
1073
+ async removeFromFriendsList(account, addresses) {
1074
+ const acc = this.findAccount(account);
1075
+ if (!acc) {
1076
+ throw new import_types2.MessengerError(
1077
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1078
+ `Account ${account} not in managed accounts`
1079
+ );
1080
+ }
1081
+ return acc.messenger.removeFromFriendsList(addresses);
1082
+ }
1083
+ async clearFriendsList(account) {
1084
+ const acc = this.findAccount(account);
1085
+ if (!acc) {
1086
+ throw new import_types2.MessengerError(
1087
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1088
+ `Account ${account} not in managed accounts`
1089
+ );
1090
+ }
1091
+ return acc.messenger.clearFriendsList();
1092
+ }
1093
+ async getFriendsList(account) {
1094
+ const acc = this.findAccount(account);
1095
+ if (!acc) {
1096
+ throw new import_types2.MessengerError(
1097
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1098
+ `Account ${account} not in managed accounts`
1099
+ );
1100
+ }
1101
+ return acc.messenger.getFriendsList();
1102
+ }
1103
+ async existInFriendsList(account, addresses) {
1104
+ const acc = this.findAccount(account);
1105
+ if (!acc) {
1106
+ throw new import_types2.MessengerError(
1107
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1108
+ `Account ${account} not in managed accounts`
1109
+ );
1110
+ }
1111
+ return acc.messenger.existInFriendsList(addresses);
1112
+ }
1113
+ async addToGuardList(account, guards) {
1114
+ const acc = this.findAccount(account);
1115
+ if (!acc) {
1116
+ throw new import_types2.MessengerError(
1117
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1118
+ `Account ${account} not in managed accounts`
1119
+ );
1120
+ }
1121
+ return acc.messenger.addToGuardList(guards);
1122
+ }
1123
+ async removeFromGuardList(account, addresses) {
1124
+ const acc = this.findAccount(account);
1125
+ if (!acc) {
1126
+ throw new import_types2.MessengerError(
1127
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1128
+ `Account ${account} not in managed accounts`
1129
+ );
1130
+ }
1131
+ return acc.messenger.removeFromGuardList(addresses);
1132
+ }
1133
+ async getGuardList(account) {
1134
+ const acc = this.findAccount(account);
1135
+ if (!acc) {
1136
+ throw new import_types2.MessengerError(
1137
+ import_types2.MessengerErrorCode.ACCOUNT_NOT_FOUND,
1138
+ `Account ${account} not in managed accounts`
1139
+ );
1140
+ }
1141
+ return acc.messenger.getGuardList();
1142
+ }
1143
+ }