n8n-nodes-base 0.221.0 → 0.223.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/build.tsbuildinfo +1 -1
- package/dist/credentials/GoogleApi.credentials.d.ts +2 -1
- package/dist/credentials/GoogleApi.credentials.js +85 -1
- package/dist/credentials/GoogleApi.credentials.js.map +1 -1
- package/dist/credentials/MySql.credentials.js +115 -0
- package/dist/credentials/MySql.credentials.js.map +1 -1
- package/dist/credentials/NocoDbApiToken.credentials.d.ts +2 -1
- package/dist/credentials/NocoDbApiToken.credentials.js +6 -0
- package/dist/credentials/NocoDbApiToken.credentials.js.map +1 -1
- package/dist/credentials/TotpApi.credentials.d.ts +7 -0
- package/dist/credentials/TotpApi.credentials.js +33 -0
- package/dist/credentials/TotpApi.credentials.js.map +1 -0
- package/dist/known/credentials.json +8 -0
- package/dist/known/nodes.json +4 -0
- package/dist/methods/defined.json +1037 -0
- package/dist/methods/referenced.json +1007 -0
- package/dist/nodes/Aws/S3/FileDescription.js +1 -1
- package/dist/nodes/Aws/S3/FileDescription.js.map +1 -1
- package/dist/nodes/Code/Code.node.js +13 -12
- package/dist/nodes/Code/Code.node.js.map +1 -1
- package/dist/nodes/Code/Sandbox.d.ts +14 -14
- package/dist/nodes/Code/Sandbox.js +35 -75
- package/dist/nodes/Code/Sandbox.js.map +1 -1
- package/dist/nodes/Code/utils.js +1 -1
- package/dist/nodes/Code/utils.js.map +1 -1
- package/dist/nodes/FreshworksCrm/descriptions/ContactDescription.js +0 -9
- package/dist/nodes/FreshworksCrm/descriptions/ContactDescription.js.map +1 -1
- package/dist/nodes/Github/GithubTrigger.node.js +0 -5
- package/dist/nodes/Github/GithubTrigger.node.js.map +1 -1
- package/dist/nodes/Gitlab/Gitlab.node.js +34 -3
- package/dist/nodes/Gitlab/Gitlab.node.js.map +1 -1
- package/dist/nodes/Google/Sheet/v2/transport/index.js +3 -2
- package/dist/nodes/Google/Sheet/v2/transport/index.js.map +1 -1
- package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js +1 -1
- package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js.map +1 -1
- package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js +1 -1
- package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js.map +1 -1
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js +15 -4
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js.map +1 -1
- package/dist/nodes/If/If.node.js +2 -2
- package/dist/nodes/If/If.node.js.map +1 -1
- package/dist/nodes/MySql/MySql.node.d.ts +3 -13
- package/dist/nodes/MySql/MySql.node.js +9 -325
- package/dist/nodes/MySql/MySql.node.js.map +1 -1
- package/dist/nodes/MySql/v1/GenericFunctions.js.map +1 -0
- package/dist/nodes/MySql/v1/MySqlV1.node.d.ts +16 -0
- package/dist/nodes/MySql/v1/MySqlV1.node.js +351 -0
- package/dist/nodes/MySql/v1/MySqlV1.node.js.map +1 -0
- package/dist/nodes/MySql/v2/MySqlV2.node.d.ts +13 -0
- package/dist/nodes/MySql/v2/MySqlV2.node.js +20 -0
- package/dist/nodes/MySql/v2/MySqlV2.node.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/common.descriptions.d.ts +6 -0
- package/dist/nodes/MySql/v2/actions/common.descriptions.js +341 -0
- package/dist/nodes/MySql/v2/actions/common.descriptions.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/Database.resource.d.ts +9 -0
- package/dist/nodes/MySql/v2/actions/database/Database.resource.js +102 -0
- package/dist/nodes/MySql/v2/actions/database/Database.resource.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.js +91 -0
- package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.js +64 -0
- package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/insert.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/insert.operation.js +175 -0
- package/dist/nodes/MySql/v2/actions/database/insert.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/select.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/select.operation.js +87 -0
- package/dist/nodes/MySql/v2/actions/database/select.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/update.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/update.operation.js +160 -0
- package/dist/nodes/MySql/v2/actions/database/update.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/database/upsert.operation.d.ts +24 -0
- package/dist/nodes/MySql/v2/actions/database/upsert.operation.js +161 -0
- package/dist/nodes/MySql/v2/actions/database/upsert.operation.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/node.type.d.ts +7 -0
- package/dist/nodes/MySql/v2/actions/node.type.js +3 -0
- package/dist/nodes/MySql/v2/actions/node.type.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/router.d.ts +3 -0
- package/dist/nodes/MySql/v2/actions/router.js +70 -0
- package/dist/nodes/MySql/v2/actions/router.js.map +1 -0
- package/dist/nodes/MySql/v2/actions/versionDescription.d.ts +2 -0
- package/dist/nodes/MySql/v2/actions/versionDescription.js +65 -0
- package/dist/nodes/MySql/v2/actions/versionDescription.js.map +1 -0
- package/dist/nodes/MySql/v2/helpers/interfaces.d.ts +35 -0
- package/dist/nodes/MySql/v2/helpers/interfaces.js +14 -0
- package/dist/nodes/MySql/v2/helpers/interfaces.js.map +1 -0
- package/dist/nodes/MySql/v2/helpers/utils.d.ts +18 -0
- package/dist/nodes/MySql/v2/helpers/utils.js +288 -0
- package/dist/nodes/MySql/v2/helpers/utils.js.map +1 -0
- package/dist/nodes/MySql/v2/methods/credentialTest.d.ts +2 -0
- package/dist/nodes/MySql/v2/methods/credentialTest.js +35 -0
- package/dist/nodes/MySql/v2/methods/credentialTest.js.map +1 -0
- package/dist/nodes/MySql/v2/methods/index.d.ts +3 -0
- package/dist/nodes/MySql/v2/methods/index.js +30 -0
- package/dist/nodes/MySql/v2/methods/index.js.map +1 -0
- package/dist/nodes/MySql/v2/methods/listSearch.d.ts +2 -0
- package/dist/nodes/MySql/v2/methods/listSearch.js +38 -0
- package/dist/nodes/MySql/v2/methods/listSearch.js.map +1 -0
- package/dist/nodes/MySql/v2/methods/loadOptions.d.ts +4 -0
- package/dist/nodes/MySql/v2/methods/loadOptions.js +50 -0
- package/dist/nodes/MySql/v2/methods/loadOptions.js.map +1 -0
- package/dist/nodes/MySql/v2/transport/index.d.ts +4 -0
- package/dist/nodes/MySql/v2/transport/index.js +102 -0
- package/dist/nodes/MySql/v2/transport/index.js.map +1 -0
- package/dist/nodes/NocoDB/NocoDB.node.js +12 -2
- package/dist/nodes/NocoDB/NocoDB.node.js.map +1 -1
- package/dist/nodes/NocoDB/OperationDescription.js +44 -30
- package/dist/nodes/NocoDB/OperationDescription.js.map +1 -1
- package/dist/nodes/OpenAi/ChatDescription.js +39 -26
- package/dist/nodes/OpenAi/ChatDescription.js.map +1 -1
- package/dist/nodes/OpenAi/TextDescription.js +2 -2
- package/dist/nodes/OpenAi/TextDescription.js.map +1 -1
- package/dist/nodes/Paddle/PaymentDescription.js +1 -1
- package/dist/nodes/Paddle/PaymentDescription.js.map +1 -1
- package/dist/nodes/Totp/Totp.node.d.ts +5 -0
- package/dist/nodes/Totp/Totp.node.js +157 -0
- package/dist/nodes/Totp/Totp.node.js.map +1 -0
- package/dist/nodes/Totp/Totp.node.json +16 -0
- package/dist/nodes/Totp/test/Totp.workflow.test.json +41 -0
- package/dist/nodes/Wait/test/Wait.workflow.json +162 -0
- package/dist/types/credentials.json +4 -3
- package/dist/types/nodes.json +15 -13
- package/package.json +10 -7
- package/dist/nodes/MySql/GenericFunctions.js.map +0 -1
- /package/dist/nodes/MySql/{GenericFunctions.d.ts → v1/GenericFunctions.d.ts} +0 -0
- /package/dist/nodes/MySql/{GenericFunctions.js → v1/GenericFunctions.js} +0 -0
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.replaceEmptyStringsByNulls = exports.addSortRules = exports.addWhereClauses = exports.configureQueryRunner = exports.prepareOutput = exports.wrapData = exports.parseMySqlError = exports.prepareErrorItem = exports.prepareQueryAndReplacements = exports.copyInputItems = void 0;
|
|
4
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
|
+
const interfaces_1 = require("./interfaces");
|
|
6
|
+
function copyInputItems(items, properties) {
|
|
7
|
+
let newItem;
|
|
8
|
+
return items.map((item) => {
|
|
9
|
+
newItem = {};
|
|
10
|
+
for (const property of properties) {
|
|
11
|
+
if (item.json[property] === undefined) {
|
|
12
|
+
newItem[property] = null;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
newItem[property] = (0, n8n_workflow_1.deepCopy)(item.json[property]);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return newItem;
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
exports.copyInputItems = copyInputItems;
|
|
22
|
+
const prepareQueryAndReplacements = (rawQuery, replacements) => {
|
|
23
|
+
if (replacements === undefined) {
|
|
24
|
+
return { query: rawQuery, values: [] };
|
|
25
|
+
}
|
|
26
|
+
let query = rawQuery;
|
|
27
|
+
const values = [];
|
|
28
|
+
const regex = /\$(\d+)(?::name)?/g;
|
|
29
|
+
const matches = rawQuery.match(regex) || [];
|
|
30
|
+
for (const match of matches) {
|
|
31
|
+
if (match.includes(':name')) {
|
|
32
|
+
const matchIndex = Number(match.replace('$', '').replace(':name', '')) - 1;
|
|
33
|
+
query = query.replace(match, `\`${replacements[matchIndex]}\``);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
const matchIndex = Number(match.replace('$', '')) - 1;
|
|
37
|
+
query = query.replace(match, '?');
|
|
38
|
+
values.push(replacements[matchIndex]);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return { query, values };
|
|
42
|
+
};
|
|
43
|
+
exports.prepareQueryAndReplacements = prepareQueryAndReplacements;
|
|
44
|
+
function prepareErrorItem(item, error, index) {
|
|
45
|
+
return {
|
|
46
|
+
json: { message: error.message, item: { ...item }, itemIndex: index, error: { ...error } },
|
|
47
|
+
pairedItem: { item: index },
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
exports.prepareErrorItem = prepareErrorItem;
|
|
51
|
+
function parseMySqlError(error, itemIndex = 0, queries) {
|
|
52
|
+
let message = error.message;
|
|
53
|
+
const description = `sql: ${error.sql}, code: ${error.code}`;
|
|
54
|
+
if ((queries === null || queries === void 0 ? void 0 : queries.length) &&
|
|
55
|
+
(message || '').toLowerCase().includes('you have an error in your sql syntax')) {
|
|
56
|
+
let queryIndex = itemIndex;
|
|
57
|
+
const failedStatement = ((message.split("near '")[1] || '').split("' at")[0] || '').split(';')[0];
|
|
58
|
+
if (failedStatement) {
|
|
59
|
+
if (queryIndex === 0 && queries.length > 1) {
|
|
60
|
+
const failedQueryIndex = queries.findIndex((query) => query.includes(failedStatement));
|
|
61
|
+
if (failedQueryIndex !== -1) {
|
|
62
|
+
queryIndex = failedQueryIndex;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
const lines = queries[queryIndex].split('\n');
|
|
66
|
+
const failedLine = lines.findIndex((line) => line.includes(failedStatement));
|
|
67
|
+
if (failedLine !== -1) {
|
|
68
|
+
message = `You have an error in your SQL syntax on line ${failedLine + 1} near '${failedStatement}'`;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
if ((error === null || error === void 0 ? void 0 : error.message).includes('ECONNREFUSED')) {
|
|
73
|
+
message = 'Connection refused';
|
|
74
|
+
}
|
|
75
|
+
return new n8n_workflow_1.NodeOperationError(this.getNode(), error, {
|
|
76
|
+
message,
|
|
77
|
+
description,
|
|
78
|
+
itemIndex,
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
exports.parseMySqlError = parseMySqlError;
|
|
82
|
+
function wrapData(data) {
|
|
83
|
+
if (!Array.isArray(data)) {
|
|
84
|
+
return [{ json: data }];
|
|
85
|
+
}
|
|
86
|
+
return data.map((item) => ({
|
|
87
|
+
json: item,
|
|
88
|
+
}));
|
|
89
|
+
}
|
|
90
|
+
exports.wrapData = wrapData;
|
|
91
|
+
function prepareOutput(response, options, statements, constructExecutionHelper) {
|
|
92
|
+
const returnData = [];
|
|
93
|
+
if (options.detailedOutput) {
|
|
94
|
+
response.forEach((entry, index) => {
|
|
95
|
+
const item = {
|
|
96
|
+
sql: statements[index],
|
|
97
|
+
data: entry,
|
|
98
|
+
};
|
|
99
|
+
const executionData = constructExecutionHelper(wrapData(item), {
|
|
100
|
+
itemData: { item: index },
|
|
101
|
+
});
|
|
102
|
+
returnData.push(...executionData);
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
response
|
|
107
|
+
.filter((entry) => Array.isArray(entry))
|
|
108
|
+
.forEach((entry, index) => {
|
|
109
|
+
const executionData = constructExecutionHelper(wrapData(entry), {
|
|
110
|
+
itemData: { item: index },
|
|
111
|
+
});
|
|
112
|
+
returnData.push(...executionData);
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
if (!returnData.length) {
|
|
116
|
+
returnData.push({ json: { success: true } });
|
|
117
|
+
}
|
|
118
|
+
return returnData;
|
|
119
|
+
}
|
|
120
|
+
exports.prepareOutput = prepareOutput;
|
|
121
|
+
function configureQueryRunner(options, pool) {
|
|
122
|
+
return async (queries) => {
|
|
123
|
+
if (queries.length === 0) {
|
|
124
|
+
return [];
|
|
125
|
+
}
|
|
126
|
+
const returnData = [];
|
|
127
|
+
const mode = options.queryBatching || interfaces_1.BATCH_MODE.SINGLE;
|
|
128
|
+
const connection = await pool.getConnection();
|
|
129
|
+
if (mode === interfaces_1.BATCH_MODE.SINGLE) {
|
|
130
|
+
const formatedQueries = queries.map(({ query, values }) => connection.format(query, values));
|
|
131
|
+
try {
|
|
132
|
+
connection.release();
|
|
133
|
+
let singleQuery = '';
|
|
134
|
+
if (formatedQueries.length > 1) {
|
|
135
|
+
singleQuery = formatedQueries.map((query) => query.trim().replace(/;$/, '')).join(';');
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
singleQuery = formatedQueries[0];
|
|
139
|
+
}
|
|
140
|
+
let response = (await pool.query(singleQuery))[0];
|
|
141
|
+
if (!response)
|
|
142
|
+
return [];
|
|
143
|
+
const statements = singleQuery
|
|
144
|
+
.replace(/\n/g, '')
|
|
145
|
+
.split(';')
|
|
146
|
+
.filter((statement) => statement !== '');
|
|
147
|
+
if (Array.isArray(response)) {
|
|
148
|
+
if (statements.length === 1)
|
|
149
|
+
response = [response];
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
response = [response];
|
|
153
|
+
}
|
|
154
|
+
returnData.push(...prepareOutput(response, options, statements, this.helpers.constructExecutionMetaData));
|
|
155
|
+
}
|
|
156
|
+
catch (err) {
|
|
157
|
+
const error = parseMySqlError.call(this, err, 0, formatedQueries);
|
|
158
|
+
if (!this.continueOnFail())
|
|
159
|
+
throw error;
|
|
160
|
+
returnData.push({ json: { message: error.message, error: { ...error } } });
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
else {
|
|
164
|
+
if (mode === interfaces_1.BATCH_MODE.INDEPENDENTLY) {
|
|
165
|
+
let formatedQuery = '';
|
|
166
|
+
for (const [index, queryWithValues] of queries.entries()) {
|
|
167
|
+
try {
|
|
168
|
+
const { query, values } = queryWithValues;
|
|
169
|
+
formatedQuery = connection.format(query, values);
|
|
170
|
+
const statements = formatedQuery.split(';').map((q) => q.trim());
|
|
171
|
+
const responses = [];
|
|
172
|
+
for (const statement of statements) {
|
|
173
|
+
if (statement === '')
|
|
174
|
+
continue;
|
|
175
|
+
const response = (await connection.query(statement))[0];
|
|
176
|
+
responses.push(response);
|
|
177
|
+
}
|
|
178
|
+
returnData.push(...prepareOutput(responses, options, statements, this.helpers.constructExecutionMetaData));
|
|
179
|
+
}
|
|
180
|
+
catch (err) {
|
|
181
|
+
const error = parseMySqlError.call(this, err, index, [formatedQuery]);
|
|
182
|
+
if (!this.continueOnFail()) {
|
|
183
|
+
connection.release();
|
|
184
|
+
throw error;
|
|
185
|
+
}
|
|
186
|
+
returnData.push(prepareErrorItem(queries[index], error, index));
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
if (mode === interfaces_1.BATCH_MODE.TRANSACTION) {
|
|
191
|
+
await connection.beginTransaction();
|
|
192
|
+
let formatedQuery = '';
|
|
193
|
+
for (const [index, queryWithValues] of queries.entries()) {
|
|
194
|
+
try {
|
|
195
|
+
const { query, values } = queryWithValues;
|
|
196
|
+
formatedQuery = connection.format(query, values);
|
|
197
|
+
const statements = formatedQuery.split(';').map((q) => q.trim());
|
|
198
|
+
const responses = [];
|
|
199
|
+
for (const statement of statements) {
|
|
200
|
+
if (statement === '')
|
|
201
|
+
continue;
|
|
202
|
+
const response = (await connection.query(statement))[0];
|
|
203
|
+
responses.push(response);
|
|
204
|
+
}
|
|
205
|
+
returnData.push(...prepareOutput(responses, options, statements, this.helpers.constructExecutionMetaData));
|
|
206
|
+
}
|
|
207
|
+
catch (err) {
|
|
208
|
+
const error = parseMySqlError.call(this, err, index, [formatedQuery]);
|
|
209
|
+
if (connection) {
|
|
210
|
+
await connection.rollback();
|
|
211
|
+
connection.release();
|
|
212
|
+
}
|
|
213
|
+
if (!this.continueOnFail())
|
|
214
|
+
throw error;
|
|
215
|
+
returnData.push(prepareErrorItem(queries[index], error, index));
|
|
216
|
+
return returnData;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
await connection.commit();
|
|
220
|
+
}
|
|
221
|
+
connection.release();
|
|
222
|
+
}
|
|
223
|
+
return returnData;
|
|
224
|
+
};
|
|
225
|
+
}
|
|
226
|
+
exports.configureQueryRunner = configureQueryRunner;
|
|
227
|
+
function addWhereClauses(node, itemIndex, query, clauses, replacements, combineConditions) {
|
|
228
|
+
if (clauses.length === 0)
|
|
229
|
+
return [query, replacements];
|
|
230
|
+
let combineWith = 'AND';
|
|
231
|
+
if (combineConditions === 'OR') {
|
|
232
|
+
combineWith = 'OR';
|
|
233
|
+
}
|
|
234
|
+
let whereQuery = ' WHERE';
|
|
235
|
+
const values = [];
|
|
236
|
+
clauses.forEach((clause, index) => {
|
|
237
|
+
if (clause.condition === 'equal') {
|
|
238
|
+
clause.condition = '=';
|
|
239
|
+
}
|
|
240
|
+
if (['>', '<', '>=', '<='].includes(clause.condition)) {
|
|
241
|
+
const value = Number(clause.value);
|
|
242
|
+
if (Number.isNaN(value)) {
|
|
243
|
+
throw new n8n_workflow_1.NodeOperationError(node, `Operator in entry ${index + 1} of 'Select Rows' works with numbers, but value ${clause.value} is not a number`, {
|
|
244
|
+
itemIndex,
|
|
245
|
+
});
|
|
246
|
+
}
|
|
247
|
+
clause.value = value;
|
|
248
|
+
}
|
|
249
|
+
let valueReplacement = ' ';
|
|
250
|
+
if (clause.condition !== 'IS NULL') {
|
|
251
|
+
valueReplacement = ' ?';
|
|
252
|
+
values.push(clause.value);
|
|
253
|
+
}
|
|
254
|
+
const operator = index === clauses.length - 1 ? '' : ` ${combineWith}`;
|
|
255
|
+
whereQuery += ` \`${clause.column}\` ${clause.condition}${valueReplacement}${operator}`;
|
|
256
|
+
});
|
|
257
|
+
return [`${query}${whereQuery}`, replacements.concat(...values)];
|
|
258
|
+
}
|
|
259
|
+
exports.addWhereClauses = addWhereClauses;
|
|
260
|
+
function addSortRules(query, rules, replacements) {
|
|
261
|
+
if (rules.length === 0)
|
|
262
|
+
return [query, replacements];
|
|
263
|
+
let orderByQuery = ' ORDER BY';
|
|
264
|
+
const values = [];
|
|
265
|
+
rules.forEach((rule, index) => {
|
|
266
|
+
const endWith = index === rules.length - 1 ? '' : ',';
|
|
267
|
+
orderByQuery += ` \`${rule.column}\` ${rule.direction}${endWith}`;
|
|
268
|
+
});
|
|
269
|
+
return [`${query}${orderByQuery}`, replacements.concat(...values)];
|
|
270
|
+
}
|
|
271
|
+
exports.addSortRules = addSortRules;
|
|
272
|
+
function replaceEmptyStringsByNulls(items, replace) {
|
|
273
|
+
if (!replace)
|
|
274
|
+
return [...items];
|
|
275
|
+
const returnData = items.map((item) => {
|
|
276
|
+
const newItem = { ...item };
|
|
277
|
+
const keys = Object.keys(newItem.json);
|
|
278
|
+
for (const key of keys) {
|
|
279
|
+
if (newItem.json[key] === '') {
|
|
280
|
+
newItem.json[key] = null;
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
return newItem;
|
|
284
|
+
});
|
|
285
|
+
return returnData;
|
|
286
|
+
}
|
|
287
|
+
exports.replaceEmptyStringsByNulls = replaceEmptyStringsByNulls;
|
|
288
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/helpers/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mysqlConnectionTest = void 0;
|
|
4
|
+
const transport_1 = require("../transport");
|
|
5
|
+
const ssh2_1 = require("ssh2");
|
|
6
|
+
async function mysqlConnectionTest(credential) {
|
|
7
|
+
const credentials = credential.data;
|
|
8
|
+
let sshClient = undefined;
|
|
9
|
+
if (credentials.sshTunnel) {
|
|
10
|
+
sshClient = new ssh2_1.Client();
|
|
11
|
+
}
|
|
12
|
+
const pool = await (0, transport_1.createPool)(credentials, {}, sshClient);
|
|
13
|
+
try {
|
|
14
|
+
const connection = await pool.getConnection();
|
|
15
|
+
connection.release();
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
return {
|
|
19
|
+
status: 'Error',
|
|
20
|
+
message: error.message,
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
finally {
|
|
24
|
+
if (sshClient) {
|
|
25
|
+
sshClient.end();
|
|
26
|
+
}
|
|
27
|
+
await pool.end();
|
|
28
|
+
}
|
|
29
|
+
return {
|
|
30
|
+
status: 'OK',
|
|
31
|
+
message: 'Connection successful!',
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
exports.mysqlConnectionTest = mysqlConnectionTest;
|
|
35
|
+
//# sourceMappingURL=credentialTest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentialTest.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/methods/credentialTest.ts"],"names":[],"mappings":";;;AAOA,4CAA0C;AAE1C,+BAA8B;AAEvB,KAAK,UAAU,mBAAmB,CAExC,UAAiC;IAEjC,MAAM,WAAW,GAAG,UAAU,CAAC,IAAsC,CAAC;IAEtE,IAAI,SAAS,GAAuB,SAAS,CAAC;IAE9C,IAAI,WAAW,CAAC,SAAS,EAAE;QAC1B,SAAS,GAAG,IAAI,aAAM,EAAE,CAAC;KACzB;IACD,MAAM,IAAI,GAAG,MAAM,IAAA,sBAAU,EAAC,WAAW,EAAE,EAAE,EAAE,SAAS,CAAC,CAAC;IAE1D,IAAI;QACH,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAC9C,UAAU,CAAC,OAAO,EAAE,CAAC;KACrB;IAAC,OAAO,KAAK,EAAE;QACf,OAAO;YACN,MAAM,EAAE,OAAO;YACf,OAAO,EAAE,KAAK,CAAC,OAAO;SACtB,CAAC;KACF;YAAS;QACT,IAAI,SAAS,EAAE;YACd,SAAS,CAAC,GAAG,EAAE,CAAC;SAChB;QACD,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC;KACjB;IAED,OAAO;QACN,MAAM,EAAE,IAAI;QACZ,OAAO,EAAE,wBAAwB;KACjC,CAAC;AACH,CAAC;AAhCD,kDAgCC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.loadOptions = exports.listSearch = exports.credentialTest = void 0;
|
|
27
|
+
exports.credentialTest = __importStar(require("./credentialTest"));
|
|
28
|
+
exports.listSearch = __importStar(require("./listSearch"));
|
|
29
|
+
exports.loadOptions = __importStar(require("./loadOptions"));
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/methods/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mEAAmD;AACnD,2DAA2C;AAC3C,6DAA6C"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.searchTables = void 0;
|
|
4
|
+
const transport_1 = require("../transport");
|
|
5
|
+
const ssh2_1 = require("ssh2");
|
|
6
|
+
async function searchTables() {
|
|
7
|
+
const credentials = await this.getCredentials('mySql');
|
|
8
|
+
const nodeOptions = this.getNodeParameter('options', 0);
|
|
9
|
+
let sshClient = undefined;
|
|
10
|
+
if (credentials.sshTunnel) {
|
|
11
|
+
sshClient = new ssh2_1.Client();
|
|
12
|
+
}
|
|
13
|
+
const pool = await (0, transport_1.createPool)(credentials, nodeOptions, sshClient);
|
|
14
|
+
try {
|
|
15
|
+
const connection = await pool.getConnection();
|
|
16
|
+
const query = 'SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE table_schema = ?';
|
|
17
|
+
const values = [credentials.database];
|
|
18
|
+
const formatedQuery = connection.format(query, values);
|
|
19
|
+
const response = (await connection.query(formatedQuery))[0];
|
|
20
|
+
connection.release();
|
|
21
|
+
const results = response.map((table) => ({
|
|
22
|
+
name: table.table_name || table.TABLE_NAME,
|
|
23
|
+
value: table.table_name || table.TABLE_NAME,
|
|
24
|
+
}));
|
|
25
|
+
return { results };
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
throw error;
|
|
29
|
+
}
|
|
30
|
+
finally {
|
|
31
|
+
if (sshClient) {
|
|
32
|
+
sshClient.end();
|
|
33
|
+
}
|
|
34
|
+
await pool.end();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.searchTables = searchTables;
|
|
38
|
+
//# sourceMappingURL=listSearch.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"listSearch.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/methods/listSearch.ts"],"names":[],"mappings":";;;AACA,4CAA0C;AAE1C,+BAA8B;AAEvB,KAAK,UAAU,YAAY;IACjC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IAEvD,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAgB,CAAC;IAEvE,IAAI,SAAS,GAAuB,SAAS,CAAC;IAE9C,IAAI,WAAW,CAAC,SAAS,EAAE;QAC1B,SAAS,GAAG,IAAI,aAAM,EAAE,CAAC;KACzB;IACD,MAAM,IAAI,GAAG,MAAM,IAAA,sBAAU,EAAC,WAAW,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;IAEnE,IAAI;QACH,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAE9C,MAAM,KAAK,GAAG,yEAAyE,CAAC;QACxF,MAAM,MAAM,GAAG,CAAC,WAAW,CAAC,QAAkB,CAAC,CAAC;QAEhD,MAAM,aAAa,GAAG,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAEvD,MAAM,QAAQ,GAAG,CAAC,MAAM,UAAU,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE5D,UAAU,CAAC,OAAO,EAAE,CAAC;QAErB,MAAM,OAAO,GAAI,QAA0B,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;YAC3D,IAAI,EAAG,KAAK,CAAC,UAAqB,IAAK,KAAK,CAAC,UAAqB;YAClE,KAAK,EAAG,KAAK,CAAC,UAAqB,IAAK,KAAK,CAAC,UAAqB;SACnE,CAAC,CAAC,CAAC;QAEJ,OAAO,EAAE,OAAO,EAAE,CAAC;KACnB;IAAC,OAAO,KAAK,EAAE;QACf,MAAM,KAAK,CAAC;KACZ;YAAS;QACT,IAAI,SAAS,EAAE;YACd,SAAS,CAAC,GAAG,EAAE,CAAC;SAChB;QACD,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC;KACjB;AACF,CAAC;AAtCD,oCAsCC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ILoadOptionsFunctions, INodePropertyOptions } from 'n8n-workflow';
|
|
2
|
+
export declare function getColumns(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]>;
|
|
3
|
+
export declare function getColumnsMultiOptions(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]>;
|
|
4
|
+
export declare function getColumnsWithoutColumnToMatchOn(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]>;
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getColumnsWithoutColumnToMatchOn = exports.getColumnsMultiOptions = exports.getColumns = void 0;
|
|
4
|
+
const transport_1 = require("../transport");
|
|
5
|
+
const ssh2_1 = require("ssh2");
|
|
6
|
+
async function getColumns() {
|
|
7
|
+
const credentials = await this.getCredentials('mySql');
|
|
8
|
+
const nodeOptions = this.getNodeParameter('options', 0);
|
|
9
|
+
let sshClient = undefined;
|
|
10
|
+
if (credentials.sshTunnel) {
|
|
11
|
+
sshClient = new ssh2_1.Client();
|
|
12
|
+
}
|
|
13
|
+
const pool = await (0, transport_1.createPool)(credentials, nodeOptions, sshClient);
|
|
14
|
+
try {
|
|
15
|
+
const connection = await pool.getConnection();
|
|
16
|
+
const table = this.getNodeParameter('table', 0, {
|
|
17
|
+
extractValue: true,
|
|
18
|
+
});
|
|
19
|
+
const columns = (await connection.query(`SHOW COLUMNS FROM \`${table}\` FROM \`${credentials.database}\``))[0];
|
|
20
|
+
connection.release();
|
|
21
|
+
return (columns || []).map((column) => ({
|
|
22
|
+
name: column.Field,
|
|
23
|
+
value: column.Field,
|
|
24
|
+
description: `type: ${column.Type.toUpperCase()}, nullable: ${column.Null}`,
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
throw error;
|
|
29
|
+
}
|
|
30
|
+
finally {
|
|
31
|
+
if (sshClient) {
|
|
32
|
+
sshClient.end();
|
|
33
|
+
}
|
|
34
|
+
await pool.end();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.getColumns = getColumns;
|
|
38
|
+
async function getColumnsMultiOptions() {
|
|
39
|
+
const returnData = await getColumns.call(this);
|
|
40
|
+
const returnAll = { name: '*', value: '*', description: 'All columns' };
|
|
41
|
+
return [returnAll, ...returnData];
|
|
42
|
+
}
|
|
43
|
+
exports.getColumnsMultiOptions = getColumnsMultiOptions;
|
|
44
|
+
async function getColumnsWithoutColumnToMatchOn() {
|
|
45
|
+
const columnToMatchOn = this.getNodeParameter('columnToMatchOn');
|
|
46
|
+
const returnData = await getColumns.call(this);
|
|
47
|
+
return returnData.filter((column) => column.value !== columnToMatchOn);
|
|
48
|
+
}
|
|
49
|
+
exports.getColumnsWithoutColumnToMatchOn = getColumnsWithoutColumnToMatchOn;
|
|
50
|
+
//# sourceMappingURL=loadOptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loadOptions.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/methods/loadOptions.ts"],"names":[],"mappings":";;;AACA,4CAA0C;AAE1C,+BAA8B;AAEvB,KAAK,UAAU,UAAU;IAC/B,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACvD,MAAM,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAgB,CAAC;IAEvE,IAAI,SAAS,GAAuB,SAAS,CAAC;IAE9C,IAAI,WAAW,CAAC,SAAS,EAAE;QAC1B,SAAS,GAAG,IAAI,aAAM,EAAE,CAAC;KACzB;IACD,MAAM,IAAI,GAAG,MAAM,IAAA,sBAAU,EAAC,WAAW,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;IAEnE,IAAI;QACH,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,aAAa,EAAE,CAAC;QAE9C,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,EAAE;YAC/C,YAAY,EAAE,IAAI;SAClB,CAAW,CAAC;QAEb,MAAM,OAAO,GAAG,CACf,MAAM,UAAU,CAAC,KAAK,CACrB,uBAAuB,KAAK,aAAa,WAAW,CAAC,QAAkB,IAAI,CAC3E,CACD,CAAC,CAAC,CAAkB,CAAC;QAEtB,UAAU,CAAC,OAAO,EAAE,CAAC;QAErB,OAAO,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,MAAmB,EAAE,EAAE,CAAC,CAAC;YACpD,IAAI,EAAE,MAAM,CAAC,KAAe;YAC5B,KAAK,EAAE,MAAM,CAAC,KAAe;YAE7B,WAAW,EAAE,SAAU,MAAM,CAAC,IAAe,CAAC,WAAW,EAAE,eAC1D,MAAM,CAAC,IACR,EAAE;SACF,CAAC,CAAC,CAAC;KACJ;IAAC,OAAO,KAAK,EAAE;QACf,MAAM,KAAK,CAAC;KACZ;YAAS;QACT,IAAI,SAAS,EAAE;YACd,SAAS,CAAC,GAAG,EAAE,CAAC;SAChB;QACD,MAAM,IAAI,CAAC,GAAG,EAAE,CAAC;KACjB;AACF,CAAC;AA1CD,gCA0CC;AAEM,KAAK,UAAU,sBAAsB;IAG3C,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,SAAS,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC;IACxE,OAAO,CAAC,SAAS,EAAE,GAAG,UAAU,CAAC,CAAC;AACnC,CAAC;AAND,wDAMC;AAEM,KAAK,UAAU,gCAAgC;IAGrD,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAW,CAAC;IAC3E,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,KAAK,eAAe,CAAC,CAAC;AACxE,CAAC;AAND,4EAMC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ICredentialDataDecryptedObject, IDataObject } from 'n8n-workflow';
|
|
2
|
+
import type { Client } from 'ssh2';
|
|
3
|
+
import type { Mysql2Pool } from '../helpers/interfaces';
|
|
4
|
+
export declare function createPool(credentials: ICredentialDataDecryptedObject, options?: IDataObject, sshClient?: Client): Promise<Mysql2Pool>;
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.createPool = void 0;
|
|
7
|
+
const promise_1 = __importDefault(require("mysql2/promise"));
|
|
8
|
+
const promises_1 = require("fs/promises");
|
|
9
|
+
const tmp_promise_1 = require("tmp-promise");
|
|
10
|
+
async function createSshConnectConfig(credentials) {
|
|
11
|
+
if (credentials.sshAuthenticateWith === 'password') {
|
|
12
|
+
return {
|
|
13
|
+
host: credentials.sshHost,
|
|
14
|
+
port: credentials.sshPort,
|
|
15
|
+
username: credentials.sshUser,
|
|
16
|
+
password: credentials.sshPassword,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
const { path } = await (0, tmp_promise_1.file)({ prefix: 'n8n-ssh-' });
|
|
21
|
+
await (0, promises_1.writeFile)(path, credentials.privateKey);
|
|
22
|
+
const options = {
|
|
23
|
+
host: credentials.host,
|
|
24
|
+
username: credentials.username,
|
|
25
|
+
port: credentials.port,
|
|
26
|
+
privateKey: path,
|
|
27
|
+
};
|
|
28
|
+
if (credentials.passphrase) {
|
|
29
|
+
options.passphrase = credentials.passphrase;
|
|
30
|
+
}
|
|
31
|
+
return options;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async function createPool(credentials, options, sshClient) {
|
|
35
|
+
if (credentials === undefined) {
|
|
36
|
+
throw new Error('Credentials not selected, select or add new credentials');
|
|
37
|
+
}
|
|
38
|
+
const { ssl, caCertificate, clientCertificate, clientPrivateKey, sshTunnel, sshHost, sshUser, sshPassword, sshPort, sshMysqlPort, privateKey, passphrase, sshAuthenticateWith, ...baseCredentials } = credentials;
|
|
39
|
+
if (ssl) {
|
|
40
|
+
baseCredentials.ssl = {};
|
|
41
|
+
if (caCertificate) {
|
|
42
|
+
baseCredentials.ssl.ca = caCertificate;
|
|
43
|
+
}
|
|
44
|
+
if (clientCertificate || clientPrivateKey) {
|
|
45
|
+
baseCredentials.ssl.cert = clientCertificate;
|
|
46
|
+
baseCredentials.ssl.key = clientPrivateKey;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
const connectionOptions = {
|
|
50
|
+
...baseCredentials,
|
|
51
|
+
multipleStatements: true,
|
|
52
|
+
supportBigNumbers: true,
|
|
53
|
+
};
|
|
54
|
+
if (options === null || options === void 0 ? void 0 : options.connectionLimit) {
|
|
55
|
+
connectionOptions.connectionLimit = options.connectionLimit;
|
|
56
|
+
}
|
|
57
|
+
if (options === null || options === void 0 ? void 0 : options.connectTimeout) {
|
|
58
|
+
connectionOptions.connectTimeout = options.connectTimeout;
|
|
59
|
+
}
|
|
60
|
+
if ((options === null || options === void 0 ? void 0 : options.largeNumbersOutput) === 'text') {
|
|
61
|
+
connectionOptions.bigNumberStrings = true;
|
|
62
|
+
}
|
|
63
|
+
if (!sshTunnel) {
|
|
64
|
+
return promise_1.default.createPool(connectionOptions);
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
if (!sshClient) {
|
|
68
|
+
throw new Error('SSH Tunnel is enabled but no SSH Client was provided');
|
|
69
|
+
}
|
|
70
|
+
const tunnelConfig = await createSshConnectConfig(credentials);
|
|
71
|
+
const forwardConfig = {
|
|
72
|
+
srcHost: '127.0.0.1',
|
|
73
|
+
srcPort: sshMysqlPort,
|
|
74
|
+
dstHost: credentials.host,
|
|
75
|
+
dstPort: credentials.port,
|
|
76
|
+
};
|
|
77
|
+
if (sshAuthenticateWith === 'privateKey') {
|
|
78
|
+
sshClient.on('end', async () => {
|
|
79
|
+
await (0, promises_1.rm)(tunnelConfig.privateKey);
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
const poolSetup = new Promise((resolve, reject) => {
|
|
83
|
+
sshClient
|
|
84
|
+
.on('ready', () => {
|
|
85
|
+
sshClient.forwardOut(forwardConfig.srcHost, forwardConfig.srcPort, forwardConfig.dstHost, forwardConfig.dstPort, (err, stream) => {
|
|
86
|
+
if (err)
|
|
87
|
+
reject(err);
|
|
88
|
+
const updatedDbServer = {
|
|
89
|
+
...connectionOptions,
|
|
90
|
+
stream,
|
|
91
|
+
};
|
|
92
|
+
const connection = promise_1.default.createPool(updatedDbServer);
|
|
93
|
+
resolve(connection);
|
|
94
|
+
});
|
|
95
|
+
})
|
|
96
|
+
.connect(tunnelConfig);
|
|
97
|
+
});
|
|
98
|
+
return poolSetup;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
exports.createPool = createPool;
|
|
102
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../nodes/MySql/v2/transport/index.ts"],"names":[],"mappings":"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"}
|