bunqueue 2.8.0 → 2.8.2

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 (1014) hide show
  1. package/README.md +44 -11
  2. package/dist/application/backgroundTasks.d.ts +0 -1
  3. package/dist/application/backgroundTasks.js +83 -1
  4. package/dist/application/cleanupTasks.d.ts +0 -1
  5. package/dist/application/cleanupTasks.js +0 -1
  6. package/dist/application/clientTracking.d.ts +23 -1
  7. package/dist/application/clientTracking.js +80 -26
  8. package/dist/application/contextFactory.d.ts +6 -1
  9. package/dist/application/contextFactory.js +7 -1
  10. package/dist/application/dependencyProcessor.d.ts +0 -1
  11. package/dist/application/dependencyProcessor.js +0 -1
  12. package/dist/application/dlqManager.d.ts +0 -1
  13. package/dist/application/dlqManager.js +5 -1
  14. package/dist/application/eventsManager.d.ts +0 -1
  15. package/dist/application/eventsManager.js +0 -1
  16. package/dist/application/jobLogsManager.d.ts +0 -1
  17. package/dist/application/jobLogsManager.js +0 -1
  18. package/dist/application/latencyTracker.d.ts +0 -1
  19. package/dist/application/latencyTracker.js +0 -1
  20. package/dist/application/lockManager.d.ts +1 -2
  21. package/dist/application/lockManager.js +1 -2
  22. package/dist/application/lockOperations.d.ts +0 -1
  23. package/dist/application/lockOperations.js +0 -1
  24. package/dist/application/metricsExporter.d.ts +0 -1
  25. package/dist/application/metricsExporter.js +0 -1
  26. package/dist/application/monitoringChecks.d.ts +0 -1
  27. package/dist/application/monitoringChecks.js +0 -1
  28. package/dist/application/operations/ack.d.ts +0 -1
  29. package/dist/application/operations/ack.js +32 -34
  30. package/dist/application/operations/ackHelpers.d.ts +0 -1
  31. package/dist/application/operations/ackHelpers.js +0 -1
  32. package/dist/application/operations/index.d.ts +0 -1
  33. package/dist/application/operations/index.js +0 -1
  34. package/dist/application/operations/jobManagement.d.ts +1 -2
  35. package/dist/application/operations/jobManagement.js +3 -3
  36. package/dist/application/operations/jobStateTransitions.d.ts +0 -1
  37. package/dist/application/operations/jobStateTransitions.js +0 -1
  38. package/dist/application/operations/pull.d.ts +0 -1
  39. package/dist/application/operations/pull.js +0 -1
  40. package/dist/application/operations/push.d.ts +0 -1
  41. package/dist/application/operations/push.js +0 -1
  42. package/dist/application/operations/queryOperations.d.ts +0 -1
  43. package/dist/application/operations/queryOperations.js +37 -4
  44. package/dist/application/operations/queueControl.d.ts +16 -5
  45. package/dist/application/operations/queueControl.js +119 -24
  46. package/dist/application/queueManager.d.ts +17 -4
  47. package/dist/application/queueManager.js +106 -28
  48. package/dist/application/stallDetection.d.ts +0 -1
  49. package/dist/application/stallDetection.js +1 -1
  50. package/dist/application/statsManager.d.ts +0 -1
  51. package/dist/application/statsManager.js +0 -1
  52. package/dist/application/taskErrorTracking.d.ts +0 -1
  53. package/dist/application/taskErrorTracking.js +0 -1
  54. package/dist/application/throughputTracker.d.ts +0 -1
  55. package/dist/application/throughputTracker.js +0 -1
  56. package/dist/application/types.d.ts +2 -2
  57. package/dist/application/types.js +0 -1
  58. package/dist/application/webhookManager.d.ts +0 -1
  59. package/dist/application/webhookManager.js +0 -1
  60. package/dist/application/workerManager.d.ts +0 -1
  61. package/dist/application/workerManager.js +0 -1
  62. package/dist/cli/client.d.ts +0 -1
  63. package/dist/cli/client.js +15 -3
  64. package/dist/cli/commands/backup.d.ts +0 -1
  65. package/dist/cli/commands/backup.js +0 -1
  66. package/dist/cli/commands/core.d.ts +0 -1
  67. package/dist/cli/commands/core.js +0 -1
  68. package/dist/cli/commands/cron.d.ts +0 -1
  69. package/dist/cli/commands/cron.js +0 -1
  70. package/dist/cli/commands/dlq.d.ts +0 -1
  71. package/dist/cli/commands/dlq.js +0 -1
  72. package/dist/cli/commands/doctor.d.ts +0 -1
  73. package/dist/cli/commands/doctor.js +0 -1
  74. package/dist/cli/commands/job.d.ts +0 -1
  75. package/dist/cli/commands/job.js +0 -1
  76. package/dist/cli/commands/monitor.d.ts +0 -1
  77. package/dist/cli/commands/monitor.js +0 -1
  78. package/dist/cli/commands/queue.d.ts +0 -1
  79. package/dist/cli/commands/queue.js +0 -1
  80. package/dist/cli/commands/rateLimit.d.ts +0 -1
  81. package/dist/cli/commands/rateLimit.js +0 -1
  82. package/dist/cli/commands/server.d.ts +0 -1
  83. package/dist/cli/commands/server.js +0 -1
  84. package/dist/cli/commands/types.d.ts +0 -1
  85. package/dist/cli/commands/types.js +0 -1
  86. package/dist/cli/commands/webhook.d.ts +0 -1
  87. package/dist/cli/commands/webhook.js +0 -1
  88. package/dist/cli/commands/worker.d.ts +0 -1
  89. package/dist/cli/commands/worker.js +0 -1
  90. package/dist/cli/help.d.ts +0 -1
  91. package/dist/cli/help.js +0 -1
  92. package/dist/cli/index.d.ts +0 -1
  93. package/dist/cli/index.js +31 -3
  94. package/dist/cli/output.d.ts +1 -2
  95. package/dist/cli/output.js +71 -10
  96. package/dist/client/bunqueue/aging.d.ts +0 -1
  97. package/dist/client/bunqueue/aging.js +0 -1
  98. package/dist/client/bunqueue/batch.d.ts +0 -1
  99. package/dist/client/bunqueue/batch.js +2 -3
  100. package/dist/client/bunqueue/cancellation.d.ts +0 -1
  101. package/dist/client/bunqueue/cancellation.js +0 -1
  102. package/dist/client/bunqueue/circuitBreaker.d.ts +0 -1
  103. package/dist/client/bunqueue/circuitBreaker.js +0 -1
  104. package/dist/client/bunqueue/dedupDebounce.d.ts +0 -1
  105. package/dist/client/bunqueue/dedupDebounce.js +0 -1
  106. package/dist/client/bunqueue/dlqRateLimit.d.ts +0 -1
  107. package/dist/client/bunqueue/dlqRateLimit.js +0 -1
  108. package/dist/client/bunqueue/retry.d.ts +0 -1
  109. package/dist/client/bunqueue/retry.js +0 -1
  110. package/dist/client/bunqueue/triggers.d.ts +0 -1
  111. package/dist/client/bunqueue/triggers.js +0 -1
  112. package/dist/client/bunqueue/ttl.d.ts +0 -1
  113. package/dist/client/bunqueue/ttl.js +0 -1
  114. package/dist/client/bunqueue/types.d.ts +0 -1
  115. package/dist/client/bunqueue/types.js +0 -1
  116. package/dist/client/bunqueue.d.ts +0 -1
  117. package/dist/client/bunqueue.js +3 -4
  118. package/dist/client/errors.d.ts +0 -1
  119. package/dist/client/errors.js +0 -1
  120. package/dist/client/events.d.ts +0 -1
  121. package/dist/client/events.js +0 -1
  122. package/dist/client/flow.d.ts +0 -1
  123. package/dist/client/flow.js +3 -2
  124. package/dist/client/flowJobFactory.d.ts +8 -2
  125. package/dist/client/flowJobFactory.js +328 -57
  126. package/dist/client/flowPush.d.ts +0 -1
  127. package/dist/client/flowPush.js +95 -47
  128. package/dist/client/flowTypes.d.ts +0 -1
  129. package/dist/client/flowTypes.js +0 -1
  130. package/dist/client/index.d.ts +0 -1
  131. package/dist/client/index.js +0 -1
  132. package/dist/client/jobConversion.d.ts +0 -1
  133. package/dist/client/jobConversion.js +12 -5
  134. package/dist/client/jobConversionHelpers.d.ts +0 -1
  135. package/dist/client/jobConversionHelpers.js +0 -1
  136. package/dist/client/jobConversionTypes.d.ts +0 -1
  137. package/dist/client/jobConversionTypes.js +0 -1
  138. package/dist/client/jobHelpers.d.ts +0 -1
  139. package/dist/client/jobHelpers.js +0 -1
  140. package/dist/client/manager.d.ts +0 -1
  141. package/dist/client/manager.js +0 -1
  142. package/dist/client/queue/addBatcher.d.ts +0 -1
  143. package/dist/client/queue/addBatcher.js +0 -1
  144. package/dist/client/queue/bullmqCompat.d.ts +1 -1
  145. package/dist/client/queue/bullmqCompat.js +0 -1
  146. package/dist/client/queue/deduplication.d.ts +0 -1
  147. package/dist/client/queue/deduplication.js +0 -1
  148. package/dist/client/queue/dlq.d.ts +0 -1
  149. package/dist/client/queue/dlq.js +0 -1
  150. package/dist/client/queue/dlqOps.d.ts +0 -1
  151. package/dist/client/queue/dlqOps.js +0 -1
  152. package/dist/client/queue/helpers.d.ts +0 -1
  153. package/dist/client/queue/helpers.js +0 -1
  154. package/dist/client/queue/index.d.ts +0 -1
  155. package/dist/client/queue/index.js +0 -1
  156. package/dist/client/queue/jobMove.d.ts +0 -1
  157. package/dist/client/queue/jobMove.js +0 -1
  158. package/dist/client/queue/jobProxy.d.ts +22 -4
  159. package/dist/client/queue/jobProxy.js +347 -67
  160. package/dist/client/queue/operations/add.d.ts +1 -1
  161. package/dist/client/queue/operations/add.js +126 -30
  162. package/dist/client/queue/operations/control.d.ts +0 -1
  163. package/dist/client/queue/operations/control.js +0 -1
  164. package/dist/client/queue/operations/counts.d.ts +0 -1
  165. package/dist/client/queue/operations/counts.js +0 -1
  166. package/dist/client/queue/operations/index.d.ts +0 -1
  167. package/dist/client/queue/operations/index.js +0 -1
  168. package/dist/client/queue/operations/management.d.ts +1 -2
  169. package/dist/client/queue/operations/management.js +27 -10
  170. package/dist/client/queue/operations/query.d.ts +12 -1
  171. package/dist/client/queue/operations/query.js +44 -5
  172. package/dist/client/queue/queue.d.ts +0 -1
  173. package/dist/client/queue/queue.js +8 -2
  174. package/dist/client/queue/queueTypes.d.ts +0 -1
  175. package/dist/client/queue/queueTypes.js +0 -1
  176. package/dist/client/queue/rateLimit.d.ts +0 -1
  177. package/dist/client/queue/rateLimit.js +0 -1
  178. package/dist/client/queue/scheduler.d.ts +2 -1
  179. package/dist/client/queue/scheduler.js +28 -1
  180. package/dist/client/queue/stall.d.ts +0 -1
  181. package/dist/client/queue/stall.js +0 -1
  182. package/dist/client/queue/workers.d.ts +0 -1
  183. package/dist/client/queue/workers.js +0 -1
  184. package/dist/client/queue.d.ts +0 -1
  185. package/dist/client/queue.js +0 -1
  186. package/dist/client/queueGroup.d.ts +0 -1
  187. package/dist/client/queueGroup.js +0 -1
  188. package/dist/client/resolveToken.d.ts +0 -1
  189. package/dist/client/resolveToken.js +0 -1
  190. package/dist/client/sandboxed/index.d.ts +0 -1
  191. package/dist/client/sandboxed/index.js +0 -1
  192. package/dist/client/sandboxed/queueOps.d.ts +0 -1
  193. package/dist/client/sandboxed/queueOps.js +0 -1
  194. package/dist/client/sandboxed/types.d.ts +0 -1
  195. package/dist/client/sandboxed/types.js +0 -1
  196. package/dist/client/sandboxed/worker.d.ts +0 -1
  197. package/dist/client/sandboxed/worker.js +57 -16
  198. package/dist/client/sandboxed/wrapper.d.ts +0 -1
  199. package/dist/client/sandboxed/wrapper.js +62 -11
  200. package/dist/client/sandboxedWorker.d.ts +0 -1
  201. package/dist/client/sandboxedWorker.js +0 -1
  202. package/dist/client/tcp/client.d.ts +9 -1
  203. package/dist/client/tcp/client.js +84 -29
  204. package/dist/client/tcp/connection.d.ts +0 -1
  205. package/dist/client/tcp/connection.js +6 -2
  206. package/dist/client/tcp/health.d.ts +0 -1
  207. package/dist/client/tcp/health.js +0 -1
  208. package/dist/client/tcp/index.d.ts +0 -1
  209. package/dist/client/tcp/index.js +0 -1
  210. package/dist/client/tcp/reconnect.d.ts +0 -1
  211. package/dist/client/tcp/reconnect.js +0 -1
  212. package/dist/client/tcp/shared.d.ts +0 -1
  213. package/dist/client/tcp/shared.js +0 -1
  214. package/dist/client/tcp/types.d.ts +7 -1
  215. package/dist/client/tcp/types.js +0 -1
  216. package/dist/client/tcpClient.d.ts +0 -1
  217. package/dist/client/tcpClient.js +0 -1
  218. package/dist/client/tcpPool.d.ts +0 -1
  219. package/dist/client/tcpPool.js +0 -1
  220. package/dist/client/types.d.ts +8 -5
  221. package/dist/client/types.js +0 -1
  222. package/dist/client/worker/ackBatcher.d.ts +0 -1
  223. package/dist/client/worker/ackBatcher.js +18 -9
  224. package/dist/client/worker/groupConcurrency.d.ts +0 -1
  225. package/dist/client/worker/groupConcurrency.js +0 -1
  226. package/dist/client/worker/index.d.ts +0 -1
  227. package/dist/client/worker/index.js +0 -1
  228. package/dist/client/worker/jobParser.d.ts +0 -1
  229. package/dist/client/worker/jobParser.js +0 -1
  230. package/dist/client/worker/processor.d.ts +0 -1
  231. package/dist/client/worker/processor.js +54 -100
  232. package/dist/client/worker/processorHandlers.d.ts +54 -0
  233. package/dist/client/worker/processorHandlers.js +372 -0
  234. package/dist/client/worker/types.d.ts +0 -1
  235. package/dist/client/worker/types.js +0 -1
  236. package/dist/client/worker/worker.d.ts +0 -1
  237. package/dist/client/worker/worker.js +0 -1
  238. package/dist/client/worker/workerHeartbeat.d.ts +0 -1
  239. package/dist/client/worker/workerHeartbeat.js +0 -1
  240. package/dist/client/worker/workerPull.d.ts +0 -1
  241. package/dist/client/worker/workerPull.js +0 -1
  242. package/dist/client/worker/workerRateLimiter.d.ts +0 -1
  243. package/dist/client/worker/workerRateLimiter.js +0 -1
  244. package/dist/client/worker.d.ts +0 -1
  245. package/dist/client/worker.js +0 -1
  246. package/dist/client/workflow/compensator.d.ts +14 -0
  247. package/dist/client/workflow/compensator.js +45 -0
  248. package/dist/client/workflow/emitter.d.ts +0 -1
  249. package/dist/client/workflow/emitter.js +15 -4
  250. package/dist/client/workflow/engine.d.ts +8 -2
  251. package/dist/client/workflow/engine.js +9 -1
  252. package/dist/client/workflow/executor.d.ts +5 -3
  253. package/dist/client/workflow/executor.js +43 -61
  254. package/dist/client/workflow/index.d.ts +1 -2
  255. package/dist/client/workflow/index.js +0 -1
  256. package/dist/client/workflow/loops.d.ts +1 -2
  257. package/dist/client/workflow/loops.js +10 -2
  258. package/dist/client/workflow/recovery.d.ts +22 -0
  259. package/dist/client/workflow/recovery.js +73 -0
  260. package/dist/client/workflow/runner.d.ts +0 -1
  261. package/dist/client/workflow/runner.js +7 -6
  262. package/dist/client/workflow/store.d.ts +2 -1
  263. package/dist/client/workflow/store.js +6 -1
  264. package/dist/client/workflow/types.d.ts +41 -23
  265. package/dist/client/workflow/types.js +0 -1
  266. package/dist/client/workflow/workflow.d.ts +17 -15
  267. package/dist/client/workflow/workflow.js +30 -21
  268. package/dist/config/index.d.ts +0 -1
  269. package/dist/config/index.js +0 -1
  270. package/dist/config/loader.d.ts +0 -1
  271. package/dist/config/loader.js +0 -1
  272. package/dist/config/resolve.d.ts +0 -1
  273. package/dist/config/resolve.js +0 -1
  274. package/dist/config/types.d.ts +0 -1
  275. package/dist/config/types.js +0 -1
  276. package/dist/domain/queue/dependencyTracker.d.ts +0 -1
  277. package/dist/domain/queue/dependencyTracker.js +0 -1
  278. package/dist/domain/queue/dlqShard.d.ts +0 -1
  279. package/dist/domain/queue/dlqShard.js +6 -1
  280. package/dist/domain/queue/index.d.ts +0 -1
  281. package/dist/domain/queue/index.js +0 -1
  282. package/dist/domain/queue/limiterManager.d.ts +0 -1
  283. package/dist/domain/queue/limiterManager.js +0 -1
  284. package/dist/domain/queue/priorityQueue.d.ts +2 -3
  285. package/dist/domain/queue/priorityQueue.js +5 -4
  286. package/dist/domain/queue/shard.d.ts +0 -1
  287. package/dist/domain/queue/shard.js +0 -1
  288. package/dist/domain/queue/shardCounters.d.ts +0 -1
  289. package/dist/domain/queue/shardCounters.js +0 -1
  290. package/dist/domain/queue/temporalManager.d.ts +0 -1
  291. package/dist/domain/queue/temporalManager.js +0 -1
  292. package/dist/domain/queue/uniqueKeyManager.d.ts +0 -1
  293. package/dist/domain/queue/uniqueKeyManager.js +0 -1
  294. package/dist/domain/queue/waiterManager.d.ts +0 -1
  295. package/dist/domain/queue/waiterManager.js +0 -1
  296. package/dist/domain/types/command.d.ts +22 -1
  297. package/dist/domain/types/command.js +0 -1
  298. package/dist/domain/types/cron.d.ts +21 -1
  299. package/dist/domain/types/cron.js +1 -1
  300. package/dist/domain/types/deduplication.d.ts +0 -1
  301. package/dist/domain/types/deduplication.js +0 -1
  302. package/dist/domain/types/dlq.d.ts +0 -1
  303. package/dist/domain/types/dlq.js +0 -1
  304. package/dist/domain/types/index.d.ts +0 -1
  305. package/dist/domain/types/index.js +0 -1
  306. package/dist/domain/types/job.d.ts +0 -1
  307. package/dist/domain/types/job.js +9 -3
  308. package/dist/domain/types/queue.d.ts +0 -1
  309. package/dist/domain/types/queue.js +0 -1
  310. package/dist/domain/types/response.d.ts +2 -1
  311. package/dist/domain/types/response.js +0 -1
  312. package/dist/domain/types/stall.d.ts +0 -1
  313. package/dist/domain/types/stall.js +0 -1
  314. package/dist/domain/types/webhook.d.ts +0 -1
  315. package/dist/domain/types/webhook.js +0 -1
  316. package/dist/domain/types/worker.d.ts +0 -1
  317. package/dist/domain/types/worker.js +0 -1
  318. package/dist/infrastructure/backup/index.d.ts +0 -1
  319. package/dist/infrastructure/backup/index.js +0 -1
  320. package/dist/infrastructure/backup/s3Backup.d.ts +0 -1
  321. package/dist/infrastructure/backup/s3Backup.js +0 -1
  322. package/dist/infrastructure/backup/s3BackupConfig.d.ts +0 -1
  323. package/dist/infrastructure/backup/s3BackupConfig.js +0 -1
  324. package/dist/infrastructure/backup/s3BackupOperations.d.ts +0 -1
  325. package/dist/infrastructure/backup/s3BackupOperations.js +44 -7
  326. package/dist/infrastructure/cloud/buffer.d.ts +0 -1
  327. package/dist/infrastructure/cloud/buffer.js +0 -1
  328. package/dist/infrastructure/cloud/circuitBreaker.d.ts +0 -1
  329. package/dist/infrastructure/cloud/circuitBreaker.js +0 -1
  330. package/dist/infrastructure/cloud/cloudAgent.d.ts +1 -2
  331. package/dist/infrastructure/cloud/cloudAgent.js +9 -12
  332. package/dist/infrastructure/cloud/commandHandler.d.ts +0 -1
  333. package/dist/infrastructure/cloud/commandHandler.js +0 -1
  334. package/dist/infrastructure/cloud/commands.d.ts +0 -1
  335. package/dist/infrastructure/cloud/commands.js +2 -3
  336. package/dist/infrastructure/cloud/config.d.ts +0 -1
  337. package/dist/infrastructure/cloud/config.js +0 -1
  338. package/dist/infrastructure/cloud/httpSender.d.ts +0 -1
  339. package/dist/infrastructure/cloud/httpSender.js +0 -1
  340. package/dist/infrastructure/cloud/index.d.ts +0 -1
  341. package/dist/infrastructure/cloud/index.js +0 -1
  342. package/dist/infrastructure/cloud/logger.d.ts +0 -1
  343. package/dist/infrastructure/cloud/logger.js +0 -1
  344. package/dist/infrastructure/cloud/redact.d.ts +10 -0
  345. package/dist/infrastructure/cloud/redact.js +21 -0
  346. package/dist/infrastructure/cloud/snapshotCollector.d.ts +4 -1
  347. package/dist/infrastructure/cloud/snapshotCollector.js +32 -18
  348. package/dist/infrastructure/cloud/snapshotHelpers.d.ts +9 -3
  349. package/dist/infrastructure/cloud/snapshotHelpers.js +10 -9
  350. package/dist/infrastructure/cloud/statsRefresh.d.ts +0 -1
  351. package/dist/infrastructure/cloud/statsRefresh.js +0 -1
  352. package/dist/infrastructure/cloud/statsUpdate.d.ts +0 -1
  353. package/dist/infrastructure/cloud/statsUpdate.js +0 -1
  354. package/dist/infrastructure/cloud/types.d.ts +0 -1
  355. package/dist/infrastructure/cloud/types.js +0 -1
  356. package/dist/infrastructure/cloud/wsSender.d.ts +0 -1
  357. package/dist/infrastructure/cloud/wsSender.js +0 -1
  358. package/dist/infrastructure/persistence/index.d.ts +0 -1
  359. package/dist/infrastructure/persistence/index.js +0 -1
  360. package/dist/infrastructure/persistence/schema.d.ts +2 -3
  361. package/dist/infrastructure/persistence/schema.js +16 -3
  362. package/dist/infrastructure/persistence/sqlite.d.ts +54 -2
  363. package/dist/infrastructure/persistence/sqlite.js +174 -3
  364. package/dist/infrastructure/persistence/sqliteBatch.d.ts +14 -1
  365. package/dist/infrastructure/persistence/sqliteBatch.js +29 -1
  366. package/dist/infrastructure/persistence/sqliteSerializer.d.ts +16 -1
  367. package/dist/infrastructure/persistence/sqliteSerializer.js +73 -9
  368. package/dist/infrastructure/persistence/statements.d.ts +2 -2
  369. package/dist/infrastructure/persistence/statements.js +3 -3
  370. package/dist/infrastructure/scheduler/cronParser.d.ts +0 -1
  371. package/dist/infrastructure/scheduler/cronParser.js +0 -1
  372. package/dist/infrastructure/scheduler/cronScheduler.d.ts +0 -1
  373. package/dist/infrastructure/scheduler/cronScheduler.js +19 -2
  374. package/dist/infrastructure/scheduler/index.d.ts +0 -1
  375. package/dist/infrastructure/scheduler/index.js +0 -1
  376. package/dist/infrastructure/server/handler.d.ts +0 -1
  377. package/dist/infrastructure/server/handler.js +0 -1
  378. package/dist/infrastructure/server/handlerRoutes.d.ts +0 -1
  379. package/dist/infrastructure/server/handlerRoutes.js +0 -1
  380. package/dist/infrastructure/server/handlers/advanced.d.ts +7 -2
  381. package/dist/infrastructure/server/handlers/advanced.js +41 -11
  382. package/dist/infrastructure/server/handlers/core.d.ts +0 -1
  383. package/dist/infrastructure/server/handlers/core.js +8 -1
  384. package/dist/infrastructure/server/handlers/cron.d.ts +0 -1
  385. package/dist/infrastructure/server/handlers/cron.js +1 -1
  386. package/dist/infrastructure/server/handlers/dashboard.d.ts +0 -1
  387. package/dist/infrastructure/server/handlers/dashboard.js +1 -1
  388. package/dist/infrastructure/server/handlers/dlq.d.ts +0 -1
  389. package/dist/infrastructure/server/handlers/dlq.js +0 -1
  390. package/dist/infrastructure/server/handlers/index.d.ts +0 -1
  391. package/dist/infrastructure/server/handlers/index.js +0 -1
  392. package/dist/infrastructure/server/handlers/management.d.ts +1 -2
  393. package/dist/infrastructure/server/handlers/management.js +27 -13
  394. package/dist/infrastructure/server/handlers/monitoring.d.ts +0 -1
  395. package/dist/infrastructure/server/handlers/monitoring.js +0 -1
  396. package/dist/infrastructure/server/handlers/query.d.ts +0 -1
  397. package/dist/infrastructure/server/handlers/query.js +0 -1
  398. package/dist/infrastructure/server/http.d.ts +0 -1
  399. package/dist/infrastructure/server/http.js +0 -1
  400. package/dist/infrastructure/server/httpEndpoints.d.ts +0 -1
  401. package/dist/infrastructure/server/httpEndpoints.js +0 -1
  402. package/dist/infrastructure/server/httpRouteJobs.d.ts +0 -1
  403. package/dist/infrastructure/server/httpRouteJobs.js +0 -1
  404. package/dist/infrastructure/server/httpRouteQueueConfig.d.ts +0 -1
  405. package/dist/infrastructure/server/httpRouteQueueConfig.js +0 -1
  406. package/dist/infrastructure/server/httpRouteQueues.d.ts +0 -1
  407. package/dist/infrastructure/server/httpRouteQueues.js +0 -1
  408. package/dist/infrastructure/server/httpRouteResources.d.ts +0 -1
  409. package/dist/infrastructure/server/httpRouteResources.js +0 -1
  410. package/dist/infrastructure/server/index.d.ts +0 -1
  411. package/dist/infrastructure/server/index.js +0 -1
  412. package/dist/infrastructure/server/protocol.d.ts +4 -1
  413. package/dist/infrastructure/server/protocol.js +17 -3
  414. package/dist/infrastructure/server/rateLimiter.d.ts +0 -1
  415. package/dist/infrastructure/server/rateLimiter.js +0 -1
  416. package/dist/infrastructure/server/socketWriteQueue.d.ts +66 -0
  417. package/dist/infrastructure/server/socketWriteQueue.js +126 -0
  418. package/dist/infrastructure/server/sseHandler.d.ts +0 -1
  419. package/dist/infrastructure/server/sseHandler.js +0 -1
  420. package/dist/infrastructure/server/tcp.d.ts +17 -1
  421. package/dist/infrastructure/server/tcp.js +112 -15
  422. package/dist/infrastructure/server/types.d.ts +0 -1
  423. package/dist/infrastructure/server/types.js +0 -1
  424. package/dist/infrastructure/server/wsHandler.d.ts +0 -1
  425. package/dist/infrastructure/server/wsHandler.js +0 -1
  426. package/dist/main.d.ts +0 -1
  427. package/dist/main.js +48 -44
  428. package/dist/mcp/adapter.d.ts +3 -4
  429. package/dist/mcp/adapter.js +48 -16
  430. package/dist/mcp/httpHandler.d.ts +0 -1
  431. package/dist/mcp/httpHandler.js +0 -1
  432. package/dist/mcp/index.d.ts +3 -4
  433. package/dist/mcp/index.js +26 -90
  434. package/dist/mcp/prompts.d.ts +0 -1
  435. package/dist/mcp/prompts.js +0 -1
  436. package/dist/mcp/resources.d.ts +0 -1
  437. package/dist/mcp/resources.js +0 -1
  438. package/dist/mcp/server.d.ts +15 -0
  439. package/dist/mcp/server.js +100 -0
  440. package/dist/mcp/tools/consumptionTools.d.ts +0 -1
  441. package/dist/mcp/tools/consumptionTools.js +0 -1
  442. package/dist/mcp/tools/cronTools.d.ts +0 -1
  443. package/dist/mcp/tools/cronTools.js +0 -1
  444. package/dist/mcp/tools/dlqTools.d.ts +0 -1
  445. package/dist/mcp/tools/dlqTools.js +0 -1
  446. package/dist/mcp/tools/flowTools.d.ts +0 -1
  447. package/dist/mcp/tools/flowTools.js +0 -1
  448. package/dist/mcp/tools/handlerTools.d.ts +0 -1
  449. package/dist/mcp/tools/handlerTools.js +0 -1
  450. package/dist/mcp/tools/jobMgmtTools.d.ts +0 -1
  451. package/dist/mcp/tools/jobMgmtTools.js +0 -1
  452. package/dist/mcp/tools/jobTools.d.ts +0 -1
  453. package/dist/mcp/tools/jobTools.js +0 -1
  454. package/dist/mcp/tools/mcpTracker.d.ts +0 -1
  455. package/dist/mcp/tools/mcpTracker.js +0 -1
  456. package/dist/mcp/tools/monitoringTools.d.ts +0 -1
  457. package/dist/mcp/tools/monitoringTools.js +0 -1
  458. package/dist/mcp/tools/queueTools.d.ts +0 -1
  459. package/dist/mcp/tools/queueTools.js +6 -4
  460. package/dist/mcp/tools/rateLimitTools.d.ts +0 -1
  461. package/dist/mcp/tools/rateLimitTools.js +0 -1
  462. package/dist/mcp/tools/webhookTools.d.ts +0 -1
  463. package/dist/mcp/tools/webhookTools.js +1 -2
  464. package/dist/mcp/tools/withErrorHandler.d.ts +0 -1
  465. package/dist/mcp/tools/withErrorHandler.js +0 -1
  466. package/dist/mcp/tools/workerMgmtTools.d.ts +0 -1
  467. package/dist/mcp/tools/workerMgmtTools.js +0 -1
  468. package/dist/shared/boundedMap.d.ts +0 -1
  469. package/dist/shared/boundedMap.js +0 -1
  470. package/dist/shared/boundedSet.d.ts +0 -1
  471. package/dist/shared/boundedSet.js +0 -1
  472. package/dist/shared/hash.d.ts +0 -1
  473. package/dist/shared/hash.js +0 -1
  474. package/dist/shared/histogram.d.ts +0 -1
  475. package/dist/shared/histogram.js +0 -1
  476. package/dist/shared/index.d.ts +0 -1
  477. package/dist/shared/index.js +0 -1
  478. package/dist/shared/lock.d.ts +0 -1
  479. package/dist/shared/lock.js +15 -1
  480. package/dist/shared/logger.d.ts +0 -1
  481. package/dist/shared/logger.js +0 -1
  482. package/dist/shared/lru.d.ts +0 -1
  483. package/dist/shared/lru.js +0 -1
  484. package/dist/shared/lruMap.d.ts +0 -1
  485. package/dist/shared/lruMap.js +0 -1
  486. package/dist/shared/lruSet.d.ts +0 -1
  487. package/dist/shared/lruSet.js +0 -1
  488. package/dist/shared/minHeap.d.ts +0 -1
  489. package/dist/shared/minHeap.js +0 -1
  490. package/dist/shared/semaphore.d.ts +0 -1
  491. package/dist/shared/semaphore.js +0 -1
  492. package/dist/shared/serialization.d.ts +0 -1
  493. package/dist/shared/serialization.js +0 -1
  494. package/dist/shared/skipList.d.ts +0 -1
  495. package/dist/shared/skipList.js +0 -1
  496. package/dist/shared/ttlMap.d.ts +0 -1
  497. package/dist/shared/ttlMap.js +0 -1
  498. package/dist/shared/version.d.ts +0 -1
  499. package/dist/shared/version.js +0 -1
  500. package/dist/shared/webhookValidation.d.ts +0 -1
  501. package/dist/shared/webhookValidation.js +0 -1
  502. package/package.json +12 -9
  503. package/dist/application/backgroundTasks.d.ts.map +0 -1
  504. package/dist/application/backgroundTasks.js.map +0 -1
  505. package/dist/application/cleanupTasks.d.ts.map +0 -1
  506. package/dist/application/cleanupTasks.js.map +0 -1
  507. package/dist/application/clientTracking.d.ts.map +0 -1
  508. package/dist/application/clientTracking.js.map +0 -1
  509. package/dist/application/contextFactory.d.ts.map +0 -1
  510. package/dist/application/contextFactory.js.map +0 -1
  511. package/dist/application/dependencyProcessor.d.ts.map +0 -1
  512. package/dist/application/dependencyProcessor.js.map +0 -1
  513. package/dist/application/dlqManager.d.ts.map +0 -1
  514. package/dist/application/dlqManager.js.map +0 -1
  515. package/dist/application/eventsManager.d.ts.map +0 -1
  516. package/dist/application/eventsManager.js.map +0 -1
  517. package/dist/application/jobLogsManager.d.ts.map +0 -1
  518. package/dist/application/jobLogsManager.js.map +0 -1
  519. package/dist/application/latencyTracker.d.ts.map +0 -1
  520. package/dist/application/latencyTracker.js.map +0 -1
  521. package/dist/application/lockManager.d.ts.map +0 -1
  522. package/dist/application/lockManager.js.map +0 -1
  523. package/dist/application/lockOperations.d.ts.map +0 -1
  524. package/dist/application/lockOperations.js.map +0 -1
  525. package/dist/application/metricsExporter.d.ts.map +0 -1
  526. package/dist/application/metricsExporter.js.map +0 -1
  527. package/dist/application/monitoringChecks.d.ts.map +0 -1
  528. package/dist/application/monitoringChecks.js.map +0 -1
  529. package/dist/application/operations/ack.d.ts.map +0 -1
  530. package/dist/application/operations/ack.js.map +0 -1
  531. package/dist/application/operations/ackHelpers.d.ts.map +0 -1
  532. package/dist/application/operations/ackHelpers.js.map +0 -1
  533. package/dist/application/operations/index.d.ts.map +0 -1
  534. package/dist/application/operations/index.js.map +0 -1
  535. package/dist/application/operations/jobManagement.d.ts.map +0 -1
  536. package/dist/application/operations/jobManagement.js.map +0 -1
  537. package/dist/application/operations/jobStateTransitions.d.ts.map +0 -1
  538. package/dist/application/operations/jobStateTransitions.js.map +0 -1
  539. package/dist/application/operations/pull.d.ts.map +0 -1
  540. package/dist/application/operations/pull.js.map +0 -1
  541. package/dist/application/operations/push.d.ts.map +0 -1
  542. package/dist/application/operations/push.js.map +0 -1
  543. package/dist/application/operations/queryOperations.d.ts.map +0 -1
  544. package/dist/application/operations/queryOperations.js.map +0 -1
  545. package/dist/application/operations/queueControl.d.ts.map +0 -1
  546. package/dist/application/operations/queueControl.js.map +0 -1
  547. package/dist/application/queueManager.d.ts.map +0 -1
  548. package/dist/application/queueManager.js.map +0 -1
  549. package/dist/application/stallDetection.d.ts.map +0 -1
  550. package/dist/application/stallDetection.js.map +0 -1
  551. package/dist/application/statsManager.d.ts.map +0 -1
  552. package/dist/application/statsManager.js.map +0 -1
  553. package/dist/application/taskErrorTracking.d.ts.map +0 -1
  554. package/dist/application/taskErrorTracking.js.map +0 -1
  555. package/dist/application/throughputTracker.d.ts.map +0 -1
  556. package/dist/application/throughputTracker.js.map +0 -1
  557. package/dist/application/types.d.ts.map +0 -1
  558. package/dist/application/types.js.map +0 -1
  559. package/dist/application/webhookManager.d.ts.map +0 -1
  560. package/dist/application/webhookManager.js.map +0 -1
  561. package/dist/application/workerManager.d.ts.map +0 -1
  562. package/dist/application/workerManager.js.map +0 -1
  563. package/dist/cli/client.d.ts.map +0 -1
  564. package/dist/cli/client.js.map +0 -1
  565. package/dist/cli/commands/backup.d.ts.map +0 -1
  566. package/dist/cli/commands/backup.js.map +0 -1
  567. package/dist/cli/commands/core.d.ts.map +0 -1
  568. package/dist/cli/commands/core.js.map +0 -1
  569. package/dist/cli/commands/cron.d.ts.map +0 -1
  570. package/dist/cli/commands/cron.js.map +0 -1
  571. package/dist/cli/commands/dlq.d.ts.map +0 -1
  572. package/dist/cli/commands/dlq.js.map +0 -1
  573. package/dist/cli/commands/doctor.d.ts.map +0 -1
  574. package/dist/cli/commands/doctor.js.map +0 -1
  575. package/dist/cli/commands/job.d.ts.map +0 -1
  576. package/dist/cli/commands/job.js.map +0 -1
  577. package/dist/cli/commands/monitor.d.ts.map +0 -1
  578. package/dist/cli/commands/monitor.js.map +0 -1
  579. package/dist/cli/commands/queue.d.ts.map +0 -1
  580. package/dist/cli/commands/queue.js.map +0 -1
  581. package/dist/cli/commands/rateLimit.d.ts.map +0 -1
  582. package/dist/cli/commands/rateLimit.js.map +0 -1
  583. package/dist/cli/commands/server.d.ts.map +0 -1
  584. package/dist/cli/commands/server.js.map +0 -1
  585. package/dist/cli/commands/types.d.ts.map +0 -1
  586. package/dist/cli/commands/types.js.map +0 -1
  587. package/dist/cli/commands/webhook.d.ts.map +0 -1
  588. package/dist/cli/commands/webhook.js.map +0 -1
  589. package/dist/cli/commands/worker.d.ts.map +0 -1
  590. package/dist/cli/commands/worker.js.map +0 -1
  591. package/dist/cli/help.d.ts.map +0 -1
  592. package/dist/cli/help.js.map +0 -1
  593. package/dist/cli/index.d.ts.map +0 -1
  594. package/dist/cli/index.js.map +0 -1
  595. package/dist/cli/output.d.ts.map +0 -1
  596. package/dist/cli/output.js.map +0 -1
  597. package/dist/client/bunqueue/aging.d.ts.map +0 -1
  598. package/dist/client/bunqueue/aging.js.map +0 -1
  599. package/dist/client/bunqueue/batch.d.ts.map +0 -1
  600. package/dist/client/bunqueue/batch.js.map +0 -1
  601. package/dist/client/bunqueue/cancellation.d.ts.map +0 -1
  602. package/dist/client/bunqueue/cancellation.js.map +0 -1
  603. package/dist/client/bunqueue/circuitBreaker.d.ts.map +0 -1
  604. package/dist/client/bunqueue/circuitBreaker.js.map +0 -1
  605. package/dist/client/bunqueue/dedupDebounce.d.ts.map +0 -1
  606. package/dist/client/bunqueue/dedupDebounce.js.map +0 -1
  607. package/dist/client/bunqueue/dlqRateLimit.d.ts.map +0 -1
  608. package/dist/client/bunqueue/dlqRateLimit.js.map +0 -1
  609. package/dist/client/bunqueue/retry.d.ts.map +0 -1
  610. package/dist/client/bunqueue/retry.js.map +0 -1
  611. package/dist/client/bunqueue/triggers.d.ts.map +0 -1
  612. package/dist/client/bunqueue/triggers.js.map +0 -1
  613. package/dist/client/bunqueue/ttl.d.ts.map +0 -1
  614. package/dist/client/bunqueue/ttl.js.map +0 -1
  615. package/dist/client/bunqueue/types.d.ts.map +0 -1
  616. package/dist/client/bunqueue/types.js.map +0 -1
  617. package/dist/client/bunqueue.d.ts.map +0 -1
  618. package/dist/client/bunqueue.js.map +0 -1
  619. package/dist/client/errors.d.ts.map +0 -1
  620. package/dist/client/errors.js.map +0 -1
  621. package/dist/client/events.d.ts.map +0 -1
  622. package/dist/client/events.js.map +0 -1
  623. package/dist/client/flow.d.ts.map +0 -1
  624. package/dist/client/flow.js.map +0 -1
  625. package/dist/client/flowJobFactory.d.ts.map +0 -1
  626. package/dist/client/flowJobFactory.js.map +0 -1
  627. package/dist/client/flowPush.d.ts.map +0 -1
  628. package/dist/client/flowPush.js.map +0 -1
  629. package/dist/client/flowTypes.d.ts.map +0 -1
  630. package/dist/client/flowTypes.js.map +0 -1
  631. package/dist/client/index.d.ts.map +0 -1
  632. package/dist/client/index.js.map +0 -1
  633. package/dist/client/jobConversion.d.ts.map +0 -1
  634. package/dist/client/jobConversion.js.map +0 -1
  635. package/dist/client/jobConversionHelpers.d.ts.map +0 -1
  636. package/dist/client/jobConversionHelpers.js.map +0 -1
  637. package/dist/client/jobConversionTypes.d.ts.map +0 -1
  638. package/dist/client/jobConversionTypes.js.map +0 -1
  639. package/dist/client/jobHelpers.d.ts.map +0 -1
  640. package/dist/client/jobHelpers.js.map +0 -1
  641. package/dist/client/manager.d.ts.map +0 -1
  642. package/dist/client/manager.js.map +0 -1
  643. package/dist/client/queue/addBatcher.d.ts.map +0 -1
  644. package/dist/client/queue/addBatcher.js.map +0 -1
  645. package/dist/client/queue/bullmqCompat.d.ts.map +0 -1
  646. package/dist/client/queue/bullmqCompat.js.map +0 -1
  647. package/dist/client/queue/deduplication.d.ts.map +0 -1
  648. package/dist/client/queue/deduplication.js.map +0 -1
  649. package/dist/client/queue/dlq.d.ts.map +0 -1
  650. package/dist/client/queue/dlq.js.map +0 -1
  651. package/dist/client/queue/dlqOps.d.ts.map +0 -1
  652. package/dist/client/queue/dlqOps.js.map +0 -1
  653. package/dist/client/queue/helpers.d.ts.map +0 -1
  654. package/dist/client/queue/helpers.js.map +0 -1
  655. package/dist/client/queue/index.d.ts.map +0 -1
  656. package/dist/client/queue/index.js.map +0 -1
  657. package/dist/client/queue/jobMove.d.ts.map +0 -1
  658. package/dist/client/queue/jobMove.js.map +0 -1
  659. package/dist/client/queue/jobProxy.d.ts.map +0 -1
  660. package/dist/client/queue/jobProxy.js.map +0 -1
  661. package/dist/client/queue/operations/add.d.ts.map +0 -1
  662. package/dist/client/queue/operations/add.js.map +0 -1
  663. package/dist/client/queue/operations/control.d.ts.map +0 -1
  664. package/dist/client/queue/operations/control.js.map +0 -1
  665. package/dist/client/queue/operations/counts.d.ts.map +0 -1
  666. package/dist/client/queue/operations/counts.js.map +0 -1
  667. package/dist/client/queue/operations/index.d.ts.map +0 -1
  668. package/dist/client/queue/operations/index.js.map +0 -1
  669. package/dist/client/queue/operations/management.d.ts.map +0 -1
  670. package/dist/client/queue/operations/management.js.map +0 -1
  671. package/dist/client/queue/operations/query.d.ts.map +0 -1
  672. package/dist/client/queue/operations/query.js.map +0 -1
  673. package/dist/client/queue/queue.d.ts.map +0 -1
  674. package/dist/client/queue/queue.js.map +0 -1
  675. package/dist/client/queue/queueTypes.d.ts.map +0 -1
  676. package/dist/client/queue/queueTypes.js.map +0 -1
  677. package/dist/client/queue/rateLimit.d.ts.map +0 -1
  678. package/dist/client/queue/rateLimit.js.map +0 -1
  679. package/dist/client/queue/scheduler.d.ts.map +0 -1
  680. package/dist/client/queue/scheduler.js.map +0 -1
  681. package/dist/client/queue/stall.d.ts.map +0 -1
  682. package/dist/client/queue/stall.js.map +0 -1
  683. package/dist/client/queue/workers.d.ts.map +0 -1
  684. package/dist/client/queue/workers.js.map +0 -1
  685. package/dist/client/queue.d.ts.map +0 -1
  686. package/dist/client/queue.js.map +0 -1
  687. package/dist/client/queueGroup.d.ts.map +0 -1
  688. package/dist/client/queueGroup.js.map +0 -1
  689. package/dist/client/resolveToken.d.ts.map +0 -1
  690. package/dist/client/resolveToken.js.map +0 -1
  691. package/dist/client/sandboxed/index.d.ts.map +0 -1
  692. package/dist/client/sandboxed/index.js.map +0 -1
  693. package/dist/client/sandboxed/queueOps.d.ts.map +0 -1
  694. package/dist/client/sandboxed/queueOps.js.map +0 -1
  695. package/dist/client/sandboxed/types.d.ts.map +0 -1
  696. package/dist/client/sandboxed/types.js.map +0 -1
  697. package/dist/client/sandboxed/worker.d.ts.map +0 -1
  698. package/dist/client/sandboxed/worker.js.map +0 -1
  699. package/dist/client/sandboxed/wrapper.d.ts.map +0 -1
  700. package/dist/client/sandboxed/wrapper.js.map +0 -1
  701. package/dist/client/sandboxedWorker.d.ts.map +0 -1
  702. package/dist/client/sandboxedWorker.js.map +0 -1
  703. package/dist/client/tcp/client.d.ts.map +0 -1
  704. package/dist/client/tcp/client.js.map +0 -1
  705. package/dist/client/tcp/connection.d.ts.map +0 -1
  706. package/dist/client/tcp/connection.js.map +0 -1
  707. package/dist/client/tcp/health.d.ts.map +0 -1
  708. package/dist/client/tcp/health.js.map +0 -1
  709. package/dist/client/tcp/index.d.ts.map +0 -1
  710. package/dist/client/tcp/index.js.map +0 -1
  711. package/dist/client/tcp/reconnect.d.ts.map +0 -1
  712. package/dist/client/tcp/reconnect.js.map +0 -1
  713. package/dist/client/tcp/shared.d.ts.map +0 -1
  714. package/dist/client/tcp/shared.js.map +0 -1
  715. package/dist/client/tcp/types.d.ts.map +0 -1
  716. package/dist/client/tcp/types.js.map +0 -1
  717. package/dist/client/tcpClient.d.ts.map +0 -1
  718. package/dist/client/tcpClient.js.map +0 -1
  719. package/dist/client/tcpPool.d.ts.map +0 -1
  720. package/dist/client/tcpPool.js.map +0 -1
  721. package/dist/client/types.d.ts.map +0 -1
  722. package/dist/client/types.js.map +0 -1
  723. package/dist/client/worker/ackBatcher.d.ts.map +0 -1
  724. package/dist/client/worker/ackBatcher.js.map +0 -1
  725. package/dist/client/worker/groupConcurrency.d.ts.map +0 -1
  726. package/dist/client/worker/groupConcurrency.js.map +0 -1
  727. package/dist/client/worker/index.d.ts.map +0 -1
  728. package/dist/client/worker/index.js.map +0 -1
  729. package/dist/client/worker/jobParser.d.ts.map +0 -1
  730. package/dist/client/worker/jobParser.js.map +0 -1
  731. package/dist/client/worker/processor.d.ts.map +0 -1
  732. package/dist/client/worker/processor.js.map +0 -1
  733. package/dist/client/worker/types.d.ts.map +0 -1
  734. package/dist/client/worker/types.js.map +0 -1
  735. package/dist/client/worker/worker.d.ts.map +0 -1
  736. package/dist/client/worker/worker.js.map +0 -1
  737. package/dist/client/worker/workerHeartbeat.d.ts.map +0 -1
  738. package/dist/client/worker/workerHeartbeat.js.map +0 -1
  739. package/dist/client/worker/workerPull.d.ts.map +0 -1
  740. package/dist/client/worker/workerPull.js.map +0 -1
  741. package/dist/client/worker/workerRateLimiter.d.ts.map +0 -1
  742. package/dist/client/worker/workerRateLimiter.js.map +0 -1
  743. package/dist/client/worker.d.ts.map +0 -1
  744. package/dist/client/worker.js.map +0 -1
  745. package/dist/client/workflow/emitter.d.ts.map +0 -1
  746. package/dist/client/workflow/emitter.js.map +0 -1
  747. package/dist/client/workflow/engine.d.ts.map +0 -1
  748. package/dist/client/workflow/engine.js.map +0 -1
  749. package/dist/client/workflow/executor.d.ts.map +0 -1
  750. package/dist/client/workflow/executor.js.map +0 -1
  751. package/dist/client/workflow/index.d.ts.map +0 -1
  752. package/dist/client/workflow/index.js.map +0 -1
  753. package/dist/client/workflow/loops.d.ts.map +0 -1
  754. package/dist/client/workflow/loops.js.map +0 -1
  755. package/dist/client/workflow/runner.d.ts.map +0 -1
  756. package/dist/client/workflow/runner.js.map +0 -1
  757. package/dist/client/workflow/store.d.ts.map +0 -1
  758. package/dist/client/workflow/store.js.map +0 -1
  759. package/dist/client/workflow/types.d.ts.map +0 -1
  760. package/dist/client/workflow/types.js.map +0 -1
  761. package/dist/client/workflow/workflow.d.ts.map +0 -1
  762. package/dist/client/workflow/workflow.js.map +0 -1
  763. package/dist/config/index.d.ts.map +0 -1
  764. package/dist/config/index.js.map +0 -1
  765. package/dist/config/loader.d.ts.map +0 -1
  766. package/dist/config/loader.js.map +0 -1
  767. package/dist/config/resolve.d.ts.map +0 -1
  768. package/dist/config/resolve.js.map +0 -1
  769. package/dist/config/types.d.ts.map +0 -1
  770. package/dist/config/types.js.map +0 -1
  771. package/dist/domain/queue/dependencyTracker.d.ts.map +0 -1
  772. package/dist/domain/queue/dependencyTracker.js.map +0 -1
  773. package/dist/domain/queue/dlqShard.d.ts.map +0 -1
  774. package/dist/domain/queue/dlqShard.js.map +0 -1
  775. package/dist/domain/queue/index.d.ts.map +0 -1
  776. package/dist/domain/queue/index.js.map +0 -1
  777. package/dist/domain/queue/limiterManager.d.ts.map +0 -1
  778. package/dist/domain/queue/limiterManager.js.map +0 -1
  779. package/dist/domain/queue/priorityQueue.d.ts.map +0 -1
  780. package/dist/domain/queue/priorityQueue.js.map +0 -1
  781. package/dist/domain/queue/shard.d.ts.map +0 -1
  782. package/dist/domain/queue/shard.js.map +0 -1
  783. package/dist/domain/queue/shardCounters.d.ts.map +0 -1
  784. package/dist/domain/queue/shardCounters.js.map +0 -1
  785. package/dist/domain/queue/temporalManager.d.ts.map +0 -1
  786. package/dist/domain/queue/temporalManager.js.map +0 -1
  787. package/dist/domain/queue/uniqueKeyManager.d.ts.map +0 -1
  788. package/dist/domain/queue/uniqueKeyManager.js.map +0 -1
  789. package/dist/domain/queue/waiterManager.d.ts.map +0 -1
  790. package/dist/domain/queue/waiterManager.js.map +0 -1
  791. package/dist/domain/types/command.d.ts.map +0 -1
  792. package/dist/domain/types/command.js.map +0 -1
  793. package/dist/domain/types/cron.d.ts.map +0 -1
  794. package/dist/domain/types/cron.js.map +0 -1
  795. package/dist/domain/types/deduplication.d.ts.map +0 -1
  796. package/dist/domain/types/deduplication.js.map +0 -1
  797. package/dist/domain/types/dlq.d.ts.map +0 -1
  798. package/dist/domain/types/dlq.js.map +0 -1
  799. package/dist/domain/types/index.d.ts.map +0 -1
  800. package/dist/domain/types/index.js.map +0 -1
  801. package/dist/domain/types/job.d.ts.map +0 -1
  802. package/dist/domain/types/job.js.map +0 -1
  803. package/dist/domain/types/queue.d.ts.map +0 -1
  804. package/dist/domain/types/queue.js.map +0 -1
  805. package/dist/domain/types/response.d.ts.map +0 -1
  806. package/dist/domain/types/response.js.map +0 -1
  807. package/dist/domain/types/stall.d.ts.map +0 -1
  808. package/dist/domain/types/stall.js.map +0 -1
  809. package/dist/domain/types/webhook.d.ts.map +0 -1
  810. package/dist/domain/types/webhook.js.map +0 -1
  811. package/dist/domain/types/worker.d.ts.map +0 -1
  812. package/dist/domain/types/worker.js.map +0 -1
  813. package/dist/infrastructure/backup/index.d.ts.map +0 -1
  814. package/dist/infrastructure/backup/index.js.map +0 -1
  815. package/dist/infrastructure/backup/s3Backup.d.ts.map +0 -1
  816. package/dist/infrastructure/backup/s3Backup.js.map +0 -1
  817. package/dist/infrastructure/backup/s3BackupConfig.d.ts.map +0 -1
  818. package/dist/infrastructure/backup/s3BackupConfig.js.map +0 -1
  819. package/dist/infrastructure/backup/s3BackupOperations.d.ts.map +0 -1
  820. package/dist/infrastructure/backup/s3BackupOperations.js.map +0 -1
  821. package/dist/infrastructure/cloud/buffer.d.ts.map +0 -1
  822. package/dist/infrastructure/cloud/buffer.js.map +0 -1
  823. package/dist/infrastructure/cloud/circuitBreaker.d.ts.map +0 -1
  824. package/dist/infrastructure/cloud/circuitBreaker.js.map +0 -1
  825. package/dist/infrastructure/cloud/cloudAgent 2.d.ts +0 -55
  826. package/dist/infrastructure/cloud/cloudAgent 2.d.ts.map +0 -1
  827. package/dist/infrastructure/cloud/cloudAgent 2.js +0 -243
  828. package/dist/infrastructure/cloud/cloudAgent 2.js.map +0 -1
  829. package/dist/infrastructure/cloud/cloudAgent.d.ts.map +0 -1
  830. package/dist/infrastructure/cloud/cloudAgent.js.map +0 -1
  831. package/dist/infrastructure/cloud/commandHandler 2.d.ts +0 -52
  832. package/dist/infrastructure/cloud/commandHandler 2.d.ts.map +0 -1
  833. package/dist/infrastructure/cloud/commandHandler 2.js +0 -84
  834. package/dist/infrastructure/cloud/commandHandler 2.js.map +0 -1
  835. package/dist/infrastructure/cloud/commandHandler.d.ts.map +0 -1
  836. package/dist/infrastructure/cloud/commandHandler.js.map +0 -1
  837. package/dist/infrastructure/cloud/commands 2.d.ts +0 -11
  838. package/dist/infrastructure/cloud/commands 2.d.ts.map +0 -1
  839. package/dist/infrastructure/cloud/commands 2.js +0 -343
  840. package/dist/infrastructure/cloud/commands 2.js.map +0 -1
  841. package/dist/infrastructure/cloud/commands.d.ts.map +0 -1
  842. package/dist/infrastructure/cloud/commands.js.map +0 -1
  843. package/dist/infrastructure/cloud/config.d.ts.map +0 -1
  844. package/dist/infrastructure/cloud/config.js.map +0 -1
  845. package/dist/infrastructure/cloud/httpSender.d.ts.map +0 -1
  846. package/dist/infrastructure/cloud/httpSender.js.map +0 -1
  847. package/dist/infrastructure/cloud/index.d.ts.map +0 -1
  848. package/dist/infrastructure/cloud/index.js.map +0 -1
  849. package/dist/infrastructure/cloud/instanceId.d.ts +0 -7
  850. package/dist/infrastructure/cloud/instanceId.d.ts.map +0 -1
  851. package/dist/infrastructure/cloud/instanceId.js +0 -34
  852. package/dist/infrastructure/cloud/instanceId.js.map +0 -1
  853. package/dist/infrastructure/cloud/logger.d.ts.map +0 -1
  854. package/dist/infrastructure/cloud/logger.js.map +0 -1
  855. package/dist/infrastructure/cloud/snapshotCollector.d.ts.map +0 -1
  856. package/dist/infrastructure/cloud/snapshotCollector.js.map +0 -1
  857. package/dist/infrastructure/cloud/snapshotHelpers.d.ts.map +0 -1
  858. package/dist/infrastructure/cloud/snapshotHelpers.js.map +0 -1
  859. package/dist/infrastructure/cloud/statsRefresh.d.ts.map +0 -1
  860. package/dist/infrastructure/cloud/statsRefresh.js.map +0 -1
  861. package/dist/infrastructure/cloud/statsUpdate.d.ts.map +0 -1
  862. package/dist/infrastructure/cloud/statsUpdate.js.map +0 -1
  863. package/dist/infrastructure/cloud/types.d.ts.map +0 -1
  864. package/dist/infrastructure/cloud/types.js.map +0 -1
  865. package/dist/infrastructure/cloud/wsSender.d.ts.map +0 -1
  866. package/dist/infrastructure/cloud/wsSender.js.map +0 -1
  867. package/dist/infrastructure/persistence/index.d.ts.map +0 -1
  868. package/dist/infrastructure/persistence/index.js.map +0 -1
  869. package/dist/infrastructure/persistence/schema.d.ts.map +0 -1
  870. package/dist/infrastructure/persistence/schema.js.map +0 -1
  871. package/dist/infrastructure/persistence/sqlite.d.ts.map +0 -1
  872. package/dist/infrastructure/persistence/sqlite.js.map +0 -1
  873. package/dist/infrastructure/persistence/sqliteBatch.d.ts.map +0 -1
  874. package/dist/infrastructure/persistence/sqliteBatch.js.map +0 -1
  875. package/dist/infrastructure/persistence/sqliteSerializer.d.ts.map +0 -1
  876. package/dist/infrastructure/persistence/sqliteSerializer.js.map +0 -1
  877. package/dist/infrastructure/persistence/statements.d.ts.map +0 -1
  878. package/dist/infrastructure/persistence/statements.js.map +0 -1
  879. package/dist/infrastructure/scheduler/cronParser.d.ts.map +0 -1
  880. package/dist/infrastructure/scheduler/cronParser.js.map +0 -1
  881. package/dist/infrastructure/scheduler/cronScheduler.d.ts.map +0 -1
  882. package/dist/infrastructure/scheduler/cronScheduler.js.map +0 -1
  883. package/dist/infrastructure/scheduler/index.d.ts.map +0 -1
  884. package/dist/infrastructure/scheduler/index.js.map +0 -1
  885. package/dist/infrastructure/server/handler.d.ts.map +0 -1
  886. package/dist/infrastructure/server/handler.js.map +0 -1
  887. package/dist/infrastructure/server/handlerRoutes.d.ts.map +0 -1
  888. package/dist/infrastructure/server/handlerRoutes.js.map +0 -1
  889. package/dist/infrastructure/server/handlers/advanced.d.ts.map +0 -1
  890. package/dist/infrastructure/server/handlers/advanced.js.map +0 -1
  891. package/dist/infrastructure/server/handlers/core.d.ts.map +0 -1
  892. package/dist/infrastructure/server/handlers/core.js.map +0 -1
  893. package/dist/infrastructure/server/handlers/cron.d.ts.map +0 -1
  894. package/dist/infrastructure/server/handlers/cron.js.map +0 -1
  895. package/dist/infrastructure/server/handlers/dashboard.d.ts.map +0 -1
  896. package/dist/infrastructure/server/handlers/dashboard.js.map +0 -1
  897. package/dist/infrastructure/server/handlers/dlq.d.ts.map +0 -1
  898. package/dist/infrastructure/server/handlers/dlq.js.map +0 -1
  899. package/dist/infrastructure/server/handlers/index.d.ts.map +0 -1
  900. package/dist/infrastructure/server/handlers/index.js.map +0 -1
  901. package/dist/infrastructure/server/handlers/management.d.ts.map +0 -1
  902. package/dist/infrastructure/server/handlers/management.js.map +0 -1
  903. package/dist/infrastructure/server/handlers/monitoring.d.ts.map +0 -1
  904. package/dist/infrastructure/server/handlers/monitoring.js.map +0 -1
  905. package/dist/infrastructure/server/handlers/query.d.ts.map +0 -1
  906. package/dist/infrastructure/server/handlers/query.js.map +0 -1
  907. package/dist/infrastructure/server/http.d.ts.map +0 -1
  908. package/dist/infrastructure/server/http.js.map +0 -1
  909. package/dist/infrastructure/server/httpEndpoints.d.ts.map +0 -1
  910. package/dist/infrastructure/server/httpEndpoints.js.map +0 -1
  911. package/dist/infrastructure/server/httpRouteJobs.d.ts.map +0 -1
  912. package/dist/infrastructure/server/httpRouteJobs.js.map +0 -1
  913. package/dist/infrastructure/server/httpRouteQueueConfig.d.ts.map +0 -1
  914. package/dist/infrastructure/server/httpRouteQueueConfig.js.map +0 -1
  915. package/dist/infrastructure/server/httpRouteQueues.d.ts.map +0 -1
  916. package/dist/infrastructure/server/httpRouteQueues.js.map +0 -1
  917. package/dist/infrastructure/server/httpRouteResources.d.ts.map +0 -1
  918. package/dist/infrastructure/server/httpRouteResources.js.map +0 -1
  919. package/dist/infrastructure/server/index.d.ts.map +0 -1
  920. package/dist/infrastructure/server/index.js.map +0 -1
  921. package/dist/infrastructure/server/protocol.d.ts.map +0 -1
  922. package/dist/infrastructure/server/protocol.js.map +0 -1
  923. package/dist/infrastructure/server/rateLimiter.d.ts.map +0 -1
  924. package/dist/infrastructure/server/rateLimiter.js.map +0 -1
  925. package/dist/infrastructure/server/sseHandler.d.ts.map +0 -1
  926. package/dist/infrastructure/server/sseHandler.js.map +0 -1
  927. package/dist/infrastructure/server/tcp.d.ts.map +0 -1
  928. package/dist/infrastructure/server/tcp.js.map +0 -1
  929. package/dist/infrastructure/server/types.d.ts.map +0 -1
  930. package/dist/infrastructure/server/types.js.map +0 -1
  931. package/dist/infrastructure/server/wsHandler.d.ts.map +0 -1
  932. package/dist/infrastructure/server/wsHandler.js.map +0 -1
  933. package/dist/main.d.ts.map +0 -1
  934. package/dist/main.js.map +0 -1
  935. package/dist/mcp/adapter.d.ts.map +0 -1
  936. package/dist/mcp/adapter.js.map +0 -1
  937. package/dist/mcp/httpHandler.d.ts.map +0 -1
  938. package/dist/mcp/httpHandler.js.map +0 -1
  939. package/dist/mcp/index.d.ts.map +0 -1
  940. package/dist/mcp/index.js.map +0 -1
  941. package/dist/mcp/mcpHandlers.d.ts +0 -129
  942. package/dist/mcp/mcpHandlers.d.ts.map +0 -1
  943. package/dist/mcp/mcpHandlers.js +0 -204
  944. package/dist/mcp/mcpHandlers.js.map +0 -1
  945. package/dist/mcp/mcpTools.d.ts +0 -15
  946. package/dist/mcp/mcpTools.d.ts.map +0 -1
  947. package/dist/mcp/mcpTools.js +0 -277
  948. package/dist/mcp/mcpTools.js.map +0 -1
  949. package/dist/mcp/prompts.d.ts.map +0 -1
  950. package/dist/mcp/prompts.js.map +0 -1
  951. package/dist/mcp/resources.d.ts.map +0 -1
  952. package/dist/mcp/resources.js.map +0 -1
  953. package/dist/mcp/tools/consumptionTools.d.ts.map +0 -1
  954. package/dist/mcp/tools/consumptionTools.js.map +0 -1
  955. package/dist/mcp/tools/cronTools.d.ts.map +0 -1
  956. package/dist/mcp/tools/cronTools.js.map +0 -1
  957. package/dist/mcp/tools/dlqTools.d.ts.map +0 -1
  958. package/dist/mcp/tools/dlqTools.js.map +0 -1
  959. package/dist/mcp/tools/flowTools.d.ts.map +0 -1
  960. package/dist/mcp/tools/flowTools.js.map +0 -1
  961. package/dist/mcp/tools/handlerTools.d.ts.map +0 -1
  962. package/dist/mcp/tools/handlerTools.js.map +0 -1
  963. package/dist/mcp/tools/jobMgmtTools.d.ts.map +0 -1
  964. package/dist/mcp/tools/jobMgmtTools.js.map +0 -1
  965. package/dist/mcp/tools/jobTools.d.ts.map +0 -1
  966. package/dist/mcp/tools/jobTools.js.map +0 -1
  967. package/dist/mcp/tools/mcpTracker.d.ts.map +0 -1
  968. package/dist/mcp/tools/mcpTracker.js.map +0 -1
  969. package/dist/mcp/tools/monitoringTools.d.ts.map +0 -1
  970. package/dist/mcp/tools/monitoringTools.js.map +0 -1
  971. package/dist/mcp/tools/queueTools.d.ts.map +0 -1
  972. package/dist/mcp/tools/queueTools.js.map +0 -1
  973. package/dist/mcp/tools/rateLimitTools.d.ts.map +0 -1
  974. package/dist/mcp/tools/rateLimitTools.js.map +0 -1
  975. package/dist/mcp/tools/webhookTools.d.ts.map +0 -1
  976. package/dist/mcp/tools/webhookTools.js.map +0 -1
  977. package/dist/mcp/tools/withErrorHandler.d.ts.map +0 -1
  978. package/dist/mcp/tools/withErrorHandler.js.map +0 -1
  979. package/dist/mcp/tools/workerMgmtTools.d.ts.map +0 -1
  980. package/dist/mcp/tools/workerMgmtTools.js.map +0 -1
  981. package/dist/shared/boundedMap.d.ts.map +0 -1
  982. package/dist/shared/boundedMap.js.map +0 -1
  983. package/dist/shared/boundedSet.d.ts.map +0 -1
  984. package/dist/shared/boundedSet.js.map +0 -1
  985. package/dist/shared/hash.d.ts.map +0 -1
  986. package/dist/shared/hash.js.map +0 -1
  987. package/dist/shared/histogram.d.ts.map +0 -1
  988. package/dist/shared/histogram.js.map +0 -1
  989. package/dist/shared/index.d.ts.map +0 -1
  990. package/dist/shared/index.js.map +0 -1
  991. package/dist/shared/lock.d.ts.map +0 -1
  992. package/dist/shared/lock.js.map +0 -1
  993. package/dist/shared/logger.d.ts.map +0 -1
  994. package/dist/shared/logger.js.map +0 -1
  995. package/dist/shared/lru.d.ts.map +0 -1
  996. package/dist/shared/lru.js.map +0 -1
  997. package/dist/shared/lruMap.d.ts.map +0 -1
  998. package/dist/shared/lruMap.js.map +0 -1
  999. package/dist/shared/lruSet.d.ts.map +0 -1
  1000. package/dist/shared/lruSet.js.map +0 -1
  1001. package/dist/shared/minHeap.d.ts.map +0 -1
  1002. package/dist/shared/minHeap.js.map +0 -1
  1003. package/dist/shared/semaphore.d.ts.map +0 -1
  1004. package/dist/shared/semaphore.js.map +0 -1
  1005. package/dist/shared/serialization.d.ts.map +0 -1
  1006. package/dist/shared/serialization.js.map +0 -1
  1007. package/dist/shared/skipList.d.ts.map +0 -1
  1008. package/dist/shared/skipList.js.map +0 -1
  1009. package/dist/shared/ttlMap.d.ts.map +0 -1
  1010. package/dist/shared/ttlMap.js.map +0 -1
  1011. package/dist/shared/version.d.ts.map +0 -1
  1012. package/dist/shared/version.js.map +0 -1
  1013. package/dist/shared/webhookValidation.d.ts.map +0 -1
  1014. package/dist/shared/webhookValidation.js.map +0 -1
@@ -509,6 +509,15 @@ export class QueueManager {
509
509
  releaseClientJobs(clientId) {
510
510
  return lockMgr.releaseClientJobs(clientId, this.contextFactory.getLockContext());
511
511
  }
512
+ /**
513
+ * Force-release client tracking without acquiring queue locks. Last-resort
514
+ * fallback when releaseClientJobs has exhausted its retry budget — clears
515
+ * the clientJobs map entry to prevent leaks and resets job heartbeats so
516
+ * the stall detector recovers orphaned active jobs on its next tick.
517
+ */
518
+ forceReleaseClientJobs(clientId) {
519
+ return lockMgr.forceReleaseClientJobs(clientId, this.contextFactory.getLockContext());
520
+ }
512
521
  // ============ Query Operations ============
513
522
  async getJob(jobId) {
514
523
  return queryOps.getJob(jobId, this.contextFactory.getQueryContext());
@@ -630,6 +639,55 @@ export class QueueManager {
630
639
  }
631
640
  obliterate(queue) {
632
641
  queueControl.obliterateQueue(queue, this.contextFactory.getQueueControlContext());
642
+ dlqOps.purgeDlqJobs(queue, this.contextFactory.getDlqContext());
643
+ // obliterateQueue() clears the waiting/delayed shard only. Active jobs in
644
+ // processingShards, plus completed/result/log/lock state in global indexes,
645
+ // plus SQLite rows, all survive unless we purge them here.
646
+ const toDrop = new Set();
647
+ for (const [jid, loc] of this.jobIndex) {
648
+ if (loc.type === 'processing') {
649
+ const job = this.processingShards[loc.shardIdx]?.get(jid);
650
+ if (job?.queue === queue)
651
+ toDrop.add(jid);
652
+ }
653
+ else if (loc.queueName === queue) {
654
+ toDrop.add(jid);
655
+ }
656
+ }
657
+ for (const jid of toDrop) {
658
+ const loc = this.jobIndex.get(jid);
659
+ if (loc?.type === 'processing') {
660
+ this.processingShards[loc.shardIdx]?.delete(jid);
661
+ }
662
+ this.jobIndex.delete(jid);
663
+ this.completedJobs.delete(jid);
664
+ this.completedJobsData.delete(jid);
665
+ this.jobResults.delete(jid);
666
+ this.jobLogs.delete(jid);
667
+ this.jobLocks.delete(jid);
668
+ this.failedChildrenValues.delete(jid);
669
+ this.ignoredChildrenFailures.delete(jid);
670
+ this.pendingDepChecks.delete(jid);
671
+ this.stalledCandidates.delete(jid);
672
+ this.repeatChain.delete(jid);
673
+ this.storage?.deleteJob(jid);
674
+ }
675
+ // repeatChain maps oldId → newId; drop rows whose value is now a ghost.
676
+ const chainKeysToDelete = [];
677
+ for (const [oldId, newId] of this.repeatChain) {
678
+ if (toDrop.has(newId))
679
+ chainKeysToDelete.push(oldId);
680
+ }
681
+ for (const oldId of chainKeysToDelete)
682
+ this.repeatChain.delete(oldId);
683
+ // Drop customId → JobId mappings that point at a dropped job
684
+ const customIdsToDelete = [];
685
+ for (const [cid, jid] of this.customIdMap.entries()) {
686
+ if (toDrop.has(jid))
687
+ customIdsToDelete.push(cid);
688
+ }
689
+ for (const cid of customIdsToDelete)
690
+ this.customIdMap.delete(cid);
633
691
  this.unregisterQueueName(queue);
634
692
  this.dashboardEmit?.('queue:obliterated', { queue });
635
693
  this.dashboardEmit?.('queue:removed', { queue });
@@ -773,8 +831,8 @@ export class QueueManager {
773
831
  async updateJobData(jobId, data) {
774
832
  return jobMgmt.updateJobData(jobId, data, this.contextFactory.getJobMgmtContext());
775
833
  }
776
- async changePriority(jobId, priority) {
777
- return jobMgmt.changeJobPriority(jobId, priority, this.contextFactory.getJobMgmtContext());
834
+ async changePriority(jobId, priority, lifo) {
835
+ return jobMgmt.changeJobPriority(jobId, priority, this.contextFactory.getJobMgmtContext(), lifo);
778
836
  }
779
837
  async promote(jobId) {
780
838
  return jobMgmt.promoteJob(jobId, this.contextFactory.getJobMgmtContext());
@@ -783,8 +841,14 @@ export class QueueManager {
783
841
  return jobMgmt.moveJobToDelayed(jobId, delay, this.contextFactory.getJobMgmtContext());
784
842
  }
785
843
  async changeDelay(jobId, delay) {
786
- // Change delay is essentially moving to delayed with new delay
787
- return jobMgmt.moveJobToDelayed(jobId, delay, this.contextFactory.getJobMgmtContext());
844
+ const ctx = this.contextFactory.getJobMgmtContext();
845
+ const loc = ctx.jobIndex.get(jobId);
846
+ // Jobs already in queue (waiting/delayed): mutate runAt in place
847
+ if (loc?.type === 'queue') {
848
+ return jobTransitions.changeWaitingDelay(jobId, delay, ctx);
849
+ }
850
+ // Active/processing jobs: move back to queue with new delay
851
+ return jobMgmt.moveJobToDelayed(jobId, delay, ctx);
788
852
  }
789
853
  async moveActiveToWait(jobId) {
790
854
  return jobTransitions.moveActiveToWait(jobId, this.contextFactory.getJobMgmtContext());
@@ -933,6 +997,15 @@ export class QueueManager {
933
997
  return this.shards;
934
998
  }
935
999
  onJobCompleted(completedId) {
1000
+ // Release flow-failure tracking once a parent job reaches terminal completion
1001
+ // (AUDIT H8). The parent consumes these values via getFailedChildrenValues()/
1002
+ // getIgnoredChildrenFailures() while it is processing (before it acks), so by the
1003
+ // time it completes they are no longer needed. Keyed by parentId; obliterate()
1004
+ // and shutdown() clear them too. Without this, every parent completion that
1005
+ // involved a failed child with continueParentOnFailure / ignoreDependencyOnFailure
1006
+ // leaked an entry permanently.
1007
+ this.failedChildrenValues.delete(completedId);
1008
+ this.ignoredChildrenFailures.delete(completedId);
936
1009
  this.pendingDepChecks.add(completedId);
937
1010
  this.scheduleDependencyFlush();
938
1011
  void this.checkFlowCompleted(completedId);
@@ -1003,7 +1076,11 @@ export class QueueManager {
1003
1076
  const entry = shard.addToDlq(parentJob, "unknown" /* FailureReason.Unknown */, failError);
1004
1077
  this.jobIndex.set(parentId, { type: 'dlq', queueName: parentJob.queue });
1005
1078
  this.storage?.saveDlqEntry(entry);
1079
+ this.storage?.deleteJob(parentId);
1006
1080
  });
1081
+ // Parent reached a terminal (DLQ) state — release its flow-failure tracking.
1082
+ this.failedChildrenValues.delete(parentId);
1083
+ this.ignoredChildrenFailures.delete(parentId);
1007
1084
  // Broadcast failed event for parent
1008
1085
  this.eventsManager.broadcast({
1009
1086
  eventType: 'failed',
@@ -1035,7 +1112,7 @@ export class QueueManager {
1035
1112
  }
1036
1113
  }
1037
1114
  /**
1038
- * continueParentOnFailure: move parent to queue immediately when a child fails.
1115
+ * continueParentOnFailure: move parent to queue when a child fails.
1039
1116
  * Stores the failure info for getFailedChildrenValues().
1040
1117
  */
1041
1118
  async continueParentOnChildFailure(childJob, error) {
@@ -1054,6 +1131,19 @@ export class QueueManager {
1054
1131
  existing[childKey] = error ?? 'unknown error';
1055
1132
  this.failedChildrenValues.set(parentId, existing);
1056
1133
  const idx = shardIndex(parentJob.queue);
1134
+ await this.promoteParentAfterChildFailure(parentId, parentJob, idx);
1135
+ }
1136
+ /**
1137
+ * Move a flow parent from its waiting state into the run queue after a child failure
1138
+ * (continueParentOnFailure / last-dependency resolution). Deferred to the next tick
1139
+ * so the failed child's worker batch drains first — the parent is then picked up on
1140
+ * a subsequent poll rather than racing to completion in the same synchronous cascade.
1141
+ */
1142
+ async promoteParentAfterChildFailure(parentId, parentJob, idx) {
1143
+ await new Promise((resolve) => {
1144
+ const timer = setTimeout(resolve, 0);
1145
+ timer.unref?.();
1146
+ });
1057
1147
  let promoted = false;
1058
1148
  await withWriteLock(this.shardLocks[idx], () => {
1059
1149
  // TOCTOU guard
@@ -1113,7 +1203,9 @@ export class QueueManager {
1113
1203
  this.ignoredChildrenFailures.set(parentId, existing);
1114
1204
  }
1115
1205
  const idx = shardIndex(parentJob.queue);
1116
- let promoted = false;
1206
+ // Remove the failed child from the parent's pending deps synchronously so
1207
+ // dependency tracking stays consistent; defer only the promotion decision.
1208
+ let readyToPromote = false;
1117
1209
  await withWriteLock(this.shardLocks[idx], () => {
1118
1210
  if (this.jobIndex.get(parentId)?.type !== 'queue')
1119
1211
  return;
@@ -1127,28 +1219,13 @@ export class QueueManager {
1127
1219
  parentJob.dependsOn.splice(depIndex, 1);
1128
1220
  shard.unregisterDependencies(parentId, [childJob.id]);
1129
1221
  }
1130
- // If no more pending deps, promote parent
1131
- const allDone = parentJob.dependsOn.length === 0 ||
1132
- parentJob.dependsOn.every((dep) => this.completedJobs.has(dep));
1133
- if (allDone) {
1134
- shard.waitingDeps.delete(parentId);
1135
- const now = Date.now();
1136
- parentJob.runAt = now;
1137
- shard.getQueue(parentJob.queue).push(parentJob);
1138
- shard.incrementQueued(parentId, false, parentJob.createdAt, parentJob.queue, now);
1139
- this.jobIndex.set(parentId, { type: 'queue', shardIdx: idx, queueName: parentJob.queue });
1140
- shard.notify();
1141
- promoted = true;
1142
- }
1222
+ // If no more pending deps, the parent is ready to be promoted
1223
+ readyToPromote =
1224
+ parentJob.dependsOn.length === 0 ||
1225
+ parentJob.dependsOn.every((dep) => this.completedJobs.has(dep));
1143
1226
  });
1144
- if (promoted) {
1145
- this.eventsManager.broadcast({
1146
- eventType: 'waiting',
1147
- queue: parentJob.queue,
1148
- jobId: parentId,
1149
- timestamp: Date.now(),
1150
- prev: 'waiting-children',
1151
- });
1227
+ if (readyToPromote) {
1228
+ await this.promoteParentAfterChildFailure(parentId, parentJob, idx);
1152
1229
  }
1153
1230
  }
1154
1231
  /**
@@ -1353,6 +1430,8 @@ export class QueueManager {
1353
1430
  this.stalledCandidates.clear();
1354
1431
  this.clientJobs.clear();
1355
1432
  this.repeatChain.clear();
1433
+ this.failedChildrenValues.clear();
1434
+ this.ignoredChildrenFailures.clear();
1356
1435
  for (const shard of this.processingShards)
1357
1436
  shard.clear();
1358
1437
  for (const shard of this.shards) {
@@ -1364,4 +1443,3 @@ export class QueueManager {
1364
1443
  }
1365
1444
  }
1366
1445
  }
1367
- //# sourceMappingURL=queueManager.js.map
@@ -8,4 +8,3 @@ import type { BackgroundContext } from './types';
8
8
  * Uses two-phase detection to prevent false positives
9
9
  */
10
10
  export declare function checkStalledJobs(ctx: BackgroundContext): void;
11
- //# sourceMappingURL=stallDetection.d.ts.map
@@ -115,6 +115,7 @@ function moveStalliedJobToDlq(job, ctx, shard, procIdx, _idx) {
115
115
  const entry = shard.addToDlq(job, "stalled" /* FailureReason.Stalled */, `Job stalled ${job.stallCount + 1} times`);
116
116
  ctx.jobIndex.set(job.id, { type: 'dlq', queueName: job.queue });
117
117
  ctx.storage?.saveDlqEntry(entry);
118
+ ctx.storage?.deleteJob(job.id);
118
119
  }
119
120
  /** Retry stalled job */
120
121
  function retryStalliedJob(job, ctx, shard, procIdx, idx) {
@@ -150,4 +151,3 @@ function retryStalliedJob(job, ctx, shard, procIdx, idx) {
150
151
  ctx.jobIndex.set(job.id, { type: 'queue', shardIdx: idx, queueName: job.queue });
151
152
  ctx.storage?.updateForRetry(job);
152
153
  }
153
- //# sourceMappingURL=stallDetection.js.map
@@ -81,4 +81,3 @@ export declare function getQueueJobCounts(queueName: string, ctx: StatsContext):
81
81
  * Use after large batch operations or when memory pressure is high.
82
82
  */
83
83
  export declare function compactMemory(ctx: StatsContext): void;
84
- //# sourceMappingURL=statsManager.d.ts.map
@@ -225,4 +225,3 @@ export function compactMemory(ctx) {
225
225
  }
226
226
  }
227
227
  }
228
- //# sourceMappingURL=statsManager.js.map
@@ -20,4 +20,3 @@ export declare function handleTaskSuccess(taskName: string): void;
20
20
  * Get error statistics for monitoring
21
21
  */
22
22
  export declare function getTaskErrorStats(): Record<string, TaskErrorState>;
23
- //# sourceMappingURL=taskErrorTracking.d.ts.map
@@ -47,4 +47,3 @@ export function handleTaskSuccess(taskName) {
47
47
  export function getTaskErrorStats() {
48
48
  return { ...taskErrors };
49
49
  }
50
- //# sourceMappingURL=taskErrorTracking.js.map
@@ -32,4 +32,3 @@ export declare class ThroughputTracker {
32
32
  /** Global singleton */
33
33
  export declare const throughputTracker: ThroughputTracker;
34
34
  export {};
35
- //# sourceMappingURL=throughputTracker.d.ts.map
@@ -50,4 +50,3 @@ export class ThroughputTracker {
50
50
  }
51
51
  /** Global singleton */
52
52
  export const throughputTracker = new ThroughputTracker();
53
- //# sourceMappingURL=throughputTracker.js.map
@@ -7,7 +7,7 @@ import type { JobLogEntry } from '../domain/types/worker';
7
7
  import type { Shard } from '../domain/queue/shard';
8
8
  import type { SqliteStorage } from '../infrastructure/persistence/sqlite';
9
9
  import type { RWLock } from '../shared/lock';
10
- import type { LRUMap, BoundedSet, SetLike } from '../shared/lru';
10
+ import type { LRUMap, BoundedSet, BoundedMap, SetLike } from '../shared/lru';
11
11
  import type { EventsManager } from './eventsManager';
12
12
  import type { WebhookManager } from './webhookManager';
13
13
  import type { WorkerManager } from './workerManager';
@@ -102,6 +102,7 @@ export interface BackgroundContext extends QueueManagerState {
102
102
  dashboardEmit?: (event: string, data: Record<string, unknown>) => void;
103
103
  workerManager: WorkerManager;
104
104
  monitoringState: MonitoringState;
105
+ completedJobsData: BoundedMap<JobId, Job>;
105
106
  }
106
107
  /** Context for stats operations */
107
108
  export interface StatsContext {
@@ -136,4 +137,3 @@ export interface StatsContext {
136
137
  totalFailed: bigint;
137
138
  }>;
138
139
  }
139
- //# sourceMappingURL=types.d.ts.map
@@ -13,4 +13,3 @@ export const DEFAULT_CONFIG = {
13
13
  stallCheckMs: 5_000,
14
14
  dlqMaintenanceMs: 60_000,
15
15
  };
16
- //# sourceMappingURL=types.js.map
@@ -45,4 +45,3 @@ export declare class WebhookManager {
45
45
  enabled: number;
46
46
  };
47
47
  }
48
- //# sourceMappingURL=webhookManager.d.ts.map
@@ -155,4 +155,3 @@ export class WebhookManager {
155
155
  };
156
156
  }
157
157
  }
158
- //# sourceMappingURL=webhookManager.js.map
@@ -58,4 +58,3 @@ export declare class WorkerManager {
58
58
  activeJobs: number;
59
59
  };
60
60
  }
61
- //# sourceMappingURL=workerManager.d.ts.map
@@ -217,4 +217,3 @@ export class WorkerManager {
217
217
  };
218
218
  }
219
219
  }
220
- //# sourceMappingURL=workerManager.js.map
@@ -15,4 +15,3 @@ export interface ClientOptions {
15
15
  }
16
16
  /** Execute a CLI command against the server */
17
17
  export declare function executeCommand(command: string, args: string[], options: ClientOptions): Promise<void>;
18
- //# sourceMappingURL=client.d.ts.map
@@ -135,11 +135,24 @@ export async function executeCommand(command, args, options) {
135
135
  }
136
136
  // Execute command
137
137
  const response = await sendCommand(connection.socket, cmd);
138
+ // Extract subcommand (first positional arg) so the formatter can pick the
139
+ // right verb for batch-id responses (queue drain → "Drained", dlq retry
140
+ // → "Retried", etc.). Falls back to undefined when not applicable.
141
+ const subcommand = typeof args[0] === 'string' && !args[0].startsWith('-') ? args[0] : undefined;
138
142
  if (!response.ok) {
139
- console.error(formatOutput(response, command, options.json));
143
+ console.error(formatOutput(response, command, options.json, subcommand));
140
144
  process.exit(1);
141
145
  }
142
- console.log(formatOutput(response, command, options.json));
146
+ console.log(formatOutput(response, command, options.json, subcommand));
147
+ // Worker registrations are tied to the TCP connection — the server
148
+ // auto-unregisters when the client disconnects (see tcp.ts close handler).
149
+ // The one-shot CLI command opens, registers, and immediately closes, so
150
+ // by the time control returns to the shell the worker is already gone.
151
+ // Emit a warning to stderr so users don't expect persistence.
152
+ if (cmd.cmd === 'RegisterWorker' && !options.json && response.ok) {
153
+ process.stderr.write('Warning: worker registration is transient and expires when this CLI process exits. ' +
154
+ 'For persistent workers, run a long-lived process via the SDK (Worker class) or `bunqueue start` with --processor.\n');
155
+ }
143
156
  }
144
157
  catch (err) {
145
158
  const message = err instanceof Error ? err.message : 'Unknown error';
@@ -192,4 +205,3 @@ async function buildCommand(command, args) {
192
205
  return null;
193
206
  }
194
207
  }
195
- //# sourceMappingURL=client.js.map
@@ -17,4 +17,3 @@ export declare function executeBackupCommand(args: string[]): Promise<BackupComm
17
17
  * Check if a command is a backup command
18
18
  */
19
19
  export declare function isBackupCommand(cmd: string): boolean;
20
- //# sourceMappingURL=backup.d.ts.map
@@ -140,4 +140,3 @@ function executeBackupStatus(manager) {
140
140
  export function isBackupCommand(cmd) {
141
141
  return cmd === 'backup';
142
142
  }
143
- //# sourceMappingURL=backup.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a core command from CLI args */
6
6
  export declare function buildCoreCommand(command: string, args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=core.d.ts.map
@@ -157,4 +157,3 @@ function buildFail(args) {
157
157
  cmd.error = values.error;
158
158
  return cmd;
159
159
  }
160
- //# sourceMappingURL=core.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a cron subcommand */
6
6
  export declare function buildCronCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=cron.d.ts.map
@@ -72,4 +72,3 @@ function buildCronDelete(args) {
72
72
  const name = requireArg(args, 0, 'name');
73
73
  return { cmd: 'CronDelete', name };
74
74
  }
75
- //# sourceMappingURL=cron.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a DLQ subcommand */
6
6
  export declare function buildDlqCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=dlq.d.ts.map
@@ -63,4 +63,3 @@ function buildDlqPurge(args) {
63
63
  const queue = requireArg(args, 0, 'queue');
64
64
  return { cmd: 'PurgeDlq', queue };
65
65
  }
66
- //# sourceMappingURL=dlq.js.map
@@ -3,4 +3,3 @@
3
3
  * Checks client/server version, connectivity, health, and queue state
4
4
  */
5
5
  export declare function runDoctor(host: string, httpPort: number): Promise<void>;
6
- //# sourceMappingURL=doctor.d.ts.map
@@ -126,4 +126,3 @@ export async function runDoctor(host, httpPort) {
126
126
  }
127
127
  process.exit(issues > 0 ? 1 : 0);
128
128
  }
129
- //# sourceMappingURL=doctor.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a job subcommand */
6
6
  export declare function buildJobCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=job.d.ts.map
@@ -155,4 +155,3 @@ function buildWaitJob(args) {
155
155
  cmd.timeout = timeout;
156
156
  return cmd;
157
157
  }
158
- //# sourceMappingURL=job.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a monitoring command */
6
6
  export declare function buildMonitorCommand(command: string): Record<string, unknown>;
7
- //# sourceMappingURL=monitor.d.ts.map
@@ -18,4 +18,3 @@ export function buildMonitorCommand(command) {
18
18
  return { cmd: 'Stats' };
19
19
  }
20
20
  }
21
- //# sourceMappingURL=monitor.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a queue subcommand */
6
6
  export declare function buildQueueCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=queue.d.ts.map
@@ -131,4 +131,3 @@ function buildIsPaused(args) {
131
131
  const queue = requireArg(args, 0, 'queue');
132
132
  return { cmd: 'IsPaused', queue };
133
133
  }
134
- //# sourceMappingURL=queue.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a rate-limit or concurrency command */
6
6
  export declare function buildRateLimitCommand(command: string, args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=rateLimit.d.ts.map
@@ -64,4 +64,3 @@ function buildConcurrencyClear(args) {
64
64
  const queue = requireArg(args, 0, 'queue');
65
65
  return { cmd: 'ClearConcurrency', queue };
66
66
  }
67
- //# sourceMappingURL=rateLimit.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Run the server */
6
6
  export declare function runServer(args: string[], showHelp: boolean): Promise<void>;
7
- //# sourceMappingURL=server.d.ts.map
@@ -182,4 +182,3 @@ ${dim}────────────────────────
182
182
  process.on('SIGINT', shutdown);
183
183
  process.on('SIGTERM', shutdown);
184
184
  }
185
- //# sourceMappingURL=server.js.map
@@ -14,4 +14,3 @@ export declare function parseJsonArg(value: string, name: string): unknown;
14
14
  export declare function parseNumberArg(value: string | undefined, name: string): number | undefined;
15
15
  /** Parse job ID argument (UUIDs, numeric IDs, or custom IDs) */
16
16
  export declare function parseBigIntArg(value: string, name: string): string;
17
- //# sourceMappingURL=types.d.ts.map
@@ -43,4 +43,3 @@ export function parseBigIntArg(value, name) {
43
43
  }
44
44
  return value;
45
45
  }
46
- //# sourceMappingURL=types.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a webhook subcommand */
6
6
  export declare function buildWebhookCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=webhook.d.ts.map
@@ -83,4 +83,3 @@ function buildRemoveWebhook(args) {
83
83
  const webhookId = requireArg(args, 0, 'webhookId');
84
84
  return { cmd: 'RemoveWebhook', webhookId };
85
85
  }
86
- //# sourceMappingURL=webhook.js.map
@@ -4,4 +4,3 @@
4
4
  */
5
5
  /** Build a worker subcommand */
6
6
  export declare function buildWorkerCommand(args: string[]): Record<string, unknown>;
7
- //# sourceMappingURL=worker.d.ts.map
@@ -49,4 +49,3 @@ function buildUnregisterWorker(args) {
49
49
  const workerId = requireArg(args, 0, 'workerId');
50
50
  return { cmd: 'UnregisterWorker', workerId };
51
51
  }
52
- //# sourceMappingURL=worker.js.map
@@ -11,4 +11,3 @@ export declare function printServerHelp(): void;
11
11
  export declare function printPushHelp(): void;
12
12
  /** Print cron add help */
13
13
  export declare function printCronAddHelp(): void;
14
- //# sourceMappingURL=help.d.ts.map
package/dist/cli/help.js CHANGED
@@ -189,4 +189,3 @@ Examples:
189
189
  bunqueue cron add health-check -q monitoring -d '{}' -e 60000
190
190
  `);
191
191
  }
192
- //# sourceMappingURL=help.js.map
@@ -20,4 +20,3 @@ export declare function parseGlobalOptions(): {
20
20
  /** Main CLI entry */
21
21
  export declare function main(): Promise<void>;
22
22
  export {};
23
- //# sourceMappingURL=index.d.ts.map
package/dist/cli/index.js CHANGED
@@ -10,6 +10,31 @@ import { isBackupCommand, executeBackupCommand } from './commands/backup';
10
10
  import { runDoctor } from './commands/doctor';
11
11
  import { VERSION } from '../shared/version';
12
12
  import { resolveToken } from '../client/resolveToken';
13
+ /**
14
+ * Resolve TCP port from env when not set via --port flag.
15
+ * Priority: explicit CLI flag (caller-checked) > TCP_PORT (server's primary var)
16
+ * > BUNQUEUE_TCP_PORT > BQ_TCP_PORT. Reads TCP_PORT first so users
17
+ * running both server and client in the same shell with TCP_PORT=X get
18
+ * consistent behavior — same var binds the server AND routes the client.
19
+ */
20
+ function resolveEnvPort(currentPort) {
21
+ const envPort = Bun.env.TCP_PORT ?? Bun.env.BUNQUEUE_TCP_PORT ?? Bun.env.BQ_TCP_PORT;
22
+ if (!envPort)
23
+ return currentPort;
24
+ const parsed = parseInt(envPort, 10);
25
+ if (isNaN(parsed) || parsed < 1 || parsed > 65535) {
26
+ console.warn(`Warning: Invalid env port "${envPort}". Using ${currentPort}.`);
27
+ return currentPort;
28
+ }
29
+ return parsed;
30
+ }
31
+ /**
32
+ * Resolve host from env when not set via --host flag.
33
+ * Priority: HOST (server's primary var) > BUNQUEUE_HOST > BQ_HOST.
34
+ */
35
+ function resolveEnvHost(currentHost) {
36
+ return Bun.env.HOST ?? Bun.env.BUNQUEUE_HOST ?? Bun.env.BQ_HOST ?? currentHost;
37
+ }
13
38
  /** Parse global options from process.argv */
14
39
  export function parseGlobalOptions() {
15
40
  const allArgs = process.argv.slice(2);
@@ -54,10 +79,10 @@ export function parseGlobalOptions() {
54
79
  else if (arg === '--json') {
55
80
  json = true;
56
81
  }
57
- else if (arg === '--help') {
82
+ else if (arg === '--help' || arg === '-h') {
58
83
  help = true;
59
84
  }
60
- else if (arg === '--version') {
85
+ else if (arg === '--version' || arg === '-v') {
61
86
  version = true;
62
87
  }
63
88
  else if (arg.startsWith('--host=')) {
@@ -107,6 +132,10 @@ export function parseGlobalOptions() {
107
132
  // Fall back to environment variables for token if not set via CLI flag
108
133
  // Priority: --token flag > BQ_TOKEN > BUNQUEUE_TOKEN
109
134
  token = resolveToken(token);
135
+ if (!portExplicit)
136
+ port = resolveEnvPort(port);
137
+ if (!hostExplicit)
138
+ host = resolveEnvHost(host);
110
139
  return {
111
140
  options: { host, port, token, json, help, version },
112
141
  commandArgs,
@@ -222,4 +251,3 @@ if (import.meta.main) {
222
251
  process.exit(1);
223
252
  });
224
253
  }
225
- //# sourceMappingURL=index.js.map
@@ -3,7 +3,6 @@
3
3
  * Formats command responses for terminal display
4
4
  */
5
5
  /** Main output formatter */
6
- export declare function formatOutput(response: Record<string, unknown>, command: string, asJson: boolean): string;
6
+ export declare function formatOutput(response: Record<string, unknown>, command: string, asJson: boolean, subcommand?: string): string;
7
7
  /** Format error message */
8
8
  export declare function formatError(message: string, asJson: boolean): string;
9
- //# sourceMappingURL=output.d.ts.map