@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.
Files changed (88) hide show
  1. package/dist/build.tsbuildinfo +1 -0
  2. package/dist/config/base-runner-config.d.ts +16 -0
  3. package/dist/config/base-runner-config.js +83 -0
  4. package/dist/config/base-runner-config.js.map +1 -0
  5. package/dist/config/js-runner-config.d.ts +5 -0
  6. package/dist/config/js-runner-config.js +37 -0
  7. package/dist/config/js-runner-config.js.map +1 -0
  8. package/dist/config/main-config.d.ts +8 -0
  9. package/dist/config/main-config.js +35 -0
  10. package/dist/config/main-config.js.map +1 -0
  11. package/dist/config/sentry-config.d.ts +6 -0
  12. package/dist/config/sentry-config.js +42 -0
  13. package/dist/config/sentry-config.js.map +1 -0
  14. package/dist/data-request/data-request-response-reconstruct.d.ts +6 -0
  15. package/dist/data-request/data-request-response-reconstruct.js +30 -0
  16. package/dist/data-request/data-request-response-reconstruct.js.map +1 -0
  17. package/dist/health-check-server.d.ts +5 -0
  18. package/dist/health-check-server.js +43 -0
  19. package/dist/health-check-server.js.map +1 -0
  20. package/dist/index.d.ts +4 -0
  21. package/dist/index.js +20 -0
  22. package/dist/index.js.map +1 -0
  23. package/dist/js-task-runner/built-ins-parser/acorn-helpers.d.ts +6 -0
  24. package/dist/js-task-runner/built-ins-parser/acorn-helpers.js +23 -0
  25. package/dist/js-task-runner/built-ins-parser/acorn-helpers.js.map +1 -0
  26. package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.d.ts +19 -0
  27. package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.js +59 -0
  28. package/dist/js-task-runner/built-ins-parser/built-ins-parser-state.js.map +1 -0
  29. package/dist/js-task-runner/built-ins-parser/built-ins-parser.d.ts +12 -0
  30. package/dist/js-task-runner/built-ins-parser/built-ins-parser.js +120 -0
  31. package/dist/js-task-runner/built-ins-parser/built-ins-parser.js.map +1 -0
  32. package/dist/js-task-runner/errors/disallowed-module.error.d.ts +4 -0
  33. package/dist/js-task-runner/errors/disallowed-module.error.js +11 -0
  34. package/dist/js-task-runner/errors/disallowed-module.error.js.map +1 -0
  35. package/dist/js-task-runner/errors/error-like.d.ts +5 -0
  36. package/dist/js-task-runner/errors/error-like.js +10 -0
  37. package/dist/js-task-runner/errors/error-like.js.map +1 -0
  38. package/dist/js-task-runner/errors/execution-error.d.ts +14 -0
  39. package/dist/js-task-runner/errors/execution-error.js +85 -0
  40. package/dist/js-task-runner/errors/execution-error.js.map +1 -0
  41. package/dist/js-task-runner/errors/serializable-error.d.ts +4 -0
  42. package/dist/js-task-runner/errors/serializable-error.js +27 -0
  43. package/dist/js-task-runner/errors/serializable-error.js.map +1 -0
  44. package/dist/js-task-runner/errors/task-cancelled-error.d.ts +4 -0
  45. package/dist/js-task-runner/errors/task-cancelled-error.js +11 -0
  46. package/dist/js-task-runner/errors/task-cancelled-error.js.map +1 -0
  47. package/dist/js-task-runner/errors/timeout-error.d.ts +5 -0
  48. package/dist/js-task-runner/errors/timeout-error.js +22 -0
  49. package/dist/js-task-runner/errors/timeout-error.js.map +1 -0
  50. package/dist/js-task-runner/errors/unsupported-function.error.d.ts +4 -0
  51. package/dist/js-task-runner/errors/unsupported-function.error.js +13 -0
  52. package/dist/js-task-runner/errors/unsupported-function.error.js.map +1 -0
  53. package/dist/js-task-runner/js-task-runner.d.ts +59 -0
  54. package/dist/js-task-runner/js-task-runner.js +381 -0
  55. package/dist/js-task-runner/js-task-runner.js.map +1 -0
  56. package/dist/js-task-runner/obj-utils.d.ts +1 -0
  57. package/dist/js-task-runner/obj-utils.js +7 -0
  58. package/dist/js-task-runner/obj-utils.js.map +1 -0
  59. package/dist/js-task-runner/require-resolver.d.ts +6 -0
  60. package/dist/js-task-runner/require-resolver.js +22 -0
  61. package/dist/js-task-runner/require-resolver.js.map +1 -0
  62. package/dist/message-types.d.ts +186 -0
  63. package/dist/message-types.js +3 -0
  64. package/dist/message-types.js.map +1 -0
  65. package/dist/node-types.d.ts +13 -0
  66. package/dist/node-types.js +67 -0
  67. package/dist/node-types.js.map +1 -0
  68. package/dist/runner-types.d.ts +77 -0
  69. package/dist/runner-types.js +32 -0
  70. package/dist/runner-types.js.map +1 -0
  71. package/dist/start.d.ts +1 -0
  72. package/dist/start.js +107 -0
  73. package/dist/start.js.map +1 -0
  74. package/dist/task-runner-javascript/node_modules/.bin/acorn +21 -0
  75. package/dist/task-runner-javascript/node_modules/.bin/n8n-copy-static-files +21 -0
  76. package/dist/task-runner-javascript/node_modules/.bin/n8n-generate-metadata +21 -0
  77. package/dist/task-runner-javascript/node_modules/.bin/n8n-generate-translations +21 -0
  78. package/dist/task-runner-javascript/node_modules/.bin/nanoid +21 -0
  79. package/dist/task-runner-sentry.d.ts +12 -0
  80. package/dist/task-runner-sentry.js +68 -0
  81. package/dist/task-runner-sentry.js.map +1 -0
  82. package/dist/task-runner.d.ts +85 -0
  83. package/dist/task-runner.js +441 -0
  84. package/dist/task-runner.js.map +1 -0
  85. package/dist/task-state.d.ts +17 -0
  86. package/dist/task-state.js +63 -0
  87. package/dist/task-state.js.map +1 -0
  88. 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"}
@@ -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 {};