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
@@ -1,78 +0,0 @@
|
|
1
|
-
import { delay } from 'bluebird';
|
2
|
-
import { QueueEventsOptions } from '../interfaces';
|
3
|
-
import { array2obj } from '../utils';
|
4
|
-
import { QueueBase } from './queue-base';
|
5
|
-
|
6
|
-
export class QueueEvents extends QueueBase {
|
7
|
-
consuming: Promise<void>;
|
8
|
-
|
9
|
-
constructor(name: string, opts?: QueueEventsOptions) {
|
10
|
-
super(name, opts);
|
11
|
-
|
12
|
-
this.opts = Object.assign(
|
13
|
-
{
|
14
|
-
blockingTimeout: 10000,
|
15
|
-
},
|
16
|
-
this.opts,
|
17
|
-
);
|
18
|
-
|
19
|
-
// tslint:disable: no-floating-promises
|
20
|
-
this.consumeEvents().catch(err => this.emit('error'));
|
21
|
-
}
|
22
|
-
|
23
|
-
private async consumeEvents() {
|
24
|
-
await this.waitUntilReady();
|
25
|
-
|
26
|
-
const opts: QueueEventsOptions = this.opts;
|
27
|
-
|
28
|
-
const key = this.keys.events;
|
29
|
-
let id = opts.lastEventId || '0-0';
|
30
|
-
|
31
|
-
while (!this.closing) {
|
32
|
-
try {
|
33
|
-
const data = await this.client.xread(
|
34
|
-
'BLOCK',
|
35
|
-
opts.blockingTimeout,
|
36
|
-
'STREAMS',
|
37
|
-
key,
|
38
|
-
id,
|
39
|
-
);
|
40
|
-
|
41
|
-
if (data) {
|
42
|
-
const stream = data[0];
|
43
|
-
const events = stream[1];
|
44
|
-
|
45
|
-
for (let i = 0; i < events.length; i++) {
|
46
|
-
id = events[i][0];
|
47
|
-
const args = array2obj(events[i][1]);
|
48
|
-
|
49
|
-
//
|
50
|
-
// TODO: we may need to have a separate xtream for progress data
|
51
|
-
// to avoid this hack.
|
52
|
-
switch (args.event) {
|
53
|
-
case 'progress':
|
54
|
-
args.data = JSON.parse(args.data);
|
55
|
-
break;
|
56
|
-
case 'completed':
|
57
|
-
args.returnvalue = JSON.parse(args.returnvalue);
|
58
|
-
break;
|
59
|
-
}
|
60
|
-
|
61
|
-
this.emit(args.event, args, id);
|
62
|
-
this.emit(`${args.event}:${args.jobId}`, args, id);
|
63
|
-
}
|
64
|
-
}
|
65
|
-
} catch (err) {
|
66
|
-
if (err.message !== 'Connection is closed.') {
|
67
|
-
throw err;
|
68
|
-
}
|
69
|
-
await delay(5000);
|
70
|
-
}
|
71
|
-
}
|
72
|
-
}
|
73
|
-
|
74
|
-
async close() {
|
75
|
-
await super.close();
|
76
|
-
return this.disconnect();
|
77
|
-
}
|
78
|
-
}
|
@@ -1,213 +0,0 @@
|
|
1
|
-
/*eslint-env node */
|
2
|
-
'use strict';
|
3
|
-
|
4
|
-
import { QueueBase } from './queue-base';
|
5
|
-
import { Job } from './job';
|
6
|
-
import { clientCommandMessageReg } from './worker';
|
7
|
-
|
8
|
-
export class QueueGetters extends QueueBase {
|
9
|
-
getJob(jobId: string) {
|
10
|
-
return Job.fromId(this, jobId);
|
11
|
-
}
|
12
|
-
|
13
|
-
private commandByType(
|
14
|
-
types: string[],
|
15
|
-
count: boolean,
|
16
|
-
callback: (key: string, dataType: string) => void,
|
17
|
-
) {
|
18
|
-
return types.map((type: string) => {
|
19
|
-
type = type === 'waiting' ? 'wait' : type; // alias
|
20
|
-
|
21
|
-
const key = this.toKey(type);
|
22
|
-
|
23
|
-
switch (type) {
|
24
|
-
case 'completed':
|
25
|
-
case 'failed':
|
26
|
-
case 'delayed':
|
27
|
-
case 'repeat':
|
28
|
-
return callback(key, count ? 'zcard' : 'zrange');
|
29
|
-
case 'active':
|
30
|
-
case 'wait':
|
31
|
-
case 'paused':
|
32
|
-
return callback(key, count ? 'llen' : 'lrange');
|
33
|
-
}
|
34
|
-
});
|
35
|
-
}
|
36
|
-
|
37
|
-
/**
|
38
|
-
Returns the number of jobs waiting to be processed.
|
39
|
-
*/
|
40
|
-
count() {
|
41
|
-
return this.getJobCountByTypes('waiting', 'paused', 'delayed');
|
42
|
-
}
|
43
|
-
|
44
|
-
// Job counts by type
|
45
|
-
// Queue#getJobCountByTypes('completed') => completed count
|
46
|
-
// Queue#getJobCountByTypes('completed,failed') => completed + failed count
|
47
|
-
// Queue#getJobCountByTypes('completed', 'failed') => completed + failed count
|
48
|
-
// Queue#getJobCountByTypes('completed', 'waiting', 'failed') => completed + waiting + failed count
|
49
|
-
async getJobCountByTypes(...types: string[]) {
|
50
|
-
const result = await this.getJobCounts(...types);
|
51
|
-
return Object.values(result).reduce((sum, count) => sum + count);
|
52
|
-
}
|
53
|
-
|
54
|
-
/**
|
55
|
-
* Returns the job counts for each type specified or every list/set in the queue by default.
|
56
|
-
*
|
57
|
-
*/
|
58
|
-
async getJobCounts(...types: string[]) {
|
59
|
-
await this.waitUntilReady();
|
60
|
-
|
61
|
-
const multi = this.client.multi();
|
62
|
-
|
63
|
-
this.commandByType(types, true, function(key, command) {
|
64
|
-
(<any>multi)[command](key);
|
65
|
-
});
|
66
|
-
|
67
|
-
const res = await multi.exec();
|
68
|
-
const counts: { [index: string]: number } = {};
|
69
|
-
res.forEach((res: number[], index: number) => {
|
70
|
-
counts[types[index]] = res[1] || 0;
|
71
|
-
});
|
72
|
-
return counts;
|
73
|
-
}
|
74
|
-
|
75
|
-
getCompletedCount() {
|
76
|
-
return this.getJobCountByTypes('completed');
|
77
|
-
}
|
78
|
-
|
79
|
-
getFailedCount() {
|
80
|
-
return this.getJobCountByTypes('failed');
|
81
|
-
}
|
82
|
-
|
83
|
-
getDelayedCount() {
|
84
|
-
return this.getJobCountByTypes('delayed');
|
85
|
-
}
|
86
|
-
|
87
|
-
getActiveCount() {
|
88
|
-
return this.getJobCountByTypes('active');
|
89
|
-
}
|
90
|
-
|
91
|
-
getWaitingCount() {
|
92
|
-
return this.getJobCountByTypes('waiting', 'paused');
|
93
|
-
}
|
94
|
-
|
95
|
-
getWaiting(start = 0, end = 1) {
|
96
|
-
return this.getJobs(['waiting'], start, end, true);
|
97
|
-
}
|
98
|
-
|
99
|
-
getActive(start = 0, end = 1) {
|
100
|
-
return this.getJobs(['active'], start, end, true);
|
101
|
-
}
|
102
|
-
|
103
|
-
getDelayed(start = 0, end = 1) {
|
104
|
-
return this.getJobs(['delayed'], start, end, true);
|
105
|
-
}
|
106
|
-
|
107
|
-
getCompleted(start = 0, end = 1) {
|
108
|
-
return this.getJobs(['completed'], start, end, false);
|
109
|
-
}
|
110
|
-
|
111
|
-
getFailed(start = 0, end = 1) {
|
112
|
-
return this.getJobs(['failed'], start, end, false);
|
113
|
-
}
|
114
|
-
|
115
|
-
async getRanges(types: string[], start = 0, end = 1, asc = false) {
|
116
|
-
const multi = this.client.multi();
|
117
|
-
const multiCommands: string[] = [];
|
118
|
-
|
119
|
-
this.commandByType(types, false, (key, command) => {
|
120
|
-
switch (command) {
|
121
|
-
case 'lrange':
|
122
|
-
if (asc) {
|
123
|
-
multiCommands.push('lrange');
|
124
|
-
multi.lrange(key, -(end + 1), -(start + 1));
|
125
|
-
} else {
|
126
|
-
multi.lrange(key, start, end);
|
127
|
-
}
|
128
|
-
break;
|
129
|
-
case 'zrange':
|
130
|
-
multiCommands.push('zrange');
|
131
|
-
if (asc) {
|
132
|
-
multi.zrange(key, start, end);
|
133
|
-
} else {
|
134
|
-
multi.zrevrange(key, start, end);
|
135
|
-
}
|
136
|
-
break;
|
137
|
-
}
|
138
|
-
});
|
139
|
-
|
140
|
-
const responses = await multi.exec();
|
141
|
-
let results: any[] = [];
|
142
|
-
|
143
|
-
responses.forEach((response: any[], index: number) => {
|
144
|
-
const result = response[1] || [];
|
145
|
-
|
146
|
-
if (asc && multiCommands[index] === 'lrange') {
|
147
|
-
results = results.concat(result.reverse());
|
148
|
-
} else {
|
149
|
-
results = results.concat(result);
|
150
|
-
}
|
151
|
-
});
|
152
|
-
return results;
|
153
|
-
}
|
154
|
-
|
155
|
-
async getJobs(types: string[] | string, start = 0, end = -1, asc = false) {
|
156
|
-
await this.waitUntilReady();
|
157
|
-
types = Array.isArray(types) ? types : [types];
|
158
|
-
|
159
|
-
if (types.indexOf('waiting') !== -1) {
|
160
|
-
types = types.concat(['paused']);
|
161
|
-
}
|
162
|
-
const jobIds = await this.getRanges(types, start, end, asc);
|
163
|
-
|
164
|
-
return Promise.all(jobIds.map(jobId => Job.fromId(this, jobId)));
|
165
|
-
}
|
166
|
-
|
167
|
-
async getJobLogs(jobId: string, start = 0, end = -1) {
|
168
|
-
const multi = this.client.multi();
|
169
|
-
|
170
|
-
const logsKey = this.toKey(jobId + ':logs');
|
171
|
-
multi.lrange(logsKey, -(end + 1), -(start + 1));
|
172
|
-
multi.llen(logsKey);
|
173
|
-
return multi.exec().then(result => ({
|
174
|
-
logs: result[0][1],
|
175
|
-
count: result[1][1],
|
176
|
-
}));
|
177
|
-
}
|
178
|
-
|
179
|
-
async getWorkers() {
|
180
|
-
await this.waitUntilReady();
|
181
|
-
const clients = await this.client.client('list');
|
182
|
-
try {
|
183
|
-
const list = await this.parseClientList(clients);
|
184
|
-
return list;
|
185
|
-
} catch (err) {
|
186
|
-
if (!clientCommandMessageReg.test(err.message)) {
|
187
|
-
throw err;
|
188
|
-
}
|
189
|
-
}
|
190
|
-
}
|
191
|
-
|
192
|
-
private parseClientList(list: string) {
|
193
|
-
const lines = list.split('\n');
|
194
|
-
const clients: { [index: string]: string }[] = [];
|
195
|
-
|
196
|
-
lines.forEach((line: string) => {
|
197
|
-
const client: { [index: string]: string } = {};
|
198
|
-
const keyValues = line.split(' ');
|
199
|
-
keyValues.forEach(function(keyValue) {
|
200
|
-
const index = keyValue.indexOf('=');
|
201
|
-
const key = keyValue.substring(0, index);
|
202
|
-
const value = keyValue.substring(index + 1);
|
203
|
-
client[key] = value;
|
204
|
-
});
|
205
|
-
const name = client['name'];
|
206
|
-
if (name && name.startsWith(this.clientName())) {
|
207
|
-
client['name'] = this.name;
|
208
|
-
clients.push(client);
|
209
|
-
}
|
210
|
-
});
|
211
|
-
return clients;
|
212
|
-
}
|
213
|
-
}
|
@@ -1,125 +0,0 @@
|
|
1
|
-
import { QueueSchedulerOptions } from '../interfaces';
|
2
|
-
import { array2obj } from '../utils';
|
3
|
-
import { QueueBase } from './';
|
4
|
-
import { Scripts } from './scripts';
|
5
|
-
|
6
|
-
const MAX_TIMEOUT_MS = Math.pow(2, 31) - 1; // 32 bit signed
|
7
|
-
|
8
|
-
/**
|
9
|
-
* This class is just used for some automatic bookkeeping of the queue,
|
10
|
-
* such as updating the delay set as well as moving stalled jobs back
|
11
|
-
* to the waiting list.
|
12
|
-
*
|
13
|
-
* Jobs are checked for stallness once every "visibility window" seconds.
|
14
|
-
* Jobs are then marked as candidates for being stalled, in the next check,
|
15
|
-
* the candidates are marked as stalled and moved to wait.
|
16
|
-
* Workers need to clean the candidate list with the jobs that they are working
|
17
|
-
* on, failing to update the list results in the job ending being stalled.
|
18
|
-
*
|
19
|
-
* This class requires a dedicated redis connection, and at least one is needed
|
20
|
-
* to be running at a given time, otherwise delays, stalled jobs, retries, repeatable
|
21
|
-
* jobs, etc, will not work correctly or at all.
|
22
|
-
*
|
23
|
-
*/
|
24
|
-
export class QueueScheduler extends QueueBase {
|
25
|
-
private nextTimestamp = Number.MAX_VALUE;
|
26
|
-
|
27
|
-
constructor(protected name: string, opts: QueueSchedulerOptions = {}) {
|
28
|
-
super(name, { maxStalledCount: 1, stalledInterval: 30000, ...opts });
|
29
|
-
|
30
|
-
// tslint:disable: no-floating-promises
|
31
|
-
this.run();
|
32
|
-
}
|
33
|
-
|
34
|
-
private async run() {
|
35
|
-
await this.waitUntilReady();
|
36
|
-
|
37
|
-
const key = this.keys.delay;
|
38
|
-
const opts = this.opts as QueueSchedulerOptions;
|
39
|
-
const delaySet = await Scripts.updateDelaySet(this, Date.now());
|
40
|
-
|
41
|
-
const [nextTimestamp] = delaySet;
|
42
|
-
let streamLastId = delaySet[1] || '0-0';
|
43
|
-
|
44
|
-
if (nextTimestamp) {
|
45
|
-
this.nextTimestamp = nextTimestamp;
|
46
|
-
}
|
47
|
-
|
48
|
-
while (!this.closing) {
|
49
|
-
// Check if at least the min stalled check time has passed.
|
50
|
-
await this.moveStalledJobsToWait();
|
51
|
-
|
52
|
-
// Listen to the delay event stream from lastDelayStreamTimestamp
|
53
|
-
// Can we use XGROUPS to reduce redundancy?
|
54
|
-
const nextDelay = this.nextTimestamp - Date.now();
|
55
|
-
const blockTime = Math.round(
|
56
|
-
Math.min(opts.stalledInterval, Math.max(nextDelay, 0)),
|
57
|
-
);
|
58
|
-
|
59
|
-
let data;
|
60
|
-
if (blockTime) {
|
61
|
-
data = await this.client.xread(
|
62
|
-
'BLOCK',
|
63
|
-
blockTime,
|
64
|
-
'STREAMS',
|
65
|
-
key,
|
66
|
-
streamLastId,
|
67
|
-
);
|
68
|
-
} else {
|
69
|
-
data = await this.client.xread('STREAMS', key, streamLastId);
|
70
|
-
}
|
71
|
-
|
72
|
-
if (data && data[0]) {
|
73
|
-
const stream = data[0];
|
74
|
-
const events = stream[1];
|
75
|
-
|
76
|
-
for (let i = 0; i < events.length; i++) {
|
77
|
-
streamLastId = events[i][0];
|
78
|
-
const args = array2obj(events[i][1]);
|
79
|
-
const nextTimestamp: number = parseInt(args.nextTimestamp);
|
80
|
-
|
81
|
-
if (nextTimestamp < this.nextTimestamp) {
|
82
|
-
this.nextTimestamp = nextTimestamp;
|
83
|
-
}
|
84
|
-
}
|
85
|
-
|
86
|
-
//
|
87
|
-
// We trim to a length of 100, which should be a very safe value
|
88
|
-
// for all kind of scenarios.
|
89
|
-
//
|
90
|
-
this.client.xtrim(key, 'MAXLEN', '~', 100);
|
91
|
-
}
|
92
|
-
|
93
|
-
const now = Date.now();
|
94
|
-
const delay = this.nextTimestamp - now;
|
95
|
-
|
96
|
-
if (delay <= 0) {
|
97
|
-
const [nextTimestamp, id] = await Scripts.updateDelaySet(this, now);
|
98
|
-
if (nextTimestamp) {
|
99
|
-
this.nextTimestamp = nextTimestamp / 4096;
|
100
|
-
streamLastId = id;
|
101
|
-
} else {
|
102
|
-
this.nextTimestamp = Number.MAX_VALUE;
|
103
|
-
}
|
104
|
-
}
|
105
|
-
}
|
106
|
-
}
|
107
|
-
|
108
|
-
private async moveStalledJobsToWait() {
|
109
|
-
if (this.closing) {
|
110
|
-
return;
|
111
|
-
}
|
112
|
-
|
113
|
-
const [failed, stalled] = await Scripts.moveStalledJobsToWait(this);
|
114
|
-
|
115
|
-
failed.forEach((jobId: string) =>
|
116
|
-
this.emit(
|
117
|
-
'failed',
|
118
|
-
jobId,
|
119
|
-
new Error('job stalled more than allowable limit'),
|
120
|
-
'active',
|
121
|
-
),
|
122
|
-
);
|
123
|
-
stalled.forEach((jobId: string) => this.emit('stalled', jobId, 'active'));
|
124
|
-
}
|
125
|
-
}
|
package/src/classes/queue.ts
DELETED
@@ -1,180 +0,0 @@
|
|
1
|
-
import { get } from 'lodash';
|
2
|
-
import { v4 } from 'node-uuid';
|
3
|
-
import {
|
4
|
-
JobsOptions,
|
5
|
-
QueueOptions,
|
6
|
-
RateLimiterOptions,
|
7
|
-
RepeatOptions,
|
8
|
-
} from '../interfaces';
|
9
|
-
import { Job, QueueGetters, Repeat } from './';
|
10
|
-
import { Scripts } from './scripts';
|
11
|
-
|
12
|
-
export class Queue extends QueueGetters {
|
13
|
-
token = v4();
|
14
|
-
limiter: RateLimiterOptions = null;
|
15
|
-
repeat: Repeat;
|
16
|
-
jobsOpts: JobsOptions;
|
17
|
-
|
18
|
-
constructor(name: string, opts?: QueueOptions) {
|
19
|
-
super(name, opts);
|
20
|
-
|
21
|
-
this.repeat = new Repeat(name, {
|
22
|
-
...opts,
|
23
|
-
connection: this.client,
|
24
|
-
});
|
25
|
-
|
26
|
-
this.jobsOpts = get(opts, 'defaultJobOptions');
|
27
|
-
|
28
|
-
// tslint:disable: no-floating-promises
|
29
|
-
this.waitUntilReady().then(() => {
|
30
|
-
this.client.hset(
|
31
|
-
this.keys.meta,
|
32
|
-
'opts.maxLenEvents',
|
33
|
-
get(opts, 'streams.events.maxLen', 10000),
|
34
|
-
);
|
35
|
-
});
|
36
|
-
}
|
37
|
-
|
38
|
-
get defaultJobOptions() {
|
39
|
-
return this.jobsOpts;
|
40
|
-
}
|
41
|
-
|
42
|
-
async add(jobName: string, data: any, opts?: JobsOptions) {
|
43
|
-
if (opts && opts.repeat) {
|
44
|
-
return this.repeat.addNextRepeatableJob(
|
45
|
-
jobName,
|
46
|
-
data,
|
47
|
-
{ ...opts, ...this.jobsOpts },
|
48
|
-
true,
|
49
|
-
);
|
50
|
-
} else {
|
51
|
-
const job = await Job.create(this, jobName, data, {
|
52
|
-
...opts,
|
53
|
-
...this.jobsOpts,
|
54
|
-
});
|
55
|
-
this.emit('waiting', job);
|
56
|
-
return job;
|
57
|
-
}
|
58
|
-
}
|
59
|
-
|
60
|
-
/**
|
61
|
-
Adds an array of jobs to the queue.
|
62
|
-
@method add
|
63
|
-
@param jobs: [] The array of jobs to add to the queue. Each job is defined by 3
|
64
|
-
properties, 'name', 'data' and 'opts'. They follow the same signature as 'Queue.add'.
|
65
|
-
*/
|
66
|
-
async addBulk(jobs: { name: string; data: any; opts?: JobsOptions }[]) {
|
67
|
-
return Job.createBulk(
|
68
|
-
this,
|
69
|
-
jobs.map(job => ({
|
70
|
-
name: job.name,
|
71
|
-
data: job.data,
|
72
|
-
opts: { ...job.opts, ...this.jobsOpts },
|
73
|
-
})),
|
74
|
-
);
|
75
|
-
}
|
76
|
-
|
77
|
-
/**
|
78
|
-
Pauses the processing of this queue globally.
|
79
|
-
|
80
|
-
We use an atomic RENAME operation on the wait queue. Since
|
81
|
-
we have blocking calls with BRPOPLPUSH on the wait queue, as long as the queue
|
82
|
-
is renamed to 'paused', no new jobs will be processed (the current ones
|
83
|
-
will run until finalized).
|
84
|
-
|
85
|
-
Adding jobs requires a LUA script to check first if the paused list exist
|
86
|
-
and in that case it will add it there instead of the wait list.
|
87
|
-
*/
|
88
|
-
async pause() {
|
89
|
-
await this.waitUntilReady();
|
90
|
-
await Scripts.pause(this, true);
|
91
|
-
this.emit('paused');
|
92
|
-
}
|
93
|
-
|
94
|
-
async resume() {
|
95
|
-
await this.waitUntilReady();
|
96
|
-
await Scripts.pause(this, false);
|
97
|
-
this.emit('resumed');
|
98
|
-
}
|
99
|
-
|
100
|
-
removeRepeatable(name: string, repeatOpts: RepeatOptions, jobId?: string) {
|
101
|
-
return this.repeat.removeRepeatable(name, repeatOpts, jobId);
|
102
|
-
}
|
103
|
-
|
104
|
-
removeRepeatableByKey(key: string) {
|
105
|
-
return this.repeat.removeRepeatableByKey(key);
|
106
|
-
}
|
107
|
-
|
108
|
-
/**
|
109
|
-
* Drains the queue, i.e., removes all jobs that are waiting
|
110
|
-
* or delayed, but not active, completed or failed.
|
111
|
-
*
|
112
|
-
* TODO: Convert to an atomic LUA script.
|
113
|
-
*/
|
114
|
-
async drain(delayed = false) {
|
115
|
-
// Get all jobids and empty all lists atomically.
|
116
|
-
let multi = this.client.multi();
|
117
|
-
|
118
|
-
multi.lrange(this.toKey('wait'), 0, -1);
|
119
|
-
multi.lrange(this.toKey('paused'), 0, -1);
|
120
|
-
if (delayed) {
|
121
|
-
// TODO: get delayed jobIds too!
|
122
|
-
multi.del(this.toKey('delayed'));
|
123
|
-
}
|
124
|
-
multi.del(this.toKey('wait'));
|
125
|
-
multi.del(this.toKey('paused'));
|
126
|
-
multi.del(this.toKey('priority'));
|
127
|
-
|
128
|
-
const [waiting, paused] = await multi.exec();
|
129
|
-
const waitingjobs = waiting[1];
|
130
|
-
const pausedJobs = paused[1];
|
131
|
-
|
132
|
-
const jobKeys = pausedJobs.concat(waitingjobs).map(this.toKey, this);
|
133
|
-
|
134
|
-
if (jobKeys.length) {
|
135
|
-
multi = this.client.multi();
|
136
|
-
|
137
|
-
multi.del.apply(multi, jobKeys);
|
138
|
-
return multi.exec();
|
139
|
-
}
|
140
|
-
}
|
141
|
-
|
142
|
-
/*@function clean
|
143
|
-
*
|
144
|
-
* Cleans jobs from a queue. Similar to remove but keeps jobs within a certain
|
145
|
-
* grace period.
|
146
|
-
*
|
147
|
-
* @param {number} grace - The grace period
|
148
|
-
* @param {number} The max number of jobs to clean
|
149
|
-
* @param {string} [type=completed] - The type of job to clean
|
150
|
-
* Possible values are completed, wait, active, paused, delayed, failed. Defaults to completed.
|
151
|
-
*/
|
152
|
-
async clean(
|
153
|
-
grace: number,
|
154
|
-
limit: number,
|
155
|
-
type:
|
156
|
-
| 'completed'
|
157
|
-
| 'wait'
|
158
|
-
| 'active'
|
159
|
-
| 'paused'
|
160
|
-
| 'delayed'
|
161
|
-
| 'failed' = 'completed',
|
162
|
-
) {
|
163
|
-
await this.waitUntilReady();
|
164
|
-
|
165
|
-
const jobs = await Scripts.cleanJobsInSet(
|
166
|
-
this,
|
167
|
-
type,
|
168
|
-
Date.now() - grace,
|
169
|
-
limit,
|
170
|
-
);
|
171
|
-
|
172
|
-
this.emit('cleaned', jobs, type);
|
173
|
-
return jobs;
|
174
|
-
}
|
175
|
-
|
176
|
-
async trimEvents(maxLength: number) {
|
177
|
-
await this.waitUntilReady();
|
178
|
-
return this.client.xtrim(this.keys.events, 'MAXLEN', '~', maxLength);
|
179
|
-
}
|
180
|
-
}
|
@@ -1,111 +0,0 @@
|
|
1
|
-
import IORedis from 'ioredis';
|
2
|
-
import * as semver from 'semver';
|
3
|
-
import { load } from '../commands';
|
4
|
-
import { ConnectionOptions, RedisOptions } from '../interfaces';
|
5
|
-
|
6
|
-
export class RedisConnection {
|
7
|
-
static minimumVersion = '5.0.0';
|
8
|
-
client: IORedis.Redis;
|
9
|
-
|
10
|
-
constructor(private opts?: ConnectionOptions | IORedis.Redis) {
|
11
|
-
if (!(opts instanceof IORedis)) {
|
12
|
-
this.opts = Object.assign(
|
13
|
-
{
|
14
|
-
port: 6379,
|
15
|
-
host: '127.0.0.1',
|
16
|
-
retryStrategy: function(times: number) {
|
17
|
-
return Math.min(Math.exp(times), 20000);
|
18
|
-
},
|
19
|
-
},
|
20
|
-
opts,
|
21
|
-
);
|
22
|
-
} else {
|
23
|
-
this.client = opts;
|
24
|
-
}
|
25
|
-
}
|
26
|
-
|
27
|
-
/**
|
28
|
-
* Waits for a redis client to be ready.
|
29
|
-
* @param {Redis} redis client
|
30
|
-
*/
|
31
|
-
static async waitUntilReady(client: IORedis.Redis) {
|
32
|
-
return new Promise(function(resolve, reject) {
|
33
|
-
if (client.status === 'ready') {
|
34
|
-
resolve();
|
35
|
-
} else {
|
36
|
-
async function handleReady() {
|
37
|
-
client.removeListener('error', handleError);
|
38
|
-
await load(client);
|
39
|
-
resolve();
|
40
|
-
}
|
41
|
-
|
42
|
-
function handleError(err: Error) {
|
43
|
-
client.removeListener('ready', handleReady);
|
44
|
-
reject(err);
|
45
|
-
}
|
46
|
-
|
47
|
-
client.once('ready', handleReady);
|
48
|
-
client.once('error', handleError);
|
49
|
-
}
|
50
|
-
});
|
51
|
-
}
|
52
|
-
|
53
|
-
async init() {
|
54
|
-
if (!this.client) {
|
55
|
-
this.client = new IORedis(<RedisOptions>this.opts);
|
56
|
-
}
|
57
|
-
|
58
|
-
await RedisConnection.waitUntilReady(this.client);
|
59
|
-
|
60
|
-
this.client.on('error', (err: Error) => {
|
61
|
-
console.error(err);
|
62
|
-
});
|
63
|
-
|
64
|
-
if ((<RedisOptions>this.opts).skipVersionCheck !== true) {
|
65
|
-
const version = await this.getRedisVersion();
|
66
|
-
if (semver.lt(version, RedisConnection.minimumVersion)) {
|
67
|
-
throw new Error(
|
68
|
-
`Redis version needs to be greater than ${RedisConnection.minimumVersion} Current: ${version}`,
|
69
|
-
);
|
70
|
-
}
|
71
|
-
}
|
72
|
-
return this.client;
|
73
|
-
}
|
74
|
-
|
75
|
-
async disconnect() {
|
76
|
-
const client = this.client;
|
77
|
-
if (client.status !== 'end') {
|
78
|
-
let _resolve, _reject;
|
79
|
-
|
80
|
-
const disconnecting = new Promise((resolve, reject) => {
|
81
|
-
client.once('end', resolve);
|
82
|
-
client.once('error', reject);
|
83
|
-
_resolve = resolve;
|
84
|
-
_reject = reject;
|
85
|
-
});
|
86
|
-
|
87
|
-
client.disconnect();
|
88
|
-
|
89
|
-
try {
|
90
|
-
await disconnecting;
|
91
|
-
} finally {
|
92
|
-
client.removeListener('end', _resolve);
|
93
|
-
client.removeListener('error', _reject);
|
94
|
-
}
|
95
|
-
}
|
96
|
-
}
|
97
|
-
|
98
|
-
async close() {}
|
99
|
-
|
100
|
-
private async getRedisVersion() {
|
101
|
-
const doc = await this.client.info();
|
102
|
-
const prefix = 'redis_version:';
|
103
|
-
const lines = doc.split('\r\n');
|
104
|
-
|
105
|
-
for (let i = 0; i < lines.length; i++) {
|
106
|
-
if (lines[i].indexOf(prefix) === 0) {
|
107
|
-
return lines[i].substr(prefix.length);
|
108
|
-
}
|
109
|
-
}
|
110
|
-
}
|
111
|
-
}
|