@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,52 @@
1
+ /**
2
+ * Worker Store
3
+ * Persistence layer for workers (memory, redis, db)
4
+ */
5
+ import type { createRedisConnection } from '../../../../src/index.js';
6
+ import { type IDatabase } from '../../../../src/index.js';
7
+ type RedisConnection = ReturnType<typeof createRedisConnection>;
8
+ export type WorkerRecord = {
9
+ name: string;
10
+ queueName: string;
11
+ version: string | null;
12
+ status: string;
13
+ autoStart: boolean;
14
+ concurrency: number;
15
+ region: string | null;
16
+ processorSpec?: string | null;
17
+ activeStatus?: boolean;
18
+ features?: Record<string, unknown> | null;
19
+ infrastructure?: Record<string, unknown> | null;
20
+ datacenter?: Record<string, unknown> | null;
21
+ createdAt: Date;
22
+ updatedAt: Date;
23
+ lastHealthCheck?: Date;
24
+ lastError?: string;
25
+ connectionState?: 'disconnected' | 'connecting' | 'connected' | 'error';
26
+ };
27
+ export type WorkerStore = {
28
+ init(): Promise<void>;
29
+ list(options?: {
30
+ offset?: number;
31
+ limit?: number;
32
+ search?: string;
33
+ includeInactive?: boolean;
34
+ }): Promise<WorkerRecord[]>;
35
+ get(name: string): Promise<WorkerRecord | null>;
36
+ save(record: WorkerRecord): Promise<void>;
37
+ update(name: string, patch: Partial<WorkerRecord>): Promise<void>;
38
+ updateMany?: (names: string[], patch: Partial<WorkerRecord>) => Promise<void>;
39
+ remove(name: string): Promise<void>;
40
+ close?(): Promise<void>;
41
+ };
42
+ export declare const InMemoryWorkerStore: Readonly<{
43
+ create(): WorkerStore;
44
+ }>;
45
+ export declare const RedisWorkerStore: Readonly<{
46
+ create(client: RedisConnection, keyPrefix?: string): WorkerStore;
47
+ }>;
48
+ export declare const DbWorkerStore: Readonly<{
49
+ create(db: IDatabase, table?: string): WorkerStore;
50
+ }>;
51
+ export {};
52
+ //# sourceMappingURL=WorkerStore.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WorkerStore.d.ts","sourceRoot":"","sources":["../../../../../packages/workers/src/storage/WorkerStore.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAC5D,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,KAAK,eAAe,GAAG,UAAU,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAEhE,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,OAAO,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC1C,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAChD,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC5C,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,eAAe,CAAC,EAAE,IAAI,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,cAAc,GAAG,YAAY,GAAG,WAAW,GAAG,OAAO,CAAC;CACzE,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACtB,IAAI,CAAC,OAAO,CAAC,EAAE;QACb,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,eAAe,CAAC,EAAE,OAAO,CAAC;KAC3B,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;IAC5B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;IAChD,IAAI,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1C,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9E,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,KAAK,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACzB,CAAC;AAgFF,eAAO,MAAM,mBAAmB;cACpB,WAAW;EA0CrB,CAAC;AAEH,eAAO,MAAM,gBAAgB;mBACZ,eAAe,uBAAmC,WAAW;EA2E5E,CAAC;AAEH,eAAO,MAAM,aAAa;eACb,SAAS,mBAA+B,WAAW;EA2D9D,CAAC"}
@@ -0,0 +1,259 @@
1
+ /**
2
+ * Worker Store
3
+ * Persistence layer for workers (memory, redis, db)
4
+ */
5
+ const now = () => new Date();
6
+ const mergeRecord = (current, patch) => ({
7
+ ...current,
8
+ ...patch,
9
+ updatedAt: patch.updatedAt ?? now(),
10
+ });
11
+ const toSqlDateTime = (value) => {
12
+ if (!value)
13
+ return null;
14
+ // Use UTC and drop timezone for SQL DATETIME compatibility
15
+ return value.toISOString().slice(0, 19).replace('T', ' ');
16
+ };
17
+ const serializeDbWorker = (record) => ({
18
+ name: record.name,
19
+ queue_name: record.queueName,
20
+ version: record.version,
21
+ status: record.status,
22
+ auto_start: record.autoStart,
23
+ concurrency: record.concurrency,
24
+ region: record.region,
25
+ processor_spec: record.processorSpec ?? null,
26
+ active_status: record.activeStatus ?? true,
27
+ features: record.features ? JSON.stringify(record.features) : null,
28
+ infrastructure: record.infrastructure ? JSON.stringify(record.infrastructure) : null,
29
+ datacenter: record.datacenter ? JSON.stringify(record.datacenter) : null,
30
+ created_at: toSqlDateTime(record.createdAt),
31
+ updated_at: toSqlDateTime(record.updatedAt),
32
+ last_health_check: toSqlDateTime(record.lastHealthCheck ?? null),
33
+ last_error: record.lastError ?? null,
34
+ connection_state: record.connectionState ?? null,
35
+ });
36
+ const getHealthCheck = (row) => {
37
+ if (!row['last_health_check']) {
38
+ return undefined;
39
+ }
40
+ return row['last_health_check'] instanceof Date
41
+ ? row['last_health_check']
42
+ : new Date(String(row['last_health_check']));
43
+ };
44
+ const deserializeDbWorker = (row) => {
45
+ const parseJson = (value) => {
46
+ if (typeof value !== 'string' || value.trim() === '')
47
+ return null;
48
+ try {
49
+ return JSON.parse(value);
50
+ }
51
+ catch {
52
+ return null;
53
+ }
54
+ };
55
+ return {
56
+ name: String(row['name'] ?? ''),
57
+ queueName: String(row['queue_name'] ?? ''),
58
+ version: row['version'] ? String(row['version']) : null,
59
+ status: String(row['status'] ?? 'unknown'),
60
+ autoStart: Boolean(row['auto_start'] ?? false),
61
+ concurrency: Number(row['concurrency'] ?? 0),
62
+ region: row['region'] ? String(row['region']) : null,
63
+ processorSpec: String(row['processor_spec']),
64
+ activeStatus: row['active_status'] === undefined ? true : Boolean(row['active_status']),
65
+ features: parseJson(row['features']),
66
+ infrastructure: parseJson(row['infrastructure']),
67
+ datacenter: parseJson(row['datacenter']),
68
+ createdAt: row['created_at'] instanceof Date ? row['created_at'] : new Date(String(row['created_at'])),
69
+ updatedAt: row['updated_at'] instanceof Date ? row['updated_at'] : new Date(String(row['updated_at'])),
70
+ lastHealthCheck: getHealthCheck(row),
71
+ lastError: row['last_error'] ? String(row['last_error']) : undefined,
72
+ connectionState: row['connection_state']
73
+ ? String(row['connection_state'])
74
+ : undefined,
75
+ };
76
+ };
77
+ export const InMemoryWorkerStore = Object.freeze({
78
+ create() {
79
+ const store = new Map();
80
+ return {
81
+ async init() {
82
+ return undefined;
83
+ },
84
+ async list(options) {
85
+ let values = Array.from(store.values());
86
+ if (options) {
87
+ const start = options.offset || 0;
88
+ const end = options.limit ? start + options.limit : undefined;
89
+ values = values.slice(start, end);
90
+ }
91
+ return values;
92
+ },
93
+ async get(name) {
94
+ return store.get(name) ?? null;
95
+ },
96
+ async save(record) {
97
+ store.set(record.name, record);
98
+ },
99
+ async update(name, patch) {
100
+ const current = store.get(name);
101
+ if (!current)
102
+ return;
103
+ store.set(name, mergeRecord(current, patch));
104
+ },
105
+ async updateMany(names, patch) {
106
+ for (const name of names) {
107
+ const current = store.get(name);
108
+ if (!current)
109
+ continue;
110
+ store.set(name, mergeRecord(current, patch));
111
+ }
112
+ },
113
+ async remove(name) {
114
+ store.delete(name);
115
+ },
116
+ async close() {
117
+ // No-op for memory store
118
+ },
119
+ };
120
+ },
121
+ });
122
+ export const RedisWorkerStore = Object.freeze({
123
+ create(client, keyPrefix = 'workers:registry') {
124
+ const key = keyPrefix;
125
+ const serialize = (record) => JSON.stringify({
126
+ ...record,
127
+ createdAt: record.createdAt.toISOString(),
128
+ updatedAt: record.updatedAt.toISOString(),
129
+ });
130
+ const deserialize = (raw) => {
131
+ const parsed = JSON.parse(raw);
132
+ return {
133
+ ...parsed,
134
+ createdAt: new Date(parsed.createdAt),
135
+ updatedAt: new Date(parsed.updatedAt),
136
+ };
137
+ };
138
+ return {
139
+ async init() {
140
+ return undefined;
141
+ },
142
+ async list(options) {
143
+ const all = await client.hgetall(key);
144
+ let values = Object.values(all).map((element) => deserialize(element));
145
+ values.sort((a, b) => a.name.localeCompare(b.name));
146
+ if (options) {
147
+ const start = options.offset || 0;
148
+ const end = options.limit ? start + options.limit : undefined;
149
+ values = values.slice(start, end);
150
+ }
151
+ return values;
152
+ },
153
+ async get(name) {
154
+ const raw = await client.hget(key, name);
155
+ return raw ? deserialize(raw) : null;
156
+ },
157
+ async save(record) {
158
+ await client.hset(key, record.name, serialize(record));
159
+ },
160
+ async update(name, patch) {
161
+ const current = await this.get(name);
162
+ if (!current)
163
+ return;
164
+ await client.hset(key, name, serialize(mergeRecord(current, patch)));
165
+ },
166
+ async updateMany(names, patch) {
167
+ if (names.length === 0)
168
+ return;
169
+ const entries = await client.hmget(key, ...names);
170
+ const updates = [];
171
+ entries.forEach((raw, index) => {
172
+ if (!raw)
173
+ return;
174
+ const current = deserialize(raw);
175
+ const updated = mergeRecord(current, patch);
176
+ updates.push(names[index], serialize(updated));
177
+ });
178
+ if (updates.length === 0)
179
+ return;
180
+ await client.hset(key, ...updates);
181
+ },
182
+ async close() {
183
+ try {
184
+ // Force disconnect in Cloudflare env to avoid hanging on quit()
185
+ client.disconnect();
186
+ }
187
+ catch {
188
+ // Ignore connection errors during cleanup
189
+ }
190
+ },
191
+ async remove(name) {
192
+ await client.hdel(key, name);
193
+ },
194
+ };
195
+ },
196
+ });
197
+ export const DbWorkerStore = Object.freeze({
198
+ create(db, table = 'zintrust_workers') {
199
+ return {
200
+ async init() {
201
+ return undefined;
202
+ },
203
+ async list(options) {
204
+ const query = db.table(table);
205
+ if (options?.limit)
206
+ query.limit(options.limit);
207
+ if (options?.offset)
208
+ query.offset(options.offset);
209
+ const rows = await query.get();
210
+ return rows.map((element) => deserializeDbWorker(element));
211
+ },
212
+ async get(name) {
213
+ const row = await db.table(table).where('name', '=', name).first();
214
+ return row ? deserializeDbWorker(row) : null;
215
+ },
216
+ async save(record) {
217
+ const existing = await db
218
+ .table(table)
219
+ .where('name', '=', record.name)
220
+ .first();
221
+ if (existing) {
222
+ await db.table(table).where('name', '=', record.name).update(serializeDbWorker(record));
223
+ return;
224
+ }
225
+ await db.table(table).insert(serializeDbWorker(record));
226
+ },
227
+ async update(name, patch) {
228
+ const current = await this.get(name);
229
+ if (!current)
230
+ return;
231
+ const updated = mergeRecord(current, patch);
232
+ await db.table(table).where('name', '=', name).update(serializeDbWorker(updated));
233
+ },
234
+ async updateMany(names, patch) {
235
+ if (names.length === 0)
236
+ return;
237
+ const update = {
238
+ updated_at: toSqlDateTime(patch.updatedAt ?? now()),
239
+ };
240
+ if (patch.status !== undefined)
241
+ update['status'] = patch.status;
242
+ if (patch.lastError !== undefined)
243
+ update['last_error'] = patch.lastError ?? null;
244
+ if (patch.lastHealthCheck !== undefined)
245
+ update['last_health_check'] = toSqlDateTime(patch.lastHealthCheck ?? null);
246
+ if (patch.connectionState !== undefined)
247
+ update['connection_state'] = patch.connectionState ?? null;
248
+ await db.table(table).whereIn('name', names).update(update);
249
+ },
250
+ async remove(name) {
251
+ await db.table(table).where('name', '=', name).delete();
252
+ },
253
+ async close() {
254
+ // Database clients often managed by pool, but if needed:
255
+ // await db.destroy?.();
256
+ },
257
+ };
258
+ },
259
+ });
@@ -0,0 +1,47 @@
1
+ export type TelemetrySettings = {
2
+ enabled: boolean;
3
+ basePath: string;
4
+ middleware: ReadonlyArray<string>;
5
+ autoRefresh: boolean;
6
+ refreshIntervalMs: number;
7
+ };
8
+ export type ResourceCurrentResponse = {
9
+ ok: boolean;
10
+ usage?: unknown;
11
+ };
12
+ export type SystemSummaryResponse = {
13
+ ok: boolean;
14
+ summary?: unknown;
15
+ };
16
+ export type ApiResponse<T> = {
17
+ ok: boolean;
18
+ error?: string;
19
+ } & T;
20
+ export type AlertRep = {
21
+ type: string;
22
+ severity: string;
23
+ message: string;
24
+ timestamp: string;
25
+ recommendation?: string;
26
+ };
27
+ export declare const TelemetryAPI: Readonly<{
28
+ getSystemSummary(): Promise<ApiResponse<{
29
+ summary: unknown;
30
+ }>>;
31
+ getMonitoringSummary(): Promise<ApiResponse<{
32
+ summary: unknown;
33
+ }>>;
34
+ getResourceCurrent(): Promise<ApiResponse<{
35
+ usage: unknown;
36
+ }>>;
37
+ getResourceTrends(): Promise<ApiResponse<{
38
+ trends: unknown;
39
+ }>>;
40
+ }>;
41
+ export declare function createSnapshotBuilder(): () => Promise<{
42
+ ok: boolean;
43
+ summary: unknown;
44
+ resources: unknown;
45
+ cost: unknown;
46
+ }>;
47
+ //# sourceMappingURL=TelemetryAPI.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TelemetryAPI.d.ts","sourceRoot":"","sources":["../../../../../../packages/workers/src/telemetry/api/TelemetryAPI.ts"],"names":[],"mappings":"AAOA,MAAM,MAAM,iBAAiB,GAAG;IAC9B,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAClC,WAAW,EAAE,OAAO,CAAC;IACrB,iBAAiB,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AACvE,MAAM,MAAM,qBAAqB,GAAG;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,OAAO,CAAC,EAAE,OAAO,CAAA;CAAE,CAAC;AAQvE,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,CAAC,CAAC;AACjE,MAAM,MAAM,QAAQ,GAAG;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,CAAC;AA+IF,eAAO,MAAM,YAAY;wBACG,OAAO,CAAC,WAAW,CAAC;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;4BAuCtC,OAAO,CAAC,WAAW,CAAC;QAAE,OAAO,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;0BAc5C,OAAO,CAAC,WAAW,CAAC;QAAE,KAAK,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;yBAczC,OAAO,CAAC,WAAW,CAAC;QAAE,MAAM,EAAE,OAAO,CAAA;KAAE,CAAC,CAAC;EAapE,CAAC;AAEH,wBAAgB,qBAAqB,UAClB,OAAO,CAAC;IACvB,EAAE,EAAE,OAAO,CAAC;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,IAAI,EAAE,OAAO,CAAC;CACf,CAAC,CA4BH"}
@@ -0,0 +1,219 @@
1
+ import { Logger } from '../../../../../src/index.js';
2
+ import { getWorkers } from '../../dashboard/workers-api.js';
3
+ import { HealthMonitor } from '../../HealthMonitor.js';
4
+ import { ResourceMonitor } from '../../ResourceMonitor.js';
5
+ const isOkWithUsage = (value) => value.ok === true && 'usage' in value;
6
+ const isOkWithSummary = (value) => value.ok === true && 'summary' in value;
7
+ // Helper function to create stopped worker alert
8
+ const createStoppedWorkerAlert = (worker) => ({
9
+ type: 'worker-stopped',
10
+ severity: 'warning',
11
+ message: `Worker ${worker.name} is stopped`,
12
+ timestamp: worker.health?.lastCheck || new Date().toISOString(),
13
+ });
14
+ // Helper function to create health check alert
15
+ const createHealthCheckAlert = (worker) => {
16
+ const check = worker.health?.checks?.[0];
17
+ if (!check)
18
+ return null;
19
+ return {
20
+ type: 'health-check-failed',
21
+ severity: check.status === 'fail' ? 'critical' : 'warning',
22
+ message: check.message || `Health check failed: ${check.name}`,
23
+ timestamp: worker.health?.lastCheck || new Date().toISOString(),
24
+ };
25
+ };
26
+ // Helper function to generate worker alerts
27
+ const generateWorkerAlerts = (workers) => {
28
+ return workers
29
+ .filter((w) => {
30
+ return (w.status !== 'running' ||
31
+ w.health?.status !== 'healthy' ||
32
+ (w.health?.checks && w.health.checks.length > 0));
33
+ })
34
+ .map((w) => {
35
+ const workerData = {
36
+ workerName: w.name,
37
+ status: w.status,
38
+ healthStatus: w.health?.status || 'unknown',
39
+ lastCheck: w.health?.lastCheck || new Date().toISOString(),
40
+ checks: w.health?.checks || [],
41
+ };
42
+ let alert = null;
43
+ if (w.status === 'stopped') {
44
+ alert = createStoppedWorkerAlert(w);
45
+ }
46
+ else if (w.health?.checks && w.health.checks.length > 0) {
47
+ alert = createHealthCheckAlert(w);
48
+ }
49
+ return {
50
+ ...workerData,
51
+ alert,
52
+ };
53
+ })
54
+ .filter((w) => w.alert !== null);
55
+ };
56
+ // Helper function to generate resource alerts
57
+ const generateResourceAlerts = (resourceUsage) => {
58
+ const resourceAlerts = [];
59
+ const cpuUsage = resourceUsage.resourceSnapshot?.cpu?.usage || 0;
60
+ const memoryUsage = resourceUsage.resourceSnapshot?.memory?.usage || 0;
61
+ if (cpuUsage > 90) {
62
+ resourceAlerts.push({
63
+ type: 'cpu-high',
64
+ severity: 'critical',
65
+ message: `Critical CPU usage: ${cpuUsage.toFixed(1)}%`,
66
+ timestamp: new Date().toISOString(),
67
+ recommendation: 'Consider scaling up or optimizing worker code',
68
+ });
69
+ }
70
+ else if (cpuUsage > 80) {
71
+ resourceAlerts.push({
72
+ type: 'cpu-high',
73
+ severity: 'warning',
74
+ message: `High CPU usage: ${cpuUsage.toFixed(1)}%`,
75
+ timestamp: new Date().toISOString(),
76
+ recommendation: 'Monitor closely and consider scaling',
77
+ });
78
+ }
79
+ if (memoryUsage > 95) {
80
+ resourceAlerts.push({
81
+ type: 'memory-high',
82
+ severity: 'critical',
83
+ message: `Critical memory usage: ${memoryUsage.toFixed(1)}%`,
84
+ timestamp: new Date().toISOString(),
85
+ recommendation: 'Increase memory allocation or optimize memory usage',
86
+ });
87
+ }
88
+ else if (memoryUsage > 85) {
89
+ resourceAlerts.push({
90
+ type: 'memory-high',
91
+ severity: 'warning',
92
+ message: `High memory usage: ${memoryUsage.toFixed(1)}%`,
93
+ timestamp: new Date().toISOString(),
94
+ recommendation: 'Monitor memory usage closely',
95
+ });
96
+ }
97
+ return resourceAlerts;
98
+ };
99
+ // Helper function to calculate monitoring summary
100
+ const calculateMonitoringSummary = (runningWorkers) => {
101
+ const healthyCount = runningWorkers.filter((w) => w.health?.status === 'healthy').length;
102
+ const degradedCount = runningWorkers.filter((w) => w.health?.status === 'warning').length;
103
+ const criticalCount = runningWorkers.filter((w) => w.health?.status === 'unhealthy').length;
104
+ return {
105
+ total: runningWorkers.length,
106
+ healthy: healthyCount,
107
+ degraded: degradedCount,
108
+ critical: criticalCount,
109
+ details: runningWorkers.map((w) => ({
110
+ workerName: w.name,
111
+ status: w.health?.status || 'unknown',
112
+ lastCheck: w.health?.lastCheck || new Date().toISOString(),
113
+ checks: w.health?.checks || [],
114
+ })),
115
+ };
116
+ };
117
+ export const TelemetryAPI = Object.freeze({
118
+ async getSystemSummary() {
119
+ try {
120
+ // Get all workers (both running and stopped) for complete alert visibility
121
+ const workersResult = await getWorkers({});
122
+ const runningWorkers = workersResult.workers.filter((w) => w.status === 'running');
123
+ // Calculate monitoring summary from running workers only
124
+ const monitoringSummary = calculateMonitoringSummary(runningWorkers);
125
+ // Generate alerts from workers and resources
126
+ const workerAlerts = generateWorkerAlerts(workersResult.workers);
127
+ const resourceUsage = ResourceMonitor.getCurrentUsage('system');
128
+ const resourceAlerts = generateResourceAlerts(resourceUsage);
129
+ // Combine all alerts
130
+ const allAlerts = [...workerAlerts, ...resourceAlerts];
131
+ return {
132
+ ok: true,
133
+ summary: {
134
+ workers: runningWorkers.length,
135
+ monitoring: {
136
+ ...monitoringSummary,
137
+ alerts: allAlerts, // Include all alerts (workers + resources)
138
+ },
139
+ resources: resourceUsage,
140
+ alerts: allAlerts, // Top-level alerts for easy access
141
+ },
142
+ };
143
+ }
144
+ catch (error) {
145
+ Logger.error('Failed to get system summary', error);
146
+ return {
147
+ ok: false,
148
+ error: error instanceof Error ? error.message : 'Unknown error',
149
+ summary: {},
150
+ };
151
+ }
152
+ },
153
+ async getMonitoringSummary() {
154
+ try {
155
+ const summary = await HealthMonitor.getSummary();
156
+ return { ok: true, summary };
157
+ }
158
+ catch (error) {
159
+ Logger.error('Failed to get monitoring summary', error);
160
+ return {
161
+ ok: false,
162
+ error: error instanceof Error ? error.message : 'Unknown error',
163
+ summary: {},
164
+ };
165
+ }
166
+ },
167
+ async getResourceCurrent() {
168
+ try {
169
+ const usage = ResourceMonitor.getCurrentUsage('system');
170
+ return { ok: true, usage };
171
+ }
172
+ catch (error) {
173
+ Logger.error('Failed to get resource usage', error);
174
+ return {
175
+ ok: false,
176
+ error: error instanceof Error ? error.message : 'Unknown error',
177
+ usage: null,
178
+ };
179
+ }
180
+ },
181
+ async getResourceTrends() {
182
+ try {
183
+ const trends = ResourceMonitor.getAllTrends('system', 'day');
184
+ return { ok: true, trends };
185
+ }
186
+ catch (error) {
187
+ Logger.error('Failed to get resource trends', error);
188
+ return {
189
+ ok: false,
190
+ error: error instanceof Error ? error.message : 'Unknown error',
191
+ trends: null,
192
+ };
193
+ }
194
+ },
195
+ });
196
+ export function createSnapshotBuilder() {
197
+ return async () => {
198
+ const [systemSummaryResult, resourceCurrentResult] = await Promise.allSettled([
199
+ TelemetryAPI.getSystemSummary(),
200
+ TelemetryAPI.getResourceCurrent(),
201
+ ]);
202
+ if (systemSummaryResult.status === 'rejected') {
203
+ Logger.error('Telemetry dashboard summary failed', systemSummaryResult.reason);
204
+ }
205
+ if (resourceCurrentResult.status === 'rejected') {
206
+ Logger.error('Telemetry resource summary failed', resourceCurrentResult.reason);
207
+ }
208
+ const systemSummary = systemSummaryResult.status === 'fulfilled' ? systemSummaryResult.value : { ok: false };
209
+ const resourceCurrent = resourceCurrentResult.status === 'fulfilled'
210
+ ? resourceCurrentResult.value
211
+ : { ok: false };
212
+ return {
213
+ ok: systemSummary.ok ?? false,
214
+ summary: isOkWithSummary(systemSummary) ? systemSummary.summary : {},
215
+ resources: isOkWithUsage(resourceCurrent) ? resourceCurrent.usage : null,
216
+ cost: null,
217
+ };
218
+ };
219
+ }
@@ -0,0 +1,18 @@
1
+ import type { IResponse } from '../../../../../src/index.js';
2
+ import type { createSnapshotBuilder, TelemetrySettings } from './TelemetryAPI';
3
+ export type TelemetrySnapshotData = {
4
+ type: string;
5
+ ts: string;
6
+ ok: boolean;
7
+ summary: unknown;
8
+ resources: unknown;
9
+ cost: unknown;
10
+ };
11
+ export declare const TelemetryMonitoringService: Readonly<{
12
+ subscribe(callback: (data: TelemetrySnapshotData) => void): void;
13
+ unsubscribe(callback: (data: TelemetrySnapshotData) => void): void;
14
+ startMonitoring(settings: TelemetrySettings, buildSnapshot: ReturnType<typeof createSnapshotBuilder>): void;
15
+ stopMonitoring(): void;
16
+ }>;
17
+ export declare const teleStream: (res: IResponse, settings: TelemetrySettings, buildSnapshot: ReturnType<typeof createSnapshotBuilder>) => Promise<void>;
18
+ //# sourceMappingURL=TelemetryMonitoringService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TelemetryMonitoringService.d.ts","sourceRoot":"","sources":["../../../../../../packages/workers/src/telemetry/api/TelemetryMonitoringService.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,OAAO,KAAK,EAAE,qBAAqB,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAE/E,MAAM,MAAM,qBAAqB,GAAG;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,OAAO,CAAC;IACZ,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,OAAO,CAAC;IACnB,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AAkFF,eAAO,MAAM,0BAA0B;wBACjB,CAAC,IAAI,EAAE,qBAAqB,KAAK,IAAI,GAAG,IAAI;0BAQ1C,CAAC,IAAI,EAAE,qBAAqB,KAAK,IAAI,GAAG,IAAI;8BAWtD,iBAAiB,iBACZ,UAAU,CAAC,OAAO,qBAAqB,CAAC,GACtD,IAAI;sBAOW,IAAI;EAOtB,CAAC;AAEH,eAAO,MAAM,UAAU,GACrB,KAAK,SAAS,EACd,UAAU,iBAAiB,EAC3B,eAAe,UAAU,CAAC,OAAO,qBAAqB,CAAC,KACtD,OAAO,CAAC,IAAI,CA8Cd,CAAC"}