@zintrust/core 0.1.49 → 0.1.50
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/package.json +1 -9
- package/src/config/index.d.ts +1 -1
- package/src/config/index.d.ts.map +1 -1
- package/src/config/index.js +30 -10
- package/src/index.d.ts +0 -2
- package/src/index.d.ts.map +1 -1
- package/src/index.js +3 -5
- package/src/proxy/d1/ZintrustD1Proxy.d.ts +2 -2
- package/src/proxy/d1/ZintrustD1Proxy.d.ts.map +1 -1
- package/src/proxy/d1/ZintrustD1Proxy.js +39 -2
- package/src/proxy/kv/ZintrustKvProxy.d.ts +2 -2
- package/src/proxy/kv/ZintrustKvProxy.d.ts.map +1 -1
- package/src/proxy/kv/ZintrustKvProxy.js +38 -2
- package/src/security/JwtManager.js +1 -1
- package/src/zintrust.comon.d.ts +9 -0
- package/src/zintrust.comon.d.ts.map +1 -0
- package/src/zintrust.comon.js +15 -0
- package/src/zintrust.plugins.d.ts +9 -3
- package/src/zintrust.plugins.d.ts.map +1 -1
- package/src/zintrust.plugins.js +10 -3
- package/src/zintrust.plugins.wg.d.ts +1 -0
- package/src/zintrust.plugins.wg.d.ts.map +1 -1
- package/src/zintrust.plugins.wg.js +1 -0
- package/app/Controllers/AuthController.d.ts +0 -10
- package/app/Controllers/AuthController.d.ts.map +0 -1
- package/app/Controllers/AuthController.js +0 -223
- package/app/Controllers/UserController.d.ts +0 -9
- package/app/Controllers/UserController.d.ts.map +0 -1
- package/app/Controllers/UserController.js +0 -8
- package/app/Controllers/UserQueryBuilderController.d.ts +0 -16
- package/app/Controllers/UserQueryBuilderController.d.ts.map +0 -1
- package/app/Controllers/UserQueryBuilderController.js +0 -404
- package/app/Middleware/ProfilerMiddleware.d.ts +0 -12
- package/app/Middleware/ProfilerMiddleware.d.ts.map +0 -1
- package/app/Middleware/ProfilerMiddleware.js +0 -47
- package/app/Middleware/index.d.ts +0 -59
- package/app/Middleware/index.d.ts.map +0 -1
- package/app/Middleware/index.js +0 -215
- package/app/Models/Post.d.ts +0 -14
- package/app/Models/Post.d.ts.map +0 -1
- package/app/Models/Post.js +0 -27
- package/app/Models/User.d.ts +0 -14
- package/app/Models/User.d.ts.map +0 -1
- package/app/Models/User.js +0 -44
- package/app/Schedules/JobTracking.d.ts +0 -3
- package/app/Schedules/JobTracking.d.ts.map +0 -1
- package/app/Schedules/JobTracking.js +0 -13
- package/app/Schedules/index.d.ts +0 -2
- package/app/Schedules/index.d.ts.map +0 -1
- package/app/Schedules/index.js +0 -1
- package/app/Toolkit/Broadcast/sendBroadcast.d.ts +0 -6
- package/app/Toolkit/Broadcast/sendBroadcast.d.ts.map +0 -1
- package/app/Toolkit/Broadcast/sendBroadcast.js +0 -5
- package/app/Toolkit/Mail/sendWelcomeEmail.d.ts +0 -6
- package/app/Toolkit/Mail/sendWelcomeEmail.d.ts.map +0 -1
- package/app/Toolkit/Mail/sendWelcomeEmail.js +0 -20
- package/app/Toolkit/Notification/sendSlackNotification.d.ts +0 -8
- package/app/Toolkit/Notification/sendSlackNotification.d.ts.map +0 -1
- package/app/Toolkit/Notification/sendSlackNotification.js +0 -5
- package/app/Toolkit/Notification/sendSms.d.ts +0 -6
- package/app/Toolkit/Notification/sendSms.d.ts.map +0 -1
- package/app/Toolkit/Notification/sendSms.js +0 -5
- package/app/Types/controller.d.ts +0 -44
- package/app/Types/controller.d.ts.map +0 -1
- package/app/Types/controller.js +0 -1
- package/config/broadcast.d.ts +0 -38
- package/config/broadcast.d.ts.map +0 -1
- package/config/broadcast.js +0 -37
- package/config/cache.d.ts +0 -40
- package/config/cache.d.ts.map +0 -1
- package/config/cache.js +0 -39
- package/config/database.d.ts +0 -58
- package/config/database.d.ts.map +0 -1
- package/config/database.js +0 -65
- package/config/mail.d.ts +0 -51
- package/config/mail.d.ts.map +0 -1
- package/config/mail.js +0 -69
- package/config/middleware.d.ts +0 -11
- package/config/middleware.d.ts.map +0 -1
- package/config/middleware.js +0 -30
- package/config/notification.d.ts +0 -33
- package/config/notification.d.ts.map +0 -1
- package/config/notification.js +0 -33
- package/config/queue.d.ts +0 -55
- package/config/queue.d.ts.map +0 -1
- package/config/queue.js +0 -87
- package/config/storage.d.ts +0 -59
- package/config/storage.d.ts.map +0 -1
- package/config/storage.js +0 -59
- package/config/workers.d.ts +0 -54
- package/config/workers.d.ts.map +0 -1
- package/config/workers.js +0 -83
- package/packages/cloudflare-d1-proxy/src/index.d.ts +0 -48
- package/packages/cloudflare-d1-proxy/src/index.d.ts.map +0 -1
- package/packages/cloudflare-d1-proxy/src/index.js +0 -387
- package/packages/cloudflare-kv-proxy/src/index.d.ts +0 -44
- package/packages/cloudflare-kv-proxy/src/index.d.ts.map +0 -1
- package/packages/cloudflare-kv-proxy/src/index.js +0 -325
- package/packages/queue-monitor/src/QueueMonitoringService.d.ts +0 -35
- package/packages/queue-monitor/src/QueueMonitoringService.d.ts.map +0 -1
- package/packages/queue-monitor/src/QueueMonitoringService.js +0 -194
- package/packages/queue-monitor/src/connection.d.ts +0 -3
- package/packages/queue-monitor/src/connection.d.ts.map +0 -1
- package/packages/queue-monitor/src/connection.js +0 -1
- package/packages/queue-monitor/src/dashboard-ui.d.ts +0 -7
- package/packages/queue-monitor/src/dashboard-ui.d.ts.map +0 -1
- package/packages/queue-monitor/src/dashboard-ui.js +0 -997
- package/packages/queue-monitor/src/driver.d.ts +0 -15
- package/packages/queue-monitor/src/driver.d.ts.map +0 -1
- package/packages/queue-monitor/src/driver.js +0 -115
- package/packages/queue-monitor/src/index.d.ts +0 -71
- package/packages/queue-monitor/src/index.d.ts.map +0 -1
- package/packages/queue-monitor/src/index.js +0 -296
- package/packages/queue-monitor/src/metrics.d.ts +0 -27
- package/packages/queue-monitor/src/metrics.d.ts.map +0 -1
- package/packages/queue-monitor/src/metrics.js +0 -92
- package/packages/queue-monitor/src/worker.d.ts +0 -8
- package/packages/queue-monitor/src/worker.d.ts.map +0 -1
- package/packages/queue-monitor/src/worker.js +0 -35
- package/packages/queue-redis/src/BullMQRedisQueue.d.ts +0 -26
- package/packages/queue-redis/src/BullMQRedisQueue.d.ts.map +0 -1
- package/packages/queue-redis/src/BullMQRedisQueue.js +0 -463
- package/packages/queue-redis/src/HttpQueueDriver.d.ts +0 -18
- package/packages/queue-redis/src/HttpQueueDriver.d.ts.map +0 -1
- package/packages/queue-redis/src/HttpQueueDriver.js +0 -249
- package/packages/queue-redis/src/QueueHttpGateway.d.ts +0 -16
- package/packages/queue-redis/src/QueueHttpGateway.d.ts.map +0 -1
- package/packages/queue-redis/src/QueueHttpGateway.js +0 -217
- package/packages/queue-redis/src/RedisPublishClient.d.ts +0 -14
- package/packages/queue-redis/src/RedisPublishClient.d.ts.map +0 -1
- package/packages/queue-redis/src/RedisPublishClient.js +0 -251
- package/packages/queue-redis/src/index.d.ts +0 -12
- package/packages/queue-redis/src/index.d.ts.map +0 -1
- package/packages/queue-redis/src/index.js +0 -10
- package/packages/queue-redis/src/register.d.ts +0 -6
- package/packages/queue-redis/src/register.d.ts.map +0 -1
- package/packages/queue-redis/src/register.js +0 -21
- package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts +0 -11
- package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts.map +0 -1
- package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.js +0 -32
- package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts +0 -11
- package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts.map +0 -1
- package/packages/workers/migrations/20260123180000_create_queue_jobs_table.js +0 -46
- package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts +0 -7
- package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts.map +0 -1
- package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.js +0 -44
- package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts +0 -7
- package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts.map +0 -1
- package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.js +0 -104
- package/packages/workers/src/AnomalyDetection.d.ts +0 -107
- package/packages/workers/src/AnomalyDetection.d.ts.map +0 -1
- package/packages/workers/src/AnomalyDetection.js +0 -329
- package/packages/workers/src/AutoScaler.d.ts +0 -128
- package/packages/workers/src/AutoScaler.d.ts.map +0 -1
- package/packages/workers/src/AutoScaler.js +0 -425
- package/packages/workers/src/BroadcastWorker.d.ts +0 -24
- package/packages/workers/src/BroadcastWorker.d.ts.map +0 -1
- package/packages/workers/src/BroadcastWorker.js +0 -24
- package/packages/workers/src/CanaryController.d.ts +0 -104
- package/packages/workers/src/CanaryController.d.ts.map +0 -1
- package/packages/workers/src/CanaryController.js +0 -424
- package/packages/workers/src/ChaosEngineering.d.ts +0 -80
- package/packages/workers/src/ChaosEngineering.d.ts.map +0 -1
- package/packages/workers/src/ChaosEngineering.js +0 -229
- package/packages/workers/src/CircuitBreaker.d.ts +0 -107
- package/packages/workers/src/CircuitBreaker.d.ts.map +0 -1
- package/packages/workers/src/CircuitBreaker.js +0 -374
- package/packages/workers/src/ClusterLock.d.ts +0 -91
- package/packages/workers/src/ClusterLock.d.ts.map +0 -1
- package/packages/workers/src/ClusterLock.js +0 -397
- package/packages/workers/src/ComplianceManager.d.ts +0 -178
- package/packages/workers/src/ComplianceManager.d.ts.map +0 -1
- package/packages/workers/src/ComplianceManager.js +0 -556
- package/packages/workers/src/DatacenterOrchestrator.d.ts +0 -134
- package/packages/workers/src/DatacenterOrchestrator.d.ts.map +0 -1
- package/packages/workers/src/DatacenterOrchestrator.js +0 -404
- package/packages/workers/src/DeadLetterQueue.d.ts +0 -123
- package/packages/workers/src/DeadLetterQueue.d.ts.map +0 -1
- package/packages/workers/src/DeadLetterQueue.js +0 -544
- package/packages/workers/src/HealthMonitor.d.ts +0 -43
- package/packages/workers/src/HealthMonitor.d.ts.map +0 -1
- package/packages/workers/src/HealthMonitor.js +0 -312
- package/packages/workers/src/MultiQueueWorker.d.ts +0 -90
- package/packages/workers/src/MultiQueueWorker.d.ts.map +0 -1
- package/packages/workers/src/MultiQueueWorker.js +0 -282
- package/packages/workers/src/NotificationWorker.d.ts +0 -24
- package/packages/workers/src/NotificationWorker.d.ts.map +0 -1
- package/packages/workers/src/NotificationWorker.js +0 -23
- package/packages/workers/src/Observability.d.ts +0 -154
- package/packages/workers/src/Observability.d.ts.map +0 -1
- package/packages/workers/src/Observability.js +0 -538
- package/packages/workers/src/PluginManager.d.ts +0 -124
- package/packages/workers/src/PluginManager.d.ts.map +0 -1
- package/packages/workers/src/PluginManager.js +0 -392
- package/packages/workers/src/PriorityQueue.d.ts +0 -118
- package/packages/workers/src/PriorityQueue.d.ts.map +0 -1
- package/packages/workers/src/PriorityQueue.js +0 -276
- package/packages/workers/src/ResourceMonitor.d.ts +0 -165
- package/packages/workers/src/ResourceMonitor.d.ts.map +0 -1
- package/packages/workers/src/ResourceMonitor.js +0 -632
- package/packages/workers/src/SLAMonitor.d.ts +0 -111
- package/packages/workers/src/SLAMonitor.d.ts.map +0 -1
- package/packages/workers/src/SLAMonitor.js +0 -274
- package/packages/workers/src/WorkerFactory.d.ts +0 -218
- package/packages/workers/src/WorkerFactory.d.ts.map +0 -1
- package/packages/workers/src/WorkerFactory.js +0 -2253
- package/packages/workers/src/WorkerInit.d.ts +0 -86
- package/packages/workers/src/WorkerInit.d.ts.map +0 -1
- package/packages/workers/src/WorkerInit.js +0 -307
- package/packages/workers/src/WorkerMetrics.d.ts +0 -116
- package/packages/workers/src/WorkerMetrics.d.ts.map +0 -1
- package/packages/workers/src/WorkerMetrics.js +0 -570
- package/packages/workers/src/WorkerRegistry.d.ts +0 -152
- package/packages/workers/src/WorkerRegistry.d.ts.map +0 -1
- package/packages/workers/src/WorkerRegistry.js +0 -396
- package/packages/workers/src/WorkerShutdown.d.ts +0 -70
- package/packages/workers/src/WorkerShutdown.d.ts.map +0 -1
- package/packages/workers/src/WorkerShutdown.js +0 -185
- package/packages/workers/src/WorkerVersioning.d.ts +0 -108
- package/packages/workers/src/WorkerVersioning.d.ts.map +0 -1
- package/packages/workers/src/WorkerVersioning.js +0 -300
- package/packages/workers/src/config/workerConfig.d.ts +0 -5
- package/packages/workers/src/config/workerConfig.d.ts.map +0 -1
- package/packages/workers/src/config/workerConfig.js +0 -25
- package/packages/workers/src/createQueueWorker.d.ts +0 -26
- package/packages/workers/src/createQueueWorker.d.ts.map +0 -1
- package/packages/workers/src/createQueueWorker.js +0 -367
- package/packages/workers/src/dashboard/index.d.ts +0 -2
- package/packages/workers/src/dashboard/index.d.ts.map +0 -1
- package/packages/workers/src/dashboard/index.js +0 -1
- package/packages/workers/src/dashboard/types.d.ts +0 -123
- package/packages/workers/src/dashboard/types.d.ts.map +0 -1
- package/packages/workers/src/dashboard/types.js +0 -1
- package/packages/workers/src/dashboard/workers-api.d.ts +0 -5
- package/packages/workers/src/dashboard/workers-api.d.ts.map +0 -1
- package/packages/workers/src/dashboard/workers-api.js +0 -738
- package/packages/workers/src/helper/index.d.ts +0 -6
- package/packages/workers/src/helper/index.d.ts.map +0 -1
- package/packages/workers/src/helper/index.js +0 -10
- package/packages/workers/src/http/WorkerApiController.d.ts +0 -39
- package/packages/workers/src/http/WorkerApiController.d.ts.map +0 -1
- package/packages/workers/src/http/WorkerApiController.js +0 -313
- package/packages/workers/src/http/WorkerController.d.ts +0 -375
- package/packages/workers/src/http/WorkerController.d.ts.map +0 -1
- package/packages/workers/src/http/WorkerController.js +0 -1454
- package/packages/workers/src/http/WorkerMonitoringService.d.ts +0 -12
- package/packages/workers/src/http/WorkerMonitoringService.d.ts.map +0 -1
- package/packages/workers/src/http/WorkerMonitoringService.js +0 -89
- package/packages/workers/src/http/middleware/CustomValidation.d.ts +0 -93
- package/packages/workers/src/http/middleware/CustomValidation.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/CustomValidation.js +0 -270
- package/packages/workers/src/http/middleware/DatacenterValidator.d.ts +0 -4
- package/packages/workers/src/http/middleware/DatacenterValidator.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/DatacenterValidator.js +0 -94
- package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts +0 -8
- package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/EditWorkerValidation.js +0 -56
- package/packages/workers/src/http/middleware/FeaturesValidator.d.ts +0 -4
- package/packages/workers/src/http/middleware/FeaturesValidator.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/FeaturesValidator.js +0 -61
- package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts +0 -32
- package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/InfrastructureValidator.js +0 -226
- package/packages/workers/src/http/middleware/OptionsValidator.d.ts +0 -4
- package/packages/workers/src/http/middleware/OptionsValidator.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/OptionsValidator.js +0 -112
- package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts +0 -8
- package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/PayloadSanitizer.js +0 -42
- package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts +0 -4
- package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/ProcessorPathSanitizer.js +0 -140
- package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts +0 -4
- package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/QueueNameSanitizer.js +0 -45
- package/packages/workers/src/http/middleware/ValidateDriver.d.ts +0 -8
- package/packages/workers/src/http/middleware/ValidateDriver.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/ValidateDriver.js +0 -20
- package/packages/workers/src/http/middleware/VersionSanitizer.d.ts +0 -4
- package/packages/workers/src/http/middleware/VersionSanitizer.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/VersionSanitizer.js +0 -25
- package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts +0 -4
- package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/WorkerNameSanitizer.js +0 -46
- package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts +0 -28
- package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts.map +0 -1
- package/packages/workers/src/http/middleware/WorkerValidationChain.js +0 -186
- package/packages/workers/src/index.d.ts +0 -47
- package/packages/workers/src/index.d.ts.map +0 -1
- package/packages/workers/src/index.js +0 -48
- package/packages/workers/src/routes/workers.d.ts +0 -13
- package/packages/workers/src/routes/workers.d.ts.map +0 -1
- package/packages/workers/src/routes/workers.js +0 -126
- package/packages/workers/src/storage/WorkerStore.d.ts +0 -52
- package/packages/workers/src/storage/WorkerStore.d.ts.map +0 -1
- package/packages/workers/src/storage/WorkerStore.js +0 -259
- package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts +0 -47
- package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts.map +0 -1
- package/packages/workers/src/telemetry/api/TelemetryAPI.js +0 -219
- package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts +0 -18
- package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts.map +0 -1
- package/packages/workers/src/telemetry/api/TelemetryMonitoringService.js +0 -140
- package/packages/workers/src/telemetry/components/AlertPanel.d.ts +0 -2
- package/packages/workers/src/telemetry/components/AlertPanel.d.ts.map +0 -1
- package/packages/workers/src/telemetry/components/AlertPanel.js +0 -13
- package/packages/workers/src/telemetry/components/CostTracking.d.ts +0 -2
- package/packages/workers/src/telemetry/components/CostTracking.d.ts.map +0 -1
- package/packages/workers/src/telemetry/components/CostTracking.js +0 -14
- package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts +0 -2
- package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts.map +0 -1
- package/packages/workers/src/telemetry/components/ResourceUsageChart.js +0 -11
- package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts +0 -2
- package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts.map +0 -1
- package/packages/workers/src/telemetry/components/WorkerHealthChart.js +0 -11
- package/packages/workers/src/telemetry/index.d.ts +0 -16
- package/packages/workers/src/telemetry/index.d.ts.map +0 -1
- package/packages/workers/src/telemetry/index.js +0 -60
- package/packages/workers/src/telemetry/routes/dashboard.d.ts +0 -7
- package/packages/workers/src/telemetry/routes/dashboard.d.ts.map +0 -1
- package/packages/workers/src/telemetry/routes/dashboard.js +0 -608
- package/packages/workers/src/type.d.ts +0 -77
- package/packages/workers/src/type.d.ts.map +0 -1
- package/packages/workers/src/type.js +0 -1
- package/packages/workers/src/ui/router/EmbeddedAssets.d.ts +0 -5
- package/packages/workers/src/ui/router/EmbeddedAssets.d.ts.map +0 -1
- package/packages/workers/src/ui/router/EmbeddedAssets.js +0 -13
- package/packages/workers/src/ui/router/ui.d.ts +0 -4
- package/packages/workers/src/ui/router/ui.d.ts.map +0 -1
- package/packages/workers/src/ui/router/ui.js +0 -208
- package/packages/workers/src/ui/types/worker-ui.d.ts +0 -230
- package/packages/workers/src/ui/types/worker-ui.d.ts.map +0 -1
- package/packages/workers/src/ui/types/worker-ui.js +0 -5
- package/routes/api.d.ts +0 -7
- package/routes/api.d.ts.map +0 -1
- package/routes/api.js +0 -136
- package/routes/broadcast.d.ts +0 -9
- package/routes/broadcast.d.ts.map +0 -1
- package/routes/broadcast.js +0 -27
- package/routes/storage.d.ts +0 -4
- package/routes/storage.d.ts.map +0 -1
- package/routes/storage.js +0 -35
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Worker Shutdown Coordinator
|
|
3
|
-
*
|
|
4
|
-
* Centralized graceful shutdown handling for the worker management system.
|
|
5
|
-
* Coordinates orderly shutdown of all worker modules and the WorkerFactory.
|
|
6
|
-
*/
|
|
7
|
-
import { Logger } from '../../../src/index.js';
|
|
8
|
-
import { WorkerFactory } from './WorkerFactory.js';
|
|
9
|
-
// ============================================================================
|
|
10
|
-
// Implementation
|
|
11
|
-
// ============================================================================
|
|
12
|
-
const state = {
|
|
13
|
-
isShuttingDown: false,
|
|
14
|
-
completedAt: null,
|
|
15
|
-
startedAt: null,
|
|
16
|
-
reason: null,
|
|
17
|
-
};
|
|
18
|
-
let shutdownHandlersRegistered = false;
|
|
19
|
-
const signalHandlers = {};
|
|
20
|
-
/**
|
|
21
|
-
* Perform graceful shutdown of all worker modules
|
|
22
|
-
*/
|
|
23
|
-
async function shutdown(options = {}) {
|
|
24
|
-
const { timeout = 30000, forceExit = true, signal = 'unknown' } = options;
|
|
25
|
-
// Prevent concurrent shutdowns
|
|
26
|
-
if (state.isShuttingDown) {
|
|
27
|
-
Logger.warn('Shutdown already in progress, ignoring duplicate request');
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
state.isShuttingDown = true;
|
|
31
|
-
state.startedAt = new Date();
|
|
32
|
-
state.reason = `Signal: ${signal}`;
|
|
33
|
-
Logger.info('🛑 Initiating graceful shutdown of worker management system', {
|
|
34
|
-
signal,
|
|
35
|
-
timeout,
|
|
36
|
-
forceExit,
|
|
37
|
-
});
|
|
38
|
-
// Setup timeout for forced shutdown
|
|
39
|
-
let timeoutHandle = null;
|
|
40
|
-
if (forceExit && timeout > 0) {
|
|
41
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
42
|
-
timeoutHandle = setTimeout(() => {
|
|
43
|
-
Logger.error('❌ Graceful shutdown timeout exceeded, forcing exit', { timeout });
|
|
44
|
-
process.exit(1);
|
|
45
|
-
}, timeout);
|
|
46
|
-
}
|
|
47
|
-
try {
|
|
48
|
-
// Shutdown WorkerFactory - this will coordinate shutdown of all modules
|
|
49
|
-
await WorkerFactory.shutdown();
|
|
50
|
-
state.completedAt = new Date();
|
|
51
|
-
const duration = state.completedAt.getTime() - (state.startedAt?.getTime() ?? 0);
|
|
52
|
-
Logger.info('✅ Worker management system shutdown complete', {
|
|
53
|
-
duration: `${duration}ms`,
|
|
54
|
-
signal,
|
|
55
|
-
});
|
|
56
|
-
// Clear timeout if successful
|
|
57
|
-
if (timeoutHandle) {
|
|
58
|
-
clearTimeout(timeoutHandle);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
catch (error) {
|
|
62
|
-
Logger.error('❌ Error during worker management system shutdown', error);
|
|
63
|
-
throw error;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
/**
|
|
67
|
-
* Register process signal handlers for graceful shutdown
|
|
68
|
-
*/
|
|
69
|
-
function registerShutdownHandlers() {
|
|
70
|
-
if (shutdownHandlersRegistered) {
|
|
71
|
-
Logger.debug('Shutdown handlers already registered, skipping');
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
Logger.debug('Registering worker management system shutdown handlers');
|
|
75
|
-
// SIGTERM - graceful shutdown (Docker, systemd, etc.)
|
|
76
|
-
signalHandlers.sigterm = async () => {
|
|
77
|
-
Logger.info('📨 Received SIGTERM signal');
|
|
78
|
-
try {
|
|
79
|
-
await shutdown({ signal: 'SIGTERM', timeout: 30000, forceExit: true });
|
|
80
|
-
}
|
|
81
|
-
catch (error) {
|
|
82
|
-
Logger.error('Error during SIGTERM shutdown', error);
|
|
83
|
-
}
|
|
84
|
-
};
|
|
85
|
-
process.on('SIGTERM', signalHandlers.sigterm);
|
|
86
|
-
// SIGINT - user interrupt (Ctrl+C) - REMOVED: handled by bootstrap.ts to prevent race condition
|
|
87
|
-
// process.on('SIGINT', async () => {
|
|
88
|
-
// Logger.info('📨 Received SIGINT signal');
|
|
89
|
-
// try {
|
|
90
|
-
// await shutdown({ signal: 'SIGINT', timeout: 30000, forceExit: true });
|
|
91
|
-
// } catch (error) {
|
|
92
|
-
// Logger.error('Error during SIGINT shutdown', error);
|
|
93
|
-
// }
|
|
94
|
-
// });
|
|
95
|
-
// SIGHUP - terminal closed
|
|
96
|
-
signalHandlers.sighup = async () => {
|
|
97
|
-
Logger.info('📨 Received SIGHUP signal');
|
|
98
|
-
try {
|
|
99
|
-
await shutdown({ signal: 'SIGHUP', timeout: 30000, forceExit: true });
|
|
100
|
-
}
|
|
101
|
-
catch (error) {
|
|
102
|
-
Logger.error('Error during SIGHUP shutdown', error);
|
|
103
|
-
}
|
|
104
|
-
};
|
|
105
|
-
process.on('SIGHUP', signalHandlers.sighup);
|
|
106
|
-
// Handle uncaught errors during shutdown
|
|
107
|
-
signalHandlers.uncaughtException = async (error) => {
|
|
108
|
-
Logger.error('💥 Uncaught exception during worker operations', error);
|
|
109
|
-
try {
|
|
110
|
-
await shutdown({ signal: 'uncaughtException', timeout: 10000, forceExit: true });
|
|
111
|
-
}
|
|
112
|
-
catch {
|
|
113
|
-
// Ignore errors during emergency shutdown
|
|
114
|
-
}
|
|
115
|
-
process.exit(1);
|
|
116
|
-
};
|
|
117
|
-
process.on('uncaughtException', signalHandlers.uncaughtException);
|
|
118
|
-
signalHandlers.unhandledRejection = (reason) => {
|
|
119
|
-
// Only log the error - don't shut down the entire application
|
|
120
|
-
Logger.error('💥 Unhandled promise rejection detected', reason);
|
|
121
|
-
Logger.warn('⚠️ This error has been logged but will not shut down the server');
|
|
122
|
-
Logger.warn('⚠️ Check the error context and fix the underlying issue');
|
|
123
|
-
};
|
|
124
|
-
process.on('unhandledRejection', signalHandlers.unhandledRejection);
|
|
125
|
-
shutdownHandlersRegistered = true;
|
|
126
|
-
Logger.debug('Worker management system shutdown handlers registered');
|
|
127
|
-
}
|
|
128
|
-
/**
|
|
129
|
-
* Unregister process signal handlers (for hot reload/testing)
|
|
130
|
-
*/
|
|
131
|
-
function unregisterShutdownHandlers() {
|
|
132
|
-
if (!shutdownHandlersRegistered)
|
|
133
|
-
return;
|
|
134
|
-
if (signalHandlers.sigterm)
|
|
135
|
-
process.off('SIGTERM', signalHandlers.sigterm);
|
|
136
|
-
if (signalHandlers.sighup)
|
|
137
|
-
process.off('SIGHUP', signalHandlers.sighup);
|
|
138
|
-
if (signalHandlers.uncaughtException)
|
|
139
|
-
process.off('uncaughtException', signalHandlers.uncaughtException);
|
|
140
|
-
if (signalHandlers.unhandledRejection)
|
|
141
|
-
process.off('unhandledRejection', signalHandlers.unhandledRejection);
|
|
142
|
-
signalHandlers.sigterm = undefined;
|
|
143
|
-
signalHandlers.sighup = undefined;
|
|
144
|
-
signalHandlers.uncaughtException = undefined;
|
|
145
|
-
signalHandlers.unhandledRejection = undefined;
|
|
146
|
-
shutdownHandlersRegistered = false;
|
|
147
|
-
Logger.debug('Worker management system shutdown handlers unregistered');
|
|
148
|
-
}
|
|
149
|
-
/**
|
|
150
|
-
* Check if system is currently shutting down
|
|
151
|
-
*/
|
|
152
|
-
function isShuttingDown() {
|
|
153
|
-
return state.isShuttingDown;
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Get current shutdown state
|
|
157
|
-
*/
|
|
158
|
-
function getShutdownState() {
|
|
159
|
-
return { ...state };
|
|
160
|
-
}
|
|
161
|
-
// ============================================================================
|
|
162
|
-
// Public API (Sealed Namespace)
|
|
163
|
-
// ============================================================================
|
|
164
|
-
export const WorkerShutdown = Object.freeze({
|
|
165
|
-
/**
|
|
166
|
-
* Perform graceful shutdown of all worker modules
|
|
167
|
-
*/
|
|
168
|
-
shutdown,
|
|
169
|
-
/**
|
|
170
|
-
* Register process signal handlers for graceful shutdown
|
|
171
|
-
*/
|
|
172
|
-
registerShutdownHandlers,
|
|
173
|
-
/**
|
|
174
|
-
* Unregister process signal handlers (for hot reload/testing)
|
|
175
|
-
*/
|
|
176
|
-
unregisterShutdownHandlers,
|
|
177
|
-
/**
|
|
178
|
-
* Check if system is currently shutting down
|
|
179
|
-
*/
|
|
180
|
-
isShuttingDown,
|
|
181
|
-
/**
|
|
182
|
-
* Get current shutdown state
|
|
183
|
-
*/
|
|
184
|
-
getShutdownState,
|
|
185
|
-
});
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Worker Versioning System
|
|
3
|
-
* Semantic versioning support for workers with backward compatibility
|
|
4
|
-
* Sealed namespace for immutability
|
|
5
|
-
*/
|
|
6
|
-
export type SemanticVersion = {
|
|
7
|
-
major: number;
|
|
8
|
-
minor: number;
|
|
9
|
-
patch: number;
|
|
10
|
-
prerelease?: string;
|
|
11
|
-
build?: string;
|
|
12
|
-
};
|
|
13
|
-
export type WorkerVersion = {
|
|
14
|
-
workerName: string;
|
|
15
|
-
version: SemanticVersion;
|
|
16
|
-
createdAt: Date;
|
|
17
|
-
deprecatedAt?: Date;
|
|
18
|
-
eolDate?: Date;
|
|
19
|
-
isActive: boolean;
|
|
20
|
-
isDeprecated: boolean;
|
|
21
|
-
migrationPath?: string;
|
|
22
|
-
changelog?: string;
|
|
23
|
-
breakingChanges?: string[];
|
|
24
|
-
};
|
|
25
|
-
export type VersionCompatibility = {
|
|
26
|
-
sourceVersion: SemanticVersion;
|
|
27
|
-
targetVersion: SemanticVersion;
|
|
28
|
-
compatible: boolean;
|
|
29
|
-
requiresMigration: boolean;
|
|
30
|
-
breakingChanges: string[];
|
|
31
|
-
recommendations: string[];
|
|
32
|
-
};
|
|
33
|
-
/**
|
|
34
|
-
* Worker Versioning - Sealed namespace
|
|
35
|
-
*/
|
|
36
|
-
export declare const WorkerVersioning: Readonly<{
|
|
37
|
-
/**
|
|
38
|
-
* Register a worker version
|
|
39
|
-
*/
|
|
40
|
-
register(workerVersion: Omit<WorkerVersion, "createdAt" | "isActive" | "isDeprecated">): void;
|
|
41
|
-
/**
|
|
42
|
-
* Get worker version
|
|
43
|
-
*/
|
|
44
|
-
getVersion(workerName: string, versionStr: string): WorkerVersion | null;
|
|
45
|
-
/**
|
|
46
|
-
* Get all versions for a worker
|
|
47
|
-
*/
|
|
48
|
-
getVersions(workerName: string, includeDeprecated?: boolean): ReadonlyArray<WorkerVersion>;
|
|
49
|
-
/**
|
|
50
|
-
* Get latest version
|
|
51
|
-
*/
|
|
52
|
-
getLatest(workerName: string): WorkerVersion | null;
|
|
53
|
-
/**
|
|
54
|
-
* Deprecate a version
|
|
55
|
-
*/
|
|
56
|
-
deprecate(workerName: string, versionStr: string, migrationPath?: string, eolDate?: Date): void;
|
|
57
|
-
/**
|
|
58
|
-
* Deactivate a version (stop accepting new jobs)
|
|
59
|
-
*/
|
|
60
|
-
deactivate(workerName: string, versionStr: string): void;
|
|
61
|
-
/**
|
|
62
|
-
* Activate a version
|
|
63
|
-
*/
|
|
64
|
-
activate(workerName: string, versionStr: string): void;
|
|
65
|
-
/**
|
|
66
|
-
* Check compatibility between versions
|
|
67
|
-
*/
|
|
68
|
-
checkCompatibility(workerName: string, sourceVersionStr: string, targetVersionStr: string): VersionCompatibility;
|
|
69
|
-
/**
|
|
70
|
-
* Set version alias
|
|
71
|
-
*/
|
|
72
|
-
setAlias(workerName: string, alias: string, versionStr: string): void;
|
|
73
|
-
/**
|
|
74
|
-
* Get version by alias
|
|
75
|
-
*/
|
|
76
|
-
resolveAlias(workerName: string, alias: string): string | null;
|
|
77
|
-
/**
|
|
78
|
-
* Parse version string
|
|
79
|
-
*/
|
|
80
|
-
parse(versionStr: string): SemanticVersion;
|
|
81
|
-
/**
|
|
82
|
-
* Convert version to string
|
|
83
|
-
*/
|
|
84
|
-
stringify(version: SemanticVersion): string;
|
|
85
|
-
/**
|
|
86
|
-
* Compare two versions
|
|
87
|
-
*/
|
|
88
|
-
compare(v1Str: string, v2Str: string): number;
|
|
89
|
-
/**
|
|
90
|
-
* Get version summary
|
|
91
|
-
*/
|
|
92
|
-
getSummary(workerName: string): {
|
|
93
|
-
totalVersions: number;
|
|
94
|
-
activeVersions: number;
|
|
95
|
-
deprecatedVersions: number;
|
|
96
|
-
latest: string | null;
|
|
97
|
-
stable: string | null;
|
|
98
|
-
};
|
|
99
|
-
/**
|
|
100
|
-
* Clear all versions for a worker
|
|
101
|
-
*/
|
|
102
|
-
clear(workerName: string): void;
|
|
103
|
-
/**
|
|
104
|
-
* Shutdown
|
|
105
|
-
*/
|
|
106
|
-
shutdown(): void;
|
|
107
|
-
}>;
|
|
108
|
-
//# sourceMappingURL=WorkerVersioning.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"WorkerVersioning.d.ts","sourceRoot":"","sources":["../../../../packages/workers/src/WorkerVersioning.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,eAAe,CAAC;IACzB,SAAS,EAAE,IAAI,CAAC;IAChB,YAAY,CAAC,EAAE,IAAI,CAAC;IACpB,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,QAAQ,EAAE,OAAO,CAAC;IAClB,YAAY,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;CAC5B,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,aAAa,EAAE,eAAe,CAAC;IAC/B,aAAa,EAAE,eAAe,CAAC;IAC/B,UAAU,EAAE,OAAO,CAAC;IACpB,iBAAiB,EAAE,OAAO,CAAC;IAC3B,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B,CAAC;AAoEF;;GAEG;AACH,eAAO,MAAM,gBAAgB;IAC3B;;OAEG;4BACqB,IAAI,CAAC,aAAa,EAAE,WAAW,GAAG,UAAU,GAAG,cAAc,CAAC,GAAG,IAAI;IA2C7F;;OAEG;2BACoB,MAAM,cAAc,MAAM,GAAG,aAAa,GAAG,IAAI;IAoBxE;;OAEG;4BACqB,MAAM,gCAA8B,aAAa,CAAC,aAAa,CAAC;IAUxF;;OAEG;0BACmB,MAAM,GAAG,aAAa,GAAG,IAAI;IAWnD;;OAEG;0BACmB,MAAM,cAAc,MAAM,kBAAkB,MAAM,YAAY,IAAI,GAAG,IAAI;IAuB/F;;OAEG;2BACoB,MAAM,cAAc,MAAM,GAAG,IAAI;IAiBxD;;OAEG;yBACkB,MAAM,cAAc,MAAM,GAAG,IAAI;IAkBtD;;OAEG;mCAEW,MAAM,oBACA,MAAM,oBACN,MAAM,GACvB,oBAAoB;IAqCvB;;OAEG;yBACkB,MAAM,SAAS,MAAM,cAAc,MAAM,GAAG,IAAI;IAerE;;OAEG;6BACsB,MAAM,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI;IAK9D;;OAEG;sBACe,MAAM,GAAG,eAAe;IAI1C;;OAEG;uBACgB,eAAe,GAAG,MAAM;IAI3C;;OAEG;mBACY,MAAM,SAAS,MAAM,GAAG,MAAM;IAM7C;;OAEG;2BACoB,MAAM,GAAG;QAC9B,aAAa,EAAE,MAAM,CAAC;QACtB,cAAc,EAAE,MAAM,CAAC;QACvB,kBAAkB,EAAE,MAAM,CAAC;QAC3B,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;QACtB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;KACvB;IAcD;;OAEG;sBACe,MAAM,GAAG,IAAI;IAkB/B;;OAEG;gBACS,IAAI;EAQhB,CAAC"}
|
|
@@ -1,300 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Worker Versioning System
|
|
3
|
-
* Semantic versioning support for workers with backward compatibility
|
|
4
|
-
* Sealed namespace for immutability
|
|
5
|
-
*/
|
|
6
|
-
import { ErrorFactory, Logger } from '../../../src/index.js';
|
|
7
|
-
// Internal state
|
|
8
|
-
const workerVersions = new Map();
|
|
9
|
-
const versionAliases = new Map(); // 'latest', 'stable', etc. -> version string
|
|
10
|
-
/**
|
|
11
|
-
* Helper: Parse version string
|
|
12
|
-
*/
|
|
13
|
-
const parseVersion = (versionStr) => {
|
|
14
|
-
const match = new RegExp(/^(\d+)\.(\d+)\.(\d+)(?:-([a-zA-Z0-9.-]+))?(?:\+([a-zA-Z0-9.-]+))?$/).exec(versionStr);
|
|
15
|
-
if (!match) {
|
|
16
|
-
throw ErrorFactory.createConfigError(`Invalid version format: ${versionStr}`);
|
|
17
|
-
}
|
|
18
|
-
return {
|
|
19
|
-
major: Number.parseInt(match[1], 10),
|
|
20
|
-
minor: Number.parseInt(match[2], 10),
|
|
21
|
-
patch: Number.parseInt(match[3], 10),
|
|
22
|
-
prerelease: match[4],
|
|
23
|
-
build: match[5],
|
|
24
|
-
};
|
|
25
|
-
};
|
|
26
|
-
/**
|
|
27
|
-
* Helper: Convert version to string
|
|
28
|
-
*/
|
|
29
|
-
const versionToString = (version) => {
|
|
30
|
-
let str = `${version.major}.${version.minor}.${version.patch}`;
|
|
31
|
-
if (typeof version.prerelease === 'string' && version.prerelease.length > 0) {
|
|
32
|
-
str += `-${version.prerelease}`;
|
|
33
|
-
}
|
|
34
|
-
if (typeof version.build === 'string' && version.build.length > 0) {
|
|
35
|
-
str += `+${version.build}`;
|
|
36
|
-
}
|
|
37
|
-
return str;
|
|
38
|
-
};
|
|
39
|
-
/**
|
|
40
|
-
* Helper: Compare versions
|
|
41
|
-
* Returns: -1 if v1 < v2, 0 if v1 === v2, 1 if v1 > v2
|
|
42
|
-
*/
|
|
43
|
-
const compareVersions = (v1, v2) => {
|
|
44
|
-
if (v1.major !== v2.major)
|
|
45
|
-
return v1.major - v2.major;
|
|
46
|
-
if (v1.minor !== v2.minor)
|
|
47
|
-
return v1.minor - v2.minor;
|
|
48
|
-
if (v1.patch !== v2.patch)
|
|
49
|
-
return v1.patch - v2.patch;
|
|
50
|
-
// Prerelease versions have lower precedence
|
|
51
|
-
if (v1.prerelease === undefined && v2.prerelease !== undefined)
|
|
52
|
-
return 1;
|
|
53
|
-
if (v1.prerelease !== undefined && v2.prerelease === undefined)
|
|
54
|
-
return -1;
|
|
55
|
-
if (v1.prerelease !== undefined && v2.prerelease !== undefined) {
|
|
56
|
-
return v1.prerelease.localeCompare(v2.prerelease);
|
|
57
|
-
}
|
|
58
|
-
return 0;
|
|
59
|
-
};
|
|
60
|
-
/**
|
|
61
|
-
* Helper: Check if versions are compatible (no breaking changes)
|
|
62
|
-
*/
|
|
63
|
-
const areVersionsCompatible = (v1, v2) => {
|
|
64
|
-
// Same major version = compatible (semver rules)
|
|
65
|
-
return v1.major === v2.major;
|
|
66
|
-
};
|
|
67
|
-
/**
|
|
68
|
-
* Worker Versioning - Sealed namespace
|
|
69
|
-
*/
|
|
70
|
-
export const WorkerVersioning = Object.freeze({
|
|
71
|
-
/**
|
|
72
|
-
* Register a worker version
|
|
73
|
-
*/
|
|
74
|
-
register(workerVersion) {
|
|
75
|
-
const { workerName, version } = workerVersion;
|
|
76
|
-
const versionStr = versionToString(version);
|
|
77
|
-
let versions = workerVersions.get(workerName);
|
|
78
|
-
if (!versions) {
|
|
79
|
-
versions = [];
|
|
80
|
-
workerVersions.set(workerName, versions);
|
|
81
|
-
}
|
|
82
|
-
// Check if version already exists
|
|
83
|
-
const existing = versions.find((v) => versionToString(v.version) === versionStr);
|
|
84
|
-
if (existing) {
|
|
85
|
-
ErrorFactory.createConfigError(`Version ${versionStr} already registered for worker "${workerName}"`);
|
|
86
|
-
}
|
|
87
|
-
const fullVersion = {
|
|
88
|
-
...workerVersion,
|
|
89
|
-
createdAt: new Date(),
|
|
90
|
-
isActive: true,
|
|
91
|
-
isDeprecated: false,
|
|
92
|
-
};
|
|
93
|
-
versions.push(fullVersion);
|
|
94
|
-
// Sort by version (descending)
|
|
95
|
-
versions.sort((a, b) => -compareVersions(a.version, b.version));
|
|
96
|
-
// Update 'latest' alias if this is the newest version
|
|
97
|
-
if (versions[0] === fullVersion) {
|
|
98
|
-
const aliasKey = `${workerName}:latest`;
|
|
99
|
-
versionAliases.set(aliasKey, versionStr);
|
|
100
|
-
}
|
|
101
|
-
Logger.info(`Worker version registered: ${workerName}@${versionStr}`, {
|
|
102
|
-
isActive: fullVersion.isActive,
|
|
103
|
-
});
|
|
104
|
-
},
|
|
105
|
-
/**
|
|
106
|
-
* Get worker version
|
|
107
|
-
*/
|
|
108
|
-
getVersion(workerName, versionStr) {
|
|
109
|
-
// Check if it's an alias
|
|
110
|
-
let newVersionStr = versionStr;
|
|
111
|
-
const aliasKey = `${workerName}:${newVersionStr}`;
|
|
112
|
-
const aliasedVersion = versionAliases.get(aliasKey);
|
|
113
|
-
if (aliasedVersion !== undefined) {
|
|
114
|
-
newVersionStr = aliasedVersion;
|
|
115
|
-
}
|
|
116
|
-
const versions = workerVersions.get(workerName);
|
|
117
|
-
if (!versions)
|
|
118
|
-
return null;
|
|
119
|
-
const version = parseVersion(newVersionStr);
|
|
120
|
-
const found = versions.find((v) => compareVersions(v.version, version) === 0);
|
|
121
|
-
return found ? { ...found } : null;
|
|
122
|
-
},
|
|
123
|
-
/**
|
|
124
|
-
* Get all versions for a worker
|
|
125
|
-
*/
|
|
126
|
-
getVersions(workerName, includeDeprecated = false) {
|
|
127
|
-
const versions = workerVersions.get(workerName) ?? [];
|
|
128
|
-
if (!includeDeprecated) {
|
|
129
|
-
return versions.filter((v) => !v.isDeprecated);
|
|
130
|
-
}
|
|
131
|
-
return versions.map((v) => ({ ...v }));
|
|
132
|
-
},
|
|
133
|
-
/**
|
|
134
|
-
* Get latest version
|
|
135
|
-
*/
|
|
136
|
-
getLatest(workerName) {
|
|
137
|
-
const versions = workerVersions.get(workerName);
|
|
138
|
-
if (!versions || versions.length === 0)
|
|
139
|
-
return null;
|
|
140
|
-
// Already sorted by version (descending)
|
|
141
|
-
const latest = versions.find((v) => v.isActive && !v.isDeprecated);
|
|
142
|
-
return latest ? { ...latest } : null;
|
|
143
|
-
},
|
|
144
|
-
/**
|
|
145
|
-
* Deprecate a version
|
|
146
|
-
*/
|
|
147
|
-
deprecate(workerName, versionStr, migrationPath, eolDate) {
|
|
148
|
-
const version = WorkerVersioning.getVersion(workerName, versionStr);
|
|
149
|
-
if (!version) {
|
|
150
|
-
throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
|
|
151
|
-
}
|
|
152
|
-
const versions = workerVersions.get(workerName) ?? [];
|
|
153
|
-
const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
|
|
154
|
-
versions[index].isDeprecated = true;
|
|
155
|
-
versions[index].deprecatedAt = new Date();
|
|
156
|
-
versions[index].migrationPath = migrationPath;
|
|
157
|
-
versions[index].eolDate = eolDate;
|
|
158
|
-
Logger.warn(`Worker version deprecated: ${workerName}@${versionStr}`, {
|
|
159
|
-
migrationPath,
|
|
160
|
-
eolDate,
|
|
161
|
-
});
|
|
162
|
-
},
|
|
163
|
-
/**
|
|
164
|
-
* Deactivate a version (stop accepting new jobs)
|
|
165
|
-
*/
|
|
166
|
-
deactivate(workerName, versionStr) {
|
|
167
|
-
const version = WorkerVersioning.getVersion(workerName, versionStr);
|
|
168
|
-
if (!version) {
|
|
169
|
-
throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
|
|
170
|
-
}
|
|
171
|
-
const versions = workerVersions.get(workerName) ?? [];
|
|
172
|
-
const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
|
|
173
|
-
versions[index].isActive = false;
|
|
174
|
-
Logger.info(`Worker version deactivated: ${workerName}@${versionStr}`);
|
|
175
|
-
},
|
|
176
|
-
/**
|
|
177
|
-
* Activate a version
|
|
178
|
-
*/
|
|
179
|
-
activate(workerName, versionStr) {
|
|
180
|
-
const version = WorkerVersioning.getVersion(workerName, versionStr);
|
|
181
|
-
if (!version) {
|
|
182
|
-
throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
|
|
183
|
-
}
|
|
184
|
-
const getWorkerVersions = workerVersions.get(workerName);
|
|
185
|
-
const versions = getWorkerVersions ?? [];
|
|
186
|
-
const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
|
|
187
|
-
versions[index].isActive = true;
|
|
188
|
-
Logger.info(`Worker version activated: ${workerName}@${versionStr}`);
|
|
189
|
-
},
|
|
190
|
-
/**
|
|
191
|
-
* Check compatibility between versions
|
|
192
|
-
*/
|
|
193
|
-
checkCompatibility(workerName, sourceVersionStr, targetVersionStr) {
|
|
194
|
-
const sourceVersion = parseVersion(sourceVersionStr);
|
|
195
|
-
const targetVersion = parseVersion(targetVersionStr);
|
|
196
|
-
const source = WorkerVersioning.getVersion(workerName, sourceVersionStr);
|
|
197
|
-
const target = WorkerVersioning.getVersion(workerName, targetVersionStr);
|
|
198
|
-
const compatible = areVersionsCompatible(sourceVersion, targetVersion);
|
|
199
|
-
const requiresMigration = !compatible || sourceVersion.major < targetVersion.major;
|
|
200
|
-
const breakingChanges = target?.breakingChanges ?? [];
|
|
201
|
-
const recommendations = [];
|
|
202
|
-
if (target?.isDeprecated === true) {
|
|
203
|
-
recommendations.push(`Target version is deprecated. Consider migrating to ${(target.migrationPath ?? '') || 'latest'}`);
|
|
204
|
-
}
|
|
205
|
-
if (!compatible) {
|
|
206
|
-
recommendations.push('Major version change detected. Review breaking changes carefully.');
|
|
207
|
-
}
|
|
208
|
-
if (source?.eolDate && source.eolDate < new Date()) {
|
|
209
|
-
recommendations.push('Source version has reached end of life. Migration is required.');
|
|
210
|
-
}
|
|
211
|
-
return {
|
|
212
|
-
sourceVersion,
|
|
213
|
-
targetVersion,
|
|
214
|
-
compatible,
|
|
215
|
-
requiresMigration,
|
|
216
|
-
breakingChanges,
|
|
217
|
-
recommendations,
|
|
218
|
-
};
|
|
219
|
-
},
|
|
220
|
-
/**
|
|
221
|
-
* Set version alias
|
|
222
|
-
*/
|
|
223
|
-
setAlias(workerName, alias, versionStr) {
|
|
224
|
-
const version = WorkerVersioning.getVersion(workerName, versionStr);
|
|
225
|
-
if (!version) {
|
|
226
|
-
throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
|
|
227
|
-
}
|
|
228
|
-
const aliasKey = `${workerName}:${alias}`;
|
|
229
|
-
versionAliases.set(aliasKey, versionStr);
|
|
230
|
-
Logger.info(`Version alias set: ${alias} -> ${workerName}@${versionStr}`);
|
|
231
|
-
},
|
|
232
|
-
/**
|
|
233
|
-
* Get version by alias
|
|
234
|
-
*/
|
|
235
|
-
resolveAlias(workerName, alias) {
|
|
236
|
-
const aliasKey = `${workerName}:${alias}`;
|
|
237
|
-
return versionAliases.get(aliasKey) ?? null;
|
|
238
|
-
},
|
|
239
|
-
/**
|
|
240
|
-
* Parse version string
|
|
241
|
-
*/
|
|
242
|
-
parse(versionStr) {
|
|
243
|
-
return parseVersion(versionStr);
|
|
244
|
-
},
|
|
245
|
-
/**
|
|
246
|
-
* Convert version to string
|
|
247
|
-
*/
|
|
248
|
-
stringify(version) {
|
|
249
|
-
return versionToString(version);
|
|
250
|
-
},
|
|
251
|
-
/**
|
|
252
|
-
* Compare two versions
|
|
253
|
-
*/
|
|
254
|
-
compare(v1Str, v2Str) {
|
|
255
|
-
const v1 = parseVersion(v1Str);
|
|
256
|
-
const v2 = parseVersion(v2Str);
|
|
257
|
-
return compareVersions(v1, v2);
|
|
258
|
-
},
|
|
259
|
-
/**
|
|
260
|
-
* Get version summary
|
|
261
|
-
*/
|
|
262
|
-
getSummary(workerName) {
|
|
263
|
-
const versions = workerVersions.get(workerName) ?? [];
|
|
264
|
-
const summary = {
|
|
265
|
-
totalVersions: versions.length,
|
|
266
|
-
activeVersions: versions.filter((v) => v.isActive).length,
|
|
267
|
-
deprecatedVersions: versions.filter((v) => v.isDeprecated).length,
|
|
268
|
-
latest: WorkerVersioning.resolveAlias(workerName, 'latest'),
|
|
269
|
-
stable: WorkerVersioning.resolveAlias(workerName, 'stable'),
|
|
270
|
-
};
|
|
271
|
-
return summary;
|
|
272
|
-
},
|
|
273
|
-
/**
|
|
274
|
-
* Clear all versions for a worker
|
|
275
|
-
*/
|
|
276
|
-
clear(workerName) {
|
|
277
|
-
workerVersions.delete(workerName);
|
|
278
|
-
// Remove aliases
|
|
279
|
-
const keysToDelete = [];
|
|
280
|
-
for (const [key] of versionAliases.entries()) {
|
|
281
|
-
if (key.startsWith(`${workerName}:`)) {
|
|
282
|
-
keysToDelete.push(key);
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
for (const key of keysToDelete) {
|
|
286
|
-
versionAliases.delete(key);
|
|
287
|
-
}
|
|
288
|
-
Logger.info(`All versions cleared for worker: ${workerName}`);
|
|
289
|
-
},
|
|
290
|
-
/**
|
|
291
|
-
* Shutdown
|
|
292
|
-
*/
|
|
293
|
-
shutdown() {
|
|
294
|
-
Logger.info('WorkerVersioning shutting down...');
|
|
295
|
-
workerVersions.clear();
|
|
296
|
-
versionAliases.clear();
|
|
297
|
-
Logger.info('WorkerVersioning shutdown complete');
|
|
298
|
-
},
|
|
299
|
-
});
|
|
300
|
-
// Graceful shutdown handled by WorkerShutdown
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"workerConfig.d.ts","sourceRoot":"","sources":["../../../../../packages/workers/src/config/workerConfig.ts"],"names":[],"mappings":"AAsBA,eAAO,MAAM,YAAY;4BATO,MAAM;EAWpC,CAAC;AAEH,eAAO,MAAM,SAAS,QAAO,MAM5B,CAAC"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Env, appConfig } from '../../../../src/index.js';
|
|
2
|
-
const normalizeBaseUrl = (value) => {
|
|
3
|
-
let end = value.length;
|
|
4
|
-
while (end > 0 && value.charAt(end - 1) === '/') {
|
|
5
|
-
end--;
|
|
6
|
-
}
|
|
7
|
-
return value.slice(0, end);
|
|
8
|
-
};
|
|
9
|
-
const withHttpScheme = (value) => value.startsWith('http://') || value.startsWith('https://') ? value : `http://${value}`;
|
|
10
|
-
const resolveWorkerApiUrl = () => {
|
|
11
|
-
const workerApiUrl = Env.get('WORKER_API_URL');
|
|
12
|
-
if (workerApiUrl) {
|
|
13
|
-
return normalizeBaseUrl(withHttpScheme(workerApiUrl));
|
|
14
|
-
}
|
|
15
|
-
return '';
|
|
16
|
-
};
|
|
17
|
-
export const WorkerConfig = Object.freeze({
|
|
18
|
-
getWorkerBaseUrl: resolveWorkerApiUrl,
|
|
19
|
-
});
|
|
20
|
-
export const keyPrefix = () => {
|
|
21
|
-
const redisKeyPrefix = (Env.get('WORKER_PERSISTENCE_REDIS_KEY_PREFIX', '') ?? '').trim();
|
|
22
|
-
return redisKeyPrefix
|
|
23
|
-
? `${redisKeyPrefix}_worker_${appConfig.prefix}`
|
|
24
|
-
: `worker_${appConfig.prefix}`;
|
|
25
|
-
};
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
type QueueWorker = {
|
|
2
|
-
processOne: (queueName?: string, driverName?: string) => Promise<boolean>;
|
|
3
|
-
processAll: (queueName?: string, driverName?: string) => Promise<number>;
|
|
4
|
-
runOnce: (opts?: {
|
|
5
|
-
queueName?: string;
|
|
6
|
-
driverName?: string;
|
|
7
|
-
maxItems?: number;
|
|
8
|
-
maxDurationMs?: number;
|
|
9
|
-
}) => Promise<number>;
|
|
10
|
-
startWorker: (opts?: {
|
|
11
|
-
queueName?: string;
|
|
12
|
-
driverName?: string;
|
|
13
|
-
signal?: AbortSignal;
|
|
14
|
-
maxDurationMs?: number;
|
|
15
|
-
}) => Promise<number>;
|
|
16
|
-
};
|
|
17
|
-
export type CreateQueueWorkerOptions<TPayload> = {
|
|
18
|
-
kindLabel: string;
|
|
19
|
-
defaultQueueName: string;
|
|
20
|
-
maxAttempts: number;
|
|
21
|
-
getLogFields: (payload: TPayload) => Record<string, unknown>;
|
|
22
|
-
handle: (payload: TPayload) => Promise<void>;
|
|
23
|
-
};
|
|
24
|
-
export declare function createQueueWorker<TPayload>(options: CreateQueueWorkerOptions<TPayload>): QueueWorker;
|
|
25
|
-
export {};
|
|
26
|
-
//# sourceMappingURL=createQueueWorker.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"createQueueWorker.d.ts","sourceRoot":"","sources":["../../../../packages/workers/src/createQueueWorker.ts"],"names":[],"mappings":"AAkHA,KAAK,WAAW,GAAG;IACjB,UAAU,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IAC1E,UAAU,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACzE,OAAO,EAAE,CAAC,IAAI,CAAC,EAAE;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACtB,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,MAAM,CAAC,EAAE,WAAW,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,wBAAwB,CAAC,QAAQ,IAAI;IAC/C,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,CAAC,OAAO,EAAE,QAAQ,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,EAAE,CAAC,OAAO,EAAE,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC9C,CAAC;AAucF,wBAAgB,iBAAiB,CAAC,QAAQ,EACxC,OAAO,EAAE,wBAAwB,CAAC,QAAQ,CAAC,GAC1C,WAAW,CAOb"}
|