n8n/packages/nodes-base/credentials/Mqtt.credentials.ts
Iván Ovejero b03e358a12
refactor: Integrate consistent-type-imports in nodes-base (no-changelog) (#5267)
* 👕 Enable `consistent-type-imports` for nodes-base

* 👕 Apply to nodes-base

*  Undo unrelated changes

* 🚚 Move to `.eslintrc.js` in nodes-base

*  Revert "Enable `consistent-type-imports` for nodes-base"

This reverts commit 529ad72b05.

* 👕 Fix severity
2023-01-27 12:22:44 +01:00

154 lines
2.7 KiB
TypeScript

import type { ICredentialType, IDisplayOptions, INodeProperties } from 'n8n-workflow';
export class Mqtt implements ICredentialType {
name = 'mqtt';
displayName = 'MQTT';
documentationUrl = 'mqtt';
properties: INodeProperties[] = [
{
displayName: 'Protocol',
name: 'protocol',
type: 'options',
options: [
{
name: 'Mqtt',
value: 'mqtt',
},
{
name: 'Mqtts',
value: 'mqtts',
},
{
name: 'Ws',
value: 'ws',
},
],
default: 'mqtt',
},
{
displayName: 'Host',
name: 'host',
type: 'string',
default: '',
},
{
displayName: 'Port',
name: 'port',
type: 'number',
default: 1883,
},
{
displayName: 'Username',
name: 'username',
type: 'string',
default: '',
},
{
displayName: 'Password',
name: 'password',
type: 'string',
typeOptions: {
password: true,
},
default: '',
},
{
displayName: 'Clean Session',
name: 'clean',
type: 'boolean',
default: true,
description:
'Whether to use clean session - set to false to receive QoS 1 and 2 messages while offline',
},
{
displayName: 'Client ID',
name: 'clientId',
type: 'string',
default: '',
description: 'Client ID. If left empty, one is autogenerated for you.',
},
{
displayName: 'SSL',
name: 'ssl',
type: 'boolean',
default: false,
},
{
displayName: 'Passwordless',
name: 'passwordless',
type: 'boolean',
displayOptions: {
show: {
ssl: [true],
},
},
default: true,
description:
'Whether to use passwordless connection with certificates (SASL mechanism EXTERNAL)',
},
{
displayName: 'CA Certificates',
name: 'ca',
type: 'string',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
},
},
default: '',
description: 'SSL CA Certificates to use',
},
{
displayName: 'Reject Unauthorized Certificate',
name: 'rejectUnauthorized',
type: 'boolean',
displayOptions: {
show: {
ssl: [true],
passwordless: [true],
},
} as IDisplayOptions,
default: false,
description: 'Whether to validate Certificate',
},
{
displayName: 'Client Certificate',
name: 'cert',
type: 'string',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
passwordless: [true],
},
} as IDisplayOptions,
default: '',
description: 'SSL Client Certificate to use',
},
{
displayName: 'Client Key',
name: 'key',
type: 'string',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
passwordless: [true],
},
},
default: '',
description: 'SSL Client Key to use',
},
];
}