bullmq 4.0.0-beta.1 → 4.0.0

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 (841) hide show
  1. package/README.md +156 -22
  2. package/dist/cjs/classes/async-fifo-queue.js +90 -0
  3. package/dist/cjs/classes/async-fifo-queue.js.map +1 -0
  4. package/dist/{classes → cjs/classes}/backoffs.js +10 -9
  5. package/dist/cjs/classes/backoffs.js.map +1 -0
  6. package/dist/cjs/classes/child-pool.js +64 -0
  7. package/dist/cjs/classes/child-pool.js.map +1 -0
  8. package/dist/cjs/classes/child-processor.js +150 -0
  9. package/dist/cjs/classes/child-processor.js.map +1 -0
  10. package/dist/cjs/classes/child.js +216 -0
  11. package/dist/cjs/classes/child.js.map +1 -0
  12. package/dist/cjs/classes/delayed-error.js +19 -0
  13. package/dist/cjs/classes/delayed-error.js.map +1 -0
  14. package/dist/cjs/classes/flow-producer.js +283 -0
  15. package/dist/cjs/classes/flow-producer.js.map +1 -0
  16. package/dist/{classes → cjs/classes}/index.js +11 -3
  17. package/dist/cjs/classes/index.js.map +1 -0
  18. package/dist/cjs/classes/job.js +768 -0
  19. package/dist/cjs/classes/job.js.map +1 -0
  20. package/dist/cjs/classes/main-base.js +45 -0
  21. package/dist/cjs/classes/main-base.js.map +1 -0
  22. package/dist/cjs/classes/main-worker.js +10 -0
  23. package/dist/cjs/classes/main-worker.js.map +1 -0
  24. package/dist/cjs/classes/main.js +10 -0
  25. package/dist/cjs/classes/main.js.map +1 -0
  26. package/dist/cjs/classes/queue-base.js +135 -0
  27. package/dist/cjs/classes/queue-base.js.map +1 -0
  28. package/dist/cjs/classes/queue-events.js +120 -0
  29. package/dist/cjs/classes/queue-events.js.map +1 -0
  30. package/dist/cjs/classes/queue-getters.js +347 -0
  31. package/dist/cjs/classes/queue-getters.js.map +1 -0
  32. package/dist/cjs/classes/queue-keys.js +45 -0
  33. package/dist/cjs/classes/queue-keys.js.map +1 -0
  34. package/dist/cjs/classes/queue.js +275 -0
  35. package/dist/cjs/classes/queue.js.map +1 -0
  36. package/dist/cjs/classes/redis-connection.js +207 -0
  37. package/dist/cjs/classes/redis-connection.js.map +1 -0
  38. package/dist/cjs/classes/repeat.js +149 -0
  39. package/dist/cjs/classes/repeat.js.map +1 -0
  40. package/dist/{classes → cjs/classes}/sandbox.js +18 -14
  41. package/dist/cjs/classes/sandbox.js.map +1 -0
  42. package/dist/cjs/classes/scripts.js +658 -0
  43. package/dist/cjs/classes/scripts.js.map +1 -0
  44. package/dist/cjs/classes/unrecoverable-error.js +19 -0
  45. package/dist/cjs/classes/unrecoverable-error.js.map +1 -0
  46. package/dist/cjs/classes/waiting-children-error.js +19 -0
  47. package/dist/cjs/classes/waiting-children-error.js.map +1 -0
  48. package/dist/cjs/classes/worker.js +577 -0
  49. package/dist/cjs/classes/worker.js.map +1 -0
  50. package/dist/cjs/commands/addJob-9.lua +170 -0
  51. package/dist/cjs/commands/changeDelay-3.lua +40 -0
  52. package/dist/cjs/commands/changePriority-5.lua +52 -0
  53. package/dist/cjs/commands/cleanJobsInSet-2.lua +48 -0
  54. package/dist/cjs/commands/drain-4.lua +26 -0
  55. package/dist/{commands → cjs/commands}/extendLock-2.lua +1 -0
  56. package/dist/cjs/commands/getCounts-1.lua +35 -0
  57. package/dist/cjs/commands/getRanges-1.lua +69 -0
  58. package/dist/cjs/commands/getState-8.lua +66 -0
  59. package/dist/cjs/commands/getStateV2-8.lua +59 -0
  60. package/dist/cjs/commands/includes/addDelayMarkerIfNeeded.lua +15 -0
  61. package/dist/cjs/commands/includes/addJobWithPriority.lua +15 -0
  62. package/dist/cjs/commands/includes/addPriorityMarkerIfNeeded.lua +12 -0
  63. package/dist/cjs/commands/includes/batches.lua +18 -0
  64. package/dist/cjs/commands/includes/checkItemInList.lua +12 -0
  65. package/dist/cjs/commands/includes/checkStalledJobs.lua +139 -0
  66. package/dist/cjs/commands/includes/cleanList.lua +47 -0
  67. package/dist/cjs/commands/includes/cleanSet.lua +39 -0
  68. package/dist/cjs/commands/includes/collectMetrics.lua +46 -0
  69. package/dist/cjs/commands/includes/destructureJobKey.lua +12 -0
  70. package/dist/cjs/commands/includes/getJobsInZset.lua +12 -0
  71. package/dist/cjs/commands/includes/getNextDelayedTimestamp.lua +13 -0
  72. package/dist/cjs/commands/includes/getRateLimitTTL.lua +17 -0
  73. package/dist/cjs/commands/includes/getTargetQueueList.lua +12 -0
  74. package/dist/cjs/commands/includes/getTimestamp.lua +19 -0
  75. package/dist/cjs/commands/includes/getZSetItems.lua +7 -0
  76. package/dist/cjs/commands/includes/isLocked.lua +31 -0
  77. package/dist/cjs/commands/includes/moveJobFromPriorityToActive.lua +14 -0
  78. package/dist/cjs/commands/includes/moveParentFromWaitingChildrenToFailed.lua +28 -0
  79. package/dist/cjs/commands/includes/prepareJobForProcessing.lua +74 -0
  80. package/dist/cjs/commands/includes/promoteDelayedJobs.lua +39 -0
  81. package/dist/cjs/commands/includes/pushBackJobWithPriority.lua +9 -0
  82. package/dist/cjs/commands/includes/removeJob.lua +13 -0
  83. package/dist/cjs/commands/includes/removeJobFromAnyState.lua +35 -0
  84. package/dist/cjs/commands/includes/removeJobs.lua +25 -0
  85. package/dist/cjs/commands/includes/removeJobsByMaxAge.lua +15 -0
  86. package/dist/cjs/commands/includes/removeJobsByMaxCount.lua +15 -0
  87. package/dist/cjs/commands/includes/removeParentDependencyKey.lua +77 -0
  88. package/dist/cjs/commands/includes/removeZSetJobs.lua +15 -0
  89. package/dist/cjs/commands/includes/trimEvents.lua +12 -0
  90. package/dist/cjs/commands/includes/updateParentDepsIfNeeded.lua +40 -0
  91. package/dist/cjs/commands/index.js +10 -0
  92. package/dist/cjs/commands/index.js.map +1 -0
  93. package/dist/cjs/commands/isFinished-3.lua +48 -0
  94. package/dist/cjs/commands/isJobInList-1.lua +16 -0
  95. package/dist/cjs/commands/moveJobFromActiveToWait-9.lua +53 -0
  96. package/dist/cjs/commands/moveStalledJobsToWait-8.lua +24 -0
  97. package/dist/cjs/commands/moveToActive-10.lua +116 -0
  98. package/dist/cjs/commands/moveToDelayed-8.lua +66 -0
  99. package/dist/cjs/commands/moveToFinished-13.lua +250 -0
  100. package/dist/cjs/commands/moveToWaitingChildren-4.lua +62 -0
  101. package/dist/cjs/commands/obliterate-2.lua +102 -0
  102. package/dist/cjs/commands/pause-5.lua +36 -0
  103. package/dist/cjs/commands/promote-7.lua +57 -0
  104. package/dist/cjs/commands/releaseLock-1.lua +19 -0
  105. package/dist/cjs/commands/removeJob-1.lua +71 -0
  106. package/{src → dist/cjs}/commands/removeRepeatable-2.lua +13 -1
  107. package/dist/cjs/commands/reprocessJob-6.lua +43 -0
  108. package/dist/cjs/commands/retryJob-9.lua +69 -0
  109. package/dist/cjs/commands/retryJobs-6.lua +53 -0
  110. package/dist/cjs/commands/saveStacktrace-1.lua +22 -0
  111. package/dist/cjs/commands/script-loader.js +408 -0
  112. package/dist/cjs/commands/script-loader.js.map +1 -0
  113. package/dist/cjs/commands/updateData-1.lua +20 -0
  114. package/dist/cjs/commands/updateProgress-2.lua +26 -0
  115. package/dist/cjs/enums/error-code.enum.js +13 -0
  116. package/dist/cjs/enums/error-code.enum.js.map +1 -0
  117. package/dist/cjs/enums/index.js +6 -0
  118. package/dist/cjs/enums/index.js.map +1 -0
  119. package/dist/cjs/enums/metrics-time.js +15 -0
  120. package/dist/cjs/enums/metrics-time.js.map +1 -0
  121. package/dist/{index.js → cjs/index.js} +2 -0
  122. package/dist/cjs/index.js.map +1 -0
  123. package/dist/cjs/interfaces/advanced-options.js +3 -0
  124. package/dist/cjs/interfaces/advanced-options.js.map +1 -0
  125. package/dist/cjs/interfaces/backoff-options.js.map +1 -0
  126. package/dist/cjs/interfaces/base-job-options.js +3 -0
  127. package/dist/cjs/interfaces/base-job-options.js.map +1 -0
  128. package/dist/cjs/interfaces/child-command.js +10 -0
  129. package/dist/cjs/interfaces/child-command.js.map +1 -0
  130. package/dist/{interfaces/backoff-opts.js → cjs/interfaces/child-message.js} +1 -1
  131. package/dist/cjs/interfaces/child-message.js.map +1 -0
  132. package/dist/{interfaces/redis-opts.js → cjs/interfaces/connection.js} +1 -1
  133. package/dist/cjs/interfaces/connection.js.map +1 -0
  134. package/dist/{interfaces/jobs-opts.js → cjs/interfaces/flow-job.js} +1 -1
  135. package/dist/cjs/interfaces/flow-job.js.map +1 -0
  136. package/dist/cjs/interfaces/index.js +28 -0
  137. package/dist/cjs/interfaces/index.js.map +1 -0
  138. package/dist/cjs/interfaces/ioredis-events.js +3 -0
  139. package/dist/cjs/interfaces/ioredis-events.js.map +1 -0
  140. package/dist/{interfaces/repeat-opts.js → cjs/interfaces/job-json.js} +1 -1
  141. package/dist/cjs/interfaces/job-json.js.map +1 -0
  142. package/dist/{interfaces/worker-opts.js → cjs/interfaces/keep-jobs.js} +1 -1
  143. package/dist/cjs/interfaces/keep-jobs.js.map +1 -0
  144. package/dist/cjs/interfaces/metrics-options.js +3 -0
  145. package/dist/cjs/interfaces/metrics-options.js.map +1 -0
  146. package/dist/cjs/interfaces/metrics.js +3 -0
  147. package/dist/cjs/interfaces/metrics.js.map +1 -0
  148. package/dist/cjs/interfaces/minimal-job.js +3 -0
  149. package/dist/cjs/interfaces/minimal-job.js.map +1 -0
  150. package/dist/cjs/interfaces/parent-command.js +15 -0
  151. package/dist/cjs/interfaces/parent-command.js.map +1 -0
  152. package/dist/cjs/interfaces/parent-message.js +3 -0
  153. package/dist/cjs/interfaces/parent-message.js.map +1 -0
  154. package/dist/cjs/interfaces/parent.js +3 -0
  155. package/dist/cjs/interfaces/parent.js.map +1 -0
  156. package/dist/{interfaces → cjs/interfaces}/queue-options.js +1 -0
  157. package/dist/cjs/interfaces/queue-options.js.map +1 -0
  158. package/dist/cjs/interfaces/rate-limiter-options.js.map +1 -0
  159. package/dist/cjs/interfaces/redis-options.js.map +1 -0
  160. package/dist/{interfaces/jobs-options.js → cjs/interfaces/redis-streams.js} +1 -1
  161. package/dist/cjs/interfaces/redis-streams.js.map +1 -0
  162. package/dist/cjs/interfaces/repeat-options.js.map +1 -0
  163. package/dist/cjs/interfaces/sandboxed-job-processor.js +3 -0
  164. package/dist/cjs/interfaces/sandboxed-job-processor.js.map +1 -0
  165. package/dist/cjs/interfaces/sandboxed-job.js +3 -0
  166. package/dist/cjs/interfaces/sandboxed-job.js.map +1 -0
  167. package/dist/cjs/interfaces/worker-options.js.map +1 -0
  168. package/dist/cjs/scripts/addJob-9.js +252 -0
  169. package/dist/cjs/scripts/addJob-9.js.map +1 -0
  170. package/dist/cjs/scripts/changeDelay-3.js +41 -0
  171. package/dist/cjs/scripts/changeDelay-3.js.map +1 -0
  172. package/dist/cjs/scripts/changePriority-5.js +87 -0
  173. package/dist/cjs/scripts/changePriority-5.js.map +1 -0
  174. package/dist/cjs/scripts/cleanJobsInSet-2.js +259 -0
  175. package/dist/cjs/scripts/cleanJobsInSet-2.js.map +1 -0
  176. package/dist/cjs/scripts/drain-4.js +178 -0
  177. package/dist/cjs/scripts/drain-4.js.map +1 -0
  178. package/dist/cjs/scripts/extendLock-2.js +30 -0
  179. package/dist/cjs/scripts/extendLock-2.js.map +1 -0
  180. package/dist/cjs/scripts/getCounts-1.js +41 -0
  181. package/dist/cjs/scripts/getCounts-1.js.map +1 -0
  182. package/dist/cjs/scripts/getRanges-1.js +72 -0
  183. package/dist/cjs/scripts/getRanges-1.js.map +1 -0
  184. package/dist/cjs/scripts/getState-8.js +74 -0
  185. package/dist/cjs/scripts/getState-8.js.map +1 -0
  186. package/dist/cjs/scripts/getStateV2-8.js +58 -0
  187. package/dist/cjs/scripts/getStateV2-8.js.map +1 -0
  188. package/dist/cjs/scripts/index.js +34 -0
  189. package/dist/cjs/scripts/index.js.map +1 -0
  190. package/dist/cjs/scripts/isFinished-3.js +49 -0
  191. package/dist/cjs/scripts/isFinished-3.js.map +1 -0
  192. package/dist/cjs/scripts/isJobInList-1.js +32 -0
  193. package/dist/cjs/scripts/isJobInList-1.js.map +1 -0
  194. package/dist/cjs/scripts/moveJobFromActiveToWait-9.js +70 -0
  195. package/dist/cjs/scripts/moveJobFromActiveToWait-9.js.map +1 -0
  196. package/dist/cjs/scripts/moveStalledJobsToWait-8.js +289 -0
  197. package/dist/cjs/scripts/moveStalledJobsToWait-8.js.map +1 -0
  198. package/dist/cjs/scripts/moveToActive-10.js +269 -0
  199. package/dist/cjs/scripts/moveToActive-10.js.map +1 -0
  200. package/dist/cjs/scripts/moveToDelayed-8.js +152 -0
  201. package/dist/cjs/scripts/moveToDelayed-8.js.map +1 -0
  202. package/dist/cjs/scripts/moveToFinished-13.js +624 -0
  203. package/dist/cjs/scripts/moveToFinished-13.js.map +1 -0
  204. package/dist/cjs/scripts/moveToWaitingChildren-4.js +59 -0
  205. package/dist/cjs/scripts/moveToWaitingChildren-4.js.map +1 -0
  206. package/dist/cjs/scripts/obliterate-2.js +244 -0
  207. package/dist/cjs/scripts/obliterate-2.js.map +1 -0
  208. package/dist/cjs/scripts/pause-5.js +48 -0
  209. package/dist/cjs/scripts/pause-5.js.map +1 -0
  210. package/dist/cjs/scripts/promote-7.js +87 -0
  211. package/dist/cjs/scripts/promote-7.js.map +1 -0
  212. package/dist/cjs/scripts/releaseLock-1.js +25 -0
  213. package/dist/cjs/scripts/releaseLock-1.js.map +1 -0
  214. package/dist/cjs/scripts/removeJob-1.js +210 -0
  215. package/dist/cjs/scripts/removeJob-1.js.map +1 -0
  216. package/dist/cjs/scripts/removeRepeatable-2.js +38 -0
  217. package/dist/cjs/scripts/removeRepeatable-2.js.map +1 -0
  218. package/dist/cjs/scripts/reprocessJob-6.js +56 -0
  219. package/dist/cjs/scripts/reprocessJob-6.js.map +1 -0
  220. package/dist/cjs/scripts/retryJob-9.js +128 -0
  221. package/dist/cjs/scripts/retryJob-9.js.map +1 -0
  222. package/dist/cjs/scripts/retryJobs-6.js +76 -0
  223. package/dist/cjs/scripts/retryJobs-6.js.map +1 -0
  224. package/dist/cjs/scripts/saveStacktrace-1.js +27 -0
  225. package/dist/cjs/scripts/saveStacktrace-1.js.map +1 -0
  226. package/dist/cjs/scripts/updateData-1.js +26 -0
  227. package/dist/cjs/scripts/updateData-1.js.map +1 -0
  228. package/dist/cjs/scripts/updateProgress-2.js +31 -0
  229. package/dist/cjs/scripts/updateProgress-2.js.map +1 -0
  230. package/dist/cjs/tsconfig-cjs.tsbuildinfo +1 -0
  231. package/dist/cjs/types/backoff-strategy.js +3 -0
  232. package/dist/cjs/types/backoff-strategy.js.map +1 -0
  233. package/dist/cjs/types/finished-status.js +3 -0
  234. package/dist/cjs/types/finished-status.js.map +1 -0
  235. package/dist/cjs/types/index.js +11 -0
  236. package/dist/cjs/types/index.js.map +1 -0
  237. package/dist/cjs/types/job-json-sandbox.js +3 -0
  238. package/dist/cjs/types/job-json-sandbox.js.map +1 -0
  239. package/dist/cjs/types/job-options.js +3 -0
  240. package/dist/cjs/types/job-options.js.map +1 -0
  241. package/dist/cjs/types/job-type.js +3 -0
  242. package/dist/cjs/types/job-type.js.map +1 -0
  243. package/dist/cjs/types/minimal-queue.js +3 -0
  244. package/dist/cjs/types/minimal-queue.js.map +1 -0
  245. package/dist/cjs/types/repeat-strategy.js +3 -0
  246. package/dist/cjs/types/repeat-strategy.js.map +1 -0
  247. package/dist/cjs/utils.js +152 -0
  248. package/dist/cjs/utils.js.map +1 -0
  249. package/dist/esm/classes/async-fifo-queue.d.ts +31 -0
  250. package/dist/esm/classes/async-fifo-queue.js +86 -0
  251. package/dist/esm/classes/async-fifo-queue.js.map +1 -0
  252. package/dist/esm/classes/backoffs.d.ts +10 -0
  253. package/dist/esm/classes/backoffs.js +44 -0
  254. package/dist/esm/classes/backoffs.js.map +1 -0
  255. package/dist/esm/classes/child-pool.d.ts +23 -0
  256. package/dist/esm/classes/child-pool.js +60 -0
  257. package/dist/esm/classes/child-pool.js.map +1 -0
  258. package/dist/esm/classes/child-processor.d.ts +26 -0
  259. package/dist/esm/classes/child-processor.js +146 -0
  260. package/dist/esm/classes/child-processor.js.map +1 -0
  261. package/dist/esm/classes/child.d.ts +36 -0
  262. package/dist/esm/classes/child.js +212 -0
  263. package/dist/esm/classes/child.js.map +1 -0
  264. package/dist/esm/classes/delayed-error.d.ts +10 -0
  265. package/dist/esm/classes/delayed-error.js +15 -0
  266. package/dist/esm/classes/delayed-error.js.map +1 -0
  267. package/dist/esm/classes/flow-producer.d.ts +163 -0
  268. package/dist/esm/classes/flow-producer.js +279 -0
  269. package/dist/esm/classes/flow-producer.js.map +1 -0
  270. package/dist/{classes → esm/classes}/index.d.ts +9 -3
  271. package/dist/esm/classes/index.js +22 -0
  272. package/dist/esm/classes/index.js.map +1 -0
  273. package/dist/esm/classes/job.d.ts +355 -0
  274. package/dist/esm/classes/job.js +764 -0
  275. package/dist/esm/classes/job.js.map +1 -0
  276. package/dist/esm/classes/main-base.d.ts +4 -0
  277. package/dist/esm/classes/main-base.js +43 -0
  278. package/dist/esm/classes/main-base.js.map +1 -0
  279. package/dist/esm/classes/main-worker.js +8 -0
  280. package/dist/esm/classes/main-worker.js.map +1 -0
  281. package/dist/esm/classes/main.js +8 -0
  282. package/dist/esm/classes/main.js.map +1 -0
  283. package/dist/esm/classes/queue-base.d.ts +67 -0
  284. package/dist/esm/classes/queue-base.js +131 -0
  285. package/dist/esm/classes/queue-base.js.map +1 -0
  286. package/dist/esm/classes/queue-events.d.ts +179 -0
  287. package/dist/esm/classes/queue-events.js +116 -0
  288. package/dist/esm/classes/queue-events.js.map +1 -0
  289. package/dist/esm/classes/queue-getters.d.ts +164 -0
  290. package/dist/esm/classes/queue-getters.js +344 -0
  291. package/dist/esm/classes/queue-getters.js.map +1 -0
  292. package/dist/esm/classes/queue-keys.d.ts +10 -0
  293. package/dist/esm/classes/queue-keys.js +41 -0
  294. package/dist/esm/classes/queue-keys.js.map +1 -0
  295. package/dist/esm/classes/queue.d.ts +236 -0
  296. package/dist/esm/classes/queue.js +271 -0
  297. package/dist/esm/classes/queue.js.map +1 -0
  298. package/dist/esm/classes/redis-connection.d.ts +37 -0
  299. package/dist/esm/classes/redis-connection.js +203 -0
  300. package/dist/esm/classes/redis-connection.js.map +1 -0
  301. package/dist/esm/classes/repeat.d.ts +25 -0
  302. package/dist/esm/classes/repeat.js +144 -0
  303. package/dist/esm/classes/repeat.js.map +1 -0
  304. package/dist/esm/classes/sandbox.d.ts +4 -0
  305. package/dist/esm/classes/sandbox.js +58 -0
  306. package/dist/esm/classes/sandbox.js.map +1 -0
  307. package/dist/esm/classes/scripts.d.ts +106 -0
  308. package/dist/esm/classes/scripts.js +654 -0
  309. package/dist/esm/classes/scripts.js.map +1 -0
  310. package/dist/esm/classes/unrecoverable-error.d.ts +10 -0
  311. package/dist/esm/classes/unrecoverable-error.js +15 -0
  312. package/dist/esm/classes/unrecoverable-error.js.map +1 -0
  313. package/dist/esm/classes/waiting-children-error.d.ts +10 -0
  314. package/dist/esm/classes/waiting-children-error.js +15 -0
  315. package/dist/esm/classes/waiting-children-error.js.map +1 -0
  316. package/dist/esm/classes/worker.d.ts +215 -0
  317. package/dist/esm/classes/worker.js +573 -0
  318. package/dist/esm/classes/worker.js.map +1 -0
  319. package/dist/esm/commands/addJob-9.lua +170 -0
  320. package/dist/esm/commands/changeDelay-3.lua +40 -0
  321. package/dist/esm/commands/changePriority-5.lua +52 -0
  322. package/dist/esm/commands/cleanJobsInSet-2.lua +48 -0
  323. package/dist/esm/commands/drain-4.lua +26 -0
  324. package/{src → dist/esm}/commands/extendLock-2.lua +1 -0
  325. package/dist/esm/commands/getCounts-1.lua +35 -0
  326. package/dist/esm/commands/getRanges-1.lua +69 -0
  327. package/dist/esm/commands/getState-8.lua +66 -0
  328. package/dist/esm/commands/getStateV2-8.lua +59 -0
  329. package/dist/esm/commands/includes/addDelayMarkerIfNeeded.lua +15 -0
  330. package/dist/esm/commands/includes/addJobWithPriority.lua +15 -0
  331. package/dist/esm/commands/includes/addPriorityMarkerIfNeeded.lua +12 -0
  332. package/dist/esm/commands/includes/batches.lua +18 -0
  333. package/dist/esm/commands/includes/checkItemInList.lua +12 -0
  334. package/dist/esm/commands/includes/checkStalledJobs.lua +139 -0
  335. package/dist/esm/commands/includes/cleanList.lua +47 -0
  336. package/dist/esm/commands/includes/cleanSet.lua +39 -0
  337. package/dist/esm/commands/includes/collectMetrics.lua +46 -0
  338. package/dist/esm/commands/includes/destructureJobKey.lua +12 -0
  339. package/dist/esm/commands/includes/getJobsInZset.lua +12 -0
  340. package/dist/esm/commands/includes/getNextDelayedTimestamp.lua +13 -0
  341. package/dist/esm/commands/includes/getRateLimitTTL.lua +17 -0
  342. package/dist/esm/commands/includes/getTargetQueueList.lua +12 -0
  343. package/dist/esm/commands/includes/getTimestamp.lua +19 -0
  344. package/dist/esm/commands/includes/getZSetItems.lua +7 -0
  345. package/dist/esm/commands/includes/isLocked.lua +31 -0
  346. package/dist/esm/commands/includes/moveJobFromPriorityToActive.lua +14 -0
  347. package/dist/esm/commands/includes/moveParentFromWaitingChildrenToFailed.lua +28 -0
  348. package/dist/esm/commands/includes/prepareJobForProcessing.lua +74 -0
  349. package/dist/esm/commands/includes/promoteDelayedJobs.lua +39 -0
  350. package/dist/esm/commands/includes/pushBackJobWithPriority.lua +9 -0
  351. package/dist/esm/commands/includes/removeJob.lua +13 -0
  352. package/dist/esm/commands/includes/removeJobFromAnyState.lua +35 -0
  353. package/dist/esm/commands/includes/removeJobs.lua +25 -0
  354. package/dist/esm/commands/includes/removeJobsByMaxAge.lua +15 -0
  355. package/dist/esm/commands/includes/removeJobsByMaxCount.lua +15 -0
  356. package/dist/esm/commands/includes/removeParentDependencyKey.lua +77 -0
  357. package/dist/esm/commands/includes/removeZSetJobs.lua +15 -0
  358. package/dist/esm/commands/includes/trimEvents.lua +12 -0
  359. package/dist/esm/commands/includes/updateParentDepsIfNeeded.lua +40 -0
  360. package/dist/esm/commands/index.d.ts +4 -0
  361. package/dist/esm/commands/index.js +5 -0
  362. package/dist/esm/commands/index.js.map +1 -0
  363. package/dist/esm/commands/isFinished-3.lua +48 -0
  364. package/dist/esm/commands/isJobInList-1.lua +16 -0
  365. package/dist/esm/commands/moveJobFromActiveToWait-9.lua +53 -0
  366. package/dist/esm/commands/moveStalledJobsToWait-8.lua +24 -0
  367. package/dist/esm/commands/moveToActive-10.lua +116 -0
  368. package/dist/esm/commands/moveToDelayed-8.lua +66 -0
  369. package/dist/esm/commands/moveToFinished-13.lua +250 -0
  370. package/dist/esm/commands/moveToWaitingChildren-4.lua +62 -0
  371. package/dist/esm/commands/obliterate-2.lua +102 -0
  372. package/dist/esm/commands/pause-5.lua +36 -0
  373. package/dist/esm/commands/promote-7.lua +57 -0
  374. package/dist/esm/commands/releaseLock-1.lua +19 -0
  375. package/dist/esm/commands/removeJob-1.lua +71 -0
  376. package/dist/{commands → esm/commands}/removeRepeatable-2.lua +13 -1
  377. package/dist/esm/commands/reprocessJob-6.lua +43 -0
  378. package/dist/esm/commands/retryJob-9.lua +69 -0
  379. package/dist/esm/commands/retryJobs-6.lua +53 -0
  380. package/dist/esm/commands/saveStacktrace-1.lua +22 -0
  381. package/dist/esm/commands/script-loader.d.ts +119 -0
  382. package/dist/esm/commands/script-loader.js +403 -0
  383. package/dist/esm/commands/script-loader.js.map +1 -0
  384. package/dist/esm/commands/updateData-1.lua +20 -0
  385. package/dist/esm/commands/updateProgress-2.lua +26 -0
  386. package/dist/esm/enums/error-code.enum.d.ts +8 -0
  387. package/dist/esm/enums/error-code.enum.js +10 -0
  388. package/dist/esm/enums/error-code.enum.js.map +1 -0
  389. package/dist/esm/enums/index.d.ts +2 -0
  390. package/dist/esm/enums/index.js +3 -0
  391. package/dist/esm/enums/index.js.map +1 -0
  392. package/dist/esm/enums/metrics-time.d.ts +10 -0
  393. package/dist/esm/enums/metrics-time.js +12 -0
  394. package/dist/esm/enums/metrics-time.js.map +1 -0
  395. package/dist/{index.d.ts → esm/index.d.ts} +2 -0
  396. package/{src/index.ts → dist/esm/index.js} +7 -4
  397. package/dist/esm/index.js.map +1 -0
  398. package/dist/esm/interfaces/advanced-options.d.ts +13 -0
  399. package/dist/esm/interfaces/advanced-options.js +2 -0
  400. package/dist/esm/interfaces/advanced-options.js.map +1 -0
  401. package/dist/esm/interfaces/backoff-options.d.ts +15 -0
  402. package/dist/esm/interfaces/backoff-options.js +2 -0
  403. package/dist/esm/interfaces/backoff-options.js.map +1 -0
  404. package/dist/esm/interfaces/base-job-options.d.ts +97 -0
  405. package/dist/esm/interfaces/base-job-options.js +2 -0
  406. package/dist/esm/interfaces/base-job-options.js.map +1 -0
  407. package/dist/esm/interfaces/child-command.d.ts +5 -0
  408. package/dist/esm/interfaces/child-command.js +7 -0
  409. package/dist/esm/interfaces/child-command.js.map +1 -0
  410. package/dist/esm/interfaces/child-message.d.ts +6 -0
  411. package/dist/esm/interfaces/child-message.js +2 -0
  412. package/dist/esm/interfaces/child-message.js.map +1 -0
  413. package/dist/esm/interfaces/connection.d.ts +8 -0
  414. package/dist/esm/interfaces/connection.js +2 -0
  415. package/dist/esm/interfaces/connection.js.map +1 -0
  416. package/dist/esm/interfaces/flow-job.d.ts +19 -0
  417. package/dist/esm/interfaces/flow-job.js +2 -0
  418. package/dist/esm/interfaces/flow-job.js.map +1 -0
  419. package/dist/esm/interfaces/index.d.ts +24 -0
  420. package/dist/esm/interfaces/index.js +25 -0
  421. package/dist/esm/interfaces/index.js.map +1 -0
  422. package/dist/esm/interfaces/ioredis-events.d.ts +8 -0
  423. package/dist/esm/interfaces/ioredis-events.js +2 -0
  424. package/dist/esm/interfaces/ioredis-events.js.map +1 -0
  425. package/dist/esm/interfaces/job-json.d.ts +37 -0
  426. package/dist/esm/interfaces/job-json.js +2 -0
  427. package/dist/esm/interfaces/job-json.js.map +1 -0
  428. package/dist/esm/interfaces/keep-jobs.d.ts +17 -0
  429. package/dist/esm/interfaces/keep-jobs.js +2 -0
  430. package/dist/esm/interfaces/keep-jobs.js.map +1 -0
  431. package/dist/esm/interfaces/metrics-options.d.ts +12 -0
  432. package/dist/esm/interfaces/metrics-options.js +2 -0
  433. package/dist/esm/interfaces/metrics-options.js.map +1 -0
  434. package/dist/esm/interfaces/metrics.d.ts +9 -0
  435. package/dist/esm/interfaces/metrics.js +2 -0
  436. package/dist/esm/interfaces/metrics.js.map +1 -0
  437. package/dist/esm/interfaces/minimal-job.d.ts +129 -0
  438. package/dist/esm/interfaces/minimal-job.js +2 -0
  439. package/dist/esm/interfaces/minimal-job.js.map +1 -0
  440. package/dist/esm/interfaces/parent-command.d.ts +10 -0
  441. package/dist/esm/interfaces/parent-command.js +12 -0
  442. package/dist/esm/interfaces/parent-command.js.map +1 -0
  443. package/dist/esm/interfaces/parent-message.d.ts +8 -0
  444. package/dist/esm/interfaces/parent-message.js +2 -0
  445. package/dist/esm/interfaces/parent-message.js.map +1 -0
  446. package/dist/esm/interfaces/parent.d.ts +20 -0
  447. package/dist/esm/interfaces/parent.js +2 -0
  448. package/dist/esm/interfaces/parent.js.map +1 -0
  449. package/dist/esm/interfaces/queue-options.d.ts +74 -0
  450. package/dist/esm/interfaces/queue-options.js +6 -0
  451. package/dist/esm/interfaces/queue-options.js.map +1 -0
  452. package/dist/esm/interfaces/rate-limiter-options.d.ts +12 -0
  453. package/dist/esm/interfaces/rate-limiter-options.js +2 -0
  454. package/dist/esm/interfaces/rate-limiter-options.js.map +1 -0
  455. package/dist/esm/interfaces/redis-options.d.ts +7 -0
  456. package/dist/esm/interfaces/redis-options.js +2 -0
  457. package/dist/esm/interfaces/redis-options.js.map +1 -0
  458. package/dist/esm/interfaces/redis-streams.d.ts +4 -0
  459. package/dist/esm/interfaces/redis-streams.js +2 -0
  460. package/dist/esm/interfaces/redis-streams.js.map +1 -0
  461. package/dist/esm/interfaces/repeat-options.d.ts +33 -0
  462. package/dist/esm/interfaces/repeat-options.js +2 -0
  463. package/dist/esm/interfaces/repeat-options.js.map +1 -0
  464. package/dist/esm/interfaces/sandboxed-job-processor.d.ts +5 -0
  465. package/dist/esm/interfaces/sandboxed-job-processor.js +2 -0
  466. package/dist/esm/interfaces/sandboxed-job-processor.js.map +1 -0
  467. package/dist/esm/interfaces/sandboxed-job.d.ts +13 -0
  468. package/dist/esm/interfaces/sandboxed-job.js +2 -0
  469. package/dist/esm/interfaces/sandboxed-job.js.map +1 -0
  470. package/dist/esm/interfaces/worker-options.d.ts +123 -0
  471. package/dist/esm/interfaces/worker-options.js +2 -0
  472. package/dist/esm/interfaces/worker-options.js.map +1 -0
  473. package/dist/esm/scripts/addJob-9.d.ts +5 -0
  474. package/dist/esm/scripts/addJob-9.js +249 -0
  475. package/dist/esm/scripts/addJob-9.js.map +1 -0
  476. package/dist/esm/scripts/changeDelay-3.d.ts +5 -0
  477. package/dist/esm/scripts/changeDelay-3.js +38 -0
  478. package/dist/esm/scripts/changeDelay-3.js.map +1 -0
  479. package/dist/esm/scripts/changePriority-5.d.ts +5 -0
  480. package/dist/esm/scripts/changePriority-5.js +84 -0
  481. package/dist/esm/scripts/changePriority-5.js.map +1 -0
  482. package/dist/esm/scripts/cleanJobsInSet-2.d.ts +5 -0
  483. package/dist/esm/scripts/cleanJobsInSet-2.js +256 -0
  484. package/dist/esm/scripts/cleanJobsInSet-2.js.map +1 -0
  485. package/dist/esm/scripts/drain-4.d.ts +5 -0
  486. package/dist/esm/scripts/drain-4.js +175 -0
  487. package/dist/esm/scripts/drain-4.js.map +1 -0
  488. package/dist/esm/scripts/extendLock-2.d.ts +5 -0
  489. package/dist/esm/scripts/extendLock-2.js +27 -0
  490. package/dist/esm/scripts/extendLock-2.js.map +1 -0
  491. package/dist/esm/scripts/getCounts-1.d.ts +5 -0
  492. package/dist/esm/scripts/getCounts-1.js +38 -0
  493. package/dist/esm/scripts/getCounts-1.js.map +1 -0
  494. package/dist/esm/scripts/getRanges-1.d.ts +5 -0
  495. package/dist/esm/scripts/getRanges-1.js +69 -0
  496. package/dist/esm/scripts/getRanges-1.js.map +1 -0
  497. package/dist/esm/scripts/getState-8.d.ts +5 -0
  498. package/dist/esm/scripts/getState-8.js +71 -0
  499. package/dist/esm/scripts/getState-8.js.map +1 -0
  500. package/dist/esm/scripts/getStateV2-8.d.ts +5 -0
  501. package/dist/esm/scripts/getStateV2-8.js +55 -0
  502. package/dist/esm/scripts/getStateV2-8.js.map +1 -0
  503. package/dist/esm/scripts/index.d.ts +30 -0
  504. package/dist/esm/scripts/index.js +31 -0
  505. package/dist/esm/scripts/index.js.map +1 -0
  506. package/dist/esm/scripts/isFinished-3.d.ts +5 -0
  507. package/dist/esm/scripts/isFinished-3.js +46 -0
  508. package/dist/esm/scripts/isFinished-3.js.map +1 -0
  509. package/dist/esm/scripts/isJobInList-1.d.ts +5 -0
  510. package/dist/esm/scripts/isJobInList-1.js +29 -0
  511. package/dist/esm/scripts/isJobInList-1.js.map +1 -0
  512. package/dist/esm/scripts/moveJobFromActiveToWait-9.d.ts +5 -0
  513. package/dist/esm/scripts/moveJobFromActiveToWait-9.js +67 -0
  514. package/dist/esm/scripts/moveJobFromActiveToWait-9.js.map +1 -0
  515. package/dist/esm/scripts/moveStalledJobsToWait-8.d.ts +5 -0
  516. package/dist/esm/scripts/moveStalledJobsToWait-8.js +286 -0
  517. package/dist/esm/scripts/moveStalledJobsToWait-8.js.map +1 -0
  518. package/dist/esm/scripts/moveToActive-10.d.ts +5 -0
  519. package/dist/esm/scripts/moveToActive-10.js +266 -0
  520. package/dist/esm/scripts/moveToActive-10.js.map +1 -0
  521. package/dist/esm/scripts/moveToDelayed-8.d.ts +5 -0
  522. package/dist/esm/scripts/moveToDelayed-8.js +149 -0
  523. package/dist/esm/scripts/moveToDelayed-8.js.map +1 -0
  524. package/dist/esm/scripts/moveToFinished-13.d.ts +5 -0
  525. package/dist/esm/scripts/moveToFinished-13.js +621 -0
  526. package/dist/esm/scripts/moveToFinished-13.js.map +1 -0
  527. package/dist/esm/scripts/moveToWaitingChildren-4.d.ts +5 -0
  528. package/dist/esm/scripts/moveToWaitingChildren-4.js +56 -0
  529. package/dist/esm/scripts/moveToWaitingChildren-4.js.map +1 -0
  530. package/dist/esm/scripts/obliterate-2.d.ts +5 -0
  531. package/dist/esm/scripts/obliterate-2.js +241 -0
  532. package/dist/esm/scripts/obliterate-2.js.map +1 -0
  533. package/dist/esm/scripts/pause-5.d.ts +5 -0
  534. package/dist/esm/scripts/pause-5.js +45 -0
  535. package/dist/esm/scripts/pause-5.js.map +1 -0
  536. package/dist/esm/scripts/promote-7.d.ts +5 -0
  537. package/dist/esm/scripts/promote-7.js +84 -0
  538. package/dist/esm/scripts/promote-7.js.map +1 -0
  539. package/dist/esm/scripts/releaseLock-1.d.ts +5 -0
  540. package/dist/esm/scripts/releaseLock-1.js +22 -0
  541. package/dist/esm/scripts/releaseLock-1.js.map +1 -0
  542. package/dist/esm/scripts/removeJob-1.d.ts +5 -0
  543. package/dist/esm/scripts/removeJob-1.js +207 -0
  544. package/dist/esm/scripts/removeJob-1.js.map +1 -0
  545. package/dist/esm/scripts/removeRepeatable-2.d.ts +5 -0
  546. package/dist/esm/scripts/removeRepeatable-2.js +35 -0
  547. package/dist/esm/scripts/removeRepeatable-2.js.map +1 -0
  548. package/dist/esm/scripts/reprocessJob-6.d.ts +5 -0
  549. package/dist/esm/scripts/reprocessJob-6.js +53 -0
  550. package/dist/esm/scripts/reprocessJob-6.js.map +1 -0
  551. package/dist/esm/scripts/retryJob-9.d.ts +5 -0
  552. package/dist/esm/scripts/retryJob-9.js +125 -0
  553. package/dist/esm/scripts/retryJob-9.js.map +1 -0
  554. package/dist/esm/scripts/retryJobs-6.d.ts +5 -0
  555. package/dist/esm/scripts/retryJobs-6.js +73 -0
  556. package/dist/esm/scripts/retryJobs-6.js.map +1 -0
  557. package/dist/esm/scripts/saveStacktrace-1.d.ts +5 -0
  558. package/dist/esm/scripts/saveStacktrace-1.js +24 -0
  559. package/dist/esm/scripts/saveStacktrace-1.js.map +1 -0
  560. package/dist/esm/scripts/updateData-1.d.ts +5 -0
  561. package/dist/esm/scripts/updateData-1.js +23 -0
  562. package/dist/esm/scripts/updateData-1.js.map +1 -0
  563. package/dist/esm/scripts/updateProgress-2.d.ts +5 -0
  564. package/dist/esm/scripts/updateProgress-2.js +28 -0
  565. package/dist/esm/scripts/updateProgress-2.js.map +1 -0
  566. package/dist/esm/tsconfig.tsbuildinfo +1 -0
  567. package/dist/esm/types/backoff-strategy.d.ts +2 -0
  568. package/dist/esm/types/backoff-strategy.js +2 -0
  569. package/dist/esm/types/backoff-strategy.js.map +1 -0
  570. package/dist/esm/types/finished-status.d.ts +2 -0
  571. package/dist/esm/types/finished-status.js +2 -0
  572. package/dist/esm/types/finished-status.js.map +1 -0
  573. package/dist/esm/types/index.d.ts +7 -0
  574. package/dist/esm/types/index.js +8 -0
  575. package/dist/esm/types/index.js.map +1 -0
  576. package/dist/esm/types/job-json-sandbox.d.ts +5 -0
  577. package/dist/esm/types/job-json-sandbox.js +2 -0
  578. package/dist/esm/types/job-json-sandbox.js.map +1 -0
  579. package/dist/esm/types/job-options.d.ts +20 -0
  580. package/dist/esm/types/job-options.js +2 -0
  581. package/dist/esm/types/job-options.js.map +1 -0
  582. package/dist/esm/types/job-type.d.ts +3 -0
  583. package/dist/esm/types/job-type.js +2 -0
  584. package/dist/esm/types/job-type.js.map +1 -0
  585. package/dist/esm/types/minimal-queue.d.ts +2 -0
  586. package/dist/esm/types/minimal-queue.js +2 -0
  587. package/dist/esm/types/minimal-queue.js.map +1 -0
  588. package/dist/esm/types/repeat-strategy.d.ts +2 -0
  589. package/dist/esm/types/repeat-strategy.js +2 -0
  590. package/dist/esm/types/repeat-strategy.js.map +1 -0
  591. package/dist/esm/utils.d.ts +42 -0
  592. package/dist/esm/utils.js +134 -0
  593. package/dist/esm/utils.js.map +1 -0
  594. package/package.json +181 -60
  595. package/.travis.yml +0 -32
  596. package/SUMMARY.md +0 -4
  597. package/commitlint.config.js +0 -1
  598. package/dist/classes/backoffs.d.ts +0 -14
  599. package/dist/classes/backoffs.js.map +0 -1
  600. package/dist/classes/child-pool.d.ts +0 -22
  601. package/dist/classes/child-pool.js +0 -98
  602. package/dist/classes/child-pool.js.map +0 -1
  603. package/dist/classes/compat.d.ts +0 -316
  604. package/dist/classes/compat.js +0 -667
  605. package/dist/classes/compat.js.map +0 -1
  606. package/dist/classes/index.js.map +0 -1
  607. package/dist/classes/job.d.ts +0 -93
  608. package/dist/classes/job.js +0 -351
  609. package/dist/classes/job.js.map +0 -1
  610. package/dist/classes/master.js +0 -112
  611. package/dist/classes/master.js.map +0 -1
  612. package/dist/classes/queue-base.d.ts +0 -23
  613. package/dist/classes/queue-base.js +0 -68
  614. package/dist/classes/queue-base.js.map +0 -1
  615. package/dist/classes/queue-events.d.ts +0 -8
  616. package/dist/classes/queue-events.js +0 -59
  617. package/dist/classes/queue-events.js.map +0 -1
  618. package/dist/classes/queue-getters.d.ts +0 -38
  619. package/dist/classes/queue-getters.js +0 -182
  620. package/dist/classes/queue-getters.js.map +0 -1
  621. package/dist/classes/queue-keeper.js +0 -103
  622. package/dist/classes/queue-keeper.js.map +0 -1
  623. package/dist/classes/queue-scheduler.d.ts +0 -25
  624. package/dist/classes/queue-scheduler.js +0 -96
  625. package/dist/classes/queue-scheduler.js.map +0 -1
  626. package/dist/classes/queue.d.ts +0 -46
  627. package/dist/classes/queue.js +0 -122
  628. package/dist/classes/queue.js.map +0 -1
  629. package/dist/classes/redis-connection.d.ts +0 -17
  630. package/dist/classes/redis-connection.js +0 -97
  631. package/dist/classes/redis-connection.js.map +0 -1
  632. package/dist/classes/repeat.d.ts +0 -26
  633. package/dist/classes/repeat.js +0 -128
  634. package/dist/classes/repeat.js.map +0 -1
  635. package/dist/classes/sandbox.d.ts +0 -2
  636. package/dist/classes/sandbox.js.map +0 -1
  637. package/dist/classes/scripts.d.ts +0 -43
  638. package/dist/classes/scripts.js +0 -296
  639. package/dist/classes/scripts.js.map +0 -1
  640. package/dist/classes/worker.d.ts +0 -38
  641. package/dist/classes/worker.js +0 -231
  642. package/dist/classes/worker.js.map +0 -1
  643. package/dist/commands/addJob-8.lua +0 -106
  644. package/dist/commands/cleanJobsInSet-1.lua +0 -48
  645. package/dist/commands/index.d.ts +0 -2
  646. package/dist/commands/index.js +0 -42
  647. package/dist/commands/index.js.map +0 -1
  648. package/dist/commands/isFinished-2.lua +0 -22
  649. package/dist/commands/isJobInList-1.lua +0 -20
  650. package/dist/commands/moveStalledJobsToWait-8.lua +0 -91
  651. package/dist/commands/moveToActive-8.lua +0 -79
  652. package/dist/commands/moveToDelayed-5.lua +0 -39
  653. package/dist/commands/moveToFinished-6.lua +0 -87
  654. package/dist/commands/moveToFinished-7.lua +0 -92
  655. package/dist/commands/pause-4.lua +0 -27
  656. package/dist/commands/promote-4.lua +0 -49
  657. package/dist/commands/releaseLock-1.lua +0 -19
  658. package/dist/commands/removeJob-10.lua +0 -37
  659. package/dist/commands/reprocessJob-4.lua +0 -36
  660. package/dist/commands/retryJob-4.lua +0 -34
  661. package/dist/commands/takeLock-1.lua +0 -17
  662. package/dist/commands/updateDelaySet-7.lua +0 -71
  663. package/dist/commands/updateProgress-2.lua +0 -15
  664. package/dist/enums/index.d.ts +0 -1
  665. package/dist/enums/index.js +0 -5
  666. package/dist/enums/index.js.map +0 -1
  667. package/dist/enums/retry-errors.enum.d.ts +0 -5
  668. package/dist/enums/retry-errors.enum.js +0 -9
  669. package/dist/enums/retry-errors.enum.js.map +0 -1
  670. package/dist/index.js.map +0 -1
  671. package/dist/interfaces/advance-opts.js +0 -12
  672. package/dist/interfaces/advance-opts.js.map +0 -1
  673. package/dist/interfaces/advanced-options.d.ts +0 -9
  674. package/dist/interfaces/advanced-options.js +0 -11
  675. package/dist/interfaces/advanced-options.js.map +0 -1
  676. package/dist/interfaces/advanced-opts.js +0 -11
  677. package/dist/interfaces/advanced-opts.js.map +0 -1
  678. package/dist/interfaces/backoff-options.d.ts +0 -4
  679. package/dist/interfaces/backoff-options.js.map +0 -1
  680. package/dist/interfaces/backoff-opts.js.map +0 -1
  681. package/dist/interfaces/index.d.ts +0 -9
  682. package/dist/interfaces/index.js +0 -6
  683. package/dist/interfaces/index.js.map +0 -1
  684. package/dist/interfaces/jobs-options.d.ts +0 -16
  685. package/dist/interfaces/jobs-options.js.map +0 -1
  686. package/dist/interfaces/jobs-opts.js.map +0 -1
  687. package/dist/interfaces/queue-keeper-opts.js +0 -3
  688. package/dist/interfaces/queue-keeper-opts.js.map +0 -1
  689. package/dist/interfaces/queue-options.d.ts +0 -24
  690. package/dist/interfaces/queue-options.js.map +0 -1
  691. package/dist/interfaces/queue-opts.js +0 -8
  692. package/dist/interfaces/queue-opts.js.map +0 -1
  693. package/dist/interfaces/queue-scheduler-options.d.ts +0 -5
  694. package/dist/interfaces/queue-scheduler-options.js +0 -3
  695. package/dist/interfaces/queue-scheduler-options.js.map +0 -1
  696. package/dist/interfaces/queue-scheduler-opts.js +0 -3
  697. package/dist/interfaces/queue-scheduler-opts.js.map +0 -1
  698. package/dist/interfaces/rate-limiter-options.d.ts +0 -4
  699. package/dist/interfaces/rate-limiter-options.js.map +0 -1
  700. package/dist/interfaces/rate-limiter-opts.js +0 -3
  701. package/dist/interfaces/rate-limiter-opts.js.map +0 -1
  702. package/dist/interfaces/redis-options.d.ts +0 -7
  703. package/dist/interfaces/redis-options.js.map +0 -1
  704. package/dist/interfaces/redis-opts.js.map +0 -1
  705. package/dist/interfaces/repeat-options.d.ts +0 -11
  706. package/dist/interfaces/repeat-options.js.map +0 -1
  707. package/dist/interfaces/repeat-opts.js.map +0 -1
  708. package/dist/interfaces/worker-options.d.ts +0 -11
  709. package/dist/interfaces/worker-options.js.map +0 -1
  710. package/dist/interfaces/worker-opts.js.map +0 -1
  711. package/dist/test/test_bulk.js +0 -55
  712. package/dist/test/test_bulk.js.map +0 -1
  713. package/dist/test/test_child-pool.js +0 -81
  714. package/dist/test/test_child-pool.js.map +0 -1
  715. package/dist/test/test_clean.js +0 -124
  716. package/dist/test/test_clean.js.map +0 -1
  717. package/dist/test/test_compat.d.ts +0 -1
  718. package/dist/test/test_compat.js +0 -533
  719. package/dist/test/test_compat.js.map +0 -1
  720. package/dist/test/test_connection.d.ts +0 -1
  721. package/dist/test/test_connection.js +0 -140
  722. package/dist/test/test_connection.js.map +0 -1
  723. package/dist/test/test_delay.d.ts +0 -1
  724. package/dist/test/test_delay.js +0 -186
  725. package/dist/test/test_delay.js.map +0 -1
  726. package/dist/test/test_events.d.ts +0 -1
  727. package/dist/test/test_events.js +0 -147
  728. package/dist/test/test_events.js.map +0 -1
  729. package/dist/test/test_getters.d.ts +0 -1
  730. package/dist/test/test_getters.js +0 -293
  731. package/dist/test/test_getters.js.map +0 -1
  732. package/dist/test/test_job.d.ts +0 -1
  733. package/dist/test/test_job.js +0 -419
  734. package/dist/test/test_job.js.map +0 -1
  735. package/dist/test/test_pause.d.ts +0 -1
  736. package/dist/test/test_pause.js +0 -255
  737. package/dist/test/test_pause.js.map +0 -1
  738. package/dist/test/test_queue.d.ts +0 -0
  739. package/dist/test/test_queue.js +0 -72
  740. package/dist/test/test_queue.js.map +0 -1
  741. package/dist/test/test_rate_limiter.d.ts +0 -1
  742. package/dist/test/test_rate_limiter.js +0 -98
  743. package/dist/test/test_rate_limiter.js.map +0 -1
  744. package/dist/test/test_repeat.d.ts +0 -1
  745. package/dist/test/test_repeat.js +0 -602
  746. package/dist/test/test_repeat.js.map +0 -1
  747. package/dist/test/test_sandboxed_process.d.ts +0 -1
  748. package/dist/test/test_sandboxed_process.js +0 -319
  749. package/dist/test/test_sandboxed_process.js.map +0 -1
  750. package/dist/test/test_stalled_jobs.d.ts +0 -1
  751. package/dist/test/test_stalled_jobs.js +0 -107
  752. package/dist/test/test_stalled_jobs.js.map +0 -1
  753. package/dist/test/test_worker.d.ts +0 -1
  754. package/dist/test/test_worker.js +0 -1182
  755. package/dist/test/test_worker.js.map +0 -1
  756. package/dist/utils.d.ts +0 -8
  757. package/dist/utils.js +0 -31
  758. package/dist/utils.js.map +0 -1
  759. package/release.txt +0 -21
  760. package/src/classes/backoffs.ts +0 -67
  761. package/src/classes/child-pool.ts +0 -119
  762. package/src/classes/compat.ts +0 -890
  763. package/src/classes/index.ts +0 -13
  764. package/src/classes/job.ts +0 -495
  765. package/src/classes/master.ts +0 -113
  766. package/src/classes/queue-base.ts +0 -87
  767. package/src/classes/queue-events.ts +0 -78
  768. package/src/classes/queue-getters.ts +0 -213
  769. package/src/classes/queue-scheduler.ts +0 -125
  770. package/src/classes/queue.ts +0 -180
  771. package/src/classes/redis-connection.ts +0 -111
  772. package/src/classes/repeat.ts +0 -217
  773. package/src/classes/sandbox.ts +0 -60
  774. package/src/classes/scripts.ts +0 -468
  775. package/src/classes/worker.ts +0 -288
  776. package/src/commands/addJob-8.lua +0 -106
  777. package/src/commands/cleanJobsInSet-1.lua +0 -48
  778. package/src/commands/index.ts +0 -62
  779. package/src/commands/isFinished-2.lua +0 -22
  780. package/src/commands/isJobInList-1.lua +0 -20
  781. package/src/commands/moveStalledJobsToWait-8.lua +0 -91
  782. package/src/commands/moveToActive-8.lua +0 -79
  783. package/src/commands/moveToDelayed-5.lua +0 -39
  784. package/src/commands/moveToFinished-7.lua +0 -92
  785. package/src/commands/pause-4.lua +0 -27
  786. package/src/commands/promote-4.lua +0 -49
  787. package/src/commands/releaseLock-1.lua +0 -19
  788. package/src/commands/removeJob-10.lua +0 -37
  789. package/src/commands/reprocessJob-4.lua +0 -36
  790. package/src/commands/retryJob-4.lua +0 -34
  791. package/src/commands/takeLock-1.lua +0 -17
  792. package/src/commands/updateDelaySet-7.lua +0 -71
  793. package/src/commands/updateProgress-2.lua +0 -15
  794. package/src/enums/index.ts +0 -1
  795. package/src/enums/retry-errors.enum.ts +0 -5
  796. package/src/interfaces/advanced-options.ts +0 -28
  797. package/src/interfaces/backoff-options.ts +0 -4
  798. package/src/interfaces/index.ts +0 -9
  799. package/src/interfaces/jobs-options.ts +0 -53
  800. package/src/interfaces/queue-options.ts +0 -30
  801. package/src/interfaces/queue-scheduler-options.ts +0 -6
  802. package/src/interfaces/rate-limiter-options.ts +0 -7
  803. package/src/interfaces/redis-options.ts +0 -9
  804. package/src/interfaces/repeat-options.ts +0 -19
  805. package/src/interfaces/worker-options.ts +0 -13
  806. package/src/test/fixtures/fixture_processor.js +0 -13
  807. package/src/test/fixtures/fixture_processor_bar.js +0 -13
  808. package/src/test/fixtures/fixture_processor_crash.js +0 -16
  809. package/src/test/fixtures/fixture_processor_exit.js +0 -15
  810. package/src/test/fixtures/fixture_processor_fail.js +0 -13
  811. package/src/test/fixtures/fixture_processor_foo.js +0 -13
  812. package/src/test/fixtures/fixture_processor_progress.js +0 -29
  813. package/src/test/fixtures/fixture_processor_slow.js +0 -13
  814. package/src/test/test_bulk.ts +0 -59
  815. package/src/test/test_child-pool.ts +0 -88
  816. package/src/test/test_clean.ts +0 -148
  817. package/src/test/test_compat.ts +0 -640
  818. package/src/test/test_connection.ts +0 -159
  819. package/src/test/test_delay.ts +0 -220
  820. package/src/test/test_events.ts +0 -198
  821. package/src/test/test_getters.ts +0 -348
  822. package/src/test/test_job.ts +0 -524
  823. package/src/test/test_pause.ts +0 -313
  824. package/src/test/test_queue.ts +0 -70
  825. package/src/test/test_rate_limiter.ts +0 -113
  826. package/src/test/test_repeat.ts +0 -783
  827. package/src/test/test_sandboxed_process.ts +0 -380
  828. package/src/test/test_stalled_jobs.ts +0 -146
  829. package/src/test/test_worker.ts +0 -1503
  830. package/src/utils.ts +0 -28
  831. package/tsconfig.json +0 -25
  832. package/tslint.json +0 -23
  833. /package/dist/{classes/master.d.ts → cjs/classes/main-worker.d.ts} +0 -0
  834. /package/dist/{test/test_bulk.d.ts → cjs/classes/main.d.ts} +0 -0
  835. /package/dist/{interfaces → cjs/interfaces}/backoff-options.js +0 -0
  836. /package/dist/{interfaces → cjs/interfaces}/rate-limiter-options.js +0 -0
  837. /package/dist/{interfaces → cjs/interfaces}/redis-options.js +0 -0
  838. /package/dist/{interfaces → cjs/interfaces}/repeat-options.js +0 -0
  839. /package/dist/{interfaces → cjs/interfaces}/worker-options.js +0 -0
  840. /package/dist/{test/test_child-pool.d.ts → esm/classes/main-worker.d.ts} +0 -0
  841. /package/dist/{test/test_clean.d.ts → esm/classes/main.d.ts} +0 -0
@@ -0,0 +1,764 @@
1
+ import { __rest } from "tslib";
2
+ import { invert } from 'lodash';
3
+ import { debuglog } from 'util';
4
+ import { errorObject, isEmpty, getParentKey, lengthInUtf8Bytes, parseObjectValues, tryCatch, } from '../utils';
5
+ import { Backoffs } from './backoffs';
6
+ import { Scripts } from './scripts';
7
+ import { UnrecoverableError } from './unrecoverable-error';
8
+ const logger = debuglog('bull');
9
+ const optsDecodeMap = {
10
+ fpof: 'failParentOnFailure',
11
+ kl: 'keepLogs',
12
+ };
13
+ const optsEncodeMap = invert(optsDecodeMap);
14
+ /**
15
+ * Job
16
+ *
17
+ * This class represents a Job in the queue. Normally job are implicitly created when
18
+ * you add a job to the queue with methods such as Queue.addJob( ... )
19
+ *
20
+ * A Job instance is also passed to the Worker's process function.
21
+ *
22
+ * @class Job
23
+ */
24
+ export class Job {
25
+ constructor(queue,
26
+ /**
27
+ * The name of the Job
28
+ */
29
+ name,
30
+ /**
31
+ * The payload for this job.
32
+ */
33
+ data,
34
+ /**
35
+ * The options object for this job.
36
+ */
37
+ opts = {}, id) {
38
+ this.queue = queue;
39
+ this.name = name;
40
+ this.data = data;
41
+ this.opts = opts;
42
+ this.id = id;
43
+ /**
44
+ * The progress a job has performed so far.
45
+ * @defaultValue 0
46
+ */
47
+ this.progress = 0;
48
+ /**
49
+ * The value returned by the processor when processing this job.
50
+ * @defaultValue null
51
+ */
52
+ this.returnvalue = null;
53
+ /**
54
+ * Stacktrace for the error (for failed jobs).
55
+ * @defaultValue null
56
+ */
57
+ this.stacktrace = null;
58
+ /**
59
+ * Number of attempts after the job has failed.
60
+ * @defaultValue 0
61
+ */
62
+ this.attemptsMade = 0;
63
+ const _a = this.opts, { repeatJobKey } = _a, restOpts = __rest(_a, ["repeatJobKey"]);
64
+ this.opts = Object.assign({
65
+ attempts: 0,
66
+ delay: 0,
67
+ }, restOpts);
68
+ this.delay = this.opts.delay;
69
+ this.repeatJobKey = repeatJobKey;
70
+ this.timestamp = opts.timestamp ? opts.timestamp : Date.now();
71
+ this.opts.backoff = Backoffs.normalize(opts.backoff);
72
+ this.parentKey = getParentKey(opts.parent);
73
+ this.parent = opts.parent
74
+ ? { id: opts.parent.id, queueKey: opts.parent.queue }
75
+ : undefined;
76
+ this.toKey = queue.toKey.bind(queue);
77
+ this.scripts = new Scripts(queue);
78
+ }
79
+ /**
80
+ * Creates a new job and adds it to the queue.
81
+ *
82
+ * @param queue - the queue where to add the job.
83
+ * @param name - the name of the job.
84
+ * @param data - the payload of the job.
85
+ * @param opts - the options bag for this job.
86
+ * @returns
87
+ */
88
+ static async create(queue, name, data, opts) {
89
+ const client = await queue.client;
90
+ const job = new this(queue, name, data, opts, opts && opts.jobId);
91
+ job.id = await job.addJob(client, {
92
+ parentKey: job.parentKey,
93
+ parentDependenciesKey: job.parentKey
94
+ ? `${job.parentKey}:dependencies`
95
+ : '',
96
+ });
97
+ return job;
98
+ }
99
+ /**
100
+ * Creates a bulk of jobs and adds them atomically to the given queue.
101
+ *
102
+ * @param queue -the queue were to add the jobs.
103
+ * @param jobs - an array of jobs to be added to the queue.
104
+ * @returns
105
+ */
106
+ static async createBulk(queue, jobs) {
107
+ const client = await queue.client;
108
+ const jobInstances = jobs.map(job => { var _a; return new this(queue, job.name, job.data, job.opts, (_a = job.opts) === null || _a === void 0 ? void 0 : _a.jobId); });
109
+ const multi = client.multi();
110
+ for (const job of jobInstances) {
111
+ job.addJob(multi, {
112
+ parentKey: job.parentKey,
113
+ parentDependenciesKey: job.parentKey
114
+ ? `${job.parentKey}:dependencies`
115
+ : '',
116
+ });
117
+ }
118
+ const results = (await multi.exec());
119
+ for (let index = 0; index < results.length; ++index) {
120
+ const [err, id] = results[index];
121
+ if (err) {
122
+ throw err;
123
+ }
124
+ jobInstances[index].id = id;
125
+ }
126
+ return jobInstances;
127
+ }
128
+ /**
129
+ * Instantiates a Job from a JobJsonRaw object (coming from a deserialized JSON object)
130
+ *
131
+ * @param queue - the queue where the job belongs to.
132
+ * @param json - the plain object containing the job.
133
+ * @param jobId - an optional job id (overrides the id coming from the JSON object)
134
+ * @returns
135
+ */
136
+ static fromJSON(queue, json, jobId) {
137
+ const data = JSON.parse(json.data || '{}');
138
+ const opts = Job.optsFromJSON(json.opts);
139
+ const job = new this(queue, json.name, data, opts, json.id || jobId);
140
+ job.progress = JSON.parse(json.progress || '0');
141
+ job.delay = parseInt(json.delay);
142
+ job.timestamp = parseInt(json.timestamp);
143
+ if (json.finishedOn) {
144
+ job.finishedOn = parseInt(json.finishedOn);
145
+ }
146
+ if (json.processedOn) {
147
+ job.processedOn = parseInt(json.processedOn);
148
+ }
149
+ if (json.rjk) {
150
+ job.repeatJobKey = json.rjk;
151
+ }
152
+ job.failedReason = json.failedReason;
153
+ job.attemptsMade = parseInt(json.attemptsMade || '0');
154
+ job.stacktrace = getTraces(json.stacktrace);
155
+ if (typeof json.returnvalue === 'string') {
156
+ job.returnvalue = getReturnValue(json.returnvalue);
157
+ }
158
+ if (json.parentKey) {
159
+ job.parentKey = json.parentKey;
160
+ }
161
+ if (json.parent) {
162
+ job.parent = JSON.parse(json.parent);
163
+ }
164
+ return job;
165
+ }
166
+ static optsFromJSON(rawOpts) {
167
+ const opts = JSON.parse(rawOpts || '{}');
168
+ const optionEntries = Object.entries(opts);
169
+ const options = {};
170
+ for (const item of optionEntries) {
171
+ const [attributeName, value] = item;
172
+ if (optsDecodeMap[attributeName]) {
173
+ options[optsDecodeMap[attributeName]] =
174
+ value;
175
+ }
176
+ else {
177
+ options[attributeName] = value;
178
+ }
179
+ }
180
+ return options;
181
+ }
182
+ /**
183
+ * Fetches a Job from the queue given the passed job id.
184
+ *
185
+ * @param queue - the queue where the job belongs to.
186
+ * @param jobId - the job id.
187
+ * @returns
188
+ */
189
+ static async fromId(queue, jobId) {
190
+ // jobId can be undefined if moveJob returns undefined
191
+ if (jobId) {
192
+ const client = await queue.client;
193
+ const jobData = await client.hgetall(queue.toKey(jobId));
194
+ return isEmpty(jobData)
195
+ ? undefined
196
+ : this.fromJSON(queue, jobData, jobId);
197
+ }
198
+ }
199
+ toJSON() {
200
+ const _a = this, { queue, scripts } = _a, withoutQueueAndScripts = __rest(_a, ["queue", "scripts"]);
201
+ return withoutQueueAndScripts;
202
+ }
203
+ /**
204
+ * Prepares a job to be serialized for storage in Redis.
205
+ * @returns
206
+ */
207
+ asJSON() {
208
+ return {
209
+ id: this.id,
210
+ name: this.name,
211
+ data: JSON.stringify(typeof this.data === 'undefined' ? {} : this.data),
212
+ opts: this.optsAsJSON(this.opts),
213
+ parent: this.parent ? Object.assign({}, this.parent) : undefined,
214
+ parentKey: this.parentKey,
215
+ progress: this.progress,
216
+ attemptsMade: this.attemptsMade,
217
+ finishedOn: this.finishedOn,
218
+ processedOn: this.processedOn,
219
+ timestamp: this.timestamp,
220
+ failedReason: JSON.stringify(this.failedReason),
221
+ stacktrace: JSON.stringify(this.stacktrace),
222
+ repeatJobKey: this.repeatJobKey,
223
+ returnvalue: JSON.stringify(this.returnvalue),
224
+ };
225
+ }
226
+ optsAsJSON(opts = {}) {
227
+ const optionEntries = Object.entries(opts);
228
+ const options = {};
229
+ for (const item of optionEntries) {
230
+ const [attributeName, value] = item;
231
+ if (optsEncodeMap[attributeName]) {
232
+ options[optsEncodeMap[attributeName]] =
233
+ value;
234
+ }
235
+ else {
236
+ options[attributeName] = value;
237
+ }
238
+ }
239
+ return options;
240
+ }
241
+ /**
242
+ * Prepares a job to be passed to Sandbox.
243
+ * @returns
244
+ */
245
+ asJSONSandbox() {
246
+ return Object.assign(Object.assign({}, this.asJSON()), { queueName: this.queueName, prefix: this.prefix });
247
+ }
248
+ /**
249
+ * Updates a job's data
250
+ *
251
+ * @param data - the data that will replace the current jobs data.
252
+ */
253
+ updateData(data) {
254
+ this.data = data;
255
+ return this.scripts.updateData(this, data);
256
+ }
257
+ /**
258
+ * Updates a job's progress
259
+ *
260
+ * @param progress - number or object to be saved as progress.
261
+ */
262
+ updateProgress(progress) {
263
+ this.progress = progress;
264
+ return this.scripts.updateProgress(this, progress);
265
+ }
266
+ /**
267
+ * Logs one row of log data.
268
+ *
269
+ * @param logRow - string with log data to be logged.
270
+ */
271
+ async log(logRow) {
272
+ const client = await this.queue.client;
273
+ const logsKey = this.toKey(this.id) + ':logs';
274
+ const multi = client.multi();
275
+ multi.rpush(logsKey, logRow);
276
+ if (this.opts.keepLogs) {
277
+ multi.ltrim(logsKey, -this.opts.keepLogs, -1);
278
+ }
279
+ const result = (await multi.exec());
280
+ return this.opts.keepLogs
281
+ ? Math.min(this.opts.keepLogs, result[0][1])
282
+ : result[0][1];
283
+ }
284
+ /**
285
+ * Clears job's logs
286
+ *
287
+ * @param keepLogs - the amount of log entries to preserve
288
+ */
289
+ async clearLogs(keepLogs) {
290
+ const client = await this.queue.client;
291
+ const logsKey = this.toKey(this.id) + ':logs';
292
+ if (keepLogs) {
293
+ await client.ltrim(logsKey, -keepLogs, -1);
294
+ }
295
+ else {
296
+ await client.del(logsKey);
297
+ }
298
+ }
299
+ /**
300
+ * Completely remove the job from the queue.
301
+ * Note, this call will throw an exception if the job
302
+ * is being processed when the call is performed.
303
+ */
304
+ async remove() {
305
+ await this.queue.waitUntilReady();
306
+ const queue = this.queue;
307
+ const job = this;
308
+ const removed = await this.scripts.remove(job.id);
309
+ if (removed) {
310
+ queue.emit('removed', job);
311
+ }
312
+ else {
313
+ throw new Error('Could not remove job ' + job.id);
314
+ }
315
+ }
316
+ /**
317
+ * Extend the lock for this job.
318
+ *
319
+ * @param token - unique token for the lock
320
+ * @param duration - lock duration in milliseconds
321
+ */
322
+ extendLock(token, duration) {
323
+ return this.scripts.extendLock(this.id, token, duration);
324
+ }
325
+ /**
326
+ * Moves a job to the completed queue.
327
+ * Returned job to be used with Queue.prototype.nextJobFromJobData.
328
+ *
329
+ * @param returnValue - The jobs success message.
330
+ * @param token - Worker token used to acquire completed job.
331
+ * @param fetchNext - True when wanting to fetch the next job.
332
+ * @returns Returns the jobData of the next job in the waiting queue.
333
+ */
334
+ async moveToCompleted(returnValue, token, fetchNext = true) {
335
+ await this.queue.waitUntilReady();
336
+ this.returnvalue = returnValue || void 0;
337
+ const stringifiedReturnValue = tryCatch(JSON.stringify, JSON, [
338
+ returnValue,
339
+ ]);
340
+ if (stringifiedReturnValue === errorObject) {
341
+ throw errorObject.value;
342
+ }
343
+ const args = this.scripts.moveToCompletedArgs(this, stringifiedReturnValue, this.opts.removeOnComplete, token, fetchNext);
344
+ const result = await this.scripts.moveToFinished(this.id, args);
345
+ this.finishedOn = args[14];
346
+ return result;
347
+ }
348
+ /**
349
+ * Moves a job to the failed queue.
350
+ *
351
+ * @param err - the jobs error message.
352
+ * @param token - token to check job is locked by current worker
353
+ * @param fetchNext - true when wanting to fetch the next job
354
+ * @returns void
355
+ */
356
+ async moveToFailed(err, token, fetchNext = false) {
357
+ const client = await this.queue.client;
358
+ const message = err === null || err === void 0 ? void 0 : err.message;
359
+ const queue = this.queue;
360
+ this.failedReason = message;
361
+ let command;
362
+ const multi = client.multi();
363
+ this.saveStacktrace(multi, err);
364
+ //
365
+ // Check if an automatic retry should be performed
366
+ //
367
+ let moveToFailed = false;
368
+ let finishedOn;
369
+ if (this.attemptsMade < this.opts.attempts &&
370
+ !this.discarded &&
371
+ !(err instanceof UnrecoverableError || err.name == 'UnrecoverableError')) {
372
+ const opts = queue.opts;
373
+ // Check if backoff is needed
374
+ const delay = await Backoffs.calculate(this.opts.backoff, this.attemptsMade, err, this, opts.settings && opts.settings.backoffStrategy);
375
+ if (delay === -1) {
376
+ moveToFailed = true;
377
+ }
378
+ else if (delay) {
379
+ const args = this.scripts.moveToDelayedArgs(this.id, Date.now() + delay, token);
380
+ multi.moveToDelayed(args);
381
+ command = 'delayed';
382
+ }
383
+ else {
384
+ // Retry immediately
385
+ multi.retryJob(this.scripts.retryJobArgs(this.id, this.opts.lifo, token));
386
+ command = 'retryJob';
387
+ }
388
+ }
389
+ else {
390
+ // If not, move to failed
391
+ moveToFailed = true;
392
+ }
393
+ if (moveToFailed) {
394
+ const args = this.scripts.moveToFailedArgs(this, message, this.opts.removeOnFail, token, fetchNext);
395
+ multi.moveToFinished(args);
396
+ finishedOn = args[14];
397
+ command = 'failed';
398
+ }
399
+ const results = await multi.exec();
400
+ const anyError = results.find(result => result[0]);
401
+ if (anyError) {
402
+ throw new Error(`Error "moveToFailed" with command ${command}: ${anyError}`);
403
+ }
404
+ const code = results[results.length - 1][1];
405
+ if (code < 0) {
406
+ throw this.scripts.finishedErrors(code, this.id, command, 'active');
407
+ }
408
+ if (finishedOn && typeof finishedOn === 'number') {
409
+ this.finishedOn = finishedOn;
410
+ }
411
+ }
412
+ /**
413
+ * @returns true if the job has completed.
414
+ */
415
+ isCompleted() {
416
+ return this.isInZSet('completed');
417
+ }
418
+ /**
419
+ * @returns true if the job has failed.
420
+ */
421
+ isFailed() {
422
+ return this.isInZSet('failed');
423
+ }
424
+ /**
425
+ * @returns true if the job is delayed.
426
+ */
427
+ isDelayed() {
428
+ return this.isInZSet('delayed');
429
+ }
430
+ /**
431
+ * @returns true if the job is waiting for children.
432
+ */
433
+ isWaitingChildren() {
434
+ return this.isInZSet('waiting-children');
435
+ }
436
+ /**
437
+ * @returns true of the job is active.
438
+ */
439
+ isActive() {
440
+ return this.isInList('active');
441
+ }
442
+ /**
443
+ * @returns true if the job is waiting.
444
+ */
445
+ async isWaiting() {
446
+ return (await this.isInList('wait')) || (await this.isInList('paused'));
447
+ }
448
+ /**
449
+ * @returns the queue name this job belongs to.
450
+ */
451
+ get queueName() {
452
+ return this.queue.name;
453
+ }
454
+ /**
455
+ * @returns the prefix that is used.
456
+ */
457
+ get prefix() {
458
+ return this.queue.opts.prefix;
459
+ }
460
+ /**
461
+ * @returns it includes the prefix, the namespace separator :, and queue name.
462
+ * @see https://www.gnu.org/software/gawk/manual/html_node/Qualified-Names.html
463
+ */
464
+ get queueQualifiedName() {
465
+ return `${this.prefix}:${this.queueName}`;
466
+ }
467
+ /**
468
+ * Get current state.
469
+ *
470
+ * @returns Returns one of these values:
471
+ * 'completed', 'failed', 'delayed', 'active', 'waiting', 'waiting-children', 'unknown'.
472
+ */
473
+ getState() {
474
+ return this.scripts.getState(this.id);
475
+ }
476
+ /**
477
+ * Change delay of a delayed job.
478
+ *
479
+ * @param delay - milliseconds to be added to current time.
480
+ * @returns void
481
+ */
482
+ async changeDelay(delay) {
483
+ await this.scripts.changeDelay(this.id, delay);
484
+ this.delay = delay;
485
+ }
486
+ /**
487
+ * Change job priority.
488
+ *
489
+ * @returns void
490
+ */
491
+ async changePriority(opts) {
492
+ await this.scripts.changePriority(this.id, opts.priority, opts.lifo);
493
+ }
494
+ /**
495
+ * Get this jobs children result values if any.
496
+ *
497
+ * @returns Object mapping children job keys with their values.
498
+ */
499
+ async getChildrenValues() {
500
+ const client = await this.queue.client;
501
+ const result = (await client.hgetall(this.toKey(`${this.id}:processed`)));
502
+ if (result) {
503
+ return parseObjectValues(result);
504
+ }
505
+ }
506
+ /**
507
+ * Get children job keys if this job is a parent and has children.
508
+ *
509
+ * @returns dependencies separated by processed and unprocessed.
510
+ */
511
+ async getDependencies(opts = {}) {
512
+ const client = await this.queue.client;
513
+ const multi = client.multi();
514
+ if (!opts.processed && !opts.unprocessed) {
515
+ multi.hgetall(this.toKey(`${this.id}:processed`));
516
+ multi.smembers(this.toKey(`${this.id}:dependencies`));
517
+ const [[err1, processed], [err2, unprocessed]] = (await multi.exec());
518
+ const transformedProcessed = parseObjectValues(processed);
519
+ return { processed: transformedProcessed, unprocessed };
520
+ }
521
+ else {
522
+ const defaultOpts = {
523
+ cursor: 0,
524
+ count: 20,
525
+ };
526
+ if (opts.processed) {
527
+ const processedOpts = Object.assign(Object.assign({}, defaultOpts), opts.processed);
528
+ multi.hscan(this.toKey(`${this.id}:processed`), processedOpts.cursor, 'COUNT', processedOpts.count);
529
+ }
530
+ if (opts.unprocessed) {
531
+ const unprocessedOpts = Object.assign(Object.assign({}, defaultOpts), opts.unprocessed);
532
+ multi.sscan(this.toKey(`${this.id}:dependencies`), unprocessedOpts.cursor, 'COUNT', unprocessedOpts.count);
533
+ }
534
+ const [result1, result2] = (await multi.exec());
535
+ const [processedCursor, processed = []] = opts.processed
536
+ ? result1[1]
537
+ : [];
538
+ const [unprocessedCursor, unprocessed = []] = opts.unprocessed
539
+ ? opts.processed
540
+ ? result2[1]
541
+ : result1[1]
542
+ : [];
543
+ const transformedProcessed = {};
544
+ for (let index = 0; index < processed.length; ++index) {
545
+ if (index % 2) {
546
+ transformedProcessed[processed[index - 1]] = JSON.parse(processed[index]);
547
+ }
548
+ }
549
+ return Object.assign(Object.assign({}, (processedCursor
550
+ ? {
551
+ processed: transformedProcessed,
552
+ nextProcessedCursor: Number(processedCursor),
553
+ }
554
+ : {})), (unprocessedCursor
555
+ ? { unprocessed, nextUnprocessedCursor: Number(unprocessedCursor) }
556
+ : {}));
557
+ }
558
+ }
559
+ /**
560
+ * Get children job counts if this job is a parent and has children.
561
+ *
562
+ * @returns dependencies count separated by processed and unprocessed.
563
+ */
564
+ async getDependenciesCount(opts = {}) {
565
+ const client = await this.queue.client;
566
+ const multi = client.multi();
567
+ const updatedOpts = !opts.processed && !opts.unprocessed
568
+ ? { processed: true, unprocessed: true }
569
+ : opts;
570
+ if (updatedOpts.processed) {
571
+ multi.hlen(this.toKey(`${this.id}:processed`));
572
+ }
573
+ if (updatedOpts.unprocessed) {
574
+ multi.scard(this.toKey(`${this.id}:dependencies`));
575
+ }
576
+ const [[err1, result1] = [], [err2, result2] = []] = (await multi.exec());
577
+ const processed = updatedOpts.processed ? result1 : undefined;
578
+ const unprocessed = updatedOpts.unprocessed
579
+ ? updatedOpts.processed
580
+ ? result2
581
+ : result1
582
+ : undefined;
583
+ return Object.assign(Object.assign({}, (updatedOpts.processed
584
+ ? {
585
+ processed,
586
+ }
587
+ : {})), (updatedOpts.unprocessed ? { unprocessed } : {}));
588
+ }
589
+ /**
590
+ * Returns a promise the resolves when the job has completed (containing the return value of the job),
591
+ * or rejects when the job has failed (containing the failedReason).
592
+ *
593
+ * @param queueEvents - Instance of QueueEvents.
594
+ * @param ttl - Time in milliseconds to wait for job to finish before timing out.
595
+ */
596
+ async waitUntilFinished(queueEvents, ttl) {
597
+ await this.queue.waitUntilReady();
598
+ const jobId = this.id;
599
+ return new Promise(async (resolve, reject) => {
600
+ let timeout;
601
+ if (ttl) {
602
+ timeout = setTimeout(() => onFailed(
603
+ /* eslint-disable max-len */
604
+ `Job wait ${this.name} timed out before finishing, no finish notification arrived after ${ttl}ms (id=${jobId})`), ttl);
605
+ }
606
+ function onCompleted(args) {
607
+ removeListeners();
608
+ resolve(args.returnvalue);
609
+ }
610
+ function onFailed(args) {
611
+ removeListeners();
612
+ reject(new Error(args.failedReason || args));
613
+ }
614
+ const completedEvent = `completed:${jobId}`;
615
+ const failedEvent = `failed:${jobId}`;
616
+ queueEvents.on(completedEvent, onCompleted);
617
+ queueEvents.on(failedEvent, onFailed);
618
+ this.queue.on('closing', onFailed);
619
+ const removeListeners = () => {
620
+ clearInterval(timeout);
621
+ queueEvents.removeListener(completedEvent, onCompleted);
622
+ queueEvents.removeListener(failedEvent, onFailed);
623
+ this.queue.removeListener('closing', onFailed);
624
+ };
625
+ // Poll once right now to see if the job has already finished. The job may have been completed before we were able
626
+ // to register the event handlers on the QueueEvents, so we check here to make sure we're not waiting for an event
627
+ // that has already happened. We block checking the job until the queue events object is actually listening to
628
+ // Redis so there's no chance that it will miss events.
629
+ await queueEvents.waitUntilReady();
630
+ const [status, result] = (await this.scripts.isFinished(jobId, true));
631
+ const finished = status != 0;
632
+ if (finished) {
633
+ if (status == -1 || status == 2) {
634
+ onFailed({ failedReason: result });
635
+ }
636
+ else {
637
+ onCompleted({ returnvalue: getReturnValue(result) });
638
+ }
639
+ }
640
+ });
641
+ }
642
+ /**
643
+ * Moves the job to the delay set.
644
+ *
645
+ * @param timestamp - timestamp where the job should be moved back to "wait"
646
+ * @param token - token to check job is locked by current worker
647
+ * @returns
648
+ */
649
+ moveToDelayed(timestamp, token) {
650
+ return this.scripts.moveToDelayed(this.id, timestamp, token);
651
+ }
652
+ /**
653
+ * Moves the job to the waiting-children set.
654
+ *
655
+ * @param token - Token to check job is locked by current worker
656
+ * @param opts - The options bag for moving a job to waiting-children.
657
+ * @returns true if the job was moved
658
+ */
659
+ moveToWaitingChildren(token, opts = {}) {
660
+ return this.scripts.moveToWaitingChildren(this.id, token, opts);
661
+ }
662
+ /**
663
+ * Promotes a delayed job so that it starts to be processed as soon as possible.
664
+ */
665
+ async promote() {
666
+ const jobId = this.id;
667
+ const code = await this.scripts.promote(jobId);
668
+ if (code < 0) {
669
+ throw this.scripts.finishedErrors(code, this.id, 'promote', 'delayed');
670
+ }
671
+ }
672
+ /**
673
+ * Attempts to retry the job. Only a job that has failed or completed can be retried.
674
+ *
675
+ * @param state - completed / failed
676
+ * @returns If resolved and return code is 1, then the queue emits a waiting event
677
+ * otherwise the operation was not a success and throw the corresponding error. If the promise
678
+ * rejects, it indicates that the script failed to execute
679
+ */
680
+ retry(state = 'failed') {
681
+ this.failedReason = null;
682
+ this.finishedOn = null;
683
+ this.processedOn = null;
684
+ this.returnvalue = null;
685
+ return this.scripts.reprocessJob(this, state);
686
+ }
687
+ /**
688
+ * Marks a job to not be retried if it fails (even if attempts has been configured)
689
+ */
690
+ discard() {
691
+ this.discarded = true;
692
+ }
693
+ async isInZSet(set) {
694
+ const client = await this.queue.client;
695
+ const score = await client.zscore(this.queue.toKey(set), this.id);
696
+ return score !== null;
697
+ }
698
+ async isInList(list) {
699
+ return this.scripts.isJobInList(this.queue.toKey(list), this.id);
700
+ }
701
+ /**
702
+ * Adds the job to Redis.
703
+ *
704
+ * @param client -
705
+ * @param parentOpts -
706
+ * @returns
707
+ */
708
+ addJob(client, parentOpts) {
709
+ var _a;
710
+ const jobData = this.asJSON();
711
+ const exceedLimit = this.opts.sizeLimit &&
712
+ lengthInUtf8Bytes(jobData.data) > this.opts.sizeLimit;
713
+ if (exceedLimit) {
714
+ throw new Error(`The size of job ${this.name} exceeds the limit ${this.opts.sizeLimit} bytes`);
715
+ }
716
+ if (this.opts.delay && this.opts.repeat && !((_a = this.opts.repeat) === null || _a === void 0 ? void 0 : _a.count)) {
717
+ throw new Error(`Delay and repeat options could not be used together`);
718
+ }
719
+ if (`${parseInt(this.id, 10)}` === this.id) {
720
+ //TODO: throw an error in next breaking change
721
+ console.warn('Custom Ids should not be integers: https://github.com/taskforcesh/bullmq/pull/1569');
722
+ }
723
+ if (this.opts.priority) {
724
+ if (Math.trunc(this.opts.priority) !== this.opts.priority) {
725
+ throw new Error(`Priority should not be float`);
726
+ }
727
+ const priorityLimit = 2 ** 21;
728
+ if (this.opts.priority > 2 ** 21) {
729
+ throw new Error(`Priority should be between 0 and ${priorityLimit}`);
730
+ }
731
+ }
732
+ return this.scripts.addJob(client, jobData, jobData.opts, this.id, parentOpts);
733
+ }
734
+ saveStacktrace(multi, err) {
735
+ this.stacktrace = this.stacktrace || [];
736
+ if (err === null || err === void 0 ? void 0 : err.stack) {
737
+ this.stacktrace.push(err.stack);
738
+ if (this.opts.stackTraceLimit) {
739
+ this.stacktrace = this.stacktrace.slice(0, this.opts.stackTraceLimit);
740
+ }
741
+ }
742
+ const args = this.scripts.saveStacktraceArgs(this.id, JSON.stringify(this.stacktrace), err === null || err === void 0 ? void 0 : err.message);
743
+ multi.saveStacktrace(args);
744
+ }
745
+ }
746
+ function getTraces(stacktrace) {
747
+ const traces = tryCatch(JSON.parse, JSON, [stacktrace]);
748
+ if (traces === errorObject || !(traces instanceof Array)) {
749
+ return [];
750
+ }
751
+ else {
752
+ return traces;
753
+ }
754
+ }
755
+ function getReturnValue(_value) {
756
+ const value = tryCatch(JSON.parse, JSON, [_value]);
757
+ if (value !== errorObject) {
758
+ return value;
759
+ }
760
+ else {
761
+ logger('corrupted returnvalue: ' + _value, value);
762
+ }
763
+ }
764
+ //# sourceMappingURL=job.js.map