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