import type { IDataObject, ILoadOptionsFunctions, INodeListSearchResult } from 'n8n-workflow'; import { createPool } from '../transport'; import type { MysqlNodeCredentials } from '../helpers/interfaces'; export async function searchTables(this: ILoadOptionsFunctions): Promise { const credentials = (await this.getCredentials('mySql')) as MysqlNodeCredentials; const nodeOptions = this.getNodeParameter('options', 0) as IDataObject; const pool = await createPool.call(this, credentials, nodeOptions); try { const connection = await pool.getConnection(); const query = 'SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = ?'; const values = [credentials.database as string]; const formatedQuery = connection.format(query, values); const response = (await connection.query(formatedQuery))[0]; connection.release(); const results = (response as IDataObject[]).map((table) => ({ name: (table.table_name as string) || (table.TABLE_NAME as string), value: (table.table_name as string) || (table.TABLE_NAME as string), })); return { results }; } finally { await pool.end(); } }