@signageos/lib 23.8.1 → 23.8.2-master.4405

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 (631) hide show
  1. package/dist/AMQP/CQRS/ICommand.d.ts +38 -0
  2. package/dist/AMQP/CQRS/ICommand.js +3 -0
  3. package/dist/AMQP/CQRS/ICommand.js.map +1 -0
  4. package/dist/AMQP/CQRS/ICommandError.d.ts +4 -0
  5. package/dist/AMQP/CQRS/ICommandError.js +3 -0
  6. package/dist/AMQP/CQRS/ICommandError.js.map +1 -0
  7. package/dist/AMQP/CQRS/commandQueue.d.ts +59 -0
  8. package/dist/AMQP/CQRS/commandQueue.js +313 -0
  9. package/dist/AMQP/CQRS/commandQueue.js.map +1 -0
  10. package/dist/AMQP/CQRS/commandResponseHelper.d.ts +3 -0
  11. package/dist/AMQP/CQRS/commandResponseHelper.js +8 -0
  12. package/dist/AMQP/CQRS/commandResponseHelper.js.map +1 -0
  13. package/dist/AMQP/CQRS/storedCommandQueue.d.ts +27 -0
  14. package/dist/AMQP/CQRS/storedCommandQueue.js +301 -0
  15. package/dist/AMQP/CQRS/storedCommandQueue.js.map +1 -0
  16. package/dist/AMQP/ChannelProvider.d.ts +37 -0
  17. package/dist/AMQP/ChannelProvider.js +886 -0
  18. package/dist/AMQP/ChannelProvider.js.map +1 -0
  19. package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.d.ts +39 -0
  20. package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.js +292 -0
  21. package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.js.map +1 -0
  22. package/dist/AMQP/DeviceActions/IDeviceAction.d.ts +4 -0
  23. package/dist/AMQP/DeviceActions/IDeviceAction.js +3 -0
  24. package/dist/AMQP/DeviceActions/IDeviceAction.js.map +1 -0
  25. package/dist/AMQP/DeviceActions/deviceActionsQueue.d.ts +83 -0
  26. package/dist/AMQP/DeviceActions/deviceActionsQueue.js +538 -0
  27. package/dist/AMQP/DeviceActions/deviceActionsQueue.js.map +1 -0
  28. package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.d.ts +47 -0
  29. package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.js +218 -0
  30. package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.js.map +1 -0
  31. package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.d.ts +13 -0
  32. package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.js +3 -0
  33. package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.js.map +1 -0
  34. package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.d.ts +15 -0
  35. package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.js +76 -0
  36. package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.js.map +1 -0
  37. package/dist/AMQP/EventSourcing/IEvent.d.ts +72 -0
  38. package/dist/AMQP/EventSourcing/IEvent.js +3 -0
  39. package/dist/AMQP/EventSourcing/IEvent.js.map +1 -0
  40. package/dist/AMQP/EventSourcing/Locked/deferredState.d.ts +21 -0
  41. package/dist/AMQP/EventSourcing/Locked/deferredState.js +72 -0
  42. package/dist/AMQP/EventSourcing/Locked/deferredState.js.map +1 -0
  43. package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.d.ts +63 -0
  44. package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.js +261 -0
  45. package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.js.map +1 -0
  46. package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.d.ts +24 -0
  47. package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.js +64 -0
  48. package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.js.map +1 -0
  49. package/dist/AMQP/EventSourcing/Locked/withLock.d.ts +42 -0
  50. package/dist/AMQP/EventSourcing/Locked/withLock.js +141 -0
  51. package/dist/AMQP/EventSourcing/Locked/withLock.js.map +1 -0
  52. package/dist/AMQP/EventSourcing/eventQueue.d.ts +87 -0
  53. package/dist/AMQP/EventSourcing/eventQueue.js +139 -0
  54. package/dist/AMQP/EventSourcing/eventQueue.js.map +1 -0
  55. package/dist/AMQP/EventSourcing/eventQueue.utils.d.ts +73 -0
  56. package/dist/AMQP/EventSourcing/eventQueue.utils.js +157 -0
  57. package/dist/AMQP/EventSourcing/eventQueue.utils.js.map +1 -0
  58. package/dist/AMQP/EventSourcing/eventQueueDetached.d.ts +49 -0
  59. package/dist/AMQP/EventSourcing/eventQueueDetached.js +428 -0
  60. package/dist/AMQP/EventSourcing/eventQueueDetached.js.map +1 -0
  61. package/dist/AMQP/EventSourcing/eventQueueDomain.d.ts +42 -0
  62. package/dist/AMQP/EventSourcing/eventQueueDomain.js +371 -0
  63. package/dist/AMQP/EventSourcing/eventQueueDomain.js.map +1 -0
  64. package/dist/AMQP/EventSourcing/eventQueuePublish.d.ts +19 -0
  65. package/dist/AMQP/EventSourcing/eventQueuePublish.js +209 -0
  66. package/dist/AMQP/EventSourcing/eventQueuePublish.js.map +1 -0
  67. package/dist/AMQP/EventSourcing/synchronization.d.ts +39 -0
  68. package/dist/AMQP/EventSourcing/synchronization.js +12 -0
  69. package/dist/AMQP/EventSourcing/synchronization.js.map +1 -0
  70. package/dist/AMQP/Exchange.d.ts +1 -0
  71. package/dist/AMQP/Exchange.js +3 -0
  72. package/dist/AMQP/Exchange.js.map +1 -0
  73. package/dist/AMQP/IAMQPPool.d.ts +5 -0
  74. package/dist/AMQP/IAMQPPool.js +3 -0
  75. package/dist/AMQP/IAMQPPool.js.map +1 -0
  76. package/dist/AMQP/IAsyncGotMessage.d.ts +15 -0
  77. package/dist/AMQP/IAsyncGotMessage.js +3 -0
  78. package/dist/AMQP/IAsyncGotMessage.js.map +1 -0
  79. package/dist/AMQP/IChannel.d.ts +43 -0
  80. package/dist/AMQP/IChannel.js +3 -0
  81. package/dist/AMQP/IChannel.js.map +1 -0
  82. package/dist/AMQP/IConsumeOptions.d.ts +106 -0
  83. package/dist/AMQP/IConsumeOptions.js +3 -0
  84. package/dist/AMQP/IConsumeOptions.js.map +1 -0
  85. package/dist/AMQP/IMessageOptions.d.ts +6 -0
  86. package/dist/AMQP/IMessageOptions.js +3 -0
  87. package/dist/AMQP/IMessageOptions.js.map +1 -0
  88. package/dist/AMQP/INackOptions.d.ts +4 -0
  89. package/dist/AMQP/INackOptions.js +3 -0
  90. package/dist/AMQP/INackOptions.js.map +1 -0
  91. package/dist/AMQP/IQueueOptions.d.ts +8 -0
  92. package/dist/AMQP/IQueueOptions.js +3 -0
  93. package/dist/AMQP/IQueueOptions.js.map +1 -0
  94. package/dist/AMQP/Logging/IDeviceLog.d.ts +15 -0
  95. package/dist/AMQP/Logging/IDeviceLog.js +10 -0
  96. package/dist/AMQP/Logging/IDeviceLog.js.map +1 -0
  97. package/dist/AMQP/Logging/logDeviceQueue.d.ts +12 -0
  98. package/dist/AMQP/Logging/logDeviceQueue.js +107 -0
  99. package/dist/AMQP/Logging/logDeviceQueue.js.map +1 -0
  100. package/dist/AMQP/QueueFetcher.d.ts +13 -0
  101. package/dist/AMQP/QueueFetcher.js +166 -0
  102. package/dist/AMQP/QueueFetcher.js.map +1 -0
  103. package/dist/AMQP/QueuePublisher.d.ts +7 -0
  104. package/dist/AMQP/QueuePublisher.js +135 -0
  105. package/dist/AMQP/QueuePublisher.js.map +1 -0
  106. package/dist/AMQP/QueueRepeatableSubscription.d.ts +14 -0
  107. package/dist/AMQP/QueueRepeatableSubscription.js +162 -0
  108. package/dist/AMQP/QueueRepeatableSubscription.js.map +1 -0
  109. package/dist/AMQP/QueueSubscriber.d.ts +11 -0
  110. package/dist/AMQP/QueueSubscriber.js +163 -0
  111. package/dist/AMQP/QueueSubscriber.js.map +1 -0
  112. package/dist/AMQP/ResponseProvider.d.ts +20 -0
  113. package/dist/AMQP/ResponseProvider.js +193 -0
  114. package/dist/AMQP/ResponseProvider.js.map +1 -0
  115. package/dist/AMQP/Static/filesQueue.d.ts +12 -0
  116. package/dist/AMQP/Static/filesQueue.js +220 -0
  117. package/dist/AMQP/Static/filesQueue.js.map +1 -0
  118. package/dist/AMQP/amqpConnectionFactory.d.ts +27 -0
  119. package/dist/AMQP/amqpConnectionFactory.js +236 -0
  120. package/dist/AMQP/amqpConnectionFactory.js.map +1 -0
  121. package/dist/AMQP/amqpErrors.d.ts +5 -0
  122. package/dist/AMQP/amqpErrors.js +30 -0
  123. package/dist/AMQP/amqpErrors.js.map +1 -0
  124. package/dist/AMQP/errors.d.ts +3 -0
  125. package/dist/AMQP/errors.js +30 -0
  126. package/dist/AMQP/errors.js.map +1 -0
  127. package/dist/AMQP/fetchNextMessage.d.ts +14 -0
  128. package/dist/AMQP/fetchNextMessage.js +118 -0
  129. package/dist/AMQP/fetchNextMessage.js.map +1 -0
  130. package/dist/AMQP/queueConfigurator.d.ts +5 -0
  131. package/dist/AMQP/queueConfigurator.js +78 -0
  132. package/dist/AMQP/queueConfigurator.js.map +1 -0
  133. package/dist/AWS/S3.d.ts +95 -0
  134. package/dist/AWS/S3.js +448 -0
  135. package/dist/AWS/S3.js.map +1 -0
  136. package/dist/AWS/S3Types.d.ts +113 -0
  137. package/dist/AWS/S3Types.js +3 -0
  138. package/dist/AWS/S3Types.js.map +1 -0
  139. package/dist/AWS/config.d.ts +2 -0
  140. package/dist/AWS/config.js +23 -0
  141. package/dist/AWS/config.js.map +1 -0
  142. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.d.ts +30 -0
  143. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.js +81 -0
  144. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.js.map +1 -0
  145. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.d.ts +5 -0
  146. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.js +33 -0
  147. package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.js.map +1 -0
  148. package/dist/Auth0/ManagementClient/Auth0ManagementClient.d.ts +41 -0
  149. package/dist/Auth0/ManagementClient/Auth0ManagementClient.js +137 -0
  150. package/dist/Auth0/ManagementClient/Auth0ManagementClient.js.map +1 -0
  151. package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.d.ts +8 -0
  152. package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.js +37 -0
  153. package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.js.map +1 -0
  154. package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.d.ts +14 -0
  155. package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.js +58 -0
  156. package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.js.map +1 -0
  157. package/dist/Auth0/auth0.types.d.ts +4 -0
  158. package/dist/Auth0/auth0.types.js +10 -0
  159. package/dist/Auth0/auth0.types.js.map +1 -0
  160. package/dist/Cache/lruCache.d.ts +22 -0
  161. package/dist/Cache/lruCache.js +42 -0
  162. package/dist/Cache/lruCache.js.map +1 -0
  163. package/dist/Cache/memoryCache.d.ts +7 -0
  164. package/dist/Cache/memoryCache.js +80 -0
  165. package/dist/Cache/memoryCache.js.map +1 -0
  166. package/dist/Config/config.d.ts +81 -0
  167. package/dist/Config/config.js +119 -0
  168. package/dist/Config/config.js.map +1 -0
  169. package/dist/Config/environment.d.ts +8 -0
  170. package/dist/Config/environment.js +13 -0
  171. package/dist/Config/environment.js.map +1 -0
  172. package/dist/Config/validation.d.ts +61 -0
  173. package/dist/Config/validation.js +56 -0
  174. package/dist/Config/validation.js.map +1 -0
  175. package/dist/DateTime/dateMonkeyPatch.d.ts +15 -0
  176. package/dist/DateTime/dateMonkeyPatch.js +149 -0
  177. package/dist/DateTime/dateMonkeyPatch.js.map +1 -0
  178. package/dist/DateTime/dateTimeFactory.d.ts +4 -0
  179. package/dist/DateTime/dateTimeFactory.js +22 -0
  180. package/dist/DateTime/dateTimeFactory.js.map +1 -0
  181. package/dist/DateTime/millisecondConstants.d.ts +7 -0
  182. package/dist/DateTime/millisecondConstants.js +11 -0
  183. package/dist/DateTime/millisecondConstants.js.map +1 -0
  184. package/dist/DateTime/posixTimezone.d.ts +1 -0
  185. package/dist/DateTime/posixTimezone.js +54 -0
  186. package/dist/DateTime/posixTimezone.js.map +1 -0
  187. package/dist/DateTime/statistics.d.ts +6 -0
  188. package/dist/DateTime/statistics.js +30 -0
  189. package/dist/DateTime/statistics.js.map +1 -0
  190. package/dist/DateTime/timeConverter.d.ts +1 -0
  191. package/dist/DateTime/timeConverter.js +11 -0
  192. package/dist/DateTime/timeConverter.js.map +1 -0
  193. package/dist/DateTime/timer.d.ts +10 -0
  194. package/dist/DateTime/timer.js +18 -0
  195. package/dist/DateTime/timer.js.map +1 -0
  196. package/dist/DateTime/timestamp.d.ts +2 -0
  197. package/dist/DateTime/timestamp.js +16 -0
  198. package/dist/DateTime/timestamp.js.map +1 -0
  199. package/dist/DateTime/waitUntil.d.ts +20 -0
  200. package/dist/DateTime/waitUntil.js +148 -0
  201. package/dist/DateTime/waitUntil.js.map +1 -0
  202. package/dist/Debug/debugClassDecorator.d.ts +13 -0
  203. package/dist/Debug/debugClassDecorator.js +63 -0
  204. package/dist/Debug/debugClassDecorator.js.map +1 -0
  205. package/dist/Debug/debugDecorator.d.ts +24 -0
  206. package/dist/Debug/debugDecorator.js +107 -0
  207. package/dist/Debug/debugDecorator.js.map +1 -0
  208. package/dist/Encryption/passwordEncryption.d.ts +4 -0
  209. package/dist/Encryption/passwordEncryption.js +29 -0
  210. package/dist/Encryption/passwordEncryption.js.map +1 -0
  211. package/dist/Encryption/tokenEncryption.d.ts +14 -0
  212. package/dist/Encryption/tokenEncryption.js +32 -0
  213. package/dist/Encryption/tokenEncryption.js.map +1 -0
  214. package/dist/Events/AsyncEventEmitter.d.ts +31 -0
  215. package/dist/Events/AsyncEventEmitter.js +125 -0
  216. package/dist/Events/AsyncEventEmitter.js.map +1 -0
  217. package/dist/Events/eventsHelpers.d.ts +3 -0
  218. package/dist/Events/eventsHelpers.js +24 -0
  219. package/dist/Events/eventsHelpers.js.map +1 -0
  220. package/dist/Events/genericGracefulExit.d.ts +11 -0
  221. package/dist/Events/genericGracefulExit.js +90 -0
  222. package/dist/Events/genericGracefulExit.js.map +1 -0
  223. package/dist/FileSystem/moduleDiscoverer.d.ts +7 -0
  224. package/dist/FileSystem/moduleDiscoverer.js +88 -0
  225. package/dist/FileSystem/moduleDiscoverer.js.map +1 -0
  226. package/dist/FileSystem/tmpDir.d.ts +9 -0
  227. package/dist/FileSystem/tmpDir.js +64 -0
  228. package/dist/FileSystem/tmpDir.js.map +1 -0
  229. package/dist/Functional/compose.d.ts +22 -0
  230. package/dist/Functional/compose.js +44 -0
  231. package/dist/Functional/compose.js.map +1 -0
  232. package/dist/GenericPool/options.d.ts +63 -0
  233. package/dist/GenericPool/options.js +3 -0
  234. package/dist/GenericPool/options.js.map +1 -0
  235. package/dist/Hash/checksum.d.ts +5 -0
  236. package/dist/Hash/checksum.js +20 -0
  237. package/dist/Hash/checksum.js.map +1 -0
  238. package/dist/Hash/checksumFile.d.ts +4 -0
  239. package/dist/Hash/checksumFile.js +82 -0
  240. package/dist/Hash/checksumFile.js.map +1 -0
  241. package/dist/Hash/generator.d.ts +2 -0
  242. package/dist/Hash/generator.js +15 -0
  243. package/dist/Hash/generator.js.map +1 -0
  244. package/dist/Http/download.d.ts +1 -0
  245. package/dist/Http/download.js +91 -0
  246. package/dist/Http/download.js.map +1 -0
  247. package/dist/HttpStatus/checks/amqpStatusCheck.d.ts +3 -0
  248. package/dist/HttpStatus/checks/amqpStatusCheck.js +98 -0
  249. package/dist/HttpStatus/checks/amqpStatusCheck.js.map +1 -0
  250. package/dist/HttpStatus/checks/mongoDBStatusCheck.d.ts +3 -0
  251. package/dist/HttpStatus/checks/mongoDBStatusCheck.js +60 -0
  252. package/dist/HttpStatus/checks/mongoDBStatusCheck.js.map +1 -0
  253. package/dist/HttpStatus/checks/redisStatusCheck.d.ts +3 -0
  254. package/dist/HttpStatus/checks/redisStatusCheck.js +94 -0
  255. package/dist/HttpStatus/checks/redisStatusCheck.js.map +1 -0
  256. package/dist/HttpStatus/createHttpStatusMiddleware.d.ts +9 -0
  257. package/dist/HttpStatus/createHttpStatusMiddleware.js +109 -0
  258. package/dist/HttpStatus/createHttpStatusMiddleware.js.map +1 -0
  259. package/dist/HttpStatus/enrichHttpServerWithStatus.d.ts +15 -0
  260. package/dist/HttpStatus/enrichHttpServerWithStatus.js +114 -0
  261. package/dist/HttpStatus/enrichHttpServerWithStatus.js.map +1 -0
  262. package/dist/HttpStatus/sendStatusResponse.d.ts +5 -0
  263. package/dist/HttpStatus/sendStatusResponse.js +71 -0
  264. package/dist/HttpStatus/sendStatusResponse.js.map +1 -0
  265. package/dist/HttpStatus/status.d.ts +19 -0
  266. package/dist/HttpStatus/status.js +132 -0
  267. package/dist/HttpStatus/status.js.map +1 -0
  268. package/dist/HttpStatus/statuses/amqpStatus.d.ts +3 -0
  269. package/dist/HttpStatus/statuses/amqpStatus.js +35 -0
  270. package/dist/HttpStatus/statuses/amqpStatus.js.map +1 -0
  271. package/dist/HttpStatus/statuses/mongoStatus.d.ts +3 -0
  272. package/dist/HttpStatus/statuses/mongoStatus.js +35 -0
  273. package/dist/HttpStatus/statuses/mongoStatus.js.map +1 -0
  274. package/dist/HttpStatus/statuses/redisStatus.d.ts +3 -0
  275. package/dist/HttpStatus/statuses/redisStatus.js +35 -0
  276. package/dist/HttpStatus/statuses/redisStatus.js.map +1 -0
  277. package/dist/InfluxDB/IInfluxDB.d.ts +5 -0
  278. package/dist/InfluxDB/IInfluxDB.js +3 -0
  279. package/dist/InfluxDB/IInfluxDB.js.map +1 -0
  280. package/dist/InfluxDB/influxDBConnectionFactory.d.ts +9 -0
  281. package/dist/InfluxDB/influxDBConnectionFactory.js +83 -0
  282. package/dist/InfluxDB/influxDBConnectionFactory.js.map +1 -0
  283. package/dist/JSON/jsonHelper.d.ts +4 -0
  284. package/dist/JSON/jsonHelper.js +21 -0
  285. package/dist/JSON/jsonHelper.js.map +1 -0
  286. package/dist/Lib/Redis/connection.utils.d.ts +22 -0
  287. package/dist/Lib/Redis/connection.utils.js +95 -0
  288. package/dist/Lib/Redis/connection.utils.js.map +1 -0
  289. package/dist/Lib/String/string.d.ts +1 -0
  290. package/dist/Lib/String/string.js +6 -0
  291. package/dist/Lib/String/string.js.map +1 -0
  292. package/dist/Lock/lockedDecorator.d.ts +12 -0
  293. package/dist/Lock/lockedDecorator.js +150 -0
  294. package/dist/Lock/lockedDecorator.js.map +1 -0
  295. package/dist/Logging/console.d.ts +8 -0
  296. package/dist/Logging/console.js +50 -0
  297. package/dist/Logging/console.js.map +1 -0
  298. package/dist/Logging/debug.d.ts +10 -0
  299. package/dist/Logging/debug.js +61 -0
  300. package/dist/Logging/debug.js.map +1 -0
  301. package/dist/Logging/format.d.ts +10 -0
  302. package/dist/Logging/format.js +79 -0
  303. package/dist/Logging/format.js.map +1 -0
  304. package/dist/Logging/logger.d.ts +53 -0
  305. package/dist/Logging/logger.js +63 -0
  306. package/dist/Logging/logger.js.map +1 -0
  307. package/dist/Logging/logging.d.ts +12 -0
  308. package/dist/Logging/logging.js +113 -0
  309. package/dist/Logging/logging.js.map +1 -0
  310. package/dist/Metrics/MetricsClient.d.ts +46 -0
  311. package/dist/Metrics/MetricsClient.js +101 -0
  312. package/dist/Metrics/MetricsClient.js.map +1 -0
  313. package/dist/Metrics/deviceConsumerMetrics.d.ts +6 -0
  314. package/dist/Metrics/deviceConsumerMetrics.js +59 -0
  315. package/dist/Metrics/deviceConsumerMetrics.js.map +1 -0
  316. package/dist/Metrics/eventConsumerMetrics.d.ts +19 -0
  317. package/dist/Metrics/eventConsumerMetrics.js +52 -0
  318. package/dist/Metrics/eventConsumerMetrics.js.map +1 -0
  319. package/dist/Metrics/eventQueueMetrics.d.ts +7 -0
  320. package/dist/Metrics/eventQueueMetrics.js +19 -0
  321. package/dist/Metrics/eventQueueMetrics.js.map +1 -0
  322. package/dist/Metrics/logMetrics.d.ts +4 -0
  323. package/dist/Metrics/logMetrics.js +20 -0
  324. package/dist/Metrics/logMetrics.js.map +1 -0
  325. package/dist/Metrics/metrics.d.ts +84 -0
  326. package/dist/Metrics/metrics.js +255 -0
  327. package/dist/Metrics/metrics.js.map +1 -0
  328. package/dist/Metrics/mongoDBMetrics.d.ts +35 -0
  329. package/dist/Metrics/mongoDBMetrics.js +162 -0
  330. package/dist/Metrics/mongoDBMetrics.js.map +1 -0
  331. package/dist/Metrics/processSocketsMetrics.d.ts +10 -0
  332. package/dist/Metrics/processSocketsMetrics.js +92 -0
  333. package/dist/Metrics/processSocketsMetrics.js.map +1 -0
  334. package/dist/Metrics/redisMetrics.d.ts +13 -0
  335. package/dist/Metrics/redisMetrics.js +60 -0
  336. package/dist/Metrics/redisMetrics.js.map +1 -0
  337. package/dist/MongoDB/MongoDBConnection.d.ts +19 -0
  338. package/dist/MongoDB/MongoDBConnection.js +185 -0
  339. package/dist/MongoDB/MongoDBConnection.js.map +1 -0
  340. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.d.ts +2 -0
  341. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.js +106 -0
  342. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.js.map +1 -0
  343. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.d.ts +2 -0
  344. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.js +94 -0
  345. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.js.map +1 -0
  346. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.d.ts +2 -0
  347. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.js +80 -0
  348. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.js.map +1 -0
  349. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.d.ts +2 -0
  350. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.js +51 -0
  351. package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.js.map +1 -0
  352. package/dist/MongoDB/ProprietaryCluster/helper.d.ts +13 -0
  353. package/dist/MongoDB/ProprietaryCluster/helper.js +147 -0
  354. package/dist/MongoDB/ProprietaryCluster/helper.js.map +1 -0
  355. package/dist/MongoDB/cursorIterator.d.ts +5 -0
  356. package/dist/MongoDB/cursorIterator.js +63 -0
  357. package/dist/MongoDB/cursorIterator.js.map +1 -0
  358. package/dist/MongoDB/escape.d.ts +4 -0
  359. package/dist/MongoDB/escape.js +54 -0
  360. package/dist/MongoDB/escape.js.map +1 -0
  361. package/dist/MongoDB/mongoDBConnectionFactory.d.ts +13 -0
  362. package/dist/MongoDB/mongoDBConnectionFactory.js +11 -0
  363. package/dist/MongoDB/mongoDBConnectionFactory.js.map +1 -0
  364. package/dist/MongoDB/proprietaryCluster.d.ts +1 -0
  365. package/dist/MongoDB/proprietaryCluster.js +76 -0
  366. package/dist/MongoDB/proprietaryCluster.js.map +1 -0
  367. package/dist/Npm/INpmClient.d.ts +25 -0
  368. package/dist/Npm/INpmClient.js +3 -0
  369. package/dist/Npm/INpmClient.js.map +1 -0
  370. package/dist/Npm/MockNpmClient.d.ts +17 -0
  371. package/dist/Npm/MockNpmClient.js +124 -0
  372. package/dist/Npm/MockNpmClient.js.map +1 -0
  373. package/dist/Npm/NpmClient.d.ts +14 -0
  374. package/dist/Npm/NpmClient.js +212 -0
  375. package/dist/Npm/NpmClient.js.map +1 -0
  376. package/dist/Npm/NpmCredentialsProvider.d.ts +18 -0
  377. package/dist/Npm/NpmCredentialsProvider.js +111 -0
  378. package/dist/Npm/NpmCredentialsProvider.js.map +1 -0
  379. package/dist/Observable/helpers.d.ts +3 -0
  380. package/dist/Observable/helpers.js +117 -0
  381. package/dist/Observable/helpers.js.map +1 -0
  382. package/dist/Parsers/parsers.d.ts +1 -0
  383. package/dist/Parsers/parsers.js +17 -0
  384. package/dist/Parsers/parsers.js.map +1 -0
  385. package/dist/Path/detector.d.ts +9 -0
  386. package/dist/Path/detector.js +78 -0
  387. package/dist/Path/detector.js.map +1 -0
  388. package/dist/Pool/IBasePool.d.ts +6 -0
  389. package/dist/Pool/IBasePool.js +3 -0
  390. package/dist/Pool/IBasePool.js.map +1 -0
  391. package/dist/Promise/cancelable.d.ts +4 -0
  392. package/dist/Promise/cancelable.js +21 -0
  393. package/dist/Promise/cancelable.js.map +1 -0
  394. package/dist/Promise/deferred.d.ts +4 -0
  395. package/dist/Promise/deferred.js +21 -0
  396. package/dist/Promise/deferred.js.map +1 -0
  397. package/dist/Promise/deferredStream.d.ts +4 -0
  398. package/dist/Promise/deferredStream.js +21 -0
  399. package/dist/Promise/deferredStream.js.map +1 -0
  400. package/dist/Promise/lock.d.ts +4 -0
  401. package/dist/Promise/lock.js +21 -0
  402. package/dist/Promise/lock.js.map +1 -0
  403. package/dist/Promise/timeoutable.d.ts +4 -0
  404. package/dist/Promise/timeoutable.js +21 -0
  405. package/dist/Promise/timeoutable.js.map +1 -0
  406. package/dist/Redis/DeviceActions/PostponedAction.d.ts +4 -0
  407. package/dist/Redis/DeviceActions/PostponedAction.js +3 -0
  408. package/dist/Redis/DeviceActions/PostponedAction.js.map +1 -0
  409. package/dist/Redis/DeviceActions/postponedDeviceActions.d.ts +8 -0
  410. package/dist/Redis/DeviceActions/postponedDeviceActions.js +333 -0
  411. package/dist/Redis/DeviceActions/postponedDeviceActions.js.map +1 -0
  412. package/dist/Redis/redisConnectionFactory.d.ts +41 -0
  413. package/dist/Redis/redisConnectionFactory.js +158 -0
  414. package/dist/Redis/redisConnectionFactory.js.map +1 -0
  415. package/dist/Redis/redisLock.d.ts +11 -0
  416. package/dist/Redis/redisLock.js +213 -0
  417. package/dist/Redis/redisLock.js.map +1 -0
  418. package/dist/Retry/retry.d.ts +28 -0
  419. package/dist/Retry/retry.js +154 -0
  420. package/dist/Retry/retry.js.map +1 -0
  421. package/dist/Rsync/copier.d.ts +1 -0
  422. package/dist/Rsync/copier.js +123 -0
  423. package/dist/Rsync/copier.js.map +1 -0
  424. package/dist/SemVer/SemVerLevel.d.ts +6 -0
  425. package/dist/SemVer/SemVerLevel.js +10 -0
  426. package/dist/SemVer/SemVerLevel.js.map +1 -0
  427. package/dist/SemVer/semVerConstants.d.ts +2 -0
  428. package/dist/SemVer/semVerConstants.js +9 -0
  429. package/dist/SemVer/semVerConstants.js.map +1 -0
  430. package/dist/SemVer/semVerHelper.d.ts +7 -0
  431. package/dist/SemVer/semVerHelper.js +82 -0
  432. package/dist/SemVer/semVerHelper.js.map +1 -0
  433. package/dist/Service/HTTP/express/app.d.ts +33 -0
  434. package/dist/Service/HTTP/express/app.js +82 -0
  435. package/dist/Service/HTTP/express/app.js.map +1 -0
  436. package/dist/Service/HTTP/express/expressFactory.d.ts +4 -0
  437. package/dist/Service/HTTP/express/expressFactory.js +22 -0
  438. package/dist/Service/HTTP/express/expressFactory.js.map +1 -0
  439. package/dist/Service/HTTP/express/monitoring.d.ts +8 -0
  440. package/dist/Service/HTTP/express/monitoring.js +25 -0
  441. package/dist/Service/HTTP/express/monitoring.js.map +1 -0
  442. package/dist/Service/HTTP/httpServerFactory.d.ts +54 -0
  443. package/dist/Service/HTTP/httpServerFactory.js +104 -0
  444. package/dist/Service/HTTP/httpServerFactory.js.map +1 -0
  445. package/dist/Service/HTTP/middleware/accessLogMiddleware.d.ts +20 -0
  446. package/dist/Service/HTTP/middleware/accessLogMiddleware.js +90 -0
  447. package/dist/Service/HTTP/middleware/accessLogMiddleware.js.map +1 -0
  448. package/dist/Service/HTTP/middleware/headersMiddleware.d.ts +2 -0
  449. package/dist/Service/HTTP/middleware/headersMiddleware.js +18 -0
  450. package/dist/Service/HTTP/middleware/headersMiddleware.js.map +1 -0
  451. package/dist/Service/HTTP/routes/app/indexPage.d.ts +7 -0
  452. package/dist/Service/HTTP/routes/app/indexPage.js +12 -0
  453. package/dist/Service/HTTP/routes/app/indexPage.js.map +1 -0
  454. package/dist/Service/HTTP/routes/app/router.d.ts +14 -0
  455. package/dist/Service/HTTP/routes/app/router.js +12 -0
  456. package/dist/Service/HTTP/routes/app/router.js.map +1 -0
  457. package/dist/Service/HTTP/routes/app/status.d.ts +13 -0
  458. package/dist/Service/HTTP/routes/app/status.js +44 -0
  459. package/dist/Service/HTTP/routes/app/status.js.map +1 -0
  460. package/dist/Service/HTTP/routes/monitoring/aliveness.d.ts +20 -0
  461. package/dist/Service/HTTP/routes/monitoring/aliveness.js +75 -0
  462. package/dist/Service/HTTP/routes/monitoring/aliveness.js.map +1 -0
  463. package/dist/Service/HTTP/routes/monitoring/metrics.d.ts +9 -0
  464. package/dist/Service/HTTP/routes/monitoring/metrics.js +59 -0
  465. package/dist/Service/HTTP/routes/monitoring/metrics.js.map +1 -0
  466. package/dist/Service/HTTP/routes/monitoring/readniness.d.ts +18 -0
  467. package/dist/Service/HTTP/routes/monitoring/readniness.js +80 -0
  468. package/dist/Service/HTTP/routes/monitoring/readniness.js.map +1 -0
  469. package/dist/Service/HTTP/routes/monitoring/router.d.ts +10 -0
  470. package/dist/Service/HTTP/routes/monitoring/router.js +12 -0
  471. package/dist/Service/HTTP/routes/monitoring/router.js.map +1 -0
  472. package/dist/Service/HTTP/server/serverFactory.d.ts +10 -0
  473. package/dist/Service/HTTP/server/serverFactory.js +133 -0
  474. package/dist/Service/HTTP/server/serverFactory.js.map +1 -0
  475. package/dist/Service/Service.d.ts +17 -0
  476. package/dist/Service/Service.js +97 -0
  477. package/dist/Service/Service.js.map +1 -0
  478. package/dist/Service/dbConnections.d.ts +8 -0
  479. package/dist/Service/dbConnections.js +3 -0
  480. package/dist/Service/dbConnections.js.map +1 -0
  481. package/dist/Service/metrics/connections.d.ts +3 -0
  482. package/dist/Service/metrics/connections.js +47 -0
  483. package/dist/Service/metrics/connections.js.map +1 -0
  484. package/dist/Service/metrics/mongodb.d.ts +2 -0
  485. package/dist/Service/metrics/mongodb.js +13 -0
  486. package/dist/Service/metrics/mongodb.js.map +1 -0
  487. package/dist/Service/metrics/redis.d.ts +2 -0
  488. package/dist/Service/metrics/redis.js +11 -0
  489. package/dist/Service/metrics/redis.js.map +1 -0
  490. package/dist/Service/process.d.ts +11 -0
  491. package/dist/Service/process.js +88 -0
  492. package/dist/Service/process.js.map +1 -0
  493. package/dist/Service/serviceFactory.d.ts +115 -0
  494. package/dist/Service/serviceFactory.js +118 -0
  495. package/dist/Service/serviceFactory.js.map +1 -0
  496. package/dist/Service/types.d.ts +55 -0
  497. package/dist/Service/types.js +3 -0
  498. package/dist/Service/types.js.map +1 -0
  499. package/dist/Storage/IArrayStorage.d.ts +7 -0
  500. package/dist/Storage/IArrayStorage.js +3 -0
  501. package/dist/Storage/IArrayStorage.js.map +1 -0
  502. package/dist/Storage/MemoryArrayStorage.d.ts +9 -0
  503. package/dist/Storage/MemoryArrayStorage.js +22 -0
  504. package/dist/Storage/MemoryArrayStorage.js.map +1 -0
  505. package/dist/String/pad.d.ts +1 -0
  506. package/dist/String/pad.js +7 -0
  507. package/dist/String/pad.js.map +1 -0
  508. package/dist/String/string.d.ts +3 -0
  509. package/dist/String/string.js +17 -0
  510. package/dist/String/string.js.map +1 -0
  511. package/dist/String/webalize.d.ts +1 -0
  512. package/dist/String/webalize.js +15 -0
  513. package/dist/String/webalize.js.map +1 -0
  514. package/dist/String/word.d.ts +32 -0
  515. package/dist/String/word.js +97 -0
  516. package/dist/String/word.js.map +1 -0
  517. package/dist/System/signalSender.d.ts +1 -0
  518. package/dist/System/signalSender.js +7 -0
  519. package/dist/System/signalSender.js.map +1 -0
  520. package/dist/ThirdParty/connection.d.ts +28 -0
  521. package/dist/ThirdParty/connection.js +9 -0
  522. package/dist/ThirdParty/connection.js.map +1 -0
  523. package/dist/Timer/Power/PowerTimerSettings.d.ts +29 -0
  524. package/dist/Timer/Power/PowerTimerSettings.js +3 -0
  525. package/dist/Timer/Power/PowerTimerSettings.js.map +1 -0
  526. package/dist/Timer/Power/PowerTimerType.d.ts +2 -0
  527. package/dist/Timer/Power/PowerTimerType.js +3 -0
  528. package/dist/Timer/Power/PowerTimerType.js.map +1 -0
  529. package/dist/Timer/Power/PowerTimerWeekday.d.ts +18 -0
  530. package/dist/Timer/Power/PowerTimerWeekday.js +18 -0
  531. package/dist/Timer/Power/PowerTimerWeekday.js.map +1 -0
  532. package/dist/Timer/Power/PowerTimerWeekdayEnum.d.ts +28 -0
  533. package/dist/Timer/Power/PowerTimerWeekdayEnum.js +32 -0
  534. package/dist/Timer/Power/PowerTimerWeekdayEnum.js.map +1 -0
  535. package/dist/Timer/Power/TimerEventWeekdayNumber.d.ts +9 -0
  536. package/dist/Timer/Power/TimerEventWeekdayNumber.js +14 -0
  537. package/dist/Timer/Power/TimerEventWeekdayNumber.js.map +1 -0
  538. package/dist/Timer/Power/powerTimerComputer.d.ts +36 -0
  539. package/dist/Timer/Power/powerTimerComputer.js +141 -0
  540. package/dist/Timer/Power/powerTimerComputer.js.map +1 -0
  541. package/dist/Timer/convertWeekday.d.ts +25 -0
  542. package/dist/Timer/convertWeekday.js +211 -0
  543. package/dist/Timer/convertWeekday.js.map +1 -0
  544. package/dist/Timer/converters.d.ts +44 -0
  545. package/dist/Timer/converters.js +72 -0
  546. package/dist/Timer/converters.js.map +1 -0
  547. package/dist/Timer/increasingInterval.d.ts +2 -0
  548. package/dist/Timer/increasingInterval.js +108 -0
  549. package/dist/Timer/increasingInterval.js.map +1 -0
  550. package/dist/Timer/nonConcurrentInterval.d.ts +4 -0
  551. package/dist/Timer/nonConcurrentInterval.js +73 -0
  552. package/dist/Timer/nonConcurrentInterval.js.map +1 -0
  553. package/dist/Timer/progressiveWait.d.ts +40 -0
  554. package/dist/Timer/progressiveWait.js +96 -0
  555. package/dist/Timer/progressiveWait.js.map +1 -0
  556. package/dist/Timer/timeout.d.ts +4 -0
  557. package/dist/Timer/timeout.js +21 -0
  558. package/dist/Timer/timeout.js.map +1 -0
  559. package/dist/Timer/wait.d.ts +5 -0
  560. package/dist/Timer/wait.js +27 -0
  561. package/dist/Timer/wait.js.map +1 -0
  562. package/dist/TypeScript/asyncIterator.d.ts +1 -0
  563. package/dist/TypeScript/asyncIterator.js +76 -0
  564. package/dist/TypeScript/asyncIterator.js.map +1 -0
  565. package/dist/TypeScript/expect.d.ts +6 -0
  566. package/dist/TypeScript/expect.js +12 -0
  567. package/dist/TypeScript/expect.js.map +1 -0
  568. package/dist/TypeScript/generator.d.ts +1 -0
  569. package/dist/TypeScript/generator.js +20 -0
  570. package/dist/TypeScript/generator.js.map +1 -0
  571. package/dist/TypeScript/object.d.ts +12 -0
  572. package/dist/TypeScript/object.js +3 -0
  573. package/dist/TypeScript/object.js.map +1 -0
  574. package/dist/TypeScript/observable-polyfill.d.ts +1 -0
  575. package/dist/TypeScript/observable-polyfill.js +33 -0
  576. package/dist/TypeScript/observable-polyfill.js.map +1 -0
  577. package/dist/Utils/array.d.ts +2 -0
  578. package/dist/Utils/array.js +23 -0
  579. package/dist/Utils/array.js.map +1 -0
  580. package/dist/Utils/enum.d.ts +24 -0
  581. package/dist/Utils/enum.js +35 -0
  582. package/dist/Utils/enum.js.map +1 -0
  583. package/dist/Utils/file.d.ts +1 -0
  584. package/dist/Utils/file.js +55 -0
  585. package/dist/Utils/file.js.map +1 -0
  586. package/dist/Utils/http.d.ts +23 -0
  587. package/dist/Utils/http.js +68 -0
  588. package/dist/Utils/http.js.map +1 -0
  589. package/dist/Utils/object.d.ts +22 -0
  590. package/dist/Utils/object.js +112 -0
  591. package/dist/Utils/object.js.map +1 -0
  592. package/dist/Utils/sorting.d.ts +1 -0
  593. package/dist/Utils/sorting.js +33 -0
  594. package/dist/Utils/sorting.js.map +1 -0
  595. package/dist/WebSocket/Client/ISocket.d.ts +55 -0
  596. package/dist/WebSocket/Client/ISocket.js +46 -0
  597. package/dist/WebSocket/Client/ISocket.js.map +1 -0
  598. package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.d.ts +8 -0
  599. package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.js +81 -0
  600. package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.js.map +1 -0
  601. package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.d.ts +25 -0
  602. package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.js +174 -0
  603. package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.js.map +1 -0
  604. package/dist/WebSocket/Client/WS/createWSSocket.d.ts +8 -0
  605. package/dist/WebSocket/Client/WS/createWSSocket.js +155 -0
  606. package/dist/WebSocket/Client/WS/createWSSocket.js.map +1 -0
  607. package/dist/WebSocket/autoWsServerFactory.d.ts +4 -0
  608. package/dist/WebSocket/autoWsServerFactory.js +334 -0
  609. package/dist/WebSocket/autoWsServerFactory.js.map +1 -0
  610. package/dist/WebSocket/perMessageDeflate.d.ts +14 -0
  611. package/dist/WebSocket/perMessageDeflate.js +3 -0
  612. package/dist/WebSocket/perMessageDeflate.js.map +1 -0
  613. package/dist/WebSocket/socketIOServerFactory.d.ts +6 -0
  614. package/dist/WebSocket/socketIOServerFactory.js +124 -0
  615. package/dist/WebSocket/socketIOServerFactory.js.map +1 -0
  616. package/dist/WebSocket/socketServer.d.ts +30 -0
  617. package/dist/WebSocket/socketServer.js +3 -0
  618. package/dist/WebSocket/socketServer.js.map +1 -0
  619. package/dist/WebSocket/wsServerFactory.d.ts +8 -0
  620. package/dist/WebSocket/wsServerFactory.js +272 -0
  621. package/dist/WebSocket/wsServerFactory.js.map +1 -0
  622. package/dist/Webpack/NpmPackPlugin.d.ts +14 -0
  623. package/dist/Webpack/NpmPackPlugin.js +90 -0
  624. package/dist/Webpack/NpmPackPlugin.js.map +1 -0
  625. package/dist/Zod/zod.d.ts +2 -0
  626. package/dist/Zod/zod.js +7 -0
  627. package/dist/Zod/zod.js.map +1 -0
  628. package/dist/Zod/zodError.d.ts +40 -0
  629. package/dist/Zod/zodError.js +76 -0
  630. package/dist/Zod/zodError.js.map +1 -0
  631. package/package.json +36 -2
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.formatNestedErrors = void 0;
27
+ var winston = __importStar(require("winston"));
28
+ /**
29
+ * Recursively formats Error objects in the log data structure.
30
+ * Handles errors in direct properties, arrays, and nested objects.
31
+ * Includes protection against circular references.
32
+ *
33
+ * Without this step, the output of serialization of the Error object is an empty object.
34
+ * @see https://stackoverflow.com/questions/18391212/is-it-not-possible-to-stringify-an-error-using-json-stringify
35
+ */
36
+ exports.formatNestedErrors = winston.format(function (info) {
37
+ var formatErrorsRecursively = function (obj, seen) {
38
+ if (seen === void 0) { seen = new WeakSet(); }
39
+ if (obj instanceof Error) {
40
+ return Object.assign({}, obj, {
41
+ message: obj.message,
42
+ stack: obj.stack,
43
+ });
44
+ }
45
+ if (Array.isArray(obj)) {
46
+ if (seen.has(obj)) {
47
+ return '[Circular]';
48
+ }
49
+ seen.add(obj);
50
+ var result = obj.map(function (item) { return formatErrorsRecursively(item, seen); });
51
+ seen.delete(obj);
52
+ return result;
53
+ }
54
+ if (obj !== null && typeof obj === 'object') {
55
+ // Handle Date objects specially - don't process them recursively
56
+ if (obj instanceof Date) {
57
+ return obj;
58
+ }
59
+ if (seen.has(obj)) {
60
+ return '[Circular]';
61
+ }
62
+ seen.add(obj);
63
+ var result = {};
64
+ for (var _i = 0, _a = Object.entries(obj); _i < _a.length; _i++) {
65
+ var _b = _a[_i], key = _b[0], value = _b[1];
66
+ result[key] = formatErrorsRecursively(value, seen);
67
+ }
68
+ seen.delete(obj);
69
+ return result;
70
+ }
71
+ return obj;
72
+ };
73
+ for (var _i = 0, _a = Object.entries(info); _i < _a.length; _i++) {
74
+ var _b = _a[_i], key = _b[0], value = _b[1];
75
+ info[key] = formatErrorsRecursively(value);
76
+ }
77
+ return info;
78
+ });
79
+ //# sourceMappingURL=format.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"format.js","sourceRoot":"","sources":["../../src/Logging/format.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAmC;AAEnC;;;;;;;GAOG;AACU,QAAA,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,UAAC,IAAI;IACrD,IAAM,uBAAuB,GAAG,UAAC,GAAQ,EAAE,IAAoB;QAApB,qBAAA,EAAA,WAAW,OAAO,EAAE;QAC9D,IAAI,GAAG,YAAY,KAAK,EAAE,CAAC;YAC1B,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,EAAE;gBAC7B,OAAO,EAAE,GAAG,CAAC,OAAO;gBACpB,KAAK,EAAE,GAAG,CAAC,KAAK;aAChB,CAAC,CAAC;QACJ,CAAC;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACxB,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACnB,OAAO,YAAY,CAAC;YACrB,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACd,IAAM,MAAM,GAAG,GAAG,CAAC,GAAG,CAAC,UAAC,IAAI,IAAK,OAAA,uBAAuB,CAAC,IAAI,EAAE,IAAI,CAAC,EAAnC,CAAmC,CAAC,CAAC;YACtE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjB,OAAO,MAAM,CAAC;QACf,CAAC;QAED,IAAI,GAAG,KAAK,IAAI,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC7C,iEAAiE;YACjE,IAAI,GAAG,YAAY,IAAI,EAAE,CAAC;gBACzB,OAAO,GAAG,CAAC;YACZ,CAAC;YAED,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACnB,OAAO,YAAY,CAAC;YACrB,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACd,IAAM,MAAM,GAAQ,EAAE,CAAC;YACvB,KAA2B,UAAmB,EAAnB,KAAA,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAnB,cAAmB,EAAnB,IAAmB,EAAE,CAAC;gBAAtC,IAAA,WAAY,EAAX,GAAG,QAAA,EAAE,KAAK,QAAA;gBACrB,MAAM,CAAC,GAAG,CAAC,GAAG,uBAAuB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;YACpD,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACjB,OAAO,MAAM,CAAC;QACf,CAAC;QAED,OAAO,GAAG,CAAC;IACZ,CAAC,CAAC;IAEF,KAA2B,UAAoB,EAApB,KAAA,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAApB,cAAoB,EAApB,IAAoB,EAAE,CAAC;QAAvC,IAAA,WAAY,EAAX,GAAG,QAAA,EAAE,KAAK,QAAA;QACrB,IAAI,CAAC,GAAG,CAAC,GAAG,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,IAAI,CAAC;AACb,CAAC,CAAC,CAAC"}
@@ -0,0 +1,53 @@
1
+ import * as winston from 'winston';
2
+ /** Central logger that aims to standardize how we work with logs across the applications.
3
+ *
4
+ * Goals:
5
+ * - Provide single API for all logs
6
+ * - Produce all logs in a standard format (most likely JSON) so that we can easily parse and analyze them with monitoring tools (i.e. Loki)
7
+ * - Provide a way to namespace logs so that we can easily filter logs by a specific part of the application
8
+ */
9
+ export interface ILogger {
10
+ error(message: string, meta?: object): ILogger;
11
+ warn(message: string, meta?: object): ILogger;
12
+ info(message: string, meta?: object): ILogger;
13
+ debug(message: string, meta?: object): ILogger;
14
+ /**
15
+ * Create a new logger instance that will include the provided namespace in metadata for all logs
16
+ *
17
+ * Can be nested to create a hierarchy of namespaces.
18
+ * For example:
19
+ *
20
+ * ```typescript
21
+ * const namespacedLogger = logger.createNamespace('myNamespace');
22
+ * const subNamespacedLogger = namespacedLogger.createNamespace('subNamespace');
23
+ * subNamespacedLogger.info('This log will include both "myNamespace" and "subNamespace" in the metadata');
24
+ * ```
25
+ *
26
+ * Will produce a log with this included in the metadata:
27
+ *
28
+ * ```json
29
+ * {
30
+ * "namespace": "myNamespace:subNamespace"
31
+ * }
32
+ * ```
33
+ */
34
+ createNamespace(namespace: string): ILogger;
35
+ }
36
+ export declare class WinstonLogger implements ILogger {
37
+ private logger;
38
+ private namespace?;
39
+ private settings;
40
+ constructor(logger: winston.Logger, namespace?: string | undefined);
41
+ error(message: string, meta?: object): ILogger;
42
+ warn(message: string, meta?: object): ILogger;
43
+ info(message: string, meta?: object): ILogger;
44
+ debug(message: string, meta?: object): ILogger;
45
+ createNamespace(namespace: string): ILogger;
46
+ setIgnoredLogNamespaces(ignoredLogNamespaces: string[]): void;
47
+ /**
48
+ * Log a message with the given level
49
+ *
50
+ * Logging can be disabled for specific namespaces by setting the `IGNORED_LOG_NAMESPACES` environment variable.
51
+ */
52
+ private log;
53
+ }
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.WinstonLogger = void 0;
15
+ var WinstonLogger = /** @class */ (function () {
16
+ function WinstonLogger(logger, namespace) {
17
+ this.logger = logger;
18
+ this.namespace = namespace;
19
+ this.settings = {
20
+ ignoredLogNamespaces: [],
21
+ };
22
+ this.settings = {
23
+ ignoredLogNamespaces: typeof process.env.IGNORED_LOG_NAMESPACES !== 'undefined' ? process.env.IGNORED_LOG_NAMESPACES.split(',') : [],
24
+ };
25
+ }
26
+ WinstonLogger.prototype.error = function (message, meta) {
27
+ this.log('error', message, meta);
28
+ return this;
29
+ };
30
+ WinstonLogger.prototype.warn = function (message, meta) {
31
+ this.log('warn', message, meta);
32
+ return this;
33
+ };
34
+ WinstonLogger.prototype.info = function (message, meta) {
35
+ this.log('info', message, meta);
36
+ return this;
37
+ };
38
+ WinstonLogger.prototype.debug = function (message, meta) {
39
+ this.log('debug', message, meta);
40
+ return this;
41
+ };
42
+ WinstonLogger.prototype.createNamespace = function (namespace) {
43
+ var prefix = this.namespace ? "".concat(this.namespace, ":") : '';
44
+ return new WinstonLogger(this.logger, prefix + namespace);
45
+ };
46
+ WinstonLogger.prototype.setIgnoredLogNamespaces = function (ignoredLogNamespaces) {
47
+ this.settings.ignoredLogNamespaces = ignoredLogNamespaces;
48
+ };
49
+ /**
50
+ * Log a message with the given level
51
+ *
52
+ * Logging can be disabled for specific namespaces by setting the `IGNORED_LOG_NAMESPACES` environment variable.
53
+ */
54
+ WinstonLogger.prototype.log = function (level, message, meta) {
55
+ var ignoreLogs = typeof this.namespace !== 'undefined' && this.settings.ignoredLogNamespaces.includes(this.namespace);
56
+ if (!ignoreLogs) {
57
+ this.logger.log(level, message, __assign({ namespace: this.namespace }, meta));
58
+ }
59
+ };
60
+ return WinstonLogger;
61
+ }());
62
+ exports.WinstonLogger = WinstonLogger;
63
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/Logging/logger.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAsCA;IAKC,uBACS,MAAsB,EACtB,SAAkB;QADlB,WAAM,GAAN,MAAM,CAAgB;QACtB,cAAS,GAAT,SAAS,CAAS;QANnB,aAAQ,GAAuC;YACtD,oBAAoB,EAAE,EAAE;SACxB,CAAC;QAMD,IAAI,CAAC,QAAQ,GAAG;YACf,oBAAoB,EAAE,OAAO,OAAO,CAAC,GAAG,CAAC,sBAAsB,KAAK,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;SACpI,CAAC;IACH,CAAC;IAEM,6BAAK,GAAZ,UAAa,OAAe,EAAE,IAAa;QAC1C,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,4BAAI,GAAX,UAAY,OAAe,EAAE,IAAa;QACzC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,4BAAI,GAAX,UAAY,OAAe,EAAE,IAAa;QACzC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,6BAAK,GAAZ,UAAa,OAAe,EAAE,IAAa;QAC1C,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,OAAO,IAAI,CAAC;IACb,CAAC;IAEM,uCAAe,GAAtB,UAAuB,SAAiB;QACvC,IAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,UAAG,IAAI,CAAC,SAAS,MAAG,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1D,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,CAAC;IAC3D,CAAC;IAEM,+CAAuB,GAA9B,UAA+B,oBAA8B;QAC5D,IAAI,CAAC,QAAQ,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;IAC3D,CAAC;IAED;;;;OAIG;IACK,2BAAG,GAAX,UAAY,KAAa,EAAE,OAAe,EAAE,IAAa;QACxD,IAAM,UAAU,GAAG,OAAO,IAAI,CAAC,SAAS,KAAK,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxH,IAAI,CAAC,UAAU,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,aAAI,SAAS,EAAE,IAAI,CAAC,SAAS,IAAK,IAAI,EAAG,CAAC;QACzE,CAAC;IACF,CAAC;IACF,oBAAC;AAAD,CAAC,AAtDD,IAsDC;AAtDY,sCAAa"}
@@ -0,0 +1,12 @@
1
+ import { WinstonLogger } from './logger';
2
+ /**
3
+ * Singleton logger to be used across the entire application
4
+ */
5
+ export declare const logger: WinstonLogger;
6
+ /**
7
+ * This function will redirect all console logs and debug logs to the logger.
8
+ *
9
+ * The goal is to collect all logs that are not logged through the central logger and make them go through the logger.
10
+ * That way we can control the format and destination of all logs no matter where they are logged.
11
+ */
12
+ export declare function redirectAllLogsToLogger(): void;
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || function (mod) {
30
+ if (mod && mod.__esModule) return mod;
31
+ var result = {};
32
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
33
+ __setModuleDefault(result, mod);
34
+ return result;
35
+ };
36
+ var __rest = (this && this.__rest) || function (s, e) {
37
+ var t = {};
38
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
39
+ t[p] = s[p];
40
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
41
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
42
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
43
+ t[p[i]] = s[p[i]];
44
+ }
45
+ return t;
46
+ };
47
+ var _a;
48
+ Object.defineProperty(exports, "__esModule", { value: true });
49
+ exports.logger = void 0;
50
+ exports.redirectAllLogsToLogger = redirectAllLogsToLogger;
51
+ var winston = __importStar(require("winston"));
52
+ var logger_1 = require("./logger");
53
+ var console_1 = require("./console");
54
+ var debug_1 = require("./debug");
55
+ var format_1 = require("./format");
56
+ var LogFormat;
57
+ (function (LogFormat) {
58
+ LogFormat["JSON"] = "json";
59
+ LogFormat["JSON_PRETTY"] = "json_pretty";
60
+ LogFormat["Simple"] = "simple";
61
+ })(LogFormat || (LogFormat = {}));
62
+ var logLevel = process.env.LOG_LEVEL || 'debug';
63
+ var logFormat = process.env.LOG_FORMAT || LogFormat.JSON;
64
+ var ensureJSONKeyOrder = winston.format(function (info) {
65
+ var level = info.level, message = info.message, rest = __rest(info, ["level", "message"]);
66
+ return __assign({ level: level, message: message }, rest);
67
+ });
68
+ var winstonFormatters = [
69
+ // parses errors and adds stack trace, when error is passed as the first argument instead of message
70
+ winston.format.errors({ stack: true }),
71
+ // parses nested error objects and adds stack trace
72
+ (0, format_1.formatNestedErrors)(),
73
+ ];
74
+ switch (logFormat) {
75
+ case LogFormat.JSON:
76
+ winstonFormatters.push(ensureJSONKeyOrder(), // ensures that the keys in the JSON are always in the order we want
77
+ winston.format.json({ deterministic: false }));
78
+ break;
79
+ case LogFormat.JSON_PRETTY:
80
+ winstonFormatters.push(ensureJSONKeyOrder(), // ensures that the keys in the JSON are always in the order we want
81
+ winston.format.json(), winston.format.prettyPrint({ colorize: true }));
82
+ break;
83
+ case LogFormat.Simple:
84
+ winstonFormatters.push(winston.format.colorize(), // adds colors to the log
85
+ winston.format.simple());
86
+ break;
87
+ default:
88
+ throw new Error("Unknown log format: ".concat(logFormat, ", allowed values are: json, simple"));
89
+ }
90
+ /**
91
+ * Since we aim to have a single API for all logs in the application, it's implemented as singleton.
92
+ * If that turns to be insufficient, we can change that later.
93
+ */
94
+ var winstonLogger = winston.createLogger({
95
+ level: logLevel,
96
+ format: (_a = winston.format).combine.apply(_a, winstonFormatters),
97
+ transports: [new winston.transports.Console()],
98
+ });
99
+ /**
100
+ * Singleton logger to be used across the entire application
101
+ */
102
+ exports.logger = new logger_1.WinstonLogger(winstonLogger);
103
+ /**
104
+ * This function will redirect all console logs and debug logs to the logger.
105
+ *
106
+ * The goal is to collect all logs that are not logged through the central logger and make them go through the logger.
107
+ * That way we can control the format and destination of all logs no matter where they are logged.
108
+ */
109
+ function redirectAllLogsToLogger() {
110
+ (0, console_1.redirectConsoleToLogger)(exports.logger);
111
+ (0, debug_1.redirectDebugToLogger)(exports.logger);
112
+ }
113
+ //# sourceMappingURL=logging.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../src/Logging/logging.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwEA,0DAGC;AA3ED,+CAAmC;AACnC,mCAAyC;AACzC,qCAAoD;AACpD,iCAAgD;AAChD,mCAA8C;AAE9C,IAAK,SAIJ;AAJD,WAAK,SAAS;IACb,0BAAa,CAAA;IACb,wCAA2B,CAAA;IAC3B,8BAAiB,CAAA;AAClB,CAAC,EAJI,SAAS,KAAT,SAAS,QAIb;AAED,IAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,OAAO,CAAC;AAClD,IAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,SAAS,CAAC,IAAI,CAAC;AAE3D,IAAM,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,UAAC,IAAI;IACtC,IAAA,KAAK,GAAuB,IAAI,MAA3B,EAAE,OAAO,GAAc,IAAI,QAAlB,EAAK,IAAI,UAAK,IAAI,EAAlC,oBAA2B,CAAF,CAAU;IACzC,kBAAS,KAAK,OAAA,EAAE,OAAO,SAAA,IAAK,IAAI,EAAG;AACpC,CAAC,CAAC,CAAC;AAEH,IAAM,iBAAiB,GAA6B;IACnD,oGAAoG;IACpG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IACtC,mDAAmD;IACnD,IAAA,2BAAkB,GAAE;CACpB,CAAC;AAEF,QAAQ,SAAS,EAAE,CAAC;IACnB,KAAK,SAAS,CAAC,IAAI;QAClB,iBAAiB,CAAC,IAAI,CACrB,kBAAkB,EAAE,EAAE,oEAAoE;QAC1F,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAC7C,CAAC;QACF,MAAM;IACP,KAAK,SAAS,CAAC,WAAW;QACzB,iBAAiB,CAAC,IAAI,CACrB,kBAAkB,EAAE,EAAE,oEAAoE;QAC1F,OAAO,CAAC,MAAM,CAAC,IAAI,EAAE,EACrB,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAC9C,CAAC;QACF,MAAM;IACP,KAAK,SAAS,CAAC,MAAM;QACpB,iBAAiB,CAAC,IAAI,CACrB,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,yBAAyB;QACpD,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CACvB,CAAC;QACF,MAAM;IACP;QACC,MAAM,IAAI,KAAK,CAAC,8BAAuB,SAAS,uCAAoC,CAAC,CAAC;AACxF,CAAC;AAED;;;GAGG;AACH,IAAM,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IAC1C,KAAK,EAAE,QAAQ;IACf,MAAM,EAAE,CAAA,KAAA,OAAO,CAAC,MAAM,CAAA,CAAC,OAAO,WAAI,iBAAiB,CAAC;IACpD,UAAU,EAAE,CAAC,IAAI,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;CAC9C,CAAC,CAAC;AAEH;;GAEG;AACU,QAAA,MAAM,GAAG,IAAI,sBAAa,CAAC,aAAa,CAAC,CAAC;AAEvD;;;;;GAKG;AACH,SAAgB,uBAAuB;IACtC,IAAA,iCAAuB,EAAC,cAAM,CAAC,CAAC;IAChC,IAAA,6BAAqB,EAAC,cAAM,CAAC,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,46 @@
1
+ import { Response } from 'express';
2
+ import * as prometheusClient from 'prom-client';
3
+ export type PrometheusClient = typeof prometheusClient;
4
+ export type BeforeServeListener = (client: PrometheusClient) => void;
5
+ /**
6
+ * Metrics client
7
+ *
8
+ * If you want to add custom application-specific metrics, you have to call getClient()
9
+ * add your metrics to the client.
10
+ *
11
+ * Example:
12
+ *
13
+ * const client = metricsClient.getClient();
14
+ * const myCounter = new client.Counter({
15
+ * name: 'my_counter',
16
+ * help: 'This is my counter',
17
+ * });
18
+ * // now you can independently increment the counter in your code
19
+ * // and the value will automatically be exposed when serving metrics
20
+ *
21
+ * For more info, see https://www.npmjs.com/package/prom-client
22
+ */
23
+ export interface IMetricsClient {
24
+ /**
25
+ * Returns Prometheus client
26
+ *
27
+ * This is useful for adding custom metrics
28
+ */
29
+ getClient(): PrometheusClient;
30
+ /**
31
+ * Initialize metrics client to start serving default Node.js metrics
32
+ */
33
+ init(): void;
34
+ /** Serve metrics as HTTP response */
35
+ serve(response: Response): Promise<Response>;
36
+ /** Clear all metrics and reset the client */
37
+ clear(): void;
38
+ }
39
+ export declare class MetricsClient implements IMetricsClient {
40
+ private client;
41
+ constructor(client?: PrometheusClient);
42
+ getClient(): PrometheusClient;
43
+ init(): void;
44
+ serve(response: Response): Promise<Response>;
45
+ clear(): void;
46
+ }
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
+ return new (P || (P = Promise))(function (resolve, reject) {
28
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
29
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
30
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
31
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
32
+ });
33
+ };
34
+ var __generator = (this && this.__generator) || function (thisArg, body) {
35
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
36
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
37
+ function verb(n) { return function (v) { return step([n, v]); }; }
38
+ function step(op) {
39
+ if (f) throw new TypeError("Generator is already executing.");
40
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
41
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
42
+ if (y = 0, t) op = [op[0] & 2, t.value];
43
+ switch (op[0]) {
44
+ case 0: case 1: t = op; break;
45
+ case 4: _.label++; return { value: op[1], done: false };
46
+ case 5: _.label++; y = op[1]; op = [0]; continue;
47
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
48
+ default:
49
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
50
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
51
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
52
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
53
+ if (t[2]) _.ops.pop();
54
+ _.trys.pop(); continue;
55
+ }
56
+ op = body.call(thisArg, _);
57
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
58
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
59
+ }
60
+ };
61
+ Object.defineProperty(exports, "__esModule", { value: true });
62
+ exports.MetricsClient = void 0;
63
+ var prometheusClient = __importStar(require("prom-client"));
64
+ var processSocketsMetrics_1 = require("./processSocketsMetrics");
65
+ var MetricsClient = /** @class */ (function () {
66
+ function MetricsClient(client) {
67
+ if (client === void 0) { client = prometheusClient; }
68
+ this.client = client;
69
+ }
70
+ MetricsClient.prototype.getClient = function () {
71
+ return this.client;
72
+ };
73
+ MetricsClient.prototype.init = function () {
74
+ this.client.collectDefaultMetrics();
75
+ (0, processSocketsMetrics_1.collectSocketMetrics)({
76
+ registry: this.client.register,
77
+ process: process,
78
+ });
79
+ };
80
+ MetricsClient.prototype.serve = function (response) {
81
+ return __awaiter(this, void 0, void 0, function () {
82
+ var responseBody;
83
+ return __generator(this, function (_a) {
84
+ switch (_a.label) {
85
+ case 0:
86
+ response.set('Content-Type', this.client.register.contentType);
87
+ return [4 /*yield*/, this.client.register.metrics()];
88
+ case 1:
89
+ responseBody = _a.sent();
90
+ return [2 /*return*/, response.send(responseBody)];
91
+ }
92
+ });
93
+ });
94
+ };
95
+ MetricsClient.prototype.clear = function () {
96
+ this.client.register.clear();
97
+ };
98
+ return MetricsClient;
99
+ }());
100
+ exports.MetricsClient = MetricsClient;
101
+ //# sourceMappingURL=MetricsClient.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MetricsClient.js","sourceRoot":"","sources":["../../src/Metrics/MetricsClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA,4DAAgD;AAChD,iEAA+D;AAyC/D;IACC,uBAAoB,MAA2C;QAA3C,uBAAA,EAAA,yBAA2C;QAA3C,WAAM,GAAN,MAAM,CAAqC;IAAG,CAAC;IAE5D,iCAAS,GAAhB;QACC,OAAO,IAAI,CAAC,MAAM,CAAC;IACpB,CAAC;IAEM,4BAAI,GAAX;QACC,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC;QACpC,IAAA,4CAAoB,EAAC;YACpB,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;YAC9B,OAAO,SAAA;SACP,CAAC,CAAC;IACJ,CAAC;IAEY,6BAAK,GAAlB,UAAmB,QAAkB;;;;;;wBACpC,QAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;wBAC1C,qBAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAA;;wBAAnD,YAAY,GAAG,SAAoC;wBACzD,sBAAO,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,EAAC;;;;KACnC;IAEM,6BAAK,GAAZ;QACC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IAC9B,CAAC;IACF,oBAAC;AAAD,CAAC,AAxBD,IAwBC;AAxBY,sCAAa"}
@@ -0,0 +1,6 @@
1
+ import { Metrics } from './metrics';
2
+ export type MetricsEvents = 'incoming_actions_received' | 'incoming_actions_successful' | 'incoming_actions_erred' | 'incoming_actions_processing_duration' | 'outgoing_actions_successful' | 'outgoing_actions_erred' | 'outgoing_actions_ack_duration';
3
+ export type TLabelsTypes = {
4
+ actionType: 'NOT_PREDEFINED_VALUE';
5
+ };
6
+ export declare const metrics: Metrics<MetricsEvents, TLabelsTypes>;
@@ -0,0 +1,59 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.metrics = void 0;
4
+ var metrics_1 = require("./metrics");
5
+ var defaultOptions = {
6
+ /**
7
+ * Buckets for the action_duration_seconds_bucket metric.
8
+ * Default buckets are [0.01, 0.05, 0.1, 0.5, 1, 2, 5, 10, 30, 60]
9
+ */
10
+ durationInSecondsHistogramBuckets: [0.01, 0.05, 0.1, 0.5, 1, 2, 5, 10, 30, 60],
11
+ };
12
+ var prefix = 'sos_device_consumer_';
13
+ var labels = {
14
+ actionType: 'NOT_PREDEFINED_VALUE',
15
+ };
16
+ var metricsConfig = {
17
+ incoming_actions_received: {
18
+ metric: 'Counter',
19
+ help: 'Total number of incoming actions received',
20
+ labels: labels,
21
+ },
22
+ incoming_actions_successful: {
23
+ metric: 'Counter',
24
+ help: 'Total number of successfully processed incoming actions',
25
+ labels: labels,
26
+ },
27
+ incoming_actions_erred: {
28
+ metric: 'Counter',
29
+ help: 'Total number of incoming actions that resulted in an error',
30
+ labels: labels,
31
+ },
32
+ incoming_actions_processing_duration: {
33
+ metric: 'Histogram',
34
+ help: 'Duration of incoming action processing in seconds',
35
+ buckets: defaultOptions.durationInSecondsHistogramBuckets,
36
+ labels: labels,
37
+ },
38
+ outgoing_actions_successful: {
39
+ metric: 'Counter',
40
+ help: 'Total number of successfully processed outgoing actions',
41
+ labels: labels,
42
+ },
43
+ outgoing_actions_erred: {
44
+ metric: 'Counter',
45
+ help: 'Total number of outgoing actions that resulted in an error',
46
+ labels: labels,
47
+ },
48
+ outgoing_actions_ack_duration: {
49
+ metric: 'Histogram',
50
+ help: 'Duration of outgoing action acknowledgment in seconds',
51
+ buckets: defaultOptions.durationInSecondsHistogramBuckets,
52
+ labels: labels,
53
+ },
54
+ };
55
+ exports.metrics = new metrics_1.Metrics({
56
+ metricsConfig: metricsConfig,
57
+ prefix: prefix,
58
+ });
59
+ //# sourceMappingURL=deviceConsumerMetrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deviceConsumerMetrics.js","sourceRoot":"","sources":["../../src/Metrics/deviceConsumerMetrics.ts"],"names":[],"mappings":";;;AAAA,qCAAoD;AAEpD,IAAM,cAAc,GAAG;IACtB;;;OAGG;IACH,iCAAiC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;CAC9E,CAAC;AAEF,IAAM,MAAM,GAAG,sBAAsB,CAAC;AAetC,IAAM,MAAM,GAAG;IACd,UAAU,EAAE,sBAAsB;CACzB,CAAC;AAEX,IAAM,aAAa,GAAgD;IAClE,yBAAyB,EAAE;QAC1B,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,2CAA2C;QACjD,MAAM,QAAA;KACN;IACD,2BAA2B,EAAE;QAC5B,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,yDAAyD;QAC/D,MAAM,QAAA;KACN;IACD,sBAAsB,EAAE;QACvB,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,4DAA4D;QAClE,MAAM,QAAA;KACN;IACD,oCAAoC,EAAE;QACrC,MAAM,EAAE,WAAW;QACnB,IAAI,EAAE,mDAAmD;QACzD,OAAO,EAAE,cAAc,CAAC,iCAAiC;QACzD,MAAM,QAAA;KACN;IACD,2BAA2B,EAAE;QAC5B,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,yDAAyD;QAC/D,MAAM,QAAA;KACN;IACD,sBAAsB,EAAE;QACvB,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,4DAA4D;QAClE,MAAM,QAAA;KACN;IACD,6BAA6B,EAAE;QAC9B,MAAM,EAAE,WAAW;QACnB,IAAI,EAAE,uDAAuD;QAC7D,OAAO,EAAE,cAAc,CAAC,iCAAiC;QACzD,MAAM,QAAA;KACN;CACD,CAAC;AAEW,QAAA,OAAO,GAAG,IAAI,iBAAO,CAA8B;IAC/D,aAAa,eAAA;IACb,MAAM,QAAA;CACN,CAAC,CAAC"}
@@ -0,0 +1,19 @@
1
+ import IEvent, { IEventPayload } from '../AMQP/EventSourcing/IEvent';
2
+ import { Metrics } from './metrics';
3
+ export type EventProcessedData = {
4
+ event: IEvent<IEventPayload>;
5
+ stats: {
6
+ /** Timestamp in milliseconds when consumption started */
7
+ start: number;
8
+ duration: number;
9
+ };
10
+ };
11
+ declare const eventPhases: readonly ["processing", "eventStart", "commandStart"];
12
+ type EventPhase = (typeof eventPhases)[number];
13
+ type MetricsEvents = 'events_total' | 'event_duration_seconds' | 'event_duration_seconds_total' | 'event_success_total' | 'event_error_total';
14
+ type TLabelsTypes = {
15
+ eventType: 'NOT_PREDEFINED_VALUE';
16
+ phase: readonly EventPhase[];
17
+ };
18
+ export declare const metrics: Metrics<MetricsEvents, TLabelsTypes>;
19
+ export {};
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.metrics = void 0;
4
+ var metrics_1 = require("./metrics");
5
+ var defaultOptions = {
6
+ /**
7
+ * Buckets for the event_duration_seconds_bucket metric.
8
+ * Default buckets are [0.01, 0.05, 0.1, 0.5, 1, 2, 5, 10, 30, 60]
9
+ */
10
+ durationInSecondsHistogramBuckets: [0.01, 0.05, 0.1, 0.5, 1, 2, 5, 10, 30, 60],
11
+ };
12
+ var prefix = 'sos_event_consumer_';
13
+ var eventPhases = ['processing', 'eventStart', 'commandStart'];
14
+ var labels = {
15
+ eventType: 'NOT_PREDEFINED_VALUE',
16
+ };
17
+ var metricsConfig = {
18
+ events_total: {
19
+ metric: 'Counter',
20
+ help: 'Number of all events',
21
+ labels: labels,
22
+ },
23
+ event_duration_seconds_total: {
24
+ metric: 'Counter',
25
+ help: 'Total duration of all events in seconds',
26
+ labels: {
27
+ eventType: 'NOT_PREDEFINED_VALUE',
28
+ phase: eventPhases,
29
+ },
30
+ },
31
+ event_duration_seconds: {
32
+ metric: 'Histogram',
33
+ help: 'Duration of all events in seconds',
34
+ buckets: defaultOptions.durationInSecondsHistogramBuckets,
35
+ labels: labels,
36
+ },
37
+ event_success_total: {
38
+ metric: 'Counter',
39
+ help: 'Number of events that succeeded',
40
+ labels: labels,
41
+ },
42
+ event_error_total: {
43
+ metric: 'Counter',
44
+ help: 'Number of events that errored',
45
+ labels: labels,
46
+ },
47
+ };
48
+ exports.metrics = new metrics_1.Metrics({
49
+ metricsConfig: metricsConfig,
50
+ prefix: prefix,
51
+ });
52
+ //# sourceMappingURL=eventConsumerMetrics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"eventConsumerMetrics.js","sourceRoot":"","sources":["../../src/Metrics/eventConsumerMetrics.ts"],"names":[],"mappings":";;;AACA,qCAAoD;AAEpD,IAAM,cAAc,GAAG;IACtB;;;OAGG;IACH,iCAAiC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;CAC9E,CAAC;AAEF,IAAM,MAAM,GAAG,qBAAqB,CAAC;AAWrC,IAAM,WAAW,GAAG,CAAC,YAAY,EAAE,YAAY,EAAE,cAAc,CAAU,CAAC;AAgB1E,IAAM,MAAM,GAAG;IACd,SAAS,EAAE,sBAAsB;CACxB,CAAC;AAEX,IAAM,aAAa,GAAgD;IAClE,YAAY,EAAE;QACb,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,sBAAsB;QAC5B,MAAM,QAAA;KACN;IACD,4BAA4B,EAAE;QAC7B,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,yCAAyC;QAC/C,MAAM,EAAE;YACP,SAAS,EAAE,sBAAsB;YACjC,KAAK,EAAE,WAAW;SAClB;KACD;IACD,sBAAsB,EAAE;QACvB,MAAM,EAAE,WAAW;QACnB,IAAI,EAAE,mCAAmC;QACzC,OAAO,EAAE,cAAc,CAAC,iCAAiC;QACzD,MAAM,QAAA;KACN;IACD,mBAAmB,EAAE;QACpB,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,iCAAiC;QACvC,MAAM,QAAA;KACN;IACD,iBAAiB,EAAE;QAClB,MAAM,EAAE,SAAS;QACjB,IAAI,EAAE,+BAA+B;QACrC,MAAM,QAAA;KACN;CACD,CAAC;AAEW,QAAA,OAAO,GAAG,IAAI,iBAAO,CAA8B;IAC/D,aAAa,eAAA;IACb,MAAM,QAAA;CACN,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { Metrics, TNOT_PREDEFINED_VALUE } from './metrics';
2
+ type MetricsEvents = 'event_enqueued';
3
+ type TLabelsTypes = {
4
+ eventType: TNOT_PREDEFINED_VALUE;
5
+ };
6
+ export declare const metrics: Metrics<MetricsEvents, TLabelsTypes>;
7
+ export {};