From 94c9cd40803bf63c39f6b961589c2596c98ead74 Mon Sep 17 00:00:00 2001 From: Alex Grozav Date: Wed, 10 Jan 2024 14:50:41 +0200 Subject: [PATCH 1/2] feat: Update @n8n/chat exports and add example images (no-changelog) (#8274) --- packages/@n8n/chat/README.md | 6 ++++++ packages/@n8n/chat/package.json | 8 ++++---- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/packages/@n8n/chat/README.md b/packages/@n8n/chat/README.md index 2273d7d5c80d2..2cb9babbf11f7 100644 --- a/packages/@n8n/chat/README.md +++ b/packages/@n8n/chat/README.md @@ -1,6 +1,12 @@ # n8n Chat This is an embeddable Chat widget for n8n. It allows the execution of AI-Powered Workflows through a Chat window. +**Windowed Example** +![n8n Chat Windowed](https://raw.githubusercontent.com/n8n-io/n8n/master/packages/%40n8n/chat/resources/images/windowed.png) + +**Fullscreen Example** +![n8n Chat Fullscreen](https://raw.githubusercontent.com/n8n-io/n8n/master/packages/%40n8n/chat/resources/images/fullscreen.png) + ## Prerequisites Create a n8n workflow which you want to execute via chat. The workflow has to be triggered using a **Chat Trigger** node. diff --git a/packages/@n8n/chat/package.json b/packages/@n8n/chat/package.json index 5700b3273e613..0f768289a96b4 100644 --- a/packages/@n8n/chat/package.json +++ b/packages/@n8n/chat/package.json @@ -1,6 +1,6 @@ { "name": "@n8n/chat", - "version": "0.6.0", + "version": "0.6.1", "scripts": { "dev": "pnpm run storybook", "build": "pnpm type-check && pnpm build:vite && pnpm run build:individual && npm run build:prepare", @@ -21,13 +21,13 @@ "build:storybook": "storybook build", "release": "pnpm run build:full && cd dist && pnpm publish" }, - "main": "./chat.umd.cjs", + "main": "./chat.umd.js", "module": "./chat.es.js", "types": "./types/index.d.ts", "exports": { ".": { - "import": "./chat.es.js", - "require": "./chat.umd.cjs" + "import": "./index.mjs", + "require": "./index.js" }, "./style.css": { "import": "./style.css", From e796e7f06d73a74a403000c53942d56cab91781b Mon Sep 17 00:00:00 2001 From: Michael Kret <88898367+michael-radency@users.noreply.github.com> Date: Wed, 10 Jan 2024 15:02:05 +0200 Subject: [PATCH 2/2] feat(MongoDB Node): Add support for TLS (#8266) --- .../credentials/MongoDb.credentials.ts | 62 +++++++++++++++++++ .../nodes/MongoDb/GenericFunctions.ts | 32 +++++++++- .../nodes-base/nodes/MongoDb/MongoDb.node.ts | 13 ++-- 3 files changed, 99 insertions(+), 8 deletions(-) diff --git a/packages/nodes-base/credentials/MongoDb.credentials.ts b/packages/nodes-base/credentials/MongoDb.credentials.ts index f018e67b59932..495e9ed5b83f2 100644 --- a/packages/nodes-base/credentials/MongoDb.credentials.ts +++ b/packages/nodes-base/credentials/MongoDb.credentials.ts @@ -96,5 +96,67 @@ export class MongoDb implements ICredentialType { }, default: 27017, }, + { + displayName: 'Use TLS', + name: 'tls', + type: 'boolean', + default: false, + }, + { + displayName: 'CA Certificate', + name: 'ca', + type: 'string', + typeOptions: { + password: true, + }, + displayOptions: { + show: { + tls: [true], + }, + }, + default: '', + }, + { + displayName: 'Public Client Certificate', + name: 'cert', + type: 'string', + typeOptions: { + password: true, + }, + displayOptions: { + show: { + tls: [true], + }, + }, + default: '', + }, + { + displayName: 'Private Client Key', + name: 'key', + type: 'string', + typeOptions: { + password: true, + }, + displayOptions: { + show: { + tls: [true], + }, + }, + default: '', + }, + { + displayName: 'Passphrase', + name: 'passphrase', + type: 'string', + typeOptions: { + password: true, + }, + displayOptions: { + show: { + tls: [true], + }, + }, + default: '', + }, ]; } diff --git a/packages/nodes-base/nodes/MongoDb/GenericFunctions.ts b/packages/nodes-base/nodes/MongoDb/GenericFunctions.ts index 1be13325373ad..3dc6be03abfa9 100644 --- a/packages/nodes-base/nodes/MongoDb/GenericFunctions.ts +++ b/packages/nodes-base/nodes/MongoDb/GenericFunctions.ts @@ -8,13 +8,16 @@ import { NodeOperationError } from 'n8n-workflow'; import get from 'lodash/get'; import set from 'lodash/set'; -import { ObjectId } from 'mongodb'; +import { MongoClient, ObjectId } from 'mongodb'; import type { IMongoCredentials, IMongoCredentialsType, IMongoParametricCredentials, } from './mongoDb.types'; +import { createSecureContext } from 'tls'; +import { formatPrivateKey } from '../../utils/utilities'; + /** * Standard way of building the MongoDB connection string, unless overridden with a provided string * @@ -140,3 +143,30 @@ export function stringifyObjectIDs(items: IDataObject[]) { } }); } + +export async function connectMongoClient(connectionString: string, credentials: IDataObject = {}) { + let client: MongoClient; + + if (credentials.tls) { + const ca = credentials.ca ? formatPrivateKey(credentials.ca as string) : undefined; + const cert = credentials.cert ? formatPrivateKey(credentials.cert as string) : undefined; + const key = credentials.key ? formatPrivateKey(credentials.key as string) : undefined; + const passphrase = (credentials.passphrase as string) || undefined; + + const secureContext = createSecureContext({ + ca, + cert, + key, + passphrase, + }); + + client = await MongoClient.connect(connectionString, { + tls: true, + secureContext, + }); + } else { + client = await MongoClient.connect(connectionString); + } + + return client; +} diff --git a/packages/nodes-base/nodes/MongoDb/MongoDb.node.ts b/packages/nodes-base/nodes/MongoDb/MongoDb.node.ts index 304abe6c38772..f506b26d5592f 100644 --- a/packages/nodes-base/nodes/MongoDb/MongoDb.node.ts +++ b/packages/nodes-base/nodes/MongoDb/MongoDb.node.ts @@ -17,12 +17,13 @@ import type { UpdateOptions, Sort, } from 'mongodb'; -import { MongoClient, ObjectId } from 'mongodb'; +import { ObjectId } from 'mongodb'; import { generatePairedItemData } from '../../utils/utilities'; import { nodeProperties } from './MongoDbProperties'; import { buildParameterizedConnString, + connectMongoClient, prepareFields, prepareItems, stringifyObjectIDs, @@ -74,7 +75,7 @@ export class MongoDb implements INodeType { ); } - const client: MongoClient = await MongoClient.connect(connectionString); + const client = await connectMongoClient(connectionString, credentials); const { databases } = await client.db().admin().listDatabases(); @@ -100,12 +101,10 @@ export class MongoDb implements INodeType { }; async execute(this: IExecuteFunctions): Promise { - const { database, connectionString } = validateAndResolveMongoCredentials( - this, - await this.getCredentials('mongoDb'), - ); + const credentials = await this.getCredentials('mongoDb'); + const { database, connectionString } = validateAndResolveMongoCredentials(this, credentials); - const client: MongoClient = await MongoClient.connect(connectionString); + const client = await connectMongoClient(connectionString, credentials); const mdb = client.db(database);