@olane/o-node 0.7.12-alpha.4 → 0.7.12-alpha.41

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 (448) hide show
  1. package/dist/o-core/src/connection/index.d.ts +8 -0
  2. package/dist/o-core/src/connection/index.d.ts.map +1 -0
  3. package/dist/o-core/src/connection/index.js +7 -0
  4. package/dist/o-core/src/connection/interfaces/connection-manager.config.d.ts +15 -0
  5. package/dist/o-core/src/connection/interfaces/connection-manager.config.d.ts.map +1 -0
  6. package/dist/o-core/src/connection/interfaces/connection-manager.config.js +1 -0
  7. package/dist/o-core/src/connection/interfaces/connection-send-params.interface.d.ts +9 -0
  8. package/dist/o-core/src/connection/interfaces/connection-send-params.interface.d.ts.map +1 -0
  9. package/dist/o-core/src/connection/interfaces/connection-send-params.interface.js +1 -0
  10. package/dist/o-core/src/connection/interfaces/connection.config.d.ts +20 -0
  11. package/dist/o-core/src/connection/interfaces/connection.config.d.ts.map +1 -0
  12. package/dist/o-core/src/connection/interfaces/connection.config.js +1 -0
  13. package/dist/o-core/src/connection/interfaces/index.d.ts +5 -0
  14. package/dist/o-core/src/connection/interfaces/index.d.ts.map +1 -0
  15. package/dist/o-core/src/connection/interfaces/index.js +4 -0
  16. package/dist/o-core/src/connection/interfaces/request-state.enum.d.ts +7 -0
  17. package/dist/o-core/src/connection/interfaces/request-state.enum.d.ts.map +1 -0
  18. package/dist/o-core/src/connection/interfaces/request-state.enum.js +7 -0
  19. package/dist/o-core/src/connection/o-connection-manager.d.ts +19 -0
  20. package/dist/o-core/src/connection/o-connection-manager.d.ts.map +1 -0
  21. package/dist/o-core/src/connection/o-connection-manager.js +27 -0
  22. package/dist/o-core/src/connection/o-connection.d.ts +26 -0
  23. package/dist/o-core/src/connection/o-connection.d.ts.map +1 -0
  24. package/dist/o-core/src/connection/o-connection.js +54 -0
  25. package/dist/o-core/src/connection/o-request.d.ts +23 -0
  26. package/dist/o-core/src/connection/o-request.d.ts.map +1 -0
  27. package/dist/o-core/src/connection/o-request.js +42 -0
  28. package/dist/o-core/src/connection/o-response.d.ts +13 -0
  29. package/dist/o-core/src/connection/o-response.d.ts.map +1 -0
  30. package/dist/o-core/src/connection/o-response.js +25 -0
  31. package/dist/o-core/src/core/defaults/config.d.ts +4 -0
  32. package/dist/o-core/src/core/defaults/config.d.ts.map +1 -0
  33. package/dist/o-core/src/core/defaults/config.js +5 -0
  34. package/dist/o-core/src/core/defaults/index.d.ts +2 -0
  35. package/dist/o-core/src/core/defaults/index.d.ts.map +1 -0
  36. package/dist/o-core/src/core/defaults/index.js +1 -0
  37. package/dist/o-core/src/core/graceful-shutdown.d.ts +25 -0
  38. package/dist/o-core/src/core/graceful-shutdown.d.ts.map +1 -0
  39. package/dist/o-core/src/core/graceful-shutdown.js +84 -0
  40. package/dist/o-core/src/core/index.d.ts +9 -0
  41. package/dist/o-core/src/core/index.d.ts.map +1 -0
  42. package/dist/o-core/src/core/index.js +8 -0
  43. package/dist/o-core/src/core/interfaces/index.d.ts +7 -0
  44. package/dist/o-core/src/core/interfaces/index.d.ts.map +1 -0
  45. package/dist/o-core/src/core/interfaces/index.js +6 -0
  46. package/dist/o-core/src/core/interfaces/node-type.enum.d.ts +10 -0
  47. package/dist/o-core/src/core/interfaces/node-type.enum.d.ts.map +1 -0
  48. package/dist/o-core/src/core/interfaces/node-type.enum.js +10 -0
  49. package/dist/o-core/src/core/interfaces/o-core.config.d.ts +23 -0
  50. package/dist/o-core/src/core/interfaces/o-core.config.d.ts.map +1 -0
  51. package/dist/o-core/src/core/interfaces/o-core.config.js +1 -0
  52. package/dist/o-core/src/core/interfaces/o-core.interface.d.ts +18 -0
  53. package/dist/o-core/src/core/interfaces/o-core.interface.d.ts.map +1 -0
  54. package/dist/o-core/src/core/interfaces/o-core.interface.js +1 -0
  55. package/dist/o-core/src/core/interfaces/state.enum.d.ts +8 -0
  56. package/dist/o-core/src/core/interfaces/state.enum.d.ts.map +1 -0
  57. package/dist/o-core/src/core/interfaces/state.enum.js +8 -0
  58. package/dist/o-core/src/core/interfaces/use-options.interface.d.ts +11 -0
  59. package/dist/o-core/src/core/interfaces/use-options.interface.d.ts.map +1 -0
  60. package/dist/o-core/src/core/interfaces/use-options.interface.js +1 -0
  61. package/dist/o-core/src/core/interfaces/use-stream-options.interface.d.ts +4 -0
  62. package/dist/o-core/src/core/interfaces/use-stream-options.interface.d.ts.map +1 -0
  63. package/dist/o-core/src/core/interfaces/use-stream-options.interface.js +1 -0
  64. package/dist/o-core/src/core/lib/events/connection-events.d.ts +31 -0
  65. package/dist/o-core/src/core/lib/events/connection-events.d.ts.map +1 -0
  66. package/dist/o-core/src/core/lib/events/connection-events.js +46 -0
  67. package/dist/o-core/src/core/lib/events/hierarchy-events.d.ts +69 -0
  68. package/dist/o-core/src/core/lib/events/hierarchy-events.d.ts.map +1 -0
  69. package/dist/o-core/src/core/lib/events/hierarchy-events.js +100 -0
  70. package/dist/o-core/src/core/lib/events/index.d.ts +6 -0
  71. package/dist/o-core/src/core/lib/events/index.d.ts.map +1 -0
  72. package/dist/o-core/src/core/lib/events/index.js +5 -0
  73. package/dist/o-core/src/core/lib/events/node-events.d.ts +40 -0
  74. package/dist/o-core/src/core/lib/events/node-events.d.ts.map +1 -0
  75. package/dist/o-core/src/core/lib/events/node-events.js +58 -0
  76. package/dist/o-core/src/core/lib/events/o-notification-event.d.ts +26 -0
  77. package/dist/o-core/src/core/lib/events/o-notification-event.d.ts.map +1 -0
  78. package/dist/o-core/src/core/lib/events/o-notification-event.js +30 -0
  79. package/dist/o-core/src/core/lib/index.d.ts +8 -0
  80. package/dist/o-core/src/core/lib/index.d.ts.map +1 -0
  81. package/dist/o-core/src/core/lib/index.js +7 -0
  82. package/dist/o-core/src/core/lib/interfaces/notification-types.d.ts +49 -0
  83. package/dist/o-core/src/core/lib/interfaces/notification-types.d.ts.map +1 -0
  84. package/dist/o-core/src/core/lib/interfaces/notification-types.js +1 -0
  85. package/dist/o-core/src/core/lib/o-hierarchy.manager.d.ts +24 -0
  86. package/dist/o-core/src/core/lib/o-hierarchy.manager.d.ts.map +1 -0
  87. package/dist/o-core/src/core/lib/o-hierarchy.manager.js +58 -0
  88. package/dist/o-core/src/core/lib/o-metrics.d.ts +5 -0
  89. package/dist/o-core/src/core/lib/o-metrics.d.ts.map +1 -0
  90. package/dist/o-core/src/core/lib/o-metrics.js +6 -0
  91. package/dist/o-core/src/core/lib/o-notification.manager.d.ts +58 -0
  92. package/dist/o-core/src/core/lib/o-notification.manager.d.ts.map +1 -0
  93. package/dist/o-core/src/core/lib/o-notification.manager.js +159 -0
  94. package/dist/o-core/src/core/lib/o-request.manager.d.ts +10 -0
  95. package/dist/o-core/src/core/lib/o-request.manager.d.ts.map +1 -0
  96. package/dist/o-core/src/core/lib/o-request.manager.js +18 -0
  97. package/dist/o-core/src/core/lib/utils/event-filters.d.ts +38 -0
  98. package/dist/o-core/src/core/lib/utils/event-filters.d.ts.map +1 -0
  99. package/dist/o-core/src/core/lib/utils/event-filters.js +159 -0
  100. package/dist/o-core/src/core/o-core.d.ts +240 -0
  101. package/dist/o-core/src/core/o-core.d.ts.map +1 -0
  102. package/dist/o-core/src/core/o-core.js +463 -0
  103. package/dist/o-core/src/core/o-dependency.d.ts +9 -0
  104. package/dist/o-core/src/core/o-dependency.d.ts.map +1 -0
  105. package/dist/o-core/src/core/o-dependency.js +15 -0
  106. package/dist/o-core/src/core/o-object.d.ts +7 -0
  107. package/dist/o-core/src/core/o-object.d.ts.map +1 -0
  108. package/dist/o-core/src/core/o-object.js +10 -0
  109. package/dist/o-core/src/core/o-parameter.d.ts +12 -0
  110. package/dist/o-core/src/core/o-parameter.d.ts.map +1 -0
  111. package/dist/o-core/src/core/o-parameter.js +21 -0
  112. package/dist/o-core/src/error/enums/codes.error.d.ts +20 -0
  113. package/dist/o-core/src/error/enums/codes.error.d.ts.map +1 -0
  114. package/dist/o-core/src/error/enums/codes.error.js +20 -0
  115. package/dist/o-core/src/error/index.d.ts +3 -0
  116. package/dist/o-core/src/error/index.d.ts.map +1 -0
  117. package/dist/o-core/src/error/index.js +2 -0
  118. package/dist/o-core/src/error/interfaces/o-error.interface.d.ts +6 -0
  119. package/dist/o-core/src/error/interfaces/o-error.interface.d.ts.map +1 -0
  120. package/dist/o-core/src/error/interfaces/o-error.interface.js +1 -0
  121. package/dist/o-core/src/error/o-error.d.ts +15 -0
  122. package/dist/o-core/src/error/o-error.d.ts.map +1 -0
  123. package/dist/o-core/src/error/o-error.js +27 -0
  124. package/dist/o-core/src/index.d.ts +8 -0
  125. package/dist/o-core/src/index.d.ts.map +1 -0
  126. package/dist/o-core/src/index.js +7 -0
  127. package/dist/o-core/src/response/index.d.ts +2 -0
  128. package/dist/o-core/src/response/index.d.ts.map +1 -0
  129. package/dist/o-core/src/response/index.js +1 -0
  130. package/dist/o-core/src/response/response-builder.d.ts +140 -0
  131. package/dist/o-core/src/response/response-builder.d.ts.map +1 -0
  132. package/dist/o-core/src/response/response-builder.js +190 -0
  133. package/dist/o-core/src/router/enums/restricted-addresses.enum.d.ts +8 -0
  134. package/dist/o-core/src/router/enums/restricted-addresses.enum.d.ts.map +1 -0
  135. package/dist/o-core/src/router/enums/restricted-addresses.enum.js +13 -0
  136. package/dist/o-core/src/router/index.d.ts +11 -0
  137. package/dist/o-core/src/router/index.d.ts.map +1 -0
  138. package/dist/o-core/src/router/index.js +10 -0
  139. package/dist/o-core/src/router/interfaces/resolve.request.d.ts +10 -0
  140. package/dist/o-core/src/router/interfaces/resolve.request.d.ts.map +1 -0
  141. package/dist/o-core/src/router/interfaces/resolve.request.js +1 -0
  142. package/dist/o-core/src/router/interfaces/route.response.d.ts +8 -0
  143. package/dist/o-core/src/router/interfaces/route.response.d.ts.map +1 -0
  144. package/dist/o-core/src/router/interfaces/route.response.js +1 -0
  145. package/dist/o-core/src/router/o-address-resolver.d.ts +14 -0
  146. package/dist/o-core/src/router/o-address-resolver.d.ts.map +1 -0
  147. package/dist/o-core/src/router/o-address-resolver.js +19 -0
  148. package/dist/o-core/src/router/o-address.d.ts +33 -0
  149. package/dist/o-core/src/router/o-address.d.ts.map +1 -0
  150. package/dist/o-core/src/router/o-address.js +114 -0
  151. package/dist/o-core/src/router/o-request-preparation.d.ts +37 -0
  152. package/dist/o-core/src/router/o-request-preparation.d.ts.map +1 -0
  153. package/dist/o-core/src/router/o-request-preparation.js +75 -0
  154. package/dist/o-core/src/router/o-request.router.d.ts +18 -0
  155. package/dist/o-core/src/router/o-request.router.d.ts.map +1 -0
  156. package/dist/o-core/src/router/o-request.router.js +12 -0
  157. package/dist/o-core/src/router/o-resolver-chain.d.ts +32 -0
  158. package/dist/o-core/src/router/o-resolver-chain.d.ts.map +1 -0
  159. package/dist/o-core/src/router/o-resolver-chain.js +62 -0
  160. package/dist/o-core/src/router/o-router.d.ts +19 -0
  161. package/dist/o-core/src/router/o-router.d.ts.map +1 -0
  162. package/dist/o-core/src/router/o-router.js +14 -0
  163. package/dist/o-core/src/router/o-routing-policy.d.ts +36 -0
  164. package/dist/o-core/src/router/o-routing-policy.d.ts.map +1 -0
  165. package/dist/o-core/src/router/o-routing-policy.js +19 -0
  166. package/dist/o-core/src/streaming/index.d.ts +11 -0
  167. package/dist/o-core/src/streaming/index.d.ts.map +1 -0
  168. package/dist/o-core/src/streaming/index.js +14 -0
  169. package/dist/o-core/src/streaming/protocol-builder.d.ts +62 -0
  170. package/dist/o-core/src/streaming/protocol-builder.d.ts.map +1 -0
  171. package/dist/o-core/src/streaming/protocol-builder.js +93 -0
  172. package/dist/o-core/src/streaming/stream-config.d.ts +36 -0
  173. package/dist/o-core/src/streaming/stream-config.d.ts.map +1 -0
  174. package/dist/o-core/src/streaming/stream-config.js +19 -0
  175. package/dist/o-core/src/streaming/stream-handler.base.d.ts +85 -0
  176. package/dist/o-core/src/streaming/stream-handler.base.d.ts.map +1 -0
  177. package/dist/o-core/src/streaming/stream-handler.base.js +112 -0
  178. package/dist/o-core/src/streaming/stream-transport.interface.d.ts +61 -0
  179. package/dist/o-core/src/streaming/stream-transport.interface.d.ts.map +1 -0
  180. package/dist/o-core/src/streaming/stream-transport.interface.js +10 -0
  181. package/dist/o-core/src/transports/custom.transport.d.ts +6 -0
  182. package/dist/o-core/src/transports/custom.transport.d.ts.map +1 -0
  183. package/dist/o-core/src/transports/custom.transport.js +10 -0
  184. package/dist/o-core/src/transports/index.d.ts +4 -0
  185. package/dist/o-core/src/transports/index.d.ts.map +1 -0
  186. package/dist/o-core/src/transports/index.js +3 -0
  187. package/dist/o-core/src/transports/interfaces/transport-type.enum.d.ts +5 -0
  188. package/dist/o-core/src/transports/interfaces/transport-type.enum.d.ts.map +1 -0
  189. package/dist/o-core/src/transports/interfaces/transport-type.enum.js +5 -0
  190. package/dist/o-core/src/transports/o-transport.d.ts +10 -0
  191. package/dist/o-core/src/transports/o-transport.d.ts.map +1 -0
  192. package/dist/o-core/src/transports/o-transport.js +16 -0
  193. package/dist/o-core/src/utils/core.utils.d.ts +34 -0
  194. package/dist/o-core/src/utils/core.utils.d.ts.map +1 -0
  195. package/dist/o-core/src/utils/core.utils.js +123 -0
  196. package/dist/o-core/src/utils/index.d.ts +6 -0
  197. package/dist/o-core/src/utils/index.d.ts.map +1 -0
  198. package/dist/o-core/src/utils/index.js +5 -0
  199. package/dist/o-core/src/utils/logger.d.ts +14 -0
  200. package/dist/o-core/src/utils/logger.d.ts.map +1 -0
  201. package/dist/o-core/src/utils/logger.js +31 -0
  202. package/dist/o-core/src/utils/object.utils.d.ts +5 -0
  203. package/dist/o-core/src/utils/object.utils.d.ts.map +1 -0
  204. package/dist/o-core/src/utils/object.utils.js +23 -0
  205. package/dist/o-core/src/utils/regex.utils.d.ts +4 -0
  206. package/dist/o-core/src/utils/regex.utils.d.ts.map +1 -0
  207. package/dist/o-core/src/utils/regex.utils.js +13 -0
  208. package/dist/o-core/src/utils/remote.utils.d.ts +4 -0
  209. package/dist/o-core/src/utils/remote.utils.d.ts.map +1 -0
  210. package/dist/o-core/src/utils/remote.utils.js +5 -0
  211. package/dist/o-core/src/utils/streaming.utils.d.ts +22 -0
  212. package/dist/o-core/src/utils/streaming.utils.d.ts.map +1 -0
  213. package/dist/o-core/src/utils/streaming.utils.js +45 -0
  214. package/dist/o-node/src/connection/index.d.ts +5 -0
  215. package/dist/o-node/src/connection/index.d.ts.map +1 -0
  216. package/dist/o-node/src/connection/index.js +4 -0
  217. package/dist/o-node/src/connection/interfaces/o-node-connection-manager.config.d.ts +6 -0
  218. package/dist/o-node/src/connection/interfaces/o-node-connection-manager.config.d.ts.map +1 -0
  219. package/dist/o-node/src/connection/interfaces/o-node-connection-manager.config.js +1 -0
  220. package/dist/o-node/src/connection/interfaces/o-node-connection.config.d.ts +6 -0
  221. package/dist/o-node/src/connection/interfaces/o-node-connection.config.d.ts.map +1 -0
  222. package/dist/o-node/src/connection/interfaces/o-node-connection.config.js +1 -0
  223. package/dist/o-node/src/connection/o-node-connection.d.ts +13 -0
  224. package/dist/o-node/src/connection/o-node-connection.d.ts.map +1 -0
  225. package/dist/o-node/src/connection/o-node-connection.js +93 -0
  226. package/dist/o-node/src/connection/o-node-connection.manager.d.ts +19 -0
  227. package/dist/o-node/src/connection/o-node-connection.manager.d.ts.map +1 -0
  228. package/dist/o-node/src/connection/o-node-connection.manager.js +65 -0
  229. package/dist/o-node/src/connection/o-stream.request.d.ts +11 -0
  230. package/dist/o-node/src/connection/o-stream.request.d.ts.map +1 -0
  231. package/dist/o-node/src/connection/o-stream.request.js +7 -0
  232. package/dist/o-node/src/index.d.ts +12 -0
  233. package/dist/o-node/src/index.d.ts.map +1 -0
  234. package/dist/o-node/src/index.js +11 -0
  235. package/dist/o-node/src/interfaces/i-heartbeatable-node.d.ts +49 -0
  236. package/dist/o-node/src/interfaces/i-heartbeatable-node.d.ts.map +1 -0
  237. package/dist/o-node/src/interfaces/i-heartbeatable-node.js +1 -0
  238. package/dist/o-node/src/interfaces/i-reconnectable-node.d.ts +46 -0
  239. package/dist/o-node/src/interfaces/i-reconnectable-node.d.ts.map +1 -0
  240. package/dist/o-node/src/interfaces/i-reconnectable-node.js +1 -0
  241. package/dist/o-node/src/interfaces/o-node.config.d.ts +49 -0
  242. package/dist/o-node/src/interfaces/o-node.config.d.ts.map +1 -0
  243. package/dist/o-node/src/interfaces/o-node.config.js +1 -0
  244. package/dist/o-node/src/interfaces/o-node.tool-config.d.ts +4 -0
  245. package/dist/o-node/src/interfaces/o-node.tool-config.d.ts.map +1 -0
  246. package/dist/o-node/src/interfaces/o-node.tool-config.js +1 -0
  247. package/dist/o-node/src/lib/network-activity.lib.d.ts +1 -0
  248. package/dist/o-node/src/lib/network-activity.lib.d.ts.map +1 -0
  249. package/dist/o-node/src/lib/network-activity.lib.js +34 -0
  250. package/dist/o-node/src/managers/o-connection-heartbeat.manager.d.ts +63 -0
  251. package/dist/o-node/src/managers/o-connection-heartbeat.manager.d.ts.map +1 -0
  252. package/dist/o-node/src/managers/o-connection-heartbeat.manager.js +227 -0
  253. package/dist/o-node/src/managers/o-reconnection.manager.d.ts +51 -0
  254. package/dist/o-node/src/managers/o-reconnection.manager.d.ts.map +1 -0
  255. package/dist/o-node/src/managers/o-reconnection.manager.js +266 -0
  256. package/dist/o-node/src/nodes/client.node.d.ts +7 -0
  257. package/dist/o-node/src/nodes/client.node.d.ts.map +1 -0
  258. package/dist/o-node/src/nodes/client.node.js +16 -0
  259. package/dist/o-node/src/nodes/index.d.ts +4 -0
  260. package/dist/o-node/src/nodes/index.d.ts.map +1 -0
  261. package/dist/o-node/src/nodes/index.js +3 -0
  262. package/dist/o-node/src/nodes/server.node.d.ts +7 -0
  263. package/dist/o-node/src/nodes/server.node.d.ts.map +1 -0
  264. package/dist/o-node/src/nodes/server.node.js +20 -0
  265. package/dist/o-node/src/nodes/websocket.node.d.ts +7 -0
  266. package/dist/o-node/src/nodes/websocket.node.d.ts.map +1 -0
  267. package/dist/o-node/src/nodes/websocket.node.js +18 -0
  268. package/dist/o-node/src/o-node.d.ts +72 -0
  269. package/dist/o-node/src/o-node.d.ts.map +1 -0
  270. package/dist/o-node/src/o-node.hierarchy-manager.d.ts +15 -0
  271. package/dist/o-node/src/o-node.hierarchy-manager.d.ts.map +1 -0
  272. package/dist/o-node/src/o-node.hierarchy-manager.js +15 -0
  273. package/dist/o-node/src/o-node.js +493 -0
  274. package/dist/o-node/src/o-node.notification-manager.d.ts +52 -0
  275. package/dist/o-node/src/o-node.notification-manager.d.ts.map +1 -0
  276. package/dist/o-node/src/o-node.notification-manager.js +188 -0
  277. package/dist/o-node/src/o-node.tool.d.ts +18 -0
  278. package/dist/o-node/src/o-node.tool.d.ts.map +1 -0
  279. package/dist/o-node/src/o-node.tool.js +83 -0
  280. package/dist/o-node/src/router/index.d.ts +6 -0
  281. package/dist/o-node/src/router/index.d.ts.map +1 -0
  282. package/dist/o-node/src/router/index.js +5 -0
  283. package/dist/o-node/src/router/interfaces/o-node-router.config.d.ts +3 -0
  284. package/dist/o-node/src/router/interfaces/o-node-router.config.d.ts.map +1 -0
  285. package/dist/o-node/src/router/interfaces/o-node-router.config.js +1 -0
  286. package/dist/o-node/src/router/interfaces/o-node-router.response.d.ts +8 -0
  287. package/dist/o-node/src/router/interfaces/o-node-router.response.d.ts.map +1 -0
  288. package/dist/o-node/src/router/interfaces/o-node-router.response.js +1 -0
  289. package/dist/o-node/src/router/o-node.address.d.ts +18 -0
  290. package/dist/o-node/src/router/o-node.address.d.ts.map +1 -0
  291. package/dist/o-node/src/router/o-node.address.js +29 -0
  292. package/dist/o-node/src/router/o-node.router.d.ts +46 -0
  293. package/dist/o-node/src/router/o-node.router.d.ts.map +1 -0
  294. package/dist/o-node/src/router/o-node.router.js +181 -0
  295. package/dist/o-node/src/router/o-node.routing-policy.d.ts +30 -0
  296. package/dist/o-node/src/router/o-node.routing-policy.d.ts.map +1 -0
  297. package/dist/o-node/src/router/o-node.routing-policy.js +57 -0
  298. package/dist/o-node/src/router/o-node.transport.d.ts +11 -0
  299. package/dist/o-node/src/router/o-node.transport.d.ts.map +1 -0
  300. package/dist/o-node/src/router/o-node.transport.js +18 -0
  301. package/dist/o-node/src/router/resolvers/index.d.ts +4 -0
  302. package/dist/o-node/src/router/resolvers/index.d.ts.map +1 -0
  303. package/dist/o-node/src/router/resolvers/index.js +3 -0
  304. package/dist/o-node/src/router/resolvers/o-node.leader-resolver-fallback.d.ts +8 -0
  305. package/dist/o-node/src/router/resolvers/o-node.leader-resolver-fallback.d.ts.map +1 -0
  306. package/dist/o-node/src/router/resolvers/o-node.leader-resolver-fallback.js +35 -0
  307. package/dist/{src/router/resolvers/o-node.child-resolver.d.ts → o-node/src/router/resolvers/o-node.resolver.d.ts} +2 -2
  308. package/dist/o-node/src/router/resolvers/o-node.resolver.d.ts.map +1 -0
  309. package/dist/o-node/src/router/resolvers/o-node.resolver.js +45 -0
  310. package/dist/o-node/src/router/resolvers/o-node.search-resolver.d.ts +170 -0
  311. package/dist/o-node/src/router/resolvers/o-node.search-resolver.d.ts.map +1 -0
  312. package/dist/o-node/src/router/resolvers/o-node.search-resolver.js +285 -0
  313. package/dist/o-node/src/router/route.request.d.ts +14 -0
  314. package/dist/o-node/src/router/route.request.d.ts.map +1 -0
  315. package/dist/o-node/src/router/route.request.js +1 -0
  316. package/dist/o-node/src/streaming/index.d.ts +10 -0
  317. package/dist/o-node/src/streaming/index.d.ts.map +1 -0
  318. package/dist/o-node/src/streaming/index.js +12 -0
  319. package/dist/o-node/src/streaming/libp2p-stream-transport.d.ts +50 -0
  320. package/dist/o-node/src/streaming/libp2p-stream-transport.d.ts.map +1 -0
  321. package/dist/o-node/src/streaming/libp2p-stream-transport.js +137 -0
  322. package/dist/o-node/src/streaming/node-stream-handler.d.ts +65 -0
  323. package/dist/o-node/src/streaming/node-stream-handler.d.ts.map +1 -0
  324. package/dist/o-node/src/streaming/node-stream-handler.js +101 -0
  325. package/dist/o-node/src/ui/index.d.ts +3 -0
  326. package/dist/o-node/src/ui/index.d.ts.map +1 -0
  327. package/dist/o-node/src/ui/index.js +2 -0
  328. package/dist/o-node/src/ui/types.d.ts +110 -0
  329. package/dist/o-node/src/ui/types.d.ts.map +1 -0
  330. package/dist/o-node/src/ui/types.js +17 -0
  331. package/dist/o-node/src/ui/ui-graph.manager.d.ts +70 -0
  332. package/dist/o-node/src/ui/ui-graph.manager.d.ts.map +1 -0
  333. package/dist/o-node/src/ui/ui-graph.manager.js +274 -0
  334. package/dist/o-node/src/utils/circuit-breaker.d.ts +107 -0
  335. package/dist/o-node/src/utils/circuit-breaker.d.ts.map +1 -0
  336. package/dist/o-node/src/utils/circuit-breaker.js +175 -0
  337. package/dist/o-node/src/utils/index.d.ts +3 -0
  338. package/dist/o-node/src/utils/index.d.ts.map +1 -0
  339. package/dist/o-node/src/utils/index.js +2 -0
  340. package/dist/o-node/src/utils/leader-request-wrapper.d.ts +66 -0
  341. package/dist/o-node/src/utils/leader-request-wrapper.d.ts.map +1 -0
  342. package/dist/o-node/src/utils/leader-request-wrapper.js +160 -0
  343. package/dist/o-node/src/utils/network.utils.d.ts +20 -0
  344. package/dist/o-node/src/utils/network.utils.d.ts.map +1 -0
  345. package/dist/o-node/src/utils/network.utils.js +74 -0
  346. package/dist/o-node/src/utils/stream.utils.d.ts +6 -0
  347. package/dist/o-node/src/utils/stream.utils.d.ts.map +1 -0
  348. package/dist/o-node/src/utils/stream.utils.js +31 -0
  349. package/dist/o-node/test/circuit-breaker.test.d.ts +2 -0
  350. package/dist/o-node/test/circuit-breaker.test.d.ts.map +1 -0
  351. package/dist/o-node/test/circuit-breaker.test.js +262 -0
  352. package/dist/o-node/test/helpers/test-node.tool.d.ts +15 -0
  353. package/dist/o-node/test/helpers/test-node.tool.d.ts.map +1 -0
  354. package/dist/o-node/test/helpers/test-node.tool.js +27 -0
  355. package/dist/o-node/test/leader-request-wrapper.test.d.ts +1 -0
  356. package/dist/o-node/test/leader-request-wrapper.test.d.ts.map +1 -0
  357. package/dist/o-node/test/leader-request-wrapper.test.js +246 -0
  358. package/dist/o-node/test/o-node.spec.d.ts +2 -0
  359. package/dist/o-node/test/o-node.spec.d.ts.map +1 -0
  360. package/dist/o-node/test/o-node.spec.js +20 -0
  361. package/dist/o-node/test/search-resolver.spec.d.ts +2 -0
  362. package/dist/o-node/test/search-resolver.spec.d.ts.map +1 -0
  363. package/dist/o-node/test/search-resolver.spec.js +693 -0
  364. package/dist/src/connection/o-node-connection.d.ts +2 -2
  365. package/dist/src/connection/o-node-connection.d.ts.map +1 -1
  366. package/dist/src/connection/o-node-connection.js +54 -19
  367. package/dist/src/connection/o-node-connection.manager.d.ts +16 -4
  368. package/dist/src/connection/o-node-connection.manager.d.ts.map +1 -1
  369. package/dist/src/connection/o-node-connection.manager.js +73 -44
  370. package/dist/src/connection/o-stream.request.d.ts +11 -0
  371. package/dist/src/connection/o-stream.request.d.ts.map +1 -0
  372. package/dist/src/connection/o-stream.request.js +7 -0
  373. package/dist/src/index.d.ts +2 -1
  374. package/dist/src/index.d.ts.map +1 -1
  375. package/dist/src/index.js +2 -1
  376. package/dist/src/interfaces/i-heartbeatable-node.d.ts +49 -0
  377. package/dist/src/interfaces/i-heartbeatable-node.d.ts.map +1 -0
  378. package/dist/src/interfaces/i-heartbeatable-node.js +1 -0
  379. package/dist/src/interfaces/i-reconnectable-node.d.ts +46 -0
  380. package/dist/src/interfaces/i-reconnectable-node.d.ts.map +1 -0
  381. package/dist/src/interfaces/i-reconnectable-node.js +1 -0
  382. package/dist/src/interfaces/o-node.config.d.ts +42 -0
  383. package/dist/src/interfaces/o-node.config.d.ts.map +1 -1
  384. package/dist/src/managers/o-connection-heartbeat.manager.d.ts +63 -0
  385. package/dist/src/managers/o-connection-heartbeat.manager.d.ts.map +1 -0
  386. package/dist/src/managers/o-connection-heartbeat.manager.js +227 -0
  387. package/dist/src/managers/o-reconnection.manager.d.ts +51 -0
  388. package/dist/src/managers/o-reconnection.manager.d.ts.map +1 -0
  389. package/dist/src/managers/o-reconnection.manager.js +266 -0
  390. package/dist/src/o-node.d.ts +30 -2
  391. package/dist/src/o-node.d.ts.map +1 -1
  392. package/dist/src/o-node.js +244 -33
  393. package/dist/src/o-node.notification-manager.d.ts +52 -0
  394. package/dist/src/o-node.notification-manager.d.ts.map +1 -0
  395. package/dist/src/o-node.notification-manager.js +188 -0
  396. package/dist/src/o-node.tool.d.ts.map +1 -1
  397. package/dist/src/o-node.tool.js +33 -24
  398. package/dist/src/router/o-node.router.d.ts +1 -0
  399. package/dist/src/router/o-node.router.d.ts.map +1 -1
  400. package/dist/src/router/o-node.router.js +61 -5
  401. package/dist/src/router/o-node.routing-policy.d.ts.map +1 -1
  402. package/dist/src/router/o-node.routing-policy.js +7 -2
  403. package/dist/src/router/resolvers/o-node.resolver.d.ts.map +1 -1
  404. package/dist/src/router/resolvers/o-node.resolver.js +5 -1
  405. package/dist/src/router/resolvers/o-node.search-resolver.d.ts.map +1 -1
  406. package/dist/src/router/resolvers/o-node.search-resolver.js +34 -9
  407. package/dist/src/streaming/index.d.ts +10 -0
  408. package/dist/src/streaming/index.d.ts.map +1 -0
  409. package/dist/src/streaming/index.js +12 -0
  410. package/dist/src/streaming/libp2p-stream-transport.d.ts +50 -0
  411. package/dist/src/streaming/libp2p-stream-transport.d.ts.map +1 -0
  412. package/dist/src/streaming/libp2p-stream-transport.js +137 -0
  413. package/dist/src/streaming/node-stream-handler.d.ts +65 -0
  414. package/dist/src/streaming/node-stream-handler.d.ts.map +1 -0
  415. package/dist/src/streaming/node-stream-handler.js +101 -0
  416. package/dist/src/streaming/o-node-streaming-client.d.ts +33 -0
  417. package/dist/src/streaming/o-node-streaming-client.d.ts.map +1 -0
  418. package/dist/src/streaming/o-node-streaming-client.js +130 -0
  419. package/dist/src/utils/circuit-breaker.d.ts +107 -0
  420. package/dist/src/utils/circuit-breaker.d.ts.map +1 -0
  421. package/dist/src/utils/circuit-breaker.js +175 -0
  422. package/dist/src/utils/circuit-breaker.test.d.ts +2 -0
  423. package/dist/src/utils/circuit-breaker.test.d.ts.map +1 -0
  424. package/dist/src/utils/circuit-breaker.test.js +262 -0
  425. package/dist/src/utils/index.d.ts +3 -0
  426. package/dist/src/utils/index.d.ts.map +1 -0
  427. package/dist/src/utils/index.js +2 -0
  428. package/dist/src/utils/leader-request-wrapper.d.ts +66 -0
  429. package/dist/src/utils/leader-request-wrapper.d.ts.map +1 -0
  430. package/dist/src/utils/leader-request-wrapper.js +160 -0
  431. package/dist/src/utils/leader-request-wrapper.test.d.ts +1 -0
  432. package/dist/src/utils/leader-request-wrapper.test.d.ts.map +1 -0
  433. package/dist/src/utils/leader-request-wrapper.test.js +246 -0
  434. package/dist/src/utils/stream.utils.d.ts +6 -0
  435. package/dist/src/utils/stream.utils.d.ts.map +1 -0
  436. package/dist/src/utils/stream.utils.js +31 -0
  437. package/dist/test/circuit-breaker.test.d.ts +2 -0
  438. package/dist/test/circuit-breaker.test.d.ts.map +1 -0
  439. package/dist/test/circuit-breaker.test.js +262 -0
  440. package/dist/test/helpers/test-node.tool.d.ts +15 -0
  441. package/dist/test/helpers/test-node.tool.d.ts.map +1 -0
  442. package/dist/test/helpers/test-node.tool.js +27 -0
  443. package/dist/test/leader-request-wrapper.test.d.ts +1 -0
  444. package/dist/test/leader-request-wrapper.test.d.ts.map +1 -0
  445. package/dist/test/leader-request-wrapper.test.js +246 -0
  446. package/package.json +6 -6
  447. package/dist/src/router/resolvers/o-node.child-resolver.d.ts.map +0 -1
  448. package/dist/src/router/resolvers/o-node.child-resolver.js +0 -58
@@ -0,0 +1 @@
1
+ {"version":3,"file":"node-stream-handler.d.ts","sourceRoot":"","sources":["../../../src/streaming/node-stream-handler.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,oBAAoB,EAErB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAErE;;GAEG;AACH,MAAM,WAAW,wBAAyB,SAAQ,oBAAoB;IACpE;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,eAAe,CAAC,EAAE,OAAO,CAAC;CAC3B;AAED;;;GAGG;AACH,qBAAa,iBAAkB,SAAQ,iBAAiB;IACtD,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,SAAS,CAAwB;IACzC,OAAO,CAAC,WAAW,CAA2B;gBAG5C,SAAS,EAAE,qBAAqB,EAChC,OAAO,GAAE,wBAA6B;IAWxC;;OAEG;IACI,eAAe,IAAI,MAAM;IAIhC;;OAEG;IACI,aAAa,IAAI,MAAM;IAI9B;;OAEG;IACI,YAAY,IAAI,IAAI;IAK3B;;OAEG;cACa,SAAS,CACvB,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,QAAQ,GAChB,OAAO,CAAC,IAAI,CAAC;IA0BhB;;OAEG;cACgB,aAAa,CAAC,OAAO,EAAE,QAAQ,GAAG,IAAI;IAOzD;;OAEG;cACgB,gBAAgB,CACjC,OAAO,EAAE,QAAQ,EACjB,WAAW,EAAE,MAAM,GAClB,IAAI;IASP;;OAEG;cACgB,aAAa,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI;IAUrE;;OAEG;IACI,KAAK,IAAI,IAAI;IAOpB;;;OAGG;WACW,MAAM,CAClB,SAAS,EAAE,qBAAqB,EAChC,OAAO,CAAC,EAAE,wBAAwB,GACjC,iBAAiB;CAGrB"}
@@ -0,0 +1,101 @@
1
+ import { StreamHandlerBase, ProtocolBuilder, } from '@olane/o-core';
2
+ /**
3
+ * o-node specific implementation of StreamHandlerBase.
4
+ * Integrates with libp2p streams and tracks metrics for o-node tools.
5
+ */
6
+ export class NodeStreamHandler extends StreamHandlerBase {
7
+ constructor(transport, options = {}) {
8
+ super(options);
9
+ this.successCount = 0;
10
+ this.errorCount = 0;
11
+ this.transport = transport;
12
+ this.nodeOptions = {
13
+ trackSuccessCount: true,
14
+ trackErrorCount: true,
15
+ ...options,
16
+ };
17
+ }
18
+ /**
19
+ * Get the success count (number of chunks successfully sent)
20
+ */
21
+ getSuccessCount() {
22
+ return this.successCount;
23
+ }
24
+ /**
25
+ * Get the error count
26
+ */
27
+ getErrorCount() {
28
+ return this.errorCount;
29
+ }
30
+ /**
31
+ * Reset metrics
32
+ */
33
+ resetMetrics() {
34
+ this.successCount = 0;
35
+ this.errorCount = 0;
36
+ }
37
+ /**
38
+ * Implementation of sendChunk using libp2p transport and protocol builder
39
+ */
40
+ async sendChunk(chunk, sequence, isLast, request) {
41
+ // Build the JSON-RPC streaming chunk message
42
+ const message = ProtocolBuilder.buildStreamChunkFromRequest(chunk, sequence, isLast, request);
43
+ // Encode the message to bytes
44
+ const encoded = ProtocolBuilder.encodeMessage(message);
45
+ // Send through the transport (handles backpressure)
46
+ await this.transport.send(encoded);
47
+ // Track metrics if enabled
48
+ if (this.nodeOptions.trackSuccessCount) {
49
+ this.successCount++;
50
+ }
51
+ // Close the stream if this is the last chunk
52
+ if (isLast) {
53
+ await this.transport.close();
54
+ }
55
+ }
56
+ /**
57
+ * Hook: Called when streaming starts
58
+ */
59
+ onStreamStart(request) {
60
+ // Reset metrics for this stream
61
+ if (this.nodeOptions.enableMetrics) {
62
+ this.resetMetrics();
63
+ }
64
+ }
65
+ /**
66
+ * Hook: Called when streaming completes successfully
67
+ */
68
+ onStreamComplete(request, totalChunks) {
69
+ // Log completion if metrics enabled
70
+ if (this.nodeOptions.enableMetrics) {
71
+ console.log(`Stream completed for ${request.method}: ${totalChunks} chunks sent`);
72
+ }
73
+ }
74
+ /**
75
+ * Hook: Called when streaming encounters an error
76
+ */
77
+ onStreamError(request, error) {
78
+ // Track error count
79
+ if (this.nodeOptions.trackErrorCount) {
80
+ this.errorCount++;
81
+ }
82
+ // Log error
83
+ console.error(`Stream error for ${request.method}:`, error);
84
+ }
85
+ /**
86
+ * Reset the handler for reuse with a new transport
87
+ */
88
+ reset() {
89
+ // Call parent reset
90
+ this.state = 0; // Reset state (IDLE)
91
+ this.currentSequence = 0;
92
+ this.resetMetrics();
93
+ }
94
+ /**
95
+ * Create a new NodeStreamHandler with a different transport
96
+ * (useful for handling multiple streams)
97
+ */
98
+ static create(transport, options) {
99
+ return new NodeStreamHandler(transport, options);
100
+ }
101
+ }
@@ -0,0 +1,33 @@
1
+ import { Stream } from '@olane/o-config';
2
+ import { oRequest, StreamTransportConfig } from '@olane/o-core';
3
+ /**
4
+ * Client-side streaming orchestration for o-node.
5
+ * Manages chunk queues, backpressure, timeouts, and provides both
6
+ * callback and AsyncGenerator interfaces for streaming responses.
7
+ */
8
+ export declare class oNodeStreamingClient {
9
+ /**
10
+ * Transmit a request via streaming and receive chunks through a callback.
11
+ * This method handles the full streaming lifecycle including timeouts,
12
+ * chunk sequencing, and cleanup.
13
+ *
14
+ * @param stream The libp2p stream to use for communication
15
+ * @param request The request to send
16
+ * @param onChunk Callback invoked for each chunk received
17
+ * @param config Optional transport configuration
18
+ * @returns Promise that resolves when the stream completes
19
+ */
20
+ streamRequest(stream: Stream, request: oRequest, onChunk: (chunk: any, sequence: number, isLast: boolean) => void, config?: StreamTransportConfig): Promise<void>;
21
+ /**
22
+ * Transmit a request via streaming and receive chunks as an AsyncGenerator.
23
+ * This enables true streaming by yielding chunks as they arrive, not buffering them all first.
24
+ * Manages chunk queue with backpressure coordination between chunk arrival and consumption.
25
+ *
26
+ * @param stream The libp2p stream to use for communication
27
+ * @param request The request to send
28
+ * @param config Optional transport configuration
29
+ * @returns AsyncGenerator that yields chunks as they arrive
30
+ */
31
+ streamAsGenerator(stream: Stream, request: oRequest, config?: StreamTransportConfig): AsyncGenerator<any, void, unknown>;
32
+ }
33
+ //# sourceMappingURL=o-node-streaming-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"o-node-streaming-client.d.ts","sourceRoot":"","sources":["../../../src/streaming/o-node-streaming-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAGL,QAAQ,EAER,qBAAqB,EACtB,MAAM,eAAe,CAAC;AAGvB;;;;GAIG;AACH,qBAAa,oBAAoB;IAC/B;;;;;;;;;;OAUG;IACG,aAAa,CACjB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,KAAK,IAAI,EAChE,MAAM,CAAC,EAAE,qBAAqB,GAC7B,OAAO,CAAC,IAAI,CAAC;IAgEhB;;;;;;;;;OASG;IACI,iBAAiB,CACtB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,QAAQ,EACjB,MAAM,CAAC,EAAE,qBAAqB,GAC7B,cAAc,CAAC,GAAG,EAAE,IAAI,EAAE,OAAO,CAAC;CA2DtC"}
@@ -0,0 +1,130 @@
1
+ import { oError, oErrorCodes, ProtocolBuilder, } from '@olane/o-core';
2
+ import { Libp2pStreamTransport } from './libp2p-stream-transport.js';
3
+ /**
4
+ * Client-side streaming orchestration for o-node.
5
+ * Manages chunk queues, backpressure, timeouts, and provides both
6
+ * callback and AsyncGenerator interfaces for streaming responses.
7
+ */
8
+ export class oNodeStreamingClient {
9
+ /**
10
+ * Transmit a request via streaming and receive chunks through a callback.
11
+ * This method handles the full streaming lifecycle including timeouts,
12
+ * chunk sequencing, and cleanup.
13
+ *
14
+ * @param stream The libp2p stream to use for communication
15
+ * @param request The request to send
16
+ * @param onChunk Callback invoked for each chunk received
17
+ * @param config Optional transport configuration
18
+ * @returns Promise that resolves when the stream completes
19
+ */
20
+ async streamRequest(stream, request, onChunk, config) {
21
+ // Create transport abstraction
22
+ const transport = new Libp2pStreamTransport(stream, config);
23
+ // Send the request using the transport
24
+ const data = new TextEncoder().encode(request.toString());
25
+ await transport.send(data);
26
+ // Set up to receive multiple chunks
27
+ return new Promise((resolve, reject) => {
28
+ // Set up timeout for receiving first chunk
29
+ const timeout = setTimeout(async () => {
30
+ transport.removeMessageHandler();
31
+ await transport.close();
32
+ reject(new oError(oErrorCodes.TIMEOUT, 'Timeout waiting for streaming response'));
33
+ }, config?.readTimeoutMs ?? 120000);
34
+ let timeoutCleared = false;
35
+ const messageHandler = async (data) => {
36
+ // Clear timeout on first message
37
+ if (!timeoutCleared) {
38
+ clearTimeout(timeout);
39
+ timeoutCleared = true;
40
+ }
41
+ try {
42
+ const response = ProtocolBuilder.decodeMessage(data);
43
+ // Try to parse as streaming chunk
44
+ const chunk = ProtocolBuilder.parseStreamChunk(response);
45
+ if (chunk) {
46
+ // Streaming response
47
+ onChunk(chunk.data, chunk.sequence, chunk.isLast);
48
+ if (chunk.isLast) {
49
+ transport.removeMessageHandler();
50
+ await transport.close();
51
+ resolve();
52
+ }
53
+ }
54
+ else {
55
+ // Non-streaming response (fallback for compatibility)
56
+ onChunk(response.result, 1, true);
57
+ transport.removeMessageHandler();
58
+ await transport.close();
59
+ resolve();
60
+ }
61
+ }
62
+ catch (error) {
63
+ transport.removeMessageHandler();
64
+ await transport.close();
65
+ reject(error);
66
+ }
67
+ };
68
+ transport.onMessage(messageHandler);
69
+ });
70
+ }
71
+ /**
72
+ * Transmit a request via streaming and receive chunks as an AsyncGenerator.
73
+ * This enables true streaming by yielding chunks as they arrive, not buffering them all first.
74
+ * Manages chunk queue with backpressure coordination between chunk arrival and consumption.
75
+ *
76
+ * @param stream The libp2p stream to use for communication
77
+ * @param request The request to send
78
+ * @param config Optional transport configuration
79
+ * @returns AsyncGenerator that yields chunks as they arrive
80
+ */
81
+ async *streamAsGenerator(stream, request, config) {
82
+ const chunkQueue = [];
83
+ let streamComplete = false;
84
+ let streamError = null;
85
+ let resolveNextChunk = null;
86
+ // Start streaming in the background using callback pattern
87
+ const transmitPromise = this.streamRequest(stream, request, (chunk, sequence, isLast) => {
88
+ chunkQueue.push({ chunk, sequence, isLast });
89
+ if (isLast) {
90
+ streamComplete = true;
91
+ }
92
+ // Notify that a new chunk is available
93
+ if (resolveNextChunk) {
94
+ resolveNextChunk();
95
+ resolveNextChunk = null;
96
+ }
97
+ }, config).catch((error) => {
98
+ streamError = error;
99
+ // Notify of error
100
+ if (resolveNextChunk) {
101
+ resolveNextChunk();
102
+ resolveNextChunk = null;
103
+ }
104
+ });
105
+ // Yield chunks as they arrive
106
+ while (!streamComplete && !streamError) {
107
+ if (chunkQueue.length > 0) {
108
+ const { chunk } = chunkQueue.shift();
109
+ yield chunk;
110
+ }
111
+ else {
112
+ // Wait for next chunk
113
+ await new Promise((resolve) => {
114
+ resolveNextChunk = resolve;
115
+ });
116
+ }
117
+ }
118
+ // Yield any remaining chunks
119
+ while (chunkQueue.length > 0) {
120
+ const { chunk } = chunkQueue.shift();
121
+ yield chunk;
122
+ }
123
+ // Wait for transmit to complete
124
+ await transmitPromise;
125
+ // If there was an error, throw it
126
+ if (streamError) {
127
+ throw streamError;
128
+ }
129
+ }
130
+ }
@@ -0,0 +1,107 @@
1
+ import { oObject } from '@olane/o-core';
2
+ export declare enum CircuitState {
3
+ CLOSED = "CLOSED",// Normal operation, requests pass through
4
+ OPEN = "OPEN",// Circuit broken, requests fast-fail
5
+ HALF_OPEN = "HALF_OPEN"
6
+ }
7
+ export interface CircuitBreakerConfig {
8
+ failureThreshold: number;
9
+ openTimeoutMs: number;
10
+ halfOpenMaxAttempts: number;
11
+ enabled: boolean;
12
+ }
13
+ export interface CircuitStats {
14
+ state: CircuitState;
15
+ consecutiveFailures: number;
16
+ totalFailures: number;
17
+ totalSuccesses: number;
18
+ lastFailureTime?: number;
19
+ lastSuccessTime?: number;
20
+ openedAt?: number;
21
+ }
22
+ /**
23
+ * Circuit Breaker Pattern Implementation
24
+ *
25
+ * Prevents cascading failures by "breaking the circuit" when a service
26
+ * experiences persistent failures. This allows the system to fail fast
27
+ * rather than wasting resources on retries that are likely to fail.
28
+ *
29
+ * States:
30
+ * - CLOSED: Normal operation, all requests pass through
31
+ * - OPEN: Circuit broken due to failures, requests fail immediately
32
+ * - HALF_OPEN: Testing recovery, limited requests allowed
33
+ *
34
+ * Flow:
35
+ * 1. CLOSED -> OPEN: After N consecutive failures
36
+ * 2. OPEN -> HALF_OPEN: After timeout period
37
+ * 3. HALF_OPEN -> CLOSED: After successful request
38
+ * 4. HALF_OPEN -> OPEN: After failure in recovery
39
+ *
40
+ * @example
41
+ * ```typescript
42
+ * const breaker = new CircuitBreaker('registry', {
43
+ * failureThreshold: 3,
44
+ * openTimeoutMs: 30000,
45
+ * halfOpenMaxAttempts: 1,
46
+ * enabled: true,
47
+ * });
48
+ *
49
+ * // Before making request
50
+ * if (!breaker.shouldAllowRequest()) {
51
+ * throw new Error('Circuit breaker is open');
52
+ * }
53
+ *
54
+ * try {
55
+ * const result = await makeRequest();
56
+ * breaker.recordSuccess();
57
+ * return result;
58
+ * } catch (error) {
59
+ * breaker.recordFailure();
60
+ * throw error;
61
+ * }
62
+ * ```
63
+ */
64
+ export declare class CircuitBreaker extends oObject {
65
+ private readonly serviceName;
66
+ private readonly config;
67
+ private state;
68
+ private consecutiveFailures;
69
+ private totalFailures;
70
+ private totalSuccesses;
71
+ private lastFailureTime?;
72
+ private lastSuccessTime?;
73
+ private openedAt?;
74
+ private halfOpenAttempts;
75
+ constructor(serviceName: string, config: CircuitBreakerConfig);
76
+ /**
77
+ * Check if a request should be allowed through the circuit breaker
78
+ * @returns true if request should proceed, false if should fast-fail
79
+ */
80
+ shouldAllowRequest(): boolean;
81
+ /**
82
+ * Record a successful request
83
+ */
84
+ recordSuccess(): void;
85
+ /**
86
+ * Record a failed request
87
+ */
88
+ recordFailure(): void;
89
+ /**
90
+ * Get current statistics
91
+ */
92
+ getStats(): CircuitStats;
93
+ /**
94
+ * Get current circuit state
95
+ */
96
+ getState(): CircuitState;
97
+ /**
98
+ * Force reset the circuit breaker to CLOSED state
99
+ * Use with caution - mainly for testing or manual recovery
100
+ */
101
+ reset(): void;
102
+ /**
103
+ * Transition to a new state
104
+ */
105
+ private transitionTo;
106
+ }
107
+ //# sourceMappingURL=circuit-breaker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circuit-breaker.d.ts","sourceRoot":"","sources":["../../../src/utils/circuit-breaker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,oBAAY,YAAY;IACtB,MAAM,WAAW,CAAE,0CAA0C;IAC7D,IAAI,SAAS,CAAE,qCAAqC;IACpD,SAAS,cAAc;CACxB;AAED,MAAM,WAAW,oBAAoB;IACnC,gBAAgB,EAAE,MAAM,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,YAAY,CAAC;IACpB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,aAAa,EAAE,MAAM,CAAC;IACtB,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCG;AACH,qBAAa,cAAe,SAAQ,OAAO;IAWvC,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM;IAXzB,OAAO,CAAC,KAAK,CAAqC;IAClD,OAAO,CAAC,mBAAmB,CAAa;IACxC,OAAO,CAAC,aAAa,CAAa;IAClC,OAAO,CAAC,cAAc,CAAa;IACnC,OAAO,CAAC,eAAe,CAAC,CAAS;IACjC,OAAO,CAAC,eAAe,CAAC,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,CAAS;IAC1B,OAAO,CAAC,gBAAgB,CAAa;gBAGlB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,oBAAoB;IAW/C;;;OAGG;IACH,kBAAkB,IAAI,OAAO;IA2C7B;;OAEG;IACH,aAAa,IAAI,IAAI;IAkBrB;;OAEG;IACH,aAAa,IAAI,IAAI;IA+BrB;;OAEG;IACH,QAAQ,IAAI,YAAY;IAYxB;;OAEG;IACH,QAAQ,IAAI,YAAY;IAIxB;;;OAGG;IACH,KAAK,IAAI,IAAI;IAQb;;OAEG;IACH,OAAO,CAAC,YAAY;CAOrB"}
@@ -0,0 +1,175 @@
1
+ import { oObject } from '@olane/o-core';
2
+ export var CircuitState;
3
+ (function (CircuitState) {
4
+ CircuitState["CLOSED"] = "CLOSED";
5
+ CircuitState["OPEN"] = "OPEN";
6
+ CircuitState["HALF_OPEN"] = "HALF_OPEN";
7
+ })(CircuitState || (CircuitState = {}));
8
+ /**
9
+ * Circuit Breaker Pattern Implementation
10
+ *
11
+ * Prevents cascading failures by "breaking the circuit" when a service
12
+ * experiences persistent failures. This allows the system to fail fast
13
+ * rather than wasting resources on retries that are likely to fail.
14
+ *
15
+ * States:
16
+ * - CLOSED: Normal operation, all requests pass through
17
+ * - OPEN: Circuit broken due to failures, requests fail immediately
18
+ * - HALF_OPEN: Testing recovery, limited requests allowed
19
+ *
20
+ * Flow:
21
+ * 1. CLOSED -> OPEN: After N consecutive failures
22
+ * 2. OPEN -> HALF_OPEN: After timeout period
23
+ * 3. HALF_OPEN -> CLOSED: After successful request
24
+ * 4. HALF_OPEN -> OPEN: After failure in recovery
25
+ *
26
+ * @example
27
+ * ```typescript
28
+ * const breaker = new CircuitBreaker('registry', {
29
+ * failureThreshold: 3,
30
+ * openTimeoutMs: 30000,
31
+ * halfOpenMaxAttempts: 1,
32
+ * enabled: true,
33
+ * });
34
+ *
35
+ * // Before making request
36
+ * if (!breaker.shouldAllowRequest()) {
37
+ * throw new Error('Circuit breaker is open');
38
+ * }
39
+ *
40
+ * try {
41
+ * const result = await makeRequest();
42
+ * breaker.recordSuccess();
43
+ * return result;
44
+ * } catch (error) {
45
+ * breaker.recordFailure();
46
+ * throw error;
47
+ * }
48
+ * ```
49
+ */
50
+ export class CircuitBreaker extends oObject {
51
+ constructor(serviceName, config) {
52
+ super();
53
+ this.serviceName = serviceName;
54
+ this.config = config;
55
+ this.state = CircuitState.CLOSED;
56
+ this.consecutiveFailures = 0;
57
+ this.totalFailures = 0;
58
+ this.totalSuccesses = 0;
59
+ this.halfOpenAttempts = 0;
60
+ this.logger.debug(`Circuit breaker initialized for ${serviceName}:`, `threshold=${config.failureThreshold},`, `timeout=${config.openTimeoutMs}ms,`, `enabled=${config.enabled}`);
61
+ }
62
+ /**
63
+ * Check if a request should be allowed through the circuit breaker
64
+ * @returns true if request should proceed, false if should fast-fail
65
+ */
66
+ shouldAllowRequest() {
67
+ if (!this.config.enabled) {
68
+ return true;
69
+ }
70
+ const now = Date.now();
71
+ switch (this.state) {
72
+ case CircuitState.CLOSED:
73
+ return true;
74
+ case CircuitState.OPEN:
75
+ // Check if timeout period has elapsed
76
+ if (this.openedAt &&
77
+ now - this.openedAt >= this.config.openTimeoutMs) {
78
+ this.logger.info(`Circuit breaker for ${this.serviceName} entering HALF_OPEN state`);
79
+ this.transitionTo(CircuitState.HALF_OPEN);
80
+ this.halfOpenAttempts = 0;
81
+ return true;
82
+ }
83
+ // Circuit still open, fast-fail
84
+ this.logger.debug(`Circuit breaker for ${this.serviceName} is OPEN, rejecting request`);
85
+ return false;
86
+ case CircuitState.HALF_OPEN:
87
+ // Allow limited attempts in HALF_OPEN state
88
+ if (this.halfOpenAttempts < this.config.halfOpenMaxAttempts) {
89
+ this.halfOpenAttempts++;
90
+ return true;
91
+ }
92
+ this.logger.debug(`Circuit breaker for ${this.serviceName} HALF_OPEN max attempts reached`);
93
+ return false;
94
+ }
95
+ }
96
+ /**
97
+ * Record a successful request
98
+ */
99
+ recordSuccess() {
100
+ if (!this.config.enabled) {
101
+ return;
102
+ }
103
+ this.totalSuccesses++;
104
+ this.lastSuccessTime = Date.now();
105
+ this.consecutiveFailures = 0;
106
+ if (this.state === CircuitState.HALF_OPEN) {
107
+ this.logger.info(`Circuit breaker for ${this.serviceName} recovered, closing circuit`);
108
+ this.transitionTo(CircuitState.CLOSED);
109
+ this.halfOpenAttempts = 0;
110
+ }
111
+ }
112
+ /**
113
+ * Record a failed request
114
+ */
115
+ recordFailure() {
116
+ if (!this.config.enabled) {
117
+ return;
118
+ }
119
+ this.totalFailures++;
120
+ this.consecutiveFailures++;
121
+ this.lastFailureTime = Date.now();
122
+ if (this.state === CircuitState.HALF_OPEN) {
123
+ this.logger.warn(`Circuit breaker for ${this.serviceName} failed in HALF_OPEN, reopening circuit`);
124
+ this.transitionTo(CircuitState.OPEN);
125
+ this.openedAt = Date.now();
126
+ this.halfOpenAttempts = 0;
127
+ return;
128
+ }
129
+ if (this.state === CircuitState.CLOSED &&
130
+ this.consecutiveFailures >= this.config.failureThreshold) {
131
+ this.logger.error(`Circuit breaker for ${this.serviceName} opening after ${this.consecutiveFailures} consecutive failures`);
132
+ this.transitionTo(CircuitState.OPEN);
133
+ this.openedAt = Date.now();
134
+ }
135
+ }
136
+ /**
137
+ * Get current statistics
138
+ */
139
+ getStats() {
140
+ return {
141
+ state: this.state,
142
+ consecutiveFailures: this.consecutiveFailures,
143
+ totalFailures: this.totalFailures,
144
+ totalSuccesses: this.totalSuccesses,
145
+ lastFailureTime: this.lastFailureTime,
146
+ lastSuccessTime: this.lastSuccessTime,
147
+ openedAt: this.openedAt,
148
+ };
149
+ }
150
+ /**
151
+ * Get current circuit state
152
+ */
153
+ getState() {
154
+ return this.state;
155
+ }
156
+ /**
157
+ * Force reset the circuit breaker to CLOSED state
158
+ * Use with caution - mainly for testing or manual recovery
159
+ */
160
+ reset() {
161
+ this.logger.info(`Circuit breaker for ${this.serviceName} manually reset`);
162
+ this.transitionTo(CircuitState.CLOSED);
163
+ this.consecutiveFailures = 0;
164
+ this.halfOpenAttempts = 0;
165
+ this.openedAt = undefined;
166
+ }
167
+ /**
168
+ * Transition to a new state
169
+ */
170
+ transitionTo(newState) {
171
+ const oldState = this.state;
172
+ this.state = newState;
173
+ this.logger.debug(`Circuit breaker for ${this.serviceName}: ${oldState} -> ${newState}`);
174
+ }
175
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=circuit-breaker.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circuit-breaker.test.d.ts","sourceRoot":"","sources":["../../../src/utils/circuit-breaker.test.ts"],"names":[],"mappings":""}