n8n-nodes-base 0.222.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.
Files changed (116) hide show
  1. package/dist/build.tsbuildinfo +1 -1
  2. package/dist/credentials/GoogleApi.credentials.d.ts +2 -1
  3. package/dist/credentials/GoogleApi.credentials.js +85 -1
  4. package/dist/credentials/GoogleApi.credentials.js.map +1 -1
  5. package/dist/credentials/MySql.credentials.js +115 -0
  6. package/dist/credentials/MySql.credentials.js.map +1 -1
  7. package/dist/credentials/NocoDbApiToken.credentials.d.ts +2 -1
  8. package/dist/credentials/NocoDbApiToken.credentials.js +6 -0
  9. package/dist/credentials/NocoDbApiToken.credentials.js.map +1 -1
  10. package/dist/known/credentials.json +1 -0
  11. package/dist/methods/defined.json +1037 -0
  12. package/dist/methods/referenced.json +1007 -0
  13. package/dist/nodes/Code/Code.node.js +13 -12
  14. package/dist/nodes/Code/Code.node.js.map +1 -1
  15. package/dist/nodes/Code/Sandbox.d.ts +14 -14
  16. package/dist/nodes/Code/Sandbox.js +35 -75
  17. package/dist/nodes/Code/Sandbox.js.map +1 -1
  18. package/dist/nodes/Code/utils.js +1 -1
  19. package/dist/nodes/Code/utils.js.map +1 -1
  20. package/dist/nodes/FreshworksCrm/descriptions/ContactDescription.js +0 -9
  21. package/dist/nodes/FreshworksCrm/descriptions/ContactDescription.js.map +1 -1
  22. package/dist/nodes/Github/GithubTrigger.node.js +0 -5
  23. package/dist/nodes/Github/GithubTrigger.node.js.map +1 -1
  24. package/dist/nodes/Gitlab/Gitlab.node.js +34 -3
  25. package/dist/nodes/Gitlab/Gitlab.node.js.map +1 -1
  26. package/dist/nodes/Google/Sheet/v2/transport/index.js +3 -2
  27. package/dist/nodes/Google/Sheet/v2/transport/index.js.map +1 -1
  28. package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js +1 -1
  29. package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js.map +1 -1
  30. package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js +1 -1
  31. package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js.map +1 -1
  32. package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js +15 -4
  33. package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js.map +1 -1
  34. package/dist/nodes/If/If.node.js +2 -2
  35. package/dist/nodes/If/If.node.js.map +1 -1
  36. package/dist/nodes/MySql/MySql.node.d.ts +3 -13
  37. package/dist/nodes/MySql/MySql.node.js +9 -325
  38. package/dist/nodes/MySql/MySql.node.js.map +1 -1
  39. package/dist/nodes/MySql/v1/GenericFunctions.js.map +1 -0
  40. package/dist/nodes/MySql/v1/MySqlV1.node.d.ts +16 -0
  41. package/dist/nodes/MySql/v1/MySqlV1.node.js +351 -0
  42. package/dist/nodes/MySql/v1/MySqlV1.node.js.map +1 -0
  43. package/dist/nodes/MySql/v2/MySqlV2.node.d.ts +13 -0
  44. package/dist/nodes/MySql/v2/MySqlV2.node.js +20 -0
  45. package/dist/nodes/MySql/v2/MySqlV2.node.js.map +1 -0
  46. package/dist/nodes/MySql/v2/actions/common.descriptions.d.ts +6 -0
  47. package/dist/nodes/MySql/v2/actions/common.descriptions.js +341 -0
  48. package/dist/nodes/MySql/v2/actions/common.descriptions.js.map +1 -0
  49. package/dist/nodes/MySql/v2/actions/database/Database.resource.d.ts +9 -0
  50. package/dist/nodes/MySql/v2/actions/database/Database.resource.js +102 -0
  51. package/dist/nodes/MySql/v2/actions/database/Database.resource.js.map +1 -0
  52. package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.d.ts +24 -0
  53. package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.js +91 -0
  54. package/dist/nodes/MySql/v2/actions/database/deleteTable.operation.js.map +1 -0
  55. package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.d.ts +24 -0
  56. package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.js +64 -0
  57. package/dist/nodes/MySql/v2/actions/database/executeQuery.operation.js.map +1 -0
  58. package/dist/nodes/MySql/v2/actions/database/insert.operation.d.ts +24 -0
  59. package/dist/nodes/MySql/v2/actions/database/insert.operation.js +175 -0
  60. package/dist/nodes/MySql/v2/actions/database/insert.operation.js.map +1 -0
  61. package/dist/nodes/MySql/v2/actions/database/select.operation.d.ts +24 -0
  62. package/dist/nodes/MySql/v2/actions/database/select.operation.js +87 -0
  63. package/dist/nodes/MySql/v2/actions/database/select.operation.js.map +1 -0
  64. package/dist/nodes/MySql/v2/actions/database/update.operation.d.ts +24 -0
  65. package/dist/nodes/MySql/v2/actions/database/update.operation.js +160 -0
  66. package/dist/nodes/MySql/v2/actions/database/update.operation.js.map +1 -0
  67. package/dist/nodes/MySql/v2/actions/database/upsert.operation.d.ts +24 -0
  68. package/dist/nodes/MySql/v2/actions/database/upsert.operation.js +161 -0
  69. package/dist/nodes/MySql/v2/actions/database/upsert.operation.js.map +1 -0
  70. package/dist/nodes/MySql/v2/actions/node.type.d.ts +7 -0
  71. package/dist/nodes/MySql/v2/actions/node.type.js +3 -0
  72. package/dist/nodes/MySql/v2/actions/node.type.js.map +1 -0
  73. package/dist/nodes/MySql/v2/actions/router.d.ts +3 -0
  74. package/dist/nodes/MySql/v2/actions/router.js +70 -0
  75. package/dist/nodes/MySql/v2/actions/router.js.map +1 -0
  76. package/dist/nodes/MySql/v2/actions/versionDescription.d.ts +2 -0
  77. package/dist/nodes/MySql/v2/actions/versionDescription.js +65 -0
  78. package/dist/nodes/MySql/v2/actions/versionDescription.js.map +1 -0
  79. package/dist/nodes/MySql/v2/helpers/interfaces.d.ts +35 -0
  80. package/dist/nodes/MySql/v2/helpers/interfaces.js +14 -0
  81. package/dist/nodes/MySql/v2/helpers/interfaces.js.map +1 -0
  82. package/dist/nodes/MySql/v2/helpers/utils.d.ts +18 -0
  83. package/dist/nodes/MySql/v2/helpers/utils.js +288 -0
  84. package/dist/nodes/MySql/v2/helpers/utils.js.map +1 -0
  85. package/dist/nodes/MySql/v2/methods/credentialTest.d.ts +2 -0
  86. package/dist/nodes/MySql/v2/methods/credentialTest.js +35 -0
  87. package/dist/nodes/MySql/v2/methods/credentialTest.js.map +1 -0
  88. package/dist/nodes/MySql/v2/methods/index.d.ts +3 -0
  89. package/dist/nodes/MySql/v2/methods/index.js +30 -0
  90. package/dist/nodes/MySql/v2/methods/index.js.map +1 -0
  91. package/dist/nodes/MySql/v2/methods/listSearch.d.ts +2 -0
  92. package/dist/nodes/MySql/v2/methods/listSearch.js +38 -0
  93. package/dist/nodes/MySql/v2/methods/listSearch.js.map +1 -0
  94. package/dist/nodes/MySql/v2/methods/loadOptions.d.ts +4 -0
  95. package/dist/nodes/MySql/v2/methods/loadOptions.js +50 -0
  96. package/dist/nodes/MySql/v2/methods/loadOptions.js.map +1 -0
  97. package/dist/nodes/MySql/v2/transport/index.d.ts +4 -0
  98. package/dist/nodes/MySql/v2/transport/index.js +102 -0
  99. package/dist/nodes/MySql/v2/transport/index.js.map +1 -0
  100. package/dist/nodes/NocoDB/NocoDB.node.js +12 -2
  101. package/dist/nodes/NocoDB/NocoDB.node.js.map +1 -1
  102. package/dist/nodes/NocoDB/OperationDescription.js +44 -30
  103. package/dist/nodes/NocoDB/OperationDescription.js.map +1 -1
  104. package/dist/nodes/OpenAi/ChatDescription.js +39 -26
  105. package/dist/nodes/OpenAi/ChatDescription.js.map +1 -1
  106. package/dist/nodes/OpenAi/TextDescription.js +2 -2
  107. package/dist/nodes/OpenAi/TextDescription.js.map +1 -1
  108. package/dist/nodes/Paddle/PaymentDescription.js +1 -1
  109. package/dist/nodes/Paddle/PaymentDescription.js.map +1 -1
  110. package/dist/nodes/Wait/test/Wait.workflow.json +162 -0
  111. package/dist/types/credentials.json +3 -3
  112. package/dist/types/nodes.json +12 -11
  113. package/package.json +4 -4
  114. package/dist/nodes/MySql/GenericFunctions.js.map +0 -1
  115. /package/dist/nodes/MySql/{GenericFunctions.d.ts → v1/GenericFunctions.d.ts} +0 -0
  116. /package/dist/nodes/MySql/{GenericFunctions.js → v1/GenericFunctions.js} +0 -0
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.execute = exports.description = void 0;
4
+ const n8n_workflow_1 = require("n8n-workflow");
5
+ const utilities_1 = require("../../../../../utils/utilities");
6
+ const utils_1 = require("../../helpers/utils");
7
+ const common_descriptions_1 = require("../common.descriptions");
8
+ const properties = [
9
+ {
10
+ displayName: 'Query',
11
+ name: 'query',
12
+ type: 'string',
13
+ default: '',
14
+ placeholder: 'e.g. SELECT id, name FROM product WHERE id < 40',
15
+ required: true,
16
+ description: "The SQL query to execute. You can use n8n expressions and $1, $2, $3, etc to refer to the 'Query Parameters' set in options below.",
17
+ typeOptions: {
18
+ rows: 3,
19
+ },
20
+ hint: 'Prefer using query parameters over n8n expressions to avoid SQL injection attacks',
21
+ },
22
+ {
23
+ displayName: `
24
+ To use query parameters in your SQL query, reference them as $1, $2, $3, etc in the corresponding order. <a target="_blank" href="https://docs.n8n.io/integrations/builtin/app-nodes/n8n-nodes-base.mysql/">More info</a>.
25
+ `,
26
+ name: 'notice',
27
+ type: 'notice',
28
+ default: '',
29
+ },
30
+ common_descriptions_1.optionsCollection,
31
+ ];
32
+ const displayOptions = {
33
+ show: {
34
+ resource: ['database'],
35
+ operation: ['executeQuery'],
36
+ },
37
+ };
38
+ exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
39
+ async function execute(inputItems, runQueries, nodeOptions) {
40
+ let returnData = [];
41
+ const items = (0, utils_1.replaceEmptyStringsByNulls)(inputItems, nodeOptions.replaceEmptyStrings);
42
+ const queries = [];
43
+ for (let i = 0; i < items.length; i++) {
44
+ const rawQuery = this.getNodeParameter('query', i);
45
+ const options = this.getNodeParameter('options', i, {});
46
+ let values;
47
+ let queryReplacement = options.queryReplacement || [];
48
+ if (typeof queryReplacement === 'string') {
49
+ queryReplacement = queryReplacement.split(',').map((entry) => entry.trim());
50
+ }
51
+ if (Array.isArray(queryReplacement)) {
52
+ values = queryReplacement;
53
+ }
54
+ else {
55
+ throw new n8n_workflow_1.NodeOperationError(this.getNode(), 'Query Replacement must be a string of comma-separated values, or an array of values', { itemIndex: i });
56
+ }
57
+ const preparedQuery = (0, utils_1.prepareQueryAndReplacements)(rawQuery, values);
58
+ queries.push(preparedQuery);
59
+ }
60
+ returnData = await runQueries(queries);
61
+ return returnData;
62
+ }
63
+ exports.execute = execute;
64
+ //# sourceMappingURL=executeQuery.operation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executeQuery.operation.js","sourceRoot":"","sources":["../../../../../../nodes/MySql/v2/actions/database/executeQuery.operation.ts"],"names":[],"mappings":";;;AAEA,+CAAkD;AAIlD,8DAAsE;AAEtE,+CAA8F;AAE9F,gEAA2D;AAE3D,MAAM,UAAU,GAAsB;IACrC;QACC,WAAW,EAAE,OAAO;QACpB,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE;QACX,WAAW,EAAE,iDAAiD;QAC9D,QAAQ,EAAE,IAAI;QACd,WAAW,EACV,oIAAoI;QACrI,WAAW,EAAE;YACZ,IAAI,EAAE,CAAC;SACP;QACD,IAAI,EAAE,mFAAmF;KACzF;IACD;QACC,WAAW,EAAE;;GAEZ;QACD,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,EAAE;KACX;IACD,uCAAiB;CACjB,CAAC;AAEF,MAAM,cAAc,GAAG;IACtB,IAAI,EAAE;QACL,QAAQ,EAAE,CAAC,UAAU,CAAC;QACtB,SAAS,EAAE,CAAC,cAAc,CAAC;KAC3B;CACD,CAAC;AAEW,QAAA,WAAW,GAAG,IAAA,gCAAoB,EAAC,cAAc,EAAE,UAAU,CAAC,CAAC;AAErE,KAAK,UAAU,OAAO,CAE5B,UAAgC,EAChC,UAAuB,EACvB,WAAwB;IAExB,IAAI,UAAU,GAAyB,EAAE,CAAC;IAC1C,MAAM,KAAK,GAAG,IAAA,kCAA0B,EAAC,UAAU,EAAE,WAAW,CAAC,mBAA8B,CAAC,CAAC;IAEjG,MAAM,OAAO,GAAsB,EAAE,CAAC;IAEtC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAW,CAAC;QAE7D,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAExD,IAAI,MAAM,CAAC;QACX,IAAI,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,EAAE,CAAC;QAEtD,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE;YACzC,gBAAgB,GAAG,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;SAC5E;QAED,IAAI,KAAK,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE;YACpC,MAAM,GAAG,gBAAiC,CAAC;SAC3C;aAAM;YACN,MAAM,IAAI,iCAAkB,CAC3B,IAAI,CAAC,OAAO,EAAE,EACd,qFAAqF,EACrF,EAAE,SAAS,EAAE,CAAC,EAAE,CAChB,CAAC;SACF;QAED,MAAM,aAAa,GAAG,IAAA,mCAA2B,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEpE,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;KAC5B;IAED,UAAU,GAAG,MAAM,UAAU,CAAC,OAAO,CAAC,CAAC;IAEvC,OAAO,UAAU,CAAC;AACnB,CAAC;AAzCD,0BAyCC"}
@@ -0,0 +1,24 @@
1
+ import type { IExecuteFunctions } from 'n8n-core';
2
+ import type { IDataObject, INodeExecutionData, INodeProperties } from 'n8n-workflow';
3
+ import type { QueryRunner } from '../../helpers/interfaces';
4
+ export declare const description: {
5
+ displayOptions: import("n8n-workflow").IDisplayOptions;
6
+ displayName: string;
7
+ name: string;
8
+ type: import("n8n-workflow").NodePropertyTypes;
9
+ typeOptions?: import("n8n-workflow").INodePropertyTypeOptions | undefined;
10
+ default: import("n8n-workflow").NodeParameterValueType;
11
+ description?: string | undefined;
12
+ hint?: string | undefined;
13
+ options?: (INodeProperties | import("n8n-workflow").INodePropertyOptions | import("n8n-workflow").INodePropertyCollection)[] | undefined;
14
+ placeholder?: string | undefined;
15
+ isNodeSetting?: boolean | undefined;
16
+ noDataExpression?: boolean | undefined;
17
+ required?: boolean | undefined;
18
+ routing?: import("n8n-workflow").INodePropertyRouting | undefined;
19
+ credentialTypes?: ("extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth")[] | undefined;
20
+ extractValue?: import("n8n-workflow").INodePropertyValueExtractorRegex | undefined;
21
+ modes?: import("n8n-workflow").INodePropertyMode[] | undefined;
22
+ requiresDataPath?: "single" | "multiple" | undefined;
23
+ }[];
24
+ export declare function execute(this: IExecuteFunctions, inputItems: INodeExecutionData[], runQueries: QueryRunner, nodeOptions: IDataObject): Promise<INodeExecutionData[]>;
@@ -0,0 +1,175 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.execute = exports.description = void 0;
4
+ const interfaces_1 = require("../../helpers/interfaces");
5
+ const utilities_1 = require("../../../../../utils/utilities");
6
+ const utils_1 = require("../../helpers/utils");
7
+ const common_descriptions_1 = require("../common.descriptions");
8
+ const properties = [
9
+ {
10
+ displayName: 'Data Mode',
11
+ name: 'dataMode',
12
+ type: 'options',
13
+ options: [
14
+ {
15
+ name: 'Auto-Map Input Data to Columns',
16
+ value: interfaces_1.DATA_MODE.AUTO_MAP,
17
+ description: 'Use when node input properties names exactly match the table column names',
18
+ },
19
+ {
20
+ name: 'Map Each Column Manually',
21
+ value: interfaces_1.DATA_MODE.MANUAL,
22
+ description: 'Set the value for each destination column manually',
23
+ },
24
+ ],
25
+ default: interfaces_1.AUTO_MAP,
26
+ description: 'Whether to map node input properties and the table data automatically or manually',
27
+ },
28
+ {
29
+ displayName: `
30
+ In this mode, make sure incoming data fields are named the same as the columns in your table. If needed, use a 'Set' node before this node to change the field names.
31
+ `,
32
+ name: 'notice',
33
+ type: 'notice',
34
+ default: '',
35
+ displayOptions: {
36
+ show: {
37
+ dataMode: [interfaces_1.DATA_MODE.AUTO_MAP],
38
+ },
39
+ },
40
+ },
41
+ {
42
+ displayName: 'Values to Send',
43
+ name: 'valuesToSend',
44
+ placeholder: 'Add Value',
45
+ type: 'fixedCollection',
46
+ typeOptions: {
47
+ multipleValueButtonText: 'Add Value',
48
+ multipleValues: true,
49
+ },
50
+ displayOptions: {
51
+ show: {
52
+ dataMode: [interfaces_1.DATA_MODE.MANUAL],
53
+ },
54
+ },
55
+ default: {},
56
+ options: [
57
+ {
58
+ displayName: 'Values',
59
+ name: 'values',
60
+ values: [
61
+ {
62
+ displayName: 'Column',
63
+ name: 'column',
64
+ type: 'options',
65
+ description: 'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
66
+ typeOptions: {
67
+ loadOptionsMethod: 'getColumns',
68
+ loadOptionsDependsOn: ['table.value'],
69
+ },
70
+ default: [],
71
+ },
72
+ {
73
+ displayName: 'Value',
74
+ name: 'value',
75
+ type: 'string',
76
+ default: '',
77
+ },
78
+ ],
79
+ },
80
+ ],
81
+ },
82
+ common_descriptions_1.optionsCollection,
83
+ ];
84
+ const displayOptions = {
85
+ show: {
86
+ resource: ['database'],
87
+ operation: ['insert'],
88
+ },
89
+ hide: {
90
+ table: [''],
91
+ },
92
+ };
93
+ exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
94
+ async function execute(inputItems, runQueries, nodeOptions) {
95
+ let returnData = [];
96
+ const items = (0, utils_1.replaceEmptyStringsByNulls)(inputItems, nodeOptions.replaceEmptyStrings);
97
+ const table = this.getNodeParameter('table', 0, '', { extractValue: true });
98
+ const dataMode = this.getNodeParameter('dataMode', 0);
99
+ const queryBatching = nodeOptions.queryBatching || interfaces_1.BATCH_MODE.SINGLE;
100
+ const queries = [];
101
+ if (queryBatching === interfaces_1.BATCH_MODE.SINGLE) {
102
+ let columns = [];
103
+ let insertItems = [];
104
+ const priority = nodeOptions.priority || '';
105
+ const ignore = nodeOptions.skipOnConflict ? 'IGNORE' : '';
106
+ if (dataMode === interfaces_1.DATA_MODE.AUTO_MAP) {
107
+ columns = [
108
+ ...new Set(items.reduce((acc, item) => {
109
+ const itemColumns = Object.keys(item.json);
110
+ return acc.concat(itemColumns);
111
+ }, [])),
112
+ ];
113
+ insertItems = (0, utils_1.copyInputItems)(items, columns);
114
+ }
115
+ if (dataMode === interfaces_1.DATA_MODE.MANUAL) {
116
+ for (let i = 0; i < items.length; i++) {
117
+ const valuesToSend = this.getNodeParameter('valuesToSend', i, [])
118
+ .values;
119
+ const item = valuesToSend.reduce((acc, { column, value }) => {
120
+ acc[column] = value;
121
+ return acc;
122
+ }, {});
123
+ insertItems.push(item);
124
+ }
125
+ columns = [
126
+ ...new Set(insertItems.reduce((acc, item) => {
127
+ const itemColumns = Object.keys(item);
128
+ return acc.concat(itemColumns);
129
+ }, [])),
130
+ ];
131
+ }
132
+ const escapedColumns = columns.map((column) => `\`${column}\``).join(', ');
133
+ const placeholder = `(${columns.map(() => '?').join(',')})`;
134
+ const replacements = items.map(() => placeholder).join(',');
135
+ const query = `INSERT ${priority} ${ignore} INTO \`${table}\` (${escapedColumns}) VALUES ${replacements}`;
136
+ const values = insertItems.reduce((acc, item) => acc.concat(Object.values(item)), []);
137
+ queries.push({ query, values });
138
+ }
139
+ else {
140
+ for (let i = 0; i < items.length; i++) {
141
+ let columns = [];
142
+ let insertItem = {};
143
+ const options = this.getNodeParameter('options', i);
144
+ const priority = options.priority || '';
145
+ const ignore = options.skipOnConflict ? 'IGNORE' : '';
146
+ if (dataMode === interfaces_1.DATA_MODE.AUTO_MAP) {
147
+ columns = Object.keys(items[i].json);
148
+ insertItem = columns.reduce((acc, key) => {
149
+ if (columns.includes(key)) {
150
+ acc[key] = items[i].json[key];
151
+ }
152
+ return acc;
153
+ }, {});
154
+ }
155
+ if (dataMode === interfaces_1.DATA_MODE.MANUAL) {
156
+ const valuesToSend = this.getNodeParameter('valuesToSend', i, [])
157
+ .values;
158
+ insertItem = valuesToSend.reduce((acc, { column, value }) => {
159
+ acc[column] = value;
160
+ return acc;
161
+ }, {});
162
+ columns = Object.keys(insertItem);
163
+ }
164
+ const escapedColumns = columns.map((column) => `\`${column}\``).join(', ');
165
+ const placeholder = `(${columns.map(() => '?').join(',')})`;
166
+ const query = `INSERT ${priority} ${ignore} INTO \`${table}\` (${escapedColumns}) VALUES ${placeholder};`;
167
+ const values = Object.values(insertItem);
168
+ queries.push({ query, values });
169
+ }
170
+ }
171
+ returnData = await runQueries(queries);
172
+ return returnData;
173
+ }
174
+ exports.execute = execute;
175
+ //# sourceMappingURL=insert.operation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"insert.operation.js","sourceRoot":"","sources":["../../../../../../nodes/MySql/v2/actions/database/insert.operation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { IExecuteFunctions } from 'n8n-core';
2
+ import type { INodeExecutionData, INodeProperties } from 'n8n-workflow';
3
+ import type { QueryRunner } from '../../helpers/interfaces';
4
+ export declare const description: {
5
+ displayOptions: import("n8n-workflow").IDisplayOptions;
6
+ displayName: string;
7
+ name: string;
8
+ type: import("n8n-workflow").NodePropertyTypes;
9
+ typeOptions?: import("n8n-workflow").INodePropertyTypeOptions | undefined;
10
+ default: import("n8n-workflow").NodeParameterValueType;
11
+ description?: string | undefined;
12
+ hint?: string | undefined;
13
+ options?: (INodeProperties | import("n8n-workflow").INodePropertyOptions | import("n8n-workflow").INodePropertyCollection)[] | undefined;
14
+ placeholder?: string | undefined;
15
+ isNodeSetting?: boolean | undefined;
16
+ noDataExpression?: boolean | undefined;
17
+ required?: boolean | undefined;
18
+ routing?: import("n8n-workflow").INodePropertyRouting | undefined;
19
+ credentialTypes?: ("extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth")[] | undefined;
20
+ extractValue?: import("n8n-workflow").INodePropertyValueExtractorRegex | undefined;
21
+ modes?: import("n8n-workflow").INodePropertyMode[] | undefined;
22
+ requiresDataPath?: "single" | "multiple" | undefined;
23
+ }[];
24
+ export declare function execute(this: IExecuteFunctions, inputItems: INodeExecutionData[], runQueries: QueryRunner): Promise<INodeExecutionData[]>;
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.execute = exports.description = void 0;
4
+ const utilities_1 = require("../../../../../utils/utilities");
5
+ const utils_1 = require("../../helpers/utils");
6
+ const common_descriptions_1 = require("../common.descriptions");
7
+ const properties = [
8
+ {
9
+ displayName: 'Return All',
10
+ name: 'returnAll',
11
+ type: 'boolean',
12
+ default: false,
13
+ description: 'Whether to return all results or only up to a given limit',
14
+ displayOptions: {
15
+ show: {
16
+ resource: ['event'],
17
+ operation: ['getAll'],
18
+ },
19
+ },
20
+ },
21
+ {
22
+ displayName: 'Limit',
23
+ name: 'limit',
24
+ type: 'number',
25
+ default: 50,
26
+ description: 'Max number of results to return',
27
+ typeOptions: {
28
+ minValue: 1,
29
+ },
30
+ displayOptions: {
31
+ show: {
32
+ returnAll: [false],
33
+ },
34
+ },
35
+ },
36
+ common_descriptions_1.selectRowsFixedCollection,
37
+ common_descriptions_1.combineConditionsCollection,
38
+ common_descriptions_1.sortFixedCollection,
39
+ common_descriptions_1.optionsCollection,
40
+ ];
41
+ const displayOptions = {
42
+ show: {
43
+ resource: ['database'],
44
+ operation: ['select'],
45
+ },
46
+ hide: {
47
+ table: [''],
48
+ },
49
+ };
50
+ exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
51
+ async function execute(inputItems, runQueries) {
52
+ let returnData = [];
53
+ const queries = [];
54
+ for (let i = 0; i < inputItems.length; i++) {
55
+ const table = this.getNodeParameter('table', i, undefined, {
56
+ extractValue: true,
57
+ });
58
+ const outputColumns = this.getNodeParameter('options.outputColumns', i, ['*']);
59
+ const selectDistinct = this.getNodeParameter('options.selectDistinct', i, false);
60
+ let query = '';
61
+ const SELECT = selectDistinct ? 'SELECT DISTINCT' : 'SELECT';
62
+ if (outputColumns.includes('*')) {
63
+ query = `${SELECT} * FROM \`${table}\``;
64
+ }
65
+ else {
66
+ const escapedColumns = outputColumns.map((column) => `\`${column}\``).join(', ');
67
+ query = `${SELECT} ${escapedColumns} FROM \`${table}\``;
68
+ }
69
+ let values = [];
70
+ const whereClauses = this.getNodeParameter('where', i, []).values || [];
71
+ const combineConditions = this.getNodeParameter('combineConditions', i, 'AND');
72
+ [query, values] = (0, utils_1.addWhereClauses)(this.getNode(), i, query, whereClauses, values, combineConditions);
73
+ const sortRules = this.getNodeParameter('sort', i, []).values || [];
74
+ [query, values] = (0, utils_1.addSortRules)(query, sortRules, values);
75
+ const returnAll = this.getNodeParameter('returnAll', i, false);
76
+ if (!returnAll) {
77
+ const limit = this.getNodeParameter('limit', i, 50);
78
+ query += ' LIMIT ?';
79
+ values.push(limit);
80
+ }
81
+ queries.push({ query, values });
82
+ }
83
+ returnData = await runQueries(queries);
84
+ return returnData;
85
+ }
86
+ exports.execute = execute;
87
+ //# sourceMappingURL=select.operation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.operation.js","sourceRoot":"","sources":["../../../../../../nodes/MySql/v2/actions/database/select.operation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { IExecuteFunctions } from 'n8n-core';
2
+ import type { IDataObject, INodeExecutionData, INodeProperties } from 'n8n-workflow';
3
+ import type { QueryRunner } from '../../helpers/interfaces';
4
+ export declare const description: {
5
+ displayOptions: import("n8n-workflow").IDisplayOptions;
6
+ displayName: string;
7
+ name: string;
8
+ type: import("n8n-workflow").NodePropertyTypes;
9
+ typeOptions?: import("n8n-workflow").INodePropertyTypeOptions | undefined;
10
+ default: import("n8n-workflow").NodeParameterValueType;
11
+ description?: string | undefined;
12
+ hint?: string | undefined;
13
+ options?: (INodeProperties | import("n8n-workflow").INodePropertyOptions | import("n8n-workflow").INodePropertyCollection)[] | undefined;
14
+ placeholder?: string | undefined;
15
+ isNodeSetting?: boolean | undefined;
16
+ noDataExpression?: boolean | undefined;
17
+ required?: boolean | undefined;
18
+ routing?: import("n8n-workflow").INodePropertyRouting | undefined;
19
+ credentialTypes?: ("extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth")[] | undefined;
20
+ extractValue?: import("n8n-workflow").INodePropertyValueExtractorRegex | undefined;
21
+ modes?: import("n8n-workflow").INodePropertyMode[] | undefined;
22
+ requiresDataPath?: "single" | "multiple" | undefined;
23
+ }[];
24
+ export declare function execute(this: IExecuteFunctions, inputItems: INodeExecutionData[], runQueries: QueryRunner, nodeOptions: IDataObject): Promise<INodeExecutionData[]>;
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.execute = exports.description = void 0;
4
+ const interfaces_1 = require("../../helpers/interfaces");
5
+ const utilities_1 = require("../../../../../utils/utilities");
6
+ const utils_1 = require("../../helpers/utils");
7
+ const common_descriptions_1 = require("../common.descriptions");
8
+ const properties = [
9
+ {
10
+ displayName: 'Data Mode',
11
+ name: 'dataMode',
12
+ type: 'options',
13
+ options: [
14
+ {
15
+ name: 'Auto-Map Input Data to Columns',
16
+ value: interfaces_1.DATA_MODE.AUTO_MAP,
17
+ description: 'Use when node input properties names exactly match the table column names',
18
+ },
19
+ {
20
+ name: 'Map Each Column Below',
21
+ value: interfaces_1.DATA_MODE.MANUAL,
22
+ description: 'Set the value for each destination column manually',
23
+ },
24
+ ],
25
+ default: interfaces_1.AUTO_MAP,
26
+ description: 'Whether to map node input properties and the table data automatically or manually',
27
+ },
28
+ {
29
+ displayName: `
30
+ In this mode, make sure incoming data fields are named the same as the columns in your table. If needed, use a 'Set' node before this node to change the field names.
31
+ `,
32
+ name: 'notice',
33
+ type: 'notice',
34
+ default: '',
35
+ displayOptions: {
36
+ show: {
37
+ dataMode: [interfaces_1.DATA_MODE.AUTO_MAP],
38
+ },
39
+ },
40
+ },
41
+ {
42
+ displayName: 'Column to Match On',
43
+ name: 'columnToMatchOn',
44
+ type: 'options',
45
+ required: true,
46
+ description: 'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
47
+ typeOptions: {
48
+ loadOptionsMethod: 'getColumns',
49
+ loadOptionsDependsOn: ['schema.value', 'table.value'],
50
+ },
51
+ default: '',
52
+ hint: "Used to find the correct row to update. Doesn't get changed.",
53
+ },
54
+ {
55
+ displayName: 'Value of Column to Match On',
56
+ name: 'valueToMatchOn',
57
+ type: 'string',
58
+ default: '',
59
+ description: 'Rows with a value in the specified "Column to Match On" that corresponds to the value in this field will be updated',
60
+ displayOptions: {
61
+ show: {
62
+ dataMode: [interfaces_1.DATA_MODE.MANUAL],
63
+ },
64
+ },
65
+ },
66
+ {
67
+ displayName: 'Values to Send',
68
+ name: 'valuesToSend',
69
+ placeholder: 'Add Value',
70
+ type: 'fixedCollection',
71
+ typeOptions: {
72
+ multipleValueButtonText: 'Add Value',
73
+ multipleValues: true,
74
+ },
75
+ displayOptions: {
76
+ show: {
77
+ dataMode: [interfaces_1.DATA_MODE.MANUAL],
78
+ },
79
+ },
80
+ default: {},
81
+ options: [
82
+ {
83
+ displayName: 'Values',
84
+ name: 'values',
85
+ values: [
86
+ {
87
+ displayName: 'Column',
88
+ name: 'column',
89
+ type: 'options',
90
+ description: 'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
91
+ typeOptions: {
92
+ loadOptionsMethod: 'getColumnsWithoutColumnToMatchOn',
93
+ loadOptionsDependsOn: ['schema.value', 'table.value'],
94
+ },
95
+ default: [],
96
+ },
97
+ {
98
+ displayName: 'Value',
99
+ name: 'value',
100
+ type: 'string',
101
+ default: '',
102
+ },
103
+ ],
104
+ },
105
+ ],
106
+ },
107
+ common_descriptions_1.optionsCollection,
108
+ ];
109
+ const displayOptions = {
110
+ show: {
111
+ resource: ['database'],
112
+ operation: ['update'],
113
+ },
114
+ hide: {
115
+ table: [''],
116
+ },
117
+ };
118
+ exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
119
+ async function execute(inputItems, runQueries, nodeOptions) {
120
+ let returnData = [];
121
+ const items = (0, utils_1.replaceEmptyStringsByNulls)(inputItems, nodeOptions.replaceEmptyStrings);
122
+ const queries = [];
123
+ for (let i = 0; i < items.length; i++) {
124
+ const table = this.getNodeParameter('table', i, undefined, {
125
+ extractValue: true,
126
+ });
127
+ const columnToMatchOn = this.getNodeParameter('columnToMatchOn', i);
128
+ const dataMode = this.getNodeParameter('dataMode', i);
129
+ let item = {};
130
+ let valueToMatchOn = '';
131
+ if (dataMode === interfaces_1.DATA_MODE.AUTO_MAP) {
132
+ item = items[i].json;
133
+ valueToMatchOn = item[columnToMatchOn];
134
+ }
135
+ if (dataMode === interfaces_1.DATA_MODE.MANUAL) {
136
+ const valuesToSend = this.getNodeParameter('valuesToSend', i, [])
137
+ .values;
138
+ item = valuesToSend.reduce((acc, { column, value }) => {
139
+ acc[column] = value;
140
+ return acc;
141
+ }, {});
142
+ valueToMatchOn = this.getNodeParameter('valueToMatchOn', i);
143
+ }
144
+ const values = [];
145
+ const updateColumns = Object.keys(item).filter((column) => column !== columnToMatchOn);
146
+ const updates = [];
147
+ for (const column of updateColumns) {
148
+ updates.push(`\`${column}\` = ?`);
149
+ values.push(item[column]);
150
+ }
151
+ const condition = `\`${columnToMatchOn}\` = ?`;
152
+ values.push(valueToMatchOn);
153
+ const query = `UPDATE \`${table}\` SET ${updates.join(', ')} WHERE ${condition}`;
154
+ queries.push({ query, values });
155
+ }
156
+ returnData = await runQueries(queries);
157
+ return returnData;
158
+ }
159
+ exports.execute = execute;
160
+ //# sourceMappingURL=update.operation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update.operation.js","sourceRoot":"","sources":["../../../../../../nodes/MySql/v2/actions/database/update.operation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { IExecuteFunctions } from 'n8n-core';
2
+ import type { IDataObject, INodeExecutionData, INodeProperties } from 'n8n-workflow';
3
+ import type { QueryRunner } from '../../helpers/interfaces';
4
+ export declare const description: {
5
+ displayOptions: import("n8n-workflow").IDisplayOptions;
6
+ displayName: string;
7
+ name: string;
8
+ type: import("n8n-workflow").NodePropertyTypes;
9
+ typeOptions?: import("n8n-workflow").INodePropertyTypeOptions | undefined;
10
+ default: import("n8n-workflow").NodeParameterValueType;
11
+ description?: string | undefined;
12
+ hint?: string | undefined;
13
+ options?: (INodeProperties | import("n8n-workflow").INodePropertyOptions | import("n8n-workflow").INodePropertyCollection)[] | undefined;
14
+ placeholder?: string | undefined;
15
+ isNodeSetting?: boolean | undefined;
16
+ noDataExpression?: boolean | undefined;
17
+ required?: boolean | undefined;
18
+ routing?: import("n8n-workflow").INodePropertyRouting | undefined;
19
+ credentialTypes?: ("extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth")[] | undefined;
20
+ extractValue?: import("n8n-workflow").INodePropertyValueExtractorRegex | undefined;
21
+ modes?: import("n8n-workflow").INodePropertyMode[] | undefined;
22
+ requiresDataPath?: "single" | "multiple" | undefined;
23
+ }[];
24
+ export declare function execute(this: IExecuteFunctions, inputItems: INodeExecutionData[], runQueries: QueryRunner, nodeOptions: IDataObject): Promise<INodeExecutionData[]>;