@atom8n/task-runner 2.2.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/dist/build.tsbuildinfo +1 -0
- package/dist/config/base-runner-config.d.ts +16 -0
- package/dist/config/base-runner-config.js +83 -0
- package/dist/config/base-runner-config.js.map +1 -0
- package/dist/config/js-runner-config.d.ts +5 -0
- package/dist/config/js-runner-config.js +37 -0
- package/dist/config/js-runner-config.js.map +1 -0
- package/dist/config/main-config.d.ts +8 -0
- package/dist/config/main-config.js +35 -0
- package/dist/config/main-config.js.map +1 -0
- package/dist/config/sentry-config.d.ts +6 -0
- package/dist/config/sentry-config.js +42 -0
- package/dist/config/sentry-config.js.map +1 -0
- package/dist/data-request/data-request-response-reconstruct.d.ts +6 -0
- package/dist/data-request/data-request-response-reconstruct.js +30 -0
- package/dist/data-request/data-request-response-reconstruct.js.map +1 -0
- package/dist/health-check-server.d.ts +5 -0
- package/dist/health-check-server.js +43 -0
- package/dist/health-check-server.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/js-task-runner/built-ins-parser/acorn-helpers.d.ts +6 -0
- package/dist/js-task-runner/built-ins-parser/acorn-helpers.js +23 -0
- package/dist/js-task-runner/built-ins-parser/acorn-helpers.js.map +1 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.d.ts +19 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.js +59 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.js.map +1 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser.d.ts +12 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser.js +120 -0
- package/dist/js-task-runner/built-ins-parser/built-ins-parser.js.map +1 -0
- package/dist/js-task-runner/errors/disallowed-module.error.d.ts +4 -0
- package/dist/js-task-runner/errors/disallowed-module.error.js +11 -0
- package/dist/js-task-runner/errors/disallowed-module.error.js.map +1 -0
- package/dist/js-task-runner/errors/error-like.d.ts +5 -0
- package/dist/js-task-runner/errors/error-like.js +10 -0
- package/dist/js-task-runner/errors/error-like.js.map +1 -0
- package/dist/js-task-runner/errors/execution-error.d.ts +14 -0
- package/dist/js-task-runner/errors/execution-error.js +85 -0
- package/dist/js-task-runner/errors/execution-error.js.map +1 -0
- package/dist/js-task-runner/errors/serializable-error.d.ts +4 -0
- package/dist/js-task-runner/errors/serializable-error.js +27 -0
- package/dist/js-task-runner/errors/serializable-error.js.map +1 -0
- package/dist/js-task-runner/errors/task-cancelled-error.d.ts +4 -0
- package/dist/js-task-runner/errors/task-cancelled-error.js +11 -0
- package/dist/js-task-runner/errors/task-cancelled-error.js.map +1 -0
- package/dist/js-task-runner/errors/timeout-error.d.ts +5 -0
- package/dist/js-task-runner/errors/timeout-error.js +22 -0
- package/dist/js-task-runner/errors/timeout-error.js.map +1 -0
- package/dist/js-task-runner/errors/unsupported-function.error.d.ts +4 -0
- package/dist/js-task-runner/errors/unsupported-function.error.js +13 -0
- package/dist/js-task-runner/errors/unsupported-function.error.js.map +1 -0
- package/dist/js-task-runner/js-task-runner.d.ts +59 -0
- package/dist/js-task-runner/js-task-runner.js +381 -0
- package/dist/js-task-runner/js-task-runner.js.map +1 -0
- package/dist/js-task-runner/obj-utils.d.ts +1 -0
- package/dist/js-task-runner/obj-utils.js +7 -0
- package/dist/js-task-runner/obj-utils.js.map +1 -0
- package/dist/js-task-runner/require-resolver.d.ts +6 -0
- package/dist/js-task-runner/require-resolver.js +22 -0
- package/dist/js-task-runner/require-resolver.js.map +1 -0
- package/dist/message-types.d.ts +186 -0
- package/dist/message-types.js +3 -0
- package/dist/message-types.js.map +1 -0
- package/dist/node-types.d.ts +13 -0
- package/dist/node-types.js +67 -0
- package/dist/node-types.js.map +1 -0
- package/dist/runner-types.d.ts +77 -0
- package/dist/runner-types.js +32 -0
- package/dist/runner-types.js.map +1 -0
- package/dist/start.d.ts +1 -0
- package/dist/start.js +107 -0
- package/dist/start.js.map +1 -0
- package/dist/task-runner-javascript/node_modules/.bin/acorn +21 -0
- package/dist/task-runner-javascript/node_modules/.bin/n8n-copy-static-files +21 -0
- package/dist/task-runner-javascript/node_modules/.bin/n8n-generate-metadata +21 -0
- package/dist/task-runner-javascript/node_modules/.bin/n8n-generate-translations +21 -0
- package/dist/task-runner-javascript/node_modules/.bin/nanoid +21 -0
- package/dist/task-runner-sentry.d.ts +12 -0
- package/dist/task-runner-sentry.js +68 -0
- package/dist/task-runner-sentry.js.map +1 -0
- package/dist/task-runner.d.ts +85 -0
- package/dist/task-runner.js +441 -0
- package/dist/task-runner.js.map +1 -0
- package/dist/task-state.d.ts +17 -0
- package/dist/task-state.js +63 -0
- package/dist/task-state.js.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TaskRunnerNodeTypes = exports.DEFAULT_NODETYPE_VERSION = void 0;
|
|
4
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
|
+
exports.DEFAULT_NODETYPE_VERSION = 1;
|
|
6
|
+
class TaskRunnerNodeTypes {
|
|
7
|
+
constructor(nodeTypes) {
|
|
8
|
+
this.nodeTypesByVersion = this.parseNodeTypes(nodeTypes);
|
|
9
|
+
}
|
|
10
|
+
parseNodeTypes(nodeTypes) {
|
|
11
|
+
const versionedTypes = new Map();
|
|
12
|
+
for (const nt of nodeTypes) {
|
|
13
|
+
const versions = Array.isArray(nt.version)
|
|
14
|
+
? nt.version
|
|
15
|
+
: [nt.version ?? exports.DEFAULT_NODETYPE_VERSION];
|
|
16
|
+
const versioned = versionedTypes.get(nt.name) ?? new Map();
|
|
17
|
+
for (const version of versions) {
|
|
18
|
+
versioned.set(version, { ...versioned.get(version), ...nt });
|
|
19
|
+
}
|
|
20
|
+
versionedTypes.set(nt.name, versioned);
|
|
21
|
+
}
|
|
22
|
+
return versionedTypes;
|
|
23
|
+
}
|
|
24
|
+
getByName(_nodeType) {
|
|
25
|
+
throw new n8n_workflow_1.ApplicationError('Unimplemented `getByName`', { level: 'error' });
|
|
26
|
+
}
|
|
27
|
+
getByNameAndVersion(nodeType, version) {
|
|
28
|
+
const versions = this.nodeTypesByVersion.get(nodeType);
|
|
29
|
+
if (!versions) {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
const nodeVersion = versions.get(version ?? Math.max(...versions.keys()));
|
|
33
|
+
if (!nodeVersion) {
|
|
34
|
+
return undefined;
|
|
35
|
+
}
|
|
36
|
+
return {
|
|
37
|
+
description: nodeVersion,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
getKnownTypes() {
|
|
41
|
+
throw new n8n_workflow_1.ApplicationError('Unimplemented `getKnownTypes`', { level: 'error' });
|
|
42
|
+
}
|
|
43
|
+
addNodeTypeDescriptions(nodeTypeDescriptions) {
|
|
44
|
+
const newNodeTypes = this.parseNodeTypes(nodeTypeDescriptions);
|
|
45
|
+
for (const [name, newVersions] of newNodeTypes.entries()) {
|
|
46
|
+
if (!this.nodeTypesByVersion.has(name)) {
|
|
47
|
+
this.nodeTypesByVersion.set(name, newVersions);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
const existingVersions = this.nodeTypesByVersion.get(name);
|
|
51
|
+
for (const [version, nodeType] of newVersions.entries()) {
|
|
52
|
+
existingVersions.set(version, nodeType);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
onlyUnknown(nodeTypes) {
|
|
58
|
+
return nodeTypes.filter(({ name, version }) => {
|
|
59
|
+
const existingVersions = this.nodeTypesByVersion.get(name);
|
|
60
|
+
if (!existingVersions)
|
|
61
|
+
return true;
|
|
62
|
+
return !existingVersions.has(version);
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.TaskRunnerNodeTypes = TaskRunnerNodeTypes;
|
|
67
|
+
//# sourceMappingURL=node-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-types.js","sourceRoot":"","sources":["../src/node-types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import type { EnvProviderState, IDataObject, IExecuteData, IExecuteFunctions, INode, INodeExecutionData, INodeParameters, IRunExecutionData, ITaskDataConnections, ITaskDataConnectionsSource, IWorkflowExecuteAdditionalData, Workflow, WorkflowExecuteMode, WorkflowParameters } from 'n8n-workflow';
|
|
2
|
+
export interface InputDataChunkDefinition {
|
|
3
|
+
startIndex: number;
|
|
4
|
+
count: number;
|
|
5
|
+
}
|
|
6
|
+
export interface InputDataRequestParams {
|
|
7
|
+
include: boolean;
|
|
8
|
+
chunk?: InputDataChunkDefinition;
|
|
9
|
+
}
|
|
10
|
+
export interface TaskDataRequestParams {
|
|
11
|
+
dataOfNodes: string[] | 'all';
|
|
12
|
+
prevNode: boolean;
|
|
13
|
+
input: InputDataRequestParams;
|
|
14
|
+
env: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface DataRequestResponse {
|
|
17
|
+
workflow: Omit<WorkflowParameters, 'nodeTypes'>;
|
|
18
|
+
inputData: ITaskDataConnections;
|
|
19
|
+
connectionInputSource: ITaskDataConnectionsSource | null;
|
|
20
|
+
node: INode;
|
|
21
|
+
runExecutionData: IRunExecutionData;
|
|
22
|
+
runIndex: number;
|
|
23
|
+
itemIndex: number;
|
|
24
|
+
activeNodeName: string;
|
|
25
|
+
siblingParameters: INodeParameters;
|
|
26
|
+
mode: WorkflowExecuteMode;
|
|
27
|
+
envProviderState: EnvProviderState;
|
|
28
|
+
defaultReturnRunIndex: number;
|
|
29
|
+
selfData: IDataObject;
|
|
30
|
+
contextNodeName: string;
|
|
31
|
+
additionalData: PartialAdditionalData;
|
|
32
|
+
}
|
|
33
|
+
export interface TaskResultData {
|
|
34
|
+
result: unknown;
|
|
35
|
+
customData?: Record<string, string>;
|
|
36
|
+
staticData?: IDataObject;
|
|
37
|
+
}
|
|
38
|
+
export interface TaskData {
|
|
39
|
+
executeFunctions: IExecuteFunctions;
|
|
40
|
+
inputData: ITaskDataConnections;
|
|
41
|
+
node: INode;
|
|
42
|
+
workflow: Workflow;
|
|
43
|
+
runExecutionData: IRunExecutionData;
|
|
44
|
+
runIndex: number;
|
|
45
|
+
itemIndex: number;
|
|
46
|
+
activeNodeName: string;
|
|
47
|
+
connectionInputData: INodeExecutionData[];
|
|
48
|
+
siblingParameters: INodeParameters;
|
|
49
|
+
mode: WorkflowExecuteMode;
|
|
50
|
+
envProviderState: EnvProviderState;
|
|
51
|
+
executeData?: IExecuteData;
|
|
52
|
+
defaultReturnRunIndex: number;
|
|
53
|
+
selfData: IDataObject;
|
|
54
|
+
contextNodeName: string;
|
|
55
|
+
additionalData: IWorkflowExecuteAdditionalData;
|
|
56
|
+
}
|
|
57
|
+
export interface PartialAdditionalData {
|
|
58
|
+
executionId?: string;
|
|
59
|
+
restartExecutionId?: string;
|
|
60
|
+
restApiUrl: string;
|
|
61
|
+
instanceBaseUrl: string;
|
|
62
|
+
formWaitingBaseUrl: string;
|
|
63
|
+
webhookBaseUrl: string;
|
|
64
|
+
webhookWaitingBaseUrl: string;
|
|
65
|
+
webhookTestBaseUrl: string;
|
|
66
|
+
currentNodeParameters?: INodeParameters;
|
|
67
|
+
executionTimeoutTimestamp?: number;
|
|
68
|
+
userId?: string;
|
|
69
|
+
variables: IDataObject;
|
|
70
|
+
}
|
|
71
|
+
export declare const EXPOSED_RPC_METHODS: string[];
|
|
72
|
+
export declare const UNSUPPORTED_HELPER_FUNCTIONS: string[];
|
|
73
|
+
export declare const AVAILABLE_RPC_METHODS: readonly [...string[], "logNodeOutput"];
|
|
74
|
+
export type NeededNodeType = {
|
|
75
|
+
name: string;
|
|
76
|
+
version: number;
|
|
77
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AVAILABLE_RPC_METHODS = exports.UNSUPPORTED_HELPER_FUNCTIONS = exports.EXPOSED_RPC_METHODS = void 0;
|
|
4
|
+
exports.EXPOSED_RPC_METHODS = [
|
|
5
|
+
'helpers.assertBinaryData',
|
|
6
|
+
'helpers.getBinaryDataBuffer',
|
|
7
|
+
'helpers.prepareBinaryData',
|
|
8
|
+
'helpers.setBinaryDataBuffer',
|
|
9
|
+
'helpers.binaryToString',
|
|
10
|
+
'helpers.httpRequest',
|
|
11
|
+
'helpers.request',
|
|
12
|
+
];
|
|
13
|
+
exports.UNSUPPORTED_HELPER_FUNCTIONS = [
|
|
14
|
+
'helpers.httpRequestWithAuthentication',
|
|
15
|
+
'helpers.requestWithAuthenticationPaginated',
|
|
16
|
+
'helpers.copyBinaryFile',
|
|
17
|
+
'helpers.createReadStream',
|
|
18
|
+
'helpers.getBinaryStream',
|
|
19
|
+
'helpers.binaryToBuffer',
|
|
20
|
+
'helpers.getBinaryMetadata',
|
|
21
|
+
'helpers.getStoragePath',
|
|
22
|
+
'helpers.getBinaryPath',
|
|
23
|
+
'helpers.writeContentToFile',
|
|
24
|
+
'helpers.copyInputItems',
|
|
25
|
+
'helpers.returnJsonArray',
|
|
26
|
+
'helpers.normalizeItems',
|
|
27
|
+
'helpers.getSSHClient',
|
|
28
|
+
'helpers.createDeferredPromise',
|
|
29
|
+
'helpers.constructExecutionMetaData',
|
|
30
|
+
];
|
|
31
|
+
exports.AVAILABLE_RPC_METHODS = [...exports.EXPOSED_RPC_METHODS, 'logNodeOutput'];
|
|
32
|
+
//# sourceMappingURL=runner-types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner-types.js","sourceRoot":"","sources":["../src/runner-types.ts"],"names":[],"mappings":";;;AAwGa,QAAA,mBAAmB,GAAG;IAElC,0BAA0B;IAG1B,6BAA6B;IAG7B,2BAA2B;IAG3B,6BAA6B;IAG7B,wBAAwB;IAGxB,qBAAqB;IAGrB,iBAAiB;CACjB,CAAC;AAGW,QAAA,4BAA4B,GAAG;IAG3C,uCAAuC;IACvC,4CAA4C;IAG5C,wBAAwB;IAGxB,0BAA0B;IAC1B,yBAAyB;IAIzB,wBAAwB;IAIxB,2BAA2B;IAC3B,wBAAwB;IACxB,uBAAuB;IAGvB,4BAA4B;IAI5B,wBAAwB;IAGxB,yBAAyB;IACzB,wBAAwB;IAIxB,sBAAsB;IAGtB,+BAA+B;IAC/B,oCAAoC;CACpC,CAAC;AAGW,QAAA,qBAAqB,GAAG,CAAC,GAAG,2BAAmB,EAAE,eAAe,CAAU,CAAC"}
|
package/dist/start.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/dist/start.js
ADDED
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const di_1 = require("@n8n/di");
|
|
37
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
38
|
+
const main_config_1 = require("./config/main-config");
|
|
39
|
+
const js_task_runner_1 = require("./js-task-runner/js-task-runner");
|
|
40
|
+
const task_runner_sentry_1 = require("./task-runner-sentry");
|
|
41
|
+
let healthCheckServer;
|
|
42
|
+
let runner;
|
|
43
|
+
let isShuttingDown = false;
|
|
44
|
+
let sentry;
|
|
45
|
+
function createSignalHandler(signal, timeoutInS = 10) {
|
|
46
|
+
return async function onSignal() {
|
|
47
|
+
if (isShuttingDown) {
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
console.log(`Received ${signal} signal, shutting down...`);
|
|
51
|
+
setTimeout(() => {
|
|
52
|
+
console.error('Shutdown timeout reached, forcing shutdown...');
|
|
53
|
+
process.exit(1);
|
|
54
|
+
}, timeoutInS * 1000).unref();
|
|
55
|
+
isShuttingDown = true;
|
|
56
|
+
try {
|
|
57
|
+
if (runner) {
|
|
58
|
+
await runner.stop();
|
|
59
|
+
runner = undefined;
|
|
60
|
+
void healthCheckServer?.stop();
|
|
61
|
+
}
|
|
62
|
+
if (sentry) {
|
|
63
|
+
await sentry.shutdown();
|
|
64
|
+
sentry = undefined;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch (e) {
|
|
68
|
+
const error = (0, n8n_workflow_1.ensureError)(e);
|
|
69
|
+
console.error('Error stopping task runner', { error });
|
|
70
|
+
}
|
|
71
|
+
finally {
|
|
72
|
+
console.log('Task runner stopped');
|
|
73
|
+
process.exit(0);
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
void (async function start() {
|
|
78
|
+
const config = di_1.Container.get(main_config_1.MainConfig);
|
|
79
|
+
(0, n8n_workflow_1.setGlobalState)({
|
|
80
|
+
defaultTimezone: config.baseRunnerConfig.timezone,
|
|
81
|
+
});
|
|
82
|
+
sentry = di_1.Container.get(task_runner_sentry_1.TaskRunnerSentry);
|
|
83
|
+
try {
|
|
84
|
+
await sentry.initIfEnabled();
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
console.error('FAILED TO INITIALIZE SENTRY. ERROR REPORTING WILL BE DISABLED. THIS IS LIKELY A CONFIGURATION OR ENVIRONMENT ISSUE.', error);
|
|
88
|
+
sentry = undefined;
|
|
89
|
+
}
|
|
90
|
+
runner = new js_task_runner_1.JsTaskRunner(config);
|
|
91
|
+
runner.on('runner:reached-idle-timeout', () => {
|
|
92
|
+
void createSignalHandler('IDLE_TIMEOUT', 3)();
|
|
93
|
+
});
|
|
94
|
+
const { enabled, host, port } = config.baseRunnerConfig.healthcheckServer;
|
|
95
|
+
if (enabled) {
|
|
96
|
+
const { HealthCheckServer } = await Promise.resolve().then(() => __importStar(require('./health-check-server')));
|
|
97
|
+
healthCheckServer = new HealthCheckServer();
|
|
98
|
+
await healthCheckServer.start(host, port);
|
|
99
|
+
}
|
|
100
|
+
process.on('SIGINT', createSignalHandler('SIGINT'));
|
|
101
|
+
process.on('SIGTERM', createSignalHandler('SIGTERM'));
|
|
102
|
+
})().catch((e) => {
|
|
103
|
+
const error = (0, n8n_workflow_1.ensureError)(e);
|
|
104
|
+
console.error('Task runner failed to start', { error });
|
|
105
|
+
process.exit(1);
|
|
106
|
+
});
|
|
107
|
+
//# sourceMappingURL=start.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"start.js","sourceRoot":"","sources":["../src/start.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
3
|
+
|
|
4
|
+
case `uname` in
|
|
5
|
+
*CYGWIN*|*MINGW*|*MSYS*)
|
|
6
|
+
if command -v cygpath > /dev/null 2>&1; then
|
|
7
|
+
basedir=`cygpath -w "$basedir"`
|
|
8
|
+
fi
|
|
9
|
+
;;
|
|
10
|
+
esac
|
|
11
|
+
|
|
12
|
+
if [ -z "$NODE_PATH" ]; then
|
|
13
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules"
|
|
14
|
+
else
|
|
15
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules:$NODE_PATH"
|
|
16
|
+
fi
|
|
17
|
+
if [ -x "$basedir/node" ]; then
|
|
18
|
+
exec "$basedir/node" "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/bin/acorn" "$@"
|
|
19
|
+
else
|
|
20
|
+
exec node "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/acorn@8.14.0/node_modules/acorn/bin/acorn" "$@"
|
|
21
|
+
fi
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
3
|
+
|
|
4
|
+
case `uname` in
|
|
5
|
+
*CYGWIN*|*MINGW*|*MSYS*)
|
|
6
|
+
if command -v cygpath > /dev/null 2>&1; then
|
|
7
|
+
basedir=`cygpath -w "$basedir"`
|
|
8
|
+
fi
|
|
9
|
+
;;
|
|
10
|
+
esac
|
|
11
|
+
|
|
12
|
+
if [ -z "$NODE_PATH" ]; then
|
|
13
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules"
|
|
14
|
+
else
|
|
15
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules:$NODE_PATH"
|
|
16
|
+
fi
|
|
17
|
+
if [ -x "$basedir/node" ]; then
|
|
18
|
+
exec "$basedir/node" "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/copy-static-files" "$@"
|
|
19
|
+
else
|
|
20
|
+
exec node "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/copy-static-files" "$@"
|
|
21
|
+
fi
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
3
|
+
|
|
4
|
+
case `uname` in
|
|
5
|
+
*CYGWIN*|*MINGW*|*MSYS*)
|
|
6
|
+
if command -v cygpath > /dev/null 2>&1; then
|
|
7
|
+
basedir=`cygpath -w "$basedir"`
|
|
8
|
+
fi
|
|
9
|
+
;;
|
|
10
|
+
esac
|
|
11
|
+
|
|
12
|
+
if [ -z "$NODE_PATH" ]; then
|
|
13
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules"
|
|
14
|
+
else
|
|
15
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules:$NODE_PATH"
|
|
16
|
+
fi
|
|
17
|
+
if [ -x "$basedir/node" ]; then
|
|
18
|
+
exec "$basedir/node" "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/generate-metadata" "$@"
|
|
19
|
+
else
|
|
20
|
+
exec node "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/generate-metadata" "$@"
|
|
21
|
+
fi
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
3
|
+
|
|
4
|
+
case `uname` in
|
|
5
|
+
*CYGWIN*|*MINGW*|*MSYS*)
|
|
6
|
+
if command -v cygpath > /dev/null 2>&1; then
|
|
7
|
+
basedir=`cygpath -w "$basedir"`
|
|
8
|
+
fi
|
|
9
|
+
;;
|
|
10
|
+
esac
|
|
11
|
+
|
|
12
|
+
if [ -z "$NODE_PATH" ]; then
|
|
13
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules"
|
|
14
|
+
else
|
|
15
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules:$NODE_PATH"
|
|
16
|
+
fi
|
|
17
|
+
if [ -x "$basedir/node" ]; then
|
|
18
|
+
exec "$basedir/node" "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/generate-translations" "$@"
|
|
19
|
+
else
|
|
20
|
+
exec node "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/n8n-core@file+packages+core_@opentelemetry+api@1.9.0_@opentelemetry+sdk-trace-base@1.30.1_@opentelemetry+api@1.9.0_/node_modules/n8n-core/bin/generate-translations" "$@"
|
|
21
|
+
fi
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#!/bin/sh
|
|
2
|
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
3
|
+
|
|
4
|
+
case `uname` in
|
|
5
|
+
*CYGWIN*|*MINGW*|*MSYS*)
|
|
6
|
+
if command -v cygpath > /dev/null 2>&1; then
|
|
7
|
+
basedir=`cygpath -w "$basedir"`
|
|
8
|
+
fi
|
|
9
|
+
;;
|
|
10
|
+
esac
|
|
11
|
+
|
|
12
|
+
if [ -z "$NODE_PATH" ]; then
|
|
13
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules"
|
|
14
|
+
else
|
|
15
|
+
export NODE_PATH="/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/bin/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules:/Users/Shared/Data/Syncthing/MyApp/n8n-solution/n8n/dist/task-runner-javascript/node_modules/.pnpm/node_modules:$NODE_PATH"
|
|
16
|
+
fi
|
|
17
|
+
if [ -x "$basedir/node" ]; then
|
|
18
|
+
exec "$basedir/node" "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/bin/nanoid.cjs" "$@"
|
|
19
|
+
else
|
|
20
|
+
exec node "$basedir/../../../../../../../dist/task-runner-javascript/node_modules/.pnpm/nanoid@3.3.8/node_modules/nanoid/bin/nanoid.cjs" "$@"
|
|
21
|
+
fi
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ErrorEvent } from '@sentry/core';
|
|
2
|
+
import { ErrorReporter } from 'n8n-core';
|
|
3
|
+
import { SentryConfig } from './config/sentry-config';
|
|
4
|
+
export declare class TaskRunnerSentry {
|
|
5
|
+
private readonly config;
|
|
6
|
+
private readonly errorReporter;
|
|
7
|
+
constructor(config: SentryConfig, errorReporter: ErrorReporter);
|
|
8
|
+
initIfEnabled(): Promise<void>;
|
|
9
|
+
shutdown(): Promise<void>;
|
|
10
|
+
filterOutUserCodeErrors: (event: ErrorEvent) => boolean;
|
|
11
|
+
private isUserCodeError;
|
|
12
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TaskRunnerSentry = void 0;
|
|
13
|
+
const di_1 = require("@n8n/di");
|
|
14
|
+
const n8n_core_1 = require("n8n-core");
|
|
15
|
+
const sentry_config_1 = require("./config/sentry-config");
|
|
16
|
+
let TaskRunnerSentry = class TaskRunnerSentry {
|
|
17
|
+
constructor(config, errorReporter) {
|
|
18
|
+
this.config = config;
|
|
19
|
+
this.errorReporter = errorReporter;
|
|
20
|
+
this.filterOutUserCodeErrors = (event) => {
|
|
21
|
+
const error = event?.exception?.values?.[0];
|
|
22
|
+
return error ? this.isUserCodeError(error) : false;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
async initIfEnabled() {
|
|
26
|
+
const { dsn, n8nVersion, environment, deploymentName } = this.config;
|
|
27
|
+
if (!dsn)
|
|
28
|
+
return;
|
|
29
|
+
await this.errorReporter.init({
|
|
30
|
+
serverType: 'task_runner',
|
|
31
|
+
dsn,
|
|
32
|
+
release: `n8n@${n8nVersion}`,
|
|
33
|
+
environment,
|
|
34
|
+
serverName: deploymentName,
|
|
35
|
+
beforeSendFilter: this.filterOutUserCodeErrors,
|
|
36
|
+
withEventLoopBlockDetection: false,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
async shutdown() {
|
|
40
|
+
if (!this.config.dsn)
|
|
41
|
+
return;
|
|
42
|
+
await this.errorReporter.shutdown();
|
|
43
|
+
}
|
|
44
|
+
isUserCodeError(error) {
|
|
45
|
+
const frames = error.stacktrace?.frames;
|
|
46
|
+
if (!frames)
|
|
47
|
+
return false;
|
|
48
|
+
return frames.some((frame) => {
|
|
49
|
+
if (frame.filename === 'node:vm' && frame.function === 'runInContext') {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
if (frame.filename === 'evalmachine.<anonymous>') {
|
|
53
|
+
return true;
|
|
54
|
+
}
|
|
55
|
+
if (frame.function === 'VmCodeWrapper') {
|
|
56
|
+
return true;
|
|
57
|
+
}
|
|
58
|
+
return false;
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
exports.TaskRunnerSentry = TaskRunnerSentry;
|
|
63
|
+
exports.TaskRunnerSentry = TaskRunnerSentry = __decorate([
|
|
64
|
+
(0, di_1.Service)(),
|
|
65
|
+
__metadata("design:paramtypes", [sentry_config_1.SentryConfig,
|
|
66
|
+
n8n_core_1.ErrorReporter])
|
|
67
|
+
], TaskRunnerSentry);
|
|
68
|
+
//# sourceMappingURL=task-runner-sentry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task-runner-sentry.js","sourceRoot":"","sources":["../src/task-runner-sentry.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,gCAAkC;AAElC,uCAAyC;AAEzC,0DAAsD;AAM/C,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAC5B,YACkB,MAAoB,EACpB,aAA4B;QAD5B,WAAM,GAAN,MAAM,CAAc;QACpB,kBAAa,GAAb,aAAa,CAAe;QA8B9C,4BAAuB,GAAG,CAAC,KAAiB,EAAE,EAAE;YAC/C,MAAM,KAAK,GAAG,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;YAE5C,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACpD,CAAC,CAAC;IAjCC,CAAC;IAEJ,KAAK,CAAC,aAAa;QAClB,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,WAAW,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAErE,IAAI,CAAC,GAAG;YAAE,OAAO;QAEjB,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YAC7B,UAAU,EAAE,aAAa;YACzB,GAAG;YACH,OAAO,EAAE,OAAO,UAAU,EAAE;YAC5B,WAAW;YACX,UAAU,EAAE,cAAc;YAC1B,gBAAgB,EAAE,IAAI,CAAC,uBAAuB;YAC9C,2BAA2B,EAAE,KAAK;SAClC,CAAC,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG;YAAE,OAAO;QAE7B,MAAM,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAkBO,eAAe,CAAC,KAAgB;QACvC,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC;QACxC,IAAI,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE1B,OAAO,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;YAC5B,IAAI,KAAK,CAAC,QAAQ,KAAK,SAAS,IAAI,KAAK,CAAC,QAAQ,KAAK,cAAc,EAAE,CAAC;gBACvE,OAAO,IAAI,CAAC;YACb,CAAC;YAED,IAAI,KAAK,CAAC,QAAQ,KAAK,yBAAyB,EAAE,CAAC;gBAClD,OAAO,IAAI,CAAC;YACb,CAAC;YAED,IAAI,KAAK,CAAC,QAAQ,KAAK,eAAe,EAAE,CAAC;gBACxC,OAAO,IAAI,CAAC;YACb,CAAC;YAED,OAAO,KAAK,CAAC;QACd,CAAC,CAAC,CAAC;IACJ,CAAC;CACD,CAAA;AAhEY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,YAAO,GAAE;qCAGiB,4BAAY;QACL,wBAAa;GAHlC,gBAAgB,CAgE5B"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { EventEmitter } from 'node:events';
|
|
2
|
+
import { WebSocket } from 'ws';
|
|
3
|
+
import type { BaseRunnerConfig } from './config/base-runner-config';
|
|
4
|
+
import type { BrokerMessage, RunnerMessage } from './message-types';
|
|
5
|
+
import { TaskRunnerNodeTypes } from './node-types';
|
|
6
|
+
import type { TaskResultData } from './runner-types';
|
|
7
|
+
import { TaskState } from './task-state';
|
|
8
|
+
export interface TaskOffer {
|
|
9
|
+
offerId: string;
|
|
10
|
+
validUntil: bigint;
|
|
11
|
+
}
|
|
12
|
+
interface DataRequest {
|
|
13
|
+
taskId: string;
|
|
14
|
+
requestId: string;
|
|
15
|
+
resolve: (data: unknown) => void;
|
|
16
|
+
reject: (error: unknown) => void;
|
|
17
|
+
}
|
|
18
|
+
interface NodeTypesRequest {
|
|
19
|
+
taskId: string;
|
|
20
|
+
requestId: string;
|
|
21
|
+
resolve: (data: unknown) => void;
|
|
22
|
+
reject: (error: unknown) => void;
|
|
23
|
+
}
|
|
24
|
+
interface RPCCall {
|
|
25
|
+
callId: string;
|
|
26
|
+
resolve: (data: unknown) => void;
|
|
27
|
+
reject: (error: unknown) => void;
|
|
28
|
+
}
|
|
29
|
+
export declare const noOp: () => void;
|
|
30
|
+
export interface TaskParams<T = unknown> {
|
|
31
|
+
taskId: string;
|
|
32
|
+
settings: T;
|
|
33
|
+
}
|
|
34
|
+
export interface TaskRunnerOpts extends BaseRunnerConfig {
|
|
35
|
+
taskType: string;
|
|
36
|
+
name?: string;
|
|
37
|
+
}
|
|
38
|
+
export declare abstract class TaskRunner extends EventEmitter {
|
|
39
|
+
id: string;
|
|
40
|
+
ws: WebSocket;
|
|
41
|
+
canSendOffers: boolean;
|
|
42
|
+
runningTasks: Map<TaskState['taskId'], TaskState>;
|
|
43
|
+
offerInterval: NodeJS.Timeout | undefined;
|
|
44
|
+
openOffers: Map<TaskOffer['offerId'], TaskOffer>;
|
|
45
|
+
dataRequests: Map<DataRequest['requestId'], DataRequest>;
|
|
46
|
+
nodeTypesRequests: Map<NodeTypesRequest['requestId'], NodeTypesRequest>;
|
|
47
|
+
rpcCalls: Map<RPCCall['callId'], RPCCall>;
|
|
48
|
+
nodeTypes: TaskRunnerNodeTypes;
|
|
49
|
+
taskType: string;
|
|
50
|
+
maxConcurrency: number;
|
|
51
|
+
name: string;
|
|
52
|
+
private idleTimer;
|
|
53
|
+
protected readonly taskTimeout: number;
|
|
54
|
+
private readonly idleTimeout;
|
|
55
|
+
constructor(opts: TaskRunnerOpts);
|
|
56
|
+
private resetIdleTimer;
|
|
57
|
+
private receiveMessage;
|
|
58
|
+
private stopTaskOffers;
|
|
59
|
+
private startTaskOffers;
|
|
60
|
+
deleteStaleOffers(): void;
|
|
61
|
+
sendOffers(): void;
|
|
62
|
+
send(message: RunnerMessage.ToBroker.All): void;
|
|
63
|
+
onMessage(message: BrokerMessage.ToRunner.All): void;
|
|
64
|
+
processDataResponse(requestId: string, data: unknown): void;
|
|
65
|
+
processNodeTypesResponse(requestId: string, nodeTypes: unknown): void;
|
|
66
|
+
hasOpenTaskSlots(): boolean;
|
|
67
|
+
offerAccepted(offerId: string, taskId: string): void;
|
|
68
|
+
taskCancelled(taskId: string, reason: string): Promise<void>;
|
|
69
|
+
taskTimedOut(taskId: string): Promise<void>;
|
|
70
|
+
receivedSettings(taskId: string, settings: unknown): Promise<void>;
|
|
71
|
+
executeTask(_taskParams: TaskParams, _signal: AbortSignal): Promise<TaskResultData>;
|
|
72
|
+
requestNodeTypes<T = unknown>(taskId: TaskState['taskId'], requestParams: RunnerMessage.ToBroker.NodeTypesRequest['requestParams']): Promise<T>;
|
|
73
|
+
requestData<T = unknown>(taskId: TaskState['taskId'], requestParams: RunnerMessage.ToBroker.TaskDataRequest['requestParams']): Promise<T>;
|
|
74
|
+
makeRpcCall(taskId: string, name: RunnerMessage.ToBroker.RPC['name'], params: unknown[]): Promise<unknown>;
|
|
75
|
+
handleRpcResponse(callId: string, status: BrokerMessage.ToRunner.RPCResponse['status'], data: unknown): void;
|
|
76
|
+
stop(): Promise<void>;
|
|
77
|
+
clearIdleTimer(): void;
|
|
78
|
+
private closeConnection;
|
|
79
|
+
private waitUntilAllTasksAreDone;
|
|
80
|
+
private taskExecutionSucceeded;
|
|
81
|
+
private taskExecutionFailed;
|
|
82
|
+
private cancelTaskRequests;
|
|
83
|
+
private finishTask;
|
|
84
|
+
}
|
|
85
|
+
export {};
|