mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-05 18:07:27 -08:00
85aa560a5d
Co-authored-by: Michael Kret <michael.k@radency.com>
49 lines
1.4 KiB
TypeScript
49 lines
1.4 KiB
TypeScript
import type mysql2 from 'mysql2/promise';
|
|
import type { IDataObject, INodeExecutionData, SSHCredentials } from 'n8n-workflow';
|
|
|
|
export type Mysql2Connection = mysql2.Connection;
|
|
export type Mysql2Pool = mysql2.Pool;
|
|
export type Mysql2OkPacket = mysql2.OkPacket;
|
|
|
|
export type QueryValues = Array<string | number | IDataObject>;
|
|
export type QueryWithValues = { query: string; values: QueryValues };
|
|
|
|
export type QueryRunner = (queries: QueryWithValues[]) => Promise<INodeExecutionData[]>;
|
|
|
|
export type WhereClause = { column: string; condition: string; value: string | number };
|
|
export type SortRule = { column: string; direction: string };
|
|
|
|
export const AUTO_MAP = 'autoMapInputData';
|
|
const MANUAL = 'defineBelow';
|
|
export const DATA_MODE = {
|
|
AUTO_MAP,
|
|
MANUAL,
|
|
};
|
|
|
|
export const SINGLE = 'single';
|
|
const TRANSACTION = 'transaction';
|
|
const INDEPENDENTLY = 'independently';
|
|
export const BATCH_MODE = { SINGLE, TRANSACTION, INDEPENDENTLY };
|
|
|
|
export type QueryMode = typeof SINGLE | typeof TRANSACTION | typeof INDEPENDENTLY;
|
|
|
|
type WithSSL =
|
|
| { ssl: false }
|
|
| { ssl: true; caCertificate: string; clientCertificate: string; clientPrivateKey: string };
|
|
|
|
type WithSSHTunnel =
|
|
| { sshTunnel: false }
|
|
| ({
|
|
sshTunnel: true;
|
|
} & SSHCredentials);
|
|
|
|
export type MysqlNodeCredentials = {
|
|
host: string;
|
|
port: number;
|
|
database: string;
|
|
user: string;
|
|
password: string;
|
|
connectTimeout: number;
|
|
} & WithSSL &
|
|
WithSSHTunnel;
|