@eggjs/schedule 5.0.1 → 6.0.0-beta.13

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 (110) hide show
  1. package/README.md +8 -14
  2. package/dist/agent.d.ts +13 -0
  3. package/dist/agent.js +32 -0
  4. package/dist/app/extend/agent.d.ts +22 -0
  5. package/dist/app/extend/agent.js +32 -0
  6. package/dist/app/extend/application.d.ts +16 -0
  7. package/dist/app/extend/application.js +18 -0
  8. package/dist/app/extend/application.unittest.d.ts +13 -0
  9. package/dist/app/extend/application.unittest.js +43 -0
  10. package/dist/app.d.ts +11 -0
  11. package/dist/app.js +69 -0
  12. package/dist/config/config.default.d.ts +6 -0
  13. package/dist/config/config.default.js +13 -0
  14. package/dist/index.d.ts +7 -0
  15. package/dist/index.js +7 -0
  16. package/dist/lib/load_schedule.d.ts +7 -0
  17. package/dist/lib/load_schedule.js +61 -0
  18. package/dist/lib/schedule.d.ts +35 -0
  19. package/dist/lib/schedule.js +77 -0
  20. package/dist/lib/schedule_worker.d.ts +14 -0
  21. package/dist/lib/schedule_worker.js +22 -0
  22. package/dist/lib/strategy/all.d.ts +8 -0
  23. package/dist/lib/strategy/all.js +11 -0
  24. package/dist/lib/strategy/base.d.ts +35 -0
  25. package/dist/lib/strategy/base.js +73 -0
  26. package/dist/lib/strategy/timer.d.ts +24 -0
  27. package/dist/lib/strategy/timer.js +71 -0
  28. package/dist/lib/strategy/worker.d.ts +8 -0
  29. package/dist/lib/strategy/worker.js +11 -0
  30. package/dist/lib/types.d.ts +44 -0
  31. package/dist/lib/types.js +1 -0
  32. package/package.json +51 -55
  33. package/dist/commonjs/agent.d.ts +0 -7
  34. package/dist/commonjs/agent.js +0 -32
  35. package/dist/commonjs/app/extend/agent.d.ts +0 -2
  36. package/dist/commonjs/app/extend/agent.js +0 -29
  37. package/dist/commonjs/app/extend/application.d.ts +0 -2
  38. package/dist/commonjs/app/extend/application.js +0 -16
  39. package/dist/commonjs/app/extend/application.unittest.d.ts +0 -2
  40. package/dist/commonjs/app/extend/application.unittest.js +0 -58
  41. package/dist/commonjs/app.d.ts +0 -6
  42. package/dist/commonjs/app.js +0 -80
  43. package/dist/commonjs/config/config.default.d.ts +0 -2
  44. package/dist/commonjs/config/config.default.js +0 -17
  45. package/dist/commonjs/index.d.ts +0 -1
  46. package/dist/commonjs/index.js +0 -18
  47. package/dist/commonjs/lib/load_schedule.d.ts +0 -3
  48. package/dist/commonjs/lib/load_schedule.js +0 -71
  49. package/dist/commonjs/lib/schedule.d.ts +0 -31
  50. package/dist/commonjs/lib/schedule.js +0 -89
  51. package/dist/commonjs/lib/schedule_worker.d.ts +0 -10
  52. package/dist/commonjs/lib/schedule_worker.js +0 -22
  53. package/dist/commonjs/lib/strategy/all.d.ts +0 -4
  54. package/dist/commonjs/lib/strategy/all.js +0 -11
  55. package/dist/commonjs/lib/strategy/base.d.ts +0 -30
  56. package/dist/commonjs/lib/strategy/base.js +0 -79
  57. package/dist/commonjs/lib/strategy/timer.d.ts +0 -20
  58. package/dist/commonjs/lib/strategy/timer.js +0 -99
  59. package/dist/commonjs/lib/strategy/worker.d.ts +0 -4
  60. package/dist/commonjs/lib/strategy/worker.js +0 -11
  61. package/dist/commonjs/lib/types.d.ts +0 -53
  62. package/dist/commonjs/lib/types.js +0 -3
  63. package/dist/commonjs/package.json +0 -3
  64. package/dist/esm/agent.d.ts +0 -7
  65. package/dist/esm/agent.js +0 -29
  66. package/dist/esm/app/extend/agent.d.ts +0 -2
  67. package/dist/esm/app/extend/agent.js +0 -27
  68. package/dist/esm/app/extend/application.d.ts +0 -2
  69. package/dist/esm/app/extend/application.js +0 -14
  70. package/dist/esm/app/extend/application.unittest.d.ts +0 -2
  71. package/dist/esm/app/extend/application.unittest.js +0 -53
  72. package/dist/esm/app.d.ts +0 -6
  73. package/dist/esm/app.js +0 -77
  74. package/dist/esm/config/config.default.d.ts +0 -2
  75. package/dist/esm/config/config.default.js +0 -15
  76. package/dist/esm/index.d.ts +0 -1
  77. package/dist/esm/index.js +0 -2
  78. package/dist/esm/lib/load_schedule.d.ts +0 -3
  79. package/dist/esm/lib/load_schedule.js +0 -65
  80. package/dist/esm/lib/schedule.d.ts +0 -31
  81. package/dist/esm/lib/schedule.js +0 -85
  82. package/dist/esm/lib/schedule_worker.d.ts +0 -10
  83. package/dist/esm/lib/schedule_worker.js +0 -18
  84. package/dist/esm/lib/strategy/all.d.ts +0 -4
  85. package/dist/esm/lib/strategy/all.js +0 -7
  86. package/dist/esm/lib/strategy/base.d.ts +0 -30
  87. package/dist/esm/lib/strategy/base.js +0 -75
  88. package/dist/esm/lib/strategy/timer.d.ts +0 -20
  89. package/dist/esm/lib/strategy/timer.js +0 -92
  90. package/dist/esm/lib/strategy/worker.d.ts +0 -4
  91. package/dist/esm/lib/strategy/worker.js +0 -7
  92. package/dist/esm/lib/types.d.ts +0 -53
  93. package/dist/esm/lib/types.js +0 -2
  94. package/dist/esm/package.json +0 -3
  95. package/dist/package.json +0 -4
  96. package/src/agent.ts +0 -36
  97. package/src/app/extend/agent.ts +0 -30
  98. package/src/app/extend/application.ts +0 -16
  99. package/src/app/extend/application.unittest.ts +0 -57
  100. package/src/app.ts +0 -92
  101. package/src/config/config.default.ts +0 -17
  102. package/src/index.ts +0 -1
  103. package/src/lib/load_schedule.ts +0 -74
  104. package/src/lib/schedule.ts +0 -100
  105. package/src/lib/schedule_worker.ts +0 -24
  106. package/src/lib/strategy/all.ts +0 -7
  107. package/src/lib/strategy/base.ts +0 -91
  108. package/src/lib/strategy/timer.ts +0 -106
  109. package/src/lib/strategy/worker.ts +0 -7
  110. package/src/lib/types.ts +0 -58
@@ -1,75 +0,0 @@
1
- export class BaseStrategy {
2
- agent;
3
- scheduleConfig;
4
- key;
5
- logger;
6
- closed = false;
7
- count = 0;
8
- constructor(scheduleConfig, agent, key) {
9
- this.agent = agent;
10
- this.key = key;
11
- this.scheduleConfig = scheduleConfig;
12
- this.logger = this.agent.getLogger('scheduleLogger');
13
- }
14
- /** keep compatibility */
15
- get schedule() {
16
- return this.scheduleConfig;
17
- }
18
- start() {
19
- // empty loop by default
20
- }
21
- close() {
22
- this.closed = true;
23
- }
24
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
25
- onJobStart(_info) { }
26
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
27
- onJobFinish(_info) { }
28
- /**
29
- * trigger one worker
30
- *
31
- * @param {...any} args - pass to job task
32
- */
33
- sendOne(...args) {
34
- /* istanbul ignore next */
35
- if (this.agent.schedule.closed) {
36
- this.logger.warn(`${this.key} skip due to schedule closed`);
37
- return;
38
- }
39
- this.count++;
40
- const info = {
41
- key: this.key,
42
- id: this.getSeqId(),
43
- args,
44
- };
45
- this.logger.info(`[Job#${info.id}] ${info.key} triggered, send random by agent`);
46
- this.agent.messenger.sendRandom('egg-schedule', info);
47
- this.onJobStart(info);
48
- }
49
- /**
50
- * trigger all worker
51
- *
52
- * @param {...any} args - pass to job task
53
- */
54
- sendAll(...args) {
55
- /* istanbul ignore next */
56
- if (this.agent.schedule.closed) {
57
- this.logger.warn(`${this.key} skip due to schedule closed`);
58
- return;
59
- }
60
- this.count++;
61
- const info = {
62
- key: this.key,
63
- id: this.getSeqId(),
64
- args,
65
- };
66
- this.logger.info(`[Job#${info.id}] ${info.key} triggered, send all by agent`);
67
- // send to all workers
68
- this.agent.messenger.send('egg-schedule', info);
69
- this.onJobStart(info);
70
- }
71
- getSeqId() {
72
- return `${Date.now()}${process.hrtime().join('')}${this.count}`;
73
- }
74
- }
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc3RyYXRlZ3kvYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sWUFBWTtJQUNiLEtBQUssQ0FBUTtJQUNiLGNBQWMsQ0FBb0I7SUFDbEMsR0FBRyxDQUFTO0lBQ1osTUFBTSxDQUFZO0lBQ2xCLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDekIsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUVWLFlBQVksY0FBaUMsRUFBRSxLQUFZLEVBQUUsR0FBVztRQUN0RSxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztRQUNmLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRUQseUJBQXlCO0lBQ3pCLElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQztJQUM3QixDQUFDO0lBRUQsS0FBSztRQUNILHdCQUF3QjtJQUMxQixDQUFDO0lBRUQsS0FBSztRQUNILElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO0lBQ3JCLENBQUM7SUFFRCw2REFBNkQ7SUFDN0QsVUFBVSxDQUFDLEtBQXlCLElBQUcsQ0FBQztJQUV4Qyw2REFBNkQ7SUFDN0QsV0FBVyxDQUFDLEtBQXlCLElBQUcsQ0FBQztJQUV6Qzs7OztPQUlHO0lBQ0gsT0FBTyxDQUFDLEdBQUcsSUFBVztRQUNwQiwwQkFBMEI7UUFDMUIsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLDhCQUE4QixDQUFDLENBQUM7WUFDNUQsT0FBTztRQUNULENBQUM7UUFFRCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFFYixNQUFNLElBQUksR0FBRztZQUNYLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBRztZQUNiLEVBQUUsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ25CLElBQUk7U0FDaUIsQ0FBQztRQUV4QixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxFQUFFLEtBQUssSUFBSSxDQUFDLEdBQUcsa0NBQWtDLENBQUMsQ0FBQztRQUNqRixJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsY0FBYyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3RELElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxPQUFPLENBQUMsR0FBRyxJQUFXO1FBQ3BCLDBCQUEwQjtRQUMxQixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQy9CLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsOEJBQThCLENBQUMsQ0FBQztZQUM1RCxPQUFPO1FBQ1QsQ0FBQztRQUVELElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUViLE1BQU0sSUFBSSxHQUFHO1lBQ1gsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFHO1lBQ2IsRUFBRSxFQUFFLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDbkIsSUFBSTtTQUNpQixDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLEVBQUUsS0FBSyxJQUFJLENBQUMsR0FBRywrQkFBK0IsQ0FBQyxDQUFDO1FBQzlFLHNCQUFzQjtRQUN0QixJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ2hELElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFPLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxHQUFHLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ2xFLENBQUM7Q0FDRiJ9
@@ -1,20 +0,0 @@
1
- import { type CronExpression } from 'cron-parser';
2
- import safeTimers from 'safe-timers';
3
- import type { Agent } from 'egg';
4
- import type { EggScheduleConfig } from '../types.js';
5
- import { BaseStrategy } from './base.js';
6
- export declare abstract class TimerStrategy extends BaseStrategy {
7
- #private;
8
- protected cronInstance?: CronExpression;
9
- constructor(scheduleConfig: EggScheduleConfig, agent: Agent, key: string);
10
- protected handler(): void;
11
- start(): void;
12
- onJobStart(): void;
13
- /**
14
- * calculate next tick
15
- *
16
- * @return {Number|undefined} time interval, if out of range then return `undefined`
17
- */
18
- protected getNextTick(): number | undefined;
19
- protected safeTimeout(handler: () => void, delay: number, ...args: any[]): number | safeTimers.Timeout;
20
- }
@@ -1,92 +0,0 @@
1
- import assert from 'node:assert';
2
- import { parseExpression } from 'cron-parser';
3
- import { ms } from 'humanize-ms';
4
- import safeTimers from 'safe-timers';
5
- import { logDate } from 'utility';
6
- import { BaseStrategy } from './base.js';
7
- export class TimerStrategy extends BaseStrategy {
8
- cronInstance;
9
- constructor(scheduleConfig, agent, key) {
10
- super(scheduleConfig, agent, key);
11
- const { interval, cron, cronOptions, immediate } = this.scheduleConfig;
12
- assert(interval || cron || immediate, `[@eggjs/schedule] ${this.key} \`schedule.interval\` or \`schedule.cron\` or \`schedule.immediate\` must be present`);
13
- // init cron parser
14
- if (cron) {
15
- try {
16
- this.cronInstance = parseExpression(cron, cronOptions);
17
- }
18
- catch (err) {
19
- throw new TypeError(`[@eggjs/schedule] ${this.key} parse cron instruction(${cron}) error: ${err.message}`, { cause: err });
20
- }
21
- }
22
- }
23
- handler() {
24
- throw new TypeError(`[@eggjs/schedule] ${this.key} strategy should override \`handler()\` method`);
25
- }
26
- start() {
27
- /* istanbul ignore next */
28
- if (this.agent.schedule.closed)
29
- return;
30
- if (this.scheduleConfig.immediate) {
31
- this.logger.info(`[Timer] ${this.key} next time will execute immediate`);
32
- setImmediate(() => this.handler());
33
- }
34
- else {
35
- this.#scheduleNext();
36
- }
37
- }
38
- #scheduleNext() {
39
- /* istanbul ignore next */
40
- if (this.agent.schedule.closed)
41
- return;
42
- // get next tick
43
- const nextTick = this.getNextTick();
44
- if (nextTick) {
45
- this.logger.info(`[Timer] ${this.key} next time will execute after ${nextTick}ms at ${logDate(new Date(Date.now() + nextTick))}`);
46
- this.safeTimeout(() => this.handler(), nextTick);
47
- }
48
- else {
49
- this.logger.info(`[Timer] ${this.key} reach endDate, will stop`);
50
- }
51
- }
52
- onJobStart() {
53
- // Next execution will trigger task at a fix rate, regardless of its execution time.
54
- this.#scheduleNext();
55
- }
56
- /**
57
- * calculate next tick
58
- *
59
- * @return {Number|undefined} time interval, if out of range then return `undefined`
60
- */
61
- getNextTick() {
62
- // interval-style
63
- if (this.scheduleConfig.interval) {
64
- return ms(this.scheduleConfig.interval);
65
- }
66
- // cron-style
67
- if (this.cronInstance) {
68
- // calculate next cron tick
69
- const now = Date.now();
70
- let nextTick;
71
- // loop to find next feature time
72
- do {
73
- try {
74
- const nextInterval = this.cronInstance.next();
75
- nextTick = nextInterval.getTime();
76
- }
77
- catch (err) {
78
- // Error: Out of the timespan range
79
- this.logger.info(`[Timer] ${this.key} cron out of the timespan range, error: %s`, err);
80
- return;
81
- }
82
- } while (now >= nextTick);
83
- return nextTick - now;
84
- }
85
- // won\'t run here
86
- }
87
- safeTimeout(handler, delay, ...args) {
88
- const fn = delay < safeTimers.maxInterval ? setTimeout : safeTimers.setTimeout;
89
- return fn(handler, delay, ...args);
90
- }
91
- }
92
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3N0cmF0ZWd5L3RpbWVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTSxNQUFNLGFBQWEsQ0FBQztBQUNqQyxPQUFPLEVBQUUsZUFBZSxFQUF1QixNQUFNLGFBQWEsQ0FBQztBQUNuRSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2pDLE9BQU8sVUFBVSxNQUFNLGFBQWEsQ0FBQztBQUNyQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBR2xDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFekMsTUFBTSxPQUFnQixhQUFjLFNBQVEsWUFBWTtJQUM1QyxZQUFZLENBQWtCO0lBRXhDLFlBQVksY0FBaUMsRUFBRSxLQUFZLEVBQUUsR0FBVztRQUN0RSxLQUFLLENBQUMsY0FBYyxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQztRQUVsQyxNQUFNLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQztRQUN2RSxNQUFNLENBQUMsUUFBUSxJQUFJLElBQUksSUFBSSxTQUFTLEVBQ2xDLHFCQUFxQixJQUFJLENBQUMsR0FBRyx1RkFBdUYsQ0FBQyxDQUFDO1FBRXhILG1CQUFtQjtRQUNuQixJQUFJLElBQUksRUFBRSxDQUFDO1lBQ1QsSUFBSSxDQUFDO2dCQUNILElBQUksQ0FBQyxZQUFZLEdBQUcsZUFBZSxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztZQUN6RCxDQUFDO1lBQUMsT0FBTyxHQUFRLEVBQUUsQ0FBQztnQkFDbEIsTUFBTSxJQUFJLFNBQVMsQ0FDakIscUJBQXFCLElBQUksQ0FBQyxHQUFHLDJCQUEyQixJQUFJLFlBQVksR0FBRyxDQUFDLE9BQU8sRUFBRSxFQUNyRixFQUFF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
@@ -1,4 +0,0 @@
1
- import { TimerStrategy } from './timer.js';
2
- export declare class WorkerStrategy extends TimerStrategy {
3
- handler(): void;
4
- }
@@ -1,7 +0,0 @@
1
- import { TimerStrategy } from './timer.js';
2
- export class WorkerStrategy extends TimerStrategy {
3
- handler() {
4
- this.sendOne();
5
- }
6
- }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zdHJhdGVneS93b3JrZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUUzQyxNQUFNLE9BQU8sY0FBZSxTQUFRLGFBQWE7SUFDL0MsT0FBTztRQUNMLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNqQixDQUFDO0NBQ0YifQ==
@@ -1,53 +0,0 @@
1
- import type { ParserOptions as CronOptions } from 'cron-parser';
2
- import type { Schedule } from './schedule.js';
3
- import type { ScheduleWorker } from './schedule_worker.js';
4
- /**
5
- * Schedule Config
6
- * @see https://www.eggjs.org/zh-CN/basics/schedule
7
- */
8
- export interface EggScheduleConfig {
9
- type?: 'worker' | 'all';
10
- interval?: string | number;
11
- cron?: string;
12
- cronOptions?: CronOptions;
13
- immediate?: boolean;
14
- disable?: boolean;
15
- env?: string[];
16
- }
17
- export type EggScheduleTask = (ctx: any, ...args: any[]) => Promise<void>;
18
- export interface EggScheduleItem {
19
- schedule: EggScheduleConfig;
20
- scheduleQueryString: string;
21
- task: EggScheduleTask;
22
- key: string;
23
- }
24
- export interface EggScheduleJobInfo {
25
- id: string;
26
- key: string;
27
- workerId: number;
28
- args: any[];
29
- success?: boolean;
30
- message?: string;
31
- rt?: number;
32
- }
33
- declare module 'egg' {
34
- interface EggScheduleAgent {
35
- schedule: Schedule;
36
- }
37
- interface Agent extends EggScheduleAgent {
38
- }
39
- interface EggScheduleApplication {
40
- scheduleWorker: ScheduleWorker;
41
- /** runSchedule in unittest */
42
- runSchedule: (schedulePath: string, ...args: any[]) => Promise<void>;
43
- }
44
- interface Application extends EggScheduleApplication {
45
- }
46
- interface EggScheduleAppConfig {
47
- schedule: {
48
- directory: string[];
49
- };
50
- }
51
- interface EggAppConfig extends EggScheduleAppConfig {
52
- }
53
- }
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
@@ -1,3 +0,0 @@
1
- {
2
- "type": "module"
3
- }
package/dist/package.json DELETED
@@ -1,4 +0,0 @@
1
- {
2
- "name": "@eggjs/schedule",
3
- "version": "5.0.1"
4
- }
package/src/agent.ts DELETED
@@ -1,36 +0,0 @@
1
- import { debuglog } from 'node:util';
2
- import type { Agent, ILifecycleBoot } from 'egg';
3
- import { WorkerStrategy } from './lib/strategy/worker.js';
4
- import { AllStrategy } from './lib/strategy/all.js';
5
- import { EggScheduleJobInfo } from './lib/types.js';
6
-
7
- const debug = debuglog('@eggjs/schedule/agent');
8
-
9
- export default class Boot implements ILifecycleBoot {
10
- #agent: Agent;
11
- constructor(agent: Agent) {
12
- this.#agent = agent;
13
- }
14
-
15
- async configDidLoad(): Promise<void> {
16
- // register built-in strategy
17
- this.#agent.schedule.use('worker', WorkerStrategy);
18
- this.#agent.schedule.use('all', AllStrategy);
19
-
20
- // wait for other plugin to register custom strategy
21
- await this.#agent.schedule.init();
22
-
23
- // dispatch job finish event to strategy
24
- this.#agent.messenger.on('egg-schedule', (info: EggScheduleJobInfo) => {
25
- // get job info from worker
26
- this.#agent.schedule.onJobFinish(info);
27
- });
28
- debug('configDidLoad');
29
- }
30
-
31
- async serverDidReady(): Promise<void> {
32
- // start schedule after worker ready
33
- this.#agent.schedule.start();
34
- debug('serverDidReady, schedule start');
35
- }
36
- }
@@ -1,30 +0,0 @@
1
- import { BaseStrategy } from '../../lib/strategy/base.js';
2
- import { TimerStrategy } from '../../lib/strategy/timer.js';
3
- import { Schedule } from '../../lib/schedule.js';
4
-
5
- const SCHEDULE = Symbol('agent#schedule');
6
-
7
- export default {
8
- /**
9
- * @member agent#ScheduleStrategy
10
- */
11
- ScheduleStrategy: BaseStrategy,
12
-
13
- /**
14
- * @member agent#TimerScheduleStrategy
15
- */
16
- TimerScheduleStrategy: TimerStrategy,
17
-
18
- /**
19
- * @member agent#schedule
20
- */
21
- get schedule() {
22
- if (!this[SCHEDULE]) {
23
- this[SCHEDULE] = new Schedule(this);
24
- this.lifecycle.registerBeforeClose(() => {
25
- return this[SCHEDULE].close();
26
- });
27
- }
28
- return this[SCHEDULE];
29
- },
30
- } as any;
@@ -1,16 +0,0 @@
1
- import { ScheduleWorker } from '../../lib/schedule_worker.js';
2
-
3
- const SCHEDULE_WORKER = Symbol('application#scheduleWorker');
4
-
5
- export default {
6
- /**
7
- * @member app#schedule
8
- */
9
- get scheduleWorker() {
10
- if (!this[SCHEDULE_WORKER]) {
11
- this[SCHEDULE_WORKER] = new ScheduleWorker(this);
12
- }
13
- return this[SCHEDULE_WORKER];
14
- },
15
- } as any;
16
-
@@ -1,57 +0,0 @@
1
- import { debuglog } from 'node:util';
2
- import path from 'node:path';
3
- import { importResolve } from '@eggjs/utils';
4
- import type { ScheduleWorker } from '../../lib/schedule_worker.js';
5
- import type { EggScheduleItem } from '../../lib/types.js';
6
-
7
- const debug = debuglog('@eggjs/schedule/app');
8
-
9
- export default {
10
- async runSchedule(schedulePath: string, ...args: any[]) {
11
- debug('[runSchedule] start schedulePath: %o, args: %o', schedulePath, args);
12
- // for test purpose
13
- const config = this.config;
14
- const directory = [
15
- path.join(config.baseDir, 'app/schedule'),
16
- ...config.schedule.directory,
17
- ];
18
-
19
- // resolve real path
20
- if (path.isAbsolute(schedulePath)) {
21
- schedulePath = importResolve(schedulePath);
22
- } else {
23
- for (const dir of directory) {
24
- const trySchedulePath = path.join(dir, schedulePath);
25
- try {
26
- schedulePath = importResolve(trySchedulePath);
27
- break;
28
- } catch (err) {
29
- debug('[runSchedule] importResolve %o error: %s', trySchedulePath, err);
30
- }
31
- }
32
- }
33
-
34
- debug('[runSchedule] resolve schedulePath: %o', schedulePath);
35
- const scheduleWorker: ScheduleWorker = this.scheduleWorker;
36
- let schedule: EggScheduleItem;
37
- try {
38
- schedule = scheduleWorker.scheduleItems[schedulePath];
39
- if (!schedule) {
40
- throw new TypeError(`Cannot find schedule ${schedulePath}`);
41
- }
42
- } catch (err: any) {
43
- err.message = `[@eggjs/schedule] ${err.message}`;
44
- throw err;
45
- }
46
-
47
- // run with anonymous context
48
- const ctx = this.createAnonymousContext({
49
- method: 'SCHEDULE',
50
- url: `/__schedule?path=${schedulePath}&${schedule.scheduleQueryString}`,
51
- });
52
- return await this.ctxStorage.run(ctx, async () => {
53
- return await schedule.task(ctx, ...args);
54
- });
55
- },
56
- } as any;
57
-
package/src/app.ts DELETED
@@ -1,92 +0,0 @@
1
- import { debuglog } from 'node:util';
2
- import type {
3
- Application, ILifecycleBoot, EggLogger,
4
- } from 'egg';
5
- import type { EggScheduleJobInfo } from './lib/types.js';
6
-
7
- const debug = debuglog('@eggjs/schedule/app');
8
-
9
- export default class Boot implements ILifecycleBoot {
10
- #app: Application;
11
- #logger: EggLogger;
12
- constructor(app: Application) {
13
- this.#app = app;
14
- this.#logger = app.getLogger('scheduleLogger');
15
- }
16
-
17
- async configDidLoad(): Promise<void> {
18
- const scheduleWorker = this.#app.scheduleWorker;
19
- await scheduleWorker.init();
20
-
21
- // log schedule list
22
- for (const s in scheduleWorker.scheduleItems) {
23
- const schedule = scheduleWorker.scheduleItems[s];
24
- if (!schedule.schedule.disable) {
25
- this.#logger.info('[@eggjs/schedule]: register schedule %s', schedule.key);
26
- }
27
- }
28
-
29
- // register schedule event
30
- this.#app.messenger.on('egg-schedule', async info => {
31
- debug('app got "egg-schedule" message: %o', info);
32
- const { id, key } = info;
33
- this.#logger.debug(`[Job#${id}] ${key} await app ready`);
34
- await this.#app.ready();
35
- const schedule = scheduleWorker.scheduleItems[key];
36
- this.#logger.debug(`[Job#${id}] ${key} task received by app`);
37
-
38
- if (!schedule) {
39
- this.#logger.warn(`[Job#${id}] ${key} unknown task`);
40
- return;
41
- }
42
-
43
- /* istanbul ignore next */
44
- if (schedule.schedule.disable) {
45
- this.#logger.warn(`[Job#${id}] ${key} disable`);
46
- return;
47
- }
48
-
49
- this.#logger.info(`[Job#${id}] ${key} executing by app`);
50
-
51
- // run with anonymous context
52
- const ctx = this.#app.createAnonymousContext({
53
- method: 'SCHEDULE',
54
- url: `/__schedule?path=${key}&${schedule.scheduleQueryString}`,
55
- });
56
-
57
- const start = Date.now();
58
-
59
- let success: boolean;
60
- let e: Error | undefined;
61
- try {
62
- // execute
63
- await this.#app.ctxStorage.run(ctx, async () => {
64
- return await schedule.task(ctx, ...info.args);
65
- });
66
- success = true;
67
- } catch (err: any) {
68
- success = false;
69
- e = err;
70
- }
71
-
72
- const rt = Date.now() - start;
73
-
74
- const msg = `[Job#${id}] ${key} execute ${success ? 'succeed' : 'failed'}, used ${rt}ms.`;
75
- if (success) {
76
- this.#logger.info(msg);
77
- } else {
78
- this.#logger.error(msg, e);
79
- }
80
-
81
- // notify agent job finish
82
- this.#app.messenger.sendToAgent('egg-schedule', {
83
- ...info,
84
- success,
85
- workerId: process.pid,
86
- rt,
87
- message: e?.message,
88
- } as EggScheduleJobInfo);
89
- });
90
- debug('configDidLoad');
91
- }
92
- }
@@ -1,17 +0,0 @@
1
- export default () => {
2
- const config = {} as Record<string, any>;
3
-
4
- config.customLogger = {
5
- scheduleLogger: {
6
- consoleLevel: 'NONE',
7
- file: 'egg-schedule.log',
8
- },
9
- };
10
-
11
- config.schedule = {
12
- // custom additional directory, full path
13
- directory: [],
14
- };
15
-
16
- return config;
17
- };
package/src/index.ts DELETED
@@ -1 +0,0 @@
1
- export * from './lib/types.js';
@@ -1,74 +0,0 @@
1
- import path from 'node:path';
2
- import assert from 'node:assert';
3
- import { stringify } from 'node:querystring';
4
- import { isClass, isFunction, isGeneratorFunction } from 'is-type-of';
5
- import { importResolve } from '@eggjs/utils';
6
- import type { EggApplicationCore, EggContext } from 'egg';
7
- import type { EggScheduleConfig, EggScheduleTask, EggScheduleItem } from './types.js';
8
-
9
- function getScheduleLoader(app: EggApplicationCore) {
10
- return class ScheduleLoader extends app.loader.FileLoader {
11
- async load() {
12
- const target = this.options.target as Record<string, EggScheduleItem>;
13
- const items = await this.parse();
14
- for (const item of items) {
15
- const schedule = item.exports as { schedule: EggScheduleConfig, task: EggScheduleTask };
16
- const fullpath = item.fullpath;
17
- const scheduleConfig = schedule.schedule;
18
- assert(scheduleConfig, `schedule(${fullpath}): must have "schedule" and "task" properties`);
19
- assert(isClass(schedule) || isFunction(schedule.task),
20
- `schedule(${fullpath}: \`schedule.task\` should be function or \`schedule\` should be class`);
21
-
22
- let task: EggScheduleTask;
23
- if (isClass(schedule)) {
24
- assert(!isGeneratorFunction(schedule.prototype.subscribe),
25
- `schedule(${fullpath}): "schedule" generator function is not support, should use async function instead`);
26
- task = async (ctx: EggContext, ...args: any[]) => {
27
- const instance = new schedule(ctx);
28
- // s.subscribe = app.toAsyncFunction(s.subscribe);
29
- return instance.subscribe(...args);
30
- };
31
- } else {
32
- assert(!isGeneratorFunction(schedule.task),
33
- `schedule(${fullpath}): "task" generator function is not support, should use async function instead`);
34
- task = schedule.task;
35
- // task = app.toAsyncFunction(schedule.task);
36
- }
37
-
38
- const env = app.config.env;
39
- const envList = schedule.schedule.env;
40
- if (Array.isArray(envList) && !envList.includes(env)) {
41
- app.coreLogger.info(`[@eggjs/schedule]: ignore schedule ${fullpath} due to \`schedule.env\` not match`);
42
- continue;
43
- }
44
-
45
- // handle symlink case
46
- const realFullpath = importResolve(fullpath);
47
- target[realFullpath] = {
48
- schedule: scheduleConfig,
49
- scheduleQueryString: stringify(scheduleConfig as any),
50
- task,
51
- key: realFullpath,
52
- };
53
- }
54
- return target;
55
- }
56
- };
57
- }
58
-
59
- export async function loadSchedule(app: EggApplicationCore) {
60
- const dirs = [
61
- ...app.loader.getLoadUnits().map(unit => path.join(unit.path, 'app/schedule')),
62
- ...app.config.schedule.directory,
63
- ];
64
-
65
- const Loader = getScheduleLoader(app);
66
- const schedules = {} as Record<string, EggScheduleItem>;
67
- await new Loader({
68
- directory: dirs,
69
- target: schedules,
70
- inject: app,
71
- }).load();
72
- Reflect.set(app, 'schedules', schedules);
73
- return schedules;
74
- }