@zintrust/core 0.1.41 → 0.1.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (547) hide show
  1. package/app/Controllers/AuthController.d.ts +10 -0
  2. package/app/Controllers/AuthController.d.ts.map +1 -0
  3. package/app/Controllers/AuthController.js +201 -0
  4. package/app/Controllers/UserController.d.ts +9 -0
  5. package/app/Controllers/UserController.d.ts.map +1 -0
  6. package/app/Controllers/UserController.js +8 -0
  7. package/app/Controllers/UserQueryBuilderController.d.ts +16 -0
  8. package/app/Controllers/UserQueryBuilderController.d.ts.map +1 -0
  9. package/app/Controllers/UserQueryBuilderController.js +404 -0
  10. package/app/Middleware/ProfilerMiddleware.d.ts +12 -0
  11. package/app/Middleware/ProfilerMiddleware.d.ts.map +1 -0
  12. package/app/Middleware/ProfilerMiddleware.js +47 -0
  13. package/app/Middleware/index.d.ts +59 -0
  14. package/app/Middleware/index.d.ts.map +1 -0
  15. package/app/Middleware/index.js +215 -0
  16. package/app/Models/Post.d.ts +14 -0
  17. package/app/Models/Post.d.ts.map +1 -0
  18. package/app/Models/Post.js +27 -0
  19. package/app/Models/User.d.ts +14 -0
  20. package/app/Models/User.d.ts.map +1 -0
  21. package/app/Models/User.js +44 -0
  22. package/app/Schedules/JobTracking.d.ts +3 -0
  23. package/app/Schedules/JobTracking.d.ts.map +1 -0
  24. package/app/Schedules/JobTracking.js +13 -0
  25. package/app/Schedules/index.d.ts +2 -0
  26. package/app/Schedules/index.d.ts.map +1 -0
  27. package/app/Schedules/index.js +1 -0
  28. package/app/Toolkit/Broadcast/sendBroadcast.d.ts +6 -0
  29. package/app/Toolkit/Broadcast/sendBroadcast.d.ts.map +1 -0
  30. package/app/Toolkit/Broadcast/sendBroadcast.js +5 -0
  31. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts +6 -0
  32. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts.map +1 -0
  33. package/app/Toolkit/Mail/sendWelcomeEmail.js +20 -0
  34. package/app/Toolkit/Notification/sendSlackNotification.d.ts +8 -0
  35. package/app/Toolkit/Notification/sendSlackNotification.d.ts.map +1 -0
  36. package/app/Toolkit/Notification/sendSlackNotification.js +5 -0
  37. package/app/Toolkit/Notification/sendSms.d.ts +6 -0
  38. package/app/Toolkit/Notification/sendSms.d.ts.map +1 -0
  39. package/app/Toolkit/Notification/sendSms.js +5 -0
  40. package/app/Types/controller.d.ts +42 -0
  41. package/app/Types/controller.d.ts.map +1 -0
  42. package/app/Types/controller.js +1 -0
  43. package/config/broadcast.d.ts +38 -0
  44. package/config/broadcast.d.ts.map +1 -0
  45. package/config/broadcast.js +37 -0
  46. package/config/cache.d.ts +40 -0
  47. package/config/cache.d.ts.map +1 -0
  48. package/config/cache.js +39 -0
  49. package/config/database.d.ts +58 -0
  50. package/config/database.d.ts.map +1 -0
  51. package/config/database.js +65 -0
  52. package/config/mail.d.ts +51 -0
  53. package/config/mail.d.ts.map +1 -0
  54. package/config/mail.js +69 -0
  55. package/config/middleware.d.ts +11 -0
  56. package/config/middleware.d.ts.map +1 -0
  57. package/config/middleware.js +30 -0
  58. package/config/notification.d.ts +33 -0
  59. package/config/notification.d.ts.map +1 -0
  60. package/config/notification.js +33 -0
  61. package/config/queue.d.ts +55 -0
  62. package/config/queue.d.ts.map +1 -0
  63. package/config/queue.js +87 -0
  64. package/config/storage.d.ts +59 -0
  65. package/config/storage.d.ts.map +1 -0
  66. package/config/storage.js +59 -0
  67. package/config/workers.d.ts +54 -0
  68. package/config/workers.d.ts.map +1 -0
  69. package/config/workers.js +83 -0
  70. package/package.json +27 -5
  71. package/packages/cloudflare-d1-proxy/src/index.d.ts +48 -0
  72. package/packages/cloudflare-d1-proxy/src/index.d.ts.map +1 -0
  73. package/packages/cloudflare-d1-proxy/src/index.js +387 -0
  74. package/packages/cloudflare-kv-proxy/src/index.d.ts +44 -0
  75. package/packages/cloudflare-kv-proxy/src/index.d.ts.map +1 -0
  76. package/packages/cloudflare-kv-proxy/src/index.js +325 -0
  77. package/packages/queue-monitor/src/QueueMonitoringService.d.ts +35 -0
  78. package/packages/queue-monitor/src/QueueMonitoringService.d.ts.map +1 -0
  79. package/packages/queue-monitor/src/QueueMonitoringService.js +194 -0
  80. package/packages/queue-monitor/src/connection.d.ts +3 -0
  81. package/packages/queue-monitor/src/connection.d.ts.map +1 -0
  82. package/packages/queue-monitor/src/connection.js +1 -0
  83. package/packages/queue-monitor/src/dashboard-ui.d.ts +7 -0
  84. package/packages/queue-monitor/src/dashboard-ui.d.ts.map +1 -0
  85. package/packages/queue-monitor/src/dashboard-ui.js +997 -0
  86. package/packages/queue-monitor/src/driver.d.ts +15 -0
  87. package/packages/queue-monitor/src/driver.d.ts.map +1 -0
  88. package/packages/queue-monitor/src/driver.js +115 -0
  89. package/packages/queue-monitor/src/index.d.ts +71 -0
  90. package/packages/queue-monitor/src/index.d.ts.map +1 -0
  91. package/packages/queue-monitor/src/index.js +296 -0
  92. package/packages/queue-monitor/src/metrics.d.ts +27 -0
  93. package/packages/queue-monitor/src/metrics.d.ts.map +1 -0
  94. package/packages/queue-monitor/src/metrics.js +92 -0
  95. package/packages/queue-monitor/src/worker.d.ts +8 -0
  96. package/packages/queue-monitor/src/worker.d.ts.map +1 -0
  97. package/packages/queue-monitor/src/worker.js +35 -0
  98. package/packages/queue-redis/src/BullMQRedisQueue.d.ts +26 -0
  99. package/packages/queue-redis/src/BullMQRedisQueue.d.ts.map +1 -0
  100. package/packages/queue-redis/src/BullMQRedisQueue.js +463 -0
  101. package/packages/queue-redis/src/HttpQueueDriver.d.ts +18 -0
  102. package/packages/queue-redis/src/HttpQueueDriver.d.ts.map +1 -0
  103. package/packages/queue-redis/src/HttpQueueDriver.js +249 -0
  104. package/packages/queue-redis/src/QueueHttpGateway.d.ts +16 -0
  105. package/packages/queue-redis/src/QueueHttpGateway.d.ts.map +1 -0
  106. package/packages/queue-redis/src/QueueHttpGateway.js +217 -0
  107. package/packages/queue-redis/src/RedisPublishClient.d.ts +14 -0
  108. package/packages/queue-redis/src/RedisPublishClient.d.ts.map +1 -0
  109. package/packages/queue-redis/src/RedisPublishClient.js +251 -0
  110. package/packages/queue-redis/src/index.d.ts +12 -0
  111. package/packages/queue-redis/src/index.d.ts.map +1 -0
  112. package/packages/queue-redis/src/index.js +10 -0
  113. package/packages/queue-redis/src/register.d.ts +6 -0
  114. package/packages/queue-redis/src/register.d.ts.map +1 -0
  115. package/packages/queue-redis/src/register.js +21 -0
  116. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts +11 -0
  117. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts.map +1 -0
  118. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.js +32 -0
  119. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts +11 -0
  120. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts.map +1 -0
  121. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.js +46 -0
  122. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts +7 -0
  123. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts.map +1 -0
  124. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.js +44 -0
  125. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts +7 -0
  126. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts.map +1 -0
  127. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.js +104 -0
  128. package/packages/workers/src/AnomalyDetection.d.ts +107 -0
  129. package/packages/workers/src/AnomalyDetection.d.ts.map +1 -0
  130. package/packages/workers/src/AnomalyDetection.js +329 -0
  131. package/packages/workers/src/AutoScaler.d.ts +128 -0
  132. package/packages/workers/src/AutoScaler.d.ts.map +1 -0
  133. package/packages/workers/src/AutoScaler.js +425 -0
  134. package/packages/workers/src/BroadcastWorker.d.ts +24 -0
  135. package/packages/workers/src/BroadcastWorker.d.ts.map +1 -0
  136. package/packages/workers/src/BroadcastWorker.js +24 -0
  137. package/packages/workers/src/CanaryController.d.ts +104 -0
  138. package/packages/workers/src/CanaryController.d.ts.map +1 -0
  139. package/packages/workers/src/CanaryController.js +424 -0
  140. package/packages/workers/src/ChaosEngineering.d.ts +80 -0
  141. package/packages/workers/src/ChaosEngineering.d.ts.map +1 -0
  142. package/packages/workers/src/ChaosEngineering.js +229 -0
  143. package/packages/workers/src/CircuitBreaker.d.ts +107 -0
  144. package/packages/workers/src/CircuitBreaker.d.ts.map +1 -0
  145. package/packages/workers/src/CircuitBreaker.js +374 -0
  146. package/packages/workers/src/ClusterLock.d.ts +91 -0
  147. package/packages/workers/src/ClusterLock.d.ts.map +1 -0
  148. package/packages/workers/src/ClusterLock.js +397 -0
  149. package/packages/workers/src/ComplianceManager.d.ts +178 -0
  150. package/packages/workers/src/ComplianceManager.d.ts.map +1 -0
  151. package/packages/workers/src/ComplianceManager.js +556 -0
  152. package/packages/workers/src/DatacenterOrchestrator.d.ts +134 -0
  153. package/packages/workers/src/DatacenterOrchestrator.d.ts.map +1 -0
  154. package/packages/workers/src/DatacenterOrchestrator.js +404 -0
  155. package/packages/workers/src/DeadLetterQueue.d.ts +123 -0
  156. package/packages/workers/src/DeadLetterQueue.d.ts.map +1 -0
  157. package/packages/workers/src/DeadLetterQueue.js +544 -0
  158. package/packages/workers/src/HealthMonitor.d.ts +43 -0
  159. package/packages/workers/src/HealthMonitor.d.ts.map +1 -0
  160. package/packages/workers/src/HealthMonitor.js +312 -0
  161. package/packages/workers/src/MultiQueueWorker.d.ts +90 -0
  162. package/packages/workers/src/MultiQueueWorker.d.ts.map +1 -0
  163. package/packages/workers/src/MultiQueueWorker.js +282 -0
  164. package/packages/workers/src/NotificationWorker.d.ts +24 -0
  165. package/packages/workers/src/NotificationWorker.d.ts.map +1 -0
  166. package/packages/workers/src/NotificationWorker.js +23 -0
  167. package/packages/workers/src/Observability.d.ts +154 -0
  168. package/packages/workers/src/Observability.d.ts.map +1 -0
  169. package/packages/workers/src/Observability.js +538 -0
  170. package/packages/workers/src/PluginManager.d.ts +124 -0
  171. package/packages/workers/src/PluginManager.d.ts.map +1 -0
  172. package/packages/workers/src/PluginManager.js +392 -0
  173. package/packages/workers/src/PriorityQueue.d.ts +118 -0
  174. package/packages/workers/src/PriorityQueue.d.ts.map +1 -0
  175. package/packages/workers/src/PriorityQueue.js +276 -0
  176. package/packages/workers/src/ResourceMonitor.d.ts +165 -0
  177. package/packages/workers/src/ResourceMonitor.d.ts.map +1 -0
  178. package/packages/workers/src/ResourceMonitor.js +632 -0
  179. package/packages/workers/src/SLAMonitor.d.ts +111 -0
  180. package/packages/workers/src/SLAMonitor.d.ts.map +1 -0
  181. package/packages/workers/src/SLAMonitor.js +274 -0
  182. package/packages/workers/src/WorkerFactory.d.ts +218 -0
  183. package/packages/workers/src/WorkerFactory.d.ts.map +1 -0
  184. package/packages/workers/src/WorkerFactory.js +2253 -0
  185. package/packages/workers/src/WorkerInit.d.ts +86 -0
  186. package/packages/workers/src/WorkerInit.d.ts.map +1 -0
  187. package/packages/workers/src/WorkerInit.js +307 -0
  188. package/packages/workers/src/WorkerMetrics.d.ts +116 -0
  189. package/packages/workers/src/WorkerMetrics.d.ts.map +1 -0
  190. package/packages/workers/src/WorkerMetrics.js +570 -0
  191. package/packages/workers/src/WorkerRegistry.d.ts +152 -0
  192. package/packages/workers/src/WorkerRegistry.d.ts.map +1 -0
  193. package/packages/workers/src/WorkerRegistry.js +396 -0
  194. package/packages/workers/src/WorkerShutdown.d.ts +70 -0
  195. package/packages/workers/src/WorkerShutdown.d.ts.map +1 -0
  196. package/packages/workers/src/WorkerShutdown.js +185 -0
  197. package/packages/workers/src/WorkerVersioning.d.ts +108 -0
  198. package/packages/workers/src/WorkerVersioning.d.ts.map +1 -0
  199. package/packages/workers/src/WorkerVersioning.js +300 -0
  200. package/packages/workers/src/config/workerConfig.d.ts +5 -0
  201. package/packages/workers/src/config/workerConfig.d.ts.map +1 -0
  202. package/packages/workers/src/config/workerConfig.js +25 -0
  203. package/packages/workers/src/createQueueWorker.d.ts +26 -0
  204. package/packages/workers/src/createQueueWorker.d.ts.map +1 -0
  205. package/packages/workers/src/createQueueWorker.js +367 -0
  206. package/packages/workers/src/dashboard/index.d.ts +2 -0
  207. package/packages/workers/src/dashboard/index.d.ts.map +1 -0
  208. package/packages/workers/src/dashboard/index.js +1 -0
  209. package/packages/workers/src/dashboard/types.d.ts +123 -0
  210. package/packages/workers/src/dashboard/types.d.ts.map +1 -0
  211. package/packages/workers/src/dashboard/types.js +1 -0
  212. package/packages/workers/src/dashboard/workers-api.d.ts +5 -0
  213. package/packages/workers/src/dashboard/workers-api.d.ts.map +1 -0
  214. package/packages/workers/src/dashboard/workers-api.js +738 -0
  215. package/packages/workers/src/helper/index.d.ts +6 -0
  216. package/packages/workers/src/helper/index.d.ts.map +1 -0
  217. package/packages/workers/src/helper/index.js +10 -0
  218. package/packages/workers/src/http/WorkerApiController.d.ts +39 -0
  219. package/packages/workers/src/http/WorkerApiController.d.ts.map +1 -0
  220. package/packages/workers/src/http/WorkerApiController.js +313 -0
  221. package/packages/workers/src/http/WorkerController.d.ts +375 -0
  222. package/packages/workers/src/http/WorkerController.d.ts.map +1 -0
  223. package/packages/workers/src/http/WorkerController.js +1454 -0
  224. package/packages/workers/src/http/WorkerMonitoringService.d.ts +12 -0
  225. package/packages/workers/src/http/WorkerMonitoringService.d.ts.map +1 -0
  226. package/packages/workers/src/http/WorkerMonitoringService.js +89 -0
  227. package/packages/workers/src/http/middleware/CustomValidation.d.ts +93 -0
  228. package/packages/workers/src/http/middleware/CustomValidation.d.ts.map +1 -0
  229. package/packages/workers/src/http/middleware/CustomValidation.js +270 -0
  230. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts +4 -0
  231. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts.map +1 -0
  232. package/packages/workers/src/http/middleware/DatacenterValidator.js +94 -0
  233. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts +8 -0
  234. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts.map +1 -0
  235. package/packages/workers/src/http/middleware/EditWorkerValidation.js +56 -0
  236. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts +4 -0
  237. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts.map +1 -0
  238. package/packages/workers/src/http/middleware/FeaturesValidator.js +60 -0
  239. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts +32 -0
  240. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts.map +1 -0
  241. package/packages/workers/src/http/middleware/InfrastructureValidator.js +226 -0
  242. package/packages/workers/src/http/middleware/OptionsValidator.d.ts +4 -0
  243. package/packages/workers/src/http/middleware/OptionsValidator.d.ts.map +1 -0
  244. package/packages/workers/src/http/middleware/OptionsValidator.js +112 -0
  245. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts +8 -0
  246. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts.map +1 -0
  247. package/packages/workers/src/http/middleware/PayloadSanitizer.js +42 -0
  248. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts +4 -0
  249. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts.map +1 -0
  250. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.js +140 -0
  251. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts +4 -0
  252. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts.map +1 -0
  253. package/packages/workers/src/http/middleware/QueueNameSanitizer.js +45 -0
  254. package/packages/workers/src/http/middleware/ValidateDriver.d.ts +8 -0
  255. package/packages/workers/src/http/middleware/ValidateDriver.d.ts.map +1 -0
  256. package/packages/workers/src/http/middleware/ValidateDriver.js +20 -0
  257. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts +4 -0
  258. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts.map +1 -0
  259. package/packages/workers/src/http/middleware/VersionSanitizer.js +25 -0
  260. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts +4 -0
  261. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts.map +1 -0
  262. package/packages/workers/src/http/middleware/WorkerNameSanitizer.js +46 -0
  263. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts +28 -0
  264. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts.map +1 -0
  265. package/packages/workers/src/http/middleware/WorkerValidationChain.js +186 -0
  266. package/packages/workers/src/index.d.ts +47 -0
  267. package/packages/workers/src/index.d.ts.map +1 -0
  268. package/packages/workers/src/index.js +48 -0
  269. package/packages/workers/src/routes/workers.d.ts +13 -0
  270. package/packages/workers/src/routes/workers.d.ts.map +1 -0
  271. package/packages/workers/src/routes/workers.js +126 -0
  272. package/packages/workers/src/storage/WorkerStore.d.ts +52 -0
  273. package/packages/workers/src/storage/WorkerStore.d.ts.map +1 -0
  274. package/packages/workers/src/storage/WorkerStore.js +259 -0
  275. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts +47 -0
  276. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts.map +1 -0
  277. package/packages/workers/src/telemetry/api/TelemetryAPI.js +219 -0
  278. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts +18 -0
  279. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts.map +1 -0
  280. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.js +140 -0
  281. package/packages/workers/src/telemetry/components/AlertPanel.d.ts +2 -0
  282. package/packages/workers/src/telemetry/components/AlertPanel.d.ts.map +1 -0
  283. package/packages/workers/src/telemetry/components/AlertPanel.js +13 -0
  284. package/packages/workers/src/telemetry/components/CostTracking.d.ts +2 -0
  285. package/packages/workers/src/telemetry/components/CostTracking.d.ts.map +1 -0
  286. package/packages/workers/src/telemetry/components/CostTracking.js +14 -0
  287. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts +2 -0
  288. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts.map +1 -0
  289. package/packages/workers/src/telemetry/components/ResourceUsageChart.js +11 -0
  290. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts +2 -0
  291. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts.map +1 -0
  292. package/packages/workers/src/telemetry/components/WorkerHealthChart.js +11 -0
  293. package/packages/workers/src/telemetry/index.d.ts +16 -0
  294. package/packages/workers/src/telemetry/index.d.ts.map +1 -0
  295. package/packages/workers/src/telemetry/index.js +60 -0
  296. package/packages/workers/src/telemetry/routes/dashboard.d.ts +7 -0
  297. package/packages/workers/src/telemetry/routes/dashboard.d.ts.map +1 -0
  298. package/packages/workers/src/telemetry/routes/dashboard.js +608 -0
  299. package/packages/workers/src/type.d.ts +77 -0
  300. package/packages/workers/src/type.d.ts.map +1 -0
  301. package/packages/workers/src/type.js +1 -0
  302. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts +5 -0
  303. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts.map +1 -0
  304. package/packages/workers/src/ui/router/EmbeddedAssets.js +13 -0
  305. package/packages/workers/src/ui/router/ui.d.ts +4 -0
  306. package/packages/workers/src/ui/router/ui.d.ts.map +1 -0
  307. package/packages/workers/src/ui/router/ui.js +208 -0
  308. package/packages/workers/src/ui/types/worker-ui.d.ts +230 -0
  309. package/packages/workers/src/ui/types/worker-ui.d.ts.map +1 -0
  310. package/packages/workers/src/ui/types/worker-ui.js +5 -0
  311. package/routes/api.d.ts +7 -0
  312. package/routes/api.d.ts.map +1 -0
  313. package/routes/api.js +129 -0
  314. package/routes/broadcast.d.ts +9 -0
  315. package/routes/broadcast.d.ts.map +1 -0
  316. package/routes/broadcast.js +27 -0
  317. package/routes/storage.d.ts +4 -0
  318. package/routes/storage.d.ts.map +1 -0
  319. package/routes/storage.js +35 -0
  320. package/src/boot/bootstrap.js +27 -11
  321. package/src/boot/registry/runtime.d.ts.map +1 -1
  322. package/src/boot/registry/runtime.js +11 -0
  323. package/src/cache/Cache.d.ts.map +1 -1
  324. package/src/cache/Cache.js +40 -8
  325. package/src/cache/drivers/KVRemoteDriver.d.ts +1 -1
  326. package/src/cache/drivers/KVRemoteDriver.d.ts.map +1 -1
  327. package/src/cache/drivers/KVRemoteDriver.js +259 -44
  328. package/src/cache/drivers/MemoryDriver.d.ts.map +1 -1
  329. package/src/cache/drivers/MemoryDriver.js +10 -2
  330. package/src/cache/drivers/RedisDriver.d.ts.map +1 -1
  331. package/src/cache/drivers/RedisDriver.js +256 -33
  332. package/src/cli/CLI.d.ts.map +1 -1
  333. package/src/cli/CLI.js +12 -0
  334. package/src/cli/commands/ConfigCommand.d.ts.map +1 -1
  335. package/src/cli/commands/ConfigCommand.js +3 -5
  336. package/src/cli/commands/D1LearnCommand.d.ts +9 -0
  337. package/src/cli/commands/D1LearnCommand.d.ts.map +1 -0
  338. package/src/cli/commands/D1LearnCommand.js +143 -0
  339. package/src/cli/commands/D1MigrateCommand.d.ts.map +1 -1
  340. package/src/cli/commands/D1MigrateCommand.js +55 -16
  341. package/src/cli/commands/InitContainerCommand.d.ts.map +1 -1
  342. package/src/cli/commands/InitContainerCommand.js +30 -15
  343. package/src/cli/commands/InitEcosystemCommand.d.ts +6 -0
  344. package/src/cli/commands/InitEcosystemCommand.d.ts.map +1 -0
  345. package/src/cli/commands/InitEcosystemCommand.js +51 -0
  346. package/src/cli/commands/MigrateCommand.d.ts.map +1 -1
  347. package/src/cli/commands/MigrateCommand.js +78 -36
  348. package/src/cli/commands/MigrateWorkerCommand.d.ts.map +1 -1
  349. package/src/cli/commands/MigrateWorkerCommand.js +36 -2
  350. package/src/cli/commands/NewCommand.d.ts.map +1 -1
  351. package/src/cli/commands/NewCommand.js +33 -0
  352. package/src/cli/commands/PutCommand.d.ts +6 -0
  353. package/src/cli/commands/PutCommand.d.ts.map +1 -0
  354. package/src/cli/commands/PutCommand.js +173 -0
  355. package/src/cli/commands/QueueRecoveryCommand.d.ts.map +1 -1
  356. package/src/cli/commands/QueueRecoveryCommand.js +113 -14
  357. package/src/cli/commands/ScheduleListCommand.d.ts +6 -0
  358. package/src/cli/commands/ScheduleListCommand.d.ts.map +1 -0
  359. package/src/cli/commands/ScheduleListCommand.js +62 -0
  360. package/src/cli/commands/ScheduleRunCommand.d.ts +6 -0
  361. package/src/cli/commands/ScheduleRunCommand.d.ts.map +1 -0
  362. package/src/cli/commands/ScheduleRunCommand.js +32 -0
  363. package/src/cli/commands/ScheduleStartCommand.d.ts +6 -0
  364. package/src/cli/commands/ScheduleStartCommand.d.ts.map +1 -0
  365. package/src/cli/commands/ScheduleStartCommand.js +40 -0
  366. package/src/cli/commands/SecretsCommand.d.ts.map +1 -1
  367. package/src/cli/commands/SecretsCommand.js +2 -2
  368. package/src/cli/commands/StartCommand.d.ts.map +1 -1
  369. package/src/cli/commands/StartCommand.js +23 -1
  370. package/src/cli/commands/schedule/ScheduleCliSupport.d.ts +6 -0
  371. package/src/cli/commands/schedule/ScheduleCliSupport.d.ts.map +1 -0
  372. package/src/cli/commands/schedule/ScheduleCliSupport.js +55 -0
  373. package/src/cli/config/ConfigManager.d.ts.map +1 -1
  374. package/src/cli/config/ConfigManager.js +8 -1
  375. package/src/cli/d1/D1SqlMigrations.d.ts.map +1 -1
  376. package/src/cli/d1/D1SqlMigrations.js +11 -1
  377. package/src/cli/d1/WranglerConfig.d.ts.map +1 -1
  378. package/src/cli/d1/WranglerConfig.js +34 -2
  379. package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
  380. package/src/cli/scaffolding/ProjectScaffolder.js +65 -73
  381. package/src/cli/services/VersionChecker.d.ts.map +1 -1
  382. package/src/cli/services/VersionChecker.js +5 -1
  383. package/src/cli/utils/DatabaseCliUtils.d.ts.map +1 -1
  384. package/src/cli/utils/DatabaseCliUtils.js +6 -1
  385. package/src/cli/utils/DistPackager.d.ts.map +1 -1
  386. package/src/cli/utils/DistPackager.js +25 -0
  387. package/src/cli/utils/EnvFileLoader.d.ts +1 -0
  388. package/src/cli/utils/EnvFileLoader.d.ts.map +1 -1
  389. package/src/cli/utils/EnvFileLoader.js +47 -14
  390. package/src/cli.d.ts +5 -0
  391. package/src/cli.d.ts.map +1 -0
  392. package/src/cli.js +4 -0
  393. package/src/collections/index.d.ts +2 -2
  394. package/src/collections/index.d.ts.map +1 -1
  395. package/src/collections/index.js +1 -1
  396. package/src/common/RemoteSignedJson.d.ts.map +1 -1
  397. package/src/common/RemoteSignedJson.js +58 -25
  398. package/src/common/utility.d.ts.map +1 -1
  399. package/src/common/utility.js +2 -6
  400. package/src/config/cache.js +1 -1
  401. package/src/config/cloudflare.d.ts.map +1 -1
  402. package/src/config/cloudflare.js +19 -8
  403. package/src/config/env.d.ts +7 -0
  404. package/src/config/env.d.ts.map +1 -1
  405. package/src/config/env.js +10 -2
  406. package/src/config/queue.js +1 -1
  407. package/src/functions/cloudflare.d.ts.map +1 -1
  408. package/src/functions/cloudflare.js +4 -2
  409. package/src/helper/index.d.ts +225 -0
  410. package/src/helper/index.d.ts.map +1 -0
  411. package/src/helper/index.js +347 -0
  412. package/src/index.d.ts +3 -6
  413. package/src/index.d.ts.map +1 -1
  414. package/src/index.js +7 -9
  415. package/src/middleware/JwtAuthMiddleware.d.ts.map +1 -1
  416. package/src/middleware/JwtAuthMiddleware.js +11 -5
  417. package/src/migrations/MigrationDiscovery.d.ts.map +1 -1
  418. package/src/migrations/MigrationDiscovery.js +2 -1
  419. package/src/orm/DatabaseAdapter.d.ts +1 -0
  420. package/src/orm/DatabaseAdapter.d.ts.map +1 -1
  421. package/src/orm/SchemaStatemenWriter.d.ts +15 -0
  422. package/src/orm/SchemaStatemenWriter.d.ts.map +1 -0
  423. package/src/orm/SchemaStatemenWriter.js +78 -0
  424. package/src/orm/adapters/D1Adapter.d.ts.map +1 -1
  425. package/src/orm/adapters/D1Adapter.js +52 -2
  426. package/src/orm/adapters/D1RemoteAdapter.d.ts.map +1 -1
  427. package/src/orm/adapters/D1RemoteAdapter.js +137 -89
  428. package/src/orm/adapters/MySQLProxyAdapter.d.ts.map +1 -1
  429. package/src/orm/adapters/MySQLProxyAdapter.js +100 -81
  430. package/src/orm/adapters/PostgreSQLProxyAdapter.d.ts.map +1 -1
  431. package/src/orm/adapters/PostgreSQLProxyAdapter.js +26 -10
  432. package/src/orm/adapters/SqlProxyAdapterUtils.d.ts.map +1 -1
  433. package/src/orm/adapters/SqlProxyAdapterUtils.js +2 -1
  434. package/src/orm/adapters/SqlProxyRegistryMode.d.ts +12 -0
  435. package/src/orm/adapters/SqlProxyRegistryMode.d.ts.map +1 -0
  436. package/src/orm/adapters/SqlProxyRegistryMode.js +24 -0
  437. package/src/orm/adapters/SqlServerProxyAdapter.d.ts +3 -0
  438. package/src/orm/adapters/SqlServerProxyAdapter.d.ts.map +1 -1
  439. package/src/orm/adapters/SqlServerProxyAdapter.js +125 -117
  440. package/src/orm/migrations/MigrationStore.js +1 -1
  441. package/src/proxy/ProxyRequestParsing.d.ts +9 -0
  442. package/src/proxy/ProxyRequestParsing.d.ts.map +1 -0
  443. package/src/proxy/ProxyRequestParsing.js +16 -0
  444. package/src/proxy/RequestValidator.d.ts.map +1 -1
  445. package/src/proxy/RequestValidator.js +2 -1
  446. package/src/proxy/SigningService.js +2 -2
  447. package/src/proxy/SqlProxyDbOverrides.d.ts +17 -0
  448. package/src/proxy/SqlProxyDbOverrides.d.ts.map +1 -0
  449. package/src/proxy/SqlProxyDbOverrides.js +1 -0
  450. package/src/proxy/SqlProxyServerDeps.d.ts +12 -0
  451. package/src/proxy/SqlProxyServerDeps.d.ts.map +1 -0
  452. package/src/proxy/SqlProxyServerDeps.js +9 -0
  453. package/src/proxy/StatementPayloadValidator.d.ts +13 -0
  454. package/src/proxy/StatementPayloadValidator.d.ts.map +1 -0
  455. package/src/proxy/StatementPayloadValidator.js +18 -0
  456. package/src/proxy/StatementRegistryLoader.d.ts +2 -0
  457. package/src/proxy/StatementRegistryLoader.d.ts.map +1 -0
  458. package/src/proxy/StatementRegistryLoader.js +36 -0
  459. package/src/proxy/StatementRegistryResolver.d.ts +15 -0
  460. package/src/proxy/StatementRegistryResolver.d.ts.map +1 -0
  461. package/src/proxy/StatementRegistryResolver.js +34 -0
  462. package/src/proxy/d1/ZintrustD1Proxy.d.ts +2 -1
  463. package/src/proxy/d1/ZintrustD1Proxy.d.ts.map +1 -1
  464. package/src/proxy/d1/ZintrustD1Proxy.js +2 -1
  465. package/src/proxy/isMutatingSql.d.ts +2 -0
  466. package/src/proxy/isMutatingSql.d.ts.map +1 -0
  467. package/src/proxy/isMutatingSql.js +12 -0
  468. package/src/proxy/kv/ZintrustKvProxy.d.ts +2 -1
  469. package/src/proxy/kv/ZintrustKvProxy.d.ts.map +1 -1
  470. package/src/proxy/kv/ZintrustKvProxy.js +2 -1
  471. package/src/proxy/mysql/MySqlProxyServer.d.ts +2 -8
  472. package/src/proxy/mysql/MySqlProxyServer.d.ts.map +1 -1
  473. package/src/proxy/mysql/MySqlProxyServer.js +84 -51
  474. package/src/proxy/postgres/PostgresProxyServer.d.ts +2 -8
  475. package/src/proxy/postgres/PostgresProxyServer.d.ts.map +1 -1
  476. package/src/proxy/postgres/PostgresProxyServer.js +86 -48
  477. package/src/proxy/smtp/SmtpProxyServer.d.ts.map +1 -1
  478. package/src/proxy/smtp/SmtpProxyServer.js +6 -5
  479. package/src/proxy/sqlserver/SqlServerProxyServer.d.ts +2 -8
  480. package/src/proxy/sqlserver/SqlServerProxyServer.d.ts.map +1 -1
  481. package/src/proxy/sqlserver/SqlServerProxyServer.js +84 -49
  482. package/src/proxy.d.ts +4 -0
  483. package/src/proxy.d.ts.map +1 -0
  484. package/src/proxy.js +3 -0
  485. package/src/runtime/RuntimeAdapter.d.ts.map +1 -1
  486. package/src/runtime/RuntimeAdapter.js +30 -12
  487. package/src/runtime/adapters/CloudflareAdapter.d.ts.map +1 -1
  488. package/src/runtime/adapters/CloudflareAdapter.js +15 -4
  489. package/src/scheduler/Schedule.d.ts +36 -0
  490. package/src/scheduler/Schedule.d.ts.map +1 -0
  491. package/src/scheduler/Schedule.js +197 -0
  492. package/src/scheduler/ScheduleHttpGateway.d.ts +8 -0
  493. package/src/scheduler/ScheduleHttpGateway.d.ts.map +1 -0
  494. package/src/scheduler/ScheduleHttpGateway.js +196 -0
  495. package/src/scheduler/ScheduleRunner.d.ts +6 -0
  496. package/src/scheduler/ScheduleRunner.d.ts.map +1 -1
  497. package/src/scheduler/ScheduleRunner.js +166 -29
  498. package/src/scheduler/SchedulerRuntime.d.ts +15 -0
  499. package/src/scheduler/SchedulerRuntime.d.ts.map +1 -0
  500. package/src/scheduler/SchedulerRuntime.js +79 -0
  501. package/src/scheduler/cron/Cron.d.ts +19 -0
  502. package/src/scheduler/cron/Cron.d.ts.map +1 -0
  503. package/src/scheduler/cron/Cron.js +200 -0
  504. package/src/scheduler/leader/SchedulerLeader.d.ts +14 -0
  505. package/src/scheduler/leader/SchedulerLeader.d.ts.map +1 -0
  506. package/src/scheduler/leader/SchedulerLeader.js +187 -0
  507. package/src/scheduler/state/ScheduleStateStore.d.ts +27 -0
  508. package/src/scheduler/state/ScheduleStateStore.d.ts.map +1 -0
  509. package/src/scheduler/state/ScheduleStateStore.js +27 -0
  510. package/src/scheduler/types.d.ts +10 -0
  511. package/src/scheduler/types.d.ts.map +1 -1
  512. package/src/schedules/index.d.ts +1 -0
  513. package/src/schedules/index.d.ts.map +1 -1
  514. package/src/schedules/index.js +1 -0
  515. package/src/schedules/job-tracking-cleanup.d.ts +4 -0
  516. package/src/schedules/job-tracking-cleanup.d.ts.map +1 -0
  517. package/src/schedules/job-tracking-cleanup.js +116 -0
  518. package/src/schedules/log-cleanup.d.ts +1 -2
  519. package/src/schedules/log-cleanup.d.ts.map +1 -1
  520. package/src/schedules/log-cleanup.js +12 -15
  521. package/src/security/Sanitizer.d.ts.map +1 -1
  522. package/src/security/Sanitizer.js +1 -9
  523. package/src/security/SignedRequest.d.ts.map +1 -1
  524. package/src/security/SignedRequest.js +2 -2
  525. package/src/security/TokenRevocation.d.ts +19 -2
  526. package/src/security/TokenRevocation.d.ts.map +1 -1
  527. package/src/security/TokenRevocation.js +558 -30
  528. package/src/templates/docker/docker-compose.ecosystem.yml.tpl +301 -0
  529. package/src/templates/docker/docker-compose.schedules.yml.tpl +84 -0
  530. package/src/templates/project/basic/app/Controllers/AuthController.ts.tpl +11 -3
  531. package/src/templates/project/basic/app/Schedules/index.ts.tpl +0 -0
  532. package/src/templates/project/basic/config/database.ts.tpl +1 -1
  533. package/src/templates/project/basic/config/middleware.ts.tpl +23 -22
  534. package/src/templates/project/basic/wrangler.jsonc.tpl +28 -0
  535. package/src/toolkit/Secrets/Manifest.d.ts.map +1 -1
  536. package/src/toolkit/Secrets/Manifest.js +5 -7
  537. package/src/tools/mail/drivers/Smtp.d.ts.map +1 -1
  538. package/src/tools/mail/drivers/Smtp.js +7 -1
  539. package/src/tools/queue/JobReconciliationRunner.d.ts.map +1 -1
  540. package/src/tools/queue/JobReconciliationRunner.js +7 -39
  541. package/src/tools/queue/JobRecoveryDaemon.d.ts.map +1 -1
  542. package/src/tools/queue/JobRecoveryDaemon.js +116 -18
  543. package/src/tools/queue/JobStateTracker.d.ts +10 -1
  544. package/src/tools/queue/JobStateTracker.d.ts.map +1 -1
  545. package/src/tools/queue/JobStateTracker.js +24 -2
  546. package/src/tools/queue/JobStateTrackerDbPersistence.d.ts.map +1 -1
  547. package/src/tools/queue/JobStateTrackerDbPersistence.js +93 -2
@@ -0,0 +1,425 @@
1
+ /**
2
+ * Worker Auto-Scaler
3
+ * Automatic worker scaling based on queue depth, resource usage, and cost optimization
4
+ * Sealed namespace for immutability
5
+ */
6
+ import { ErrorFactory, Logger, workersConfig } from '../../../src/index.js';
7
+ // Internal state
8
+ let config = null;
9
+ let scalingInterval = null;
10
+ const lastScalingDecisions = new Map();
11
+ const scalingHistory = new Map();
12
+ // Cost tracking
13
+ let currentHourlyCost = 0;
14
+ let dailyCost = 0;
15
+ let weeklyCost = 0;
16
+ let monthlyCost = 0;
17
+ const lastCostReset = {
18
+ daily: new Date(),
19
+ weekly: new Date(),
20
+ monthly: new Date(),
21
+ };
22
+ /**
23
+ * Helper: Reset cost counters if period has passed
24
+ */
25
+ const resetCostCountersIfNeeded = () => {
26
+ const now = new Date();
27
+ // Daily reset (midnight UTC)
28
+ const lastDailyReset = new Date(lastCostReset.daily);
29
+ lastDailyReset.setUTCHours(0, 0, 0, 0);
30
+ const todayMidnight = new Date(now);
31
+ todayMidnight.setUTCHours(0, 0, 0, 0);
32
+ if (todayMidnight > lastDailyReset) {
33
+ dailyCost = 0;
34
+ lastCostReset.daily = now;
35
+ Logger.info('Daily cost counter reset');
36
+ }
37
+ // Weekly reset (Sunday midnight UTC)
38
+ const dayOfWeek = now.getUTCDay();
39
+ const lastWeeklyReset = new Date(lastCostReset.weekly);
40
+ const daysSinceLastReset = Math.floor((now.getTime() - lastWeeklyReset.getTime()) / (24 * 60 * 60 * 1000));
41
+ if (daysSinceLastReset >= 7 || (dayOfWeek === 0 && now.getUTCHours() === 0)) {
42
+ weeklyCost = 0;
43
+ lastCostReset.weekly = now;
44
+ Logger.info('Weekly cost counter reset');
45
+ }
46
+ // Monthly reset (1st of month midnight UTC)
47
+ if (now.getUTCDate() === 1 && now.getUTCDate() !== lastCostReset.monthly.getUTCDate()) {
48
+ monthlyCost = 0;
49
+ lastCostReset.monthly = now;
50
+ Logger.info('Monthly cost counter reset');
51
+ }
52
+ };
53
+ /**
54
+ * Helper: Check if in off-peak period
55
+ */
56
+ const isOffPeakPeriod = (schedule) => {
57
+ if (!schedule)
58
+ return false;
59
+ const now = new Date();
60
+ const timeStr = now.toLocaleTimeString('en-US', {
61
+ timeZone: schedule.timezone,
62
+ hour12: false,
63
+ hour: '2-digit',
64
+ minute: '2-digit',
65
+ });
66
+ const [currentHour, currentMinute] = timeStr.split(':').map(Number);
67
+ const currentMinutes = currentHour * 60 + currentMinute;
68
+ const [startHour, startMinute] = schedule.start.split(':').map(Number);
69
+ const startMinutes = startHour * 60 + startMinute;
70
+ const [endHour, endMinute] = schedule.end.split(':').map(Number);
71
+ const endMinutes = endHour * 60 + endMinute;
72
+ // Handle cases where period crosses midnight
73
+ if (startMinutes > endMinutes) {
74
+ return currentMinutes >= startMinutes || currentMinutes < endMinutes;
75
+ }
76
+ return currentMinutes >= startMinutes && currentMinutes < endMinutes;
77
+ };
78
+ /**
79
+ * Helper: Calculate scaling step based on aggressiveness
80
+ */
81
+ const calculateScalingStep = (currentConcurrency, aggressiveness) => {
82
+ const baseStep = Math.max(1, Math.ceil(currentConcurrency * 0.1)); // 10% of current
83
+ switch (aggressiveness) {
84
+ case 'conservative':
85
+ return Math.max(1, Math.ceil(baseStep * 0.5)); // 5% increase
86
+ case 'moderate':
87
+ return baseStep; // 10% increase
88
+ case 'aggressive':
89
+ return Math.ceil(baseStep * 2); // 20% increase
90
+ }
91
+ };
92
+ /**
93
+ * Helper: Check if cooldown period has passed
94
+ */
95
+ const canScale = (workerName, cooldownPeriod) => {
96
+ const lastDecision = lastScalingDecisions.get(workerName);
97
+ if (!lastDecision || lastDecision.action === 'no-change') {
98
+ return true;
99
+ }
100
+ const elapsedSeconds = (Date.now() - lastDecision.timestamp.getTime()) / 1000;
101
+ return elapsedSeconds >= cooldownPeriod;
102
+ };
103
+ /**
104
+ * Helper: Check budget constraints
105
+ */
106
+ const checkBudgetConstraints = (additionalCost) => {
107
+ if (config?.costOptimization?.enabled === undefined) {
108
+ return { allowed: true };
109
+ }
110
+ resetCostCountersIfNeeded();
111
+ const { budgetAlerts } = config.costOptimization;
112
+ // Check daily limit
113
+ if (dailyCost + additionalCost > budgetAlerts.dailyLimit) {
114
+ return {
115
+ allowed: false,
116
+ reason: `Would exceed daily budget: $${(dailyCost + additionalCost).toFixed(2)} > $${budgetAlerts.dailyLimit}`,
117
+ };
118
+ }
119
+ // Check weekly limit
120
+ if (weeklyCost + additionalCost > budgetAlerts.weeklyLimit) {
121
+ return {
122
+ allowed: false,
123
+ reason: `Would exceed weekly budget: $${(weeklyCost + additionalCost).toFixed(2)} > $${budgetAlerts.weeklyLimit}`,
124
+ };
125
+ }
126
+ // Check monthly limit
127
+ if (monthlyCost + additionalCost > budgetAlerts.monthlyLimit) {
128
+ return {
129
+ allowed: false,
130
+ reason: `Would exceed monthly budget: $${(monthlyCost + additionalCost).toFixed(2)} > $${budgetAlerts.monthlyLimit}`,
131
+ };
132
+ }
133
+ return { allowed: true };
134
+ };
135
+ /**
136
+ * Helper: Make scaling decision for a worker
137
+ */
138
+ const buildDecision = (workerName, action, currentConcurrency, targetConcurrency, reason, metrics) => ({
139
+ workerName,
140
+ action,
141
+ currentConcurrency,
142
+ targetConcurrency,
143
+ reason,
144
+ metrics,
145
+ timestamp: new Date(),
146
+ });
147
+ const getOffPeakDecision = (workerName, policy, currentConcurrency, metrics) => {
148
+ if (config?.costOptimization.enabled === undefined)
149
+ return null;
150
+ const schedule = config.costOptimization.offPeakSchedule;
151
+ if (!schedule || !isOffPeakPeriod(schedule))
152
+ return null;
153
+ const reductionPercentage = schedule.reductionPercentage;
154
+ const targetConcurrency = Math.max(policy.minConcurrency, Math.ceil(currentConcurrency * (1 - reductionPercentage / 100)));
155
+ if (targetConcurrency >= currentConcurrency)
156
+ return null;
157
+ return buildDecision(workerName, 'scale-down', currentConcurrency, targetConcurrency, `Off-peak reduction: ${reductionPercentage}%`, metrics);
158
+ };
159
+ const getScaleUpDecision = (workerName, policy, currentConcurrency, metrics) => {
160
+ const shouldScaleUp = metrics.queueDepth > policy.scaleUpThreshold.queueDepth ||
161
+ metrics.cpuUsage > policy.scaleUpThreshold.cpuUsage ||
162
+ metrics.memoryUsage > policy.scaleUpThreshold.memoryUsage;
163
+ if (!shouldScaleUp || currentConcurrency >= policy.maxConcurrency)
164
+ return null;
165
+ const step = calculateScalingStep(currentConcurrency, policy.aggressiveness);
166
+ const targetConcurrency = Math.min(policy.maxConcurrency, currentConcurrency + step);
167
+ const additionalCost = metrics.costPerHour * (targetConcurrency - currentConcurrency);
168
+ const budgetCheck = checkBudgetConstraints(additionalCost);
169
+ if (!budgetCheck.allowed) {
170
+ return buildDecision(workerName, 'no-change', currentConcurrency, currentConcurrency, budgetCheck.reason ?? 'Budget constraints prevent scale-up', metrics);
171
+ }
172
+ const reasons = [];
173
+ if (metrics.queueDepth > policy.scaleUpThreshold.queueDepth) {
174
+ reasons.push(`Queue depth: ${metrics.queueDepth} > ${policy.scaleUpThreshold.queueDepth}`);
175
+ }
176
+ if (metrics.cpuUsage > policy.scaleUpThreshold.cpuUsage) {
177
+ reasons.push(`CPU usage: ${metrics.cpuUsage}% > ${policy.scaleUpThreshold.cpuUsage}%`);
178
+ }
179
+ if (metrics.memoryUsage > policy.scaleUpThreshold.memoryUsage) {
180
+ reasons.push(`Memory usage: ${metrics.memoryUsage}% > ${policy.scaleUpThreshold.memoryUsage}%`);
181
+ }
182
+ return buildDecision(workerName, 'scale-up', currentConcurrency, targetConcurrency, reasons.join('; '), metrics);
183
+ };
184
+ const getScaleDownDecision = (workerName, policy, currentConcurrency, metrics) => {
185
+ const shouldScaleDown = metrics.queueDepth < policy.scaleDownThreshold.queueDepth &&
186
+ metrics.cpuUsage < policy.scaleDownThreshold.cpuUsage &&
187
+ metrics.memoryUsage < policy.scaleDownThreshold.memoryUsage;
188
+ if (!shouldScaleDown || currentConcurrency <= policy.minConcurrency)
189
+ return null;
190
+ const step = calculateScalingStep(currentConcurrency, policy.aggressiveness);
191
+ const targetConcurrency = Math.max(policy.minConcurrency, currentConcurrency - step);
192
+ return buildDecision(workerName, 'scale-down', currentConcurrency, targetConcurrency, `Low utilization: Queue=${metrics.queueDepth}, CPU=${metrics.cpuUsage}%, Mem=${metrics.memoryUsage}%`, metrics);
193
+ };
194
+ const makeScalingDecision = (workerName, workerConfig, metrics) => {
195
+ if (!config) {
196
+ throw ErrorFactory.createGeneralError('AutoScaler not configured');
197
+ }
198
+ const policy = config.scalingPolicies.get(workerName) ?? getDefaultScalingPolicy(workerConfig);
199
+ const currentConcurrency = workerConfig.concurrency ?? 1;
200
+ if (!canScale(workerName, policy.cooldownPeriod)) {
201
+ return buildDecision(workerName, 'no-change', currentConcurrency, currentConcurrency, 'Cooldown period not elapsed', metrics);
202
+ }
203
+ const offPeakDecision = getOffPeakDecision(workerName, policy, currentConcurrency, metrics);
204
+ if (offPeakDecision)
205
+ return offPeakDecision;
206
+ const scaleUpDecision = getScaleUpDecision(workerName, policy, currentConcurrency, metrics);
207
+ if (scaleUpDecision)
208
+ return scaleUpDecision;
209
+ const scaleDownDecision = getScaleDownDecision(workerName, policy, currentConcurrency, metrics);
210
+ if (scaleDownDecision)
211
+ return scaleDownDecision;
212
+ return buildDecision(workerName, 'no-change', currentConcurrency, currentConcurrency, 'Metrics within acceptable range', metrics);
213
+ };
214
+ /**
215
+ * Helper: Get default scaling policy from worker config
216
+ */
217
+ const getDefaultScalingPolicy = (workerConfig) => {
218
+ const autoScaling = workerConfig.autoScaling;
219
+ return {
220
+ minConcurrency: autoScaling?.minConcurrency ?? 1,
221
+ maxConcurrency: autoScaling?.maxConcurrency ?? 10,
222
+ scaleUpThreshold: {
223
+ queueDepth: autoScaling?.scaleUpThreshold ?? 100,
224
+ cpuUsage: 70,
225
+ memoryUsage: 80,
226
+ },
227
+ scaleDownThreshold: {
228
+ queueDepth: autoScaling?.scaleDownThreshold ?? 10,
229
+ cpuUsage: 30,
230
+ memoryUsage: 40,
231
+ },
232
+ cooldownPeriod: autoScaling?.cooldownPeriod ?? 300, // 5 minutes
233
+ aggressiveness: 'moderate',
234
+ };
235
+ };
236
+ /**
237
+ * Helper: Record scaling decision
238
+ */
239
+ const recordScalingDecision = (decision) => {
240
+ lastScalingDecisions.set(decision.workerName, decision);
241
+ // Add to history
242
+ let history = scalingHistory.get(decision.workerName);
243
+ if (!history) {
244
+ history = [];
245
+ scalingHistory.set(decision.workerName, history);
246
+ }
247
+ history.push(decision);
248
+ // Keep only last 1000 decisions
249
+ if (history.length > 1000) {
250
+ history.shift();
251
+ }
252
+ // Update cost tracking
253
+ if (decision.action === 'scale-up') {
254
+ const additionalCost = decision.metrics.costPerHour * (decision.targetConcurrency - decision.currentConcurrency);
255
+ currentHourlyCost += additionalCost;
256
+ dailyCost += additionalCost;
257
+ weeklyCost += additionalCost;
258
+ monthlyCost += additionalCost;
259
+ }
260
+ };
261
+ /**
262
+ * Worker Auto-Scaler - Sealed namespace
263
+ */
264
+ export const AutoScaler = Object.freeze({
265
+ /**
266
+ * Initialize auto-scaler with configuration
267
+ */
268
+ initialize(autoScalerConfig) {
269
+ if (config) {
270
+ Logger.warn('AutoScaler already initialized');
271
+ return;
272
+ }
273
+ config = autoScalerConfig;
274
+ if (config.enabled) {
275
+ AutoScaler.start();
276
+ }
277
+ Logger.info('AutoScaler initialized', { enabled: config.enabled });
278
+ },
279
+ /**
280
+ * Start auto-scaling checks
281
+ */
282
+ start() {
283
+ if (!config) {
284
+ throw ErrorFactory.createConfigError('AutoScaler not initialized');
285
+ }
286
+ if (scalingInterval) {
287
+ Logger.warn('AutoScaler already running');
288
+ return;
289
+ }
290
+ if (!config.enabled) {
291
+ Logger.warn('AutoScaler is disabled in config');
292
+ return;
293
+ }
294
+ scalingInterval = setInterval(() => {
295
+ // Scaling checks will be triggered externally via evaluate()
296
+ // This interval is just a keepalive
297
+ }, config.checkInterval * 1000);
298
+ Logger.info('AutoScaler started', { checkInterval: config.checkInterval });
299
+ },
300
+ /**
301
+ * Stop auto-scaling checks
302
+ */
303
+ stop() {
304
+ if (scalingInterval) {
305
+ clearInterval(scalingInterval);
306
+ scalingInterval = null;
307
+ Logger.info('AutoScaler stopped');
308
+ }
309
+ },
310
+ /**
311
+ * Evaluate scaling decision for a worker
312
+ */
313
+ evaluate(workerName, metrics) {
314
+ if (!config) {
315
+ throw ErrorFactory.createConfigError('AutoScaler not initialized');
316
+ }
317
+ const workerConfig = workersConfig.defaultWorker;
318
+ const decision = makeScalingDecision(workerName, workerConfig, metrics);
319
+ recordScalingDecision(decision);
320
+ if (decision.action !== 'no-change') {
321
+ Logger.info(`Scaling decision for ${workerName}`, {
322
+ action: decision.action,
323
+ from: decision.currentConcurrency,
324
+ to: decision.targetConcurrency,
325
+ reason: decision.reason,
326
+ });
327
+ }
328
+ return decision;
329
+ },
330
+ /**
331
+ * Get last scaling decision
332
+ */
333
+ getLastDecision(workerName) {
334
+ return lastScalingDecisions.get(workerName) ?? null;
335
+ },
336
+ /**
337
+ * Get scaling history
338
+ */
339
+ getHistory(workerName, limit = 100) {
340
+ const history = scalingHistory.get(workerName) ?? [];
341
+ return history.slice(-limit);
342
+ },
343
+ /**
344
+ * Clear scaling history for a worker
345
+ */
346
+ clearHistory(workerName) {
347
+ lastScalingDecisions.delete(workerName);
348
+ scalingHistory.delete(workerName);
349
+ Logger.info(`Cleared auto-scaling history for ${workerName}`);
350
+ },
351
+ /**
352
+ * Get cost summary
353
+ */
354
+ getCostSummary() {
355
+ if (config?.costOptimization.enabled === undefined) {
356
+ return {
357
+ currentHourlyCost: 0,
358
+ dailyCost: 0,
359
+ weeklyCost: 0,
360
+ monthlyCost: 0,
361
+ budgetLimits: { dailyLimit: 0, weeklyLimit: 0, monthlyLimit: 0 },
362
+ utilizationPercentage: { daily: 0, weekly: 0, monthly: 0 },
363
+ };
364
+ }
365
+ resetCostCountersIfNeeded();
366
+ const { budgetAlerts } = config.costOptimization;
367
+ return {
368
+ currentHourlyCost,
369
+ dailyCost,
370
+ weeklyCost,
371
+ monthlyCost,
372
+ budgetLimits: budgetAlerts,
373
+ utilizationPercentage: {
374
+ daily: (dailyCost / budgetAlerts.dailyLimit) * 100,
375
+ weekly: (weeklyCost / budgetAlerts.weeklyLimit) * 100,
376
+ monthly: (monthlyCost / budgetAlerts.monthlyLimit) * 100,
377
+ },
378
+ };
379
+ },
380
+ /**
381
+ * Set scaling policy for a worker
382
+ */
383
+ setScalingPolicy(workerName, policy) {
384
+ if (!config) {
385
+ throw ErrorFactory.createWorkerError('AutoScaler not initialized');
386
+ }
387
+ config.scalingPolicies.set(workerName, policy);
388
+ Logger.info(`Updated scaling policy for ${workerName}`);
389
+ },
390
+ /**
391
+ * Get scaling policy for a worker
392
+ */
393
+ getScalingPolicy(workerName) {
394
+ if (!config) {
395
+ return null;
396
+ }
397
+ return config.scalingPolicies.get(workerName) ?? null;
398
+ },
399
+ /**
400
+ * Check if currently in off-peak period
401
+ */
402
+ isOffPeak() {
403
+ if (config?.costOptimization.enabled === undefined) {
404
+ return false;
405
+ }
406
+ return isOffPeakPeriod(config.costOptimization.offPeakSchedule);
407
+ },
408
+ /**
409
+ * Get configuration
410
+ */
411
+ getConfig() {
412
+ return config ? { ...config } : null;
413
+ },
414
+ /**
415
+ * Shutdown
416
+ */
417
+ shutdown() {
418
+ AutoScaler.stop();
419
+ config = null;
420
+ lastScalingDecisions.clear();
421
+ scalingHistory.clear();
422
+ Logger.info('AutoScaler shutdown complete');
423
+ },
424
+ });
425
+ // Graceful shutdown handled by WorkerShutdown
@@ -0,0 +1,24 @@
1
+ /**
2
+ * BroadcastWorker - Processes queued broadcasts
3
+ *
4
+ * This worker dequeues broadcast messages and sends them using the Broadcast service.
5
+ * Use with Queue.dequeue() in a background process or cron job.
6
+ */
7
+ export declare const BroadcastWorker: Readonly<{
8
+ processOne: (queueName?: string, driverName?: string) => Promise<boolean>;
9
+ processAll: (queueName?: string, driverName?: string) => Promise<number>;
10
+ runOnce: (opts?: {
11
+ queueName?: string;
12
+ driverName?: string;
13
+ maxItems?: number;
14
+ maxDurationMs?: number;
15
+ }) => Promise<number>;
16
+ startWorker: (opts?: {
17
+ queueName?: string;
18
+ driverName?: string;
19
+ signal?: AbortSignal;
20
+ maxDurationMs?: number;
21
+ }) => Promise<number>;
22
+ }>;
23
+ export default BroadcastWorker;
24
+ //# sourceMappingURL=BroadcastWorker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BroadcastWorker.d.ts","sourceRoot":"","sources":["../../../../packages/workers/src/BroadcastWorker.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAYH,eAAO,MAAM,eAAe;0BAiBugF,CAAC,oBAAoB,CAAC;0BAAuD,CAAC,oBAAoB,CAAC;kBAA8C,CAAC;iBAAiB,CAAC;kBAAwB,CAAC;gBAAsB,CAAC;qBAA2B,CAAC;;sBAAuD,CAAC;iBAAiB,CAAC;kBAAwB,CAAC;cAAoB,CAAC;qBAAgC,CAAC;;EAH16F,CAAC;AAEH,eAAe,eAAe,CAAC"}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * BroadcastWorker - Processes queued broadcasts
3
+ *
4
+ * This worker dequeues broadcast messages and sends them using the Broadcast service.
5
+ * Use with Queue.dequeue() in a background process or cron job.
6
+ */
7
+ import { Broadcast } from '../../../src/index.js';
8
+ import { createQueueWorker } from './createQueueWorker.js';
9
+ export const BroadcastWorker = Object.freeze({
10
+ ...createQueueWorker({
11
+ kindLabel: 'broadcast',
12
+ defaultQueueName: 'broadcasts',
13
+ maxAttempts: 3,
14
+ getLogFields: (payload) => ({
15
+ channel: payload.channel,
16
+ event: payload.event,
17
+ queuedAt: payload.timestamp,
18
+ }),
19
+ handle: async (payload) => {
20
+ await Broadcast.send(payload.channel, payload.event, payload.data);
21
+ },
22
+ }),
23
+ });
24
+ export default BroadcastWorker;
@@ -0,0 +1,104 @@
1
+ /**
2
+ * Canary Deployment Controller
3
+ * Gradual rollout with traffic percentage control and automatic rollback
4
+ * Sealed namespace for immutability
5
+ */
6
+ export type CanaryStage = 'initial' | 'ramping' | 'monitoring' | 'completed' | 'rolling-back' | 'failed';
7
+ export type CanaryDeploymentConfig = {
8
+ workerName: string;
9
+ currentVersion: string;
10
+ canaryVersion: string;
11
+ initialTrafficPercent: number;
12
+ targetTrafficPercent: number;
13
+ incrementPercent: number;
14
+ incrementInterval: number;
15
+ monitoringDuration: number;
16
+ errorThreshold: number;
17
+ latencyThreshold: number;
18
+ minSuccessRate: number;
19
+ autoRollback: boolean;
20
+ };
21
+ export type CanaryDeployment = {
22
+ config: CanaryDeploymentConfig;
23
+ currentTrafficPercent: number;
24
+ stage: CanaryStage;
25
+ startedAt: Date;
26
+ completedAt?: Date;
27
+ metrics: {
28
+ currentVersion: {
29
+ processed: number;
30
+ errors: number;
31
+ avgLatency: number;
32
+ };
33
+ canaryVersion: {
34
+ processed: number;
35
+ errors: number;
36
+ avgLatency: number;
37
+ };
38
+ };
39
+ history: Array<{
40
+ timestamp: Date;
41
+ trafficPercent: number;
42
+ stage: CanaryStage;
43
+ metrics: CanaryDeployment['metrics'];
44
+ decision: string;
45
+ }>;
46
+ };
47
+ /**
48
+ * Canary Deployment Controller - Sealed namespace
49
+ */
50
+ export declare const CanaryController: Readonly<{
51
+ /**
52
+ * Start canary deployment
53
+ */
54
+ start(config: CanaryDeploymentConfig): void;
55
+ /**
56
+ * Pause canary deployment
57
+ */
58
+ pause(workerName: string): void;
59
+ /**
60
+ * Resume canary deployment
61
+ */
62
+ resume(workerName: string): void;
63
+ /**
64
+ * Complete canary deployment
65
+ */
66
+ complete(workerName: string): void;
67
+ /**
68
+ * Rollback canary deployment
69
+ */
70
+ rollback(workerName: string, reason: string): void;
71
+ /**
72
+ * Get canary deployment status
73
+ */
74
+ getStatus(workerName: string): CanaryDeployment | null;
75
+ /**
76
+ * Update metrics for canary deployment
77
+ */
78
+ updateMetrics(workerName: string, version: string, processed: number, errors: number, avgLatency: number): void;
79
+ /**
80
+ * Route job to version based on traffic percentage
81
+ */
82
+ routeJob(workerName: string): string | null;
83
+ /**
84
+ * List all canary deployments
85
+ */
86
+ listDeployments(): string[];
87
+ /**
88
+ * Get deployment history
89
+ */
90
+ getHistory(workerName: string): CanaryDeployment["history"] | null;
91
+ /**
92
+ * Remove completed/failed deployment
93
+ */
94
+ remove(workerName: string): void;
95
+ /**
96
+ * Purge deployment data (force cleanup)
97
+ */
98
+ purge(workerName: string): void;
99
+ /**
100
+ * Shutdown all canary deployments
101
+ */
102
+ shutdown(): void;
103
+ }>;
104
+ //# sourceMappingURL=CanaryController.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CanaryController.d.ts","sourceRoot":"","sources":["../../../../packages/workers/src/CanaryController.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,MAAM,MAAM,WAAW,GACnB,SAAS,GACT,SAAS,GACT,YAAY,GACZ,WAAW,GACX,cAAc,GACd,QAAQ,CAAC;AAEb,MAAM,MAAM,sBAAsB,GAAG;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,gBAAgB,EAAE,MAAM,CAAC;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,MAAM,EAAE,sBAAsB,CAAC;IAC/B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,KAAK,EAAE,WAAW,CAAC;IACnB,SAAS,EAAE,IAAI,CAAC;IAChB,WAAW,CAAC,EAAE,IAAI,CAAC;IACnB,OAAO,EAAE;QACP,cAAc,EAAE;YACd,SAAS,EAAE,MAAM,CAAC;YAClB,MAAM,EAAE,MAAM,CAAC;YACf,UAAU,EAAE,MAAM,CAAC;SACpB,CAAC;QACF,aAAa,EAAE;YACb,SAAS,EAAE,MAAM,CAAC;YAClB,MAAM,EAAE,MAAM,CAAC;YACf,UAAU,EAAE,MAAM,CAAC;SACpB,CAAC;KACH,CAAC;IACF,OAAO,EAAE,KAAK,CAAC;QACb,SAAS,EAAE,IAAI,CAAC;QAChB,cAAc,EAAE,MAAM,CAAC;QACvB,KAAK,EAAE,WAAW,CAAC;QACnB,OAAO,EAAE,gBAAgB,CAAC,SAAS,CAAC,CAAC;QACrC,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC,CAAC;CACJ,CAAC;AAwKF;;GAEG;AACH,eAAO,MAAM,gBAAgB;IAC3B;;OAEG;kBACW,sBAAsB,GAAG,IAAI;IAwE3C;;OAEG;sBACe,MAAM,GAAG,IAAI;IAiB/B;;OAEG;uBACgB,MAAM,GAAG,IAAI;IAiChC;;OAEG;yBACkB,MAAM,GAAG,IAAI;IAsClC;;OAEG;yBACkB,MAAM,UAAU,MAAM,GAAG,IAAI;IAqClD;;OAEG;0BACmB,MAAM,GAAG,gBAAgB,GAAG,IAAI;IAKtD;;OAEG;8BAEW,MAAM,WACT,MAAM,aACJ,MAAM,UACT,MAAM,cACF,MAAM,GACjB,IAAI;IAcP;;OAEG;yBACkB,MAAM,GAAG,MAAM,GAAG,IAAI;IAiB3C;;OAEG;uBACgB,MAAM,EAAE;IAI3B;;OAEG;2BACoB,MAAM,GAAG,gBAAgB,CAAC,SAAS,CAAC,GAAG,IAAI;IAKlE;;OAEG;uBACgB,MAAM,GAAG,IAAI;IAkBhC;;OAEG;sBACe,MAAM,GAAG,IAAI;IAiB/B;;OAEG;gBACS,IAAI;EAahB,CAAC"}