mirror of
https://github.com/n8n-io/n8n.git
synced 2024-12-25 04:34:06 -08:00
027dfb2f0a
* ⚡ Enable `esModuleInterop` for /core * ⚡ Adjust imports in /core * ⚡ Enable `esModuleInterop` for /cli * ⚡ Adjust imports in /cli * ⚡ Enable `esModuleInterop` for /nodes-base * ⚡ Adjust imports in /nodes-base * ⚡ Make imports consistent * ⬆️ Upgrade TypeScript to 4.6 (#3109) * ⬆️ Upgrade TypeScript to 4.6 * 📦 Update package-lock.json * 🔧 Avoid erroring on untyped errors * 📘 Fix type error Co-authored-by: Jan Oberhauser <jan.oberhauser@gmail.com>
65 lines
1.3 KiB
TypeScript
65 lines
1.3 KiB
TypeScript
import {
|
|
IDataObject,
|
|
INodeExecutionData,
|
|
} from 'n8n-workflow';
|
|
|
|
import snowflake from 'snowflake-sdk';
|
|
|
|
export function connect(conn: snowflake.Connection) {
|
|
return new Promise((resolve, reject) => {
|
|
conn.connect((err, conn) => {
|
|
if (!err) {
|
|
// @ts-ignore
|
|
resolve();
|
|
} else {
|
|
reject(err);
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
export function destroy(conn: snowflake.Connection) {
|
|
return new Promise((resolve, reject) => {
|
|
conn.destroy((err, conn) => {
|
|
if (!err) {
|
|
// @ts-ignore
|
|
resolve();
|
|
} else {
|
|
reject(err);
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
export function execute(conn: snowflake.Connection, sqlText: string, binds: snowflake.InsertBinds) {
|
|
return new Promise((resolve, reject) => {
|
|
conn.execute({
|
|
sqlText,
|
|
binds,
|
|
complete: (err, stmt, rows) => {
|
|
if (!err) {
|
|
resolve(rows);
|
|
} else {
|
|
reject(err);
|
|
}
|
|
},
|
|
});
|
|
});
|
|
}
|
|
|
|
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] = JSON.parse(JSON.stringify(item.json[property]));
|
|
}
|
|
}
|
|
return newItem;
|
|
});
|
|
}
|