@aztec/foundation 0.7.2 → 0.7.3

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 (351) hide show
  1. package/.tsbuildinfo +1 -0
  2. package/dest/abi/abi.d.ts +232 -0
  3. package/dest/abi/abi.d.ts.map +1 -0
  4. package/dest/abi/abi.js +37 -0
  5. package/dest/abi/abi_coder.d.ts +8 -0
  6. package/dest/abi/abi_coder.d.ts.map +1 -0
  7. package/dest/abi/abi_coder.js +24 -0
  8. package/dest/abi/decoder.d.ts +57 -0
  9. package/dest/abi/decoder.d.ts.map +1 -0
  10. package/dest/abi/decoder.js +149 -0
  11. package/dest/abi/decoder.test.d.ts +2 -0
  12. package/dest/abi/decoder.test.d.ts.map +1 -0
  13. package/dest/abi/decoder.test.js +70 -0
  14. package/dest/abi/encoder.d.ts +10 -0
  15. package/dest/abi/encoder.d.ts.map +1 -0
  16. package/dest/abi/encoder.js +89 -0
  17. package/dest/abi/encoder.test.d.ts +2 -0
  18. package/dest/abi/encoder.test.d.ts.map +1 -0
  19. package/dest/abi/encoder.test.js +74 -0
  20. package/dest/abi/function_selector.d.ts +73 -0
  21. package/dest/abi/function_selector.d.ts.map +1 -0
  22. package/dest/abi/function_selector.js +104 -0
  23. package/dest/abi/index.d.ts +6 -0
  24. package/dest/abi/index.d.ts.map +1 -0
  25. package/dest/abi/index.js +6 -0
  26. package/dest/async-map/async_map.test.d.ts +2 -0
  27. package/dest/async-map/async_map.test.d.ts.map +1 -0
  28. package/dest/async-map/async_map.test.js +9 -0
  29. package/dest/async-map/index.d.ts +13 -0
  30. package/dest/async-map/index.d.ts.map +1 -0
  31. package/dest/async-map/index.js +19 -0
  32. package/dest/aztec-address/index.d.ts +114 -0
  33. package/dest/aztec-address/index.d.ts.map +1 -0
  34. package/dest/aztec-address/index.js +148 -0
  35. package/dest/bigint-buffer/bigint-buffer.test.d.ts +2 -0
  36. package/dest/bigint-buffer/bigint-buffer.test.d.ts.map +1 -0
  37. package/dest/bigint-buffer/bigint-buffer.test.js +18 -0
  38. package/dest/bigint-buffer/index.d.ts +35 -0
  39. package/dest/bigint-buffer/index.d.ts.map +1 -0
  40. package/dest/bigint-buffer/index.js +68 -0
  41. package/dest/collection/array.d.ts +30 -0
  42. package/dest/collection/array.d.ts.map +1 -0
  43. package/dest/collection/array.js +47 -0
  44. package/dest/collection/index.d.ts +2 -0
  45. package/dest/collection/index.d.ts.map +1 -0
  46. package/dest/collection/index.js +2 -0
  47. package/dest/committable/committable.d.ts +28 -0
  48. package/dest/committable/committable.d.ts.map +1 -0
  49. package/dest/committable/committable.js +41 -0
  50. package/dest/committable/committable.test.d.ts +2 -0
  51. package/dest/committable/committable.test.d.ts.map +1 -0
  52. package/dest/committable/committable.test.js +26 -0
  53. package/dest/committable/index.d.ts +2 -0
  54. package/dest/committable/index.d.ts.map +1 -0
  55. package/dest/committable/index.js +2 -0
  56. package/dest/crypto/index.d.ts +4 -0
  57. package/dest/crypto/index.d.ts.map +1 -0
  58. package/dest/crypto/index.js +4 -0
  59. package/dest/crypto/keccak/index.d.ts +20 -0
  60. package/dest/crypto/keccak/index.d.ts.map +1 -0
  61. package/dest/crypto/keccak/index.js +31 -0
  62. package/dest/crypto/random/index.d.ts +3 -0
  63. package/dest/crypto/random/index.d.ts.map +1 -0
  64. package/dest/crypto/random/index.js +36 -0
  65. package/dest/crypto/random/index.test.d.ts +2 -0
  66. package/dest/crypto/random/index.test.d.ts.map +1 -0
  67. package/dest/crypto/random/index.test.js +13 -0
  68. package/dest/crypto/sha256/index.d.ts +11 -0
  69. package/dest/crypto/sha256/index.d.ts.map +1 -0
  70. package/dest/crypto/sha256/index.js +14 -0
  71. package/dest/crypto/sha256/index.test.d.ts +2 -0
  72. package/dest/crypto/sha256/index.test.d.ts.map +1 -0
  73. package/dest/crypto/sha256/index.test.js +11 -0
  74. package/dest/errors/index.d.ts +8 -0
  75. package/dest/errors/index.d.ts.map +1 -0
  76. package/dest/errors/index.js +8 -0
  77. package/dest/eth-address/eth_address.test.d.ts +2 -0
  78. package/dest/eth-address/eth_address.test.d.ts.map +1 -0
  79. package/dest/eth-address/eth_address.test.js +95 -0
  80. package/dest/eth-address/index.d.ts +144 -0
  81. package/dest/eth-address/index.d.ts.map +1 -0
  82. package/dest/eth-address/index.js +228 -0
  83. package/dest/fields/coordinate.d.ts +67 -0
  84. package/dest/fields/coordinate.d.ts.map +1 -0
  85. package/dest/fields/coordinate.js +95 -0
  86. package/dest/fields/coordinate.test.d.ts +2 -0
  87. package/dest/fields/coordinate.test.d.ts.map +1 -0
  88. package/dest/fields/coordinate.test.js +22 -0
  89. package/dest/fields/fields.d.ts +177 -0
  90. package/dest/fields/fields.d.ts.map +1 -0
  91. package/dest/fields/fields.js +219 -0
  92. package/dest/fields/grumpkin_scalar.d.ts +96 -0
  93. package/dest/fields/grumpkin_scalar.d.ts.map +1 -0
  94. package/dest/fields/grumpkin_scalar.js +125 -0
  95. package/dest/fields/grumpkin_scalar.test.d.ts +2 -0
  96. package/dest/fields/grumpkin_scalar.test.d.ts.map +1 -0
  97. package/dest/fields/grumpkin_scalar.test.js +45 -0
  98. package/dest/fields/index.d.ts +5 -0
  99. package/dest/fields/index.d.ts.map +1 -0
  100. package/dest/fields/index.js +5 -0
  101. package/dest/fields/point.d.ts +105 -0
  102. package/dest/fields/point.d.ts.map +1 -0
  103. package/dest/fields/point.js +125 -0
  104. package/dest/fifo/bounded_serial_queue.d.ts +56 -0
  105. package/dest/fifo/bounded_serial_queue.d.ts.map +1 -0
  106. package/dest/fifo/bounded_serial_queue.js +94 -0
  107. package/dest/fifo/index.d.ts +5 -0
  108. package/dest/fifo/index.d.ts.map +1 -0
  109. package/dest/fifo/index.js +5 -0
  110. package/dest/fifo/memory_fifo.d.ts +55 -0
  111. package/dest/fifo/memory_fifo.d.ts.map +1 -0
  112. package/dest/fifo/memory_fifo.js +109 -0
  113. package/dest/fifo/semaphore.d.ts +23 -0
  114. package/dest/fifo/semaphore.d.ts.map +1 -0
  115. package/dest/fifo/semaphore.js +30 -0
  116. package/dest/fifo/serial_queue.d.ts +48 -0
  117. package/dest/fifo/serial_queue.d.ts.map +1 -0
  118. package/dest/fifo/serial_queue.js +74 -0
  119. package/dest/json-rpc/class_converter.d.ts +144 -0
  120. package/dest/json-rpc/class_converter.d.ts.map +1 -0
  121. package/dest/json-rpc/class_converter.js +100 -0
  122. package/dest/json-rpc/client/index.d.ts +2 -0
  123. package/dest/json-rpc/client/index.d.ts.map +1 -0
  124. package/dest/json-rpc/client/index.js +2 -0
  125. package/dest/json-rpc/client/json_rpc_client.d.ts +29 -0
  126. package/dest/json-rpc/client/json_rpc_client.d.ts.map +1 -0
  127. package/dest/json-rpc/client/json_rpc_client.js +104 -0
  128. package/dest/json-rpc/client/json_rpc_client.test.d.ts +2 -0
  129. package/dest/json-rpc/client/json_rpc_client.test.d.ts.map +1 -0
  130. package/dest/json-rpc/client/json_rpc_client.test.js +20 -0
  131. package/dest/json-rpc/convert.d.ts +28 -0
  132. package/dest/json-rpc/convert.d.ts.map +1 -0
  133. package/dest/json-rpc/convert.js +139 -0
  134. package/dest/json-rpc/convert.test.d.ts +2 -0
  135. package/dest/json-rpc/convert.test.d.ts.map +1 -0
  136. package/dest/json-rpc/convert.test.js +68 -0
  137. package/dest/json-rpc/fixtures/class_a.d.ts +11 -0
  138. package/dest/json-rpc/fixtures/class_a.d.ts.map +1 -0
  139. package/dest/json-rpc/fixtures/class_a.js +17 -0
  140. package/dest/json-rpc/fixtures/class_b.d.ts +11 -0
  141. package/dest/json-rpc/fixtures/class_b.d.ts.map +1 -0
  142. package/dest/json-rpc/fixtures/class_b.js +17 -0
  143. package/dest/json-rpc/fixtures/test_state.d.ts +47 -0
  144. package/dest/json-rpc/fixtures/test_state.d.ts.map +1 -0
  145. package/dest/json-rpc/fixtures/test_state.js +62 -0
  146. package/dest/json-rpc/index.d.ts +3 -0
  147. package/dest/json-rpc/index.d.ts.map +1 -0
  148. package/dest/json-rpc/index.js +3 -0
  149. package/dest/json-rpc/js_utils.d.ts +13 -0
  150. package/dest/json-rpc/js_utils.d.ts.map +1 -0
  151. package/dest/json-rpc/js_utils.js +18 -0
  152. package/dest/json-rpc/server/index.d.ts +3 -0
  153. package/dest/json-rpc/server/index.d.ts.map +1 -0
  154. package/dest/json-rpc/server/index.js +3 -0
  155. package/dest/json-rpc/server/json_proxy.d.ts +18 -0
  156. package/dest/json-rpc/server/json_proxy.d.ts.map +1 -0
  157. package/dest/json-rpc/server/json_proxy.js +36 -0
  158. package/dest/json-rpc/server/json_rpc_server.d.ts +34 -0
  159. package/dest/json-rpc/server/json_rpc_server.d.ts.map +1 -0
  160. package/dest/json-rpc/server/json_rpc_server.js +133 -0
  161. package/dest/json-rpc/server/json_rpc_server.test.d.ts +2 -0
  162. package/dest/json-rpc/server/json_rpc_server.test.d.ts.map +1 -0
  163. package/dest/json-rpc/server/json_rpc_server.test.js +22 -0
  164. package/dest/log/console.d.ts +11 -0
  165. package/dest/log/console.d.ts.map +1 -0
  166. package/dest/log/console.js +38 -0
  167. package/dest/log/debug.d.ts +43 -0
  168. package/dest/log/debug.d.ts.map +1 -0
  169. package/dest/log/debug.js +75 -0
  170. package/dest/log/index.d.ts +9 -0
  171. package/dest/log/index.d.ts.map +1 -0
  172. package/dest/log/index.js +5 -0
  173. package/dest/log/log_history.d.ts +31 -0
  174. package/dest/log/log_history.d.ts.map +1 -0
  175. package/dest/log/log_history.js +42 -0
  176. package/dest/log/log_history.test.d.ts +2 -0
  177. package/dest/log/log_history.test.d.ts.map +1 -0
  178. package/dest/log/log_history.test.js +78 -0
  179. package/dest/log/logger.d.ts +34 -0
  180. package/dest/log/logger.d.ts.map +1 -0
  181. package/dest/log/logger.js +78 -0
  182. package/dest/mutex/index.d.ts +53 -0
  183. package/dest/mutex/index.d.ts.map +1 -0
  184. package/dest/mutex/index.js +74 -0
  185. package/dest/mutex/mutex.test.d.ts +9 -0
  186. package/dest/mutex/mutex.test.d.ts.map +1 -0
  187. package/dest/mutex/mutex.test.js +58 -0
  188. package/dest/mutex/mutex_database.d.ts +10 -0
  189. package/dest/mutex/mutex_database.d.ts.map +1 -0
  190. package/dest/mutex/mutex_database.js +2 -0
  191. package/dest/retry/index.d.ts +44 -0
  192. package/dest/retry/index.d.ts.map +1 -0
  193. package/dest/retry/index.js +89 -0
  194. package/dest/running-promise/index.d.ts +35 -0
  195. package/dest/running-promise/index.d.ts.map +1 -0
  196. package/dest/running-promise/index.js +59 -0
  197. package/dest/serialize/buffer_reader.d.ts +188 -0
  198. package/dest/serialize/buffer_reader.d.ts.map +1 -0
  199. package/dest/serialize/buffer_reader.js +229 -0
  200. package/dest/serialize/buffer_reader.test.d.ts +2 -0
  201. package/dest/serialize/buffer_reader.test.d.ts.map +1 -0
  202. package/dest/serialize/buffer_reader.test.js +156 -0
  203. package/dest/serialize/deserializer.d.ts +134 -0
  204. package/dest/serialize/deserializer.d.ts.map +1 -0
  205. package/dest/serialize/deserializer.js +145 -0
  206. package/dest/serialize/free_funcs.d.ts +203 -0
  207. package/dest/serialize/free_funcs.d.ts.map +1 -0
  208. package/dest/serialize/free_funcs.js +250 -0
  209. package/dest/serialize/index.d.ts +6 -0
  210. package/dest/serialize/index.d.ts.map +1 -0
  211. package/dest/serialize/index.js +6 -0
  212. package/dest/serialize/serialize.test.d.ts +2 -0
  213. package/dest/serialize/serialize.test.d.ts.map +1 -0
  214. package/dest/serialize/serialize.test.js +68 -0
  215. package/dest/serialize/serializer.d.ts +89 -0
  216. package/dest/serialize/serializer.d.ts.map +1 -0
  217. package/dest/serialize/serializer.js +111 -0
  218. package/dest/serialize/types.d.ts +33 -0
  219. package/dest/serialize/types.d.ts.map +1 -0
  220. package/dest/serialize/types.js +22 -0
  221. package/dest/sleep/index.d.ts +52 -0
  222. package/dest/sleep/index.d.ts.map +1 -0
  223. package/dest/sleep/index.js +70 -0
  224. package/dest/timer/index.d.ts +3 -0
  225. package/dest/timer/index.d.ts.map +1 -0
  226. package/dest/timer/index.js +3 -0
  227. package/dest/timer/timeout.d.ts +41 -0
  228. package/dest/timer/timeout.d.ts.map +1 -0
  229. package/dest/timer/timeout.js +62 -0
  230. package/dest/timer/timer.d.ts +33 -0
  231. package/dest/timer/timer.d.ts.map +1 -0
  232. package/dest/timer/timer.js +38 -0
  233. package/dest/transport/browser/index.d.ts +5 -0
  234. package/dest/transport/browser/index.d.ts.map +1 -0
  235. package/dest/transport/browser/index.js +5 -0
  236. package/dest/transport/browser/message_port_socket.d.ts +37 -0
  237. package/dest/transport/browser/message_port_socket.d.ts.map +1 -0
  238. package/dest/transport/browser/message_port_socket.js +46 -0
  239. package/dest/transport/browser/shared_worker_connector.d.ts +19 -0
  240. package/dest/transport/browser/shared_worker_connector.d.ts.map +1 -0
  241. package/dest/transport/browser/shared_worker_connector.js +21 -0
  242. package/dest/transport/browser/shared_worker_listener.d.ts +38 -0
  243. package/dest/transport/browser/shared_worker_listener.d.ts.map +1 -0
  244. package/dest/transport/browser/shared_worker_listener.js +37 -0
  245. package/dest/transport/browser/worker_connector.d.ts +26 -0
  246. package/dest/transport/browser/worker_connector.d.ts.map +1 -0
  247. package/dest/transport/browser/worker_connector.js +30 -0
  248. package/dest/transport/browser/worker_listener.d.ts +39 -0
  249. package/dest/transport/browser/worker_listener.d.ts.map +1 -0
  250. package/dest/transport/browser/worker_listener.js +39 -0
  251. package/dest/transport/dispatch/create_dispatch_fn.d.ts +25 -0
  252. package/dest/transport/dispatch/create_dispatch_fn.d.ts.map +1 -0
  253. package/dest/transport/dispatch/create_dispatch_fn.js +18 -0
  254. package/dest/transport/dispatch/create_dispatch_proxy.d.ts +102 -0
  255. package/dest/transport/dispatch/create_dispatch_proxy.d.ts.map +1 -0
  256. package/dest/transport/dispatch/create_dispatch_proxy.js +56 -0
  257. package/dest/transport/dispatch/messages.d.ts +52 -0
  258. package/dest/transport/dispatch/messages.d.ts.map +1 -0
  259. package/dest/transport/dispatch/messages.js +12 -0
  260. package/dest/transport/index.d.ts +12 -0
  261. package/dest/transport/index.d.ts.map +1 -0
  262. package/dest/transport/index.js +12 -0
  263. package/dest/transport/interface/connector.d.ts +8 -0
  264. package/dest/transport/interface/connector.d.ts.map +1 -0
  265. package/dest/transport/interface/connector.js +2 -0
  266. package/dest/transport/interface/listener.d.ts +13 -0
  267. package/dest/transport/interface/listener.d.ts.map +1 -0
  268. package/dest/transport/interface/listener.js +2 -0
  269. package/dest/transport/interface/socket.d.ts +13 -0
  270. package/dest/transport/interface/socket.d.ts.map +1 -0
  271. package/dest/transport/interface/socket.js +2 -0
  272. package/dest/transport/interface/transferable.d.ts +68 -0
  273. package/dest/transport/interface/transferable.d.ts.map +1 -0
  274. package/dest/transport/interface/transferable.js +63 -0
  275. package/dest/transport/node/index.d.ts +3 -0
  276. package/dest/transport/node/index.d.ts.map +1 -0
  277. package/dest/transport/node/index.js +3 -0
  278. package/dest/transport/node/node_connector.d.ts +28 -0
  279. package/dest/transport/node/node_connector.d.ts.map +1 -0
  280. package/dest/transport/node/node_connector.js +28 -0
  281. package/dest/transport/node/node_connector_socket.d.ts +42 -0
  282. package/dest/transport/node/node_connector_socket.d.ts.map +1 -0
  283. package/dest/transport/node/node_connector_socket.js +48 -0
  284. package/dest/transport/node/node_listener.d.ts +26 -0
  285. package/dest/transport/node/node_listener.d.ts.map +1 -0
  286. package/dest/transport/node/node_listener.js +30 -0
  287. package/dest/transport/node/node_listener_socket.d.ts +37 -0
  288. package/dest/transport/node/node_listener_socket.d.ts.map +1 -0
  289. package/dest/transport/node/node_listener_socket.js +44 -0
  290. package/dest/transport/transport_client.d.ts +61 -0
  291. package/dest/transport/transport_client.d.ts.map +1 -0
  292. package/dest/transport/transport_client.js +94 -0
  293. package/dest/transport/transport_server.d.ts +56 -0
  294. package/dest/transport/transport_server.d.ts.map +1 -0
  295. package/dest/transport/transport_server.js +101 -0
  296. package/dest/types/index.d.ts +7 -0
  297. package/dest/types/index.d.ts.map +1 -0
  298. package/dest/types/index.js +2 -0
  299. package/dest/url/index.d.ts +9 -0
  300. package/dest/url/index.d.ts.map +1 -0
  301. package/dest/url/index.js +66 -0
  302. package/dest/wasm/empty_wasi_sdk.d.ts +130 -0
  303. package/dest/wasm/empty_wasi_sdk.d.ts.map +1 -0
  304. package/dest/wasm/empty_wasi_sdk.js +166 -0
  305. package/dest/wasm/index.d.ts +2 -0
  306. package/dest/wasm/index.d.ts.map +1 -0
  307. package/dest/wasm/index.js +2 -0
  308. package/dest/wasm/wasm_module.d.ts +135 -0
  309. package/dest/wasm/wasm_module.d.ts.map +1 -0
  310. package/dest/wasm/wasm_module.js +205 -0
  311. package/dest/wasm/wasm_module.test.d.ts +2 -0
  312. package/dest/wasm/wasm_module.test.d.ts.map +1 -0
  313. package/dest/wasm/wasm_module.test.js +24 -0
  314. package/dest/worker/browser/index.d.ts +3 -0
  315. package/dest/worker/browser/index.d.ts.map +1 -0
  316. package/dest/worker/browser/index.js +3 -0
  317. package/dest/worker/browser/start_web_module.d.ts +7 -0
  318. package/dest/worker/browser/start_web_module.d.ts.map +1 -0
  319. package/dest/worker/browser/start_web_module.js +22 -0
  320. package/dest/worker/browser/web_data_store.d.ts +23 -0
  321. package/dest/worker/browser/web_data_store.d.ts.map +1 -0
  322. package/dest/worker/browser/web_data_store.js +32 -0
  323. package/dest/worker/browser/web_worker.d.ts +10 -0
  324. package/dest/worker/browser/web_worker.d.ts.map +1 -0
  325. package/dest/worker/browser/web_worker.js +23 -0
  326. package/dest/worker/data_store.d.ts +20 -0
  327. package/dest/worker/data_store.d.ts.map +1 -0
  328. package/dest/worker/data_store.js +2 -0
  329. package/dest/worker/index.d.ts +3 -0
  330. package/dest/worker/index.d.ts.map +1 -0
  331. package/dest/worker/index.js +2 -0
  332. package/dest/worker/node/index.d.ts +3 -0
  333. package/dest/worker/node/index.d.ts.map +1 -0
  334. package/dest/worker/node/index.js +3 -0
  335. package/dest/worker/node/node_data_store.d.ts +12 -0
  336. package/dest/worker/node/node_data_store.d.ts.map +1 -0
  337. package/dest/worker/node/node_data_store.js +21 -0
  338. package/dest/worker/node/node_worker.d.ts +6 -0
  339. package/dest/worker/node/node_worker.d.ts.map +1 -0
  340. package/dest/worker/node/node_worker.js +20 -0
  341. package/dest/worker/node/start_node_module.d.ts +7 -0
  342. package/dest/worker/node/start_node_module.d.ts.map +1 -0
  343. package/dest/worker/node/start_node_module.js +26 -0
  344. package/dest/worker/wasm_worker.d.ts +9 -0
  345. package/dest/worker/wasm_worker.d.ts.map +1 -0
  346. package/dest/worker/wasm_worker.js +2 -0
  347. package/dest/worker/worker_pool.d.ts +40 -0
  348. package/dest/worker/worker_pool.d.ts.map +1 -0
  349. package/dest/worker/worker_pool.js +62 -0
  350. package/package.json +1 -1
  351. package/Dockerfile +0 -15
@@ -0,0 +1,28 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { Worker } from 'worker_threads';
3
+ import { Connector } from '../interface/connector.js';
4
+ import { NodeConnectorSocket } from './node_connector_socket.js';
5
+ /**
6
+ * The NodeConnector class is a concrete implementation of the Connector interface, utilizing worker_threads for
7
+ * efficient parallel execution. This class provides an easy way to establish a connection with a Worker instance,
8
+ * allowing seamless communication via sockets.
9
+ *
10
+ * @example
11
+ * const worker = new Worker('./path/to/worker.js');
12
+ * const nodeConnector = new NodeConnector(worker);
13
+ * const socket = await nodeConnector.createSocket();
14
+ * socket.send('Hello from main thread!');
15
+ */
16
+ export declare class NodeConnector implements Connector {
17
+ private worker;
18
+ constructor(worker: Worker);
19
+ /**
20
+ * Creates a new instance of NodeConnectorSocket using the worker provided in the constructor.
21
+ * The createSocket method is used to establish connections using the worker_threads module,
22
+ * allowing for efficient and fast communication between different parts of the application.
23
+ *
24
+ * @returns A Promise that resolves to a newly created NodeConnectorSocket instance.
25
+ */
26
+ createSocket(): Promise<NodeConnectorSocket>;
27
+ }
28
+ //# sourceMappingURL=node_connector.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_connector.d.ts","sourceRoot":"","sources":["../../../src/transport/node/node_connector.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE;;;;;;;;;;GAUG;AACH,qBAAa,aAAc,YAAW,SAAS;IACjC,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAElC;;;;;;OAMG;IACH,YAAY;CAGb"}
@@ -0,0 +1,28 @@
1
+ import { NodeConnectorSocket } from './node_connector_socket.js';
2
+ /**
3
+ * The NodeConnector class is a concrete implementation of the Connector interface, utilizing worker_threads for
4
+ * efficient parallel execution. This class provides an easy way to establish a connection with a Worker instance,
5
+ * allowing seamless communication via sockets.
6
+ *
7
+ * @example
8
+ * const worker = new Worker('./path/to/worker.js');
9
+ * const nodeConnector = new NodeConnector(worker);
10
+ * const socket = await nodeConnector.createSocket();
11
+ * socket.send('Hello from main thread!');
12
+ */
13
+ export class NodeConnector {
14
+ constructor(worker) {
15
+ this.worker = worker;
16
+ }
17
+ /**
18
+ * Creates a new instance of NodeConnectorSocket using the worker provided in the constructor.
19
+ * The createSocket method is used to establish connections using the worker_threads module,
20
+ * allowing for efficient and fast communication between different parts of the application.
21
+ *
22
+ * @returns A Promise that resolves to a newly created NodeConnectorSocket instance.
23
+ */
24
+ createSocket() {
25
+ return Promise.resolve(new NodeConnectorSocket(this.worker));
26
+ }
27
+ }
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZV9jb25uZWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHJhbnNwb3J0L25vZGUvbm9kZV9jb25uZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFakU7Ozs7Ozs7Ozs7R0FVRztBQUNILE1BQU0sT0FBTyxhQUFhO0lBQ3hCLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQUcsQ0FBQztJQUV0Qzs7Ozs7O09BTUc7SUFDSCxZQUFZO1FBQ1YsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksbUJBQW1CLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFDL0QsQ0FBQztDQUNGIn0=
@@ -0,0 +1,42 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { Worker } from 'worker_threads';
3
+ import { Socket } from '../interface/socket.js';
4
+ /**
5
+ * NodeConnectorSocket is a wrapper class that implements the Socket interface for messaging between
6
+ * the main thread and worker threads in a Node.js environment. It uses the Worker API for
7
+ * communication by sending and receiving messages through postMessage and handling messages using
8
+ * event listeners.
9
+ *
10
+ * The send method sends messages to the worker thread, and the registerHandler method registers a
11
+ * callback function to handle incoming messages from the worker. The close method cleans up
12
+ * resources when the socket is no longer needed.
13
+ */
14
+ export declare class NodeConnectorSocket implements Socket {
15
+ private worker;
16
+ constructor(worker: Worker);
17
+ /**
18
+ * Sends a message from the NodeConnectorSocket instance to the associated worker thread.
19
+ * The 'msg' can be any data type and 'transfer' is an optional array of transferable objects
20
+ * that can be transferred with zero-copy semantics. The function returns a resolved Promise
21
+ * once the message has been posted.
22
+ *
23
+ * @param msg - The message to send to the worker thread.
24
+ * @param transfer - Optional array of Transferable objects to transfer ownership alongside the message.
25
+ * @returns A Promise that resolves when the message has been posted.
26
+ */
27
+ send(msg: any, transfer?: Transferable[]): Promise<void>;
28
+ /**
29
+ * Registers a callback function to handle incoming messages from the worker.
30
+ * The provided callback will be executed whenever a message is received from
31
+ * the worker, passing the message as its single argument.
32
+ *
33
+ * @param cb - The callback function to be called when a message is received.
34
+ */
35
+ registerHandler(cb: (msg: any) => any): void;
36
+ /**
37
+ * Closes the worker connection and removes all event listeners.
38
+ * Sends an undefined message to the worker for graceful termination.
39
+ */
40
+ close(): void;
41
+ }
42
+ //# sourceMappingURL=node_connector_socket.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_connector_socket.d.ts","sourceRoot":"","sources":["../../../src/transport/node/node_connector_socket.ts"],"names":[],"mappings":";AAAA,OAAO,EAAoB,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD;;;;;;;;;GASG;AACH,qBAAa,mBAAoB,YAAW,MAAM;IACpC,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,MAAM;IAElC;;;;;;;;;OASG;IACH,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,QAAQ,GAAE,YAAY,EAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAK5D;;;;;;OAMG;IACH,eAAe,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,GAAG,IAAI;IAI5C;;;OAGG;IACH,KAAK;CAIN"}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * NodeConnectorSocket is a wrapper class that implements the Socket interface for messaging between
3
+ * the main thread and worker threads in a Node.js environment. It uses the Worker API for
4
+ * communication by sending and receiving messages through postMessage and handling messages using
5
+ * event listeners.
6
+ *
7
+ * The send method sends messages to the worker thread, and the registerHandler method registers a
8
+ * callback function to handle incoming messages from the worker. The close method cleans up
9
+ * resources when the socket is no longer needed.
10
+ */
11
+ export class NodeConnectorSocket {
12
+ constructor(worker) {
13
+ this.worker = worker;
14
+ }
15
+ /**
16
+ * Sends a message from the NodeConnectorSocket instance to the associated worker thread.
17
+ * The 'msg' can be any data type and 'transfer' is an optional array of transferable objects
18
+ * that can be transferred with zero-copy semantics. The function returns a resolved Promise
19
+ * once the message has been posted.
20
+ *
21
+ * @param msg - The message to send to the worker thread.
22
+ * @param transfer - Optional array of Transferable objects to transfer ownership alongside the message.
23
+ * @returns A Promise that resolves when the message has been posted.
24
+ */
25
+ send(msg, transfer = []) {
26
+ this.worker.postMessage(msg, transfer);
27
+ return Promise.resolve();
28
+ }
29
+ /**
30
+ * Registers a callback function to handle incoming messages from the worker.
31
+ * The provided callback will be executed whenever a message is received from
32
+ * the worker, passing the message as its single argument.
33
+ *
34
+ * @param cb - The callback function to be called when a message is received.
35
+ */
36
+ registerHandler(cb) {
37
+ this.worker.on('message', cb);
38
+ }
39
+ /**
40
+ * Closes the worker connection and removes all event listeners.
41
+ * Sends an undefined message to the worker for graceful termination.
42
+ */
43
+ close() {
44
+ void this.send(undefined);
45
+ this.worker.removeAllListeners();
46
+ }
47
+ }
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZV9jb25uZWN0b3Jfc29ja2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RyYW5zcG9ydC9ub2RlL25vZGVfY29ubmVjdG9yX3NvY2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQTs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO0lBQUcsQ0FBQztJQUV0Qzs7Ozs7Ozs7O09BU0c7SUFDSCxJQUFJLENBQUMsR0FBUSxFQUFFLFdBQTJCLEVBQUU7UUFDMUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLFFBQThCLENBQUMsQ0FBQztRQUM3RCxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsZUFBZSxDQUFDLEVBQXFCO1FBQ25DLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsS0FBSztRQUNILEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLGtCQUFrQixFQUFFLENBQUM7SUFDbkMsQ0FBQztDQUNGIn0=
@@ -0,0 +1,26 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import EventEmitter from 'events';
3
+ import { Listener } from '../interface/listener.js';
4
+ /**
5
+ * NodeListener is an event-driven class that extends EventEmitter and implements the Listener interface.
6
+ * It provides methods to open and close communication with a worker thread using the NodeListenerSocket.
7
+ * The 'new_socket' event is emitted when a new NodeListenerSocket instance is created, allowing for
8
+ * efficient processing of incoming messages from the parent thread.
9
+ */
10
+ export declare class NodeListener extends EventEmitter implements Listener {
11
+ constructor();
12
+ /**
13
+ * Opens a new connection to a parent worker thread and emits an event with the created NodeListenerSocket instance.
14
+ * The 'new_socket' event can be listened for, providing access to the newly created NodeListenerSocket.
15
+ *
16
+ * Fires NodeListener#new_socket.
17
+ */
18
+ open(): void;
19
+ /**
20
+ * Closes the NodeListener instance.
21
+ * This method currently has no implementation, as there is no need to perform any actions
22
+ * when closing a NodeListener. It exists for compatibility with the Listener interface.
23
+ */
24
+ close(): void;
25
+ }
26
+ //# sourceMappingURL=node_listener.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_listener.d.ts","sourceRoot":"","sources":["../../../src/transport/node/node_listener.ts"],"names":[],"mappings":";AAAA,OAAO,YAAY,MAAM,QAAQ,CAAC;AAGlC,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AAGpD;;;;;GAKG;AACH,qBAAa,YAAa,SAAQ,YAAa,YAAW,QAAQ;;IAKhE;;;;;OAKG;IACH,IAAI;IAIJ;;;;OAIG;IACH,KAAK;CACN"}
@@ -0,0 +1,30 @@
1
+ import EventEmitter from 'events';
2
+ import { parentPort } from 'worker_threads';
3
+ import { NodeListenerSocket } from './node_listener_socket.js';
4
+ /**
5
+ * NodeListener is an event-driven class that extends EventEmitter and implements the Listener interface.
6
+ * It provides methods to open and close communication with a worker thread using the NodeListenerSocket.
7
+ * The 'new_socket' event is emitted when a new NodeListenerSocket instance is created, allowing for
8
+ * efficient processing of incoming messages from the parent thread.
9
+ */
10
+ export class NodeListener extends EventEmitter {
11
+ constructor() {
12
+ super();
13
+ }
14
+ /**
15
+ * Opens a new connection to a parent worker thread and emits an event with the created NodeListenerSocket instance.
16
+ * The 'new_socket' event can be listened for, providing access to the newly created NodeListenerSocket.
17
+ *
18
+ * Fires NodeListener#new_socket.
19
+ */
20
+ open() {
21
+ this.emit('new_socket', new NodeListenerSocket(parentPort));
22
+ }
23
+ /**
24
+ * Closes the NodeListener instance.
25
+ * This method currently has no implementation, as there is no need to perform any actions
26
+ * when closing a NodeListener. It exists for compatibility with the Listener interface.
27
+ */
28
+ close() { }
29
+ }
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZV9saXN0ZW5lci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90cmFuc3BvcnQvbm9kZS9ub2RlX2xpc3RlbmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sWUFBWSxNQUFNLFFBQVEsQ0FBQztBQUNsQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHNUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFL0Q7Ozs7O0dBS0c7QUFDSCxNQUFNLE9BQU8sWUFBYSxTQUFRLFlBQVk7SUFDNUM7UUFDRSxLQUFLLEVBQUUsQ0FBQztJQUNWLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILElBQUk7UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxJQUFJLGtCQUFrQixDQUFDLFVBQWlCLENBQUMsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsS0FBSyxLQUFJLENBQUM7Q0FDWCJ9
@@ -0,0 +1,37 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { MessagePort } from 'worker_threads';
3
+ import { Socket } from '../interface/socket.js';
4
+ /**
5
+ * An implementation of a TransportSocket using MessagePorts.
6
+ */
7
+ export declare class NodeListenerSocket implements Socket {
8
+ private port;
9
+ constructor(port: MessagePort);
10
+ /**
11
+ * Sends a message through the MessagePort along with any provided Transferables.
12
+ * The transfer list allows for efficient sending of certain types of data,
13
+ * such as ArrayBuffer, ImageBitmap, and MessagePort.
14
+ * The Promise resolves once the message has been successfully sent.
15
+ *
16
+ * @param msg - The message to be sent through the MessagePort.
17
+ * @param transfer - An optional array of Transferable objects to be transferred.
18
+ * @returns A Promise that resolves once the message has been sent.
19
+ */
20
+ send(msg: any, transfer?: Transferable[]): Promise<void>;
21
+ /**
22
+ * Registers a callback function to handle incoming messages from the MessagePort.
23
+ * When a message is received, the provided callback function will be invoked with
24
+ * the received message as its argument. This method allows for efficient and
25
+ * dynamic handling of incoming data in a NodeListenerSocket instance.
26
+ *
27
+ * @param cb - The callback function to process incoming messages.
28
+ */
29
+ registerHandler(cb: (msg: any) => any): void;
30
+ /**
31
+ * Closes the NodeListenerSocket instance, removing all listeners and closing the underlying MessagePort.
32
+ * Sends an undefined message to notify any connected ports about the closure before removing event listeners
33
+ * and cleaning up resources. This method should be called when the socket is no longer needed to avoid memory leaks.
34
+ */
35
+ close(): void;
36
+ }
37
+ //# sourceMappingURL=node_listener_socket.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node_listener_socket.d.ts","sourceRoot":"","sources":["../../../src/transport/node/node_listener_socket.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAoB,MAAM,gBAAgB,CAAC;AAE/D,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD;;GAEG;AACH,qBAAa,kBAAmB,YAAW,MAAM;IACnC,OAAO,CAAC,IAAI;gBAAJ,IAAI,EAAE,WAAW;IAErC;;;;;;;;;OASG;IACH,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,QAAQ,GAAE,YAAY,EAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAK5D;;;;;;;OAOG;IACH,eAAe,CAAC,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,KAAK,GAAG,GAAG,IAAI;IAI5C;;;;OAIG;IACH,KAAK;CAKN"}
@@ -0,0 +1,44 @@
1
+ /**
2
+ * An implementation of a TransportSocket using MessagePorts.
3
+ */
4
+ export class NodeListenerSocket {
5
+ constructor(port) {
6
+ this.port = port;
7
+ }
8
+ /**
9
+ * Sends a message through the MessagePort along with any provided Transferables.
10
+ * The transfer list allows for efficient sending of certain types of data,
11
+ * such as ArrayBuffer, ImageBitmap, and MessagePort.
12
+ * The Promise resolves once the message has been successfully sent.
13
+ *
14
+ * @param msg - The message to be sent through the MessagePort.
15
+ * @param transfer - An optional array of Transferable objects to be transferred.
16
+ * @returns A Promise that resolves once the message has been sent.
17
+ */
18
+ send(msg, transfer = []) {
19
+ this.port.postMessage(msg, transfer);
20
+ return Promise.resolve();
21
+ }
22
+ /**
23
+ * Registers a callback function to handle incoming messages from the MessagePort.
24
+ * When a message is received, the provided callback function will be invoked with
25
+ * the received message as its argument. This method allows for efficient and
26
+ * dynamic handling of incoming data in a NodeListenerSocket instance.
27
+ *
28
+ * @param cb - The callback function to process incoming messages.
29
+ */
30
+ registerHandler(cb) {
31
+ this.port.on('message', cb);
32
+ }
33
+ /**
34
+ * Closes the NodeListenerSocket instance, removing all listeners and closing the underlying MessagePort.
35
+ * Sends an undefined message to notify any connected ports about the closure before removing event listeners
36
+ * and cleaning up resources. This method should be called when the socket is no longer needed to avoid memory leaks.
37
+ */
38
+ close() {
39
+ void this.send(undefined);
40
+ this.port.removeAllListeners();
41
+ this.port.close();
42
+ }
43
+ }
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZV9saXN0ZW5lcl9zb2NrZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdHJhbnNwb3J0L25vZGUvbm9kZV9saXN0ZW5lcl9zb2NrZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSUE7O0dBRUc7QUFDSCxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLFlBQW9CLElBQWlCO1FBQWpCLFNBQUksR0FBSixJQUFJLENBQWE7SUFBRyxDQUFDO0lBRXpDOzs7Ozs7Ozs7T0FTRztJQUNILElBQUksQ0FBQyxHQUFRLEVBQUUsV0FBMkIsRUFBRTtRQUMxQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUUsUUFBOEIsQ0FBQyxDQUFDO1FBQzNELE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRDs7Ozs7OztPQU9HO0lBQ0gsZUFBZSxDQUFDLEVBQXFCO1FBQ25DLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILEtBQUs7UUFDSCxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDcEIsQ0FBQztDQUNGIn0=
@@ -0,0 +1,61 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import EventEmitter from 'events';
3
+ import { Connector } from './interface/connector.js';
4
+ /**
5
+ * Represents a transport client for communication between TransportServer and clients.
6
+ * Provides request/response functionality, event handling, and multiplexing support
7
+ * for efficient and concurrent communication with a corresponding TransportServer.
8
+ */
9
+ export interface ITransportClient<Payload> extends EventEmitter {
10
+ on(name: 'event_msg', handler: (payload: Payload) => void): this;
11
+ emit(name: 'event_msg', payload: Payload): boolean;
12
+ }
13
+ /**
14
+ * A TransportClient provides a request/response and event api to a corresponding TransportServer.
15
+ * If `broadcast` is called on TransportServer, TransportClients will emit an `event_msg`.
16
+ * The `request` method will block until a response is returned from the TransportServer's dispatch function.
17
+ * Request multiplexing is supported.
18
+ */
19
+ export declare class TransportClient<Payload> extends EventEmitter {
20
+ private transportConnect;
21
+ private msgId;
22
+ private pendingRequests;
23
+ private socket?;
24
+ constructor(transportConnect: Connector);
25
+ /**
26
+ * Initializes and opens the socket connection for the TransportClient.
27
+ * This method creates a new Socket instance using the provided Connector,
28
+ * registers a handler for incoming messages, and establishes the connection.
29
+ * It should be called before making any requests or handling events.
30
+ *
31
+ * @throws An error if the socket is already open or there's an issue opening the connection.
32
+ * @returns A Promise that resolves when the socket connection is successfully opened.
33
+ */
34
+ open(): Promise<void>;
35
+ /**
36
+ * Close the transport client's socket connection and remove all event listeners.
37
+ * This method should be called when the client is no longer needed to ensure proper cleanup
38
+ * and prevent potential memory leaks. Once closed, the client cannot be reused and a new
39
+ * instance must be created if another connection is needed.
40
+ */
41
+ close(): void;
42
+ /**
43
+ * Sends a request to the TransportServer with the given payload and transferable objects.
44
+ * The method will block until a response from the TransportServer's dispatch function is returned.
45
+ * Request multiplexing is supported, allowing multiple requests to be sent concurrently.
46
+ *
47
+ * @param payload - The message payload to send to the server.
48
+ * @param transfer - An optional array of ArrayBuffer, MessagePort, or ImageBitmap objects to transfer ownership.
49
+ * @returns A Promise that resolves with the server's response data or rejects with an error message.
50
+ */
51
+ request(payload: Payload, transfer?: Transferable[]): Promise<any>;
52
+ /**
53
+ * Handles incoming socket messages from the TransportServer, such as ResponseMessage and EventMessage.
54
+ * If it's an EventMessage, emits an 'event_msg' event with the payload.
55
+ * If it's a ResponseMessage, resolves or rejects the corresponding pending request based on the message content.
56
+ *
57
+ * @param msg - The ResponseMessage or EventMessage received from the TransportServer, or undefined if the remote socket closed.
58
+ */
59
+ private handleSocketMessage;
60
+ }
61
+ //# sourceMappingURL=transport_client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport_client.d.ts","sourceRoot":"","sources":["../../src/transport/transport_client.ts"],"names":[],"mappings":";AAAA,OAAO,YAAY,MAAM,QAAQ,CAAC;AAIlC,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAqBrD;;;;GAIG;AACH,MAAM,WAAW,gBAAgB,CAAC,OAAO,CAAE,SAAQ,YAAY;IAE7D,EAAE,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,GAAG,IAAI,CAAC;IAEjE,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC;CACpD;AAED;;;;;GAKG;AACH,qBAAa,eAAe,CAAC,OAAO,CAAE,SAAQ,YAAY;IAK5C,OAAO,CAAC,gBAAgB;IAJpC,OAAO,CAAC,KAAK,CAAK;IAClB,OAAO,CAAC,eAAe,CAAwB;IAC/C,OAAO,CAAC,MAAM,CAAC,CAAS;gBAEJ,gBAAgB,EAAE,SAAS;IAI/C;;;;;;;;OAQG;IACG,IAAI;IAKV;;;;;OAKG;IACH,KAAK;IAML;;;;;;;;OAQG;IACH,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,YAAY,EAAE;IAanD;;;;;;OAMG;IACH,OAAO,CAAC,mBAAmB;CAsB5B"}
@@ -0,0 +1,94 @@
1
+ import EventEmitter from 'events';
2
+ import { createDebugLogger } from '../log/index.js';
3
+ import { isEventMessage } from './dispatch/messages.js';
4
+ const debug = createDebugLogger('aztec:transport_client');
5
+ /**
6
+ * A TransportClient provides a request/response and event api to a corresponding TransportServer.
7
+ * If `broadcast` is called on TransportServer, TransportClients will emit an `event_msg`.
8
+ * The `request` method will block until a response is returned from the TransportServer's dispatch function.
9
+ * Request multiplexing is supported.
10
+ */
11
+ export class TransportClient extends EventEmitter {
12
+ constructor(transportConnect) {
13
+ super();
14
+ this.transportConnect = transportConnect;
15
+ this.msgId = 0;
16
+ this.pendingRequests = [];
17
+ }
18
+ /**
19
+ * Initializes and opens the socket connection for the TransportClient.
20
+ * This method creates a new Socket instance using the provided Connector,
21
+ * registers a handler for incoming messages, and establishes the connection.
22
+ * It should be called before making any requests or handling events.
23
+ *
24
+ * @throws An error if the socket is already open or there's an issue opening the connection.
25
+ * @returns A Promise that resolves when the socket connection is successfully opened.
26
+ */
27
+ async open() {
28
+ this.socket = await this.transportConnect.createSocket();
29
+ this.socket.registerHandler(msg => this.handleSocketMessage(msg));
30
+ }
31
+ /**
32
+ * Close the transport client's socket connection and remove all event listeners.
33
+ * This method should be called when the client is no longer needed to ensure proper cleanup
34
+ * and prevent potential memory leaks. Once closed, the client cannot be reused and a new
35
+ * instance must be created if another connection is needed.
36
+ */
37
+ close() {
38
+ this.socket?.close();
39
+ this.socket = undefined;
40
+ this.removeAllListeners();
41
+ }
42
+ /**
43
+ * Sends a request to the TransportServer with the given payload and transferable objects.
44
+ * The method will block until a response from the TransportServer's dispatch function is returned.
45
+ * Request multiplexing is supported, allowing multiple requests to be sent concurrently.
46
+ *
47
+ * @param payload - The message payload to send to the server.
48
+ * @param transfer - An optional array of ArrayBuffer, MessagePort, or ImageBitmap objects to transfer ownership.
49
+ * @returns A Promise that resolves with the server's response data or rejects with an error message.
50
+ */
51
+ request(payload, transfer) {
52
+ if (!this.socket) {
53
+ throw new Error('Socket not open.');
54
+ }
55
+ const msgId = this.msgId++;
56
+ const msg = { msgId, payload };
57
+ debug(`->`, msg);
58
+ return new Promise((resolve, reject) => {
59
+ this.pendingRequests.push({ resolve, reject, msgId });
60
+ this.socket.send(msg, transfer).catch(reject);
61
+ });
62
+ }
63
+ /**
64
+ * Handles incoming socket messages from the TransportServer, such as ResponseMessage and EventMessage.
65
+ * If it's an EventMessage, emits an 'event_msg' event with the payload.
66
+ * If it's a ResponseMessage, resolves or rejects the corresponding pending request based on the message content.
67
+ *
68
+ * @param msg - The ResponseMessage or EventMessage received from the TransportServer, or undefined if the remote socket closed.
69
+ */
70
+ handleSocketMessage(msg) {
71
+ if (msg === undefined) {
72
+ // The remote socket closed.
73
+ this.close();
74
+ return;
75
+ }
76
+ debug(`<-`, msg);
77
+ if (isEventMessage(msg)) {
78
+ this.emit('event_msg', msg.payload);
79
+ return;
80
+ }
81
+ const reqIndex = this.pendingRequests.findIndex(r => r.msgId === msg.msgId);
82
+ if (reqIndex === -1) {
83
+ return;
84
+ }
85
+ const [pending] = this.pendingRequests.splice(reqIndex, 1);
86
+ if (msg.error) {
87
+ pending.reject(new Error(msg.error));
88
+ }
89
+ else {
90
+ pending.resolve(msg.payload);
91
+ }
92
+ }
93
+ }
94
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNwb3J0X2NsaWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc3BvcnQvdHJhbnNwb3J0X2NsaWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFlBQVksTUFBTSxRQUFRLENBQUM7QUFFbEMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDcEQsT0FBTyxFQUFpQyxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUl2RixNQUFNLEtBQUssR0FBRyxpQkFBaUIsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO0FBOEIxRDs7Ozs7R0FLRztBQUNILE1BQU0sT0FBTyxlQUF5QixTQUFRLFlBQVk7SUFLeEQsWUFBb0IsZ0JBQTJCO1FBQzdDLEtBQUssRUFBRSxDQUFDO1FBRFUscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFXO1FBSnZDLFVBQUssR0FBRyxDQUFDLENBQUM7UUFDVixvQkFBZSxHQUFxQixFQUFFLENBQUM7SUFLL0MsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsS0FBSyxDQUFDLElBQUk7UUFDUixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3pELElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDcEUsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSztRQUNILElBQUksQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUM7UUFDckIsSUFBSSxDQUFDLE1BQU0sR0FBRyxTQUFTLENBQUM7UUFDeEIsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVEOzs7Ozs7OztPQVFHO0lBQ0gsT0FBTyxDQUFDLE9BQWdCLEVBQUUsUUFBeUI7UUFDakQsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDaEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1NBQ3JDO1FBQ0QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzNCLE1BQU0sR0FBRyxHQUFHLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxDQUFDO1FBQy9CLEtBQUssQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDakIsT0FBTyxJQUFJLE9BQU8sQ0FBTSxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUMxQyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUN0RCxJQUFJLENBQUMsTUFBTyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7Ozs7T0FNRztJQUNLLG1CQUFtQixDQUFDLEdBQWlFO1FBQzNGLElBQUksR0FBRyxLQUFLLFNBQVMsRUFBRTtZQUNyQiw0QkFBNEI7WUFDNUIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2IsT0FBTztTQUNSO1FBQ0QsS0FBSyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztRQUNqQixJQUFJLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDcEMsT0FBTztTQUNSO1FBQ0QsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1RSxJQUFJLFFBQVEsS0FBSyxDQUFDLENBQUMsRUFBRTtZQUNuQixPQUFPO1NBQ1I7UUFDRCxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzNELElBQUksR0FBRyxDQUFDLEtBQUssRUFBRTtZQUNiLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDdEM7YUFBTTtZQUNMLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQzlCO0lBQ0gsQ0FBQztDQUNGIn0=
@@ -0,0 +1,56 @@
1
+ import { Listener } from './interface/listener.js';
2
+ /**
3
+ * Keeps track of clients, providing a broadcast, and request/response api with multiplexing.
4
+ */
5
+ export declare class TransportServer<Payload> {
6
+ private listener;
7
+ private msgHandlerFn;
8
+ private sockets;
9
+ constructor(listener: Listener, msgHandlerFn: (msg: Payload) => Promise<any>);
10
+ /**
11
+ * Starts the TransportServer, allowing it to accept new connections and handle incoming messages.
12
+ * The server will listen for 'new_socket' events from the underlying listener and invoke the provided message handler function
13
+ * for each received message. The server remains active until the 'stop' method is called.
14
+ */
15
+ start(): void;
16
+ /**
17
+ * Stops accepting new connections. It doesn't close existing sockets.
18
+ * It's expected the clients will gracefully complete by closing their end, sending an `undefined` message.
19
+ */
20
+ stop(): void;
21
+ /**
22
+ * Sends a broadcast message to all connected clients.
23
+ * The given payload will be sent to all the clients currently connected to the TransportServer.
24
+ * It waits for all the messages to be sent and resolves when they are all sent successfully.
25
+ *
26
+ * @param msg - The payload to broadcast to all connected clients.
27
+ * @returns A Promise that resolves when all messages have been sent successfully.
28
+ */
29
+ broadcast(msg: Payload): Promise<void>;
30
+ /**
31
+ * Handles the addition of a new socket to the server by registering a message handler for the client
32
+ * and adding the socket to the list of active sockets. The message handler processes incoming messages
33
+ * from the client, including detecting client disconnection and removing the closed socket.
34
+ *
35
+ * @param socket - The new Socket instance that has connected to the server.
36
+ */
37
+ private handleNewSocket;
38
+ /**
39
+ * Detect the 'transferables' argument to our socket from our message
40
+ * handler return type.
41
+ * @param data - The compound payload data.
42
+ * @returns The split data and transferables.
43
+ */
44
+ private getPayloadAndTransfers;
45
+ /**
46
+ * Handles incoming socket messages, processing the request and sending back a response.
47
+ * This function is responsible for invoking the registered message handler function with the received
48
+ * payload, extracting the result and transferables, and sending a response message back to the client.
49
+ * In case of an error during message handling, it sends an error response with the stack trace.
50
+ *
51
+ * @param socket - The Socket instance from which the message was received.
52
+ * @param msg - The RequestMessage object containing the message ID and payload.
53
+ */
54
+ private handleSocketMessage;
55
+ }
56
+ //# sourceMappingURL=transport_server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport_server.d.ts","sourceRoot":"","sources":["../../src/transport/transport_server.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAInD;;GAEG;AACH,qBAAa,eAAe,CAAC,OAAO;IAGtB,OAAO,CAAC,QAAQ;IAAY,OAAO,CAAC,YAAY;IAF5D,OAAO,CAAC,OAAO,CAAgB;gBAEX,QAAQ,EAAE,QAAQ,EAAU,YAAY,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,CAAC,GAAG,CAAC;IAE5F;;;;OAIG;IACH,KAAK;IAKL;;;OAGG;IACH,IAAI;IAIJ;;;;;;;OAOG;IACG,SAAS,CAAC,GAAG,EAAE,OAAO;IAI5B;;;;;;OAMG;IACH,OAAO,CAAC,eAAe;IAcvB;;;;;OAKG;IACH,OAAO,CAAC,sBAAsB;IAe9B;;;;;;;;OAQG;YACW,mBAAmB;CAalC"}
@@ -0,0 +1,101 @@
1
+ import { isTransferDescriptor } from './interface/transferable.js';
2
+ /**
3
+ * Keeps track of clients, providing a broadcast, and request/response api with multiplexing.
4
+ */
5
+ export class TransportServer {
6
+ constructor(listener, msgHandlerFn) {
7
+ this.listener = listener;
8
+ this.msgHandlerFn = msgHandlerFn;
9
+ this.sockets = [];
10
+ }
11
+ /**
12
+ * Starts the TransportServer, allowing it to accept new connections and handle incoming messages.
13
+ * The server will listen for 'new_socket' events from the underlying listener and invoke the provided message handler function
14
+ * for each received message. The server remains active until the 'stop' method is called.
15
+ */
16
+ start() {
17
+ this.listener.on('new_socket', client => this.handleNewSocket(client));
18
+ this.listener.open();
19
+ }
20
+ /**
21
+ * Stops accepting new connections. It doesn't close existing sockets.
22
+ * It's expected the clients will gracefully complete by closing their end, sending an `undefined` message.
23
+ */
24
+ stop() {
25
+ this.listener.close();
26
+ }
27
+ /**
28
+ * Sends a broadcast message to all connected clients.
29
+ * The given payload will be sent to all the clients currently connected to the TransportServer.
30
+ * It waits for all the messages to be sent and resolves when they are all sent successfully.
31
+ *
32
+ * @param msg - The payload to broadcast to all connected clients.
33
+ * @returns A Promise that resolves when all messages have been sent successfully.
34
+ */
35
+ async broadcast(msg) {
36
+ await Promise.all(this.sockets.map(s => s.send({ payload: msg })));
37
+ }
38
+ /**
39
+ * Handles the addition of a new socket to the server by registering a message handler for the client
40
+ * and adding the socket to the list of active sockets. The message handler processes incoming messages
41
+ * from the client, including detecting client disconnection and removing the closed socket.
42
+ *
43
+ * @param socket - The new Socket instance that has connected to the server.
44
+ */
45
+ handleNewSocket(socket) {
46
+ socket.registerHandler(async (msg) => {
47
+ if (msg === undefined) {
48
+ // Client socket has closed. Remove it from the list of sockets. Call close on it for any cleanup.
49
+ const socketIndex = this.sockets.findIndex(s => s === socket);
50
+ const [closingSocket] = this.sockets.splice(socketIndex, 1);
51
+ closingSocket.close();
52
+ return;
53
+ }
54
+ return await this.handleSocketMessage(socket, msg);
55
+ });
56
+ this.sockets.push(socket);
57
+ }
58
+ /**
59
+ * Detect the 'transferables' argument to our socket from our message
60
+ * handler return type.
61
+ * @param data - The compound payload data.
62
+ * @returns The split data and transferables.
63
+ */
64
+ getPayloadAndTransfers(data) {
65
+ if (isTransferDescriptor(data)) {
66
+ // We treat PayloadWithTransfers specially so that we're able to
67
+ // attach transferables while keeping a simple return-type based usage
68
+ return [data.send, data.transferables];
69
+ }
70
+ if (data instanceof Uint8Array) {
71
+ // We may want to devise a better solution to this. We maybe given a view over a non cloneable/transferrable
72
+ // ArrayBuffer (such as a view over wasm memory). In this case we want to take a copy, and then transfer it.
73
+ const respPayload = data instanceof Uint8Array && ArrayBuffer.isView(data) ? new Uint8Array(data) : data;
74
+ const transferables = data instanceof Uint8Array ? [respPayload.buffer] : [];
75
+ return [respPayload, transferables];
76
+ }
77
+ return [data, []];
78
+ }
79
+ /**
80
+ * Handles incoming socket messages, processing the request and sending back a response.
81
+ * This function is responsible for invoking the registered message handler function with the received
82
+ * payload, extracting the result and transferables, and sending a response message back to the client.
83
+ * In case of an error during message handling, it sends an error response with the stack trace.
84
+ *
85
+ * @param socket - The Socket instance from which the message was received.
86
+ * @param msg - The RequestMessage object containing the message ID and payload.
87
+ */
88
+ async handleSocketMessage(socket, { msgId, payload }) {
89
+ try {
90
+ const data = await this.msgHandlerFn(payload);
91
+ const [respPayload, transferables] = this.getPayloadAndTransfers(data);
92
+ const rep = { msgId, payload: respPayload };
93
+ await socket.send(rep, transferables);
94
+ }
95
+ catch (err) {
96
+ const rep = { msgId, error: err.stack };
97
+ await socket.send(rep);
98
+ }
99
+ }
100
+ }
101
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNwb3J0X3NlcnZlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90cmFuc3BvcnQvdHJhbnNwb3J0X3NlcnZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUVuRTs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBRzFCLFlBQW9CLFFBQWtCLEVBQVUsWUFBNEM7UUFBeEUsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUFVLGlCQUFZLEdBQVosWUFBWSxDQUFnQztRQUZwRixZQUFPLEdBQWEsRUFBRSxDQUFDO0lBRWdFLENBQUM7SUFFaEc7Ozs7T0FJRztJQUNILEtBQUs7UUFDSCxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7UUFDdkUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsSUFBSTtRQUNGLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVEOzs7Ozs7O09BT0c7SUFDSCxLQUFLLENBQUMsU0FBUyxDQUFDLEdBQVk7UUFDMUIsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0ssZUFBZSxDQUFDLE1BQWM7UUFDcEMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUMsR0FBRyxFQUFDLEVBQUU7WUFDakMsSUFBSSxHQUFHLEtBQUssU0FBUyxFQUFFO2dCQUNyQixrR0FBa0c7Z0JBQ2xHLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLE1BQU0sQ0FBQyxDQUFDO2dCQUM5RCxNQUFNLENBQUMsYUFBYSxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQyxDQUFDO2dCQUM1RCxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7Z0JBQ3RCLE9BQU87YUFDUjtZQUNELE9BQU8sTUFBTSxJQUFJLENBQUMsbUJBQW1CLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ3JELENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDNUIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0ssc0JBQXNCLENBQUMsSUFBUztRQUN0QyxJQUFJLG9CQUFvQixDQUFDLElBQUksQ0FBQyxFQUFFO1lBQzlCLGdFQUFnRTtZQUNoRSxzRUFBc0U7WUFDdEUsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQ3hDO1FBQ0QsSUFBSSxJQUFJLFlBQVksVUFBVSxFQUFFO1lBQzlCLDRHQUE0RztZQUM1Ryw0R0FBNEc7WUFDNUcsTUFBTSxXQUFXLEdBQUcsSUFBSSxZQUFZLFVBQVUsSUFBSSxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1lBQ3pHLE1BQU0sYUFBYSxHQUFHLElBQUksWUFBWSxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDN0UsT0FBTyxDQUFDLFdBQVcsRUFBRSxhQUFhLENBQUMsQ0FBQztTQUNyQztRQUNELE9BQU8sQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDcEIsQ0FBQztJQUNEOzs7Ozs7OztPQVFHO0lBQ0ssS0FBSyxDQUFDLG1CQUFtQixDQUFDLE1BQWMsRUFBRSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQTJCO1FBQzNGLElBQUk7WUFDRixNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7WUFFOUMsTUFBTSxDQUFDLFdBQVcsRUFBRSxhQUFhLENBQUMsR0FBRyxJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDdkUsTUFBTSxHQUFHLEdBQTZCLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsQ0FBQztZQUV0RSxNQUFNLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLGFBQWEsQ0FBQyxDQUFDO1NBQ3ZDO1FBQUMsT0FBTyxHQUFRLEVBQUU7WUFDakIsTUFBTSxHQUFHLEdBQTZCLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbEUsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ3hCO0lBQ0gsQ0FBQztDQUNGIn0=