n8n/packages/nodes-base/credentials/MySql.credentials.ts
2024-12-19 18:46:14 +01:00

105 lines
1.8 KiB
TypeScript

import type { ICredentialType, INodeProperties } from 'n8n-workflow';
import { sshTunnelProperties } from '@utils/sshTunnel.properties';
export class MySql implements ICredentialType {
name = 'mySql';
displayName = 'MySQL';
documentationUrl = 'mySql';
properties: INodeProperties[] = [
{
displayName: 'Host',
name: 'host',
type: 'string',
default: 'localhost',
},
{
displayName: 'Database',
name: 'database',
type: 'string',
default: 'mysql',
},
{
displayName: 'User',
name: 'user',
type: 'string',
default: 'mysql',
},
{
displayName: 'Password',
name: 'password',
type: 'string',
typeOptions: {
password: true,
},
default: '',
},
{
displayName: 'Port',
name: 'port',
type: 'number',
default: 3306,
},
{
displayName: 'Connect Timeout',
name: 'connectTimeout',
type: 'number',
default: 10000,
description:
'The milliseconds before a timeout occurs during the initial connection to the MySQL server',
},
{
displayName: 'SSL',
name: 'ssl',
type: 'boolean',
default: false,
},
{
displayName: 'CA Certificate',
name: 'caCertificate',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
},
},
type: 'string',
default: '',
},
{
displayName: 'Client Private Key',
name: 'clientPrivateKey',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
},
},
type: 'string',
default: '',
},
{
displayName: 'Client Certificate',
name: 'clientCertificate',
typeOptions: {
password: true,
},
displayOptions: {
show: {
ssl: [true],
},
},
type: 'string',
default: '',
},
...sshTunnelProperties,
];
}