@nocobase/plugin-workflow 2.1.0-beta.1 → 2.1.0-beta.10
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 +201 -661
- package/README.md +79 -10
- package/dist/client/0e458d99e9fc5e65.js +10 -0
- package/dist/client/index.js +1 -1
- package/dist/externalVersion.js +12 -12
- package/dist/locale/zh-CN.json +2 -1
- package/dist/node_modules/cron-parser/package.json +1 -1
- package/dist/node_modules/lru-cache/package.json +1 -1
- package/dist/node_modules/nodejs-snowflake/package.json +1 -1
- package/dist/server/Dispatcher.d.ts +3 -2
- package/dist/server/Dispatcher.js +74 -61
- package/dist/swagger/index.d.ts +814 -62
- package/dist/swagger/index.js +975 -205
- package/package.json +3 -3
- package/dist/client/c1347b9d21f864d9.js +0 -10
package/dist/externalVersion.js
CHANGED
|
@@ -11,8 +11,8 @@ module.exports = {
|
|
|
11
11
|
"react": "18.2.0",
|
|
12
12
|
"@formily/core": "2.3.7",
|
|
13
13
|
"@formily/react": "2.3.7",
|
|
14
|
-
"@nocobase/client": "2.1.0-beta.
|
|
15
|
-
"@nocobase/utils": "2.1.0-beta.
|
|
14
|
+
"@nocobase/client": "2.1.0-beta.10",
|
|
15
|
+
"@nocobase/utils": "2.1.0-beta.10",
|
|
16
16
|
"antd": "5.24.2",
|
|
17
17
|
"@ant-design/icons": "5.6.1",
|
|
18
18
|
"react-router-dom": "6.30.1",
|
|
@@ -20,18 +20,18 @@ module.exports = {
|
|
|
20
20
|
"lodash": "4.17.21",
|
|
21
21
|
"@dnd-kit/core": "6.1.0",
|
|
22
22
|
"@formily/shared": "2.3.7",
|
|
23
|
-
"@nocobase/flow-engine": "2.1.0-beta.
|
|
24
|
-
"@nocobase/plugin-mobile": "2.1.0-beta.
|
|
23
|
+
"@nocobase/flow-engine": "2.1.0-beta.10",
|
|
24
|
+
"@nocobase/plugin-mobile": "2.1.0-beta.10",
|
|
25
25
|
"sequelize": "6.35.2",
|
|
26
|
-
"@nocobase/server": "2.1.0-beta.
|
|
27
|
-
"@nocobase/database": "2.1.0-beta.
|
|
28
|
-
"@nocobase/data-source-manager": "2.1.0-beta.
|
|
29
|
-
"@nocobase/logger": "2.1.0-beta.
|
|
30
|
-
"@nocobase/evaluators": "2.1.0-beta.
|
|
26
|
+
"@nocobase/server": "2.1.0-beta.10",
|
|
27
|
+
"@nocobase/database": "2.1.0-beta.10",
|
|
28
|
+
"@nocobase/data-source-manager": "2.1.0-beta.10",
|
|
29
|
+
"@nocobase/logger": "2.1.0-beta.10",
|
|
30
|
+
"@nocobase/evaluators": "2.1.0-beta.10",
|
|
31
31
|
"@formily/antd-v5": "1.2.3",
|
|
32
32
|
"@formily/reactive": "2.3.7",
|
|
33
|
-
"@nocobase/actions": "2.1.0-beta.
|
|
33
|
+
"@nocobase/actions": "2.1.0-beta.10",
|
|
34
34
|
"dayjs": "1.11.13",
|
|
35
|
-
"@nocobase/plugin-workflow-test": "2.1.0-beta.
|
|
36
|
-
"@nocobase/test": "2.1.0-beta.
|
|
35
|
+
"@nocobase/plugin-workflow-test": "2.1.0-beta.10",
|
|
36
|
+
"@nocobase/test": "2.1.0-beta.10"
|
|
37
37
|
};
|
package/dist/locale/zh-CN.json
CHANGED
|
@@ -223,12 +223,13 @@
|
|
|
223
223
|
"The workflow tasks page has already been created.": "工作流待办页面已创建。",
|
|
224
224
|
"This is a main version, delete it will cause the whole workflow to be deleted (including all other revisions).": "当前是主版本,删除将导致整个流程被删除(包括所有其他版本)。",
|
|
225
225
|
"This node contains branches, deleting will also be preformed to them, are you sure?": "节点包含分支,将同时删除其所有分支下的子节点,确定继续?",
|
|
226
|
+
"This type of node can not be used in current type of workflow or execute mode.": "该类型的节点在当前类型的工作流或执行模式中不可用。",
|
|
226
227
|
"This type of trigger has not been supported to be executed manually.": "该类型的触发器暂未支持手动执行。",
|
|
227
228
|
"This will perform all the actions configured in the workflow. Are you sure you want to continue?": "将按照工作流中配置的所有操作执行,确定继续吗?",
|
|
228
229
|
"Trigger": "触发器",
|
|
229
230
|
"Trigger data": "触发数据",
|
|
230
231
|
"Trigger data context": "触发数据上下文",
|
|
231
|
-
"Trigger in executed workflow cannot be modified": "
|
|
232
|
+
"Trigger in executed workflow cannot be modified": "已执行的工作流中的触发器无法修改",
|
|
232
233
|
"Trigger mode": "触发模式",
|
|
233
234
|
"Trigger on": "触发时机",
|
|
234
235
|
"Trigger time": "触发时间",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"name":"cron-parser","version":"4.4.0","description":"Node.js library for parsing crontab instructions","main":"lib/parser.js","types":"index.d.ts","typesVersions":{"<4.1":{"*":["types/ts3/*"]}},"directories":{"test":"test"},"scripts":{"test:tsd":"tsd","test:unit":"TZ=UTC tap ./test/*.js","test:cover":"TZ=UTC tap --coverage-report=html ./test/*.js","lint":"eslint .","lint:fix":"eslint --fix .","test":"npm run lint && npm run test:unit && npm run test:tsd"},"repository":{"type":"git","url":"https://github.com/harrisiirak/cron-parser.git"},"keywords":["cron","crontab","parser"],"author":"Harri Siirak","contributors":["Nicholas Clawson","Daniel Prentis <daniel@salsitasoft.com>","Renault John Lecoultre","Richard Astbury <richard.astbury@gmail.com>","Meaglin Wasabi <Meaglin.wasabi@gmail.com>","Mike Kusold <hello@mikekusold.com>","Alex Kit <alex.kit@atmajs.com>","Santiago Gimeno <santiago.gimeno@gmail.com>","Daniel <darc.tec@gmail.com>","Christian Steininger <christian.steininger.cs@gmail.com>","Mykola Piskovyi <m.piskovyi@gmail.com>","Brian Vaughn <brian.david.vaughn@gmail.com>","Nicholas Clawson <nickclaw@gmail.com>","Yasuhiroki <yasuhiroki.duck@gmail.com>","Nicholas Clawson <nickclaw@gmail.com>","Brendan Warkentin <faazshift@gmail.com>","Charlie Fish <fishcharlie.code@gmail.com>","Ian Graves <ian+diskimage@iangrav.es>","Andy Thompson <me@andytson.com>","Regev Brody <regevbr@gmail.com>"],"license":"MIT","dependencies":{"luxon":"^1.28.0"},"devDependencies":{"eslint":"^8.2.0","sinon":"^10.0.0","tap":"^16.0.1","tsd":"^0.19.0"},"engines":{"node":">=0.8"},"browser":{"fs":false},"tap":{"check-coverage":false},"tsd":{"directory":"test","compilerOptions":{"lib":["es2017","dom"]}},"_lastModified":"2026-
|
|
1
|
+
{"name":"cron-parser","version":"4.4.0","description":"Node.js library for parsing crontab instructions","main":"lib/parser.js","types":"index.d.ts","typesVersions":{"<4.1":{"*":["types/ts3/*"]}},"directories":{"test":"test"},"scripts":{"test:tsd":"tsd","test:unit":"TZ=UTC tap ./test/*.js","test:cover":"TZ=UTC tap --coverage-report=html ./test/*.js","lint":"eslint .","lint:fix":"eslint --fix .","test":"npm run lint && npm run test:unit && npm run test:tsd"},"repository":{"type":"git","url":"https://github.com/harrisiirak/cron-parser.git"},"keywords":["cron","crontab","parser"],"author":"Harri Siirak","contributors":["Nicholas Clawson","Daniel Prentis <daniel@salsitasoft.com>","Renault John Lecoultre","Richard Astbury <richard.astbury@gmail.com>","Meaglin Wasabi <Meaglin.wasabi@gmail.com>","Mike Kusold <hello@mikekusold.com>","Alex Kit <alex.kit@atmajs.com>","Santiago Gimeno <santiago.gimeno@gmail.com>","Daniel <darc.tec@gmail.com>","Christian Steininger <christian.steininger.cs@gmail.com>","Mykola Piskovyi <m.piskovyi@gmail.com>","Brian Vaughn <brian.david.vaughn@gmail.com>","Nicholas Clawson <nickclaw@gmail.com>","Yasuhiroki <yasuhiroki.duck@gmail.com>","Nicholas Clawson <nickclaw@gmail.com>","Brendan Warkentin <faazshift@gmail.com>","Charlie Fish <fishcharlie.code@gmail.com>","Ian Graves <ian+diskimage@iangrav.es>","Andy Thompson <me@andytson.com>","Regev Brody <regevbr@gmail.com>"],"license":"MIT","dependencies":{"luxon":"^1.28.0"},"devDependencies":{"eslint":"^8.2.0","sinon":"^10.0.0","tap":"^16.0.1","tsd":"^0.19.0"},"engines":{"node":">=0.8"},"browser":{"fs":false},"tap":{"check-coverage":false},"tsd":{"directory":"test","compilerOptions":{"lib":["es2017","dom"]}},"_lastModified":"2026-03-19T03:15:39.148Z"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"name":"lru-cache","description":"A cache object that deletes the least-recently-used items.","version":"8.0.5","author":"Isaac Z. Schlueter <i@izs.me>","keywords":["mru","lru","cache"],"sideEffects":false,"scripts":{"build":"npm run prepare","preprepare":"rm -rf dist","prepare":"tsc -p tsconfig.json && tsc -p tsconfig-esm.json","postprepare":"bash fixup.sh","pretest":"npm run prepare","presnap":"npm run prepare","test":"c8 tap","snap":"c8 tap","preversion":"npm test","postversion":"npm publish","prepublishOnly":"git push origin --follow-tags","format":"prettier --write .","typedoc":"typedoc --tsconfig tsconfig-esm.json ./src/*.ts","benchmark-results-typedoc":"bash scripts/benchmark-results-typedoc.sh","prebenchmark":"npm run prepare","benchmark":"make -C benchmark","preprofile":"npm run prepare","profile":"make -C benchmark profile"},"main":"./dist/cjs/index-cjs.js","module":"./dist/mjs/index.js","types":"./dist/mjs/index.d.ts","exports":{"./min":{"import":{"types":"./dist/mjs/index.d.ts","default":"./dist/mjs/index.min.js"},"require":{"types":"./dist/cjs/index.d.ts","default":"./dist/cjs/index.min.js"}},".":{"import":{"types":"./dist/mjs/index.d.ts","default":"./dist/mjs/index.js"},"require":{"types":"./dist/cjs/index.d.ts","default":"./dist/cjs/index-cjs.js"}}},"repository":"git://github.com/isaacs/node-lru-cache.git","devDependencies":{"@size-limit/preset-small-lib":"^7.0.8","@types/node":"^17.0.31","@types/tap":"^15.0.6","benchmark":"^2.1.4","c8":"^7.11.2","clock-mock":"^1.0.6","esbuild":"^0.17.11","eslint-config-prettier":"^8.5.0","marked":"^4.2.12","mkdirp":"^2.1.5","prettier":"^2.6.2","size-limit":"^7.0.8","tap":"^16.3.4","ts-node":"^10.7.0","tslib":"^2.4.0","typedoc":"^0.23.24","typescript":"^4.6.4"},"license":"ISC","files":["dist"],"engines":{"node":">=16.14"},"prettier":{"semi":false,"printWidth":70,"tabWidth":2,"useTabs":false,"singleQuote":true,"jsxSingleQuote":false,"bracketSameLine":true,"arrowParens":"avoid","endOfLine":"lf"},"tap":{"coverage":false,"node-arg":["--expose-gc","--no-warnings","--loader","ts-node/esm"],"ts":false},"size-limit":[{"path":"./dist/mjs/index.js"}],"_lastModified":"2026-
|
|
1
|
+
{"name":"lru-cache","description":"A cache object that deletes the least-recently-used items.","version":"8.0.5","author":"Isaac Z. Schlueter <i@izs.me>","keywords":["mru","lru","cache"],"sideEffects":false,"scripts":{"build":"npm run prepare","preprepare":"rm -rf dist","prepare":"tsc -p tsconfig.json && tsc -p tsconfig-esm.json","postprepare":"bash fixup.sh","pretest":"npm run prepare","presnap":"npm run prepare","test":"c8 tap","snap":"c8 tap","preversion":"npm test","postversion":"npm publish","prepublishOnly":"git push origin --follow-tags","format":"prettier --write .","typedoc":"typedoc --tsconfig tsconfig-esm.json ./src/*.ts","benchmark-results-typedoc":"bash scripts/benchmark-results-typedoc.sh","prebenchmark":"npm run prepare","benchmark":"make -C benchmark","preprofile":"npm run prepare","profile":"make -C benchmark profile"},"main":"./dist/cjs/index-cjs.js","module":"./dist/mjs/index.js","types":"./dist/mjs/index.d.ts","exports":{"./min":{"import":{"types":"./dist/mjs/index.d.ts","default":"./dist/mjs/index.min.js"},"require":{"types":"./dist/cjs/index.d.ts","default":"./dist/cjs/index.min.js"}},".":{"import":{"types":"./dist/mjs/index.d.ts","default":"./dist/mjs/index.js"},"require":{"types":"./dist/cjs/index.d.ts","default":"./dist/cjs/index-cjs.js"}}},"repository":"git://github.com/isaacs/node-lru-cache.git","devDependencies":{"@size-limit/preset-small-lib":"^7.0.8","@types/node":"^17.0.31","@types/tap":"^15.0.6","benchmark":"^2.1.4","c8":"^7.11.2","clock-mock":"^1.0.6","esbuild":"^0.17.11","eslint-config-prettier":"^8.5.0","marked":"^4.2.12","mkdirp":"^2.1.5","prettier":"^2.6.2","size-limit":"^7.0.8","tap":"^16.3.4","ts-node":"^10.7.0","tslib":"^2.4.0","typedoc":"^0.23.24","typescript":"^4.6.4"},"license":"ISC","files":["dist"],"engines":{"node":">=16.14"},"prettier":{"semi":false,"printWidth":70,"tabWidth":2,"useTabs":false,"singleQuote":true,"jsxSingleQuote":false,"bracketSameLine":true,"arrowParens":"avoid","endOfLine":"lf"},"tap":{"coverage":false,"node-arg":["--expose-gc","--no-warnings","--loader","ts-node/esm"],"ts":false},"size-limit":[{"path":"./dist/mjs/index.js"}],"_lastModified":"2026-03-19T03:15:38.852Z"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"name":"nodejs-snowflake","collaborators":["Utkarsh Srivastava <utkarsh@sagacious.dev>"],"description":"Generate time sortable 64 bits unique ids for distributed systems (inspired from twitter snowflake)","version":"2.0.1","license":"Apache 2.0","repository":{"type":"git","url":"https://github.com/utkarsh-pro/nodejs-snowflake.git"},"files":["nodejs_snowflake_bg.wasm","nodejs_snowflake.js","nodejs_snowflake.d.ts"],"main":"nodejs_snowflake.js","types":"nodejs_snowflake.d.ts","_lastModified":"2026-
|
|
1
|
+
{"name":"nodejs-snowflake","collaborators":["Utkarsh Srivastava <utkarsh@sagacious.dev>"],"description":"Generate time sortable 64 bits unique ids for distributed systems (inspired from twitter snowflake)","version":"2.0.1","license":"Apache 2.0","repository":{"type":"git","url":"https://github.com/utkarsh-pro/nodejs-snowflake.git"},"files":["nodejs_snowflake_bg.wasm","nodejs_snowflake.js","nodejs_snowflake.d.ts"],"main":"nodejs_snowflake.js","types":"nodejs_snowflake.d.ts","_lastModified":"2026-03-19T03:15:38.673Z"}
|
|
@@ -30,6 +30,7 @@ export default class Dispatcher {
|
|
|
30
30
|
private readonly plugin;
|
|
31
31
|
private ready;
|
|
32
32
|
private executing;
|
|
33
|
+
private preparing;
|
|
33
34
|
private pending;
|
|
34
35
|
private events;
|
|
35
36
|
private eventsCount;
|
|
@@ -39,15 +40,15 @@ export default class Dispatcher {
|
|
|
39
40
|
setReady(ready: boolean): void;
|
|
40
41
|
getEventsCount(): number;
|
|
41
42
|
trigger(workflow: WorkflowModel, context: object, options?: EventOptions): void | Promise<Processor | null>;
|
|
43
|
+
private prepare;
|
|
42
44
|
resume(job: any): Promise<void>;
|
|
43
45
|
start(execution: ExecutionModel): Promise<void>;
|
|
44
46
|
beforeStop(): Promise<void>;
|
|
45
|
-
dispatch():
|
|
47
|
+
dispatch(): void;
|
|
46
48
|
run(pending: Pending): Promise<void>;
|
|
47
49
|
private triggerSync;
|
|
48
50
|
private validateEvent;
|
|
49
51
|
private createExecution;
|
|
50
|
-
private prepare;
|
|
51
52
|
private acquirePendingExecution;
|
|
52
53
|
private acquireQueueingExecution;
|
|
53
54
|
private process;
|
|
@@ -29,22 +29,22 @@ __export(Dispatcher_exports, {
|
|
|
29
29
|
default: () => Dispatcher
|
|
30
30
|
});
|
|
31
31
|
module.exports = __toCommonJS(Dispatcher_exports);
|
|
32
|
-
var
|
|
32
|
+
var import_node_crypto = require("node:crypto");
|
|
33
33
|
var import_sequelize = require("sequelize");
|
|
34
34
|
var import_constants = require("./constants");
|
|
35
35
|
var import_Plugin = require("./Plugin");
|
|
36
36
|
class Dispatcher {
|
|
37
37
|
constructor(plugin) {
|
|
38
38
|
this.plugin = plugin;
|
|
39
|
-
this.prepare = this.prepare.bind(this);
|
|
40
39
|
}
|
|
41
40
|
ready = false;
|
|
42
41
|
executing = null;
|
|
42
|
+
preparing = null;
|
|
43
43
|
pending = [];
|
|
44
44
|
events = [];
|
|
45
45
|
eventsCount = 0;
|
|
46
46
|
get idle() {
|
|
47
|
-
return this.ready && !this.executing && !this.pending.length && !this.events.length;
|
|
47
|
+
return this.ready && !this.executing && !this.preparing && !this.pending.length && !this.events.length;
|
|
48
48
|
}
|
|
49
49
|
onQueueExecution = async (event) => {
|
|
50
50
|
const ExecutionRepo = this.plugin.db.getRepository("executions");
|
|
@@ -96,11 +96,55 @@ class Dispatcher {
|
|
|
96
96
|
this.eventsCount = this.events.length;
|
|
97
97
|
logger.info(`new event triggered, now events: ${this.events.length}`);
|
|
98
98
|
logger.debug(`event data:`, { context });
|
|
99
|
-
|
|
100
|
-
|
|
99
|
+
this.prepare();
|
|
100
|
+
}
|
|
101
|
+
prepare() {
|
|
102
|
+
if (this.preparing) {
|
|
101
103
|
return;
|
|
102
104
|
}
|
|
103
|
-
|
|
105
|
+
this.preparing = (async () => {
|
|
106
|
+
try {
|
|
107
|
+
while (this.events.length) {
|
|
108
|
+
if (this.executing && this.plugin.db.options.dialect === "sqlite") {
|
|
109
|
+
await this.executing;
|
|
110
|
+
}
|
|
111
|
+
const event = this.events.shift();
|
|
112
|
+
this.eventsCount = this.events.length;
|
|
113
|
+
if (!event) continue;
|
|
114
|
+
const logger = this.plugin.getLogger(event[0].id);
|
|
115
|
+
logger.info(`preparing execution for event`);
|
|
116
|
+
try {
|
|
117
|
+
const execution = await this.createExecution(...event);
|
|
118
|
+
if (!(execution == null ? void 0 : execution.dispatched)) {
|
|
119
|
+
if (this.plugin.serving() && !this.executing && !this.pending.length) {
|
|
120
|
+
logger.info(`local pending list is empty, adding execution (${execution.id}) to pending list`);
|
|
121
|
+
this.pending.push({ execution });
|
|
122
|
+
} else {
|
|
123
|
+
logger.info(
|
|
124
|
+
`instance is not serving as worker or local pending list is not empty, sending execution (${execution.id}) to queue`
|
|
125
|
+
);
|
|
126
|
+
try {
|
|
127
|
+
await this.plugin.app.eventQueue.publish(this.plugin.channelPendingExecution, {
|
|
128
|
+
executionId: execution.id
|
|
129
|
+
});
|
|
130
|
+
} catch (qErr) {
|
|
131
|
+
logger.error(`publishing execution (${execution.id}) to queue failed:`, { error: qErr });
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
} catch (error) {
|
|
136
|
+
logger.error(`failed to create execution:`, { error });
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
} finally {
|
|
140
|
+
this.preparing = null;
|
|
141
|
+
if (this.events.length) {
|
|
142
|
+
this.prepare();
|
|
143
|
+
} else {
|
|
144
|
+
this.dispatch();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
})();
|
|
104
148
|
}
|
|
105
149
|
async resume(job) {
|
|
106
150
|
let { execution } = job;
|
|
@@ -119,16 +163,26 @@ class Dispatcher {
|
|
|
119
163
|
}
|
|
120
164
|
async beforeStop() {
|
|
121
165
|
this.ready = false;
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
166
|
+
this.plugin.getLogger("dispatcher").info("app is stopping, draining local queues...");
|
|
167
|
+
while (this.preparing || this.executing || this.events.length || this.pending.length) {
|
|
168
|
+
if (this.preparing) {
|
|
169
|
+
await this.preparing;
|
|
170
|
+
}
|
|
171
|
+
if (this.executing) {
|
|
172
|
+
await this.executing;
|
|
173
|
+
}
|
|
174
|
+
if (this.events.length && !this.preparing) {
|
|
175
|
+
this.prepare();
|
|
176
|
+
}
|
|
177
|
+
if (this.pending.length && !this.executing) {
|
|
178
|
+
this.dispatch();
|
|
179
|
+
}
|
|
180
|
+
await new Promise((resolve) => setImmediate(resolve));
|
|
127
181
|
}
|
|
182
|
+
this.plugin.getLogger("dispatcher").info("local queues drained");
|
|
128
183
|
}
|
|
129
184
|
dispatch() {
|
|
130
|
-
if (!this.ready) {
|
|
131
|
-
this.plugin.getLogger("dispatcher").warn(`app is not ready, new dispatching will be ignored`);
|
|
185
|
+
if (!this.ready && !this.pending.length && !this.events.length) {
|
|
132
186
|
return;
|
|
133
187
|
}
|
|
134
188
|
if (this.executing) {
|
|
@@ -136,7 +190,8 @@ class Dispatcher {
|
|
|
136
190
|
return;
|
|
137
191
|
}
|
|
138
192
|
if (this.events.length) {
|
|
139
|
-
|
|
193
|
+
this.prepare();
|
|
194
|
+
return;
|
|
140
195
|
}
|
|
141
196
|
this.executing = (async () => {
|
|
142
197
|
let next = null;
|
|
@@ -149,13 +204,15 @@ class Dispatcher {
|
|
|
149
204
|
this.plugin.getLogger(next[0].workflowId).info(`pending execution (${next[0].id}) ready to process`);
|
|
150
205
|
}
|
|
151
206
|
} else {
|
|
152
|
-
if (this.plugin.serving()) {
|
|
207
|
+
if (this.ready && this.plugin.serving()) {
|
|
153
208
|
execution = await this.acquireQueueingExecution();
|
|
154
209
|
if (execution) {
|
|
155
210
|
next = [execution];
|
|
156
211
|
}
|
|
157
212
|
} else {
|
|
158
|
-
this.plugin.getLogger("dispatcher").warn(
|
|
213
|
+
this.plugin.getLogger("dispatcher").warn(
|
|
214
|
+
`${import_Plugin.WORKER_JOB_WORKFLOW_PROCESS} is not serving on this instance or app not ready, new dispatching will be ignored`
|
|
215
|
+
);
|
|
159
216
|
}
|
|
160
217
|
}
|
|
161
218
|
if (next) {
|
|
@@ -233,7 +290,7 @@ class Dispatcher {
|
|
|
233
290
|
{
|
|
234
291
|
context,
|
|
235
292
|
key: workflow.key,
|
|
236
|
-
eventKey: options.eventKey ?? (0,
|
|
293
|
+
eventKey: options.eventKey ?? (0, import_node_crypto.randomUUID)(),
|
|
237
294
|
stack: options.stack,
|
|
238
295
|
dispatched: deferred ?? false,
|
|
239
296
|
status: deferred ? import_constants.EXECUTION_STATUS.STARTED : import_constants.EXECUTION_STATUS.QUEUEING,
|
|
@@ -268,50 +325,6 @@ class Dispatcher {
|
|
|
268
325
|
execution.workflow = workflow;
|
|
269
326
|
return execution;
|
|
270
327
|
}
|
|
271
|
-
prepare = async () => {
|
|
272
|
-
if (this.executing && this.plugin.db.options.dialect === "sqlite") {
|
|
273
|
-
await this.executing;
|
|
274
|
-
}
|
|
275
|
-
const event = this.events.shift();
|
|
276
|
-
this.eventsCount = this.events.length;
|
|
277
|
-
if (!event) {
|
|
278
|
-
this.plugin.getLogger("dispatcher").info(`events queue is empty, no need to prepare`);
|
|
279
|
-
return;
|
|
280
|
-
}
|
|
281
|
-
const logger = this.plugin.getLogger(event[0].id);
|
|
282
|
-
logger.info(`preparing execution for event`);
|
|
283
|
-
try {
|
|
284
|
-
const execution = await this.createExecution(...event);
|
|
285
|
-
if (!(execution == null ? void 0 : execution.dispatched)) {
|
|
286
|
-
if (this.plugin.serving() && !this.executing && !this.pending.length) {
|
|
287
|
-
logger.info(`local pending list is empty, adding execution (${execution.id}) to pending list`);
|
|
288
|
-
this.pending.push({ execution });
|
|
289
|
-
} else {
|
|
290
|
-
logger.info(
|
|
291
|
-
`instance is not serving as worker or local pending list is not empty, sending execution (${execution.id}) to queue`
|
|
292
|
-
);
|
|
293
|
-
try {
|
|
294
|
-
await this.plugin.app.eventQueue.publish(this.plugin.channelPendingExecution, {
|
|
295
|
-
executionId: execution.id
|
|
296
|
-
});
|
|
297
|
-
} catch (qErr) {
|
|
298
|
-
logger.error(`publishing execution (${execution.id}) to queue failed:`, { error: qErr });
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
} catch (error) {
|
|
303
|
-
logger.error(`failed to create execution:`, { error });
|
|
304
|
-
}
|
|
305
|
-
if (this.events.length) {
|
|
306
|
-
await this.prepare();
|
|
307
|
-
} else {
|
|
308
|
-
this.plugin.getLogger("dispatcher").info("no more events need to be prepared, dispatching...");
|
|
309
|
-
if (this.executing) {
|
|
310
|
-
await this.executing;
|
|
311
|
-
}
|
|
312
|
-
this.dispatch();
|
|
313
|
-
}
|
|
314
|
-
};
|
|
315
328
|
async acquirePendingExecution(execution) {
|
|
316
329
|
const logger = this.plugin.getLogger(execution.workflowId);
|
|
317
330
|
const isolationLevel = this.plugin.db.options.dialect === "sqlite" ? [][0] : import_sequelize.Transaction.ISOLATION_LEVELS.REPEATABLE_READ;
|