@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.
- package/dist/AMQP/CQRS/ICommand.d.ts +38 -0
- package/dist/AMQP/CQRS/ICommand.js +3 -0
- package/dist/AMQP/CQRS/ICommand.js.map +1 -0
- package/dist/AMQP/CQRS/ICommandError.d.ts +4 -0
- package/dist/AMQP/CQRS/ICommandError.js +3 -0
- package/dist/AMQP/CQRS/ICommandError.js.map +1 -0
- package/dist/AMQP/CQRS/commandQueue.d.ts +59 -0
- package/dist/AMQP/CQRS/commandQueue.js +313 -0
- package/dist/AMQP/CQRS/commandQueue.js.map +1 -0
- package/dist/AMQP/CQRS/commandResponseHelper.d.ts +3 -0
- package/dist/AMQP/CQRS/commandResponseHelper.js +8 -0
- package/dist/AMQP/CQRS/commandResponseHelper.js.map +1 -0
- package/dist/AMQP/CQRS/storedCommandQueue.d.ts +27 -0
- package/dist/AMQP/CQRS/storedCommandQueue.js +301 -0
- package/dist/AMQP/CQRS/storedCommandQueue.js.map +1 -0
- package/dist/AMQP/ChannelProvider.d.ts +37 -0
- package/dist/AMQP/ChannelProvider.js +886 -0
- package/dist/AMQP/ChannelProvider.js.map +1 -0
- package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.d.ts +39 -0
- package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.js +292 -0
- package/dist/AMQP/DeviceActions/Bridge/deviceActionBridgeFactory.js.map +1 -0
- package/dist/AMQP/DeviceActions/IDeviceAction.d.ts +4 -0
- package/dist/AMQP/DeviceActions/IDeviceAction.js +3 -0
- package/dist/AMQP/DeviceActions/IDeviceAction.js.map +1 -0
- package/dist/AMQP/DeviceActions/deviceActionsQueue.d.ts +83 -0
- package/dist/AMQP/DeviceActions/deviceActionsQueue.js +538 -0
- package/dist/AMQP/DeviceActions/deviceActionsQueue.js.map +1 -0
- package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.d.ts +47 -0
- package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.js +218 -0
- package/dist/AMQP/EventSourcing/EventConsumer/AmqpEventConsumer.js.map +1 -0
- package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.d.ts +13 -0
- package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.js +3 -0
- package/dist/AMQP/EventSourcing/EventConsumer/IEventConsumer.js.map +1 -0
- package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.d.ts +15 -0
- package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.js +76 -0
- package/dist/AMQP/EventSourcing/EventConsumer/InMemoryEventConsumer.js.map +1 -0
- package/dist/AMQP/EventSourcing/IEvent.d.ts +72 -0
- package/dist/AMQP/EventSourcing/IEvent.js +3 -0
- package/dist/AMQP/EventSourcing/IEvent.js.map +1 -0
- package/dist/AMQP/EventSourcing/Locked/deferredState.d.ts +21 -0
- package/dist/AMQP/EventSourcing/Locked/deferredState.js +72 -0
- package/dist/AMQP/EventSourcing/Locked/deferredState.js.map +1 -0
- package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.d.ts +63 -0
- package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.js +261 -0
- package/dist/AMQP/EventSourcing/Locked/lockedEventConsumer.js.map +1 -0
- package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.d.ts +24 -0
- package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.js +64 -0
- package/dist/AMQP/EventSourcing/Locked/rejectedTimestamps.js.map +1 -0
- package/dist/AMQP/EventSourcing/Locked/withLock.d.ts +42 -0
- package/dist/AMQP/EventSourcing/Locked/withLock.js +141 -0
- package/dist/AMQP/EventSourcing/Locked/withLock.js.map +1 -0
- package/dist/AMQP/EventSourcing/eventQueue.d.ts +87 -0
- package/dist/AMQP/EventSourcing/eventQueue.js +139 -0
- package/dist/AMQP/EventSourcing/eventQueue.js.map +1 -0
- package/dist/AMQP/EventSourcing/eventQueue.utils.d.ts +73 -0
- package/dist/AMQP/EventSourcing/eventQueue.utils.js +157 -0
- package/dist/AMQP/EventSourcing/eventQueue.utils.js.map +1 -0
- package/dist/AMQP/EventSourcing/eventQueueDetached.d.ts +49 -0
- package/dist/AMQP/EventSourcing/eventQueueDetached.js +428 -0
- package/dist/AMQP/EventSourcing/eventQueueDetached.js.map +1 -0
- package/dist/AMQP/EventSourcing/eventQueueDomain.d.ts +42 -0
- package/dist/AMQP/EventSourcing/eventQueueDomain.js +371 -0
- package/dist/AMQP/EventSourcing/eventQueueDomain.js.map +1 -0
- package/dist/AMQP/EventSourcing/eventQueuePublish.d.ts +19 -0
- package/dist/AMQP/EventSourcing/eventQueuePublish.js +209 -0
- package/dist/AMQP/EventSourcing/eventQueuePublish.js.map +1 -0
- package/dist/AMQP/EventSourcing/synchronization.d.ts +39 -0
- package/dist/AMQP/EventSourcing/synchronization.js +12 -0
- package/dist/AMQP/EventSourcing/synchronization.js.map +1 -0
- package/dist/AMQP/Exchange.d.ts +1 -0
- package/dist/AMQP/Exchange.js +3 -0
- package/dist/AMQP/Exchange.js.map +1 -0
- package/dist/AMQP/IAMQPPool.d.ts +5 -0
- package/dist/AMQP/IAMQPPool.js +3 -0
- package/dist/AMQP/IAMQPPool.js.map +1 -0
- package/dist/AMQP/IAsyncGotMessage.d.ts +15 -0
- package/dist/AMQP/IAsyncGotMessage.js +3 -0
- package/dist/AMQP/IAsyncGotMessage.js.map +1 -0
- package/dist/AMQP/IChannel.d.ts +43 -0
- package/dist/AMQP/IChannel.js +3 -0
- package/dist/AMQP/IChannel.js.map +1 -0
- package/dist/AMQP/IConsumeOptions.d.ts +106 -0
- package/dist/AMQP/IConsumeOptions.js +3 -0
- package/dist/AMQP/IConsumeOptions.js.map +1 -0
- package/dist/AMQP/IMessageOptions.d.ts +6 -0
- package/dist/AMQP/IMessageOptions.js +3 -0
- package/dist/AMQP/IMessageOptions.js.map +1 -0
- package/dist/AMQP/INackOptions.d.ts +4 -0
- package/dist/AMQP/INackOptions.js +3 -0
- package/dist/AMQP/INackOptions.js.map +1 -0
- package/dist/AMQP/IQueueOptions.d.ts +8 -0
- package/dist/AMQP/IQueueOptions.js +3 -0
- package/dist/AMQP/IQueueOptions.js.map +1 -0
- package/dist/AMQP/Logging/IDeviceLog.d.ts +15 -0
- package/dist/AMQP/Logging/IDeviceLog.js +10 -0
- package/dist/AMQP/Logging/IDeviceLog.js.map +1 -0
- package/dist/AMQP/Logging/logDeviceQueue.d.ts +12 -0
- package/dist/AMQP/Logging/logDeviceQueue.js +107 -0
- package/dist/AMQP/Logging/logDeviceQueue.js.map +1 -0
- package/dist/AMQP/QueueFetcher.d.ts +13 -0
- package/dist/AMQP/QueueFetcher.js +166 -0
- package/dist/AMQP/QueueFetcher.js.map +1 -0
- package/dist/AMQP/QueuePublisher.d.ts +7 -0
- package/dist/AMQP/QueuePublisher.js +135 -0
- package/dist/AMQP/QueuePublisher.js.map +1 -0
- package/dist/AMQP/QueueRepeatableSubscription.d.ts +14 -0
- package/dist/AMQP/QueueRepeatableSubscription.js +162 -0
- package/dist/AMQP/QueueRepeatableSubscription.js.map +1 -0
- package/dist/AMQP/QueueSubscriber.d.ts +11 -0
- package/dist/AMQP/QueueSubscriber.js +163 -0
- package/dist/AMQP/QueueSubscriber.js.map +1 -0
- package/dist/AMQP/ResponseProvider.d.ts +20 -0
- package/dist/AMQP/ResponseProvider.js +193 -0
- package/dist/AMQP/ResponseProvider.js.map +1 -0
- package/dist/AMQP/Static/filesQueue.d.ts +12 -0
- package/dist/AMQP/Static/filesQueue.js +220 -0
- package/dist/AMQP/Static/filesQueue.js.map +1 -0
- package/dist/AMQP/amqpConnectionFactory.d.ts +27 -0
- package/dist/AMQP/amqpConnectionFactory.js +236 -0
- package/dist/AMQP/amqpConnectionFactory.js.map +1 -0
- package/dist/AMQP/amqpErrors.d.ts +5 -0
- package/dist/AMQP/amqpErrors.js +30 -0
- package/dist/AMQP/amqpErrors.js.map +1 -0
- package/dist/AMQP/errors.d.ts +3 -0
- package/dist/AMQP/errors.js +30 -0
- package/dist/AMQP/errors.js.map +1 -0
- package/dist/AMQP/fetchNextMessage.d.ts +14 -0
- package/dist/AMQP/fetchNextMessage.js +118 -0
- package/dist/AMQP/fetchNextMessage.js.map +1 -0
- package/dist/AMQP/queueConfigurator.d.ts +5 -0
- package/dist/AMQP/queueConfigurator.js +78 -0
- package/dist/AMQP/queueConfigurator.js.map +1 -0
- package/dist/AWS/S3.d.ts +95 -0
- package/dist/AWS/S3.js +448 -0
- package/dist/AWS/S3.js.map +1 -0
- package/dist/AWS/S3Types.d.ts +113 -0
- package/dist/AWS/S3Types.js +3 -0
- package/dist/AWS/S3Types.js.map +1 -0
- package/dist/AWS/config.d.ts +2 -0
- package/dist/AWS/config.js +23 -0
- package/dist/AWS/config.js.map +1 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.d.ts +30 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.js +81 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.js.map +1 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.d.ts +5 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.js +33 -0
- package/dist/Auth0/AuthenticationClient/Auth0AuthenticationClient.utils.js.map +1 -0
- package/dist/Auth0/ManagementClient/Auth0ManagementClient.d.ts +41 -0
- package/dist/Auth0/ManagementClient/Auth0ManagementClient.js +137 -0
- package/dist/Auth0/ManagementClient/Auth0ManagementClient.js.map +1 -0
- package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.d.ts +8 -0
- package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.js +37 -0
- package/dist/Auth0/ManagementClient/auth0ManagementClient.utils.js.map +1 -0
- package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.d.ts +14 -0
- package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.js +58 -0
- package/dist/Auth0/UserInfoClient/Auth0UserInfoClient.js.map +1 -0
- package/dist/Auth0/auth0.types.d.ts +4 -0
- package/dist/Auth0/auth0.types.js +10 -0
- package/dist/Auth0/auth0.types.js.map +1 -0
- package/dist/Cache/lruCache.d.ts +22 -0
- package/dist/Cache/lruCache.js +42 -0
- package/dist/Cache/lruCache.js.map +1 -0
- package/dist/Cache/memoryCache.d.ts +7 -0
- package/dist/Cache/memoryCache.js +80 -0
- package/dist/Cache/memoryCache.js.map +1 -0
- package/dist/Config/config.d.ts +81 -0
- package/dist/Config/config.js +119 -0
- package/dist/Config/config.js.map +1 -0
- package/dist/Config/environment.d.ts +8 -0
- package/dist/Config/environment.js +13 -0
- package/dist/Config/environment.js.map +1 -0
- package/dist/Config/validation.d.ts +61 -0
- package/dist/Config/validation.js +56 -0
- package/dist/Config/validation.js.map +1 -0
- package/dist/DateTime/dateMonkeyPatch.d.ts +15 -0
- package/dist/DateTime/dateMonkeyPatch.js +149 -0
- package/dist/DateTime/dateMonkeyPatch.js.map +1 -0
- package/dist/DateTime/dateTimeFactory.d.ts +4 -0
- package/dist/DateTime/dateTimeFactory.js +22 -0
- package/dist/DateTime/dateTimeFactory.js.map +1 -0
- package/dist/DateTime/millisecondConstants.d.ts +7 -0
- package/dist/DateTime/millisecondConstants.js +11 -0
- package/dist/DateTime/millisecondConstants.js.map +1 -0
- package/dist/DateTime/posixTimezone.d.ts +1 -0
- package/dist/DateTime/posixTimezone.js +54 -0
- package/dist/DateTime/posixTimezone.js.map +1 -0
- package/dist/DateTime/statistics.d.ts +6 -0
- package/dist/DateTime/statistics.js +30 -0
- package/dist/DateTime/statistics.js.map +1 -0
- package/dist/DateTime/timeConverter.d.ts +1 -0
- package/dist/DateTime/timeConverter.js +11 -0
- package/dist/DateTime/timeConverter.js.map +1 -0
- package/dist/DateTime/timer.d.ts +10 -0
- package/dist/DateTime/timer.js +18 -0
- package/dist/DateTime/timer.js.map +1 -0
- package/dist/DateTime/timestamp.d.ts +2 -0
- package/dist/DateTime/timestamp.js +16 -0
- package/dist/DateTime/timestamp.js.map +1 -0
- package/dist/DateTime/waitUntil.d.ts +20 -0
- package/dist/DateTime/waitUntil.js +148 -0
- package/dist/DateTime/waitUntil.js.map +1 -0
- package/dist/Debug/debugClassDecorator.d.ts +13 -0
- package/dist/Debug/debugClassDecorator.js +63 -0
- package/dist/Debug/debugClassDecorator.js.map +1 -0
- package/dist/Debug/debugDecorator.d.ts +24 -0
- package/dist/Debug/debugDecorator.js +107 -0
- package/dist/Debug/debugDecorator.js.map +1 -0
- package/dist/Encryption/passwordEncryption.d.ts +4 -0
- package/dist/Encryption/passwordEncryption.js +29 -0
- package/dist/Encryption/passwordEncryption.js.map +1 -0
- package/dist/Encryption/tokenEncryption.d.ts +14 -0
- package/dist/Encryption/tokenEncryption.js +32 -0
- package/dist/Encryption/tokenEncryption.js.map +1 -0
- package/dist/Events/AsyncEventEmitter.d.ts +31 -0
- package/dist/Events/AsyncEventEmitter.js +125 -0
- package/dist/Events/AsyncEventEmitter.js.map +1 -0
- package/dist/Events/eventsHelpers.d.ts +3 -0
- package/dist/Events/eventsHelpers.js +24 -0
- package/dist/Events/eventsHelpers.js.map +1 -0
- package/dist/Events/genericGracefulExit.d.ts +11 -0
- package/dist/Events/genericGracefulExit.js +90 -0
- package/dist/Events/genericGracefulExit.js.map +1 -0
- package/dist/FileSystem/moduleDiscoverer.d.ts +7 -0
- package/dist/FileSystem/moduleDiscoverer.js +88 -0
- package/dist/FileSystem/moduleDiscoverer.js.map +1 -0
- package/dist/FileSystem/tmpDir.d.ts +9 -0
- package/dist/FileSystem/tmpDir.js +64 -0
- package/dist/FileSystem/tmpDir.js.map +1 -0
- package/dist/Functional/compose.d.ts +22 -0
- package/dist/Functional/compose.js +44 -0
- package/dist/Functional/compose.js.map +1 -0
- package/dist/GenericPool/options.d.ts +63 -0
- package/dist/GenericPool/options.js +3 -0
- package/dist/GenericPool/options.js.map +1 -0
- package/dist/Hash/checksum.d.ts +5 -0
- package/dist/Hash/checksum.js +20 -0
- package/dist/Hash/checksum.js.map +1 -0
- package/dist/Hash/checksumFile.d.ts +4 -0
- package/dist/Hash/checksumFile.js +82 -0
- package/dist/Hash/checksumFile.js.map +1 -0
- package/dist/Hash/generator.d.ts +2 -0
- package/dist/Hash/generator.js +15 -0
- package/dist/Hash/generator.js.map +1 -0
- package/dist/Http/download.d.ts +1 -0
- package/dist/Http/download.js +91 -0
- package/dist/Http/download.js.map +1 -0
- package/dist/HttpStatus/checks/amqpStatusCheck.d.ts +3 -0
- package/dist/HttpStatus/checks/amqpStatusCheck.js +98 -0
- package/dist/HttpStatus/checks/amqpStatusCheck.js.map +1 -0
- package/dist/HttpStatus/checks/mongoDBStatusCheck.d.ts +3 -0
- package/dist/HttpStatus/checks/mongoDBStatusCheck.js +60 -0
- package/dist/HttpStatus/checks/mongoDBStatusCheck.js.map +1 -0
- package/dist/HttpStatus/checks/redisStatusCheck.d.ts +3 -0
- package/dist/HttpStatus/checks/redisStatusCheck.js +94 -0
- package/dist/HttpStatus/checks/redisStatusCheck.js.map +1 -0
- package/dist/HttpStatus/createHttpStatusMiddleware.d.ts +9 -0
- package/dist/HttpStatus/createHttpStatusMiddleware.js +109 -0
- package/dist/HttpStatus/createHttpStatusMiddleware.js.map +1 -0
- package/dist/HttpStatus/enrichHttpServerWithStatus.d.ts +15 -0
- package/dist/HttpStatus/enrichHttpServerWithStatus.js +114 -0
- package/dist/HttpStatus/enrichHttpServerWithStatus.js.map +1 -0
- package/dist/HttpStatus/sendStatusResponse.d.ts +5 -0
- package/dist/HttpStatus/sendStatusResponse.js +71 -0
- package/dist/HttpStatus/sendStatusResponse.js.map +1 -0
- package/dist/HttpStatus/status.d.ts +19 -0
- package/dist/HttpStatus/status.js +132 -0
- package/dist/HttpStatus/status.js.map +1 -0
- package/dist/HttpStatus/statuses/amqpStatus.d.ts +3 -0
- package/dist/HttpStatus/statuses/amqpStatus.js +35 -0
- package/dist/HttpStatus/statuses/amqpStatus.js.map +1 -0
- package/dist/HttpStatus/statuses/mongoStatus.d.ts +3 -0
- package/dist/HttpStatus/statuses/mongoStatus.js +35 -0
- package/dist/HttpStatus/statuses/mongoStatus.js.map +1 -0
- package/dist/HttpStatus/statuses/redisStatus.d.ts +3 -0
- package/dist/HttpStatus/statuses/redisStatus.js +35 -0
- package/dist/HttpStatus/statuses/redisStatus.js.map +1 -0
- package/dist/InfluxDB/IInfluxDB.d.ts +5 -0
- package/dist/InfluxDB/IInfluxDB.js +3 -0
- package/dist/InfluxDB/IInfluxDB.js.map +1 -0
- package/dist/InfluxDB/influxDBConnectionFactory.d.ts +9 -0
- package/dist/InfluxDB/influxDBConnectionFactory.js +83 -0
- package/dist/InfluxDB/influxDBConnectionFactory.js.map +1 -0
- package/dist/JSON/jsonHelper.d.ts +4 -0
- package/dist/JSON/jsonHelper.js +21 -0
- package/dist/JSON/jsonHelper.js.map +1 -0
- package/dist/Lib/Redis/connection.utils.d.ts +22 -0
- package/dist/Lib/Redis/connection.utils.js +95 -0
- package/dist/Lib/Redis/connection.utils.js.map +1 -0
- package/dist/Lib/String/string.d.ts +1 -0
- package/dist/Lib/String/string.js +6 -0
- package/dist/Lib/String/string.js.map +1 -0
- package/dist/Lock/lockedDecorator.d.ts +12 -0
- package/dist/Lock/lockedDecorator.js +150 -0
- package/dist/Lock/lockedDecorator.js.map +1 -0
- package/dist/Logging/console.d.ts +8 -0
- package/dist/Logging/console.js +50 -0
- package/dist/Logging/console.js.map +1 -0
- package/dist/Logging/debug.d.ts +10 -0
- package/dist/Logging/debug.js +61 -0
- package/dist/Logging/debug.js.map +1 -0
- package/dist/Logging/format.d.ts +10 -0
- package/dist/Logging/format.js +79 -0
- package/dist/Logging/format.js.map +1 -0
- package/dist/Logging/logger.d.ts +53 -0
- package/dist/Logging/logger.js +63 -0
- package/dist/Logging/logger.js.map +1 -0
- package/dist/Logging/logging.d.ts +12 -0
- package/dist/Logging/logging.js +113 -0
- package/dist/Logging/logging.js.map +1 -0
- package/dist/Metrics/MetricsClient.d.ts +46 -0
- package/dist/Metrics/MetricsClient.js +101 -0
- package/dist/Metrics/MetricsClient.js.map +1 -0
- package/dist/Metrics/deviceConsumerMetrics.d.ts +6 -0
- package/dist/Metrics/deviceConsumerMetrics.js +59 -0
- package/dist/Metrics/deviceConsumerMetrics.js.map +1 -0
- package/dist/Metrics/eventConsumerMetrics.d.ts +19 -0
- package/dist/Metrics/eventConsumerMetrics.js +52 -0
- package/dist/Metrics/eventConsumerMetrics.js.map +1 -0
- package/dist/Metrics/eventQueueMetrics.d.ts +7 -0
- package/dist/Metrics/eventQueueMetrics.js +19 -0
- package/dist/Metrics/eventQueueMetrics.js.map +1 -0
- package/dist/Metrics/logMetrics.d.ts +4 -0
- package/dist/Metrics/logMetrics.js +20 -0
- package/dist/Metrics/logMetrics.js.map +1 -0
- package/dist/Metrics/metrics.d.ts +84 -0
- package/dist/Metrics/metrics.js +255 -0
- package/dist/Metrics/metrics.js.map +1 -0
- package/dist/Metrics/mongoDBMetrics.d.ts +35 -0
- package/dist/Metrics/mongoDBMetrics.js +162 -0
- package/dist/Metrics/mongoDBMetrics.js.map +1 -0
- package/dist/Metrics/processSocketsMetrics.d.ts +10 -0
- package/dist/Metrics/processSocketsMetrics.js +92 -0
- package/dist/Metrics/processSocketsMetrics.js.map +1 -0
- package/dist/Metrics/redisMetrics.d.ts +13 -0
- package/dist/Metrics/redisMetrics.js +60 -0
- package/dist/Metrics/redisMetrics.js.map +1 -0
- package/dist/MongoDB/MongoDBConnection.d.ts +19 -0
- package/dist/MongoDB/MongoDBConnection.js +185 -0
- package/dist/MongoDB/MongoDBConnection.js.map +1 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.d.ts +2 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.js +106 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/dynamicPriority.js.map +1 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.d.ts +2 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.js +94 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/lowReadLatency.js.map +1 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.d.ts +2 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.js +80 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/ordinary.js.map +1 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.d.ts +2 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.js +51 -0
- package/dist/MongoDB/ProprietaryCluster/SelectionStrategy/random.js.map +1 -0
- package/dist/MongoDB/ProprietaryCluster/helper.d.ts +13 -0
- package/dist/MongoDB/ProprietaryCluster/helper.js +147 -0
- package/dist/MongoDB/ProprietaryCluster/helper.js.map +1 -0
- package/dist/MongoDB/cursorIterator.d.ts +5 -0
- package/dist/MongoDB/cursorIterator.js +63 -0
- package/dist/MongoDB/cursorIterator.js.map +1 -0
- package/dist/MongoDB/escape.d.ts +4 -0
- package/dist/MongoDB/escape.js +54 -0
- package/dist/MongoDB/escape.js.map +1 -0
- package/dist/MongoDB/mongoDBConnectionFactory.d.ts +13 -0
- package/dist/MongoDB/mongoDBConnectionFactory.js +11 -0
- package/dist/MongoDB/mongoDBConnectionFactory.js.map +1 -0
- package/dist/MongoDB/proprietaryCluster.d.ts +1 -0
- package/dist/MongoDB/proprietaryCluster.js +76 -0
- package/dist/MongoDB/proprietaryCluster.js.map +1 -0
- package/dist/Npm/INpmClient.d.ts +25 -0
- package/dist/Npm/INpmClient.js +3 -0
- package/dist/Npm/INpmClient.js.map +1 -0
- package/dist/Npm/MockNpmClient.d.ts +17 -0
- package/dist/Npm/MockNpmClient.js +124 -0
- package/dist/Npm/MockNpmClient.js.map +1 -0
- package/dist/Npm/NpmClient.d.ts +14 -0
- package/dist/Npm/NpmClient.js +212 -0
- package/dist/Npm/NpmClient.js.map +1 -0
- package/dist/Npm/NpmCredentialsProvider.d.ts +18 -0
- package/dist/Npm/NpmCredentialsProvider.js +111 -0
- package/dist/Npm/NpmCredentialsProvider.js.map +1 -0
- package/dist/Observable/helpers.d.ts +3 -0
- package/dist/Observable/helpers.js +117 -0
- package/dist/Observable/helpers.js.map +1 -0
- package/dist/Parsers/parsers.d.ts +1 -0
- package/dist/Parsers/parsers.js +17 -0
- package/dist/Parsers/parsers.js.map +1 -0
- package/dist/Path/detector.d.ts +9 -0
- package/dist/Path/detector.js +78 -0
- package/dist/Path/detector.js.map +1 -0
- package/dist/Pool/IBasePool.d.ts +6 -0
- package/dist/Pool/IBasePool.js +3 -0
- package/dist/Pool/IBasePool.js.map +1 -0
- package/dist/Promise/cancelable.d.ts +4 -0
- package/dist/Promise/cancelable.js +21 -0
- package/dist/Promise/cancelable.js.map +1 -0
- package/dist/Promise/deferred.d.ts +4 -0
- package/dist/Promise/deferred.js +21 -0
- package/dist/Promise/deferred.js.map +1 -0
- package/dist/Promise/deferredStream.d.ts +4 -0
- package/dist/Promise/deferredStream.js +21 -0
- package/dist/Promise/deferredStream.js.map +1 -0
- package/dist/Promise/lock.d.ts +4 -0
- package/dist/Promise/lock.js +21 -0
- package/dist/Promise/lock.js.map +1 -0
- package/dist/Promise/timeoutable.d.ts +4 -0
- package/dist/Promise/timeoutable.js +21 -0
- package/dist/Promise/timeoutable.js.map +1 -0
- package/dist/Redis/DeviceActions/PostponedAction.d.ts +4 -0
- package/dist/Redis/DeviceActions/PostponedAction.js +3 -0
- package/dist/Redis/DeviceActions/PostponedAction.js.map +1 -0
- package/dist/Redis/DeviceActions/postponedDeviceActions.d.ts +8 -0
- package/dist/Redis/DeviceActions/postponedDeviceActions.js +333 -0
- package/dist/Redis/DeviceActions/postponedDeviceActions.js.map +1 -0
- package/dist/Redis/redisConnectionFactory.d.ts +41 -0
- package/dist/Redis/redisConnectionFactory.js +158 -0
- package/dist/Redis/redisConnectionFactory.js.map +1 -0
- package/dist/Redis/redisLock.d.ts +11 -0
- package/dist/Redis/redisLock.js +213 -0
- package/dist/Redis/redisLock.js.map +1 -0
- package/dist/Retry/retry.d.ts +28 -0
- package/dist/Retry/retry.js +154 -0
- package/dist/Retry/retry.js.map +1 -0
- package/dist/Rsync/copier.d.ts +1 -0
- package/dist/Rsync/copier.js +123 -0
- package/dist/Rsync/copier.js.map +1 -0
- package/dist/SemVer/SemVerLevel.d.ts +6 -0
- package/dist/SemVer/SemVerLevel.js +10 -0
- package/dist/SemVer/SemVerLevel.js.map +1 -0
- package/dist/SemVer/semVerConstants.d.ts +2 -0
- package/dist/SemVer/semVerConstants.js +9 -0
- package/dist/SemVer/semVerConstants.js.map +1 -0
- package/dist/SemVer/semVerHelper.d.ts +7 -0
- package/dist/SemVer/semVerHelper.js +82 -0
- package/dist/SemVer/semVerHelper.js.map +1 -0
- package/dist/Service/HTTP/express/app.d.ts +33 -0
- package/dist/Service/HTTP/express/app.js +82 -0
- package/dist/Service/HTTP/express/app.js.map +1 -0
- package/dist/Service/HTTP/express/expressFactory.d.ts +4 -0
- package/dist/Service/HTTP/express/expressFactory.js +22 -0
- package/dist/Service/HTTP/express/expressFactory.js.map +1 -0
- package/dist/Service/HTTP/express/monitoring.d.ts +8 -0
- package/dist/Service/HTTP/express/monitoring.js +25 -0
- package/dist/Service/HTTP/express/monitoring.js.map +1 -0
- package/dist/Service/HTTP/httpServerFactory.d.ts +54 -0
- package/dist/Service/HTTP/httpServerFactory.js +104 -0
- package/dist/Service/HTTP/httpServerFactory.js.map +1 -0
- package/dist/Service/HTTP/middleware/accessLogMiddleware.d.ts +20 -0
- package/dist/Service/HTTP/middleware/accessLogMiddleware.js +90 -0
- package/dist/Service/HTTP/middleware/accessLogMiddleware.js.map +1 -0
- package/dist/Service/HTTP/middleware/headersMiddleware.d.ts +2 -0
- package/dist/Service/HTTP/middleware/headersMiddleware.js +18 -0
- package/dist/Service/HTTP/middleware/headersMiddleware.js.map +1 -0
- package/dist/Service/HTTP/routes/app/indexPage.d.ts +7 -0
- package/dist/Service/HTTP/routes/app/indexPage.js +12 -0
- package/dist/Service/HTTP/routes/app/indexPage.js.map +1 -0
- package/dist/Service/HTTP/routes/app/router.d.ts +14 -0
- package/dist/Service/HTTP/routes/app/router.js +12 -0
- package/dist/Service/HTTP/routes/app/router.js.map +1 -0
- package/dist/Service/HTTP/routes/app/status.d.ts +13 -0
- package/dist/Service/HTTP/routes/app/status.js +44 -0
- package/dist/Service/HTTP/routes/app/status.js.map +1 -0
- package/dist/Service/HTTP/routes/monitoring/aliveness.d.ts +20 -0
- package/dist/Service/HTTP/routes/monitoring/aliveness.js +75 -0
- package/dist/Service/HTTP/routes/monitoring/aliveness.js.map +1 -0
- package/dist/Service/HTTP/routes/monitoring/metrics.d.ts +9 -0
- package/dist/Service/HTTP/routes/monitoring/metrics.js +59 -0
- package/dist/Service/HTTP/routes/monitoring/metrics.js.map +1 -0
- package/dist/Service/HTTP/routes/monitoring/readniness.d.ts +18 -0
- package/dist/Service/HTTP/routes/monitoring/readniness.js +80 -0
- package/dist/Service/HTTP/routes/monitoring/readniness.js.map +1 -0
- package/dist/Service/HTTP/routes/monitoring/router.d.ts +10 -0
- package/dist/Service/HTTP/routes/monitoring/router.js +12 -0
- package/dist/Service/HTTP/routes/monitoring/router.js.map +1 -0
- package/dist/Service/HTTP/server/serverFactory.d.ts +10 -0
- package/dist/Service/HTTP/server/serverFactory.js +133 -0
- package/dist/Service/HTTP/server/serverFactory.js.map +1 -0
- package/dist/Service/Service.d.ts +17 -0
- package/dist/Service/Service.js +97 -0
- package/dist/Service/Service.js.map +1 -0
- package/dist/Service/dbConnections.d.ts +8 -0
- package/dist/Service/dbConnections.js +3 -0
- package/dist/Service/dbConnections.js.map +1 -0
- package/dist/Service/metrics/connections.d.ts +3 -0
- package/dist/Service/metrics/connections.js +47 -0
- package/dist/Service/metrics/connections.js.map +1 -0
- package/dist/Service/metrics/mongodb.d.ts +2 -0
- package/dist/Service/metrics/mongodb.js +13 -0
- package/dist/Service/metrics/mongodb.js.map +1 -0
- package/dist/Service/metrics/redis.d.ts +2 -0
- package/dist/Service/metrics/redis.js +11 -0
- package/dist/Service/metrics/redis.js.map +1 -0
- package/dist/Service/process.d.ts +11 -0
- package/dist/Service/process.js +88 -0
- package/dist/Service/process.js.map +1 -0
- package/dist/Service/serviceFactory.d.ts +115 -0
- package/dist/Service/serviceFactory.js +118 -0
- package/dist/Service/serviceFactory.js.map +1 -0
- package/dist/Service/types.d.ts +55 -0
- package/dist/Service/types.js +3 -0
- package/dist/Service/types.js.map +1 -0
- package/dist/Storage/IArrayStorage.d.ts +7 -0
- package/dist/Storage/IArrayStorage.js +3 -0
- package/dist/Storage/IArrayStorage.js.map +1 -0
- package/dist/Storage/MemoryArrayStorage.d.ts +9 -0
- package/dist/Storage/MemoryArrayStorage.js +22 -0
- package/dist/Storage/MemoryArrayStorage.js.map +1 -0
- package/dist/String/pad.d.ts +1 -0
- package/dist/String/pad.js +7 -0
- package/dist/String/pad.js.map +1 -0
- package/dist/String/string.d.ts +3 -0
- package/dist/String/string.js +17 -0
- package/dist/String/string.js.map +1 -0
- package/dist/String/webalize.d.ts +1 -0
- package/dist/String/webalize.js +15 -0
- package/dist/String/webalize.js.map +1 -0
- package/dist/String/word.d.ts +32 -0
- package/dist/String/word.js +97 -0
- package/dist/String/word.js.map +1 -0
- package/dist/System/signalSender.d.ts +1 -0
- package/dist/System/signalSender.js +7 -0
- package/dist/System/signalSender.js.map +1 -0
- package/dist/ThirdParty/connection.d.ts +28 -0
- package/dist/ThirdParty/connection.js +9 -0
- package/dist/ThirdParty/connection.js.map +1 -0
- package/dist/Timer/Power/PowerTimerSettings.d.ts +29 -0
- package/dist/Timer/Power/PowerTimerSettings.js +3 -0
- package/dist/Timer/Power/PowerTimerSettings.js.map +1 -0
- package/dist/Timer/Power/PowerTimerType.d.ts +2 -0
- package/dist/Timer/Power/PowerTimerType.js +3 -0
- package/dist/Timer/Power/PowerTimerType.js.map +1 -0
- package/dist/Timer/Power/PowerTimerWeekday.d.ts +18 -0
- package/dist/Timer/Power/PowerTimerWeekday.js +18 -0
- package/dist/Timer/Power/PowerTimerWeekday.js.map +1 -0
- package/dist/Timer/Power/PowerTimerWeekdayEnum.d.ts +28 -0
- package/dist/Timer/Power/PowerTimerWeekdayEnum.js +32 -0
- package/dist/Timer/Power/PowerTimerWeekdayEnum.js.map +1 -0
- package/dist/Timer/Power/TimerEventWeekdayNumber.d.ts +9 -0
- package/dist/Timer/Power/TimerEventWeekdayNumber.js +14 -0
- package/dist/Timer/Power/TimerEventWeekdayNumber.js.map +1 -0
- package/dist/Timer/Power/powerTimerComputer.d.ts +36 -0
- package/dist/Timer/Power/powerTimerComputer.js +141 -0
- package/dist/Timer/Power/powerTimerComputer.js.map +1 -0
- package/dist/Timer/convertWeekday.d.ts +25 -0
- package/dist/Timer/convertWeekday.js +211 -0
- package/dist/Timer/convertWeekday.js.map +1 -0
- package/dist/Timer/converters.d.ts +44 -0
- package/dist/Timer/converters.js +72 -0
- package/dist/Timer/converters.js.map +1 -0
- package/dist/Timer/increasingInterval.d.ts +2 -0
- package/dist/Timer/increasingInterval.js +108 -0
- package/dist/Timer/increasingInterval.js.map +1 -0
- package/dist/Timer/nonConcurrentInterval.d.ts +4 -0
- package/dist/Timer/nonConcurrentInterval.js +73 -0
- package/dist/Timer/nonConcurrentInterval.js.map +1 -0
- package/dist/Timer/progressiveWait.d.ts +40 -0
- package/dist/Timer/progressiveWait.js +96 -0
- package/dist/Timer/progressiveWait.js.map +1 -0
- package/dist/Timer/timeout.d.ts +4 -0
- package/dist/Timer/timeout.js +21 -0
- package/dist/Timer/timeout.js.map +1 -0
- package/dist/Timer/wait.d.ts +5 -0
- package/dist/Timer/wait.js +27 -0
- package/dist/Timer/wait.js.map +1 -0
- package/dist/TypeScript/asyncIterator.d.ts +1 -0
- package/dist/TypeScript/asyncIterator.js +76 -0
- package/dist/TypeScript/asyncIterator.js.map +1 -0
- package/dist/TypeScript/expect.d.ts +6 -0
- package/dist/TypeScript/expect.js +12 -0
- package/dist/TypeScript/expect.js.map +1 -0
- package/dist/TypeScript/generator.d.ts +1 -0
- package/dist/TypeScript/generator.js +20 -0
- package/dist/TypeScript/generator.js.map +1 -0
- package/dist/TypeScript/object.d.ts +12 -0
- package/dist/TypeScript/object.js +3 -0
- package/dist/TypeScript/object.js.map +1 -0
- package/dist/TypeScript/observable-polyfill.d.ts +1 -0
- package/dist/TypeScript/observable-polyfill.js +33 -0
- package/dist/TypeScript/observable-polyfill.js.map +1 -0
- package/dist/Utils/array.d.ts +2 -0
- package/dist/Utils/array.js +23 -0
- package/dist/Utils/array.js.map +1 -0
- package/dist/Utils/enum.d.ts +24 -0
- package/dist/Utils/enum.js +35 -0
- package/dist/Utils/enum.js.map +1 -0
- package/dist/Utils/file.d.ts +1 -0
- package/dist/Utils/file.js +55 -0
- package/dist/Utils/file.js.map +1 -0
- package/dist/Utils/http.d.ts +23 -0
- package/dist/Utils/http.js +68 -0
- package/dist/Utils/http.js.map +1 -0
- package/dist/Utils/object.d.ts +22 -0
- package/dist/Utils/object.js +112 -0
- package/dist/Utils/object.js.map +1 -0
- package/dist/Utils/sorting.d.ts +1 -0
- package/dist/Utils/sorting.js +33 -0
- package/dist/Utils/sorting.js.map +1 -0
- package/dist/WebSocket/Client/ISocket.d.ts +55 -0
- package/dist/WebSocket/Client/ISocket.js +46 -0
- package/dist/WebSocket/Client/ISocket.js.map +1 -0
- package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.d.ts +8 -0
- package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.js +81 -0
- package/dist/WebSocket/Client/SocketIO/createSocketIOSocket.js.map +1 -0
- package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.d.ts +25 -0
- package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.js +174 -0
- package/dist/WebSocket/Client/WS/AutoReconnectingWSSocket.js.map +1 -0
- package/dist/WebSocket/Client/WS/createWSSocket.d.ts +8 -0
- package/dist/WebSocket/Client/WS/createWSSocket.js +155 -0
- package/dist/WebSocket/Client/WS/createWSSocket.js.map +1 -0
- package/dist/WebSocket/autoWsServerFactory.d.ts +4 -0
- package/dist/WebSocket/autoWsServerFactory.js +334 -0
- package/dist/WebSocket/autoWsServerFactory.js.map +1 -0
- package/dist/WebSocket/perMessageDeflate.d.ts +14 -0
- package/dist/WebSocket/perMessageDeflate.js +3 -0
- package/dist/WebSocket/perMessageDeflate.js.map +1 -0
- package/dist/WebSocket/socketIOServerFactory.d.ts +6 -0
- package/dist/WebSocket/socketIOServerFactory.js +124 -0
- package/dist/WebSocket/socketIOServerFactory.js.map +1 -0
- package/dist/WebSocket/socketServer.d.ts +30 -0
- package/dist/WebSocket/socketServer.js +3 -0
- package/dist/WebSocket/socketServer.js.map +1 -0
- package/dist/WebSocket/wsServerFactory.d.ts +8 -0
- package/dist/WebSocket/wsServerFactory.js +272 -0
- package/dist/WebSocket/wsServerFactory.js.map +1 -0
- package/dist/Webpack/NpmPackPlugin.d.ts +14 -0
- package/dist/Webpack/NpmPackPlugin.js +90 -0
- package/dist/Webpack/NpmPackPlugin.js.map +1 -0
- package/dist/Zod/zod.d.ts +2 -0
- package/dist/Zod/zod.js +7 -0
- package/dist/Zod/zod.js.map +1 -0
- package/dist/Zod/zodError.d.ts +40 -0
- package/dist/Zod/zodError.js +76 -0
- package/dist/Zod/zodError.js.map +1 -0
- 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"}
|