mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-10 22:54:05 -08:00
61e26804ba
* ⚡ enabled array-type * ⚡ await-thenable on * ⚡ ban-types on * ⚡ default-param-last on * ⚡ dot-notation on * ⚡ member-delimiter-style on * ⚡ no-duplicate-imports on * ⚡ no-empty-interface on * ⚡ no-floating-promises on * ⚡ no-for-in-array on * ⚡ no-invalid-void-type on * ⚡ no-loop-func on * ⚡ no-shadow on * ⚡ ban-ts-comment re enabled * ⚡ @typescript-eslint/lines-between-class-members on * address my own comment * @typescript-eslint/return-await on * @typescript-eslint/promise-function-async on * @typescript-eslint/no-unnecessary-boolean-literal-compare on * @typescript-eslint/no-unnecessary-type-assertion on * prefer-const on * @typescript-eslint/prefer-optional-chain on Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
154 lines
2.7 KiB
TypeScript
154 lines
2.7 KiB
TypeScript
import { 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',
|
|
},
|
|
];
|
|
}
|