@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,404 @@
1
+ /**
2
+ * Datacenter Orchestration
3
+ * Multi-datacenter worker coordination with region affinity and failover
4
+ * Sealed namespace for immutability
5
+ */
6
+ import { ErrorFactory, Logger } from '../../../src/index.js';
7
+ import { ClusterLock } from './ClusterLock.js';
8
+ // Internal state
9
+ const regions = new Map();
10
+ const workerPlacements = new Map();
11
+ const failoverPolicies = new Map();
12
+ const healthCheckIntervals = new Map();
13
+ /**
14
+ * Helper: Calculate distance between two coordinates (Haversine formula)
15
+ */
16
+ const calculateDistance = (lat1, lng1, lat2, lng2) => {
17
+ const R = 6371; // Earth's radius in km
18
+ const dLat = ((lat2 - lat1) * Math.PI) / 180;
19
+ const dLng = ((lng2 - lng1) * Math.PI) / 180;
20
+ const a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
21
+ Math.cos((lat1 * Math.PI) / 180) *
22
+ Math.cos((lat2 * Math.PI) / 180) *
23
+ Math.sin(dLng / 2) *
24
+ Math.sin(dLng / 2);
25
+ const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
26
+ return R * c;
27
+ };
28
+ /**
29
+ * Helper: Find optimal region for placement
30
+ */
31
+ const findOptimalRegion = (placement, clientRegion) => {
32
+ const candidateRegions = [placement.primaryRegion, ...placement.secondaryRegions];
33
+ const healthyRegions = candidateRegions.filter((regionId) => {
34
+ const region = regions.get(regionId);
35
+ return region?.healthStatus === 'healthy' && region.currentLoad < region.capacity;
36
+ });
37
+ if (healthyRegions.length === 0) {
38
+ return null;
39
+ }
40
+ // If client region specified and local preference enabled
41
+ if (placement.affinityRules.preferLocal &&
42
+ typeof clientRegion === 'string' &&
43
+ clientRegion.length > 0) {
44
+ if (healthyRegions.includes(clientRegion)) {
45
+ return clientRegion;
46
+ }
47
+ }
48
+ // Sort by priority, then by current load (lower is better)
49
+ healthyRegions.sort((a, b) => {
50
+ const regionA = regions.get(a);
51
+ const regionB = regions.get(b);
52
+ if (!regionA || !regionB) {
53
+ return 0;
54
+ }
55
+ if (regionA.priority !== regionB.priority) {
56
+ return regionB.priority - regionA.priority;
57
+ }
58
+ const loadA = regionA.currentLoad / regionA.capacity;
59
+ const loadB = regionB.currentLoad / regionB.capacity;
60
+ return loadA - loadB;
61
+ });
62
+ return healthyRegions[0];
63
+ };
64
+ /**
65
+ * Helper: Perform health check for region
66
+ */
67
+ const performHealthCheck = async (regionId) => {
68
+ const region = regions.get(regionId);
69
+ if (!region) {
70
+ return;
71
+ }
72
+ try {
73
+ // Check if region can acquire lock (indicates healthy Redis connection)
74
+ const lockKey = `health:${regionId}`;
75
+ const acquired = await ClusterLock.acquire({
76
+ lockKey,
77
+ ttl: 5,
78
+ region: regionId,
79
+ userId: regionId,
80
+ });
81
+ if (acquired) {
82
+ await ClusterLock.release(lockKey, regionId);
83
+ // Update health status
84
+ if (region.healthStatus === 'offline') {
85
+ region.healthStatus = 'healthy';
86
+ Logger.info(`Region recovered: ${regionId}`);
87
+ }
88
+ }
89
+ }
90
+ catch (error) {
91
+ Logger.error(`Health check failed for region: ${regionId}`, error);
92
+ region.healthStatus = 'offline';
93
+ // Trigger failover if enabled
94
+ const policy = failoverPolicies.get(regionId);
95
+ if (policy?.enabled === true && policy.autoFailover) {
96
+ triggerFailover(regionId);
97
+ }
98
+ }
99
+ };
100
+ /**
101
+ * Helper: Trigger failover from unhealthy region
102
+ */
103
+ const triggerFailover = (failedRegionId) => {
104
+ Logger.warn(`Triggering failover from region: ${failedRegionId}`);
105
+ // Find all workers placed in failed region
106
+ const affectedWorkers = [];
107
+ for (const [workerName, placement] of workerPlacements.entries()) {
108
+ if (placement.primaryRegion === failedRegionId) {
109
+ affectedWorkers.push(workerName);
110
+ }
111
+ }
112
+ // Reassign workers to healthy regions
113
+ for (const workerName of affectedWorkers) {
114
+ const placement = workerPlacements.get(workerName);
115
+ if (!placement) {
116
+ continue;
117
+ }
118
+ const newRegion = findOptimalRegion(placement);
119
+ if (newRegion === null) {
120
+ Logger.error(`Failover failed: No healthy region available for worker`, {
121
+ workerName,
122
+ failedRegion: failedRegionId,
123
+ });
124
+ continue;
125
+ }
126
+ Logger.info(`Failover: Moving worker from ${failedRegionId} to ${newRegion}`, {
127
+ workerName,
128
+ });
129
+ // Update placement (would trigger actual worker migration in real implementation)
130
+ placement.primaryRegion = newRegion;
131
+ }
132
+ };
133
+ /**
134
+ * Datacenter Orchestrator - Sealed namespace
135
+ */
136
+ export const DatacenterOrchestrator = Object.freeze({
137
+ /**
138
+ * Register datacenter region
139
+ */
140
+ registerRegion(region) {
141
+ if (regions.has(region.id)) {
142
+ throw ErrorFactory.createConfigError(`Region "${region.id}" already registered`);
143
+ }
144
+ regions.set(region.id, { ...region });
145
+ Logger.info(`Datacenter region registered: ${region.id}`, {
146
+ location: `${region.location.city}, ${region.location.country}`,
147
+ capacity: region.capacity,
148
+ });
149
+ },
150
+ /**
151
+ * Unregister datacenter region
152
+ */
153
+ unregisterRegion(regionId) {
154
+ const region = regions.get(regionId);
155
+ if (!region) {
156
+ throw ErrorFactory.createNotFoundError(`Region "${regionId}" not found`);
157
+ }
158
+ // Check if any workers are still placed in this region
159
+ const hasWorkers = Array.from(workerPlacements.values()).some((p) => p.primaryRegion === regionId || p.secondaryRegions.includes(regionId));
160
+ if (hasWorkers) {
161
+ throw ErrorFactory.createValidationError(`Cannot unregister region with active workers: ${regionId}`);
162
+ }
163
+ regions.delete(regionId);
164
+ // Stop health checks
165
+ const interval = healthCheckIntervals.get(regionId);
166
+ if (interval) {
167
+ clearInterval(interval);
168
+ healthCheckIntervals.delete(regionId);
169
+ }
170
+ Logger.info(`Datacenter region unregistered: ${regionId}`);
171
+ },
172
+ /**
173
+ * Get region information
174
+ */
175
+ getRegion(regionId) {
176
+ const region = regions.get(regionId);
177
+ return region ? { ...region } : null;
178
+ },
179
+ /**
180
+ * List all regions
181
+ */
182
+ listRegions(healthStatus) {
183
+ const allRegions = Array.from(regions.values());
184
+ if (healthStatus) {
185
+ return allRegions.filter((r) => r.healthStatus === healthStatus);
186
+ }
187
+ return allRegions;
188
+ },
189
+ /**
190
+ * Update region health status
191
+ */
192
+ updateRegionHealth(regionId, healthStatus) {
193
+ const region = regions.get(regionId);
194
+ if (!region) {
195
+ throw ErrorFactory.createNotFoundError(`Region "${regionId}" not found`);
196
+ }
197
+ const oldStatus = region.healthStatus;
198
+ region.healthStatus = healthStatus;
199
+ Logger.info(`Region health updated: ${regionId}`, {
200
+ oldStatus,
201
+ newStatus: healthStatus,
202
+ });
203
+ // Trigger failover if region went offline
204
+ if (healthStatus === 'offline' && oldStatus !== 'offline') {
205
+ const policy = failoverPolicies.get(regionId);
206
+ if (policy?.enabled === true && policy.autoFailover) {
207
+ triggerFailover(regionId);
208
+ }
209
+ }
210
+ },
211
+ /**
212
+ * Update region load
213
+ */
214
+ updateRegionLoad(regionId, currentLoad) {
215
+ const region = regions.get(regionId);
216
+ if (!region) {
217
+ throw ErrorFactory.createNotFoundError(`Region "${regionId}" not found`);
218
+ }
219
+ region.currentLoad = currentLoad;
220
+ // Check if region is overloaded
221
+ if (currentLoad > region.capacity * 0.9) {
222
+ Logger.warn(`Region approaching capacity: ${regionId}`, {
223
+ currentLoad,
224
+ capacity: region.capacity,
225
+ });
226
+ region.healthStatus = 'degraded';
227
+ }
228
+ else if (region.healthStatus === 'degraded' && currentLoad < region.capacity * 0.7) {
229
+ region.healthStatus = 'healthy';
230
+ }
231
+ },
232
+ /**
233
+ * Place worker in datacenter
234
+ */
235
+ placeWorker(placement) {
236
+ if (workerPlacements.has(placement.workerName)) {
237
+ throw ErrorFactory.createConfigError(`Worker "${placement.workerName}" already has a placement`);
238
+ }
239
+ // Validate regions exist
240
+ const allRegions = [placement.primaryRegion, ...placement.secondaryRegions];
241
+ for (const regionId of allRegions) {
242
+ if (!regions.has(regionId)) {
243
+ throw ErrorFactory.createNotFoundError(`Region "${regionId}" not found`);
244
+ }
245
+ }
246
+ workerPlacements.set(placement.workerName, { ...placement });
247
+ Logger.info(`Worker placed in datacenter: ${placement.workerName}`, {
248
+ primaryRegion: placement.primaryRegion,
249
+ secondaryRegions: placement.secondaryRegions,
250
+ });
251
+ },
252
+ /**
253
+ * Get worker placement
254
+ */
255
+ getPlacement(workerName) {
256
+ const placement = workerPlacements.get(workerName);
257
+ return placement ? { ...placement } : null;
258
+ },
259
+ /**
260
+ * Update worker placement
261
+ */
262
+ updatePlacement(workerName, updates) {
263
+ const placement = workerPlacements.get(workerName);
264
+ if (!placement) {
265
+ throw ErrorFactory.createNotFoundError(`Placement not found for worker "${workerName}"`);
266
+ }
267
+ Object.assign(placement, updates);
268
+ Logger.info(`Worker placement updated: ${workerName}`);
269
+ },
270
+ /**
271
+ * Remove worker placement
272
+ */
273
+ removeWorker(workerName) {
274
+ if (!workerPlacements.has(workerName)) {
275
+ return;
276
+ }
277
+ workerPlacements.delete(workerName);
278
+ Logger.info(`Worker placement removed: ${workerName}`);
279
+ },
280
+ /**
281
+ * Find optimal region for job execution
282
+ */
283
+ findOptimalRegion(workerName, clientRegion) {
284
+ const placement = workerPlacements.get(workerName);
285
+ if (!placement) {
286
+ throw ErrorFactory.createNotFoundError(`Placement not found for worker "${workerName}"`);
287
+ }
288
+ return findOptimalRegion(placement, clientRegion);
289
+ },
290
+ /**
291
+ * Set failover policy for region
292
+ */
293
+ setFailoverPolicy(regionId, policy) {
294
+ const region = regions.get(regionId);
295
+ if (!region) {
296
+ throw ErrorFactory.createNotFoundError(`Region "${regionId}" not found`);
297
+ }
298
+ failoverPolicies.set(regionId, { ...policy });
299
+ // Start health checks if enabled
300
+ if (policy.enabled) {
301
+ DatacenterOrchestrator.startHealthChecks(regionId, policy.healthCheckInterval);
302
+ }
303
+ Logger.info(`Failover policy set for region: ${regionId}`, {
304
+ autoFailover: policy.autoFailover,
305
+ });
306
+ },
307
+ /**
308
+ * Get failover policy
309
+ */
310
+ getFailoverPolicy(regionId) {
311
+ const policy = failoverPolicies.get(regionId);
312
+ return policy ? { ...policy } : null;
313
+ },
314
+ /**
315
+ * Start health checks for region
316
+ */
317
+ startHealthChecks(regionId, intervalSeconds) {
318
+ // Clear existing interval
319
+ const existing = healthCheckIntervals.get(regionId);
320
+ if (existing) {
321
+ clearInterval(existing);
322
+ }
323
+ // Start new interval
324
+ const interval = setInterval(() => {
325
+ performHealthCheck(regionId);
326
+ }, intervalSeconds * 1000);
327
+ healthCheckIntervals.set(regionId, interval);
328
+ Logger.info(`Health checks started for region: ${regionId}`, {
329
+ interval: intervalSeconds,
330
+ });
331
+ },
332
+ /**
333
+ * Stop health checks for region
334
+ */
335
+ stopHealthChecks(regionId) {
336
+ const interval = healthCheckIntervals.get(regionId);
337
+ if (interval) {
338
+ clearInterval(interval);
339
+ healthCheckIntervals.delete(regionId);
340
+ Logger.info(`Health checks stopped for region: ${regionId}`);
341
+ }
342
+ },
343
+ /**
344
+ * Get datacenter topology
345
+ */
346
+ getTopology() {
347
+ const regionList = Array.from(regions.values());
348
+ const connections = [];
349
+ // Calculate latencies between regions based on distance
350
+ for (let i = 0; i < regionList.length; i++) {
351
+ for (let j = i + 1; j < regionList.length; j++) {
352
+ const from = regionList[i];
353
+ const to = regionList[j];
354
+ if (from.location.coordinates && to.location.coordinates) {
355
+ const distance = calculateDistance(from.location.coordinates.lat, from.location.coordinates.lng, to.location.coordinates.lat, to.location.coordinates.lng);
356
+ // Rough estimate: 1ms per 100km + base latency
357
+ const latency = Math.round(distance / 100) + 10;
358
+ connections.push({
359
+ from: from.id,
360
+ to: to.id,
361
+ latency,
362
+ bandwidth: 10000, // 10 Gbps default
363
+ });
364
+ }
365
+ }
366
+ }
367
+ return {
368
+ regions: regionList,
369
+ connections,
370
+ };
371
+ },
372
+ /**
373
+ * Get load balancing recommendation
374
+ */
375
+ getLoadBalancingRecommendation() {
376
+ const regionList = Array.from(regions.values()).filter((r) => r.healthStatus === 'healthy');
377
+ const totalCapacity = regionList.reduce((sum, r) => sum + r.capacity, 0);
378
+ return regionList.map((region) => {
379
+ const idealLoad = (region.capacity / totalCapacity) * 100;
380
+ const currentLoadPercent = (region.currentLoad / region.capacity) * 100;
381
+ const recommendedAdjustment = idealLoad - currentLoadPercent;
382
+ return {
383
+ regionId: region.id,
384
+ recommendedLoad: Math.max(0, region.currentLoad + recommendedAdjustment),
385
+ };
386
+ });
387
+ },
388
+ /**
389
+ * Shutdown datacenter orchestrator
390
+ */
391
+ shutdown() {
392
+ Logger.info('DatacenterOrchestrator shutting down...');
393
+ // Stop all health checks
394
+ for (const interval of healthCheckIntervals.values()) {
395
+ clearInterval(interval);
396
+ }
397
+ healthCheckIntervals.clear();
398
+ regions.clear();
399
+ workerPlacements.clear();
400
+ failoverPolicies.clear();
401
+ Logger.info('DatacenterOrchestrator shutdown complete');
402
+ },
403
+ });
404
+ // Graceful shutdown handled by WorkerShutdown
@@ -0,0 +1,123 @@
1
+ /**
2
+ * Dead Letter Queue Manager
3
+ * Failed job handling with compliance tracking (GDPR/HIPAA/SOC2)
4
+ * Sealed namespace for immutability
5
+ */
6
+ import { type RedisConfig } from '../../../src/index.js';
7
+ export type FailedJobEntry = {
8
+ id: string;
9
+ queueName: string;
10
+ workerName: string;
11
+ jobName: string;
12
+ data: unknown;
13
+ error: {
14
+ message: string;
15
+ stack?: string;
16
+ name: string;
17
+ };
18
+ attemptsMade: number;
19
+ maxAttempts: number;
20
+ failedAt: Date;
21
+ firstAttemptAt: Date;
22
+ lastAttemptAt: Date;
23
+ processingTime: number;
24
+ metadata: {
25
+ version?: string;
26
+ region?: string;
27
+ instanceId?: string;
28
+ };
29
+ complianceFlags: {
30
+ containsPII: boolean;
31
+ containsPHI: boolean;
32
+ dataClassification: 'public' | 'internal' | 'confidential' | 'restricted';
33
+ };
34
+ };
35
+ export type ComplianceAuditEntry = {
36
+ timestamp: Date;
37
+ action: 'access' | 'retry' | 'delete' | 'export' | 'anonymize';
38
+ failedJobId: string;
39
+ userId: string;
40
+ userRole?: string;
41
+ reason: string;
42
+ ipAddress?: string;
43
+ dataAccessed?: string[];
44
+ result: 'success' | 'failure';
45
+ errorMessage?: string;
46
+ };
47
+ export type RetentionPolicy = {
48
+ enabled: boolean;
49
+ defaultRetentionDays: number;
50
+ gdprCompliant: boolean;
51
+ hipaaCompliant: boolean;
52
+ soc2Compliant: boolean;
53
+ autoDeleteAfterDays?: number;
54
+ anonymizeInsteadOfDelete: boolean;
55
+ };
56
+ export type DLQStats = {
57
+ totalFailed: number;
58
+ byQueue: Record<string, number>;
59
+ byWorker: Record<string, number>;
60
+ byErrorType: Record<string, number>;
61
+ oldestFailure: Date | null;
62
+ newestFailure: Date | null;
63
+ averageAttempts: number;
64
+ retentionViolations: number;
65
+ };
66
+ /**
67
+ * Dead Letter Queue Manager - Sealed namespace
68
+ */
69
+ export declare const DeadLetterQueue: Readonly<{
70
+ /**
71
+ * Initialize DLQ with Redis and retention policy
72
+ */
73
+ initialize(config: RedisConfig, policy: RetentionPolicy): void;
74
+ /**
75
+ * Add failed job to DLQ
76
+ */
77
+ addFailedJob(entry: FailedJobEntry): Promise<void>;
78
+ /**
79
+ * Get failed job by ID
80
+ */
81
+ getFailedJob(queueName: string, jobId: string, userId: string, reason: string): Promise<FailedJobEntry | null>;
82
+ /**
83
+ * Get all failed jobs for a queue
84
+ */
85
+ getFailedJobs(queueName: string, limit?: number): Promise<ReadonlyArray<FailedJobEntry>>;
86
+ /**
87
+ * Retry a failed job
88
+ */
89
+ retry(queueName: string, jobId: string, userId: string, reason: string): Promise<boolean>;
90
+ /**
91
+ * Delete a failed job (GDPR right to deletion)
92
+ */
93
+ deleteFailedJob(queueName: string, jobId: string, userId: string, reason: string): Promise<boolean>;
94
+ /**
95
+ * Anonymize a failed job (GDPR/HIPAA compliance)
96
+ */
97
+ anonymizeFailedJob(queueName: string, jobId: string, userId: string, reason: string): Promise<boolean>;
98
+ /**
99
+ * Get audit log for a failed job
100
+ */
101
+ getAuditLog(failedJobId: string, limit?: number): Promise<ReadonlyArray<ComplianceAuditEntry>>;
102
+ /**
103
+ * Get DLQ statistics
104
+ */
105
+ getStats(): Promise<DLQStats>;
106
+ /**
107
+ * Export failed jobs (compliance)
108
+ */
109
+ exportFailedJobs(queueName: string, userId: string, reason: string): Promise<ReadonlyArray<FailedJobEntry>>;
110
+ /**
111
+ * Update retention policy
112
+ */
113
+ updateRetentionPolicy(policy: RetentionPolicy): void;
114
+ /**
115
+ * Get current retention policy
116
+ */
117
+ getRetentionPolicy(): RetentionPolicy | null;
118
+ /**
119
+ * Shutdown DLQ manager
120
+ */
121
+ shutdown(): Promise<void>;
122
+ }>;
123
+ //# sourceMappingURL=DeadLetterQueue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DeadLetterQueue.d.ts","sourceRoot":"","sources":["../../../../packages/workers/src/DeadLetterQueue.ts"],"names":[],"mappings":"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"}