From cefec7739b6da820d64f9476476e1901d4f386bf Mon Sep 17 00:00:00 2001 From: Jan Oberhauser Date: Wed, 22 Mar 2023 12:05:07 +0100 Subject: [PATCH 1/4] fix(Split In Batches Node): Roll back changes in v1 and create v2 (#5747) --- .../SplitInBatches/SplitInBatches.node.ts | 173 ++--------------- .../test/SplitInBatches.combineData.json | 2 +- ...w.json => SplitInBatches.workflow_v1.json} | 0 .../test/SplitInBatches.workflow_v2.json | 178 ++++++++++++++++++ .../v1/SplitInBatchesV1.node.ts | 143 ++++++++++++++ .../v2/SplitInBatchesV2.node.ts | 161 ++++++++++++++++ 6 files changed, 502 insertions(+), 155 deletions(-) rename packages/nodes-base/nodes/SplitInBatches/test/{SplitInBatches.workflow.json => SplitInBatches.workflow_v1.json} (100%) create mode 100644 packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v2.json create mode 100644 packages/nodes-base/nodes/SplitInBatches/v1/SplitInBatchesV1.node.ts create mode 100644 packages/nodes-base/nodes/SplitInBatches/v2/SplitInBatchesV2.node.ts diff --git a/packages/nodes-base/nodes/SplitInBatches/SplitInBatches.node.ts b/packages/nodes-base/nodes/SplitInBatches/SplitInBatches.node.ts index c6ec5342e3..15add2e037 100644 --- a/packages/nodes-base/nodes/SplitInBatches/SplitInBatches.node.ts +++ b/packages/nodes-base/nodes/SplitInBatches/SplitInBatches.node.ts @@ -1,160 +1,25 @@ -import type { - IExecuteFunctions, - INodeExecutionData, - INodeType, - INodeTypeDescription, - IPairedItemData, -} from 'n8n-workflow'; -import { deepCopy } from 'n8n-workflow'; +import type { INodeTypeBaseDescription, IVersionedNodeType } from 'n8n-workflow'; +import { VersionedNodeType } from 'n8n-workflow'; -export class SplitInBatches implements INodeType { - description: INodeTypeDescription = { - displayName: 'Split In Batches', - name: 'splitInBatches', - icon: 'fa:th-large', - group: ['organization'], - version: 1, - description: 'Split data into batches and iterate over each batch', - defaults: { - name: 'Split In Batches', - color: '#007755', - }, - inputs: ['main'], - // eslint-disable-next-line n8n-nodes-base/node-class-description-outputs-wrong - outputs: ['main', 'main'], - outputNames: ['loop', 'done'], - properties: [ - { - displayName: - 'You may not need this node — n8n nodes automatically run once for each input item. More info', - name: 'splitInBatchesNotice', - type: 'notice', - default: '', - }, - { - displayName: 'Batch Size', - name: 'batchSize', - type: 'number', - typeOptions: { - minValue: 1, - }, - default: 10, - description: 'The number of items to return with each call', - }, - { - displayName: 'Options', - name: 'options', - type: 'collection', - placeholder: 'Add Option', - default: {}, - options: [ - { - displayName: 'Reset', - name: 'reset', - type: 'boolean', - default: false, - description: - 'Whether the node will be reset and so with the current input-data newly initialized', - }, - ], - }, - ], - }; +import { SplitInBatchesV1 } from './v1/SplitInBatchesV1.node'; +import { SplitInBatchesV2 } from './v2/SplitInBatchesV2.node'; - async execute(this: IExecuteFunctions): Promise { - // Get the input data and create a new array so that we can remove - // items without a problem - const items = this.getInputData().slice(); +export class SplitInBatches extends VersionedNodeType { + constructor() { + const baseDescription: INodeTypeBaseDescription = { + displayName: 'Split In Batches', + name: 'splitInBatches', + icon: 'fa:th-large', + group: ['organization'], + description: 'Split data into batches and iterate over each batch', + defaultVersion: 2, + }; - const nodeContext = this.getContext('node'); + const nodeVersions: IVersionedNodeType['nodeVersions'] = { + 1: new SplitInBatchesV1(), + 2: new SplitInBatchesV2(), + }; - const batchSize = this.getNodeParameter('batchSize', 0) as number; - - const returnItems: INodeExecutionData[] = []; - - const options = this.getNodeParameter('options', 0, {}); - - if (nodeContext.items === undefined || options.reset === true) { - // Is the first time the node runs - - const sourceData = this.getInputSourceData(); - - nodeContext.currentRunIndex = 0; - nodeContext.maxRunIndex = Math.ceil(items.length / batchSize); - nodeContext.sourceData = deepCopy(sourceData); - - // Get the items which should be returned - returnItems.push.apply(returnItems, items.splice(0, batchSize)); - - // Save the incoming items to be able to return them for later runs - nodeContext.items = [...items]; - - // Reset processedItems as they get only added starting from the first iteration - nodeContext.processedItems = []; - } else { - // The node has been called before. So return the next batch of items. - nodeContext.currentRunIndex += 1; - returnItems.push.apply( - returnItems, - (nodeContext.items as INodeExecutionData[]).splice(0, batchSize), - ); - - const addSourceOverwrite = (pairedItem: IPairedItemData | number): IPairedItemData => { - if (typeof pairedItem === 'number') { - return { - item: pairedItem, - sourceOverwrite: nodeContext.sourceData, - }; - } - - return { - ...pairedItem, - sourceOverwrite: nodeContext.sourceData, - }; - }; - - function getPairedItemInformation( - item: INodeExecutionData, - ): IPairedItemData | IPairedItemData[] { - if (item.pairedItem === undefined) { - return { - item: 0, - sourceOverwrite: nodeContext.sourceData, - }; - } - - if (Array.isArray(item.pairedItem)) { - return item.pairedItem.map(addSourceOverwrite); - } - - return addSourceOverwrite(item.pairedItem); - } - - const sourceOverwrite = this.getInputSourceData(); - - const newItems = items.map((item, index) => { - return { - ...item, - pairedItem: { - sourceOverwrite, - item: index, - }, - }; - }); - - nodeContext.processedItems = [...nodeContext.processedItems, ...newItems]; - - returnItems.map((item) => { - item.pairedItem = getPairedItemInformation(item); - }); - } - - nodeContext.noItemsLeft = nodeContext.items.length === 0; - - if (returnItems.length === 0) { - return [[], nodeContext.processedItems]; - } - - return [returnItems, []]; + super(nodeVersions, baseDescription); } } diff --git a/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.combineData.json b/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.combineData.json index 2971f99e29..94349deb7f 100644 --- a/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.combineData.json +++ b/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.combineData.json @@ -26,7 +26,7 @@ }, "name": "SplitInBatches1", "type": "n8n-nodes-base.splitInBatches", - "typeVersion": 1, + "typeVersion": 2, "position": [1340, 400], "id": "02d51797-ae62-4fd6-b703-426a4b3fb951" }, diff --git a/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow.json b/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v1.json similarity index 100% rename from packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow.json rename to packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v1.json diff --git a/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v2.json b/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v2.json new file mode 100644 index 0000000000..a39dd9f41d --- /dev/null +++ b/packages/nodes-base/nodes/SplitInBatches/test/SplitInBatches.workflow_v2.json @@ -0,0 +1,178 @@ +{ + "name": "Split in Batches Test", + "nodes": [ + { + "parameters": {}, + "id": "86b8149f-b0a0-489c-bb62-e59142988996", + "name": "When clicking \"Execute Workflow\"", + "type": "n8n-nodes-base.manualTrigger", + "typeVersion": 1, + "position": [400, 220] + }, + { + "parameters": { + "batchSize": 1, + "options": {} + }, + "id": "30c5546e-bdcc-44ff-bfca-89c5fb97b678", + "name": "Split In Batches", + "type": "n8n-nodes-base.splitInBatches", + "typeVersion": 2, + "position": [1100, 220] + }, + { + "parameters": { + "values": { + "string": [ + { + "name": "data[0]", + "value": "n8n" + }, + { + "name": "data[1]", + "value": "test" + } + ] + }, + "options": {} + }, + "id": "92d386b8-60be-4f8b-801c-b6459ec206f7", + "name": "Set", + "type": "n8n-nodes-base.set", + "typeVersion": 1, + "position": [640, 220] + }, + { + "parameters": { + "fieldToSplitOut": "data", + "options": {} + }, + "id": "74b7e63e-a9f8-4a82-9e1f-7b2429d9118d", + "name": "Item Lists", + "type": "n8n-nodes-base.itemLists", + "typeVersion": 1, + "position": [860, 220] + }, + { + "parameters": { + "conditions": { + "boolean": [ + { + "value1": "={{ $node[\"Split In Batches\"].context[\"noItemsLeft\"] }}", + "value2": true + } + ] + } + }, + "id": "a5f68369-4e70-4f16-b260-3c8b74517993", + "name": "IF", + "type": "n8n-nodes-base.if", + "typeVersion": 1, + "position": [1280, 220] + }, + { + "parameters": { + "values": { + "string": [ + { + "name": "maxRunIndex", + "value": "={{ $node[\"Split In Batches\"].context[\"maxRunIndex\"] }}" + }, + { + "value": "={{ $node[\"Split In Batches\"].context[\"currentRunIndex\"] }}" + } + ] + }, + "options": {} + }, + "id": "1f44eb0a-5fb7-43a7-8281-84a8a7ec8464", + "name": "Output", + "type": "n8n-nodes-base.set", + "typeVersion": 1, + "position": [1480, 200] + } + ], + "pinData": { + "Output": [ + { + "json": { + "data": "test", + "maxRunIndex": 2, + "propertyName": 1 + } + } + ] + }, + "connections": { + "When clicking \"Execute Workflow\"": { + "main": [ + [ + { + "node": "Set", + "type": "main", + "index": 0 + } + ] + ] + }, + "Split In Batches": { + "main": [ + [ + { + "node": "IF", + "type": "main", + "index": 0 + } + ] + ] + }, + "Set": { + "main": [ + [ + { + "node": "Item Lists", + "type": "main", + "index": 0 + } + ] + ] + }, + "Item Lists": { + "main": [ + [ + { + "node": "Split In Batches", + "type": "main", + "index": 0 + } + ] + ] + }, + "IF": { + "main": [ + [ + { + "node": "Output", + "type": "main", + "index": 0 + } + ], + [ + { + "node": "Split In Batches", + "type": "main", + "index": 0 + } + ] + ] + } + }, + "active": false, + "settings": {}, + "versionId": "de1a454e-43e9-4c2d-b786-18da5d97940f", + "id": "389", + "meta": { + "instanceId": "REMOVED" + }, + "tags": [] +} diff --git a/packages/nodes-base/nodes/SplitInBatches/v1/SplitInBatchesV1.node.ts b/packages/nodes-base/nodes/SplitInBatches/v1/SplitInBatchesV1.node.ts new file mode 100644 index 0000000000..ba7d2c497a --- /dev/null +++ b/packages/nodes-base/nodes/SplitInBatches/v1/SplitInBatchesV1.node.ts @@ -0,0 +1,143 @@ +/* eslint-disable n8n-nodes-base/node-filename-against-convention */ +import type { + IExecuteFunctions, + INodeExecutionData, + INodeType, + INodeTypeDescription, + IPairedItemData, +} from 'n8n-workflow'; +import { deepCopy } from 'n8n-workflow'; + +export class SplitInBatchesV1 implements INodeType { + description: INodeTypeDescription = { + displayName: 'Split In Batches', + name: 'splitInBatches', + icon: 'fa:th-large', + group: ['organization'], + version: 1, + description: 'Split data into batches and iterate over each batch', + defaults: { + name: 'Split In Batches', + color: '#007755', + }, + inputs: ['main'], + outputs: ['main'], + properties: [ + { + displayName: + 'You may not need this node — n8n nodes automatically run once for each input item. More info', + name: 'splitInBatchesNotice', + type: 'notice', + default: '', + }, + { + displayName: 'Batch Size', + name: 'batchSize', + type: 'number', + typeOptions: { + minValue: 1, + }, + default: 10, + description: 'The number of items to return with each call', + }, + { + displayName: 'Options', + name: 'options', + type: 'collection', + placeholder: 'Add Option', + default: {}, + options: [ + { + displayName: 'Reset', + name: 'reset', + type: 'boolean', + default: false, + description: + 'Whether the node will be reset and so with the current input-data newly initialized', + }, + ], + }, + ], + }; + + async execute(this: IExecuteFunctions): Promise { + // Get the input data and create a new array so that we can remove + // items without a problem + const items = this.getInputData().slice(); + + const nodeContext = this.getContext('node'); + + const batchSize = this.getNodeParameter('batchSize', 0) as number; + + const returnItems: INodeExecutionData[] = []; + + const options = this.getNodeParameter('options', 0, {}); + + if (nodeContext.items === undefined || options.reset === true) { + // Is the first time the node runs + + const sourceData = this.getInputSourceData(); + + nodeContext.currentRunIndex = 0; + nodeContext.maxRunIndex = Math.ceil(items.length / batchSize); + nodeContext.sourceData = deepCopy(sourceData); + + // Get the items which should be returned + returnItems.push.apply(returnItems, items.splice(0, batchSize)); + + // Set the other items to be saved in the context to return at later runs + nodeContext.items = [...items]; + } else { + // The node has been called before. So return the next batch of items. + nodeContext.currentRunIndex += 1; + returnItems.push.apply( + returnItems, + (nodeContext.items as INodeExecutionData[]).splice(0, batchSize), + ); + + const addSourceOverwrite = (pairedItem: IPairedItemData | number): IPairedItemData => { + if (typeof pairedItem === 'number') { + return { + item: pairedItem, + sourceOverwrite: nodeContext.sourceData, + }; + } + + return { + ...pairedItem, + sourceOverwrite: nodeContext.sourceData, + }; + }; + + function getPairedItemInformation( + item: INodeExecutionData, + ): IPairedItemData | IPairedItemData[] { + if (item.pairedItem === undefined) { + return { + item: 0, + sourceOverwrite: nodeContext.sourceData, + }; + } + + if (Array.isArray(item.pairedItem)) { + return item.pairedItem.map(addSourceOverwrite); + } + + return addSourceOverwrite(item.pairedItem); + } + + returnItems.map((item) => { + item.pairedItem = getPairedItemInformation(item); + }); + } + + nodeContext.noItemsLeft = nodeContext.items.length === 0; + + if (returnItems.length === 0) { + // No data left to return so stop execution of the branch + return null; + } + + return [returnItems]; + } +} diff --git a/packages/nodes-base/nodes/SplitInBatches/v2/SplitInBatchesV2.node.ts b/packages/nodes-base/nodes/SplitInBatches/v2/SplitInBatchesV2.node.ts new file mode 100644 index 0000000000..31252fd483 --- /dev/null +++ b/packages/nodes-base/nodes/SplitInBatches/v2/SplitInBatchesV2.node.ts @@ -0,0 +1,161 @@ +/* eslint-disable n8n-nodes-base/node-filename-against-convention */ +import type { + IExecuteFunctions, + INodeExecutionData, + INodeType, + INodeTypeDescription, + IPairedItemData, +} from 'n8n-workflow'; +import { deepCopy } from 'n8n-workflow'; + +export class SplitInBatchesV2 implements INodeType { + description: INodeTypeDescription = { + displayName: 'Split In Batches', + name: 'splitInBatches', + icon: 'fa:th-large', + group: ['organization'], + version: 2, + description: 'Split data into batches and iterate over each batch', + defaults: { + name: 'Split In Batches', + color: '#007755', + }, + inputs: ['main'], + // eslint-disable-next-line n8n-nodes-base/node-class-description-outputs-wrong + outputs: ['main', 'main'], + outputNames: ['loop', 'done'], + properties: [ + { + displayName: + 'You may not need this node — n8n nodes automatically run once for each input item. More info', + name: 'splitInBatchesNotice', + type: 'notice', + default: '', + }, + { + displayName: 'Batch Size', + name: 'batchSize', + type: 'number', + typeOptions: { + minValue: 1, + }, + default: 10, + description: 'The number of items to return with each call', + }, + { + displayName: 'Options', + name: 'options', + type: 'collection', + placeholder: 'Add Option', + default: {}, + options: [ + { + displayName: 'Reset', + name: 'reset', + type: 'boolean', + default: false, + description: + 'Whether the node will be reset and so with the current input-data newly initialized', + }, + ], + }, + ], + }; + + async execute(this: IExecuteFunctions): Promise { + // Get the input data and create a new array so that we can remove + // items without a problem + const items = this.getInputData().slice(); + + const nodeContext = this.getContext('node'); + + const batchSize = this.getNodeParameter('batchSize', 0) as number; + + const returnItems: INodeExecutionData[] = []; + + const options = this.getNodeParameter('options', 0, {}); + + if (nodeContext.items === undefined || options.reset === true) { + // Is the first time the node runs + + const sourceData = this.getInputSourceData(); + + nodeContext.currentRunIndex = 0; + nodeContext.maxRunIndex = Math.ceil(items.length / batchSize); + nodeContext.sourceData = deepCopy(sourceData); + + // Get the items which should be returned + returnItems.push.apply(returnItems, items.splice(0, batchSize)); + + // Save the incoming items to be able to return them for later runs + nodeContext.items = [...items]; + + // Reset processedItems as they get only added starting from the first iteration + nodeContext.processedItems = []; + } else { + // The node has been called before. So return the next batch of items. + nodeContext.currentRunIndex += 1; + returnItems.push.apply( + returnItems, + (nodeContext.items as INodeExecutionData[]).splice(0, batchSize), + ); + + const addSourceOverwrite = (pairedItem: IPairedItemData | number): IPairedItemData => { + if (typeof pairedItem === 'number') { + return { + item: pairedItem, + sourceOverwrite: nodeContext.sourceData, + }; + } + + return { + ...pairedItem, + sourceOverwrite: nodeContext.sourceData, + }; + }; + + function getPairedItemInformation( + item: INodeExecutionData, + ): IPairedItemData | IPairedItemData[] { + if (item.pairedItem === undefined) { + return { + item: 0, + sourceOverwrite: nodeContext.sourceData, + }; + } + + if (Array.isArray(item.pairedItem)) { + return item.pairedItem.map(addSourceOverwrite); + } + + return addSourceOverwrite(item.pairedItem); + } + + const sourceOverwrite = this.getInputSourceData(); + + const newItems = items.map((item, index) => { + return { + ...item, + pairedItem: { + sourceOverwrite, + item: index, + }, + }; + }); + + nodeContext.processedItems = [...nodeContext.processedItems, ...newItems]; + + returnItems.map((item) => { + item.pairedItem = getPairedItemInformation(item); + }); + } + + nodeContext.noItemsLeft = nodeContext.items.length === 0; + + if (returnItems.length === 0) { + return [[], nodeContext.processedItems]; + } + + return [returnItems, []]; + } +} From a70e639c75302597564e07fb410c7dc0fb0066da Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E0=A4=95=E0=A4=BE=E0=A4=B0=E0=A4=A4=E0=A5=8B=E0=A4=AB?= =?UTF-8?q?=E0=A5=8D=E0=A4=AB=E0=A5=87=E0=A4=B2=E0=A4=B8=E0=A5=8D=E0=A4=95?= =?UTF-8?q?=E0=A5=8D=E0=A4=B0=E0=A4=BF=E0=A4=AA=E0=A5=8D=E0=A4=9F=E2=84=A2?= Date: Wed, 22 Mar 2023 14:22:50 +0100 Subject: [PATCH 2/4] fix(core): Require Auth on icons and nodes/credentials types static files (no-changelog) (#5745) --- packages/cli/src/Server.ts | 2 -- 1 file changed, 2 deletions(-) diff --git a/packages/cli/src/Server.ts b/packages/cli/src/Server.ts index 92a7632b2e..e9c9d6acc4 100644 --- a/packages/cli/src/Server.ts +++ b/packages/cli/src/Server.ts @@ -435,8 +435,6 @@ class Server extends AbstractServer { 'assets', 'healthz', 'metrics', - 'icons', - 'types', 'e2e', this.endpointWebhook, this.endpointWebhookTest, From 4ac944af3028b70ae600000300c16de77c1af1d5 Mon Sep 17 00:00:00 2001 From: agobrech <45268029+agobrech@users.noreply.github.com> Date: Wed, 22 Mar 2023 22:04:25 +0100 Subject: [PATCH 3/4] fix(HTTP Request Node): Fix AWS credentials to automatically deconstruct the url (#5751) Workaround to use decompose uri whe OptionsUri is being used --- .../nodes-base/credentials/Aws.credentials.ts | 81 ++++++++++++------- 1 file changed, 50 insertions(+), 31 deletions(-) diff --git a/packages/nodes-base/credentials/Aws.credentials.ts b/packages/nodes-base/credentials/Aws.credentials.ts index 46d126872e..9e28902ce3 100644 --- a/packages/nodes-base/credentials/Aws.credentials.ts +++ b/packages/nodes-base/credentials/Aws.credentials.ts @@ -9,6 +9,7 @@ import type { IHttpRequestOptions, INodeProperties, } from 'n8n-workflow'; +import type { OptionsWithUri } from 'request'; export const regions = [ { @@ -285,44 +286,62 @@ export class Aws implements ICredentialType { let body = requestOptions.body; let region = credentials.region; const query = requestOptions.qs?.query as IDataObject; - if (!requestOptions.baseURL && !requestOptions.url) { - let endpointString: string; - if (service === 'lambda' && credentials.lambdaEndpoint) { - endpointString = credentials.lambdaEndpoint as string; - } else if (service === 'sns' && credentials.snsEndpoint) { - endpointString = credentials.snsEndpoint as string; - } else if (service === 'sqs' && credentials.sqsEndpoint) { - endpointString = credentials.sqsEndpoint as string; - } else if (service === 's3' && credentials.s3Endpoint) { - endpointString = credentials.s3Endpoint as string; - } else if (service === 'ses' && credentials.sesEndpoint) { - endpointString = credentials.sesEndpoint as string; - } else if (service === 'rekognition' && credentials.rekognitionEndpoint) { - endpointString = credentials.rekognitionEndpoint as string; - } else if (service === 'sqs' && credentials.sqsEndpoint) { - endpointString = credentials.sqsEndpoint as string; - } else if (service) { - endpointString = `https://${service}.${credentials.region}.amazonaws.com`; - } - endpoint = new URL( - endpointString!.replace('{region}', credentials.region as string) + (path as string), - ); - } else { - // If no endpoint is set, we try to decompose the path and use the default endpoint - const customUrl = new URL(`${requestOptions.baseURL!}${requestOptions.url}${path ?? ''}`); - service = customUrl.hostname.split('.')[0]; - region = customUrl.hostname.split('.')[1]; + + // ! Workaround as we still use the OptionsWithUri interface which uses uri instead of url + // ! To change when we replace the interface with IHttpRequestOptions + const requestWithUri = requestOptions as unknown as OptionsWithUri; + if (requestWithUri.uri) { + requestOptions.url = requestWithUri.uri as string; + endpoint = new URL(requestOptions.url); if (service === 'sts') { try { - customUrl.searchParams.set('Action', 'GetCallerIdentity'); - customUrl.searchParams.set('Version', '2011-06-15'); + endpoint.searchParams.set('Action', 'GetCallerIdentity'); + endpoint.searchParams.set('Version', '2011-06-15'); } catch (err) { console.log(err); } } - endpoint = customUrl; + service = endpoint.hostname.split('.')[0]; + region = endpoint.hostname.split('.')[1]; + } else { + if (!requestOptions.baseURL && !requestOptions.url) { + let endpointString: string; + if (service === 'lambda' && credentials.lambdaEndpoint) { + endpointString = credentials.lambdaEndpoint as string; + } else if (service === 'sns' && credentials.snsEndpoint) { + endpointString = credentials.snsEndpoint as string; + } else if (service === 'sqs' && credentials.sqsEndpoint) { + endpointString = credentials.sqsEndpoint as string; + } else if (service === 's3' && credentials.s3Endpoint) { + endpointString = credentials.s3Endpoint as string; + } else if (service === 'ses' && credentials.sesEndpoint) { + endpointString = credentials.sesEndpoint as string; + } else if (service === 'rekognition' && credentials.rekognitionEndpoint) { + endpointString = credentials.rekognitionEndpoint as string; + } else if (service === 'sqs' && credentials.sqsEndpoint) { + endpointString = credentials.sqsEndpoint as string; + } else if (service) { + endpointString = `https://${service}.${credentials.region}.amazonaws.com`; + } + endpoint = new URL( + endpointString!.replace('{region}', credentials.region as string) + (path as string), + ); + } else { + // If no endpoint is set, we try to decompose the path and use the default endpoint + const customUrl = new URL(`${requestOptions.baseURL!}${requestOptions.url}${path ?? ''}`); + service = customUrl.hostname.split('.')[0]; + region = customUrl.hostname.split('.')[1]; + if (service === 'sts') { + try { + customUrl.searchParams.set('Action', 'GetCallerIdentity'); + customUrl.searchParams.set('Version', '2011-06-15'); + } catch (err) { + console.log(err); + } + } + endpoint = customUrl; + } } - if (query && Object.keys(query).length !== 0) { Object.keys(query).forEach((key) => { endpoint.searchParams.append(key, query[key] as string); From 5dd92c6b9490b02243ab2eeedee4b06006555460 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Thu, 23 Mar 2023 15:37:49 +0100 Subject: [PATCH 4/4] :rocket: Release 0.221.0 (#5726) --- CHANGELOG.md | 36 +++++++++++++++++++++++++++++ package.json | 2 +- packages/cli/package.json | 2 +- packages/core/package.json | 2 +- packages/design-system/package.json | 2 +- packages/editor-ui/package.json | 2 +- packages/node-dev/package.json | 2 +- packages/nodes-base/package.json | 2 +- packages/workflow/package.json | 2 +- 9 files changed, 44 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 294ce6ecc0..f2aa55521a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,39 @@ +# [0.221.0](https://github.com/n8n-io/n8n/compare/n8n@0.220.0...n8n@0.221.0) (2023-03-23) + + +### Bug Fixes + +* **core:** Fix calling error workflows in main mode recovery ([#5698](https://github.com/n8n-io/n8n/issues/5698)) ([e0ea97a](https://github.com/n8n-io/n8n/commit/e0ea97af8d7aaa014680f5f9d5702d1cafd49757)) +* **core:** Fix telemetry execution status for manual workflows executions ([#5712](https://github.com/n8n-io/n8n/issues/5712)) ([a28396e](https://github.com/n8n-io/n8n/commit/a28396ee91bfbccc6596812606c237a8e2c34088)) +* **core:** Return saml attributes after connection test ([#5717](https://github.com/n8n-io/n8n/issues/5717)) ([be172cb](https://github.com/n8n-io/n8n/commit/be172cb720c8a44ebd1f0b86dddab321e1e3c9fd)) +* **editor:** Disable tooltip for display modes that don't support mapping ([#5715](https://github.com/n8n-io/n8n/issues/5715)) ([fb8755e](https://github.com/n8n-io/n8n/commit/fb8755ea3c720c98f002a6756c39b8fed11482c0)) +* **editor:** Fix execution list item selection ([#5606](https://github.com/n8n-io/n8n/issues/5606)) ([7a352ef](https://github.com/n8n-io/n8n/commit/7a352efff944c52062412e53ea2c1a034a25f908)) +* **editor:** Fix for large notifications being cut off ([#5705](https://github.com/n8n-io/n8n/issues/5705)) ([c07f838](https://github.com/n8n-io/n8n/commit/c07f838ce60dc33261fe3e1b5e7dd6fe05f1d63b)) +* **editor:** Fix redo in code and expression editor ([#5708](https://github.com/n8n-io/n8n/issues/5708)) ([cd7a55b](https://github.com/n8n-io/n8n/commit/cd7a55ba5aeb83d1e540a65b5c6b2c74fd742461)) +* **editor:** Fix the canvas node distance when automatically injecting manual trigger ([#5716](https://github.com/n8n-io/n8n/issues/5716)) ([cb2ba97](https://github.com/n8n-io/n8n/commit/cb2ba97f3837b572e237da1256b9f2ee376767a9)) +* **HTTP Request Node:** Fix AWS credentials to automatically deconstruct the url ([#5751](https://github.com/n8n-io/n8n/issues/5751)) ([4ac944a](https://github.com/n8n-io/n8n/commit/4ac944af3028b70ae600000300c16de77c1af1d5)) +* **Split In Batches Node:** Roll back changes in v1 and create v2 ([#5747](https://github.com/n8n-io/n8n/issues/5747)) ([cefec77](https://github.com/n8n-io/n8n/commit/cefec7739b6da820d64f9476476e1901d4f386bf)) + + +### Features + +* **core:** Augment data instead of copying it ([#5487](https://github.com/n8n-io/n8n/issues/5487)) ([0876c38](https://github.com/n8n-io/n8n/commit/0876c38aaeb8355141fecbc14e84cdda0b2c737b)) +* **editor:** Move canvas by holding Space or Middle mouse button ([#5719](https://github.com/n8n-io/n8n/issues/5719)) ([19dded1](https://github.com/n8n-io/n8n/commit/19dded18c9a588a30b9ac1fc274dcd967e9b7b6b)) +* **editor:** Recommend and pre-select auth type with overrides ([#5684](https://github.com/n8n-io/n8n/issues/5684)) ([f59b591](https://github.com/n8n-io/n8n/commit/f59b591c93ecd7cbd279668abe6494ef2b88c831)) +* **editor:** SSO login button ([#5615](https://github.com/n8n-io/n8n/issues/5615)) ([6916628](https://github.com/n8n-io/n8n/commit/6916628a9f11e07cbcdf390f747f396fb0ef9e3c)) +* **QuickChart Node:** Add QuickChart node ([#3572](https://github.com/n8n-io/n8n/issues/3572)) ([233f1fa](https://github.com/n8n-io/n8n/commit/233f1fa7ec230e92e868de0247e315aa6a705ead)) + + + +## [0.220.1](https://github.com/n8n-io/n8n/compare/n8n@0.220.0...n8n@0.220.1) (2023-03-22) + + +### Bug Fixes + +* **Split In Batches Node:** Roll back changes in v1 and create v2 ([#5747](https://github.com/n8n-io/n8n/issues/5747)) ([6d1c88e](https://github.com/n8n-io/n8n/commit/6d1c88ea8c2e5dc72c6e6edeeeef52dc1fba4075)) + + + # [0.220.0](https://github.com/n8n-io/n8n/compare/n8n@0.219.1...n8n@0.220.0) (2023-03-16) diff --git a/package.json b/package.json index e69c7a2986..830e762f8e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "n8n", - "version": "0.220.0", + "version": "0.221.0", "private": true, "homepage": "https://n8n.io", "engines": { diff --git a/packages/cli/package.json b/packages/cli/package.json index 83feb4ce8e..c0649065ec 100644 --- a/packages/cli/package.json +++ b/packages/cli/package.json @@ -1,6 +1,6 @@ { "name": "n8n", - "version": "0.220.0", + "version": "0.221.0", "description": "n8n Workflow Automation Tool", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", diff --git a/packages/core/package.json b/packages/core/package.json index 472e4ec1f6..a1ea182a0c 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "n8n-core", - "version": "0.159.0", + "version": "0.160.0", "description": "Core functionality of n8n", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", diff --git a/packages/design-system/package.json b/packages/design-system/package.json index 40d9464dd8..bb56ef9560 100644 --- a/packages/design-system/package.json +++ b/packages/design-system/package.json @@ -1,6 +1,6 @@ { "name": "n8n-design-system", - "version": "0.58.0", + "version": "0.59.0", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", "author": { diff --git a/packages/editor-ui/package.json b/packages/editor-ui/package.json index 6823adcc84..5bf7f2ad54 100644 --- a/packages/editor-ui/package.json +++ b/packages/editor-ui/package.json @@ -1,6 +1,6 @@ { "name": "n8n-editor-ui", - "version": "0.186.0", + "version": "0.187.0", "description": "Workflow Editor UI for n8n", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", diff --git a/packages/node-dev/package.json b/packages/node-dev/package.json index 432be1663b..2b0759927c 100644 --- a/packages/node-dev/package.json +++ b/packages/node-dev/package.json @@ -1,6 +1,6 @@ { "name": "n8n-node-dev", - "version": "0.98.0", + "version": "0.99.0", "description": "CLI to simplify n8n credentials/node development", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", diff --git a/packages/nodes-base/package.json b/packages/nodes-base/package.json index d638228998..30a3ec5b88 100644 --- a/packages/nodes-base/package.json +++ b/packages/nodes-base/package.json @@ -1,6 +1,6 @@ { "name": "n8n-nodes-base", - "version": "0.218.0", + "version": "0.219.0", "description": "Base nodes of n8n", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io", diff --git a/packages/workflow/package.json b/packages/workflow/package.json index ae585d7d98..d257335d47 100644 --- a/packages/workflow/package.json +++ b/packages/workflow/package.json @@ -1,6 +1,6 @@ { "name": "n8n-workflow", - "version": "0.141.0", + "version": "0.142.0", "description": "Workflow base code of n8n", "license": "SEE LICENSE IN LICENSE.md", "homepage": "https://n8n.io",