bullmq 4.0.0-beta.2 → 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 (820) hide show
  1. package/README.md +153 -19
  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/cjs/interfaces/child-message.js +3 -0
  131. package/dist/cjs/interfaces/child-message.js.map +1 -0
  132. package/dist/{interfaces/jobs-options.js → cjs/interfaces/connection.js} +1 -1
  133. package/dist/cjs/interfaces/connection.js.map +1 -0
  134. package/dist/cjs/interfaces/flow-job.js +3 -0
  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/cjs/interfaces/job-json.js +3 -0
  141. package/dist/cjs/interfaces/job-json.js.map +1 -0
  142. package/dist/cjs/interfaces/keep-jobs.js +3 -0
  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/cjs/interfaces/redis-streams.js +3 -0
  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/{interfaces/queue-scheduler-options.js → cjs/interfaces/sandboxed-job-processor.js} +1 -1
  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 +180 -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 -315
  604. package/dist/classes/compat.js +0 -671
  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 -353
  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 -22
  613. package/dist/classes/queue-base.js +0 -66
  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 -183
  620. package/dist/classes/queue-getters.js.map +0 -1
  621. package/dist/classes/queue-scheduler.d.ts +0 -25
  622. package/dist/classes/queue-scheduler.js +0 -97
  623. package/dist/classes/queue-scheduler.js.map +0 -1
  624. package/dist/classes/queue.d.ts +0 -56
  625. package/dist/classes/queue.js +0 -130
  626. package/dist/classes/queue.js.map +0 -1
  627. package/dist/classes/redis-connection.d.ts +0 -22
  628. package/dist/classes/redis-connection.js +0 -108
  629. package/dist/classes/redis-connection.js.map +0 -1
  630. package/dist/classes/repeat.d.ts +0 -26
  631. package/dist/classes/repeat.js +0 -129
  632. package/dist/classes/repeat.js.map +0 -1
  633. package/dist/classes/sandbox.d.ts +0 -2
  634. package/dist/classes/sandbox.js.map +0 -1
  635. package/dist/classes/scripts.d.ts +0 -43
  636. package/dist/classes/scripts.js +0 -307
  637. package/dist/classes/scripts.js.map +0 -1
  638. package/dist/classes/worker.d.ts +0 -40
  639. package/dist/classes/worker.js +0 -246
  640. package/dist/classes/worker.js.map +0 -1
  641. package/dist/commands/addJob-8.lua +0 -106
  642. package/dist/commands/cleanJobsInSet-1.lua +0 -48
  643. package/dist/commands/index.d.ts +0 -2
  644. package/dist/commands/index.js +0 -42
  645. package/dist/commands/index.js.map +0 -1
  646. package/dist/commands/isFinished-2.lua +0 -22
  647. package/dist/commands/isJobInList-1.lua +0 -20
  648. package/dist/commands/moveStalledJobsToWait-8.lua +0 -91
  649. package/dist/commands/moveToActive-8.lua +0 -79
  650. package/dist/commands/moveToDelayed-5.lua +0 -39
  651. package/dist/commands/moveToFinished-7.lua +0 -92
  652. package/dist/commands/pause-4.lua +0 -27
  653. package/dist/commands/promote-4.lua +0 -49
  654. package/dist/commands/releaseLock-1.lua +0 -19
  655. package/dist/commands/removeJob-10.lua +0 -37
  656. package/dist/commands/reprocessJob-4.lua +0 -36
  657. package/dist/commands/retryJob-4.lua +0 -34
  658. package/dist/commands/takeLock-1.lua +0 -17
  659. package/dist/commands/updateDelaySet-7.lua +0 -71
  660. package/dist/commands/updateProgress-2.lua +0 -15
  661. package/dist/enums/index.d.ts +0 -1
  662. package/dist/enums/index.js +0 -5
  663. package/dist/enums/index.js.map +0 -1
  664. package/dist/enums/retry-errors.enum.d.ts +0 -5
  665. package/dist/enums/retry-errors.enum.js +0 -9
  666. package/dist/enums/retry-errors.enum.js.map +0 -1
  667. package/dist/index.js.map +0 -1
  668. package/dist/interfaces/advanced-options.d.ts +0 -9
  669. package/dist/interfaces/advanced-options.js +0 -11
  670. package/dist/interfaces/advanced-options.js.map +0 -1
  671. package/dist/interfaces/backoff-options.d.ts +0 -4
  672. package/dist/interfaces/backoff-options.js.map +0 -1
  673. package/dist/interfaces/index.d.ts +0 -9
  674. package/dist/interfaces/index.js +0 -6
  675. package/dist/interfaces/index.js.map +0 -1
  676. package/dist/interfaces/jobs-options.d.ts +0 -16
  677. package/dist/interfaces/jobs-options.js.map +0 -1
  678. package/dist/interfaces/queue-options.d.ts +0 -24
  679. package/dist/interfaces/queue-options.js.map +0 -1
  680. package/dist/interfaces/queue-scheduler-options.d.ts +0 -5
  681. package/dist/interfaces/queue-scheduler-options.js.map +0 -1
  682. package/dist/interfaces/rate-limiter-options.d.ts +0 -4
  683. package/dist/interfaces/rate-limiter-options.js.map +0 -1
  684. package/dist/interfaces/redis-options.d.ts +0 -5
  685. package/dist/interfaces/redis-options.js.map +0 -1
  686. package/dist/interfaces/repeat-options.d.ts +0 -11
  687. package/dist/interfaces/repeat-options.js.map +0 -1
  688. package/dist/interfaces/worker-options.d.ts +0 -11
  689. package/dist/interfaces/worker-options.js.map +0 -1
  690. package/dist/test/test_bulk.js +0 -55
  691. package/dist/test/test_bulk.js.map +0 -1
  692. package/dist/test/test_child-pool.js +0 -81
  693. package/dist/test/test_child-pool.js.map +0 -1
  694. package/dist/test/test_clean.js +0 -124
  695. package/dist/test/test_clean.js.map +0 -1
  696. package/dist/test/test_compat.d.ts +0 -1
  697. package/dist/test/test_compat.js +0 -533
  698. package/dist/test/test_compat.js.map +0 -1
  699. package/dist/test/test_connection.d.ts +0 -1
  700. package/dist/test/test_connection.js +0 -142
  701. package/dist/test/test_connection.js.map +0 -1
  702. package/dist/test/test_delay.d.ts +0 -1
  703. package/dist/test/test_delay.js +0 -188
  704. package/dist/test/test_delay.js.map +0 -1
  705. package/dist/test/test_events.d.ts +0 -1
  706. package/dist/test/test_events.js +0 -148
  707. package/dist/test/test_events.js.map +0 -1
  708. package/dist/test/test_getters.d.ts +0 -1
  709. package/dist/test/test_getters.js +0 -293
  710. package/dist/test/test_getters.js.map +0 -1
  711. package/dist/test/test_job.d.ts +0 -1
  712. package/dist/test/test_job.js +0 -419
  713. package/dist/test/test_job.js.map +0 -1
  714. package/dist/test/test_pause.d.ts +0 -1
  715. package/dist/test/test_pause.js +0 -254
  716. package/dist/test/test_pause.js.map +0 -1
  717. package/dist/test/test_queue.d.ts +0 -0
  718. package/dist/test/test_queue.js +0 -72
  719. package/dist/test/test_queue.js.map +0 -1
  720. package/dist/test/test_rate_limiter.d.ts +0 -1
  721. package/dist/test/test_rate_limiter.js +0 -98
  722. package/dist/test/test_rate_limiter.js.map +0 -1
  723. package/dist/test/test_repeat.d.ts +0 -1
  724. package/dist/test/test_repeat.js +0 -604
  725. package/dist/test/test_repeat.js.map +0 -1
  726. package/dist/test/test_sandboxed_process.d.ts +0 -1
  727. package/dist/test/test_sandboxed_process.js +0 -319
  728. package/dist/test/test_sandboxed_process.js.map +0 -1
  729. package/dist/test/test_stalled_jobs.d.ts +0 -1
  730. package/dist/test/test_stalled_jobs.js +0 -107
  731. package/dist/test/test_stalled_jobs.js.map +0 -1
  732. package/dist/test/test_worker.d.ts +0 -1
  733. package/dist/test/test_worker.js +0 -1182
  734. package/dist/test/test_worker.js.map +0 -1
  735. package/dist/utils.d.ts +0 -8
  736. package/dist/utils.js +0 -31
  737. package/dist/utils.js.map +0 -1
  738. package/release.txt +0 -21
  739. package/src/classes/backoffs.ts +0 -67
  740. package/src/classes/child-pool.ts +0 -119
  741. package/src/classes/compat.ts +0 -889
  742. package/src/classes/index.ts +0 -13
  743. package/src/classes/job.ts +0 -492
  744. package/src/classes/master.ts +0 -113
  745. package/src/classes/queue-base.ts +0 -80
  746. package/src/classes/queue-events.ts +0 -78
  747. package/src/classes/queue-getters.ts +0 -213
  748. package/src/classes/queue-scheduler.ts +0 -127
  749. package/src/classes/queue.ts +0 -194
  750. package/src/classes/redis-connection.ts +0 -127
  751. package/src/classes/repeat.ts +0 -212
  752. package/src/classes/sandbox.ts +0 -60
  753. package/src/classes/scripts.ts +0 -482
  754. package/src/classes/worker.ts +0 -313
  755. package/src/commands/addJob-8.lua +0 -106
  756. package/src/commands/cleanJobsInSet-1.lua +0 -48
  757. package/src/commands/index.ts +0 -62
  758. package/src/commands/isFinished-2.lua +0 -22
  759. package/src/commands/isJobInList-1.lua +0 -20
  760. package/src/commands/moveStalledJobsToWait-8.lua +0 -91
  761. package/src/commands/moveToActive-8.lua +0 -79
  762. package/src/commands/moveToDelayed-5.lua +0 -39
  763. package/src/commands/moveToFinished-7.lua +0 -92
  764. package/src/commands/pause-4.lua +0 -27
  765. package/src/commands/promote-4.lua +0 -49
  766. package/src/commands/releaseLock-1.lua +0 -19
  767. package/src/commands/removeJob-10.lua +0 -37
  768. package/src/commands/reprocessJob-4.lua +0 -36
  769. package/src/commands/retryJob-4.lua +0 -34
  770. package/src/commands/takeLock-1.lua +0 -17
  771. package/src/commands/updateDelaySet-7.lua +0 -71
  772. package/src/commands/updateProgress-2.lua +0 -15
  773. package/src/enums/index.ts +0 -1
  774. package/src/enums/retry-errors.enum.ts +0 -5
  775. package/src/interfaces/advanced-options.ts +0 -28
  776. package/src/interfaces/backoff-options.ts +0 -4
  777. package/src/interfaces/index.ts +0 -9
  778. package/src/interfaces/jobs-options.ts +0 -53
  779. package/src/interfaces/queue-options.ts +0 -30
  780. package/src/interfaces/queue-scheduler-options.ts +0 -6
  781. package/src/interfaces/rate-limiter-options.ts +0 -7
  782. package/src/interfaces/redis-options.ts +0 -7
  783. package/src/interfaces/repeat-options.ts +0 -19
  784. package/src/interfaces/worker-options.ts +0 -13
  785. package/src/test/fixtures/fixture_processor.js +0 -13
  786. package/src/test/fixtures/fixture_processor_bar.js +0 -13
  787. package/src/test/fixtures/fixture_processor_crash.js +0 -16
  788. package/src/test/fixtures/fixture_processor_exit.js +0 -15
  789. package/src/test/fixtures/fixture_processor_fail.js +0 -13
  790. package/src/test/fixtures/fixture_processor_foo.js +0 -13
  791. package/src/test/fixtures/fixture_processor_progress.js +0 -29
  792. package/src/test/fixtures/fixture_processor_slow.js +0 -13
  793. package/src/test/test_bulk.ts +0 -59
  794. package/src/test/test_child-pool.ts +0 -88
  795. package/src/test/test_clean.ts +0 -148
  796. package/src/test/test_compat.ts +0 -640
  797. package/src/test/test_connection.ts +0 -161
  798. package/src/test/test_delay.ts +0 -221
  799. package/src/test/test_events.ts +0 -198
  800. package/src/test/test_getters.ts +0 -348
  801. package/src/test/test_job.ts +0 -524
  802. package/src/test/test_pause.ts +0 -312
  803. package/src/test/test_queue.ts +0 -70
  804. package/src/test/test_rate_limiter.ts +0 -113
  805. package/src/test/test_repeat.ts +0 -787
  806. package/src/test/test_sandboxed_process.ts +0 -380
  807. package/src/test/test_stalled_jobs.ts +0 -146
  808. package/src/test/test_worker.ts +0 -1503
  809. package/src/utils.ts +0 -28
  810. package/tsconfig.json +0 -25
  811. package/tslint.json +0 -23
  812. /package/dist/{classes/master.d.ts → cjs/classes/main-worker.d.ts} +0 -0
  813. /package/dist/{test/test_bulk.d.ts → cjs/classes/main.d.ts} +0 -0
  814. /package/dist/{interfaces → cjs/interfaces}/backoff-options.js +0 -0
  815. /package/dist/{interfaces → cjs/interfaces}/rate-limiter-options.js +0 -0
  816. /package/dist/{interfaces → cjs/interfaces}/redis-options.js +0 -0
  817. /package/dist/{interfaces → cjs/interfaces}/repeat-options.js +0 -0
  818. /package/dist/{interfaces → cjs/interfaces}/worker-options.js +0 -0
  819. /package/dist/{test/test_child-pool.d.ts → esm/classes/main-worker.d.ts} +0 -0
  820. /package/dist/{test/test_clean.d.ts → esm/classes/main.d.ts} +0 -0
@@ -1,313 +0,0 @@
1
- import * as Bluebird from 'bluebird';
2
- import fs from 'fs';
3
- import { Redis } from 'ioredis';
4
- import path from 'path';
5
- import { Processor, WorkerOptions } from '../interfaces';
6
- import { QueueBase, Repeat } from './';
7
- import { ChildPool, pool } from './child-pool';
8
- import { Job } from './job';
9
- import { RedisConnection } from './redis-connection';
10
- import sandbox from './sandbox';
11
- import { Scripts } from './scripts';
12
-
13
- // note: sandboxed processors would also like to define concurrency per process
14
- // for better resource utilization.
15
-
16
- export const clientCommandMessageReg = /ERR unknown command '\s*client\s*'/;
17
-
18
- export class Worker extends QueueBase {
19
- opts: WorkerOptions;
20
-
21
- private drained: boolean;
22
- private waiting = false;
23
- private processFn: Processor;
24
-
25
- private resumeWorker: () => void;
26
- private paused: Promise<void>;
27
- private _repeat: Repeat;
28
- private childPool: ChildPool;
29
-
30
- private blockingConnection: RedisConnection;
31
-
32
- private processing: Set<Promise<Job | void>>; // { [index: number]: Promise<Job | void> } = {};
33
- constructor(
34
- name: string,
35
- processor: string | Processor,
36
- opts: WorkerOptions = {},
37
- ) {
38
- super(name, opts);
39
-
40
- this.opts = {
41
- // settings: {},
42
- drainDelay: 5,
43
- concurrency: 1,
44
- ...this.opts,
45
- };
46
-
47
- this.blockingConnection = new RedisConnection(opts.connection);
48
- this.blockingConnection.on('error', this.emit.bind(this));
49
-
50
- if (typeof processor === 'function') {
51
- this.processFn = processor;
52
- } else {
53
- // SANDBOXED
54
- const supportedFileTypes = ['.js', '.ts', '.flow'];
55
- const processorFile =
56
- processor +
57
- (supportedFileTypes.includes(path.extname(processor)) ? '' : '.js');
58
-
59
- if (!fs.existsSync(processorFile)) {
60
- // TODO are we forced to use sync api here?
61
- throw new Error(`File ${processorFile} does not exist`);
62
- }
63
-
64
- this.childPool = this.childPool || pool;
65
- this.processFn = sandbox(processor, this.childPool).bind(this);
66
- }
67
-
68
- /* tslint:disable: no-floating-promises */
69
- this.run();
70
- }
71
-
72
- get repeat() {
73
- return new Promise<Repeat>(async resolve => {
74
- if (!this._repeat) {
75
- const connection = await this.client;
76
- this._repeat = new Repeat(this.name, {
77
- ...this.opts,
78
- connection,
79
- });
80
- }
81
- resolve(this._repeat);
82
- });
83
- }
84
-
85
- private async run() {
86
- const client = await this.client;
87
-
88
- // IDEA, How to store metadata associated to a worker.
89
- // create a key from the worker ID associated to the given name.
90
- // We keep a hash table bull:myqueue:workers where every worker is a hash key workername:workerId with json holding
91
- // metadata of the worker. The worker key gets expired every 30 seconds or so, we renew the worker metadata.
92
- //
93
- try {
94
- await client.client('setname', this.clientName());
95
- } catch (err) {
96
- if (!clientCommandMessageReg.test(err.message)) {
97
- throw err;
98
- }
99
- }
100
-
101
- const opts: WorkerOptions = <WorkerOptions>this.opts;
102
-
103
- const processing = (this.processing = new Set());
104
-
105
- while (!this.closing) {
106
- if (processing.size < opts.concurrency) {
107
- processing.add(this.getNextJob());
108
- }
109
-
110
- //
111
- // Get the first promise that completes
112
- //
113
- const [completed] = await Promise.race(
114
- [...processing].map(p => p.then(() => [p])),
115
- );
116
-
117
- processing.delete(completed);
118
-
119
- const job = await completed;
120
-
121
- if (job) {
122
- processing.add(this.processJob(job));
123
- }
124
- }
125
- return Promise.all(processing);
126
- }
127
-
128
- /**
129
- Returns a promise that resolves to the next job in queue.
130
- */
131
- async getNextJob() {
132
- if (this.paused) {
133
- await this.paused;
134
- }
135
-
136
- if (this.closing) {
137
- return;
138
- }
139
-
140
- if (this.drained) {
141
- try {
142
- const jobId = await this.waitForJob();
143
-
144
- if (jobId) {
145
- return this.moveToActive(jobId);
146
- }
147
- } catch (err) {
148
- // Swallow error
149
- if (err.message !== 'Connection is closed.') {
150
- console.error('BRPOPLPUSH', err);
151
- }
152
- }
153
- } else {
154
- return this.moveToActive();
155
- }
156
- }
157
-
158
- private async moveToActive(jobId?: string) {
159
- const [jobData, id] = await Scripts.moveToActive(this, jobId);
160
- return this.nextJobFromJobData(jobData, id);
161
- }
162
-
163
- private async waitForJob() {
164
- const client = await this.blockingConnection.client;
165
-
166
- let jobId;
167
- const opts: WorkerOptions = <WorkerOptions>this.opts;
168
-
169
- try {
170
- this.waiting = true;
171
- jobId = await client.brpoplpush(
172
- this.keys.wait,
173
- this.keys.active,
174
- opts.drainDelay,
175
- );
176
- } finally {
177
- this.waiting = false;
178
- }
179
- return jobId;
180
- }
181
-
182
- private async nextJobFromJobData(jobData: any, jobId: string) {
183
- if (jobData) {
184
- this.drained = false;
185
- const job = Job.fromJSON(this, jobData, jobId);
186
- if (job.opts.repeat) {
187
- const repeat = await this.repeat;
188
- await repeat.addNextRepeatableJob(job.name, job.data, job.opts);
189
- }
190
- return job;
191
- } else if (!this.drained) {
192
- this.emit('drained');
193
- this.drained = true;
194
- }
195
- }
196
-
197
- async processJob(job: Job) {
198
- if (!job || this.closing || this.paused) {
199
- return;
200
- }
201
- const handleCompleted = async (result: any) => {
202
- const jobData = await job.moveToCompleted(
203
- result,
204
- !(this.closing || this.paused),
205
- );
206
- this.emit('completed', job, result, 'active');
207
- return jobData ? this.nextJobFromJobData(jobData[0], jobData[1]) : null;
208
- };
209
-
210
- const handleFailed = async (err: Error) => {
211
- let error = err;
212
- if (
213
- error instanceof Bluebird.OperationalError &&
214
- (<any>error).cause instanceof Error
215
- ) {
216
- error = (<any>error).cause; // Handle explicit rejection
217
- }
218
-
219
- await job.moveToFailed(err);
220
- this.emit('failed', job, error, 'active');
221
- };
222
-
223
- // TODO: how to cancel the processing? (null -> job.cancel() => throw CancelError()void)
224
- this.emit('active', job, null, 'waiting');
225
-
226
- try {
227
- const result = await this.processFn(job);
228
- const nextJob = await handleCompleted(result);
229
- return nextJob;
230
- } catch (err) {
231
- return handleFailed(err);
232
- }
233
-
234
- /*
235
- var timeoutMs = job.opts.timeout;
236
-
237
- if (timeoutMs) {
238
- jobPromise = jobPromise.timeout(timeoutMs);
239
- }
240
- */
241
- // Local event with jobPromise so that we can cancel job.
242
- // this.emit('active', job, jobPromise, 'waiting');
243
-
244
- // return jobPromise.then(handleCompleted).catch(handleFailed);
245
- }
246
-
247
- /**
248
- Pauses the processing of this queue only for this worker.
249
- */
250
- async pause(doNotWaitActive?: boolean) {
251
- if (!this.paused) {
252
- this.paused = new Promise(resolve => {
253
- this.resumeWorker = function() {
254
- resolve();
255
- this.paused = null; // Allow pause to be checked externally for paused state.
256
- this.resumeWorker = null;
257
- };
258
- });
259
- await (!doNotWaitActive && this.whenCurrentJobsFinished());
260
- this.emit('paused');
261
- }
262
- }
263
-
264
- resume() {
265
- if (this.resumeWorker) {
266
- this.resumeWorker();
267
- this.emit('resumed');
268
- }
269
- }
270
-
271
- isPaused() {
272
- return !!this.paused;
273
- }
274
-
275
- /**
276
- * Returns a promise that resolves when active jobs are cleared
277
- *
278
- * @returns {Promise}
279
- */
280
- private async whenCurrentJobsFinished(reconnect = true) {
281
- //
282
- // Force reconnection of blocking connection to abort blocking redis call immediately.
283
- //
284
- this.waiting && (await this.blockingConnection.disconnect());
285
-
286
- // If we are disconnected, how are we going to update the completed/failed sets?
287
- if (this.processing) {
288
- await Promise.all(this.processing);
289
- }
290
-
291
- this.waiting && reconnect && (await this.blockingConnection.reconnect());
292
- }
293
-
294
- async close(force = false) {
295
- const client = await this.blockingConnection.client;
296
-
297
- this.emit('closing', 'closing queue');
298
- await super.close();
299
-
300
- try {
301
- await this.resume();
302
- if (!force) {
303
- await this.whenCurrentJobsFinished(false);
304
- } else {
305
- await client.disconnect();
306
- }
307
- await this.disconnect();
308
- } finally {
309
- this.childPool && this.childPool.clean();
310
- }
311
- this.emit('closed');
312
- }
313
- }
@@ -1,106 +0,0 @@
1
- --[[
2
- Adds a job to the queue by doing the following:
3
- - Increases the job counter if needed.
4
- - Creates a new job key with the job data.
5
-
6
- - if delayed:
7
- - computes timestamp.
8
- - adds to delayed zset.
9
- - Emits a global event 'delayed' if the job is delayed.
10
- - if not delayed
11
- - Adds the jobId to the wait/paused list in one of three ways:
12
- - LIFO
13
- - FIFO
14
- - prioritized.
15
- - Adds the job to the "added" list so that workers gets notified.
16
-
17
- Input:
18
- KEYS[1] 'wait',
19
- KEYS[2] 'paused'
20
- KEYS[3] 'meta'
21
- KEYS[4] 'id'
22
- KEYS[5] 'delayed'
23
- KEYS[6] 'priority'
24
- KEYS[7] events stream key
25
- KEYS[8] delay stream key
26
-
27
- ARGV[1] key prefix,
28
- ARGV[2] custom id (will not generate one automatically)
29
- ARGV[3] name
30
- ARGV[4] data (json stringified job data)
31
- ARGV[5] opts (json stringified job opts)
32
- ARGV[6] timestamp
33
- ARGV[7] delay
34
- ARGV[8] delayedTimestamp
35
- ARGV[9] priority
36
- ARGV[10] LIFO
37
- ]]
38
- local jobId
39
- local jobIdKey
40
- local rcall = redis.call
41
-
42
- local jobCounter = rcall("INCR", KEYS[4])
43
-
44
- if ARGV[2] == "" then
45
- jobId = jobCounter
46
- jobIdKey = ARGV[1] .. jobId
47
- else
48
- jobId = ARGV[2]
49
- jobIdKey = ARGV[1] .. jobId
50
- if rcall("EXISTS", jobIdKey) == 1 then
51
- return jobId .. "" -- convert to string
52
- end
53
- end
54
-
55
- -- Store the job.
56
- rcall("HMSET", jobIdKey, "name", ARGV[3], "data", ARGV[4], "opts", ARGV[5],
57
- "timestamp", ARGV[6], "delay", ARGV[7], "priority", ARGV[9])
58
-
59
- -- Check if job is delayed
60
- local delayedTimestamp = tonumber(ARGV[8])
61
- if (delayedTimestamp ~= 0) then
62
- local timestamp = delayedTimestamp * 0x1000 + bit.band(jobCounter, 0xfff)
63
- rcall("ZADD", KEYS[5], timestamp, jobId)
64
- rcall("XADD", KEYS[7], "*", "event", "delayed", "jobId", jobId, "delay",
65
- delayedTimestamp)
66
- rcall("XADD", KEYS[8], "*", "nextTimestamp", delayedTimestamp)
67
- else
68
- local target
69
-
70
- -- Whe check for the meta.paused key to decide if we are paused or not
71
- -- (since an empty list and !EXISTS are not really the same)
72
- local paused
73
- if rcall("HEXISTS", KEYS[3], "paused") ~= 1 then
74
- target = KEYS[1]
75
- paused = false
76
- else
77
- target = KEYS[2]
78
- paused = true
79
- end
80
-
81
- -- Standard or priority add
82
- local priority = tonumber(ARGV[9])
83
- if priority == 0 then
84
- -- LIFO or FIFO
85
- rcall(ARGV[10], target, jobId)
86
- else
87
- -- Priority add
88
- rcall("ZADD", KEYS[6], priority, jobId)
89
- local count = rcall("ZCOUNT", KEYS[6], 0, priority)
90
-
91
- local len = rcall("LLEN", target)
92
- local id = rcall("LINDEX", target, len - (count - 1))
93
- if id then
94
- rcall("LINSERT", target, "BEFORE", id, jobId)
95
- else
96
- rcall("RPUSH", target, jobId)
97
- end
98
- end
99
- -- Emit waiting event
100
- rcall("XADD", KEYS[7], "*", "event", "waiting", "jobId", jobId)
101
- end
102
-
103
- local maxEvents = rcall("HGET", KEYS[3], "opts.maxLenEvents")
104
- if (maxEvents) then rcall("XTRIM", KEYS[7], "MAXLEN", "~", maxEvents) end
105
-
106
- return jobId .. "" -- convert to string
@@ -1,48 +0,0 @@
1
- --[[
2
- Remove jobs from the specific set.
3
-
4
- Input:
5
- KEYS[1] set key,
6
-
7
- ARGV[1] jobId
8
- ARGV[2] timestamp
9
- ARGV[3] limit the number of jobs to be removed. 0 is unlimited
10
- ARGV[4] set name, can be any of 'wait', 'active', 'paused', 'delayed', 'completed', or 'failed'
11
-
12
- TODO: emit a "cleaned" global event.
13
- ]]
14
- local command = "ZRANGE"
15
- local isList = false
16
-
17
- if ARGV[4] == "wait" or ARGV[4] == "active" or ARGV[4] == "paused" then
18
- command = "LRANGE"
19
- isList = true
20
- end
21
-
22
- local jobs = redis.call(command, KEYS[1], 0, -1)
23
- local deleted = {}
24
- local deletedCount = 0
25
- local limit = tonumber(ARGV[3])
26
- local jobTS
27
- for _, job in ipairs(jobs) do
28
- if limit > 0 and deletedCount >= limit then
29
- break
30
- end
31
-
32
- local jobKey = ARGV[1] .. job
33
- if (redis.call("EXISTS", jobKey .. ":lock") == 0) then
34
- jobTS = redis.call("HGET", jobKey, "timestamp")
35
- if (not jobTS or jobTS < ARGV[2]) then
36
- if isList then
37
- redis.call("LREM", KEYS[1], 0, job)
38
- else
39
- redis.call("ZREM", KEYS[1], job)
40
- end
41
- redis.call("DEL", jobKey)
42
- deletedCount = deletedCount + 1
43
- table.insert(deleted, job)
44
- end
45
- end
46
- end
47
-
48
- return deleted
@@ -1,62 +0,0 @@
1
- /**
2
- * Load redis lua scripts.
3
- * The name of the script must have the following format:
4
- *
5
- * cmdName-numKeys.lua
6
- *
7
- * cmdName must be in camel case format.
8
- *
9
- * For example:
10
- * moveToFinish-3.lua
11
- *
12
- */
13
- 'use strict';
14
-
15
- import IORedis from 'ioredis';
16
-
17
- const path = require('path');
18
- const util = require('util');
19
-
20
- const fs = require('fs');
21
-
22
- const readdir = util.promisify(fs.readdir);
23
- const readFile = util.promisify(fs.readFile);
24
-
25
- interface Command {
26
- name: string;
27
- options: {
28
- numberOfKeys: number;
29
- lua: string;
30
- };
31
- }
32
-
33
- export const load = async function(client: IORedis.Redis) {
34
- const scripts = await loadScripts(__dirname);
35
-
36
- scripts.forEach((command: Command) => {
37
- client.defineCommand(command.name, command.options);
38
- });
39
- };
40
-
41
- async function loadScripts(dir: string): Promise<Command[]> {
42
- const files = await readdir(dir);
43
-
44
- const commands = await Promise.all<Command>(
45
- files
46
- .filter((file: string) => path.extname(file) === '.lua')
47
- .map(async (file: string) => {
48
- const longName = path.basename(file, '.lua');
49
- const name = longName.split('-')[0];
50
- const numberOfKeys = parseInt(longName.split('-')[1]);
51
-
52
- const lua = await readFile(path.join(dir, file));
53
-
54
- return {
55
- name,
56
- options: { numberOfKeys, lua: lua.toString() },
57
- };
58
- }),
59
- );
60
-
61
- return commands;
62
- }
@@ -1,22 +0,0 @@
1
- --[[
2
- Checks if a job is finished (.i.e. is in the completed or failed set)
3
-
4
- Input:
5
- KEYS[1] completed key
6
- KEYS[2] failed key
7
-
8
- ARGV[1] job id
9
- Output:
10
- 0 - not finished.
11
- 1 - completed.
12
- 2 - failed.
13
- ]]
14
- if redis.call("ZSCORE", KEYS[1], ARGV[1]) ~= false then
15
- return 1
16
- end
17
-
18
- if redis.call("ZSCORE", KEYS[2], ARGV[1]) ~= false then
19
- return 2
20
- end
21
-
22
- return 0
@@ -1,20 +0,0 @@
1
- --[[
2
- Checks if job is in a given list.
3
-
4
- Input:
5
- KEYS[1]
6
- ARGV[1]
7
-
8
- Output:
9
- 1 if element found in the list.
10
- ]]
11
- local function item_in_list (list, item)
12
- for _, v in pairs(list) do
13
- if v == item then
14
- return 1
15
- end
16
- end
17
- return nil
18
- end
19
- local items = redis.call("LRANGE", KEYS[1] , 0, -1)
20
- return item_in_list(items, ARGV[1])
@@ -1,91 +0,0 @@
1
- --[[
2
- Move stalled jobs to wait.
3
-
4
- Input:
5
- KEYS[1] 'stalled' (SET)
6
- KEYS[2] 'wait', (LIST)
7
- KEYS[3] 'active', (LIST)
8
- KEYS[4] 'failed', (ZSET)
9
- KEYS[5] 'stalled-check', (KEY)
10
-
11
- KEYS[6] 'meta', (KEY)
12
- KEYS[7] 'paused', (LIST)
13
-
14
- KEYS[8] 'event stream' (STREAM)
15
-
16
- ARGV[1] Max stalled job count
17
- ARGV[2] queue.toKey('')
18
- ARGV[3] timestamp
19
- ARGV[4] max check time
20
-
21
- Events:
22
- 'stalled' with stalled job id.
23
- ]] local rcall = redis.call
24
-
25
- -- Check if we need to check for stalled jobs now.
26
- if rcall("EXISTS", KEYS[5]) == 1 then return {{}, {}} end
27
-
28
- rcall("SET", KEYS[5], ARGV[3], "PX", ARGV[4])
29
-
30
- -- Move all stalled jobs to wait
31
- local stalling = rcall('SMEMBERS', KEYS[1])
32
- local stalled = {}
33
- local failed = {}
34
- if (#stalling > 0) then
35
-
36
- local dst
37
- -- wait or paused destination
38
- if rcall("HEXISTS", KEYS[6], "paused") ~= 1 then
39
- dst = KEYS[2]
40
- else
41
- dst = KEYS[7]
42
- end
43
-
44
- rcall('DEL', KEYS[1])
45
-
46
- local MAX_STALLED_JOB_COUNT = tonumber(ARGV[1])
47
-
48
- -- Remove from active list
49
- for i, jobId in ipairs(stalling) do
50
- local jobKey = ARGV[2] .. jobId
51
-
52
- -- Check that the lock is also missing, then we can handle this job as really stalled.
53
- if (rcall("EXISTS", jobKey .. ":lock") == 0) then
54
- -- Remove from the active queue.
55
- local removed = rcall("LREM", KEYS[3], 1, jobId)
56
-
57
- if (removed > 0) then
58
- -- If this job has been stalled too many times, such as if it crashes the worker, then fail it.
59
- local stalledCount = rcall("HINCRBY", jobKey, "stalledCounter",
60
- 1)
61
- if (stalledCount > MAX_STALLED_JOB_COUNT) then
62
- rcall("ZADD", KEYS[4], ARGV[3], jobId)
63
- rcall("HSET", jobKey, "failedReason",
64
- "job stalled more than allowable limit")
65
- rcall("XADD", KEYS[8], "*", "event", "failed", "jobId",
66
- jobId, 'prev', 'active')
67
- table.insert(failed, jobId)
68
- else
69
- -- Move the job back to the wait queue, to immediately be picked up by a waiting worker.
70
- rcall("RPUSH", dst, jobId)
71
- rcall("XADD", KEYS[8], "*", "event", "waiting", "jobId",
72
- jobId, 'prev', 'active')
73
-
74
- -- Emit the stalled event
75
- rcall("XADD", KEYS[8], "*", "event", "stalled", "jobId",
76
- jobId)
77
- table.insert(stalled, jobId)
78
- end
79
- end
80
- end
81
- end
82
- end
83
-
84
- -- Mark potentially stalled jobs
85
- local active = rcall('LRANGE', KEYS[3], 0, -1)
86
- if (#active > 0) then rcall('SADD', KEYS[1], unpack(active)) end
87
-
88
- local maxEvents = rcall("HGET", KEYS[6], "opts.maxLenEvents")
89
- if maxEvents then rcall("XTRIM", KEYS[8], "MAXLEN", "~", maxEvents) end
90
-
91
- return {failed, stalled}