2021-08-29 11:58:11 -07:00
|
|
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
|
|
/* eslint-disable import/no-extraneous-dependencies */
|
|
|
|
/* eslint-disable import/no-cycle */
|
|
|
|
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
|
|
// eslint-disable-next-line max-classes-per-file
|
|
|
|
import * as express from 'express';
|
2021-09-21 10:38:24 -07:00
|
|
|
import * as FormData from 'form-data';
|
|
|
|
import { URLSearchParams } from 'url';
|
2021-11-05 09:45:51 -07:00
|
|
|
import { IDeferredPromise } from './DeferredPromise';
|
2019-06-23 03:35:23 -07:00
|
|
|
import { Workflow } from './Workflow';
|
2019-12-19 14:07:55 -08:00
|
|
|
import { WorkflowHooks } from './WorkflowHooks';
|
2022-06-06 00:17:35 -07:00
|
|
|
import { WorkflowActivationError } from './WorkflowActivationError';
|
2021-04-16 09:33:36 -07:00
|
|
|
import { WorkflowOperationError } from './WorkflowErrors';
|
|
|
|
import { NodeApiError, NodeOperationError } from './NodeErrors';
|
2019-06-23 03:35:23 -07:00
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface IAdditionalCredentialOptions {
|
|
|
|
oauth2?: IOAuth2Options;
|
|
|
|
credentialsDecrypted?: ICredentialsDecrypted;
|
|
|
|
}
|
|
|
|
|
2021-08-29 11:58:11 -07:00
|
|
|
export type IAllExecuteFunctions =
|
|
|
|
| IExecuteFunctions
|
2022-02-05 13:55:43 -08:00
|
|
|
| IExecutePaginationFunctions
|
2021-08-29 11:58:11 -07:00
|
|
|
| IExecuteSingleFunctions
|
|
|
|
| IHookFunctions
|
|
|
|
| ILoadOptionsFunctions
|
|
|
|
| IPollFunctions
|
|
|
|
| ITriggerFunctions
|
|
|
|
| IWebhookFunctions;
|
2020-01-13 18:46:58 -08:00
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IBinaryData {
|
|
|
|
[key: string]: string | undefined;
|
|
|
|
data: string;
|
|
|
|
mimeType: string;
|
|
|
|
fileName?: string;
|
2021-03-18 10:13:24 -07:00
|
|
|
directory?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
fileExtension?: string;
|
2021-12-23 13:29:04 -08:00
|
|
|
id?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2022-07-15 01:36:01 -07:00
|
|
|
// All properties in this interface except for
|
|
|
|
// "includeCredentialsOnRefreshOnBody" will get
|
|
|
|
// removed once we add the OAuth2 hooks to the
|
|
|
|
// credentials file.
|
2020-07-25 10:58:38 -07:00
|
|
|
export interface IOAuth2Options {
|
|
|
|
includeCredentialsOnRefreshOnBody?: boolean;
|
|
|
|
property?: string;
|
|
|
|
tokenType?: string;
|
2020-09-16 00:16:06 -07:00
|
|
|
keepBearer?: boolean;
|
2021-02-21 23:49:00 -08:00
|
|
|
tokenExpiredStatusCode?: number;
|
2022-07-15 01:36:01 -07:00
|
|
|
keyToIncludeInAccessTokenHeader?: string;
|
2020-07-25 10:58:38 -07:00
|
|
|
}
|
2019-06-23 03:35:23 -07:00
|
|
|
|
|
|
|
export interface IConnection {
|
|
|
|
// The node the connection is to
|
|
|
|
node: string;
|
|
|
|
|
|
|
|
// The type of the input on destination node (for example "main")
|
|
|
|
type: string;
|
|
|
|
|
|
|
|
// The output/input-index of destination node (if node has multiple inputs/outputs of the same type)
|
|
|
|
index: number;
|
|
|
|
}
|
|
|
|
|
2022-06-06 00:17:35 -07:00
|
|
|
export type ExecutionError =
|
|
|
|
| WorkflowActivationError
|
|
|
|
| WorkflowOperationError
|
|
|
|
| NodeOperationError
|
|
|
|
| NodeApiError;
|
2019-06-23 03:35:23 -07:00
|
|
|
|
|
|
|
// Get used to gives nodes access to credentials
|
|
|
|
export interface IGetCredentials {
|
2021-10-13 15:21:00 -07:00
|
|
|
get(type: string, id: string | null): Promise<ICredentialsEncrypted>;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
export abstract class ICredentials {
|
2021-10-13 15:21:00 -07:00
|
|
|
id?: string;
|
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
name: string;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
type: string;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
data: string | undefined;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
nodesAccess: ICredentialNodeAccess[];
|
|
|
|
|
2021-10-13 15:21:00 -07:00
|
|
|
constructor(
|
|
|
|
nodeCredentials: INodeCredentialsDetails,
|
|
|
|
type: string,
|
|
|
|
nodesAccess: ICredentialNodeAccess[],
|
|
|
|
data?: string,
|
|
|
|
) {
|
|
|
|
// eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
|
|
|
|
this.id = nodeCredentials.id || undefined;
|
|
|
|
this.name = nodeCredentials.name;
|
2020-01-25 23:48:38 -08:00
|
|
|
this.type = type;
|
|
|
|
this.nodesAccess = nodesAccess;
|
|
|
|
this.data = data;
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract getData(encryptionKey: string, nodeType?: string): ICredentialDataDecryptedObject;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
abstract getDataKey(key: string, encryptionKey: string, nodeType?: string): CredentialInformation;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
abstract getDataToSave(): ICredentialsEncrypted;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
abstract hasNodeAccess(nodeType: string): boolean;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
abstract setData(data: ICredentialDataDecryptedObject, encryptionKey: string): void;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
2020-01-25 23:48:38 -08:00
|
|
|
abstract setDataKey(key: string, data: CredentialInformation, encryptionKey: string): void;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
// Defines which nodes are allowed to access the credentials and
|
|
|
|
// when that access got grented from which user
|
|
|
|
export interface ICredentialNodeAccess {
|
|
|
|
nodeType: string;
|
|
|
|
user?: string;
|
2019-07-22 11:29:06 -07:00
|
|
|
date?: Date;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface ICredentialsDecrypted {
|
2021-10-13 15:21:00 -07:00
|
|
|
id: string | number;
|
2019-06-23 03:35:23 -07:00
|
|
|
name: string;
|
|
|
|
type: string;
|
|
|
|
nodesAccess: ICredentialNodeAccess[];
|
|
|
|
data?: ICredentialDataDecryptedObject;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ICredentialsEncrypted {
|
2021-10-13 15:21:00 -07:00
|
|
|
id?: string | number;
|
2019-06-23 03:35:23 -07:00
|
|
|
name: string;
|
|
|
|
type: string;
|
|
|
|
nodesAccess: ICredentialNodeAccess[];
|
|
|
|
data?: string;
|
|
|
|
}
|
|
|
|
|
2021-01-24 04:33:57 -08:00
|
|
|
export interface ICredentialsExpressionResolveValues {
|
|
|
|
connectionInputData: INodeExecutionData[];
|
|
|
|
itemIndex: number;
|
|
|
|
node: INode;
|
|
|
|
runExecutionData: IRunExecutionData | null;
|
|
|
|
runIndex: number;
|
|
|
|
workflow: Workflow;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
// Simplified options of request library
|
|
|
|
export interface IRequestOptionsSimplified {
|
|
|
|
auth?: {
|
|
|
|
username: string;
|
|
|
|
password: string;
|
|
|
|
};
|
|
|
|
body: IDataObject;
|
|
|
|
headers: IDataObject;
|
|
|
|
qs: IDataObject;
|
|
|
|
}
|
|
|
|
|
2022-06-26 15:55:51 -07:00
|
|
|
export interface IRequestOptionsSimplifiedAuth {
|
|
|
|
auth?: {
|
|
|
|
username: string;
|
|
|
|
password: string;
|
|
|
|
};
|
|
|
|
body?: IDataObject;
|
|
|
|
headers?: IDataObject;
|
|
|
|
qs?: IDataObject;
|
feat(Elasticsearch Node): Add credential tests, index pipelines and index refresh (#2420)
* 🐛 ES query string not passed to request
* 🔑 Add ES credential test
* ✨ Add ES index pipelines and index refresh
* :hammer: merge fix
* :zap: renamed additional filds as options
* :zap: added ignore ssl to credentials
* :zap: Improvements
* :zap: Improvements
* feat(Redis Node): Add push and pop operations (#3127)
* ✨ Add push and pop operations
* :zap: linter fixes
* :zap: linter fixes
* 🐛 Fix errors and remove overwrite
* 🐛 Remove errant hint
* :zap: Small change
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
* refactor: Telemetry updates (#3529)
* Init unit tests for telemetry
* Update telemetry tests
* Test Workflow execution errored event
* Add new tracking logic in pulse
* cleanup
* interfaces
* Add event_version for Workflow execution count event
* add version_cli in all events
* add user saved credentials event
* update manual wf exec finished, fixes
* improve typings, lint
* add node_graph_string in User clicked execute workflow button event
* add User set node operation or mode event
* Add instance started event in FE
* Add User clicked retry execution button event
* add expression editor event
* add input node type to add node event
* add User stopped workflow execution wvent
* add error message in saved credential event
* update stop execution event
* add execution preflight event
* Remove instance started even tfrom FE, add session started to FE,BE
* improve typing
* remove node_graph as property from all events
* move back from default export
* move psl npm package to cli package
* cr
* update webhook node domain logic
* fix is_valid for User saved credentials event
* fix Expression Editor variable selector event
* add caused_by_credential in preflight event
* undo webhook_domain
* change node_type to full type
* add webhook_domain property in manual execution event (#3680)
* add webhook_domain property in manual execution event
* lint fix
* feat(SpreadsheetFile Node): Allow skipping headers when writing spreadsheets (#3234)
* ⚡ Allow skipping headers when writing spreadsheets
* Fix type on sheet options
* fix(Telegram Node): Fix sending binaryData media (photo, document, video etc.) (#3408)
* fixed send media (photo, document, video etc.) issues on Telegram Node
* fixed send media (photo, document, video etc.) issues on Telegram Node
* file name is optional now
* :zap: lock file and linter fix
* :zap: improvements
* :zap: fixes
* :zap: Improvements
* :zap: Add placeholder to File Name
* :zap: Add error message
* :fire: Remove requestWithAuthentication
* :zap: Fix typo
* :shirt: Fix linting issues
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
* feat(Freshworks CRM Node): Add Search + Lookup functionality (#3131)
* Add fields and Ops for Lookup Search
* Adds Search (Search + Lookup) operations
* :hammer: credentials update
* :hammer: improvements
* :zap: clean up and linter fixes
* :zap: merged search and query, more hints
* :zap: Improvements
* :zap: Add generic type to authentication method
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
* feat(Jira Trigger Node): Add optional query auth for security (#3172)
* ✨ Add query auth for Jira Trigger security
* :zap: small fixes:
* :zap: Response with 403 when invalid query authentication
* :shirt: Fix linting issues
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
* :zap: Changed authentication to use the generic type
Co-authored-by: Michael Kret <michael.k@radency.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
Co-authored-by: Nicholas Penree <nick@penree.com>
Co-authored-by: Taha Sönmez <35905778+tahasonmez@users.noreply.github.com>
Co-authored-by: Jan Thiel <JanThiel@users.noreply.github.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
2022-07-10 02:00:47 -07:00
|
|
|
skipSslCertificateValidation?: boolean | string;
|
2022-06-26 15:55:51 -07:00
|
|
|
}
|
|
|
|
|
2022-07-19 01:09:06 -07:00
|
|
|
export interface IHttpRequestHelper {
|
|
|
|
helpers: { httpRequest: IAllExecuteFunctions['helpers']['httpRequest'] };
|
|
|
|
}
|
2020-01-25 23:48:38 -08:00
|
|
|
export abstract class ICredentialsHelper {
|
|
|
|
encryptionKey: string;
|
|
|
|
|
2021-08-20 09:57:30 -07:00
|
|
|
constructor(encryptionKey: string) {
|
2020-01-25 23:48:38 -08:00
|
|
|
this.encryptionKey = encryptionKey;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
abstract getParentTypes(name: string): string[];
|
|
|
|
|
|
|
|
abstract authenticate(
|
|
|
|
credentials: ICredentialDataDecryptedObject,
|
|
|
|
typeName: string,
|
|
|
|
requestOptions: IHttpRequestOptions | IRequestOptionsSimplified,
|
|
|
|
workflow: Workflow,
|
|
|
|
node: INode,
|
2022-04-10 02:33:42 -07:00
|
|
|
defaultTimezone: string,
|
2022-02-05 13:55:43 -08:00
|
|
|
): Promise<IHttpRequestOptions>;
|
|
|
|
|
2022-07-19 01:09:06 -07:00
|
|
|
abstract preAuthentication(
|
|
|
|
helpers: IHttpRequestHelper,
|
|
|
|
credentials: ICredentialDataDecryptedObject,
|
|
|
|
typeName: string,
|
|
|
|
node: INode,
|
|
|
|
credentialsExpired: boolean,
|
|
|
|
): Promise<ICredentialDataDecryptedObject | undefined>;
|
|
|
|
|
2021-10-13 15:21:00 -07:00
|
|
|
abstract getCredentials(
|
|
|
|
nodeCredentials: INodeCredentialsDetails,
|
|
|
|
type: string,
|
|
|
|
): Promise<ICredentials>;
|
2021-08-29 11:58:11 -07:00
|
|
|
|
|
|
|
abstract getDecrypted(
|
2021-10-13 15:21:00 -07:00
|
|
|
nodeCredentials: INodeCredentialsDetails,
|
2021-08-29 11:58:11 -07:00
|
|
|
type: string,
|
|
|
|
mode: WorkflowExecuteMode,
|
2022-04-10 02:33:42 -07:00
|
|
|
defaultTimezone: string,
|
2021-08-29 11:58:11 -07:00
|
|
|
raw?: boolean,
|
|
|
|
expressionResolveValues?: ICredentialsExpressionResolveValues,
|
|
|
|
): Promise<ICredentialDataDecryptedObject>;
|
|
|
|
|
|
|
|
abstract updateCredentials(
|
2021-10-13 15:21:00 -07:00
|
|
|
nodeCredentials: INodeCredentialsDetails,
|
2021-08-29 11:58:11 -07:00
|
|
|
type: string,
|
|
|
|
data: ICredentialDataDecryptedObject,
|
|
|
|
): Promise<void>;
|
2020-01-25 23:48:38 -08:00
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface IAuthenticateBase {
|
|
|
|
type: string;
|
2022-06-26 15:55:51 -07:00
|
|
|
properties:
|
|
|
|
| {
|
|
|
|
[key: string]: string;
|
|
|
|
}
|
|
|
|
| IRequestOptionsSimplifiedAuth;
|
2022-02-05 13:55:43 -08:00
|
|
|
}
|
|
|
|
|
2022-06-26 15:55:51 -07:00
|
|
|
export interface IAuthenticateGeneric extends IAuthenticateBase {
|
|
|
|
type: 'generic';
|
|
|
|
properties: IRequestOptionsSimplifiedAuth;
|
2022-02-05 13:55:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
export type IAuthenticate =
|
|
|
|
| ((
|
|
|
|
credentials: ICredentialDataDecryptedObject,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
) => Promise<IHttpRequestOptions>)
|
2022-06-26 15:55:51 -07:00
|
|
|
| IAuthenticateGeneric;
|
2022-02-05 13:55:43 -08:00
|
|
|
|
|
|
|
export interface IAuthenticateRuleBase {
|
|
|
|
type: string;
|
|
|
|
properties: {
|
|
|
|
[key: string]: string | number;
|
|
|
|
};
|
|
|
|
errorMessage?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IAuthenticateRuleResponseCode extends IAuthenticateRuleBase {
|
|
|
|
type: 'responseCode';
|
|
|
|
properties: {
|
|
|
|
value: number;
|
|
|
|
message: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-04-19 03:36:01 -07:00
|
|
|
export interface IAuthenticateRuleResponseSuccessBody extends IAuthenticateRuleBase {
|
|
|
|
type: 'responseSuccessBody';
|
|
|
|
properties: {
|
|
|
|
message: string;
|
|
|
|
key: string;
|
|
|
|
value: any;
|
|
|
|
};
|
|
|
|
}
|
2022-07-20 04:50:16 -07:00
|
|
|
|
|
|
|
type Override<A extends object, B extends object> = Omit<A, keyof B> & B;
|
|
|
|
|
|
|
|
export namespace DeclarativeRestApiSettings {
|
|
|
|
// The type below might be extended
|
|
|
|
// with new options that need to be parsed as expressions
|
|
|
|
export type HttpRequestOptions = Override<
|
|
|
|
IHttpRequestOptions,
|
|
|
|
{ skipSslCertificateValidation?: string | boolean; url?: string }
|
|
|
|
>;
|
|
|
|
|
|
|
|
export type ResultOptions = {
|
|
|
|
maxResults?: number | string;
|
|
|
|
options: HttpRequestOptions;
|
|
|
|
paginate?: boolean | string;
|
|
|
|
preSend: PreSendAction[];
|
|
|
|
postReceive: Array<{
|
|
|
|
data: {
|
|
|
|
parameterValue: string | IDataObject | undefined;
|
|
|
|
};
|
|
|
|
actions: PostReceiveAction[];
|
|
|
|
}>;
|
|
|
|
requestOperations?: IN8nRequestOperations;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface ICredentialTestRequest {
|
2022-07-20 04:50:16 -07:00
|
|
|
request: DeclarativeRestApiSettings.HttpRequestOptions;
|
2022-04-19 03:36:01 -07:00
|
|
|
rules?: IAuthenticateRuleResponseCode[] | IAuthenticateRuleResponseSuccessBody[];
|
2022-02-05 13:55:43 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface ICredentialTestRequestData {
|
|
|
|
nodeType?: INodeType;
|
|
|
|
testRequest: ICredentialTestRequest;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface ICredentialType {
|
|
|
|
name: string;
|
|
|
|
displayName: string;
|
2021-09-11 01:15:36 -07:00
|
|
|
icon?: string;
|
2020-01-13 18:46:58 -08:00
|
|
|
extends?: string[];
|
2019-06-23 03:35:23 -07:00
|
|
|
properties: INodeProperties[];
|
2020-08-17 02:58:36 -07:00
|
|
|
documentationUrl?: string;
|
2020-01-25 23:48:38 -08:00
|
|
|
__overwrittenProperties?: string[];
|
2022-02-05 13:55:43 -08:00
|
|
|
authenticate?: IAuthenticate;
|
2022-07-19 01:09:06 -07:00
|
|
|
preAuthentication?: (
|
|
|
|
this: IHttpRequestHelper,
|
|
|
|
credentials: ICredentialDataDecryptedObject,
|
|
|
|
) => Promise<IDataObject>;
|
2022-02-05 13:55:43 -08:00
|
|
|
test?: ICredentialTestRequest;
|
2022-05-24 02:36:19 -07:00
|
|
|
genericAuth?: boolean;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface ICredentialTypes {
|
2022-02-05 13:55:43 -08:00
|
|
|
credentialTypes?: ICredentialTypeData;
|
|
|
|
init(credentialTypes?: ICredentialTypeData): Promise<void>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getAll(): ICredentialType[];
|
|
|
|
getByName(credentialType: string): ICredentialType;
|
|
|
|
}
|
|
|
|
|
|
|
|
// The way the credentials get saved in the database (data encrypted)
|
|
|
|
export interface ICredentialData {
|
2021-10-13 15:21:00 -07:00
|
|
|
id?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
name: string;
|
|
|
|
data: string; // Contains the access data as encrypted JSON string
|
|
|
|
nodesAccess: ICredentialNodeAccess[];
|
|
|
|
}
|
|
|
|
|
|
|
|
// The encrypted credentials which the nodes can access
|
2020-01-13 18:46:58 -08:00
|
|
|
export type CredentialInformation = string | number | boolean | IDataObject;
|
2019-06-23 03:35:23 -07:00
|
|
|
|
|
|
|
// The encrypted credentials which the nodes can access
|
|
|
|
export interface ICredentialDataDecryptedObject {
|
|
|
|
[key: string]: CredentialInformation;
|
|
|
|
}
|
|
|
|
|
|
|
|
// First array index: The output/input-index (if node has multiple inputs/outputs of the same type)
|
|
|
|
// Second array index: The different connections (if one node is connected to multiple nodes)
|
|
|
|
export type NodeInputConnections = IConnection[][];
|
|
|
|
|
2022-06-03 08:25:07 -07:00
|
|
|
export interface INodeConnection {
|
|
|
|
sourceIndex: number;
|
|
|
|
destinationIndex: number;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface INodeConnections {
|
|
|
|
// Input name
|
|
|
|
[key: string]: NodeInputConnections;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IConnections {
|
|
|
|
// Node name
|
|
|
|
[key: string]: INodeConnections;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type GenericValue = string | object | number | boolean | undefined | null;
|
|
|
|
|
|
|
|
export interface IDataObject {
|
|
|
|
[key: string]: GenericValue | IDataObject | GenericValue[] | IDataObject[];
|
|
|
|
}
|
|
|
|
|
2021-11-05 09:45:51 -07:00
|
|
|
// export type IExecuteResponsePromiseData = IDataObject;
|
|
|
|
export type IExecuteResponsePromiseData = IDataObject | IN8nHttpFullResponse;
|
|
|
|
|
2021-09-21 10:38:24 -07:00
|
|
|
export interface INodeTypeNameVersion {
|
|
|
|
name: string;
|
|
|
|
version: number;
|
|
|
|
}
|
|
|
|
|
2019-12-31 12:19:37 -08:00
|
|
|
export interface IGetExecutePollFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
node: INode,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
activation: WorkflowActivateMode,
|
|
|
|
): IPollFunctions;
|
2019-12-31 12:19:37 -08:00
|
|
|
}
|
|
|
|
|
2019-08-08 11:38:25 -07:00
|
|
|
export interface IGetExecuteTriggerFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
node: INode,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
activation: WorkflowActivateMode,
|
|
|
|
): ITriggerFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
}
|
|
|
|
|
2022-05-30 03:16:44 -07:00
|
|
|
export interface IRunNodeResponse {
|
|
|
|
data: INodeExecutionData[][] | null | undefined;
|
|
|
|
closeFunction?: () => Promise<void>;
|
|
|
|
}
|
2019-08-08 11:38:25 -07:00
|
|
|
export interface IGetExecuteFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
runExecutionData: IRunExecutionData,
|
|
|
|
runIndex: number,
|
|
|
|
connectionInputData: INodeExecutionData[],
|
|
|
|
inputData: ITaskDataConnections,
|
|
|
|
node: INode,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
2022-06-03 08:25:07 -07:00
|
|
|
executeData: IExecuteData,
|
2021-08-29 11:58:11 -07:00
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
): IExecuteFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IGetExecuteSingleFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
runExecutionData: IRunExecutionData,
|
|
|
|
runIndex: number,
|
|
|
|
connectionInputData: INodeExecutionData[],
|
|
|
|
inputData: ITaskDataConnections,
|
|
|
|
node: INode,
|
|
|
|
itemIndex: number,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
2022-06-03 08:25:07 -07:00
|
|
|
executeData: IExecuteData,
|
2021-08-29 11:58:11 -07:00
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
): IExecuteSingleFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IGetExecuteHookFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
node: INode,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
activation: WorkflowActivateMode,
|
|
|
|
isTest?: boolean,
|
|
|
|
webhookData?: IWebhookData,
|
|
|
|
): IHookFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IGetExecuteWebhookFunctions {
|
2021-08-29 11:58:11 -07:00
|
|
|
(
|
|
|
|
workflow: Workflow,
|
|
|
|
node: INode,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
|
|
|
mode: WorkflowExecuteMode,
|
|
|
|
webhookData: IWebhookData,
|
|
|
|
): IWebhookFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
}
|
|
|
|
|
2022-06-03 08:25:07 -07:00
|
|
|
export interface ISourceDataConnections {
|
|
|
|
// Key for each input type and because there can be multiple inputs of the same type it is an array
|
|
|
|
// null is also allowed because if we still need data for a later while executing the workflow set teompoary to null
|
|
|
|
// the nodes get as input TaskDataConnections which is identical to this one except that no null is allowed.
|
|
|
|
[key: string]: Array<ISourceData[] | null>;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IExecuteData {
|
|
|
|
data: ITaskDataConnections;
|
|
|
|
node: INode;
|
2022-06-03 08:25:07 -07:00
|
|
|
source: ITaskDataConnectionsSource | null;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export type IContextObject = {
|
2021-08-29 11:58:11 -07:00
|
|
|
[key: string]: any;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
export interface IExecuteContextData {
|
|
|
|
// Keys are: "flow" | "node:<NODE_NAME>"
|
|
|
|
[key: string]: IContextObject;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export type IHttpRequestMethods = 'DELETE' | 'GET' | 'HEAD' | 'PATCH' | 'POST' | 'PUT';
|
|
|
|
|
2021-09-21 10:38:24 -07:00
|
|
|
export interface IHttpRequestOptions {
|
|
|
|
url: string;
|
2022-02-05 13:55:43 -08:00
|
|
|
baseURL?: string;
|
2021-09-21 10:38:24 -07:00
|
|
|
headers?: IDataObject;
|
2022-02-05 13:55:43 -08:00
|
|
|
method?: IHttpRequestMethods;
|
2021-09-21 10:38:24 -07:00
|
|
|
body?: FormData | GenericValue | GenericValue[] | Buffer | URLSearchParams;
|
|
|
|
qs?: IDataObject;
|
|
|
|
arrayFormat?: 'indices' | 'brackets' | 'repeat' | 'comma';
|
|
|
|
auth?: {
|
|
|
|
username: string;
|
|
|
|
password: string;
|
|
|
|
};
|
|
|
|
disableFollowRedirect?: boolean;
|
|
|
|
encoding?: 'arraybuffer' | 'blob' | 'document' | 'json' | 'text' | 'stream';
|
|
|
|
skipSslCertificateValidation?: boolean;
|
|
|
|
returnFullResponse?: boolean;
|
2022-03-06 02:41:01 -08:00
|
|
|
ignoreHttpStatusErrors?: boolean;
|
2021-09-21 10:38:24 -07:00
|
|
|
proxy?: {
|
|
|
|
host: string;
|
|
|
|
port: number;
|
|
|
|
auth?: {
|
|
|
|
username: string;
|
|
|
|
password: string;
|
|
|
|
};
|
|
|
|
protocol?: string;
|
|
|
|
};
|
|
|
|
timeout?: number;
|
|
|
|
json?: boolean;
|
|
|
|
}
|
|
|
|
|
2021-11-05 09:45:51 -07:00
|
|
|
export type IN8nHttpResponse = IDataObject | Buffer | GenericValue | GenericValue[] | null;
|
2021-09-21 10:38:24 -07:00
|
|
|
|
|
|
|
export interface IN8nHttpFullResponse {
|
|
|
|
body: IN8nHttpResponse;
|
|
|
|
headers: IDataObject;
|
|
|
|
statusCode: number;
|
2021-11-05 09:45:51 -07:00
|
|
|
statusMessage?: string;
|
2021-09-21 10:38:24 -07:00
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface IN8nRequestOperations {
|
|
|
|
pagination?:
|
|
|
|
| IN8nRequestOperationPaginationOffset
|
|
|
|
| ((
|
|
|
|
this: IExecutePaginationFunctions,
|
2022-07-20 04:50:16 -07:00
|
|
|
requestOptions: DeclarativeRestApiSettings.ResultOptions,
|
2022-02-05 13:55:43 -08:00
|
|
|
) => Promise<INodeExecutionData[]>);
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IN8nRequestOperationPaginationBase {
|
|
|
|
type: string;
|
|
|
|
properties: {
|
|
|
|
[key: string]: string | number;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IN8nRequestOperationPaginationOffset extends IN8nRequestOperationPaginationBase {
|
|
|
|
type: 'offset';
|
|
|
|
properties: {
|
|
|
|
limitParameter: string;
|
|
|
|
offsetParameter: string;
|
|
|
|
pageSize: number;
|
|
|
|
rootProperty?: string; // Optional Path to option array
|
|
|
|
type: 'body' | 'query';
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IExecuteFunctions {
|
2020-03-17 05:18:04 -07:00
|
|
|
continueOnFail(): boolean;
|
2021-08-29 11:58:11 -07:00
|
|
|
evaluateExpression(
|
|
|
|
expression: string,
|
|
|
|
itemIndex: number,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[];
|
|
|
|
executeWorkflow(
|
|
|
|
workflowInfo: IExecuteWorkflowInfo,
|
|
|
|
inputData?: INodeExecutionData[],
|
|
|
|
): Promise<any>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getContext(type: string): IContextObject;
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string, itemIndex?: number): Promise<ICredentialDataDecryptedObject>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getInputData(inputIndex?: number, inputName?: string): INodeExecutionData[];
|
|
|
|
getMode(): WorkflowExecuteMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-09-21 10:38:24 -07:00
|
|
|
getNodeParameter<T extends { resource: string }>(
|
|
|
|
parameterName: 'resource',
|
|
|
|
itemIndex?: number,
|
|
|
|
): T['resource'];
|
|
|
|
// getNodeParameter(parameterName: 'operation', itemIndex?: number): string;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
itemIndex: number,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-09-04 05:53:39 -07:00
|
|
|
getWorkflowDataProxy(itemIndex: number): IWorkflowDataProxyData;
|
2019-06-23 03:35:23 -07:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
2019-12-19 14:07:55 -08:00
|
|
|
getRestApiUrl(): string;
|
2019-06-23 03:35:23 -07:00
|
|
|
getTimezone(): string;
|
2022-06-03 08:25:07 -07:00
|
|
|
getExecuteData(): IExecuteData;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2021-08-29 11:58:11 -07:00
|
|
|
prepareOutputData(
|
|
|
|
outputData: INodeExecutionData[],
|
|
|
|
outputIndex?: number,
|
|
|
|
): Promise<INodeExecutionData[][]>;
|
2021-08-21 05:11:32 -07:00
|
|
|
putExecutionToWait(waitTill: Date): Promise<void>;
|
2021-11-05 09:45:51 -07:00
|
|
|
sendMessageToUI(message: any): void; // tslint:disable-line:no-any
|
|
|
|
sendResponse(response: IExecuteResponsePromiseData): void; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IExecuteSingleFunctions {
|
2020-03-17 05:18:04 -07:00
|
|
|
continueOnFail(): boolean;
|
2021-08-29 11:58:11 -07:00
|
|
|
evaluateExpression(
|
|
|
|
expression: string,
|
|
|
|
itemIndex: number | undefined,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[];
|
2019-06-23 03:35:23 -07:00
|
|
|
getContext(type: string): IContextObject;
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getInputData(inputIndex?: number, inputName?: string): INodeExecutionData;
|
2022-06-26 15:52:37 -07:00
|
|
|
getItemIndex(): number;
|
2019-06-23 03:35:23 -07:00
|
|
|
getMode(): WorkflowExecuteMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-12-19 14:07:55 -08:00
|
|
|
getRestApiUrl(): string;
|
2019-06-23 03:35:23 -07:00
|
|
|
getTimezone(): string;
|
2022-06-03 08:25:07 -07:00
|
|
|
getExecuteData(): IExecuteData;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2019-09-04 05:53:39 -07:00
|
|
|
getWorkflowDataProxy(): IWorkflowDataProxyData;
|
2019-06-23 03:35:23 -07:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface IExecutePaginationFunctions extends IExecuteSingleFunctions {
|
|
|
|
makeRoutingRequest(
|
|
|
|
this: IAllExecuteFunctions,
|
2022-07-20 04:50:16 -07:00
|
|
|
requestOptions: DeclarativeRestApiSettings.ResultOptions,
|
2022-02-05 13:55:43 -08:00
|
|
|
): Promise<INodeExecutionData[]>;
|
|
|
|
}
|
2020-01-02 15:13:53 -08:00
|
|
|
export interface IExecuteWorkflowInfo {
|
|
|
|
code?: IWorkflowBase;
|
|
|
|
id?: string;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export type ICredentialTestFunction = (
|
|
|
|
this: ICredentialTestFunctions,
|
|
|
|
credential: ICredentialsDecrypted,
|
|
|
|
) => Promise<INodeCredentialTestResult>;
|
|
|
|
|
2021-09-11 01:15:36 -07:00
|
|
|
export interface ICredentialTestFunctions {
|
|
|
|
helpers: {
|
|
|
|
[key: string]: (...args: any[]) => any;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface ILoadOptionsFunctions {
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
|
|
|
getCurrentNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
):
|
|
|
|
| NodeParameterValue
|
|
|
|
| INodeParameters
|
|
|
|
| NodeParameterValue[]
|
|
|
|
| INodeParameters[]
|
|
|
|
| object
|
|
|
|
| undefined;
|
2019-10-20 12:42:34 -07:00
|
|
|
getCurrentNodeParameters(): INodeParameters | undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
getTimezone(): string;
|
2019-12-19 14:07:55 -08:00
|
|
|
getRestApiUrl(): string;
|
2019-06-23 03:35:23 -07:00
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
// TODO: Remove from here. Add it only now to LoadOptions as many nodes do import
|
|
|
|
// from n8n-workflow instead of n8n-core
|
|
|
|
requestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: any, // tslint:disable-line:no-any
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<any>;
|
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: ((...args: any[]) => any) | undefined; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IHookFunctions {
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getMode(): WorkflowExecuteMode;
|
2021-03-23 11:08:47 -07:00
|
|
|
getActivationMode(): WorkflowActivateMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2019-06-23 03:35:23 -07:00
|
|
|
getNodeWebhookUrl: (name: string) => string | undefined;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-06-23 03:35:23 -07:00
|
|
|
getTimezone(): string;
|
|
|
|
getWebhookDescription(name: string): IWebhookDescription | undefined;
|
2019-07-12 02:33:18 -07:00
|
|
|
getWebhookName(): string;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2019-06-23 03:35:23 -07:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-12-31 12:19:37 -08:00
|
|
|
export interface IPollFunctions {
|
|
|
|
__emit(data: INodeExecutionData[][]): void;
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2019-12-31 12:19:37 -08:00
|
|
|
getMode(): WorkflowExecuteMode;
|
2021-03-23 11:08:47 -07:00
|
|
|
getActivationMode(): WorkflowActivateMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-12-31 12:19:37 -08:00
|
|
|
getRestApiUrl(): string;
|
|
|
|
getTimezone(): string;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2019-12-31 12:19:37 -08:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-12-31 12:19:37 -08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface ITriggerFunctions {
|
2021-11-05 09:45:51 -07:00
|
|
|
emit(
|
|
|
|
data: INodeExecutionData[][],
|
|
|
|
responsePromise?: IDeferredPromise<IExecuteResponsePromiseData>,
|
2022-05-30 03:16:44 -07:00
|
|
|
donePromise?: IDeferredPromise<IRun>,
|
2021-11-05 09:45:51 -07:00
|
|
|
): void;
|
2022-04-02 08:33:31 -07:00
|
|
|
emitError(error: Error, responsePromise?: IDeferredPromise<IExecuteResponsePromiseData>): void;
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getMode(): WorkflowExecuteMode;
|
2021-03-23 11:08:47 -07:00
|
|
|
getActivationMode(): WorkflowActivateMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-12-19 14:07:55 -08:00
|
|
|
getRestApiUrl(): string;
|
2019-06-23 03:35:23 -07:00
|
|
|
getTimezone(): string;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2019-06-23 03:35:23 -07:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWebhookFunctions {
|
|
|
|
getBodyData(): IDataObject;
|
2022-04-14 23:00:47 -07:00
|
|
|
getCredentials(type: string): Promise<ICredentialDataDecryptedObject>;
|
2019-06-23 03:35:23 -07:00
|
|
|
getHeaderData(): object;
|
|
|
|
getMode(): WorkflowExecuteMode;
|
2020-02-15 17:07:01 -08:00
|
|
|
getNode(): INode;
|
2021-08-29 11:58:11 -07:00
|
|
|
getNodeParameter(
|
|
|
|
parameterName: string,
|
|
|
|
fallbackValue?: any,
|
|
|
|
): NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[] | object;
|
2019-07-12 02:33:18 -07:00
|
|
|
getNodeWebhookUrl: (name: string) => string | undefined;
|
2021-01-23 11:00:32 -08:00
|
|
|
getParamsData(): object;
|
2019-06-23 03:35:23 -07:00
|
|
|
getQueryData(): object;
|
|
|
|
getRequestObject(): express.Request;
|
|
|
|
getResponseObject(): express.Response;
|
|
|
|
getTimezone(): string;
|
2019-07-12 02:33:18 -07:00
|
|
|
getWebhookName(): string;
|
2019-06-23 03:35:23 -07:00
|
|
|
getWorkflowStaticData(type: string): IDataObject;
|
2020-04-11 01:30:50 -07:00
|
|
|
getWorkflow(): IWorkflowMetadata;
|
2021-08-29 11:58:11 -07:00
|
|
|
prepareOutputData(
|
|
|
|
outputData: INodeExecutionData[],
|
|
|
|
outputIndex?: number,
|
|
|
|
): Promise<INodeExecutionData[][]>;
|
2019-06-23 03:35:23 -07:00
|
|
|
helpers: {
|
2021-09-21 10:38:24 -07:00
|
|
|
httpRequest(
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2022-02-05 13:55:43 -08:00
|
|
|
httpRequestWithAuthentication(
|
|
|
|
this: IAllExecuteFunctions,
|
|
|
|
credentialsType: string,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
additionalCredentialOptions?: IAdditionalCredentialOptions,
|
|
|
|
): Promise<IN8nHttpResponse | IN8nHttpFullResponse>;
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: (...args: any[]) => any; // tslint:disable-line:no-any
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-10-13 15:21:00 -07:00
|
|
|
export interface INodeCredentialsDetails {
|
|
|
|
id: string | null;
|
|
|
|
name: string;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface INodeCredentials {
|
2021-10-13 15:21:00 -07:00
|
|
|
[key: string]: INodeCredentialsDetails;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INode {
|
2022-08-03 04:06:53 -07:00
|
|
|
id: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
name: string;
|
|
|
|
typeVersion: number;
|
|
|
|
type: string;
|
|
|
|
position: [number, number];
|
|
|
|
disabled?: boolean;
|
2021-07-01 00:04:24 -07:00
|
|
|
notes?: string;
|
2020-05-05 08:34:12 -07:00
|
|
|
notesInFlow?: boolean;
|
2019-07-18 10:26:16 -07:00
|
|
|
retryOnFail?: boolean;
|
|
|
|
maxTries?: number;
|
|
|
|
waitBetweenTries?: number;
|
2020-04-12 10:58:30 -07:00
|
|
|
alwaysOutputData?: boolean;
|
2020-08-08 11:31:04 -07:00
|
|
|
executeOnce?: boolean;
|
2019-06-23 03:35:23 -07:00
|
|
|
continueOnFail?: boolean;
|
|
|
|
parameters: INodeParameters;
|
|
|
|
credentials?: INodeCredentials;
|
2020-06-10 07:17:16 -07:00
|
|
|
webhookId?: string;
|
2022-07-20 08:50:39 -07:00
|
|
|
}
|
|
|
|
|
2022-07-22 03:19:45 -07:00
|
|
|
export interface IPinData {
|
2022-07-20 08:50:39 -07:00
|
|
|
[nodeName: string]: IDataObject[];
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodes {
|
|
|
|
[key: string]: INode;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IObservableObject {
|
2021-08-29 11:58:11 -07:00
|
|
|
[key: string]: any;
|
2019-06-23 03:35:23 -07:00
|
|
|
__dataChanged: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IBinaryKeyData {
|
|
|
|
[key: string]: IBinaryData;
|
|
|
|
}
|
|
|
|
|
2022-06-03 08:25:07 -07:00
|
|
|
export interface IPairedItemData {
|
|
|
|
item: number;
|
|
|
|
input?: number; // If undefined "0" gets used
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface INodeExecutionData {
|
2022-06-03 08:25:07 -07:00
|
|
|
[key: string]:
|
|
|
|
| IDataObject
|
|
|
|
| IBinaryKeyData
|
|
|
|
| IPairedItemData
|
|
|
|
| IPairedItemData[]
|
|
|
|
| NodeApiError
|
|
|
|
| NodeOperationError
|
|
|
|
| number
|
|
|
|
| undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
json: IDataObject;
|
|
|
|
binary?: IBinaryKeyData;
|
2021-09-21 10:38:24 -07:00
|
|
|
error?: NodeApiError | NodeOperationError;
|
2022-06-03 08:25:07 -07:00
|
|
|
pairedItem?: IPairedItemData | IPairedItemData[] | number;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeExecuteFunctions {
|
2019-12-31 12:19:37 -08:00
|
|
|
getExecutePollFunctions: IGetExecutePollFunctions;
|
2019-08-08 11:38:25 -07:00
|
|
|
getExecuteTriggerFunctions: IGetExecuteTriggerFunctions;
|
|
|
|
getExecuteFunctions: IGetExecuteFunctions;
|
|
|
|
getExecuteSingleFunctions: IGetExecuteSingleFunctions;
|
|
|
|
getExecuteHookFunctions: IGetExecuteHookFunctions;
|
|
|
|
getExecuteWebhookFunctions: IGetExecuteWebhookFunctions;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// The values a node property can have
|
2020-10-26 01:26:07 -07:00
|
|
|
export type NodeParameterValue = string | number | boolean | undefined | null;
|
2019-06-23 03:35:23 -07:00
|
|
|
|
|
|
|
export interface INodeParameters {
|
|
|
|
// TODO: Later also has to be possible to add multiple ones with the name name. So array has to be possible
|
2019-10-20 12:42:34 -07:00
|
|
|
[key: string]: NodeParameterValue | INodeParameters | NodeParameterValue[] | INodeParameters[];
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2021-08-29 11:58:11 -07:00
|
|
|
export type NodePropertyTypes =
|
|
|
|
| 'boolean'
|
|
|
|
| 'collection'
|
|
|
|
| 'color'
|
|
|
|
| 'dateTime'
|
|
|
|
| 'fixedCollection'
|
|
|
|
| 'hidden'
|
|
|
|
| 'json'
|
|
|
|
| 'notice'
|
|
|
|
| 'multiOptions'
|
|
|
|
| 'number'
|
|
|
|
| 'options'
|
2022-05-24 02:36:19 -07:00
|
|
|
| 'string'
|
|
|
|
| 'credentialsSelect';
|
2019-06-23 03:35:23 -07:00
|
|
|
|
2021-12-23 02:41:46 -08:00
|
|
|
export type CodeAutocompleteTypes = 'function' | 'functionItem';
|
|
|
|
|
|
|
|
export type EditorTypes = 'code' | 'json';
|
2019-09-04 09:22:06 -07:00
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface ILoadOptions {
|
|
|
|
routing?: {
|
|
|
|
operations?: IN8nRequestOperations;
|
|
|
|
output?: INodeRequestOutput;
|
2022-07-20 04:50:16 -07:00
|
|
|
request?: DeclarativeRestApiSettings.HttpRequestOptions;
|
2022-02-05 13:55:43 -08:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface INodePropertyTypeOptions {
|
|
|
|
alwaysOpenEditWindow?: boolean; // Supported by: string
|
2021-12-23 02:41:46 -08:00
|
|
|
codeAutocomplete?: CodeAutocompleteTypes; // Supported by: string
|
2021-08-29 11:58:11 -07:00
|
|
|
editor?: EditorTypes; // Supported by: string
|
|
|
|
loadOptionsDependsOn?: string[]; // Supported by: options
|
|
|
|
loadOptionsMethod?: string; // Supported by: options
|
2022-02-05 13:55:43 -08:00
|
|
|
loadOptions?: ILoadOptions; // Supported by: options
|
2021-08-29 11:58:11 -07:00
|
|
|
maxValue?: number; // Supported by: number
|
|
|
|
minValue?: number; // Supported by: number
|
|
|
|
multipleValues?: boolean; // Supported by: <All>
|
|
|
|
multipleValueButtonText?: string; // Supported when "multipleValues" set to true
|
|
|
|
numberPrecision?: number; // Supported by: number
|
|
|
|
password?: boolean; // Supported by: string
|
|
|
|
rows?: number; // Supported by: string
|
|
|
|
showAlpha?: boolean; // Supported by: color
|
|
|
|
sortable?: boolean; // Supported when "multipleValues" set to true
|
2022-07-19 01:09:06 -07:00
|
|
|
expirable?: boolean; // Supported by: hidden (only in the credentials)
|
2022-02-05 13:55:43 -08:00
|
|
|
[key: string]: any;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IDisplayOptions {
|
|
|
|
hide?: {
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: NodeParameterValue[] | undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
show?: {
|
2021-09-21 10:38:24 -07:00
|
|
|
[key: string]: NodeParameterValue[] | undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeProperties {
|
|
|
|
displayName: string;
|
|
|
|
name: string;
|
|
|
|
type: NodePropertyTypes;
|
|
|
|
typeOptions?: INodePropertyTypeOptions;
|
|
|
|
default: NodeParameterValue | INodeParameters | INodeParameters[] | NodeParameterValue[];
|
|
|
|
description?: string;
|
2022-01-27 22:55:25 -08:00
|
|
|
hint?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
displayOptions?: IDisplayOptions;
|
2021-02-20 04:51:06 -08:00
|
|
|
options?: Array<INodePropertyOptions | INodeProperties | INodePropertyCollection>;
|
2019-06-23 03:35:23 -07:00
|
|
|
placeholder?: string;
|
|
|
|
isNodeSetting?: boolean;
|
|
|
|
noDataExpression?: boolean;
|
|
|
|
required?: boolean;
|
2022-02-05 13:55:43 -08:00
|
|
|
routing?: INodePropertyRouting;
|
2022-05-24 02:36:19 -07:00
|
|
|
credentialTypes?: Array<
|
|
|
|
'extends:oAuth2Api' | 'extends:oAuth1Api' | 'has:authenticate' | 'has:genericAuth'
|
|
|
|
>;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
export interface INodePropertyOptions {
|
|
|
|
name: string;
|
2021-12-03 00:44:16 -08:00
|
|
|
value: string | number | boolean;
|
2022-07-04 12:54:56 -07:00
|
|
|
action?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
description?: string;
|
2022-02-05 13:55:43 -08:00
|
|
|
routing?: INodePropertyRouting;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodePropertyCollection {
|
|
|
|
displayName: string;
|
|
|
|
name: string;
|
|
|
|
values: INodeProperties[];
|
|
|
|
}
|
|
|
|
|
2019-07-13 10:50:41 -07:00
|
|
|
export interface IParameterDependencies {
|
|
|
|
[key: string]: string[];
|
|
|
|
}
|
|
|
|
|
2019-12-31 12:19:37 -08:00
|
|
|
export interface IPollResponse {
|
|
|
|
closeFunction?: () => Promise<void>;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface ITriggerResponse {
|
|
|
|
closeFunction?: () => Promise<void>;
|
|
|
|
// To manually trigger the run
|
|
|
|
manualTriggerFunction?: () => Promise<void>;
|
|
|
|
// Gets added automatically at manual workflow runs resolves with
|
|
|
|
// the first emitted data
|
|
|
|
manualTriggerResponse?: Promise<INodeExecutionData[][]>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeType {
|
|
|
|
description: INodeTypeDescription;
|
|
|
|
execute?(this: IExecuteFunctions): Promise<INodeExecutionData[][] | null>;
|
|
|
|
executeSingle?(this: IExecuteSingleFunctions): Promise<INodeExecutionData>;
|
2019-12-31 12:19:37 -08:00
|
|
|
poll?(this: IPollFunctions): Promise<INodeExecutionData[][] | null>;
|
2019-06-23 03:35:23 -07:00
|
|
|
trigger?(this: ITriggerFunctions): Promise<ITriggerResponse | undefined>;
|
2019-10-11 04:02:44 -07:00
|
|
|
webhook?(this: IWebhookFunctions): Promise<IWebhookResponseData>;
|
2019-06-23 03:35:23 -07:00
|
|
|
hooks?: {
|
|
|
|
[key: string]: (this: IHookFunctions) => Promise<boolean>;
|
|
|
|
};
|
|
|
|
methods?: {
|
|
|
|
loadOptions?: {
|
|
|
|
[key: string]: (this: ILoadOptionsFunctions) => Promise<INodePropertyOptions[]>;
|
2021-08-29 11:58:11 -07:00
|
|
|
};
|
2021-09-11 01:15:36 -07:00
|
|
|
credentialTest?: {
|
|
|
|
// Contains a group of functins that test credentials.
|
2022-02-05 13:55:43 -08:00
|
|
|
[functionName: string]: ICredentialTestFunction;
|
2021-09-11 01:15:36 -07:00
|
|
|
};
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
webhookMethods?: {
|
|
|
|
[key: string]: IWebhookSetupMethods;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:24 -07:00
|
|
|
export interface INodeVersionedType {
|
|
|
|
nodeVersions: {
|
|
|
|
[key: number]: INodeType;
|
|
|
|
};
|
|
|
|
currentVersion: number;
|
|
|
|
description: INodeTypeBaseDescription;
|
|
|
|
getNodeType: (version?: number) => INodeType;
|
|
|
|
}
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface INodeCredentialTestResult {
|
2021-09-11 01:15:36 -07:00
|
|
|
status: 'OK' | 'Error';
|
|
|
|
message: string;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface INodeCredentialTestRequest {
|
2021-09-11 01:15:36 -07:00
|
|
|
nodeToTestWith?: string; // node name i.e. slack
|
|
|
|
credentials: ICredentialsDecrypted;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export type WebhookSetupMethodNames = 'checkExists' | 'create' | 'delete';
|
|
|
|
|
|
|
|
export interface IWebhookSetupMethods {
|
|
|
|
[key: string]: ((this: IHookFunctions) => Promise<boolean>) | undefined;
|
|
|
|
checkExists?: (this: IHookFunctions) => Promise<boolean>;
|
|
|
|
create?: (this: IHookFunctions) => Promise<boolean>;
|
|
|
|
delete?: (this: IHookFunctions) => Promise<boolean>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeCredentialDescription {
|
|
|
|
name: string;
|
|
|
|
required?: boolean;
|
|
|
|
displayOptions?: IDisplayOptions;
|
2022-02-05 13:55:43 -08:00
|
|
|
testedBy?: ICredentialTestRequest | string; // Name of a function inside `loadOptions.credentialTest`
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export type INodeIssueTypes = 'credentials' | 'execution' | 'parameters' | 'typeUnknown';
|
|
|
|
|
|
|
|
export interface INodeIssueObjectProperty {
|
|
|
|
[key: string]: string[];
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeIssueData {
|
|
|
|
node: string;
|
|
|
|
type: INodeIssueTypes;
|
|
|
|
value: boolean | string | string[] | INodeIssueObjectProperty;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeIssues {
|
|
|
|
execution?: boolean;
|
|
|
|
credentials?: INodeIssueObjectProperty;
|
|
|
|
parameters?: INodeIssueObjectProperty;
|
|
|
|
typeUnknown?: boolean;
|
|
|
|
[key: string]: undefined | boolean | INodeIssueObjectProperty;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWorfklowIssues {
|
|
|
|
[key: string]: INodeIssues;
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:24 -07:00
|
|
|
export interface INodeTypeBaseDescription {
|
2019-06-23 03:35:23 -07:00
|
|
|
displayName: string;
|
|
|
|
name: string;
|
|
|
|
icon?: string;
|
|
|
|
group: string[];
|
|
|
|
description: string;
|
2020-11-09 03:23:53 -08:00
|
|
|
documentationUrl?: string;
|
2021-09-21 10:38:24 -07:00
|
|
|
subtitle?: string;
|
|
|
|
defaultVersion?: number;
|
|
|
|
codex?: CodexData;
|
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface INodePropertyRouting {
|
|
|
|
operations?: IN8nRequestOperations; // Should be changed, does not sound right
|
|
|
|
output?: INodeRequestOutput;
|
2022-07-20 04:50:16 -07:00
|
|
|
request?: DeclarativeRestApiSettings.HttpRequestOptions;
|
2022-02-05 13:55:43 -08:00
|
|
|
send?: INodeRequestSend;
|
|
|
|
}
|
|
|
|
|
|
|
|
export type PostReceiveAction =
|
|
|
|
| ((
|
|
|
|
this: IExecuteSingleFunctions,
|
|
|
|
items: INodeExecutionData[],
|
|
|
|
response: IN8nHttpFullResponse,
|
|
|
|
) => Promise<INodeExecutionData[]>)
|
|
|
|
| IPostReceiveBinaryData
|
|
|
|
| IPostReceiveRootProperty
|
|
|
|
| IPostReceiveSet
|
|
|
|
| IPostReceiveSetKeyValue
|
|
|
|
| IPostReceiveSort;
|
|
|
|
|
|
|
|
export type PreSendAction = (
|
|
|
|
this: IExecuteSingleFunctions,
|
|
|
|
requestOptions: IHttpRequestOptions,
|
|
|
|
) => Promise<IHttpRequestOptions>;
|
|
|
|
|
|
|
|
export interface INodeRequestOutput {
|
|
|
|
maxResults?: number | string;
|
|
|
|
postReceive?: PostReceiveAction[];
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeRequestSend {
|
|
|
|
preSend?: PreSendAction[];
|
|
|
|
paginate?: boolean | string; // Where should this life?
|
|
|
|
property?: string; // Maybe: propertyName, destinationProperty?
|
|
|
|
propertyInDotNotation?: boolean; // Enabled by default
|
|
|
|
type?: 'body' | 'query';
|
|
|
|
value?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveBase {
|
|
|
|
type: string;
|
2022-07-26 05:43:36 -07:00
|
|
|
enabled?: boolean | string;
|
2022-02-05 13:55:43 -08:00
|
|
|
properties: {
|
|
|
|
[key: string]: string | number | IDataObject;
|
|
|
|
};
|
|
|
|
errorMessage?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveBinaryData extends IPostReceiveBase {
|
|
|
|
type: 'binaryData';
|
|
|
|
properties: {
|
|
|
|
destinationProperty: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveRootProperty extends IPostReceiveBase {
|
|
|
|
type: 'rootProperty';
|
|
|
|
properties: {
|
|
|
|
property: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveSet extends IPostReceiveBase {
|
|
|
|
type: 'set';
|
|
|
|
properties: {
|
|
|
|
value: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveSetKeyValue extends IPostReceiveBase {
|
|
|
|
type: 'setKeyValue';
|
|
|
|
properties: {
|
|
|
|
[key: string]: string | number;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IPostReceiveSort extends IPostReceiveBase {
|
|
|
|
type: 'sort';
|
|
|
|
properties: {
|
|
|
|
key: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:24 -07:00
|
|
|
export interface INodeTypeDescription extends INodeTypeBaseDescription {
|
2022-04-28 10:04:09 -07:00
|
|
|
version: number | number[];
|
2021-09-21 10:38:24 -07:00
|
|
|
defaults: INodeParameters;
|
:sparkles: Improve Waiting Webhook call state in WF Canvas (#2430)
* N8N-2586 Improve Waiting Webhook call state in WF Canvas
* N8N-2586 Added watcher for showing Webhook's Node Tooltip on execution
* N8N-2586 Show helping tooltip for trigger node if wokrflow is running, it is a trigger node, if it is only one trigger node in WF
* N8N-2586 Rework/Move logic to computed property, Created getter for ActveTriggerNodesInWokrflow, Add style to trigger node's tooltip, remove comments
* N8N-2586 Added EventTriggerDescription prop in INodeTypeDescription Interface, Updated Logic for TriggerNode Tooltip based on the new prop
* N8N-2586 Add new use cases/watcher to show Trigger Nodes Tooltip / If has issues, if paused, if wokrlfow is running, Refactor Getter
* N8N-2586 Added z-index to tooltip, Added new Scenario for Tooltip if it is Draged&Droped on the WF
* N8N-2586 Refactor computed property for draged nodes
* N8N-2586 Fixed Conflicts
* N8N-2586 Fixed Tooltip
* N8N-2586 Dont show tooltip on core trigger nodes that execute automatically
* N8N-2586 Fixed Webhook tooltip when adding/deleting canvas during WF execution
* N8N-2586 Updated Logic, Simplify the code
* N8N-2586 Simplify Code
* N8N-2586 Added check for nodetype
* update dragging to use local state
* N8N-2586 Added eventTriggerDescription to Interval Node
* add comment, use new getter
* update to always check
Co-authored-by: Mutasem <mutdmour@gmail.com>
2021-11-25 14:33:41 -08:00
|
|
|
eventTriggerDescription?: string;
|
2022-01-21 09:00:00 -08:00
|
|
|
activationMessage?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
inputs: string[];
|
2019-08-02 06:56:05 -07:00
|
|
|
inputNames?: string[];
|
2019-06-23 03:35:23 -07:00
|
|
|
outputs: string[];
|
|
|
|
outputNames?: string[];
|
|
|
|
properties: INodeProperties[];
|
|
|
|
credentials?: INodeCredentialDescription[];
|
|
|
|
maxNodes?: number; // How many nodes of that type can be created in a workflow
|
2019-12-31 12:19:37 -08:00
|
|
|
polling?: boolean;
|
2022-07-20 04:50:16 -07:00
|
|
|
requestDefaults?: DeclarativeRestApiSettings.HttpRequestOptions;
|
2022-02-05 13:55:43 -08:00
|
|
|
requestOperations?: IN8nRequestOperations;
|
2019-06-23 03:35:23 -07:00
|
|
|
hooks?: {
|
|
|
|
[key: string]: INodeHookDescription[] | undefined;
|
|
|
|
activate?: INodeHookDescription[];
|
|
|
|
deactivate?: INodeHookDescription[];
|
|
|
|
};
|
|
|
|
webhooks?: IWebhookDescription[];
|
2021-11-15 02:19:43 -08:00
|
|
|
translation?: { [key: string]: object };
|
2022-06-20 12:39:24 -07:00
|
|
|
mockManualExecution?: true;
|
|
|
|
triggerPanel?: {
|
|
|
|
header?: string;
|
|
|
|
executionsHelp?:
|
|
|
|
| string
|
|
|
|
| {
|
|
|
|
active: string;
|
|
|
|
inactive: string;
|
|
|
|
};
|
|
|
|
activationHint?:
|
|
|
|
| string
|
|
|
|
| {
|
|
|
|
active: string;
|
|
|
|
inactive: string;
|
|
|
|
};
|
|
|
|
};
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeHookDescription {
|
|
|
|
method: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWebhookData {
|
|
|
|
httpMethod: WebhookHttpMethod;
|
|
|
|
node: string;
|
|
|
|
path: string;
|
|
|
|
webhookDescription: IWebhookDescription;
|
2020-01-22 15:06:43 -08:00
|
|
|
workflowId: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
workflowExecuteAdditionalData: IWorkflowExecuteAdditionalData;
|
2021-01-23 11:00:32 -08:00
|
|
|
webhookId?: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWebhookDescription {
|
2020-06-10 06:39:15 -07:00
|
|
|
[key: string]: WebhookHttpMethod | WebhookResponseMode | boolean | string | undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
httpMethod: WebhookHttpMethod | string;
|
2020-06-10 06:39:15 -07:00
|
|
|
isFullPath?: boolean;
|
2019-06-23 03:35:23 -07:00
|
|
|
name: string;
|
|
|
|
path: string;
|
|
|
|
responseBinaryPropertyName?: string;
|
2019-10-16 05:01:39 -07:00
|
|
|
responseContentType?: string;
|
|
|
|
responsePropertyName?: string;
|
2019-08-28 08:16:09 -07:00
|
|
|
responseMode?: WebhookResponseMode | string;
|
|
|
|
responseData?: WebhookResponseData | string;
|
2021-08-21 05:11:32 -07:00
|
|
|
restartWebhook?: boolean;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2019-09-04 05:53:39 -07:00
|
|
|
export interface IWorkflowDataProxyData {
|
2021-12-23 02:41:46 -08:00
|
|
|
[key: string]: any;
|
2021-08-29 11:58:11 -07:00
|
|
|
$binary: any;
|
|
|
|
$data: any;
|
|
|
|
$env: any;
|
|
|
|
$evaluateExpression: any;
|
|
|
|
$item: any;
|
|
|
|
$items: any;
|
|
|
|
$json: any;
|
|
|
|
$node: any;
|
|
|
|
$parameter: any;
|
|
|
|
$position: any;
|
|
|
|
$workflow: any;
|
2022-03-13 01:34:44 -08:00
|
|
|
$: any;
|
|
|
|
$input: any;
|
|
|
|
$thisItem: any;
|
|
|
|
$thisRunIndex: number;
|
|
|
|
$thisItemIndex: number;
|
|
|
|
$now: any;
|
|
|
|
$today: any;
|
2019-09-04 05:53:39 -07:00
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export type IWorkflowDataProxyAdditionalKeys = IDataObject;
|
2021-08-21 05:11:32 -07:00
|
|
|
|
2020-02-15 17:07:01 -08:00
|
|
|
export interface IWorkflowMetadata {
|
|
|
|
id?: number | string;
|
|
|
|
name?: string;
|
|
|
|
active: boolean;
|
|
|
|
}
|
|
|
|
|
2022-02-20 01:30:01 -08:00
|
|
|
export type WebhookHttpMethod = 'DELETE' | 'GET' | 'HEAD' | 'PATCH' | 'POST' | 'PUT' | 'OPTIONS';
|
2019-06-23 03:35:23 -07:00
|
|
|
|
2019-10-11 04:02:44 -07:00
|
|
|
export interface IWebhookResponseData {
|
2019-06-23 03:35:23 -07:00
|
|
|
workflowData?: INodeExecutionData[][];
|
2021-08-29 11:58:11 -07:00
|
|
|
webhookResponse?: any;
|
2019-06-23 03:35:23 -07:00
|
|
|
noWebhookResponse?: boolean;
|
|
|
|
}
|
|
|
|
|
2022-02-19 03:37:41 -08:00
|
|
|
export type WebhookResponseData = 'allEntries' | 'firstEntryJson' | 'firstEntryBinary' | 'noData';
|
2019-06-23 03:35:23 -07:00
|
|
|
export type WebhookResponseMode = 'onReceived' | 'lastNode';
|
|
|
|
|
|
|
|
export interface INodeTypes {
|
2019-08-08 11:38:25 -07:00
|
|
|
nodeTypes: INodeTypeData;
|
|
|
|
init(nodeTypes?: INodeTypeData): Promise<void>;
|
2021-09-21 10:38:24 -07:00
|
|
|
getAll(): Array<INodeType | INodeVersionedType>;
|
|
|
|
getByNameAndVersion(nodeType: string, version?: number): INodeType | undefined;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2022-02-05 13:55:43 -08:00
|
|
|
export interface ICredentialTypeData {
|
|
|
|
[key: string]: {
|
|
|
|
type: ICredentialType;
|
|
|
|
sourcePath: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-08-08 11:38:25 -07:00
|
|
|
export interface INodeTypeData {
|
|
|
|
[key: string]: {
|
2021-09-21 10:38:24 -07:00
|
|
|
type: INodeType | INodeVersionedType;
|
2019-08-08 11:38:25 -07:00
|
|
|
sourcePath: string;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IRun {
|
|
|
|
data: IRunExecutionData;
|
|
|
|
finished?: boolean;
|
|
|
|
mode: WorkflowExecuteMode;
|
2021-08-21 05:11:32 -07:00
|
|
|
waitTill?: Date;
|
2019-07-22 11:29:06 -07:00
|
|
|
startedAt: Date;
|
2021-02-08 23:59:32 -08:00
|
|
|
stoppedAt?: Date;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Contains all the data which is needed to execute a workflow and so also to
|
|
|
|
// start restart it again after it did fail.
|
|
|
|
// The RunData, ExecuteData and WaitForExecution contain often the same data.
|
|
|
|
export interface IRunExecutionData {
|
|
|
|
startData?: {
|
|
|
|
destinationNode?: string;
|
|
|
|
runNodeFilter?: string[];
|
|
|
|
};
|
|
|
|
resultData: {
|
2021-04-16 09:33:36 -07:00
|
|
|
error?: ExecutionError;
|
2019-06-23 03:35:23 -07:00
|
|
|
runData: IRunData;
|
2022-07-22 03:19:45 -07:00
|
|
|
pinData?: IPinData;
|
2019-06-23 03:35:23 -07:00
|
|
|
lastNodeExecuted?: string;
|
|
|
|
};
|
|
|
|
executionData?: {
|
|
|
|
contextData: IExecuteContextData;
|
|
|
|
nodeExecutionStack: IExecuteData[];
|
|
|
|
waitingExecution: IWaitingForExecution;
|
2022-06-03 08:25:07 -07:00
|
|
|
waitingExecutionSource: IWaitingForExecutionSource | null;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
2021-08-21 05:11:32 -07:00
|
|
|
waitTill?: Date;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IRunData {
|
|
|
|
// node-name: result-data
|
|
|
|
[key: string]: ITaskData[];
|
|
|
|
}
|
|
|
|
|
|
|
|
// The data that gets returned when a node runs
|
|
|
|
export interface ITaskData {
|
|
|
|
startTime: number;
|
|
|
|
executionTime: number;
|
|
|
|
data?: ITaskDataConnections;
|
2021-04-16 09:33:36 -07:00
|
|
|
error?: ExecutionError;
|
2022-06-03 08:25:07 -07:00
|
|
|
source: Array<ISourceData | null>; // Is an array as nodes have multiple inputs
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ISourceData {
|
|
|
|
previousNode: string;
|
|
|
|
previousNodeOutput?: number; // If undefined "0" gets used
|
|
|
|
previousNodeRun?: number; // If undefined "0" gets used
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2022-06-03 08:25:07 -07:00
|
|
|
// The data for all the different kind of connectons (like main) and all the indexes
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface ITaskDataConnections {
|
|
|
|
// Key for each input type and because there can be multiple inputs of the same type it is an array
|
|
|
|
// null is also allowed because if we still need data for a later while executing the workflow set teompoary to null
|
|
|
|
// the nodes get as input TaskDataConnections which is identical to this one except that no null is allowed.
|
|
|
|
[key: string]: Array<INodeExecutionData[] | null>;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Keeps data while workflow gets executed and allows when provided to restart execution
|
|
|
|
export interface IWaitingForExecution {
|
|
|
|
// Node name
|
|
|
|
[key: string]: {
|
|
|
|
// Run index
|
2021-08-29 11:58:11 -07:00
|
|
|
[key: number]: ITaskDataConnections;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-06-03 08:25:07 -07:00
|
|
|
export interface ITaskDataConnectionsSource {
|
|
|
|
// Key for each input type and because there can be multiple inputs of the same type it is an array
|
|
|
|
// null is also allowed because if we still need data for a later while executing the workflow set teompoary to null
|
|
|
|
// the nodes get as input TaskDataConnections which is identical to this one except that no null is allowed.
|
|
|
|
[key: string]: Array<ISourceData | null>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWaitingForExecutionSource {
|
|
|
|
// Node name
|
|
|
|
[key: string]: {
|
|
|
|
// Run index
|
|
|
|
[key: number]: ITaskDataConnectionsSource;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-12-19 14:07:55 -08:00
|
|
|
export interface IWorkflowBase {
|
2021-08-29 11:58:11 -07:00
|
|
|
id?: number | string | any;
|
2019-12-19 14:07:55 -08:00
|
|
|
name: string;
|
|
|
|
active: boolean;
|
|
|
|
createdAt: Date;
|
|
|
|
updatedAt: Date;
|
|
|
|
nodes: INode[];
|
|
|
|
connections: IConnections;
|
|
|
|
settings?: IWorkflowSettings;
|
|
|
|
staticData?: IDataObject;
|
2022-07-22 03:19:45 -07:00
|
|
|
pinData?: IPinData;
|
2019-12-19 14:07:55 -08:00
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IWorkflowCredentials {
|
2021-10-13 15:21:00 -07:00
|
|
|
[credentialType: string]: {
|
|
|
|
[id: string]: ICredentialsEncrypted;
|
2019-06-23 03:35:23 -07:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWorkflowExecuteHooks {
|
2021-08-29 11:58:11 -07:00
|
|
|
[key: string]: Array<(...args: any[]) => Promise<void>> | undefined;
|
|
|
|
nodeExecuteAfter?: Array<
|
|
|
|
(nodeName: string, data: ITaskData, executionData: IRunExecutionData) => Promise<void>
|
|
|
|
>;
|
|
|
|
nodeExecuteBefore?: Array<(nodeName: string) => Promise<void>>;
|
|
|
|
workflowExecuteAfter?: Array<(data: IRun, newStaticData: IDataObject) => Promise<void>>;
|
|
|
|
workflowExecuteBefore?: Array<(workflow: Workflow, data: IRunExecutionData) => Promise<void>>;
|
2021-11-05 09:45:51 -07:00
|
|
|
sendResponse?: Array<(response: IExecuteResponsePromiseData) => Promise<void>>;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface IWorkflowExecuteAdditionalData {
|
2020-01-25 23:48:38 -08:00
|
|
|
credentialsHelper: ICredentialsHelper;
|
2019-06-23 03:35:23 -07:00
|
|
|
encryptionKey: string;
|
2021-08-29 11:58:11 -07:00
|
|
|
executeWorkflow: (
|
|
|
|
workflowInfo: IExecuteWorkflowInfo,
|
|
|
|
additionalData: IWorkflowExecuteAdditionalData,
|
|
|
|
inputData?: INodeExecutionData[],
|
|
|
|
parentExecutionId?: string,
|
|
|
|
loadedWorkflowData?: IWorkflowBase,
|
|
|
|
loadedRunData?: any,
|
|
|
|
) => Promise<any>;
|
2019-12-19 14:07:55 -08:00
|
|
|
// hooks?: IWorkflowExecuteHooks;
|
2021-08-21 05:11:32 -07:00
|
|
|
executionId?: string;
|
2019-12-19 14:07:55 -08:00
|
|
|
hooks?: WorkflowHooks;
|
2019-06-23 03:35:23 -07:00
|
|
|
httpResponse?: express.Response;
|
|
|
|
httpRequest?: express.Request;
|
2019-12-19 14:07:55 -08:00
|
|
|
restApiUrl: string;
|
2021-08-29 11:58:11 -07:00
|
|
|
sendMessageToUI?: (source: string, message: any) => void;
|
2019-06-23 03:35:23 -07:00
|
|
|
timezone: string;
|
|
|
|
webhookBaseUrl: string;
|
2021-08-21 05:11:32 -07:00
|
|
|
webhookWaitingBaseUrl: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
webhookTestBaseUrl: string;
|
2021-02-20 04:51:06 -08:00
|
|
|
currentNodeParameters?: INodeParameters;
|
2021-04-17 07:44:07 -07:00
|
|
|
executionTimeoutTimestamp?: number;
|
feat: Add User Management (#2636)
* ✅ adjust tests
* 🛠 refactor user invites to be indempotent (#2791)
* 🔐 Encrypt SMTP pass for user management backend (#2793)
* :package: Add crypto-js to /cli
* :package: Update package-lock.json
* :sparkles: Create type for SMTP config
* :zap: Encrypt SMTP pass
* :zap: Update format for `userManagement.emails.mode`
* :zap: Update format for `binaryDataManager.mode`
* :zap: Update format for `logs.level`
* :fire: Remove logging
* :shirt: Fix lint
* 👰 n8n 2826 um wedding FE<>BE (#2789)
* remove mocks
* update authorization func
* lock down default role
* 🐛 fix requiring authentication for OPTIONS requests
* :bug: fix cors and cookie issues in dev
* update setup route
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* update telemetry
* 🐛 preload role for users
* :bug: remove auth for password reset routes
* 🐛 fix forgot-password flow
* :zap: allow workflow tag disabling
* update telemetry init
* add reset
* clear error notifications on signin
* remove load settings from node view
* remove user id from user state
* inherit existing user props
* go back in history on button click
* use replace to force redirect
* update stories
* :zap: add env check for tag create
* :test_tube: Add `/users` tests for user management backend (#2790)
* :zap: Refactor users namespace
* :zap: Adjust fillout endpoint
* :zap: Refactor initTestServer arg
* :pencil2: Specify agent type
* :pencil2: Specify role type
* :zap: Tighten `/users/:id` check
* :sparkles: Add initial tests
* :truck: Reposition init server map
* :zap: Set constants in `validatePassword()`
* :zap: Tighten `/users/:id` check
* :zap: Improve checks in `/users/:id`
* :sparkles: Add tests for `/users/:id`
* :package: Update package-lock.json
* :zap: Simplify expectation
* :zap: Reuse util for authless agent
* :truck: Make role names consistent
* :blue_book: Tighten namespaces map type
* :fire: Remove unneeded default arg
* :sparkles: Add tests for `POST /users`
* :blue_book: Create test SMTP account type
* :pencil2: Improve wording
* :art: Formatting
* :fire: Remove temp fix
* :zap: Replace helper with config call
* :zap: Fix failing tests
* :fire: Remove outdated test
* :fire: Remove unused helper
* :zap: Increase readability of domain fetcher
* :zap: Refactor payload validation
* :fire: Remove repetition
* :rewind: Restore logging
* :zap: Initialize logger in tests
* :fire: Remove redundancy from check
* :truck: Move `globalOwnerRole` fetching to global scope
* :fire: Remove unused imports
* :truck: Move random utils to own module
* :truck: Move test types to own module
* :pencil2: Add dividers to utils
* :pencil2: Reorder `initTestServer` param docstring
* :pencil2: Add TODO comment
* :zap: Dry up member creation
* :zap: Tighten search criteria
* :test_tube: Add expectation to `GET /users`
* :zap: Create role fetcher utils
* :zap: Create one more role fetch util
* :fire: Remove unneeded DB query
* :test_tube: Add expectation to `POST /users`
* :test_tube: Add expectation to `DELETE /users/:id`
* :test_tube: Add another expectation to `DELETE /users/:id`
* :test_tube: Add expectations to `DELETE /users/:id`
* :test_tube: Adjust expectations in `POST /users/:id`
* :test_tube: Add expectations to `DELETE /users/:id`
* :shirt: Fix build
* :zap: Update method
* :blue_book: Fix `userToDelete` type
* :zap: Refactor `createAgent()`
* :zap: Make role fetching global
* :zap: Optimize roles fetching
* :zap: Centralize member creation
* :zap: Refactor truncation helper
* :test_tube: Add teardown to `DELETE /users/:id`
* :test_tube: Add DB expectations to users tests
* :fire: Remove pass validation due to hash
* :pencil2: Improve pass validation error message
* :zap: Improve owner pass validation
* :zap: Create logger initialization helper
* :zap: Optimize helpers
* :zap: Restructure `getAllRoles` helper
* :test_tube: Add password reset flow tests for user management backend (#2807)
* :zap: Refactor users namespace
* :zap: Adjust fillout endpoint
* :zap: Refactor initTestServer arg
* :pencil2: Specify agent type
* :pencil2: Specify role type
* :zap: Tighten `/users/:id` check
* :sparkles: Add initial tests
* :truck: Reposition init server map
* :zap: Set constants in `validatePassword()`
* :zap: Tighten `/users/:id` check
* :zap: Improve checks in `/users/:id`
* :sparkles: Add tests for `/users/:id`
* :package: Update package-lock.json
* :zap: Simplify expectation
* :zap: Reuse util for authless agent
* :truck: Make role names consistent
* :blue_book: Tighten namespaces map type
* :fire: Remove unneeded default arg
* :sparkles: Add tests for `POST /users`
* :blue_book: Create test SMTP account type
* :pencil2: Improve wording
* :art: Formatting
* :fire: Remove temp fix
* :zap: Replace helper with config call
* :zap: Fix failing tests
* :fire: Remove outdated test
* :sparkles: Add tests for password reset flow
* :pencil2: Fix test wording
* :zap: Set password reset namespace
* :fire: Remove unused helper
* :zap: Increase readability of domain fetcher
* :zap: Refactor payload validation
* :fire: Remove repetition
* :rewind: Restore logging
* :zap: Initialize logger in tests
* :fire: Remove redundancy from check
* :truck: Move `globalOwnerRole` fetching to global scope
* :fire: Remove unused imports
* :truck: Move random utils to own module
* :truck: Move test types to own module
* :pencil2: Add dividers to utils
* :pencil2: Reorder `initTestServer` param docstring
* :pencil2: Add TODO comment
* :zap: Dry up member creation
* :zap: Tighten search criteria
* :test_tube: Add expectation to `GET /users`
* :zap: Create role fetcher utils
* :zap: Create one more role fetch util
* :fire: Remove unneeded DB query
* :test_tube: Add expectation to `POST /users`
* :test_tube: Add expectation to `DELETE /users/:id`
* :test_tube: Add another expectation to `DELETE /users/:id`
* :test_tube: Add expectations to `DELETE /users/:id`
* :test_tube: Adjust expectations in `POST /users/:id`
* :test_tube: Add expectations to `DELETE /users/:id`
* :blue_book: Add namespace name to type
* :truck: Adjust imports
* :zap: Optimize `globalOwnerRole` fetching
* :test_tube: Add expectations
* :shirt: Fix build
* :shirt: Fix build
* :zap: Update method
* :zap: Update method
* :test_tube: Fix `POST /change-password` test
* :blue_book: Fix `userToDelete` type
* :zap: Refactor `createAgent()`
* :zap: Make role fetching global
* :zap: Optimize roles fetching
* :zap: Centralize member creation
* :zap: Refactor truncation helper
* :test_tube: Add teardown to `DELETE /users/:id`
* :test_tube: Add DB expectations to users tests
* :zap: Refactor as in users namespace
* :test_tube: Add expectation to `POST /change-password`
* :fire: Remove pass validation due to hash
* :pencil2: Improve pass validation error message
* :zap: Improve owner pass validation
* :zap: Create logger initialization helper
* :zap: Optimize helpers
* :zap: Restructure `getAllRoles` helper
* :zap: Update `truncate` calls
* :bug: return 200 for non-existing user
* ✅ fix tests for forgot-password and user creation
* Update packages/editor-ui/src/components/MainSidebar.vue
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
* Update packages/editor-ui/src/components/Telemetry.vue
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
* Update packages/editor-ui/src/plugins/telemetry/index.ts
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
* Update packages/editor-ui/src/plugins/telemetry/index.ts
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
* Update packages/editor-ui/src/plugins/telemetry/index.ts
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
* :truck: Fix imports
* :zap: reset password just if password exists
* Fix validation at `PATCH /workfows/:id` (#2819)
* :bug: Validate entity only if workflow
* :shirt: Fix build
* 🔨 refactor response from user creation
* 🐛 um email invite fix (#2833)
* update users invite
* fix notificaitons stacking on top of each other
* remove unnessary check
* fix type issues
* update structure
* fix types
* 🐘 database migrations UM + password reset expiration (#2710)
* Add table prefix and assign existing workflows and credentials to owner for sqlite
* Added user management migration to MySQL
* Fixed some missing table prefixes and removed unnecessary user id
* Created migration for postgres and applies minor fixes
* Fixed migration for sqlite by removing the unnecessary index and for mysql by removing unnecessary user data
* Added password reset token expiration
* Addressing comments made by Ben
* ⚡️ add missing tablePrefix
* ✅ fix tests + add tests for expiring pw-reset-token
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* :zap: treat skipped personalizationSurvey as not answered
* :bug: removing active workflows when deleting user, :bug: fix reinvite, :bug: fix resolve-signup-token, 🐘 remove workflowname uniqueness
* ✅ Add DB state check tests (#2841)
* :fire: Remove unneeded import
* :fire: Remove unneeded vars
* :pencil2: Improve naming
* :test_tube: Add expectations to `POST /owner`
* :test_tube: Add expectations to `PATCH /me`
* :test_tube: Add expectation to `PATCH /me/password`
* :pencil2: Clarify when owner is owner shell
* :test_tube: Add more expectations
* :rewind: Restore package-lock to parent branch state
* Add logging to user management endpoints v2 (#2836)
* :zap: Initialize logger in tests
* :zap: Add logs to mailer
* :zap: Add logs to middleware
* :zap: Add logs to me endpoints
* :zap: Add logs to owner endpoints
* :zap: Add logs to pass flow endpoints
* :zap: Add logs to users endpoints
* :blue_book: Improve typings
* :zap: Merge two logs into one
* :zap: Adjust log type
* :zap: Add password reset email log
* :pencil2: Reword log message
* :zap: Adjust log meta object
* :zap: Add total to log
* :pencil2: Add detail to log message
* :pencil2: Reword log message
* :pencil2: Reword log message
* :bug: Make total users to set up accurate
* :pencil2: Reword `Logger.debug()` messages
* :pencil2: Phrasing change for consistency
* :bug: Fix ID overridden in range query
* :hammer: small refactoring
* 🔐 add auth to push-connection
* 🛠 ✅ Create credentials namespace and add tests (#2831)
* :test_tube: Fix failing test
* :blue_book: Improve `createAgent` signature
* :truck: Fix `LoggerProxy` import
* :sparkles: Create credentials endpoints namespace
* :test_tube: Set up initial tests
* :zap: Add validation to model
* :zap: Adjust validation
* :test_tube: Add test
* :truck: Sort creds endpoints
* :pencil2: Plan out pending tests
* :test_tube: Add deletion tests
* :test_tube: Add patch tests
* :test_tube: Add get cred tests
* :truck: Hoist import
* :pencil2: Make test descriptions consistent
* :pencil2: Adjust description
* :test_tube: Add missing test
* :pencil2: Make get descriptions consistent
* :rewind: Undo line break
* :zap: Refactor to simplify `saveCredential`
* :test_tube: Add non-owned tests for owner
* :pencil2: Improve naming
* :pencil2: Add clarifying comments
* :truck: Improve imports
* :zap: Initialize config file
* :fire: Remove unneeded import
* :truck: Rename dir
* :zap: Adjust deletion call
* :zap: Adjust error code
* :pencil2: Touch up comment
* :zap: Optimize fetching with `@RelationId`
* :test_tube: Add expectations
* :zap: Simplify mock calls
* :blue_book: Set deep readonly to object constants
* :fire: Remove unused param and encryption key
* :zap: Add more `@RelationId` calls in models
* :rewind: Restore
* :bug: no auth for .svg
* 🛠 move auth cookie name to constant; 🐛 fix auth for push-connection
* ✅ Add auth middleware tests (#2853)
* :zap: Simplify existing suite
* :test_tube: Validate that auth cookie exists
* :pencil2: Move comment
* :fire: Remove unneeded imports
* :pencil2: Add clarifying comments
* :pencil2: Document auth endpoints
* :test_tube: Add middleware tests
* :pencil2: Fix typos
Co-authored-by: Ben Hesseldieck <1849459+BHesseldieck@users.noreply.github.com>
* 🔥 Remove test description wrappers (#2874)
* :fire: Remove /owner test wrappers
* :fire: Remove auth middleware test wrappers
* :fire: Remove auth endpoints test wrappers
* :fire: Remove overlooked middleware wrappers
* :fire: Remove me namespace test wrappers
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* ✨ Runtime checks for credentials load and execute workflows (#2697)
* Runtime checks for credentials load and execute workflows
* Fixed from reviewers
* Changed runtime validation for credentials to be on start instead of on demand
* Refactored validations to use user id instead of whole User instance
* Removed user entity from workflow project because it is no longer needed
* General fixes and improvements to runtime checks
* Remove query builder and improve styling
* Fix lint issues
* :zap: remove personalizationAnswers when fetching all users
* ✅ fix failing get all users test
* ✅ check authorization routes also for authentication
* :bug: fix defaults in reset command
* 🛠 refactorings from walkthrough (#2856)
* :zap: Make `getTemplate` async
* :zap: Remove query builder from `getCredentials`
* :zap: Add save manual executions log message
* :rewind: Restore and hide migrations logs
* :zap: Centralize ignore paths check
* :shirt: Fix build
* :truck: Rename `hasOwner` to `isInstanceOwnerSetUp`
* :zap: Add `isSetUp` flag to `User`
* :zap: Add `isSetUp` to FE interface
* :zap: Adjust `isSetUp` checks on FE
* :shirt: Fix build
* :zap: Adjust `isPendingUser()` check
* :truck: Shorten helper name
* :zap: Refactor as `isPending` per feedback
* :pencil2: Update log message
* :zap: Broaden check
* :fire: Remove unneeded relation
* :zap: Refactor query
* :fire: Re-remove logs from migrations
* 🛠 set up credentials router (#2882)
* :zap: Refactor creds endpoints into router
* :test_tube: Refactor creds tests to use router
* :truck: Rename arg for consistency
* :truck: Move `credentials.api.ts` outside /public
* :truck: Rename constant for consistency
* :blue_book: Simplify types
* :fire: Remove unneeded arg
* :truck: Rename router to controller
* :zap: Shorten endpoint
* :zap: Update `initTestServer()` arg
* :zap: Mutate response body in GET /credentials
* 🏎 improve performance of type cast for FE
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* :bug: remove GET /login from auth
* 🔀 merge master + FE update (#2905)
* :sparkles: Add Templates (#2720)
* Templates Bugs / Fixed Various Bugs / Multiply Api Request, Carousel Gradient, Core Nodes Filters ...
* Updated MainSidebar Paddings
* N8N-Templates Bugfixing - Remove Unnecesairy Icon (Shape), Refatctor infiniteScrollEnabled Prop + updated infiniterScroll functinality
* N8N-2853 Fixed Carousel Arrows Bug after Cleaning the SearchBar
* fix telemetry init
* fix search tracking issues
* N8N-2853 Created FilterTemplateNode Constant Array, Filter PlayButton and WebhookRespond from Nodes, Added Box for showing more nodes inside TemplateList, Updated NewWorkflowButton to primary, Fixed Markdown issue with Code
* N8N-2853 Removed Placeholder if Workflows Or Collections are not found, Updated the Logic
* fix telemetry events
* clean up session id
* update user inserted event
* N8N-2853 Fixed Categories to Moving if the names are long
* Add todos
* Update Routes on loading
* fix spacing
* Update Border Color
* Update Border Readius
* fix filter fn
* fix constant, console error
* N8N-2853 PR Fixes, Refactoring, Removing unnecesairy code ..
* N8N-2853 PR Fixes - Editor-ui Fixes, Refactoring, Removing Dead Code ...
* N8N-2853 Refactor Card to LongCard
* clean up spacing, replace css var
* clean up spacing
* set categories as optional in node
* replace vars
* refactor store
* remove unnesssary import
* fix error
* fix templates view to start
* add to cache
* fix coll view data
* fix categories
* fix category event
* fix collections carousel
* fix initial load and search
* fix infinite load
* fix query param
* fix scrolling issues
* fix scroll to top
* fix search
* fix collections search
* fix navigation bug
* rename view
* update package lock
* rename workflow view
* rename coll view
* update routes
* add wrapper component
* set session id
* fix search tracking
* fix session tracking
* remove deleted mutation
* remove check for unsupported nodes
* refactor filters
* lazy load template
* clean up types
* refactor infinte scroll
* fix end of search
* Fix spacing
* fix coll loading
* fix types
* fix coll view list
* fix navigation
* rename types
* rename state
* fix search responsiveness
* fix coll view spacing
* fix search view spacing
* clean up views
* set background color
* center page not vert
* fix workflow view
* remove import
* fix background color
* fix background
* clean props
* clean up imports
* refactor button
* update background color
* fix spacing issue
* rename event
* update telemetry event
* update endpoints, add loading view, check for endpoint health
* remove conolse log
* N8N-2853 Fixed Menu Items Padding
* replace endpoints
* fix type issues
* fix categories
* N8N-2853 Fixed ParameterInput Placeholder after ElementUI Upgrade
* update createdAt
* :zap: Fix placeholder in creds config modal
* :pencil2: Adjust docstring to `credText` placeholder version
* N8N-2853 Optimized
* N8N-2853 Optimized code
* :zap: Add deployment type to FE settings
* :zap: Add deployment type to interfaces
* N8N-2853 Removed Animated prop from components
* :zap: Add deployment type to store module
* :sparkles: Create hiring banner
* :zap: Display hiring banner
* :rewind: Undo unrelated change
* N8N-2853 Refactor TemplateFilters
* :zap: Fix indentation
* N8N-2853 Reorder items / TemplateList
* :shirt: Fix lint
* N8N-2853 Refactor TemplateFilters Component
* N8N-2853 Reorder TemplateList
* refactor template card
* update timeout
* fix removelistener
* fix spacing
* split enabled from offline
* add spacing to go back
* N8N-2853 Fixed Screens for Tablet & Mobile
* N8N-2853 Update Stores Order
* remove image componet
* remove placeholder changes
* N8N-2853 Fixed Chinnese Placeholders for El Select Component that comes from the Library Upgrade
* N8N-2853 Fixed Vue Agile Console Warnings
* N8N-2853 Update Collection Route
* :pencil2: Update jobs URL
* :truck: Move logging to root component
* :zap: Refactor `deploymentType` to `isInternalUser`
* :zap: Improve syntax
* fix cut bug in readonly view
* N8N-3012 Fixed Details section in templates with lots of description, Fixed Mardown Block with overflox-x
* N8N-3012 Increased Font-size, Spacing and Line-height of the Categories Items
* N8N-3012 Fixed Vue-agile client width error on resize
* only delay redirect for root path
* N8N-3012 Fixed Carousel Arrows that Disappear
* N8N-3012 Make Loading Screen same color as Templates
* N8N-3012 Markdown renders inline block as block code
* add offline warning
* hide log from workflow iframe
* update text
* make search button larger
* N8N-3012 Categories / Tags extended all the way in details section
* load data in cred modals
* remove deleted message
* add external hook
* remove import
* update env variable description
* fix markdown width issue
* disable telemetry for demo, add session id to template pages
* fix telemetery bugs
* N8N-3012 Not found Collections/Wokrkflow
* N8N-3012 Checkboxes change order when categories are changed
* N8N-3012 Refactor SortedCategories inside TemplateFilters component
* fix firefox bug
* add telemetry requirements
* add error check
* N8N-3012 Update GoBackButton to check if Route History is present
* N8N-3012 Fixed WF Nodes Icons
* hide workflow screenshots
* remove unnessary mixins
* rename prop
* fix design a bit
* rename data
* clear workspace on destroy
* fix copy paste bug
* fix disabled state
* N8N-3012 Fixed Saving/Leave without saving Modal
* fix telemetry issue
* fix telemetry issues, error bug
* fix error notification
* disable workflow menu items on templates
* fix i18n elementui issue
* Remove Emit - NodeType from HoverableNodeIcon component
* TechnicalFixes: NavigateTo passed down as function should be helper
* TechnicalFixes: Update NavigateTo function
* TechnicalFixes: Add FilterCoreNodes directly as function
* check for empty connecitions
* fix titles
* respect new lines
* increase categories to be sliced
* rename prop
* onUseWorkflow
* refactor click event
* fix bug, refactor
* fix loading story
* add default
* fix styles at right level of abstraction
* add wrapper with width
* remove loading blocks component
* add story
* rename prop
* fix spacing
* refactor tag, add story
* move margin to container
* fix tag redirect, remove unnessary check
* make version optional
* rename view
* move from workflows to templates store
* remove unnessary change
* remove unnessary css
* rename component
* refactor collection card
* add boolean to prevent shrink
* clean up carousel
* fix redirection bug on save
* remove listeners to fix multiple listeners bug
* remove unnessary types
* clean up boolean set
* fix node select bug
* rename component
* remove unnessary class
* fix redirection bug
* remove unnessary error
* fix typo
* fix blockquotes, pre
* refactor markdown rendering
* remove console log
* escape markdown
* fix safari bug
* load active workflows to fix modal bug
* :arrow_up: Update package-lock.json file
* :zap: Add n8n version as header
Co-authored-by: Mutasem Aldmour <4711238+mutdmour@users.noreply.github.com>
Co-authored-by: Mutasem <mutdmour@gmail.com>
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
* :bookmark: Release n8n-workflow@0.88.0
* :arrow_up: Set n8n-workflow@0.88.0 on n8n-core
* :bookmark: Release n8n-core@0.106.0
* :arrow_up: Set n8n-core@0.106.0 and n8n-workflow@0.88.0 on n8n-node-dev
* :bookmark: Release n8n-node-dev@0.45.0
* :arrow_up: Set n8n-core@0.106.0 and n8n-workflow@0.88.0 on n8n-nodes-base
* :bookmark: Release n8n-nodes-base@0.163.0
* :bookmark: Release n8n-design-system@0.12.0
* :arrow_up: Set n8n-design-system@0.12.0 and n8n-workflow@0.88.0 on n8n-editor-ui
* :bookmark: Release n8n-editor-ui@0.132.0
* :arrow_up: Set n8n-core@0.106.0, n8n-editor-ui@0.132.0, n8n-nodes-base@0.163.0 and n8n-workflow@0.88.0 on n8n
* :bookmark: Release n8n@0.165.0
* fix default user bug
* fix bug
* update package lock
* fix duplicate import
* fix settings
* fix templates access
Co-authored-by: Oliver Trajceski <olivertrajceski@yahoo.com>
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
* :zap: n8n 2952 personalisation (#2911)
* refactor/update survey
* update customers
* Fix up personalization survey
* fix recommendation logic
* set to false
* hide suggested nodes when empty
* use keys
* add missing logic
* switch types
* Fix logic
* remove unused constants
* add back constant
* refactor filtering inputs
* hide last input on personal
* fix other
* ✨ add current pw check for change password (#2912)
* fix back button
* Add current password input
* add to modal
* update package.json
* delete mock file
* delete mock file
* get settings func
* update router
* update package lock
* update package lock
* Fix invite text
* update error i18n
* open personalization on search if not set
* update error view i18n
* update change password
* update settings sidebar
* remove import
* fix sidebar
* :goal_net: fix error for credential/workflow not found
* update invite modal
* ✨ persist skipping owner setup (#2894)
* 🚧 added skipInstanceOwnerSetup to DB + route to save skipping
* ✨ skipping owner setup persists
* ✅ add tests for authorization and /owner/skip-setup
* 🛠 refactor FE settings getter
* 🛠 move setting setup stop to owner creation
* :bug: fix wrong setting of User.isPending
* :bug: fix isPending
* 🏷 add isPending to PublicUser
* :bug: fix unused import
* update delete modal
* change password modal
* remove _label
* sort keys
* remove key
* update key names
* fix test endpoint
* 🥅 Handle error workflows permissions (#2908)
* Handle error workflows permissions
* Fixed wrong query format
* 🛠 refactor query
Co-authored-by: Ben Hesseldieck <1849459+BHesseldieck@users.noreply.github.com>
* fix ts issue
* fix list after ispending changes
* fix error page bugs
* fix error redirect
* fix notification
* :bug: fix survey import in migration
* fix up spacing
* update keys spacing
* update keys
* add space
* update key
* fix up more spacing
* 🔐 add current password (#2919)
* add curr pass
* update key names
* :bug: stringify tag ids
* 🔐 check current password before update
* add package lock
* fix dep version
* update version
* 🐛 fix access for instance owner to credentials (#2927)
* 🛠 stringify tag id on entity
* 🔐 Update password requirements (#2920)
* :zap: Update password requirements
* :zap: Adjust random helpers
* ✅ fix tests for currentPassword check
* change redirection, add homepage
* fix error view redirection
* updated wording
* fix setup redirection
* update validator
* remove successfully
* update consumers
* update settings redirect
* on signup, redirect to homepage
* update empty state
* add space to emails
* remove brackets
* add opacity
* update spacing
* remove border from last user
* personal details updated
* update redirect on sign up
* prevent text wrap
* fix notification title line height
* remove console log
* 🐘 Support testing with Postgres and MySQL (#2886)
* :card_file_box: Fix Postgres migrations
* :zap: Add DB-specific scripts
* :sparkles: Set up test connections
* :zap: Add Postgres UUID check
* :test_tube: Make test adjustments for Postgres
* :zap: Refactor connection logic
* :sparkles: Set up double init for Postgres
* :pencil2: Add TODOs
* :zap: Refactor DB dropping logic
* :sparkles: Implement global teardown
* :sparkles: Create TypeORM wrappers
* :sparkles: Initial MySQL setup
* :zap: Clean up Postgres connection options
* :zap: Simplify by sharing bootstrap connection name
* :card_file_box: Fix MySQL migrations
* :fire: Remove comments
* :zap: Use ES6 imports
* :fire: Remove outdated comments
* :zap: Centralize bootstrap connection name handles
* :zap: Centralize database types
* :pencil2: Update comment
* :truck: Rename `findRepository`
* :construction: Attempt to truncate MySQL
* :sparkles: Implement creds router
* :bug: Fix duplicated MySQL bootstrap
* :bug: Fix misresolved merge conflict
* :card_file_box: Fix tags migration
* :card_file_box: Fix MySQL UM migration
* :bug: Fix MySQL parallelization issues
* :blue_book: Augment TypeORM to prevent error
* :fire: Remove comments
* :sparkles: Support one sqlite DB per suite run
* :truck: Move `testDb` to own module
* :fire: Deduplicate bootstrap Postgres logic
* :fire: Remove unneeded comment
* :zap: Make logger init calls consistent
* :pencil2: Improve comment
* :pencil2: Add dividers
* :art: Improve formatting
* :fire: Remove duplicate MySQL global setting
* :truck: Move comment
* :zap: Update default test script
* :fire: Remove unneeded helper
* :zap: Unmarshal answers from Postgres
* :bug: Phase out `isTestRun`
* :zap: Refactor `isEmailSetup`
* :fire: Remove unneeded imports
* :zap: Handle bootstrap connection errors
* :fire: Remove unneeded imports
* :fire: Remove outdated comments
* :pencil2: Fix typos
* :truck: Relocate `answersFormatter`
* :rewind: Undo package.json miscommit
* :fire: Remove unneeded import
* :zap: Refactor test DB prefixing
* :zap: Add no-leftover check to MySQL
* :package: Update package.json
* :zap: Autoincrement on simulated MySQL truncation
* :fire: Remove debugging queries
* ✏️ fix email template link expiry
* 🔥 remove unused import
* ✅ fix testing email not sent error
* fix duplicate import
* add package lock
* fix export
* change opacity
* fix text issue
* update action box
* update error title
* update forgot password
* update survey
* update product text
* remove unset fields
* add category to page events
* remove duplicate import
* update key
* update key
* update label type
* 🎨 um/fe review (#2946)
* :whale: Update Node.js versions of Docker images to 16
* :bug: Fix that some keyboard shortcuts did no longer work
* N8N-3057 Fixed Keyboard shortcuts no longer working on / Fixed callDebounced function
* N8N-3057 Update Debounce Function
* N8N-3057 Refactor callDebounce function
* N8N-3057 Update Dobounce Function
* :bug: Fix issue with tooltips getting displayed behind node details view
* fix tooltips z-index
* move all element ui components
* update package lock
* :bug: Fix credentials list load issue (#2931)
* always fetch credentials
* only fetch credentials once
* :zap: Allow to disable hiring banner (#2902)
* :sparkles: Add flag
* :zap: Adjust interfaces
* :zap: Adjust store module
* :zap: Adjust frontend settings
* :zap: Adjust frontend display
* :bug: Fix issue that ctrl + o did behave wrong on workflow templates page (#2934)
* N8N-3094 Workflow Templates cmd-o acts on the Preview/Iframe
* N8N-3094 Workflow Templates cmd-o acts on the Preview/Iframe
* disable shortcuts for preview
Co-authored-by: Mutasem <mutdmour@gmail.com>
* :arrow_up: Update package-lock.json file
* :bug: Fix sorting by field in Baserow Node (#2942)
This fixes a bug which currently leads to the "Sorting" option of the node to be ignored.
* :bug: Fix some i18n line break issues
* :sparkles: Add Odoo Node (#2601)
* added odoo scaffolding
* update getting data from odoo instance
* added scaffolding for main loop and request functions
* added functions for CRUD opperations
* improoved error handling for odooJSONRPCRequest
* updated odoo node and fixing nodelinter issues
* fixed alpabetical order
* fixed types in odoo node
* fixing linter errors
* fixing linter errors
* fixed data shape returned from man loop
* updated node input types, added fields list to models
* update when custom resource is selected options for fields list will be populated dynamicly
* minor fixes
* :hammer: fixed credential test, updating CRUD methods
* :hammer: added additional fields to crm resource
* :hammer: added descriptions, fixed credentials test bug
* :hammer: standardize node and descriptions design
* :hammer: removed comments
* :hammer: added pagination to getAll operation
* :zap: removed leftover function from previous implementation, removed required from optional fields
* :zap: fixed id field, added indication of type and if required to field description, replaced string input in filters to fetched list of fields
* :hammer: fetching list of models from odoo, added selection of fields to be returned to predefined models, fixes accordingly to review
* :zap: Small improvements
* :hammer: extracted adress fields into collection, changed fields to include in descriptions, minor tweaks
* :zap: Improvements
* :hammer: working on review
* :hammer: fixed linter errors
* :hammer: review wip
* :hammer: review wip
* :hammer: review wip
* :zap: updated display name for URL in credentials
* :hammer: added checks for valid id to delete and update
* :zap: Minor improvements
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
* :bug: Handle Wise SCA requests (#2734)
* :zap: Improve Wise error message after previous change
* fix duplicate import
* add package lock
* fix export
* change opacity
* fix text issue
* update action box
* update error title
* update forgot password
* update survey
* update product text
* remove unset fields
* add category to page events
* remove duplicate import
* update key
* update key
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
Co-authored-by: Oliver Trajceski <olivertrajceski@yahoo.com>
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Tom <19203795+that-one-tom@users.noreply.github.com>
Co-authored-by: Michael Kret <88898367+michael-radency@users.noreply.github.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
Co-authored-by: pemontto <939704+pemontto@users.noreply.github.com>
* Move owner skip from settings
* 🐛 SMTP fixes (#2937)
* :fire: Remove `UM_` from SMTP env vars
* :fire: Remove SMTP host default value
* :zap: Update sender value
* :zap: Update invite template
* :zap: Update password reset template
* :zap: Update `N8N_EMAIL_MODE` default value
* :fire: Remove `EMAIL` from all SMTP vars
* :sparkles: Implement `verifyConnection()`
* :truck: Reposition comment
* :pencil2: Fix typo
* :pencil2: Minor env var documentation improvements
* :art: Fix spacing
* :art: Fix spacing
* :card_file_box: Remove SMTP settings cache
* :zap: Adjust log message
* :zap: Update error message
* :pencil2: Fix template typo
* :pencil2: Adjust wording
* :zap: Interpolate email into success toast
* :pencil2: Adjust base message in `verifyConnection()`
* :zap: Verify connection on password reset
* :zap: Bring up POST /users SMTP check
* :bug: remove cookie if cookie is not valid
* :zap: verify connection on instantiation
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* 🔊 create logger helper for migrations (#2944)
* 🔥 remove unused database
* :loud_sound: add migration logging for sqlite
* 🔥 remove unnecessary index creation
* ⚡️ change log level to warn
* 🐛 Fix issue with workflow process to initialize db connection correctly (#2948)
* ✏️ update error messages for webhhook run/activation
* 📈 Implement telemetry events (#2868)
* Implement basic telemetry events
* Fixing user id as part of the telemetry data
* Added user id to be part of the tracked data
* :sparkles: Create telemetry mock
* :test_tube: Fix tests with telemetry mock
* :test_tube: Fix missing key in authless endpoint
* :blue_book: Create authless request type
* :fire: Remove log
* :bug: Fix `migration_strategy` assignment
* :blue_book: Remove `instance_id` from `ITelemetryUserDeletionData`
* :zap: Simplify concatenation
* :zap: Simplify `track()` call signature
* Fixed payload of telemetry to always include user_id
* Fixing minor issues
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
* 🔊 Added logs to credentials, executions and workflows (#2915)
* Added logs to credentials, executions and workflows
* Some updates according to ivov's feedback
* :zap: update log levels
* ✅ fix tests
Co-authored-by: Ben Hesseldieck <b.hesseldieck@gmail.com>
* :bug: fix telemetry error
* fix conflicts with master
* fix duplicate
* add package-lock
* :bug: Um/fixes (#2952)
* add initials to avatar
* redirect to signin if invalid token
* update pluralization
* add auth page category
* data transferred
* touch up setup page
* update button to add cursor
* fix personalization modal not closing
* ✏️ fix environment name
* 🐛 fix disabling UM
* 🐛 fix email setup flag
* 🐛 FE fixes 1 (#2953)
* add initials to avatar
* redirect to signin if invalid token
* update pluralization
* add auth page category
* data transferred
* touch up setup page
* update button to add cursor
* fix personalization modal not closing
* capitalize labels, refactor text
* Fixed the issue with telemetry data missing for personalization survey
* Changed invite email text
* 🐛 Fix quotes issue with postgres migration (#2958)
* Changed text for invite link
* 🐛 fix reset command for mysql
* ✅ fix race condition in test DB creation
* 🔐 block user creation if UM is disabled
* 🥅 improve smtp setup issue error
* :zap: update error message
* refactor route rules
* set package lock
* fix access
* remove capitalize
* update input labels
* refactor heading
* change span to fragment
* add route types
* refactor views
* ✅ fix increase timeout for mysql
* :zap: correct logic of error message
* refactor view names
* :zap: update randomString
* 📈 Added missing event regarding failed emails (#2964)
* replace label with info
* 🛠 refactor JWT-secret creation
* remove duplicate key
* remove unused part
* remove semicolon
* fix up i18n pattern
* update translation keys
* update urls
* support i18n in nds
* fix how external keys are handled
* add source
* 💥 update timestamp of UM migration
* ✏️ small message updates
* fix tracking
* update notification line-height
* fix avatar opacity
* fix up empty state
* shift focus to input
* 🔐 Disable basic auth after owner has been set up (#2973)
* Disable basic auth after owner has been set up
* Remove unnecessary comparison
* rename modal title
* 🐛 use pgcrypto extension for uuid creation (#2977)
* 📧 Added public url variable for emails (#2967)
* Added public url variable for emails
* Fixed base url for reset password - the current implementation overrides possibly existing path
* Change variable name to editorUrl
* Using correct name editorUrl for emails
* Changed variable description
* Improved base url naming and appending path so it remains consistent
* Removed trailing slash from editor base url
* 🌐 fix i18n pattern (#2970)
* fix up i18n pattern
* update translation keys
* update urls
* support i18n in nds
* fix how external keys are handled
* add source
* Um/fixes 1000 (#2980)
* fix select issue
* 😫 hacky solution to circumvent pgcrypto (#2979)
* fix owner bug after transfer. always fetch latest credentials
* add confirmation modal to setup
* Use webhook url as fallback when editor url is not defined
* fix enter bug
* update modal
* update modal
* update modal text, fix bug in settings view
* Updating editor url to not append path
* rename keys
Co-authored-by: Iván Ovejero <ivov.src@gmail.com>
Co-authored-by: Mutasem Aldmour <4711238+mutdmour@users.noreply.github.com>
Co-authored-by: Mutasem <mutdmour@gmail.com>
Co-authored-by: Ahsan Virani <ahsan.virani@gmail.com>
Co-authored-by: Omar Ajoue <krynble@gmail.com>
Co-authored-by: Oliver Trajceski <olivertrajceski@yahoo.com>
Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
Co-authored-by: Tom <19203795+that-one-tom@users.noreply.github.com>
Co-authored-by: Michael Kret <88898367+michael-radency@users.noreply.github.com>
Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
Co-authored-by: pemontto <939704+pemontto@users.noreply.github.com>
2022-03-14 06:46:32 -07:00
|
|
|
userId: string;
|
2019-06-23 03:35:23 -07:00
|
|
|
}
|
|
|
|
|
2021-08-29 11:58:11 -07:00
|
|
|
export type WorkflowExecuteMode =
|
|
|
|
| 'cli'
|
|
|
|
| 'error'
|
|
|
|
| 'integrated'
|
|
|
|
| 'internal'
|
|
|
|
| 'manual'
|
|
|
|
| 'retry'
|
|
|
|
| 'trigger'
|
|
|
|
| 'webhook';
|
2021-03-23 11:08:47 -07:00
|
|
|
export type WorkflowActivateMode = 'init' | 'create' | 'update' | 'activate' | 'manual';
|
2019-12-19 14:07:55 -08:00
|
|
|
|
|
|
|
export interface IWorkflowHooksOptionalParameters {
|
|
|
|
parentProcessMode?: string;
|
|
|
|
retryOf?: string;
|
|
|
|
sessionId?: string;
|
|
|
|
}
|
|
|
|
|
2019-06-23 03:35:23 -07:00
|
|
|
export interface IWorkflowSettings {
|
|
|
|
[key: string]: IDataObject | string | number | boolean | undefined;
|
|
|
|
}
|
2021-04-16 09:33:36 -07:00
|
|
|
|
2021-05-01 20:43:01 -07:00
|
|
|
export type LogTypes = 'debug' | 'verbose' | 'info' | 'warn' | 'error';
|
|
|
|
|
|
|
|
export interface ILogger {
|
|
|
|
log: (type: LogTypes, message: string, meta?: object) => void;
|
|
|
|
debug: (message: string, meta?: object) => void;
|
|
|
|
verbose: (message: string, meta?: object) => void;
|
|
|
|
info: (message: string, meta?: object) => void;
|
|
|
|
warn: (message: string, meta?: object) => void;
|
|
|
|
error: (message: string, meta?: object) => void;
|
|
|
|
}
|
2021-04-16 09:33:36 -07:00
|
|
|
|
|
|
|
export interface IStatusCodeMessages {
|
|
|
|
[key: string]: string;
|
|
|
|
}
|
2021-06-12 08:15:23 -07:00
|
|
|
|
2021-06-17 22:58:26 -07:00
|
|
|
export type CodexData = {
|
|
|
|
categories?: string[];
|
2021-08-29 11:58:11 -07:00
|
|
|
subcategories?: { [category: string]: string[] };
|
2021-06-17 22:58:26 -07:00
|
|
|
alias?: string[];
|
|
|
|
};
|
|
|
|
|
2021-06-12 08:15:23 -07:00
|
|
|
export type JsonValue = string | number | boolean | null | JsonObject | JsonValue[];
|
|
|
|
|
|
|
|
export type JsonObject = { [key: string]: JsonValue };
|
2021-09-21 10:38:24 -07:00
|
|
|
|
|
|
|
export type AllEntities<M> = M extends { [key: string]: string } ? Entity<M, keyof M> : never;
|
|
|
|
|
|
|
|
export type Entity<M, K> = K extends keyof M ? { resource: K; operation: M[K] } : never;
|
|
|
|
|
|
|
|
export type PropertiesOf<M extends { resource: string; operation: string }> = Array<
|
|
|
|
Omit<INodeProperties, 'displayOptions'> & {
|
|
|
|
displayOptions?: {
|
|
|
|
[key in 'show' | 'hide']?: {
|
|
|
|
resource?: Array<M['resource']>;
|
|
|
|
operation?: Array<M['operation']>;
|
|
|
|
[otherKey: string]: NodeParameterValue[] | undefined;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
>;
|
2021-10-18 20:57:49 -07:00
|
|
|
|
|
|
|
// Telemetry
|
|
|
|
|
2022-07-09 23:53:04 -07:00
|
|
|
export interface ITelemetryTrackProperties {
|
|
|
|
user_id?: string;
|
|
|
|
[key: string]: GenericValue;
|
|
|
|
}
|
|
|
|
|
2021-10-18 20:57:49 -07:00
|
|
|
export interface INodesGraph {
|
|
|
|
node_types: string[];
|
|
|
|
node_connections: IDataObject[];
|
|
|
|
nodes: INodesGraphNode;
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
notes: INotesGraphNode;
|
2022-07-20 08:50:39 -07:00
|
|
|
is_pinned: boolean;
|
2021-10-18 20:57:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodesGraphNode {
|
|
|
|
[key: string]: INodeGraphItem;
|
|
|
|
}
|
|
|
|
|
feat(editor): Add Workflow Stickies (Notes) (#3154)
* N8N-3029 Add Node Type for Wokrflow Stickies/Notes
* N8N-3029 Update Content, Update Aliasses
* N8N-3030 Created N8N Sticky Component in Design System
* N8N-3030 Fixed Code spaccing Sticky Component
* N8N-3030 Fixed Code spaccing StickyStories Component
* N8N-3030 Fixed Code spaccing Markdown Component
* N8N-3030 Added Sticky Colors Pallete into Storybook, Update Color Variables for Sticky Component
* N8N-3030 Added Unfocus Event
* N8N-3030 Update Default Placeholder, Markdown Styles, Fixed Edit State, Added Text to EditState, Fixed Height of Area, Turned off Resize of textarea
* N8N-3030 Update Sticky Overflow, Update Hover States, Updated Markdown Overflow
* N8N-3030, N8N-3031 - Add Resize to Sticky, Created N8n-Resize component
* N8N-3031 Fixed Importing Components in Editor-ui
* N8N-3031 Fixed Resize Component, Fixed Gradient
* N8N-3030, N8N-3031 Update Note Description
* N8N-3032 Hotfix Building Storybook
* N8N-3032 - Select Behaviour, Changes in Resize Component, Emit on Width/Height/Top/Left Change
* N8N-3032 Update Resize Component to emmit left/top, Update Dynamic Resize on Selected Background
* N8N-3032 Updated / Dragging vs Resizing, prevent open Modal for stickies
* N8N-3032 Added ID props to n8n-sticky // dynamic id for multi resizing in NodeView
* N8N-3033 Add dynamic size Tooltip on Sticky
* N8N-3033 Updated Z-index for Sticky Component
* N8N-3033 Updated N8N-Resize Component, Fixed SelectedBackround for Sticky Component
* N8N-3033 Refactor
* N8N-3033 Focus/Defocus on TextArea
* N8N-3033 Fixed Resizing on NW Point
* N8N-3030 Save content in vuex on input change
* N8N-3033 Fixed Resizer, Save Width and Height in Vue
* N8N-3033 Hide Sticky Footer on small height/width
* N8N-3033 Fixed Resizer
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Dynamic Z-index for Stickies
* N8N-3033 Removed static z-index for select sticky class
* N8N-3034 Added Telemetry
* N8N-3030 Formatter
* N8N-3030 Format code
* N8N-3030 Fixed Selecting Stickies
* N8N-3033 Fixed Notifications
* N8N-3030 Added new paddings for Default Stickies
* N8N-3033 Prevent Scrolling NodeView when Sticky is in Edit mode and Mouse is Over the TextArea
* N8N-3030 Prevent double clicking to switch state of Sticky component in Edit Mode
* N8N-3033 Fixed Z-index of Stickies
* N8N-3033 Prevent delete node when in EditMode
* N8N-3030 Prevent Delete Button to delete the Sticky while in Edit Mode
* N8N-3030 Change EditMode (emit) on keyboard shortucts, update Markdown Links & Images, Added new props
* N8N-3030 Sticky Component - No padding when hiding footer text
* N8N-3033 Fix Resizing enter into Edit Mode
* N8N-3033 Selecting different nodes - exit the edit mode
* N8N-3033 Auto Select Text in text-area by default - Sticky Component
* N8N-3033 Prevent Default behaviour for CTRL + X, CTRL + A when Sticky is Active && inEditMode
* N8N-3033 Refactor Resizer, Refactor Sticky, Update zIndex inEditMode
* N8N-3033 Updated Default Text // Node-base, Storybook
* N8N-3033 Add Resizing in EditMode - Components update
* N8N-3033 Fixed Footer - Show/Hide on Resize in EditMode
* N8N-3033 Fix ActiveSticky on Init
* N8N-3033 Refactor Sticky in Vuex, Fixed Init Sticky Tweaks, Prevent Modal Openning, Save on Keyboard shortcuts
* Stickies - Update Note node with new props
* N8N-3030 Updated Default Note text, Update the Markdown Link
* N8N-3030 CMD-C does not copy the text fix
* N8N-3030 Fix Max Zoom / Zoom out shortcuts disabled in editState
* N8N-3030 Z-index fixed during Edit Mode typing
* N8N-3030 Prevent Autoselect Text in Stickies if the text is not default
* N8N-3030 Fixed ReadOnly Bugs / Prevent showing Tooltip, Resizing
* N8N-3030 Added Sticky Creator Button
* N8N-3030 Update Icon / Sticky Creator Button
* N8N-3033 Update Sticky Icon / StickyCreator Button
* update package lock
* 🔩 update note props
* 🚿 clean props
* 🔧 linting
* :wrench: fix spacing
* remove resize component
* remove resize component
* ✂ clean up sticky
* revert back to height width
* revert back to height/width
* replace zindex property
* replace default text property
* use i18n to translate
* update package lock
* move resize
* clean up how height/width are set
* fix resize for sticky to support left/top
* clean up resize
* fix lasso/highlight bug
* remove unused props
* fix zoom to fit
* fix padding for demo view
* fix readonly
* remove iseditable, use active state
* clean up keyboard events
* chang button size, no edit on insert
* scale resizing correctly
* make active on resize
* fix select on resize/move
* use outline icon
* allow for multiple line breaks
* fix multi line bug
* fix edit mode outline
* keep edit open as one resizes
* respect multiple spaces
* fix scrolling bug
* clean up hover impl
* clean up references to note
* disable for rename
* fix drifting while drag
* fix mouse cursor on resize
* fix sticky min height
* refactor resize into component
* fix pulling too far bug
* fix delete/cut all bug
* fix padding bottom
* fix active change on resize
* add transition to button
* Fix sticky markdown click
* add solid fa icon
* update node graph, telemetry event
* add snapping
* change alt text
* update package lock
* fix bug in button hover
* add back transition
* clean up resize
* add grid size as param
* remove breaks
* clean up markdown
* lint fixes
* fix spacing
* clean up markdown colors
* clean up classes in resize
* clean up resize
* update sticky story
* fix spacing
* clean up classes
* revert change
* revert change
* revert change
* clean up sticky component
* remove unused component
* remove unnessary data
* remove unnessary data
* clean up actions
* clean up sticky size
* clean up unnessary border style
* fix bug
* replace sticky note name
* update description
* remove support for multi spaces
* update tracking name
* update telemetry reqs
* fix enter bug
* update alt text
* update sticky notes doc url
* fix readonly bug
* update class name
* update quote marks
Co-authored-by: SchnapsterDog <olivertrajceski@yahoo.com>
2022-04-25 03:38:37 -07:00
|
|
|
export interface INotesGraphNode {
|
|
|
|
[key: string]: INoteGraphItem;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INoteGraphItem {
|
|
|
|
overlapping: boolean;
|
|
|
|
position: [number, number];
|
|
|
|
height: number;
|
|
|
|
width: number;
|
|
|
|
}
|
|
|
|
|
2021-10-18 20:57:49 -07:00
|
|
|
export interface INodeGraphItem {
|
2022-08-03 04:06:53 -07:00
|
|
|
id: string;
|
2021-10-18 20:57:49 -07:00
|
|
|
type: string;
|
|
|
|
resource?: string;
|
|
|
|
operation?: string;
|
2022-05-24 02:36:19 -07:00
|
|
|
domain?: string; // HTTP Request node v1
|
|
|
|
domain_base?: string; // HTTP Request node v2
|
|
|
|
domain_path?: string; // HTTP Request node v2
|
2022-01-07 08:14:59 -08:00
|
|
|
position: [number, number];
|
|
|
|
mode?: string;
|
2022-05-24 02:36:19 -07:00
|
|
|
credential_type?: string; // HTTP Request node v2
|
|
|
|
credential_set?: boolean; // HTTP Request node v2
|
|
|
|
method?: string; // HTTP Request node v2
|
2022-08-03 04:06:53 -07:00
|
|
|
src_node_id?: string;
|
|
|
|
src_instance_id?: string;
|
2021-10-18 20:57:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodeNameIndex {
|
|
|
|
[name: string]: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface INodesGraphResult {
|
|
|
|
nodeGraph: INodesGraph;
|
|
|
|
nameIndices: INodeNameIndex;
|
2022-07-09 23:53:04 -07:00
|
|
|
webhookNodeNames: string[];
|
2021-10-18 20:57:49 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export interface ITelemetryClientConfig {
|
|
|
|
url: string;
|
|
|
|
key: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface ITelemetrySettings {
|
|
|
|
enabled: boolean;
|
|
|
|
config?: ITelemetryClientConfig;
|
|
|
|
}
|
2022-05-23 08:56:15 -07:00
|
|
|
|
|
|
|
export interface IConnectedNode {
|
|
|
|
name: string;
|
|
|
|
indicies: number[];
|
|
|
|
depth: number;
|
|
|
|
}
|
2022-06-13 22:27:19 -07:00
|
|
|
|
|
|
|
export enum OAuth2GrantType {
|
|
|
|
authorizationCode = 'authorizationCode',
|
|
|
|
clientCredentials = 'clientCredentials',
|
|
|
|
}
|
|
|
|
export interface IOAuth2Credentials {
|
|
|
|
grantType: 'authorizationCode' | 'clientCredentials';
|
|
|
|
clientId: string;
|
|
|
|
clientSecret: string;
|
|
|
|
accessTokenUrl: string;
|
|
|
|
authUrl: string;
|
|
|
|
authQueryParameters: string;
|
|
|
|
authentication: 'body' | 'header';
|
|
|
|
scope: string;
|
|
|
|
oauthTokenData?: IDataObject;
|
|
|
|
}
|
2022-07-20 07:24:03 -07:00
|
|
|
|
|
|
|
export type PublicInstalledPackage = {
|
|
|
|
packageName: string;
|
|
|
|
installedVersion: string;
|
|
|
|
authorName?: string;
|
|
|
|
authorEmail?: string;
|
|
|
|
installedNodes: PublicInstalledNode[];
|
|
|
|
createdAt: Date;
|
|
|
|
updatedAt: Date;
|
|
|
|
updateAvailable?: string;
|
|
|
|
failedLoading?: boolean;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type PublicInstalledNode = {
|
|
|
|
name: string;
|
|
|
|
type: string;
|
|
|
|
latestVersion: string;
|
|
|
|
package: PublicInstalledPackage;
|
|
|
|
};
|