mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-14 14:28:14 -08:00
b03e358a12
* 👕 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
154 lines
2.7 KiB
TypeScript
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',
|
|
},
|
|
];
|
|
}
|