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.
Files changed (174) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +353 -0
  3. package/dist/index.d.ts +7 -0
  4. package/dist/index.js +12 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/job/compute-next-run-at.d.ts +3 -0
  7. package/dist/job/compute-next-run-at.js +114 -0
  8. package/dist/job/compute-next-run-at.js.map +1 -0
  9. package/dist/job/disable.d.ts +3 -0
  10. package/dist/job/disable.js +9 -0
  11. package/dist/job/disable.js.map +1 -0
  12. package/dist/job/enable.d.ts +3 -0
  13. package/dist/job/enable.js +9 -0
  14. package/dist/job/enable.js.map +1 -0
  15. package/dist/job/fail.d.ts +3 -0
  16. package/dist/job/fail.js +28 -0
  17. package/dist/job/fail.js.map +1 -0
  18. package/dist/job/fetch-status.d.ts +10 -0
  19. package/dist/job/fetch-status.js +23 -0
  20. package/dist/job/fetch-status.js.map +1 -0
  21. package/dist/job/index.d.ts +89 -0
  22. package/dist/job/index.js +109 -0
  23. package/dist/job/index.js.map +1 -0
  24. package/dist/job/is-expired.d.ts +2 -0
  25. package/dist/job/is-expired.js +16 -0
  26. package/dist/job/is-expired.js.map +1 -0
  27. package/dist/job/is-running.d.ts +2 -0
  28. package/dist/job/is-running.js +21 -0
  29. package/dist/job/is-running.js.map +1 -0
  30. package/dist/job/priority.d.ts +3 -0
  31. package/dist/job/priority.js +10 -0
  32. package/dist/job/priority.js.map +1 -0
  33. package/dist/job/remove.d.ts +2 -0
  34. package/dist/job/remove.js +8 -0
  35. package/dist/job/remove.js.map +1 -0
  36. package/dist/job/repeat-at.d.ts +3 -0
  37. package/dist/job/repeat-at.js +9 -0
  38. package/dist/job/repeat-at.js.map +1 -0
  39. package/dist/job/repeat-every.d.ts +10 -0
  40. package/dist/job/repeat-every.js +21 -0
  41. package/dist/job/repeat-every.js.map +1 -0
  42. package/dist/job/run.d.ts +3 -0
  43. package/dist/job/run.js +92 -0
  44. package/dist/job/run.js.map +1 -0
  45. package/dist/job/save.d.ts +3 -0
  46. package/dist/job/save.js +8 -0
  47. package/dist/job/save.js.map +1 -0
  48. package/dist/job/schedule.d.ts +3 -0
  49. package/dist/job/schedule.js +12 -0
  50. package/dist/job/schedule.js.map +1 -0
  51. package/dist/job/set-shouldsaveresult.d.ts +3 -0
  52. package/dist/job/set-shouldsaveresult.js +9 -0
  53. package/dist/job/set-shouldsaveresult.js.map +1 -0
  54. package/dist/job/to-json.d.ts +3 -0
  55. package/dist/job/to-json.js +21 -0
  56. package/dist/job/to-json.js.map +1 -0
  57. package/dist/job/touch.d.ts +3 -0
  58. package/dist/job/touch.js +14 -0
  59. package/dist/job/touch.js.map +1 -0
  60. package/dist/job/unique.d.ts +6 -0
  61. package/dist/job/unique.js +10 -0
  62. package/dist/job/unique.js.map +1 -0
  63. package/dist/pulse/cancel.d.ts +3 -0
  64. package/dist/pulse/cancel.js +21 -0
  65. package/dist/pulse/cancel.js.map +1 -0
  66. package/dist/pulse/close.d.ts +5 -0
  67. package/dist/pulse/close.js +25 -0
  68. package/dist/pulse/close.js.map +1 -0
  69. package/dist/pulse/count-jobs.d.ts +5 -0
  70. package/dist/pulse/count-jobs.js +12 -0
  71. package/dist/pulse/count-jobs.js.map +1 -0
  72. package/dist/pulse/create.d.ts +3 -0
  73. package/dist/pulse/create.js +31 -0
  74. package/dist/pulse/create.js.map +1 -0
  75. package/dist/pulse/database.d.ts +4 -0
  76. package/dist/pulse/database.js +33 -0
  77. package/dist/pulse/database.js.map +1 -0
  78. package/dist/pulse/db-init.d.ts +3 -0
  79. package/dist/pulse/db-init.js +34 -0
  80. package/dist/pulse/db-init.js.map +1 -0
  81. package/dist/pulse/default-concurrency.d.ts +3 -0
  82. package/dist/pulse/default-concurrency.js +13 -0
  83. package/dist/pulse/default-concurrency.js.map +1 -0
  84. package/dist/pulse/default-lock-lifetime.d.ts +3 -0
  85. package/dist/pulse/default-lock-lifetime.js +13 -0
  86. package/dist/pulse/default-lock-lifetime.js.map +1 -0
  87. package/dist/pulse/default-lock-limit.d.ts +3 -0
  88. package/dist/pulse/default-lock-limit.js +13 -0
  89. package/dist/pulse/default-lock-limit.js.map +1 -0
  90. package/dist/pulse/define.d.ts +23 -0
  91. package/dist/pulse/define.js +34 -0
  92. package/dist/pulse/define.js.map +1 -0
  93. package/dist/pulse/disable.d.ts +3 -0
  94. package/dist/pulse/disable.js +22 -0
  95. package/dist/pulse/disable.js.map +1 -0
  96. package/dist/pulse/drain.d.ts +2 -0
  97. package/dist/pulse/drain.js +26 -0
  98. package/dist/pulse/drain.js.map +1 -0
  99. package/dist/pulse/enable.d.ts +3 -0
  100. package/dist/pulse/enable.js +22 -0
  101. package/dist/pulse/enable.js.map +1 -0
  102. package/dist/pulse/every.d.ts +4 -0
  103. package/dist/pulse/every.js +37 -0
  104. package/dist/pulse/every.js.map +1 -0
  105. package/dist/pulse/find-and-lock-next-job.d.ts +3 -0
  106. package/dist/pulse/find-and-lock-next-job.js +43 -0
  107. package/dist/pulse/find-and-lock-next-job.js.map +1 -0
  108. package/dist/pulse/has-mongo-protocol.d.ts +1 -0
  109. package/dist/pulse/has-mongo-protocol.js +8 -0
  110. package/dist/pulse/has-mongo-protocol.js.map +1 -0
  111. package/dist/pulse/index.d.ts +115 -0
  112. package/dist/pulse/index.js +208 -0
  113. package/dist/pulse/index.js.map +1 -0
  114. package/dist/pulse/job-processing-queue.d.ts +11 -0
  115. package/dist/pulse/job-processing-queue.js +51 -0
  116. package/dist/pulse/job-processing-queue.js.map +1 -0
  117. package/dist/pulse/jobs.d.ts +6 -0
  118. package/dist/pulse/jobs.js +14 -0
  119. package/dist/pulse/jobs.js.map +1 -0
  120. package/dist/pulse/lock-limit.d.ts +3 -0
  121. package/dist/pulse/lock-limit.js +13 -0
  122. package/dist/pulse/lock-limit.js.map +1 -0
  123. package/dist/pulse/max-concurrency.d.ts +3 -0
  124. package/dist/pulse/max-concurrency.js +13 -0
  125. package/dist/pulse/max-concurrency.js.map +1 -0
  126. package/dist/pulse/mongo.d.ts +4 -0
  127. package/dist/pulse/mongo.js +10 -0
  128. package/dist/pulse/mongo.js.map +1 -0
  129. package/dist/pulse/name.d.ts +3 -0
  130. package/dist/pulse/name.js +13 -0
  131. package/dist/pulse/name.js.map +1 -0
  132. package/dist/pulse/now.d.ts +3 -0
  133. package/dist/pulse/now.js +21 -0
  134. package/dist/pulse/now.js.map +1 -0
  135. package/dist/pulse/process-every.d.ts +3 -0
  136. package/dist/pulse/process-every.js +14 -0
  137. package/dist/pulse/process-every.js.map +1 -0
  138. package/dist/pulse/purge.d.ts +2 -0
  139. package/dist/pulse/purge.js +13 -0
  140. package/dist/pulse/purge.js.map +1 -0
  141. package/dist/pulse/resume-on-restart.d.ts +3 -0
  142. package/dist/pulse/resume-on-restart.js +39 -0
  143. package/dist/pulse/resume-on-restart.js.map +1 -0
  144. package/dist/pulse/save-job.d.ts +4 -0
  145. package/dist/pulse/save-job.js +104 -0
  146. package/dist/pulse/save-job.js.map +1 -0
  147. package/dist/pulse/schedule.d.ts +4 -0
  148. package/dist/pulse/schedule.js +36 -0
  149. package/dist/pulse/schedule.js.map +1 -0
  150. package/dist/pulse/sort.d.ts +3 -0
  151. package/dist/pulse/sort.js +13 -0
  152. package/dist/pulse/sort.js.map +1 -0
  153. package/dist/pulse/start.d.ts +2 -0
  154. package/dist/pulse/start.js +19 -0
  155. package/dist/pulse/start.js.map +1 -0
  156. package/dist/pulse/stop.d.ts +2 -0
  157. package/dist/pulse/stop.js +38 -0
  158. package/dist/pulse/stop.js.map +1 -0
  159. package/dist/utils/create-job.d.ts +3 -0
  160. package/dist/utils/create-job.js +10 -0
  161. package/dist/utils/create-job.js.map +1 -0
  162. package/dist/utils/error.d.ts +12 -0
  163. package/dist/utils/error.js +34 -0
  164. package/dist/utils/error.js.map +1 -0
  165. package/dist/utils/index.d.ts +4 -0
  166. package/dist/utils/index.js +8 -0
  167. package/dist/utils/index.js.map +1 -0
  168. package/dist/utils/parse-priority.d.ts +1 -0
  169. package/dist/utils/parse-priority.js +31 -0
  170. package/dist/utils/parse-priority.js.map +1 -0
  171. package/dist/utils/process-jobs.d.ts +3 -0
  172. package/dist/utils/process-jobs.js +203 -0
  173. package/dist/utils/process-jobs.js.map +1 -0
  174. 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,3 @@
1
+ import { Pulse } from '.';
2
+ export type LockLimitMethod = (limit: number) => Pulse;
3
+ export declare const lockLimit: LockLimitMethod;
@@ -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,3 @@
1
+ import { Pulse } from '.';
2
+ export type MaxConcurrencyMethod = (concurrency: number) => Pulse;
3
+ export declare const maxConcurrency: MaxConcurrencyMethod;
@@ -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,4 @@
1
+ import { AnyError, Collection, Db } from 'mongodb';
2
+ import { Pulse } from '.';
3
+ export type MongoMethod = (mdb: Db, collection?: string, cb?: (error: AnyError | undefined, collection: Collection<any> | null) => void) => Pulse;
4
+ export declare const mongo: MongoMethod;
@@ -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,3 @@
1
+ import { Pulse } from '.';
2
+ export type NameMethod = (name: string) => Pulse;
3
+ export declare const name: NameMethod;
@@ -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,3 @@
1
+ import { Job, JobAttributesData } from '../job';
2
+ export type NowMethod = <T extends JobAttributesData>(name: string, data?: T) => Promise<Job>;
3
+ export declare const now: NowMethod;
@@ -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,3 @@
1
+ import { Pulse } from '.';
2
+ export type ProcessEveryMethod = (time: string) => Pulse;
3
+ export declare const processEvery: ProcessEveryMethod;
@@ -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,2 @@
1
+ export type PurgeMethod = () => Promise<number | undefined>;
2
+ export declare const purge: PurgeMethod;
@@ -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,3 @@
1
+ import { Pulse } from '.';
2
+ export type ResumeOnRestartMethod = (resume?: boolean) => Pulse;
3
+ export declare const resumeOnRestart: ResumeOnRestartMethod;
@@ -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