mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-13 05:47:31 -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>
76 lines
2 KiB
TypeScript
76 lines
2 KiB
TypeScript
import {
|
|
deepCopy,
|
|
ICredentialDataDecryptedObject,
|
|
IDataObject,
|
|
ILoadOptionsFunctions,
|
|
INodeExecutionData,
|
|
INodeListSearchResult,
|
|
} from 'n8n-workflow';
|
|
import mysql2 from 'mysql2/promise';
|
|
|
|
/**
|
|
* Returns of copy of the items which only contains the json data and
|
|
* of that only the define properties
|
|
*
|
|
* @param {INodeExecutionData[]} items The items to copy
|
|
* @param {string[]} properties The properties it should include
|
|
*/
|
|
export function copyInputItems(items: INodeExecutionData[], properties: string[]): IDataObject[] {
|
|
// Prepare the data to insert and copy it to be returned
|
|
let newItem: IDataObject;
|
|
return items.map((item) => {
|
|
newItem = {};
|
|
for (const property of properties) {
|
|
if (item.json[property] === undefined) {
|
|
newItem[property] = null;
|
|
} else {
|
|
newItem[property] = deepCopy(item.json[property]);
|
|
}
|
|
}
|
|
return newItem;
|
|
});
|
|
}
|
|
|
|
export async function createConnection(
|
|
credentials: ICredentialDataDecryptedObject,
|
|
): Promise<mysql2.Connection> {
|
|
const { ssl, caCertificate, clientCertificate, clientPrivateKey, ...baseCredentials } =
|
|
credentials;
|
|
|
|
if (ssl) {
|
|
baseCredentials.ssl = {};
|
|
|
|
if (caCertificate) {
|
|
baseCredentials.ssl.ca = caCertificate;
|
|
}
|
|
|
|
if (clientCertificate || clientPrivateKey) {
|
|
baseCredentials.ssl.cert = clientCertificate;
|
|
baseCredentials.ssl.key = clientPrivateKey;
|
|
}
|
|
}
|
|
|
|
return mysql2.createConnection(baseCredentials);
|
|
}
|
|
|
|
export async function searchTables(
|
|
this: ILoadOptionsFunctions,
|
|
query?: string,
|
|
): Promise<INodeListSearchResult> {
|
|
const credentials = await this.getCredentials('mySql');
|
|
const connection = await createConnection(credentials);
|
|
const sql = `
|
|
SELECT table_name FROM information_schema.tables
|
|
WHERE table_schema = '${credentials.database}'
|
|
and table_name like '%${query || ''}%'
|
|
ORDER BY table_name
|
|
`;
|
|
const [rows] = await connection.query(sql);
|
|
const results = (rows as IDataObject[]).map((r) => ({
|
|
name: r.TABLE_NAME as string,
|
|
value: r.TABLE_NAME as string,
|
|
}));
|
|
await connection.end();
|
|
return { results };
|
|
}
|