agenda-ts 1.6.9-beta.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/LICENSE +21 -0
- package/README.md +353 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +12 -0
- package/dist/index.js.map +1 -0
- package/dist/job/compute-next-run-at.d.ts +3 -0
- package/dist/job/compute-next-run-at.js +114 -0
- package/dist/job/compute-next-run-at.js.map +1 -0
- package/dist/job/disable.d.ts +3 -0
- package/dist/job/disable.js +9 -0
- package/dist/job/disable.js.map +1 -0
- package/dist/job/enable.d.ts +3 -0
- package/dist/job/enable.js +9 -0
- package/dist/job/enable.js.map +1 -0
- package/dist/job/fail.d.ts +3 -0
- package/dist/job/fail.js +28 -0
- package/dist/job/fail.js.map +1 -0
- package/dist/job/fetch-status.d.ts +10 -0
- package/dist/job/fetch-status.js +23 -0
- package/dist/job/fetch-status.js.map +1 -0
- package/dist/job/index.d.ts +89 -0
- package/dist/job/index.js +109 -0
- package/dist/job/index.js.map +1 -0
- package/dist/job/is-expired.d.ts +2 -0
- package/dist/job/is-expired.js +16 -0
- package/dist/job/is-expired.js.map +1 -0
- package/dist/job/is-running.d.ts +2 -0
- package/dist/job/is-running.js +21 -0
- package/dist/job/is-running.js.map +1 -0
- package/dist/job/priority.d.ts +3 -0
- package/dist/job/priority.js +10 -0
- package/dist/job/priority.js.map +1 -0
- package/dist/job/remove.d.ts +2 -0
- package/dist/job/remove.js +8 -0
- package/dist/job/remove.js.map +1 -0
- package/dist/job/repeat-at.d.ts +3 -0
- package/dist/job/repeat-at.js +9 -0
- package/dist/job/repeat-at.js.map +1 -0
- package/dist/job/repeat-every.d.ts +10 -0
- package/dist/job/repeat-every.js +21 -0
- package/dist/job/repeat-every.js.map +1 -0
- package/dist/job/run.d.ts +3 -0
- package/dist/job/run.js +92 -0
- package/dist/job/run.js.map +1 -0
- package/dist/job/save.d.ts +3 -0
- package/dist/job/save.js +8 -0
- package/dist/job/save.js.map +1 -0
- package/dist/job/schedule.d.ts +3 -0
- package/dist/job/schedule.js +12 -0
- package/dist/job/schedule.js.map +1 -0
- package/dist/job/set-shouldsaveresult.d.ts +3 -0
- package/dist/job/set-shouldsaveresult.js +9 -0
- package/dist/job/set-shouldsaveresult.js.map +1 -0
- package/dist/job/to-json.d.ts +3 -0
- package/dist/job/to-json.js +21 -0
- package/dist/job/to-json.js.map +1 -0
- package/dist/job/touch.d.ts +3 -0
- package/dist/job/touch.js +14 -0
- package/dist/job/touch.js.map +1 -0
- package/dist/job/unique.d.ts +6 -0
- package/dist/job/unique.js +10 -0
- package/dist/job/unique.js.map +1 -0
- package/dist/pulse/cancel.d.ts +3 -0
- package/dist/pulse/cancel.js +21 -0
- package/dist/pulse/cancel.js.map +1 -0
- package/dist/pulse/close.d.ts +5 -0
- package/dist/pulse/close.js +25 -0
- package/dist/pulse/close.js.map +1 -0
- package/dist/pulse/count-jobs.d.ts +5 -0
- package/dist/pulse/count-jobs.js +12 -0
- package/dist/pulse/count-jobs.js.map +1 -0
- package/dist/pulse/create.d.ts +3 -0
- package/dist/pulse/create.js +31 -0
- package/dist/pulse/create.js.map +1 -0
- package/dist/pulse/database.d.ts +4 -0
- package/dist/pulse/database.js +33 -0
- package/dist/pulse/database.js.map +1 -0
- package/dist/pulse/db-init.d.ts +3 -0
- package/dist/pulse/db-init.js +34 -0
- package/dist/pulse/db-init.js.map +1 -0
- package/dist/pulse/default-concurrency.d.ts +3 -0
- package/dist/pulse/default-concurrency.js +13 -0
- package/dist/pulse/default-concurrency.js.map +1 -0
- package/dist/pulse/default-lock-lifetime.d.ts +3 -0
- package/dist/pulse/default-lock-lifetime.js +13 -0
- package/dist/pulse/default-lock-lifetime.js.map +1 -0
- package/dist/pulse/default-lock-limit.d.ts +3 -0
- package/dist/pulse/default-lock-limit.js +13 -0
- package/dist/pulse/default-lock-limit.js.map +1 -0
- package/dist/pulse/define.d.ts +23 -0
- package/dist/pulse/define.js +34 -0
- package/dist/pulse/define.js.map +1 -0
- package/dist/pulse/disable.d.ts +3 -0
- package/dist/pulse/disable.js +22 -0
- package/dist/pulse/disable.js.map +1 -0
- package/dist/pulse/drain.d.ts +2 -0
- package/dist/pulse/drain.js +26 -0
- package/dist/pulse/drain.js.map +1 -0
- package/dist/pulse/enable.d.ts +3 -0
- package/dist/pulse/enable.js +22 -0
- package/dist/pulse/enable.js.map +1 -0
- package/dist/pulse/every.d.ts +4 -0
- package/dist/pulse/every.js +37 -0
- package/dist/pulse/every.js.map +1 -0
- package/dist/pulse/find-and-lock-next-job.d.ts +3 -0
- package/dist/pulse/find-and-lock-next-job.js +43 -0
- package/dist/pulse/find-and-lock-next-job.js.map +1 -0
- package/dist/pulse/has-mongo-protocol.d.ts +1 -0
- package/dist/pulse/has-mongo-protocol.js +8 -0
- package/dist/pulse/has-mongo-protocol.js.map +1 -0
- package/dist/pulse/index.d.ts +115 -0
- package/dist/pulse/index.js +208 -0
- package/dist/pulse/index.js.map +1 -0
- package/dist/pulse/job-processing-queue.d.ts +11 -0
- package/dist/pulse/job-processing-queue.js +51 -0
- package/dist/pulse/job-processing-queue.js.map +1 -0
- package/dist/pulse/jobs.d.ts +6 -0
- package/dist/pulse/jobs.js +14 -0
- package/dist/pulse/jobs.js.map +1 -0
- package/dist/pulse/lock-limit.d.ts +3 -0
- package/dist/pulse/lock-limit.js +13 -0
- package/dist/pulse/lock-limit.js.map +1 -0
- package/dist/pulse/max-concurrency.d.ts +3 -0
- package/dist/pulse/max-concurrency.js +13 -0
- package/dist/pulse/max-concurrency.js.map +1 -0
- package/dist/pulse/mongo.d.ts +4 -0
- package/dist/pulse/mongo.js +10 -0
- package/dist/pulse/mongo.js.map +1 -0
- package/dist/pulse/name.d.ts +3 -0
- package/dist/pulse/name.js +13 -0
- package/dist/pulse/name.js.map +1 -0
- package/dist/pulse/now.d.ts +3 -0
- package/dist/pulse/now.js +21 -0
- package/dist/pulse/now.js.map +1 -0
- package/dist/pulse/process-every.d.ts +3 -0
- package/dist/pulse/process-every.js +14 -0
- package/dist/pulse/process-every.js.map +1 -0
- package/dist/pulse/purge.d.ts +2 -0
- package/dist/pulse/purge.js +13 -0
- package/dist/pulse/purge.js.map +1 -0
- package/dist/pulse/resume-on-restart.d.ts +3 -0
- package/dist/pulse/resume-on-restart.js +39 -0
- package/dist/pulse/resume-on-restart.js.map +1 -0
- package/dist/pulse/save-job.d.ts +4 -0
- package/dist/pulse/save-job.js +104 -0
- package/dist/pulse/save-job.js.map +1 -0
- package/dist/pulse/schedule.d.ts +4 -0
- package/dist/pulse/schedule.js +36 -0
- package/dist/pulse/schedule.js.map +1 -0
- package/dist/pulse/sort.d.ts +3 -0
- package/dist/pulse/sort.js +13 -0
- package/dist/pulse/sort.js.map +1 -0
- package/dist/pulse/start.d.ts +2 -0
- package/dist/pulse/start.js +19 -0
- package/dist/pulse/start.js.map +1 -0
- package/dist/pulse/stop.d.ts +2 -0
- package/dist/pulse/stop.js +38 -0
- package/dist/pulse/stop.js.map +1 -0
- package/dist/utils/create-job.d.ts +3 -0
- package/dist/utils/create-job.js +10 -0
- package/dist/utils/create-job.js.map +1 -0
- package/dist/utils/error.d.ts +12 -0
- package/dist/utils/error.js +34 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.js +8 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/parse-priority.d.ts +1 -0
- package/dist/utils/parse-priority.js +31 -0
- package/dist/utils/parse-priority.js.map +1 -0
- package/dist/utils/process-jobs.d.ts +3 -0
- package/dist/utils/process-jobs.js +203 -0
- package/dist/utils/process-jobs.js.map +1 -0
- package/package.json +99 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { EventEmitter } from 'events';
|
|
2
|
+
import { AnyError, Collection, MongoClient, MongoClientOptions, Db as MongoDb } from 'mongodb';
|
|
3
|
+
import { Job } from '../job';
|
|
4
|
+
import { CancelMethod } from './cancel';
|
|
5
|
+
import { CloseMethod } from './close';
|
|
6
|
+
import { CountJobsMethod } from './count-jobs';
|
|
7
|
+
import { CreateMethod } from './create';
|
|
8
|
+
import { DatabaseMethod } from './database';
|
|
9
|
+
import { DbInitMethod } from './db-init';
|
|
10
|
+
import { DefaultConcurrencyMethod } from './default-concurrency';
|
|
11
|
+
import { DefaultLockLifetimeMethod } from './default-lock-lifetime';
|
|
12
|
+
import { DefaultLockLimitMethod } from './default-lock-limit';
|
|
13
|
+
import { DefineMethod } from './define';
|
|
14
|
+
import { DisableMethod } from './disable';
|
|
15
|
+
import { DrainMethod } from './drain';
|
|
16
|
+
import { EnableMethod } from './enable';
|
|
17
|
+
import { EveryMethod } from './every';
|
|
18
|
+
import { JobProcessingQueue } from './job-processing-queue';
|
|
19
|
+
import { JobsMethod } from './jobs';
|
|
20
|
+
import { LockLimitMethod } from './lock-limit';
|
|
21
|
+
import { MaxConcurrencyMethod } from './max-concurrency';
|
|
22
|
+
import { MongoMethod } from './mongo';
|
|
23
|
+
import { NameMethod } from './name';
|
|
24
|
+
import { NowMethod } from './now';
|
|
25
|
+
import { ProcessEveryMethod } from './process-every';
|
|
26
|
+
import { PurgeMethod } from './purge';
|
|
27
|
+
import { ResumeOnRestartMethod } from './resume-on-restart';
|
|
28
|
+
import { SaveJobMethod } from './save-job';
|
|
29
|
+
import { ScheduleMethod } from './schedule';
|
|
30
|
+
import { SortMethod } from './sort';
|
|
31
|
+
import { StartMethod } from './start';
|
|
32
|
+
import { StopMethod } from './stop';
|
|
33
|
+
export type PulseOnEventType = 'ready' | 'start' | 'success' | 'fail' | 'complete' | 'cancel' | 'error';
|
|
34
|
+
export interface PulseConfig {
|
|
35
|
+
name?: string;
|
|
36
|
+
processEvery?: string;
|
|
37
|
+
maxConcurrency?: number;
|
|
38
|
+
defaultConcurrency?: number;
|
|
39
|
+
lockLimit?: number;
|
|
40
|
+
defaultLockLimit?: number;
|
|
41
|
+
defaultLockLifetime?: number;
|
|
42
|
+
sort?: any;
|
|
43
|
+
mongo?: MongoDb;
|
|
44
|
+
db?: {
|
|
45
|
+
address: string;
|
|
46
|
+
collection?: string;
|
|
47
|
+
options?: MongoClientOptions;
|
|
48
|
+
};
|
|
49
|
+
disableAutoIndex?: boolean;
|
|
50
|
+
resumeOnRestart?: boolean;
|
|
51
|
+
}
|
|
52
|
+
declare class Pulse extends EventEmitter {
|
|
53
|
+
private _lazyBindings;
|
|
54
|
+
_defaultConcurrency: any;
|
|
55
|
+
_defaultLockLifetime: any;
|
|
56
|
+
_defaultLockLimit: any;
|
|
57
|
+
_definitions: any;
|
|
58
|
+
_findAndLockNextJob: (this: Pulse, jobName: string, definition: any) => Promise<Job | undefined>;
|
|
59
|
+
_indices: any;
|
|
60
|
+
_disableAutoIndex: boolean;
|
|
61
|
+
_resumeOnRestart: boolean;
|
|
62
|
+
_isLockingOnTheFly: boolean;
|
|
63
|
+
_isJobQueueFilling: Map<string, boolean>;
|
|
64
|
+
_jobQueue: JobProcessingQueue;
|
|
65
|
+
_jobsToLock: Job[];
|
|
66
|
+
_lockedJobs: Job[];
|
|
67
|
+
_runningJobs: Job[];
|
|
68
|
+
_lockLimit: any;
|
|
69
|
+
_maxConcurrency: any;
|
|
70
|
+
_mongoUseUnifiedTopology?: boolean;
|
|
71
|
+
_name: any;
|
|
72
|
+
_processEvery: number;
|
|
73
|
+
_ready: Promise<unknown>;
|
|
74
|
+
_sort: any;
|
|
75
|
+
_db: MongoClient;
|
|
76
|
+
_mdb: MongoDb;
|
|
77
|
+
_collection: Collection;
|
|
78
|
+
_nextScanAt: any;
|
|
79
|
+
_processInterval: any;
|
|
80
|
+
_readyAt: Date;
|
|
81
|
+
constructor(config?: PulseConfig, cb?: (error: AnyError | undefined, collection: Collection<any> | null) => void);
|
|
82
|
+
get define(): DefineMethod;
|
|
83
|
+
get every(): EveryMethod;
|
|
84
|
+
get processEvery(): ProcessEveryMethod;
|
|
85
|
+
get cancel(): CancelMethod;
|
|
86
|
+
get close(): CloseMethod;
|
|
87
|
+
get create(): CreateMethod;
|
|
88
|
+
get dbInit(): DbInitMethod;
|
|
89
|
+
get defaultConcurrency(): DefaultConcurrencyMethod;
|
|
90
|
+
get defaultLockLifetime(): DefaultLockLifetimeMethod;
|
|
91
|
+
get defaultLockLimit(): DefaultLockLimitMethod;
|
|
92
|
+
get disable(): DisableMethod;
|
|
93
|
+
get enable(): EnableMethod;
|
|
94
|
+
get jobs(): JobsMethod;
|
|
95
|
+
get countJobs(): CountJobsMethod;
|
|
96
|
+
get lockLimit(): LockLimitMethod;
|
|
97
|
+
get maxConcurrency(): MaxConcurrencyMethod;
|
|
98
|
+
get name(): NameMethod;
|
|
99
|
+
get now(): NowMethod;
|
|
100
|
+
get purge(): PurgeMethod;
|
|
101
|
+
get saveJob(): SaveJobMethod;
|
|
102
|
+
get schedule(): ScheduleMethod;
|
|
103
|
+
get sort(): SortMethod;
|
|
104
|
+
get start(): StartMethod;
|
|
105
|
+
get stop(): StopMethod;
|
|
106
|
+
get drain(): DrainMethod;
|
|
107
|
+
get mongo(): MongoMethod;
|
|
108
|
+
get database(): DatabaseMethod;
|
|
109
|
+
get resumeOnRestart(): ResumeOnRestartMethod;
|
|
110
|
+
get getJobsRepo(): (this: Pulse, query?: {}, sort?: {}, limit?: number, skip?: number) => Promise<import("mongodb").WithId<import("bson").Document>[]>;
|
|
111
|
+
on(event: PulseOnEventType, listener: (...arg: any[]) => void): this;
|
|
112
|
+
private init;
|
|
113
|
+
private bindMethod;
|
|
114
|
+
}
|
|
115
|
+
export { Pulse };
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Pulse = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const events_1 = require("events");
|
|
6
|
+
const human_interval_1 = tslib_1.__importDefault(require("human-interval"));
|
|
7
|
+
const cancel_1 = require("./cancel");
|
|
8
|
+
const close_1 = require("./close");
|
|
9
|
+
const count_jobs_1 = require("./count-jobs");
|
|
10
|
+
const create_1 = require("./create");
|
|
11
|
+
const database_1 = require("./database");
|
|
12
|
+
const db_init_1 = require("./db-init");
|
|
13
|
+
const default_concurrency_1 = require("./default-concurrency");
|
|
14
|
+
const default_lock_lifetime_1 = require("./default-lock-lifetime");
|
|
15
|
+
const default_lock_limit_1 = require("./default-lock-limit");
|
|
16
|
+
const define_1 = require("./define");
|
|
17
|
+
const disable_1 = require("./disable");
|
|
18
|
+
const drain_1 = require("./drain");
|
|
19
|
+
const enable_1 = require("./enable");
|
|
20
|
+
const every_1 = require("./every");
|
|
21
|
+
const find_and_lock_next_job_1 = require("./find-and-lock-next-job");
|
|
22
|
+
const job_processing_queue_1 = require("./job-processing-queue");
|
|
23
|
+
const jobs_1 = require("./jobs");
|
|
24
|
+
const lock_limit_1 = require("./lock-limit");
|
|
25
|
+
const max_concurrency_1 = require("./max-concurrency");
|
|
26
|
+
const mongo_1 = require("./mongo");
|
|
27
|
+
const name_1 = require("./name");
|
|
28
|
+
const now_1 = require("./now");
|
|
29
|
+
const process_every_1 = require("./process-every");
|
|
30
|
+
const purge_1 = require("./purge");
|
|
31
|
+
const resume_on_restart_1 = require("./resume-on-restart");
|
|
32
|
+
const save_job_1 = require("./save-job");
|
|
33
|
+
const schedule_1 = require("./schedule");
|
|
34
|
+
const sort_1 = require("./sort");
|
|
35
|
+
const start_1 = require("./start");
|
|
36
|
+
const stop_1 = require("./stop");
|
|
37
|
+
class Pulse extends events_1.EventEmitter {
|
|
38
|
+
_lazyBindings = {};
|
|
39
|
+
_defaultConcurrency;
|
|
40
|
+
_defaultLockLifetime;
|
|
41
|
+
_defaultLockLimit;
|
|
42
|
+
_definitions;
|
|
43
|
+
_findAndLockNextJob = find_and_lock_next_job_1.findAndLockNextJob;
|
|
44
|
+
_indices;
|
|
45
|
+
_disableAutoIndex;
|
|
46
|
+
_resumeOnRestart;
|
|
47
|
+
_isLockingOnTheFly;
|
|
48
|
+
_isJobQueueFilling;
|
|
49
|
+
_jobQueue;
|
|
50
|
+
_jobsToLock;
|
|
51
|
+
_lockedJobs;
|
|
52
|
+
_runningJobs;
|
|
53
|
+
_lockLimit;
|
|
54
|
+
_maxConcurrency;
|
|
55
|
+
_mongoUseUnifiedTopology;
|
|
56
|
+
_name;
|
|
57
|
+
_processEvery;
|
|
58
|
+
_ready;
|
|
59
|
+
_sort;
|
|
60
|
+
_db;
|
|
61
|
+
_mdb;
|
|
62
|
+
_collection;
|
|
63
|
+
_nextScanAt;
|
|
64
|
+
_processInterval;
|
|
65
|
+
_readyAt;
|
|
66
|
+
constructor(config = {}, cb) {
|
|
67
|
+
super();
|
|
68
|
+
this._name = config.name;
|
|
69
|
+
this._processEvery = ((0, human_interval_1.default)(config.processEvery) ?? (0, human_interval_1.default)('5 seconds'));
|
|
70
|
+
this._defaultConcurrency = config.defaultConcurrency || 5;
|
|
71
|
+
this._maxConcurrency = config.maxConcurrency || 20;
|
|
72
|
+
this._defaultLockLimit = config.defaultLockLimit || 0;
|
|
73
|
+
this._lockLimit = config.lockLimit || 0;
|
|
74
|
+
this._definitions = {};
|
|
75
|
+
this._runningJobs = [];
|
|
76
|
+
this._lockedJobs = [];
|
|
77
|
+
this._jobQueue = new job_processing_queue_1.JobProcessingQueue();
|
|
78
|
+
this._defaultLockLifetime = config.defaultLockLifetime || 10 * 60 * 1000;
|
|
79
|
+
this._sort = config.sort || { nextRunAt: 1, priority: -1 };
|
|
80
|
+
this._indices = {
|
|
81
|
+
name: 1,
|
|
82
|
+
...this._sort,
|
|
83
|
+
priority: -1,
|
|
84
|
+
lockedAt: 1,
|
|
85
|
+
nextRunAt: 1,
|
|
86
|
+
disabled: 1,
|
|
87
|
+
};
|
|
88
|
+
this._disableAutoIndex = config.disableAutoIndex === true;
|
|
89
|
+
this._resumeOnRestart = config.resumeOnRestart !== false;
|
|
90
|
+
this._isLockingOnTheFly = false;
|
|
91
|
+
this._isJobQueueFilling = new Map();
|
|
92
|
+
this._jobsToLock = [];
|
|
93
|
+
this._ready = new Promise((resolve) => {
|
|
94
|
+
this.once('ready', resolve);
|
|
95
|
+
});
|
|
96
|
+
this._readyAt = new Date();
|
|
97
|
+
this.init(config, cb);
|
|
98
|
+
}
|
|
99
|
+
get define() {
|
|
100
|
+
return this.bindMethod('define', define_1.define);
|
|
101
|
+
}
|
|
102
|
+
get every() {
|
|
103
|
+
return this.bindMethod('every', every_1.every);
|
|
104
|
+
}
|
|
105
|
+
get processEvery() {
|
|
106
|
+
return this.bindMethod('processEvery', process_every_1.processEvery);
|
|
107
|
+
}
|
|
108
|
+
get cancel() {
|
|
109
|
+
return this.bindMethod('cancel', cancel_1.cancel);
|
|
110
|
+
}
|
|
111
|
+
get close() {
|
|
112
|
+
return this.bindMethod('close', close_1.close);
|
|
113
|
+
}
|
|
114
|
+
get create() {
|
|
115
|
+
return this.bindMethod('create', create_1.create);
|
|
116
|
+
}
|
|
117
|
+
get dbInit() {
|
|
118
|
+
return this.bindMethod('dbInit', db_init_1.dbInit);
|
|
119
|
+
}
|
|
120
|
+
get defaultConcurrency() {
|
|
121
|
+
return this.bindMethod('defaultConcurrency', default_concurrency_1.defaultConcurrency);
|
|
122
|
+
}
|
|
123
|
+
get defaultLockLifetime() {
|
|
124
|
+
return this.bindMethod('defaultLockLifetime', default_lock_lifetime_1.defaultLockLifetime);
|
|
125
|
+
}
|
|
126
|
+
get defaultLockLimit() {
|
|
127
|
+
return this.bindMethod('defaultLockLimit', default_lock_limit_1.defaultLockLimit);
|
|
128
|
+
}
|
|
129
|
+
get disable() {
|
|
130
|
+
return this.bindMethod('disable', disable_1.disable);
|
|
131
|
+
}
|
|
132
|
+
get enable() {
|
|
133
|
+
return this.bindMethod('enable', enable_1.enable);
|
|
134
|
+
}
|
|
135
|
+
get jobs() {
|
|
136
|
+
return this.bindMethod('jobs', jobs_1.jobs);
|
|
137
|
+
}
|
|
138
|
+
get countJobs() {
|
|
139
|
+
return this.bindMethod('countJobs', count_jobs_1.countJobs);
|
|
140
|
+
}
|
|
141
|
+
get lockLimit() {
|
|
142
|
+
return this.bindMethod('lockLimit', lock_limit_1.lockLimit);
|
|
143
|
+
}
|
|
144
|
+
get maxConcurrency() {
|
|
145
|
+
return this.bindMethod('maxConcurrency', max_concurrency_1.maxConcurrency);
|
|
146
|
+
}
|
|
147
|
+
get name() {
|
|
148
|
+
return this.bindMethod('name', name_1.name);
|
|
149
|
+
}
|
|
150
|
+
get now() {
|
|
151
|
+
return this.bindMethod('now', now_1.now);
|
|
152
|
+
}
|
|
153
|
+
get purge() {
|
|
154
|
+
return this.bindMethod('purge', purge_1.purge);
|
|
155
|
+
}
|
|
156
|
+
get saveJob() {
|
|
157
|
+
return this.bindMethod('saveJob', save_job_1.saveJob);
|
|
158
|
+
}
|
|
159
|
+
get schedule() {
|
|
160
|
+
return this.bindMethod('schedule', schedule_1.schedule);
|
|
161
|
+
}
|
|
162
|
+
get sort() {
|
|
163
|
+
return this.bindMethod('sort', sort_1.sort);
|
|
164
|
+
}
|
|
165
|
+
get start() {
|
|
166
|
+
return this.bindMethod('start', start_1.start);
|
|
167
|
+
}
|
|
168
|
+
get stop() {
|
|
169
|
+
return this.bindMethod('stop', stop_1.stop);
|
|
170
|
+
}
|
|
171
|
+
get drain() {
|
|
172
|
+
return this.bindMethod('drain', drain_1.drain);
|
|
173
|
+
}
|
|
174
|
+
get mongo() {
|
|
175
|
+
return this.bindMethod('mongo', mongo_1.mongo);
|
|
176
|
+
}
|
|
177
|
+
get database() {
|
|
178
|
+
return this.bindMethod('database', database_1.database);
|
|
179
|
+
}
|
|
180
|
+
get resumeOnRestart() {
|
|
181
|
+
return this.bindMethod('resumeOnRestart', resume_on_restart_1.resumeOnRestart);
|
|
182
|
+
}
|
|
183
|
+
get getJobsRepo() {
|
|
184
|
+
return this.bindMethod('getJobsRepo', jobs_1.getJobsRepo);
|
|
185
|
+
}
|
|
186
|
+
on(event, listener) {
|
|
187
|
+
return super.on(event, listener);
|
|
188
|
+
}
|
|
189
|
+
init(config, cb) {
|
|
190
|
+
if (config.mongo) {
|
|
191
|
+
this.mongo(config.mongo, config.db ? config.db.collection : undefined, cb);
|
|
192
|
+
if (config.mongo.s && config.mongo.topology && config.mongo.topology.s) {
|
|
193
|
+
this._mongoUseUnifiedTopology = Boolean(config.mongo.topology.s.options.useUnifiedTopology);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
else if (config.db) {
|
|
197
|
+
this.database(config.db.address, config.db.collection, config.db.options, cb);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
bindMethod(methodName, fn) {
|
|
201
|
+
if (!this._lazyBindings[methodName]) {
|
|
202
|
+
this._lazyBindings[methodName] = fn.bind(this);
|
|
203
|
+
}
|
|
204
|
+
return this._lazyBindings[methodName];
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
exports.Pulse = Pulse;
|
|
208
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/pulse/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Job } from '../job';
|
|
2
|
+
declare class JobProcessingQueue {
|
|
3
|
+
protected _queue: Job[];
|
|
4
|
+
constructor();
|
|
5
|
+
get length(): number;
|
|
6
|
+
pop(this: JobProcessingQueue): Job<import("../job").JobAttributesData> | undefined;
|
|
7
|
+
insert(this: JobProcessingQueue, job: Job): void;
|
|
8
|
+
push(this: JobProcessingQueue, job: Job): void;
|
|
9
|
+
returnNextConcurrencyFreeJob(this: JobProcessingQueue, pulseDefinitions: any): Job<import("../job").JobAttributesData>;
|
|
10
|
+
}
|
|
11
|
+
export { JobProcessingQueue };
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.JobProcessingQueue = void 0;
|
|
4
|
+
class JobProcessingQueue {
|
|
5
|
+
_queue;
|
|
6
|
+
constructor() {
|
|
7
|
+
this._queue = [];
|
|
8
|
+
}
|
|
9
|
+
get length() {
|
|
10
|
+
return this._queue.length;
|
|
11
|
+
}
|
|
12
|
+
pop() {
|
|
13
|
+
return this._queue.pop();
|
|
14
|
+
}
|
|
15
|
+
insert(job) {
|
|
16
|
+
const matchIndex = this._queue.findIndex((element) => {
|
|
17
|
+
if (element.attrs.nextRunAt.getTime() <= job.attrs.nextRunAt.getTime()) {
|
|
18
|
+
if (element.attrs.nextRunAt.getTime() === job.attrs.nextRunAt.getTime()) {
|
|
19
|
+
if (element.attrs.priority >= job.attrs.priority) {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
return false;
|
|
28
|
+
});
|
|
29
|
+
if (matchIndex === -1) {
|
|
30
|
+
this._queue.push(job);
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
this._queue.splice(matchIndex, 0, job);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
push(job) {
|
|
37
|
+
this._queue.push(job);
|
|
38
|
+
}
|
|
39
|
+
returnNextConcurrencyFreeJob(pulseDefinitions) {
|
|
40
|
+
let next;
|
|
41
|
+
for (next = this._queue.length - 1; next > 0; next -= 1) {
|
|
42
|
+
const def = pulseDefinitions[this._queue[next].attrs.name];
|
|
43
|
+
if (def.concurrency > def.running) {
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return this._queue[next];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
exports.JobProcessingQueue = JobProcessingQueue;
|
|
51
|
+
//# sourceMappingURL=job-processing-queue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"job-processing-queue.js","sourceRoot":"","sources":["../../src/pulse/job-processing-queue.ts"],"names":[],"mappings":";;;AAQA,MAAM,kBAAkB;IACZ,MAAM,CAAQ;IAExB;QACE,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACnB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;IAC5B,CAAC;IAMD,GAAG;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;IAC3B,CAAC;IASD,MAAM,CAA2B,GAAQ;QACvC,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACnD,IAAI,OAAO,CAAC,KAAK,CAAC,SAAU,CAAC,OAAO,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,SAAU,CAAC,OAAO,EAAE,EAAE,CAAC;gBACzE,IAAI,OAAO,CAAC,KAAK,CAAC,SAAU,CAAC,OAAO,EAAE,KAAK,GAAG,CAAC,KAAK,CAAC,SAAU,CAAC,OAAO,EAAE,EAAE,CAAC;oBAC1E,IAAI,OAAO,CAAC,KAAK,CAAC,QAAQ,IAAI,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;wBACjD,OAAO,IAAI,CAAC;oBACd,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,OAAO,IAAI,CAAC;gBACd,CAAC;YACH,CAAC;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CAAC;QAEH,IAAI,UAAU,KAAK,CAAC,CAAC,EAAE,CAAC;YACtB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACxB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;IAMD,IAAI,CAA2B,GAAQ;QACrC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAQD,4BAA4B,CAA2B,gBAAqB;QAC1E,IAAI,IAAI,CAAC;QACT,KAAK,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,CAAC;YACxD,MAAM,GAAG,GAAG,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YAC3D,IAAI,GAAG,CAAC,WAAW,GAAG,GAAG,CAAC,OAAO,EAAE,CAAC;gBAClC,MAAM;YACR,CAAC;QACH,CAAC;QAED,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;CACF;AAEQ,gDAAkB"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Filter, Sort } from 'mongodb';
|
|
2
|
+
import { Pulse } from '.';
|
|
3
|
+
import { Job } from '../job';
|
|
4
|
+
export declare const getJobsRepo: (this: Pulse, query?: {}, sort?: {}, limit?: number, skip?: number) => Promise<import("mongodb").WithId<import("bson").Document>[]>;
|
|
5
|
+
export type JobsMethod = (query?: Filter<any>, sort?: Sort | string, limit?: number, skip?: number) => Promise<Job[]>;
|
|
6
|
+
export declare const jobs: JobsMethod;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.jobs = exports.getJobsRepo = void 0;
|
|
4
|
+
const utils_1 = require("../utils");
|
|
5
|
+
const getJobsRepo = async function (query = {}, sort = {}, limit = 0, skip = 0) {
|
|
6
|
+
return await this._collection.find(query).sort(sort).limit(limit).skip(skip).toArray();
|
|
7
|
+
};
|
|
8
|
+
exports.getJobsRepo = getJobsRepo;
|
|
9
|
+
const jobs = async function (query = {}, sort = {}, limit = 0, skip = 0) {
|
|
10
|
+
const result = await exports.getJobsRepo.call(this, query, sort, limit, skip);
|
|
11
|
+
return result.map((job) => (0, utils_1.createJob)(this, job));
|
|
12
|
+
};
|
|
13
|
+
exports.jobs = jobs;
|
|
14
|
+
//# sourceMappingURL=jobs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jobs.js","sourceRoot":"","sources":["../../src/pulse/jobs.ts"],"names":[],"mappings":";;;AAGA,oCAAqC;AAE9B,MAAM,WAAW,GAAG,KAAK,WAAwB,KAAK,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,KAAK,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC;IAChG,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC;AACzF,CAAC,CAAC;AAFW,QAAA,WAAW,eAEtB;AAcK,MAAM,IAAI,GAAe,KAAK,WAAwB,KAAK,GAAG,EAAE,EAAE,IAAI,GAAG,EAAE,EAAE,KAAK,GAAG,CAAC,EAAE,IAAI,GAAG,CAAC;IACrG,MAAM,MAAM,GAAG,MAAM,mBAAW,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IACtE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,IAAA,iBAAS,EAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;AACxD,CAAC,CAAC;AAHW,QAAA,IAAI,QAGf"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.lockLimit = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:locklimit');
|
|
7
|
+
const lockLimit = function (limit) {
|
|
8
|
+
debug('Pulse.lockLimit(%d)', limit);
|
|
9
|
+
this._lockLimit = limit;
|
|
10
|
+
return this;
|
|
11
|
+
};
|
|
12
|
+
exports.lockLimit = lockLimit;
|
|
13
|
+
//# sourceMappingURL=lock-limit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lock-limit.js","sourceRoot":"","sources":["../../src/pulse/lock-limit.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AAGnC,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,iBAAiB,CAAC,CAAC;AASzC,MAAM,SAAS,GAAoB,UAAuB,KAAK;IAEpE,KAAK,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAC;IACpC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IACxB,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AALW,QAAA,SAAS,aAKpB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.maxConcurrency = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:maxConcurrency');
|
|
7
|
+
const maxConcurrency = function (concurrency) {
|
|
8
|
+
debug('Pulse.maxConcurrency(%d)', concurrency);
|
|
9
|
+
this._maxConcurrency = concurrency;
|
|
10
|
+
return this;
|
|
11
|
+
};
|
|
12
|
+
exports.maxConcurrency = maxConcurrency;
|
|
13
|
+
//# sourceMappingURL=max-concurrency.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"max-concurrency.js","sourceRoot":"","sources":["../../src/pulse/max-concurrency.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AAGnC,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,sBAAsB,CAAC,CAAC;AAU9C,MAAM,cAAc,GAAyB,UAAuB,WAAW;IACpF,KAAK,CAAC,0BAA0B,EAAE,WAAW,CAAC,CAAC;IAC/C,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC;IACnC,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAJW,QAAA,cAAc,kBAIzB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mongo = void 0;
|
|
4
|
+
const mongo = function (mdb, collection, cb) {
|
|
5
|
+
this._mdb = mdb;
|
|
6
|
+
this.dbInit(collection, cb);
|
|
7
|
+
return this;
|
|
8
|
+
};
|
|
9
|
+
exports.mongo = mongo;
|
|
10
|
+
//# sourceMappingURL=mongo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mongo.js","sourceRoot":"","sources":["../../src/pulse/mongo.ts"],"names":[],"mappings":";;;AAgBO,MAAM,KAAK,GAAgB,UAAuB,GAAG,EAAE,UAAW,EAAE,EAAG;IAC5E,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;IAChB,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAC5B,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAJW,QAAA,KAAK,SAIhB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.name = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:name');
|
|
7
|
+
const name = function (name) {
|
|
8
|
+
debug('Pulse.name(%s)', name);
|
|
9
|
+
this._name = name;
|
|
10
|
+
return this;
|
|
11
|
+
};
|
|
12
|
+
exports.name = name;
|
|
13
|
+
//# sourceMappingURL=name.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"name.js","sourceRoot":"","sources":["../../src/pulse/name.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AAGnC,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,YAAY,CAAC,CAAC;AASpC,MAAM,IAAI,GAAe,UAAuB,IAAI;IACzD,KAAK,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;IAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IAClB,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAJW,QAAA,IAAI,QAIf"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.now = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:now');
|
|
7
|
+
const now = async function (name, data) {
|
|
8
|
+
debug('Pulse.now(%s, [Object])', name);
|
|
9
|
+
try {
|
|
10
|
+
const job = this.create(name, data || {});
|
|
11
|
+
job.schedule(new Date());
|
|
12
|
+
await job.save();
|
|
13
|
+
return job;
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
debug('error trying to create a job for this exact moment');
|
|
17
|
+
throw error;
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
exports.now = now;
|
|
21
|
+
//# sourceMappingURL=now.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"now.js","sourceRoot":"","sources":["../../src/pulse/now.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AAInC,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,WAAW,CAAC,CAAC;AAUnC,MAAM,GAAG,GAAc,KAAK,WAAwB,IAAI,EAAE,IAAI;IACnE,KAAK,CAAC,yBAAyB,EAAE,IAAI,CAAC,CAAC;IACvC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;QAE1C,GAAG,CAAC,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACzB,MAAM,GAAG,CAAC,IAAI,EAAE,CAAC;QAEjB,OAAO,GAAG,CAAC;IACb,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,KAAK,CAAC,oDAAoD,CAAC,CAAC;QAC5D,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC,CAAC;AAbW,QAAA,GAAG,OAad"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.processEvery = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const human_interval_1 = tslib_1.__importDefault(require("human-interval"));
|
|
7
|
+
const debug = (0, debug_1.default)('pulse:processEvery');
|
|
8
|
+
const processEvery = function (time) {
|
|
9
|
+
debug('Pulse.processEvery(%d)', time);
|
|
10
|
+
this._processEvery = (0, human_interval_1.default)(time);
|
|
11
|
+
return this;
|
|
12
|
+
};
|
|
13
|
+
exports.processEvery = processEvery;
|
|
14
|
+
//# sourceMappingURL=process-every.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"process-every.js","sourceRoot":"","sources":["../../src/pulse/process-every.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AACnC,4EAA2C;AAG3C,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,oBAAoB,CAAC,CAAC;AAS5C,MAAM,YAAY,GAAuB,UAAuB,IAAI;IACzE,KAAK,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC;IAEtC,IAAI,CAAC,aAAa,GAAG,IAAA,wBAAa,EAAC,IAAI,CAAC,CAAC;IACzC,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AALW,QAAA,YAAY,gBAKvB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.purge = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:purge');
|
|
7
|
+
const purge = async function () {
|
|
8
|
+
const definedNames = Object.keys(this._definitions);
|
|
9
|
+
debug('Pulse.purge(%o)', definedNames);
|
|
10
|
+
return this.cancel({ name: { $not: { $in: definedNames } } });
|
|
11
|
+
};
|
|
12
|
+
exports.purge = purge;
|
|
13
|
+
//# sourceMappingURL=purge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"purge.js","sourceRoot":"","sources":["../../src/pulse/purge.ts"],"names":[],"mappings":";;;;AAAA,0DAAmC;AAGnC,MAAM,KAAK,GAAG,IAAA,eAAc,EAAC,aAAa,CAAC,CAAC;AASrC,MAAM,KAAK,GAAgB,KAAK;IAErC,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpD,KAAK,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IACvC,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC,CAAC;AAChE,CAAC,CAAC;AALW,QAAA,KAAK,SAKhB"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resumeOnRestart = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const debug_1 = tslib_1.__importDefault(require("debug"));
|
|
6
|
+
const debug = (0, debug_1.default)('pulse:resumeOnRestart');
|
|
7
|
+
const resumeOnRestart = function (resume = true) {
|
|
8
|
+
debug('Pulse.resumeOnRestart()');
|
|
9
|
+
this._resumeOnRestart = resume;
|
|
10
|
+
if (this._collection && this._resumeOnRestart) {
|
|
11
|
+
const now = new Date();
|
|
12
|
+
this._collection
|
|
13
|
+
.updateMany({
|
|
14
|
+
$or: [
|
|
15
|
+
{
|
|
16
|
+
lockedAt: { $exists: true },
|
|
17
|
+
nextRunAt: { $ne: null },
|
|
18
|
+
$or: [{ $expr: { $eq: ['$runCount', '$finishedCount'] } }, { lastFinishedAt: { $exists: false } }],
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
lockedAt: { $exists: false },
|
|
22
|
+
lastFinishedAt: { $exists: false },
|
|
23
|
+
nextRunAt: { $lte: now, $ne: null },
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
}, {
|
|
27
|
+
$unset: { lockedAt: undefined, lastModifiedBy: undefined, lastRunAt: undefined },
|
|
28
|
+
$set: { nextRunAt: now },
|
|
29
|
+
})
|
|
30
|
+
.then((result) => {
|
|
31
|
+
if (result.modifiedCount > 0) {
|
|
32
|
+
debug('resuming unfinished %d jobs(%s)', result.modifiedCount, now.toISOString());
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return this;
|
|
37
|
+
};
|
|
38
|
+
exports.resumeOnRestart = resumeOnRestart;
|
|
39
|
+
//# sourceMappingURL=resume-on-restart.js.map
|