n8n-nodes-base 1.114.0 → 1.115.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/credentials/MongoDb.credentials.d.ts.map +1 -1
- package/dist/credentials/MongoDb.credentials.js +3 -0
- package/dist/credentials/MongoDb.credentials.js.map +1 -1
- package/dist/credentials/OracleDBApi.credentials.d.ts +8 -0
- package/dist/credentials/OracleDBApi.credentials.d.ts.map +1 -0
- package/dist/credentials/OracleDBApi.credentials.js +205 -0
- package/dist/credentials/OracleDBApi.credentials.js.map +1 -0
- package/dist/credentials/SentryIoApi.credentials.d.ts +3 -1
- package/dist/credentials/SentryIoApi.credentials.d.ts.map +1 -1
- package/dist/credentials/SentryIoApi.credentials.js +15 -0
- package/dist/credentials/SentryIoApi.credentials.js.map +1 -1
- package/dist/credentials/SentryIoServerApi.credentials.d.ts +3 -1
- package/dist/credentials/SentryIoServerApi.credentials.d.ts.map +1 -1
- package/dist/credentials/SentryIoServerApi.credentials.js +15 -0
- package/dist/credentials/SentryIoServerApi.credentials.js.map +1 -1
- package/dist/known/credentials.json +7 -0
- package/dist/known/nodes.json +4 -0
- package/dist/methods/defined.json +4 -0
- package/dist/methods/referenced.json +4 -0
- package/dist/nodes/Code/PythonTaskRunnerSandbox.d.ts.map +1 -1
- package/dist/nodes/Code/PythonTaskRunnerSandbox.js +11 -3
- package/dist/nodes/Code/PythonTaskRunnerSandbox.js.map +1 -1
- package/dist/nodes/Form/utils/formCompletionUtils.d.ts.map +1 -1
- package/dist/nodes/Form/utils/formCompletionUtils.js +5 -4
- package/dist/nodes/Form/utils/formCompletionUtils.js.map +1 -1
- package/dist/nodes/Google/Gmail/GmailTrigger.node.d.ts.map +1 -1
- package/dist/nodes/Google/Gmail/GmailTrigger.node.js +12 -12
- package/dist/nodes/Google/Gmail/GmailTrigger.node.js.map +1 -1
- package/dist/nodes/HttpRequest/GenericFunctions.d.ts +3 -0
- package/dist/nodes/HttpRequest/GenericFunctions.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/GenericFunctions.js +20 -1
- package/dist/nodes/HttpRequest/GenericFunctions.js.map +1 -1
- package/dist/nodes/HttpRequest/HttpRequest.node.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/HttpRequest.node.js +2 -1
- package/dist/nodes/HttpRequest/HttpRequest.node.js.map +1 -1
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js +3 -2
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js.map +1 -1
- package/dist/nodes/JotForm/JotFormTrigger.node.d.ts.map +1 -1
- package/dist/nodes/JotForm/JotFormTrigger.node.js +4 -5
- package/dist/nodes/JotForm/JotFormTrigger.node.js.map +1 -1
- package/dist/nodes/JotForm/jotform.dark.svg +13 -0
- package/dist/nodes/JotForm/jotform.svg +1 -0
- package/dist/nodes/Notion/shared/descriptions/DatabasePageDescription.js +1 -1
- package/dist/nodes/Notion/shared/descriptions/DatabasePageDescription.js.map +1 -1
- package/dist/nodes/Oracle/Sql/OracleSql.node.d.ts +14 -0
- package/dist/nodes/Oracle/Sql/OracleSql.node.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/OracleSql.node.js +22 -0
- package/dist/nodes/Oracle/Sql/OracleSql.node.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/common.descriptions.d.ts +8 -0
- package/dist/nodes/Oracle/Sql/actions/common.descriptions.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/common.descriptions.js +531 -0
- package/dist/nodes/Oracle/Sql/actions/common.descriptions.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/Database.resource.d.ts +10 -0
- package/dist/nodes/Oracle/Sql/actions/database/Database.resource.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/Database.resource.js +112 -0
- package/dist/nodes/Oracle/Sql/actions/database/Database.resource.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/deleteTable.operation.d.ts +30 -0
- package/dist/nodes/Oracle/Sql/actions/database/deleteTable.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/deleteTable.operation.js +138 -0
- package/dist/nodes/Oracle/Sql/actions/database/deleteTable.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/executeQuery.operation.d.ts +40 -0
- package/dist/nodes/Oracle/Sql/actions/database/executeQuery.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/executeQuery.operation.js +66 -0
- package/dist/nodes/Oracle/Sql/actions/database/executeQuery.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/insert.operation.d.ts +30 -0
- package/dist/nodes/Oracle/Sql/actions/database/insert.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/insert.operation.js +146 -0
- package/dist/nodes/Oracle/Sql/actions/database/insert.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/select.operation.d.ts +30 -0
- package/dist/nodes/Oracle/Sql/actions/database/select.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/select.operation.js +90 -0
- package/dist/nodes/Oracle/Sql/actions/database/select.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/update.operation.d.ts +30 -0
- package/dist/nodes/Oracle/Sql/actions/database/update.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/update.operation.js +147 -0
- package/dist/nodes/Oracle/Sql/actions/database/update.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/upsert.operation.d.ts +30 -0
- package/dist/nodes/Oracle/Sql/actions/database/upsert.operation.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/database/upsert.operation.js +150 -0
- package/dist/nodes/Oracle/Sql/actions/database/upsert.operation.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/node.type.d.ts +9 -0
- package/dist/nodes/Oracle/Sql/actions/node.type.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/node.type.js +7 -0
- package/dist/nodes/Oracle/Sql/actions/node.type.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/router.d.ts +3 -0
- package/dist/nodes/Oracle/Sql/actions/router.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/router.js +77 -0
- package/dist/nodes/Oracle/Sql/actions/router.js.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/versionDescription.d.ts +3 -0
- package/dist/nodes/Oracle/Sql/actions/versionDescription.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/actions/versionDescription.js +78 -0
- package/dist/nodes/Oracle/Sql/actions/versionDescription.js.map +1 -0
- package/dist/nodes/Oracle/Sql/helpers/interfaces.d.ts +118 -0
- package/dist/nodes/Oracle/Sql/helpers/interfaces.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/helpers/interfaces.js +3 -0
- package/dist/nodes/Oracle/Sql/helpers/interfaces.js.map +1 -0
- package/dist/nodes/Oracle/Sql/helpers/utils.d.ts +38 -0
- package/dist/nodes/Oracle/Sql/helpers/utils.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/helpers/utils.js +859 -0
- package/dist/nodes/Oracle/Sql/helpers/utils.js.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/credentialTest.d.ts +3 -0
- package/dist/nodes/Oracle/Sql/methods/credentialTest.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/credentialTest.js +25 -0
- package/dist/nodes/Oracle/Sql/methods/credentialTest.js.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/index.d.ts +5 -0
- package/dist/nodes/Oracle/Sql/methods/index.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/index.js +41 -0
- package/dist/nodes/Oracle/Sql/methods/index.js.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/listSearch.d.ts +4 -0
- package/dist/nodes/Oracle/Sql/methods/listSearch.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/listSearch.js +100 -0
- package/dist/nodes/Oracle/Sql/methods/listSearch.js.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/loadOptions.d.ts +4 -0
- package/dist/nodes/Oracle/Sql/methods/loadOptions.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/loadOptions.js +29 -0
- package/dist/nodes/Oracle/Sql/methods/loadOptions.js.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/resourceMapping.d.ts +3 -0
- package/dist/nodes/Oracle/Sql/methods/resourceMapping.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/methods/resourceMapping.js +32 -0
- package/dist/nodes/Oracle/Sql/methods/resourceMapping.js.map +1 -0
- package/dist/nodes/Oracle/Sql/oracle.svg +4 -0
- package/dist/nodes/Oracle/Sql/transport/index.d.ts +5 -0
- package/dist/nodes/Oracle/Sql/transport/index.d.ts.map +1 -0
- package/dist/nodes/Oracle/Sql/transport/index.js +53 -0
- package/dist/nodes/Oracle/Sql/transport/index.js.map +1 -0
- package/dist/nodes/SentryIo/GenericFunctions.d.ts.map +1 -1
- package/dist/nodes/SentryIo/GenericFunctions.js +13 -16
- package/dist/nodes/SentryIo/GenericFunctions.js.map +1 -1
- package/dist/nodes/SentryIo/SentryIo.node.d.ts.map +1 -1
- package/dist/nodes/SentryIo/SentryIo.node.js +5 -42
- package/dist/nodes/SentryIo/SentryIo.node.js.map +1 -1
- package/dist/nodes/Slack/V2/SlackV2.node.js +2 -2
- package/dist/nodes/Slack/V2/SlackV2.node.js.map +1 -1
- package/dist/nodes/SpreadsheetFile/v2/fromFile.operation.d.ts.map +1 -1
- package/dist/nodes/SpreadsheetFile/v2/fromFile.operation.js +18 -15
- package/dist/nodes/SpreadsheetFile/v2/fromFile.operation.js.map +1 -1
- package/dist/typecheck.tsbuildinfo +1 -1
- package/dist/types/credentials.json +5 -4
- package/dist/types/nodes.json +10 -9
- package/package.json +9 -5
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { IExecuteFunctions, INodeExecutionData, INodeProperties } from 'n8n-workflow';
|
|
2
|
+
import type * as oracleDBTypes from 'oracledb';
|
|
3
|
+
import type { OracleDBNodeOptions, QueriesRunner } 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;
|
|
10
|
+
default: import("n8n-workflow").NodeParameterValueType;
|
|
11
|
+
description?: string;
|
|
12
|
+
hint?: string;
|
|
13
|
+
disabledOptions?: import("n8n-workflow").IDisplayOptions;
|
|
14
|
+
options?: Array<import("n8n-workflow").INodePropertyOptions | INodeProperties | import("n8n-workflow").INodePropertyCollection>;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
isNodeSetting?: boolean;
|
|
17
|
+
noDataExpression?: boolean;
|
|
18
|
+
required?: boolean;
|
|
19
|
+
routing?: import("n8n-workflow").INodePropertyRouting;
|
|
20
|
+
credentialTypes?: Array<"extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth">;
|
|
21
|
+
extractValue?: import("n8n-workflow").INodePropertyValueExtractor;
|
|
22
|
+
modes?: import("n8n-workflow").INodePropertyMode[];
|
|
23
|
+
requiresDataPath?: "single" | "multiple";
|
|
24
|
+
doNotInherit?: boolean;
|
|
25
|
+
validateType?: import("n8n-workflow").FieldType;
|
|
26
|
+
ignoreValidationDuringExecution?: boolean;
|
|
27
|
+
allowArbitraryValues?: boolean;
|
|
28
|
+
}[];
|
|
29
|
+
export declare function execute(this: IExecuteFunctions, runQueries: QueriesRunner, items: INodeExecutionData[], nodeOptions: OracleDBNodeOptions, pool: oracleDBTypes.Pool): Promise<INodeExecutionData[]>;
|
|
30
|
+
//# sourceMappingURL=update.operation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.operation.d.ts","sourceRoot":"","sources":["../../../../../../nodes/Oracle/Sql/actions/database/update.operation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEX,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,MAAM,cAAc,CAAC;AAEtB,OAAO,KAAK,KAAK,aAAa,MAAM,UAAU,CAAC;AAI/C,OAAO,KAAK,EAEX,mBAAmB,EAEnB,aAAa,EAEb,MAAM,0BAA0B,CAAC;AAoDlC,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;GAAmD,CAAC;AAE5E,wBAAsB,OAAO,CAC5B,IAAI,EAAE,iBAAiB,EACvB,UAAU,EAAE,aAAa,EACzB,KAAK,EAAE,kBAAkB,EAAE,EAC3B,WAAW,EAAE,mBAAmB,EAChC,IAAI,EAAE,aAAa,CAAC,IAAI,GACtB,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAsK/B"}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.description = void 0;
|
|
4
|
+
exports.execute = execute;
|
|
5
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
6
|
+
const utilities_1 = require("../../../../../utils/utilities");
|
|
7
|
+
const utils_1 = require("../../helpers/utils");
|
|
8
|
+
const common_descriptions_1 = require("../common.descriptions");
|
|
9
|
+
const properties = [
|
|
10
|
+
{
|
|
11
|
+
displayName: 'Columns',
|
|
12
|
+
name: 'columns',
|
|
13
|
+
type: 'resourceMapper',
|
|
14
|
+
noDataExpression: true,
|
|
15
|
+
default: {
|
|
16
|
+
mappingMode: 'defineBelow',
|
|
17
|
+
value: null,
|
|
18
|
+
},
|
|
19
|
+
required: true,
|
|
20
|
+
typeOptions: {
|
|
21
|
+
loadOptionsDependsOn: ['table.value', 'operation'],
|
|
22
|
+
resourceMapper: {
|
|
23
|
+
resourceMapperMethod: 'getMappingColumns',
|
|
24
|
+
mode: 'update',
|
|
25
|
+
fieldWords: {
|
|
26
|
+
singular: 'column',
|
|
27
|
+
plural: 'columns',
|
|
28
|
+
},
|
|
29
|
+
addAllFields: true,
|
|
30
|
+
multiKeyMatch: true,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
...common_descriptions_1.optionsCollection,
|
|
35
|
+
];
|
|
36
|
+
const displayOptions = {
|
|
37
|
+
show: {
|
|
38
|
+
resource: ['database'],
|
|
39
|
+
operation: ['update'],
|
|
40
|
+
},
|
|
41
|
+
hide: {
|
|
42
|
+
table: [''],
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
|
|
46
|
+
async function execute(runQueries, items, nodeOptions, pool) {
|
|
47
|
+
let schema = this.getNodeParameter('schema', 0, undefined, {
|
|
48
|
+
extractValue: true,
|
|
49
|
+
});
|
|
50
|
+
let table = this.getNodeParameter('table', 0, undefined, {
|
|
51
|
+
extractValue: true,
|
|
52
|
+
});
|
|
53
|
+
let tableSchema = await (0, utils_1.getColumnMetaData)(this.getNode(), pool, schema, table);
|
|
54
|
+
const queries = [];
|
|
55
|
+
const stmtBatching = nodeOptions.stmtBatching || 'single';
|
|
56
|
+
if (stmtBatching === 'single') {
|
|
57
|
+
const dataMode = this.getNodeParameter('columns.mappingMode', 0);
|
|
58
|
+
let item = {};
|
|
59
|
+
if (dataMode === 'autoMapInputData') {
|
|
60
|
+
item = items[0].json;
|
|
61
|
+
}
|
|
62
|
+
else if (dataMode === 'defineBelow') {
|
|
63
|
+
item = this.getNodeParameter('columns.value', 0);
|
|
64
|
+
}
|
|
65
|
+
const columnMetaDataObject = (0, utils_1.getColumnMap)(tableSchema);
|
|
66
|
+
// where clause column
|
|
67
|
+
const columnsToMatchOn = this.getNodeParameter('columns.matchingColumns', 0);
|
|
68
|
+
const updateColumns = Object.keys(item).filter((column) => !columnsToMatchOn.includes(column));
|
|
69
|
+
if (!updateColumns.length) {
|
|
70
|
+
throw new n8n_workflow_1.NodeOperationError(this.getNode(), "Add values to update to the input item or set the 'Data Mode' to 'Define Below' to define the values to update.");
|
|
71
|
+
}
|
|
72
|
+
let query = `UPDATE ${(0, utils_1.quoteSqlIdentifier)(schema)}.${(0, utils_1.quoteSqlIdentifier)(table)}`;
|
|
73
|
+
let outputColumns = this.getNodeParameter('options.outputColumns', 0, []);
|
|
74
|
+
if (outputColumns.includes('*'))
|
|
75
|
+
outputColumns = Object.keys(columnMetaDataObject);
|
|
76
|
+
query = (0, utils_1.getBindDefsForExecuteMany)(this.getNode(), query, columnMetaDataObject, updateColumns, outputColumns, item, nodeOptions, 'update', columnsToMatchOn);
|
|
77
|
+
const executeManyValues = [];
|
|
78
|
+
const keysOrder = [...updateColumns, ...columnsToMatchOn];
|
|
79
|
+
for (let i = 0; i < items.length; i++) {
|
|
80
|
+
if (dataMode === 'autoMapInputData') {
|
|
81
|
+
item = items[i].json;
|
|
82
|
+
}
|
|
83
|
+
else if (dataMode === 'defineBelow') {
|
|
84
|
+
item = this.getNodeParameter('columns.value', i);
|
|
85
|
+
}
|
|
86
|
+
const result = [];
|
|
87
|
+
for (const key of keysOrder) {
|
|
88
|
+
const type = columnMetaDataObject[key].type;
|
|
89
|
+
let value = item[key];
|
|
90
|
+
value = (0, utils_1.getCompatibleValue)(type, value);
|
|
91
|
+
result.push(value);
|
|
92
|
+
}
|
|
93
|
+
executeManyValues.push(result);
|
|
94
|
+
}
|
|
95
|
+
queries.push({ query, executeManyValues, outputColumns });
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
const updateTableSchema = (0, utils_1.configureTableSchemaUpdater)(this.getNode(), schema, table);
|
|
99
|
+
for (let index = 0; index < items.length; index++) {
|
|
100
|
+
schema = this.getNodeParameter('schema', index, undefined, {
|
|
101
|
+
extractValue: true,
|
|
102
|
+
});
|
|
103
|
+
table = this.getNodeParameter('table', index, undefined, {
|
|
104
|
+
extractValue: true,
|
|
105
|
+
});
|
|
106
|
+
const dataMode = this.getNodeParameter('columns.mappingMode', index);
|
|
107
|
+
let item = {};
|
|
108
|
+
if (dataMode === 'autoMapInputData') {
|
|
109
|
+
item = items[index].json;
|
|
110
|
+
// Column refresh is needed only for 'autoMapInputData'
|
|
111
|
+
tableSchema = await updateTableSchema(pool, tableSchema, schema, table, index);
|
|
112
|
+
}
|
|
113
|
+
else if (dataMode === 'defineBelow') {
|
|
114
|
+
item = this.getNodeParameter('columns.value', index);
|
|
115
|
+
}
|
|
116
|
+
// where clause column
|
|
117
|
+
const columnsToMatchOn = this.getNodeParameter('columns.matchingColumns', index);
|
|
118
|
+
const columnMetaDataObject = (0, utils_1.getColumnMap)(tableSchema);
|
|
119
|
+
const updateColumns = Object.keys(item).filter((column) => !columnsToMatchOn.includes(column));
|
|
120
|
+
if (!updateColumns.length) {
|
|
121
|
+
throw new n8n_workflow_1.NodeOperationError(this.getNode(), "Add values to update to the input item or set the 'Data Mode' to 'Define Below' to define the values to update.");
|
|
122
|
+
}
|
|
123
|
+
if (Object.keys(item).length === columnsToMatchOn.length) {
|
|
124
|
+
// Only match column exists, nothing to update
|
|
125
|
+
throw new n8n_workflow_1.NodeOperationError(this.getNode(), "Add values to update to the input item or set the 'Data Mode' to 'Define Below' to define the values to update.");
|
|
126
|
+
}
|
|
127
|
+
const bindParams = []; // bindParameters
|
|
128
|
+
let [quotedColsArray, _replacements, posIndex] = (0, utils_1.getInBindParametersForExecute)(updateColumns, columnMetaDataObject, item, 'update', bindParams);
|
|
129
|
+
let query = `UPDATE ${(0, utils_1.quoteSqlIdentifier)(schema)}.${(0, utils_1.quoteSqlIdentifier)(table)} SET ${quotedColsArray.join(',')}`;
|
|
130
|
+
if (columnsToMatchOn.length > 0) {
|
|
131
|
+
[quotedColsArray, _replacements, posIndex] = (0, utils_1.getInBindParametersForExecute)(columnsToMatchOn, columnMetaDataObject, item, 'update', bindParams, posIndex);
|
|
132
|
+
const condition = quotedColsArray.join(' AND ');
|
|
133
|
+
query += ` WHERE ${condition}`;
|
|
134
|
+
}
|
|
135
|
+
let outputColumns = this.getNodeParameter('options.outputColumns', index, []);
|
|
136
|
+
if (outputColumns.includes('*'))
|
|
137
|
+
outputColumns = Object.keys(columnMetaDataObject);
|
|
138
|
+
if (outputColumns.length > 0) {
|
|
139
|
+
const updatedQuery = (0, utils_1.getOutBindDefsForExecute)(query, columnMetaDataObject, outputColumns, bindParams, posIndex);
|
|
140
|
+
query = updatedQuery;
|
|
141
|
+
}
|
|
142
|
+
queries.push({ query, values: bindParams, outputColumns });
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
return await runQueries(queries, items, nodeOptions);
|
|
146
|
+
}
|
|
147
|
+
//# sourceMappingURL=update.operation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.operation.js","sourceRoot":"","sources":["../../../../../../nodes/Oracle/Sql/actions/database/update.operation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { IExecuteFunctions, INodeExecutionData, INodeProperties } from 'n8n-workflow';
|
|
2
|
+
import type * as oracleDBTypes from 'oracledb';
|
|
3
|
+
import type { OracleDBNodeOptions, QueriesRunner } 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;
|
|
10
|
+
default: import("n8n-workflow").NodeParameterValueType;
|
|
11
|
+
description?: string;
|
|
12
|
+
hint?: string;
|
|
13
|
+
disabledOptions?: import("n8n-workflow").IDisplayOptions;
|
|
14
|
+
options?: Array<import("n8n-workflow").INodePropertyOptions | INodeProperties | import("n8n-workflow").INodePropertyCollection>;
|
|
15
|
+
placeholder?: string;
|
|
16
|
+
isNodeSetting?: boolean;
|
|
17
|
+
noDataExpression?: boolean;
|
|
18
|
+
required?: boolean;
|
|
19
|
+
routing?: import("n8n-workflow").INodePropertyRouting;
|
|
20
|
+
credentialTypes?: Array<"extends:oAuth2Api" | "extends:oAuth1Api" | "has:authenticate" | "has:genericAuth">;
|
|
21
|
+
extractValue?: import("n8n-workflow").INodePropertyValueExtractor;
|
|
22
|
+
modes?: import("n8n-workflow").INodePropertyMode[];
|
|
23
|
+
requiresDataPath?: "single" | "multiple";
|
|
24
|
+
doNotInherit?: boolean;
|
|
25
|
+
validateType?: import("n8n-workflow").FieldType;
|
|
26
|
+
ignoreValidationDuringExecution?: boolean;
|
|
27
|
+
allowArbitraryValues?: boolean;
|
|
28
|
+
}[];
|
|
29
|
+
export declare function execute(this: IExecuteFunctions, runQueries: QueriesRunner, items: INodeExecutionData[], nodeOptions: OracleDBNodeOptions, pool: oracleDBTypes.Pool): Promise<INodeExecutionData[]>;
|
|
30
|
+
//# sourceMappingURL=upsert.operation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upsert.operation.d.ts","sourceRoot":"","sources":["../../../../../../nodes/Oracle/Sql/actions/database/upsert.operation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEX,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,EACf,MAAM,cAAc,CAAC;AAEtB,OAAO,KAAK,KAAK,aAAa,MAAM,UAAU,CAAC;AAI/C,OAAO,KAAK,EAGX,mBAAmB,EACnB,aAAa,EAEb,MAAM,0BAA0B,CAAC;AAuKlC,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;GAAmD,CAAC;AAE5E,wBAAsB,OAAO,CAC5B,IAAI,EAAE,iBAAiB,EACvB,UAAU,EAAE,aAAa,EACzB,KAAK,EAAE,kBAAkB,EAAE,EAC3B,WAAW,EAAE,mBAAmB,EAChC,IAAI,EAAE,aAAa,CAAC,IAAI,GACtB,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAmF/B"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.description = void 0;
|
|
4
|
+
exports.execute = execute;
|
|
5
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
6
|
+
const utilities_1 = require("../../../../../utils/utilities");
|
|
7
|
+
const utils_1 = require("../../helpers/utils");
|
|
8
|
+
const common_descriptions_1 = require("../common.descriptions");
|
|
9
|
+
const properties = [
|
|
10
|
+
{
|
|
11
|
+
displayName: 'Columns',
|
|
12
|
+
name: 'columns',
|
|
13
|
+
type: 'resourceMapper',
|
|
14
|
+
noDataExpression: true,
|
|
15
|
+
default: {
|
|
16
|
+
mappingMode: 'defineBelow',
|
|
17
|
+
value: null,
|
|
18
|
+
},
|
|
19
|
+
required: true,
|
|
20
|
+
typeOptions: {
|
|
21
|
+
loadOptionsDependsOn: ['table.value', 'operation'],
|
|
22
|
+
resourceMapper: {
|
|
23
|
+
resourceMapperMethod: 'getMappingColumns',
|
|
24
|
+
mode: 'upsert',
|
|
25
|
+
fieldWords: {
|
|
26
|
+
singular: 'column',
|
|
27
|
+
plural: 'columns',
|
|
28
|
+
},
|
|
29
|
+
addAllFields: true,
|
|
30
|
+
multiKeyMatch: true,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
...common_descriptions_1.optionsCollection,
|
|
35
|
+
];
|
|
36
|
+
const displayOptions = {
|
|
37
|
+
show: {
|
|
38
|
+
resource: ['database'],
|
|
39
|
+
operation: ['upsert'],
|
|
40
|
+
},
|
|
41
|
+
hide: {
|
|
42
|
+
table: [''],
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
function getQueryAndOutputColumns(ctx, items, item, schema, table, tableSchema, bindParams, bindDefs, index, executeManyValues = null) {
|
|
46
|
+
const columnMetaDataObject = (0, utils_1.getColumnMap)(tableSchema);
|
|
47
|
+
const columnsToMatchOn = ctx.getNodeParameter('columns.matchingColumns', index);
|
|
48
|
+
if (columnsToMatchOn.length === 0) {
|
|
49
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'No matching columns configured. Please define at least one column to match on.');
|
|
50
|
+
}
|
|
51
|
+
if (item[columnsToMatchOn[0]] === undefined) {
|
|
52
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), "Column to match on not found in input item. Add a column to match on or set the 'Data Mode' to 'Define Below' to define the value to match on.");
|
|
53
|
+
}
|
|
54
|
+
if (Object.keys(item).length === columnsToMatchOn.length) {
|
|
55
|
+
// Only match column exists, nothing to update/insert
|
|
56
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), "Add values to update or insert to the input item or set the 'Data Mode' to 'Define Below' to define the values to insert or update.");
|
|
57
|
+
}
|
|
58
|
+
const updateColumns = Object.keys(item).filter((column) => !columnsToMatchOn.includes(column));
|
|
59
|
+
const inputColumns = Object.keys(item);
|
|
60
|
+
const [sourceSelect, posIndex1] = (0, utils_1.getInBindParametersForSourceSelect)(columnsToMatchOn, columnMetaDataObject, item, bindParams, bindDefs, 0);
|
|
61
|
+
const onClause = (0, utils_1.getOnClauseFromColumns)(columnsToMatchOn);
|
|
62
|
+
const [updateSetClause, posIndex2] = (0, utils_1.getUpdateSetClause)(updateColumns, columnMetaDataObject, item, bindParams, bindDefs, posIndex1);
|
|
63
|
+
const [insertColsStr, insertValsStr, posIndex3] = (0, utils_1.getInsertClauseAndBinds)(inputColumns, columnMetaDataObject, item, bindParams, bindDefs, posIndex2);
|
|
64
|
+
let query = `MERGE INTO ${(0, utils_1.quoteSqlIdentifier)(schema)}.${(0, utils_1.quoteSqlIdentifier)(table)} t
|
|
65
|
+
USING (SELECT ${sourceSelect} FROM dual) s
|
|
66
|
+
ON (${onClause})
|
|
67
|
+
WHEN MATCHED THEN
|
|
68
|
+
UPDATE SET ${updateSetClause}
|
|
69
|
+
WHEN NOT MATCHED THEN
|
|
70
|
+
INSERT (${insertColsStr}) VALUES (${insertValsStr})
|
|
71
|
+
`;
|
|
72
|
+
let outputColumns = ctx.getNodeParameter('options.outputColumns', 0, []);
|
|
73
|
+
if (outputColumns.includes('*'))
|
|
74
|
+
outputColumns = Object.keys(columnMetaDataObject);
|
|
75
|
+
if (outputColumns.length > 0) {
|
|
76
|
+
query = (0, utils_1.getOutBindDefsForExecute)(query, columnMetaDataObject, outputColumns, bindDefs ?? bindParams, posIndex3);
|
|
77
|
+
}
|
|
78
|
+
if (executeManyValues) {
|
|
79
|
+
const keysOrder = [...columnsToMatchOn, ...updateColumns, ...inputColumns];
|
|
80
|
+
for (let i = 0; i < items.length; i++) {
|
|
81
|
+
const dataMode = ctx.getNodeParameter('columns.mappingMode', i);
|
|
82
|
+
if (dataMode === 'autoMapInputData') {
|
|
83
|
+
item = items[i].json;
|
|
84
|
+
}
|
|
85
|
+
if (dataMode === 'defineBelow') {
|
|
86
|
+
item = ctx.getNodeParameter('columns.value', i);
|
|
87
|
+
}
|
|
88
|
+
const result = [];
|
|
89
|
+
for (const key of keysOrder) {
|
|
90
|
+
const type = columnMetaDataObject[key].type;
|
|
91
|
+
const value = (0, utils_1.getCompatibleValue)(type, item[key]);
|
|
92
|
+
result.push(value);
|
|
93
|
+
}
|
|
94
|
+
executeManyValues.push(result);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
return [query, outputColumns];
|
|
98
|
+
}
|
|
99
|
+
exports.description = (0, utilities_1.updateDisplayOptions)(displayOptions, properties);
|
|
100
|
+
async function execute(runQueries, items, nodeOptions, pool) {
|
|
101
|
+
const stmtBatching = nodeOptions.stmtBatching ?? 'single';
|
|
102
|
+
const queries = [];
|
|
103
|
+
let item = {};
|
|
104
|
+
let schema = this.getNodeParameter('schema', 0, undefined, {
|
|
105
|
+
extractValue: true,
|
|
106
|
+
});
|
|
107
|
+
let table = this.getNodeParameter('table', 0, undefined, {
|
|
108
|
+
extractValue: true,
|
|
109
|
+
});
|
|
110
|
+
let tableSchema = await (0, utils_1.getColumnMetaData)(this.getNode(), pool, schema, table);
|
|
111
|
+
let dataMode = this.getNodeParameter('columns.mappingMode', 0);
|
|
112
|
+
if (stmtBatching === 'single') {
|
|
113
|
+
const executeManyValues = [];
|
|
114
|
+
const bindDefs = [];
|
|
115
|
+
if (dataMode === 'autoMapInputData') {
|
|
116
|
+
item = items[0].json;
|
|
117
|
+
}
|
|
118
|
+
else if (dataMode === 'defineBelow') {
|
|
119
|
+
item = this.getNodeParameter('columns.value', 0);
|
|
120
|
+
}
|
|
121
|
+
const [query, outputColumns] = getQueryAndOutputColumns(this, items, item, schema, table, tableSchema, [], bindDefs, 0, executeManyValues);
|
|
122
|
+
nodeOptions.bindDefs = bindDefs;
|
|
123
|
+
queries.push({ query, executeManyValues, outputColumns });
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
const updateTableSchema = (0, utils_1.configureTableSchemaUpdater)(this.getNode(), schema, table);
|
|
127
|
+
for (let i = 0; i < items.length; i++) {
|
|
128
|
+
dataMode = this.getNodeParameter('columns.mappingMode', i);
|
|
129
|
+
schema = this.getNodeParameter('schema', i, undefined, {
|
|
130
|
+
extractValue: true,
|
|
131
|
+
});
|
|
132
|
+
table = this.getNodeParameter('table', i, undefined, {
|
|
133
|
+
extractValue: true,
|
|
134
|
+
});
|
|
135
|
+
if (dataMode === 'autoMapInputData') {
|
|
136
|
+
item = items[i].json;
|
|
137
|
+
// Column refresh is needed only for 'autoMapInputData'
|
|
138
|
+
tableSchema = await updateTableSchema(pool, tableSchema, schema, table, i);
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
item = this.getNodeParameter('columns.value', i);
|
|
142
|
+
}
|
|
143
|
+
const bindParams = []; // bindParameters
|
|
144
|
+
const [query, outputColumns] = getQueryAndOutputColumns(this, items, item, schema, table, tableSchema, bindParams, null, i, null);
|
|
145
|
+
queries.push({ query, values: bindParams, outputColumns });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
return await runQueries(queries, items, nodeOptions);
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=upsert.operation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upsert.operation.js","sourceRoot":"","sources":["../../../../../../nodes/Oracle/Sql/actions/database/upsert.operation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AllEntities, Entity } from 'n8n-workflow';
|
|
2
|
+
type OracleDBMap = {
|
|
3
|
+
database: 'deleteTable' | 'execute' | 'insert' | 'select' | 'update' | 'upsert';
|
|
4
|
+
};
|
|
5
|
+
export type OracleDBType = AllEntities<OracleDBMap>;
|
|
6
|
+
export type OracleDatabaseType = Entity<OracleDBMap, 'database'>;
|
|
7
|
+
export declare function isOracleDBOperation(op: string): op is OracleDBMap['database'];
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=node.type.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.type.d.ts","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/node.type.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAExD,KAAK,WAAW,GAAG;IAClB,QAAQ,EAAE,aAAa,GAAG,SAAS,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;CAChF,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC;AAEpD,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;AAEjE,wBAAgB,mBAAmB,CAAC,EAAE,EAAE,MAAM,GAAG,EAAE,IAAI,WAAW,CAAC,UAAU,CAAC,CAE7E"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.isOracleDBOperation = isOracleDBOperation;
|
|
4
|
+
function isOracleDBOperation(op) {
|
|
5
|
+
return ['deleteTable', 'execute', 'insert', 'select', 'update', 'upsert'].includes(op);
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=node.type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node.type.js","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/node.type.ts"],"names":[],"mappings":";;AAUA,kDAEC;AAFD,SAAgB,mBAAmB,CAAC,EAAU;IAC7C,OAAO,CAAC,aAAa,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;AACxF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/router.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAU1E,wBAAsB,MAAM,CAAC,IAAI,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAqDrF"}
|
|
@@ -0,0 +1,77 @@
|
|
|
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 () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.router = router;
|
|
37
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
38
|
+
const database = __importStar(require("./database/Database.resource"));
|
|
39
|
+
const node_type_1 = require("./node.type");
|
|
40
|
+
const utils_1 = require("../helpers/utils");
|
|
41
|
+
const transport_1 = require("../transport");
|
|
42
|
+
async function router() {
|
|
43
|
+
let returnData = [];
|
|
44
|
+
const items = this.getInputData();
|
|
45
|
+
const resource = this.getNodeParameter('resource', 0);
|
|
46
|
+
const operation = this.getNodeParameter('operation', 0);
|
|
47
|
+
if (!(0, node_type_1.isOracleDBOperation)(operation)) {
|
|
48
|
+
throw new n8n_workflow_1.NodeOperationError(this.getNode(), `The operation "${operation}" is not a valid value!`);
|
|
49
|
+
}
|
|
50
|
+
const credentials = await this.getCredentials('oracleDBApi');
|
|
51
|
+
const options = this.getNodeParameter('options', 0, {});
|
|
52
|
+
const node = this.getNode();
|
|
53
|
+
options.nodeVersion = node.typeVersion;
|
|
54
|
+
options.operation = operation;
|
|
55
|
+
options.autoCommit = options.autoCommit ?? true;
|
|
56
|
+
const pool = await transport_1.configureOracleDB.call(this, credentials, options);
|
|
57
|
+
const runQueries = utils_1.configureQueryRunner.call(this, this.getNode(), this.continueOnFail(), pool);
|
|
58
|
+
const oracleDBNodeData = {
|
|
59
|
+
resource,
|
|
60
|
+
operation,
|
|
61
|
+
};
|
|
62
|
+
switch (oracleDBNodeData.resource) {
|
|
63
|
+
case 'database':
|
|
64
|
+
returnData = await database[oracleDBNodeData.operation].execute.call(this, runQueries, items, options, pool);
|
|
65
|
+
break;
|
|
66
|
+
default:
|
|
67
|
+
throw new n8n_workflow_1.NodeOperationError(this.getNode(), `The operation "${operation}" is not supported!`);
|
|
68
|
+
}
|
|
69
|
+
if (operation === 'select' && items.length > 1 && !node.executeOnce) {
|
|
70
|
+
this.addExecutionHints({
|
|
71
|
+
message: `This node ran ${items.length} times, once for each input item. To run for the first item only, enable 'execute once' in the node settings`,
|
|
72
|
+
location: 'outputPane',
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
return [returnData];
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.js","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/router.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,wBAqDC;AA9DD,+CAAkD;AAElD,uEAAyD;AAEzD,2CAAkD;AAElD,4CAAwD;AACxD,4CAAiD;AAE1C,KAAK,UAAU,MAAM;IAC3B,IAAI,UAAU,GAAyB,EAAE,CAAC;IAE1C,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;IAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAe,UAAU,EAAE,CAAC,CAAC,CAAC;IACpE,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAExD,IAAI,CAAC,IAAA,+BAAmB,EAAC,SAAS,CAAC,EAAE,CAAC;QACrC,MAAM,IAAI,iCAAkB,CAC3B,IAAI,CAAC,OAAO,EAAE,EACd,kBAAkB,SAAS,yBAAyB,CACpD,CAAC;IACH,CAAC;IAED,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,cAAc,CAA0B,aAAa,CAAC,CAAC;IACtF,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAwB,CAAC;IAC/E,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC5B,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;IACvC,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAC9B,OAAO,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,IAAI,IAAI,CAAC;IAEhD,MAAM,IAAI,GAAG,MAAM,6BAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,CAAC;IACtE,MAAM,UAAU,GAAG,4BAAoB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,CAAC;IAChG,MAAM,gBAAgB,GAAiB;QACtC,QAAQ;QACR,SAAS;KACT,CAAC;IAEF,QAAQ,gBAAgB,CAAC,QAAQ,EAAE,CAAC;QACnC,KAAK,UAAU;YACd,UAAU,GAAG,MAAM,QAAQ,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,IAAI,CACnE,IAAI,EACJ,UAAU,EACV,KAAK,EACL,OAAO,EACP,IAAI,CACJ,CAAC;YACF,MAAM;QACP;YACC,MAAM,IAAI,iCAAkB,CAC3B,IAAI,CAAC,OAAO,EAAE,EACd,kBAAkB,SAAS,qBAAqB,CAChD,CAAC;IACJ,CAAC;IAED,IAAI,SAAS,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACrE,IAAI,CAAC,iBAAiB,CAAC;YACtB,OAAO,EAAE,iBAAiB,KAAK,CAAC,MAAM,8GAA8G;YACpJ,QAAQ,EAAE,YAAY;SACtB,CAAC,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,UAAU,CAAC,CAAC;AACrB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versionDescription.d.ts","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/versionDescription.ts"],"names":[],"mappings":"AAEA,OAAO,EAAuB,KAAK,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAI9E,eAAO,MAAM,kBAAkB,EAAE,oBAqChC,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/* eslint-disable n8n-nodes-base/node-filename-against-convention */
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
+
}) : function(o, v) {
|
|
17
|
+
o["default"] = v;
|
|
18
|
+
});
|
|
19
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
+
var ownKeys = function(o) {
|
|
21
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
+
var ar = [];
|
|
23
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
+
return ar;
|
|
25
|
+
};
|
|
26
|
+
return ownKeys(o);
|
|
27
|
+
};
|
|
28
|
+
return function (mod) {
|
|
29
|
+
if (mod && mod.__esModule) return mod;
|
|
30
|
+
var result = {};
|
|
31
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
+
__setModuleDefault(result, mod);
|
|
33
|
+
return result;
|
|
34
|
+
};
|
|
35
|
+
})();
|
|
36
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
+
exports.versionDescription = void 0;
|
|
38
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
39
|
+
const database = __importStar(require("./database/Database.resource"));
|
|
40
|
+
exports.versionDescription = {
|
|
41
|
+
displayName: 'Oracle Database',
|
|
42
|
+
name: 'oracleDatabase',
|
|
43
|
+
icon: 'file:oracle.svg',
|
|
44
|
+
group: ['input'],
|
|
45
|
+
version: [1],
|
|
46
|
+
subtitle: '={{ $parameter["operation"] }}',
|
|
47
|
+
description: 'Get, add and update data in Oracle database',
|
|
48
|
+
defaults: {
|
|
49
|
+
name: 'Oracle Database',
|
|
50
|
+
},
|
|
51
|
+
inputs: [n8n_workflow_1.NodeConnectionTypes.Main],
|
|
52
|
+
outputs: [n8n_workflow_1.NodeConnectionTypes.Main],
|
|
53
|
+
usableAsTool: true,
|
|
54
|
+
credentials: [
|
|
55
|
+
{
|
|
56
|
+
name: 'oracleDBApi',
|
|
57
|
+
required: true,
|
|
58
|
+
testedBy: 'oracleDBConnectionTest',
|
|
59
|
+
},
|
|
60
|
+
],
|
|
61
|
+
properties: [
|
|
62
|
+
{
|
|
63
|
+
displayName: 'Resource',
|
|
64
|
+
name: 'resource',
|
|
65
|
+
type: 'hidden',
|
|
66
|
+
noDataExpression: true,
|
|
67
|
+
options: [
|
|
68
|
+
{
|
|
69
|
+
name: 'Database',
|
|
70
|
+
value: 'database',
|
|
71
|
+
},
|
|
72
|
+
],
|
|
73
|
+
default: 'database',
|
|
74
|
+
},
|
|
75
|
+
...database.description,
|
|
76
|
+
],
|
|
77
|
+
};
|
|
78
|
+
//# sourceMappingURL=versionDescription.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versionDescription.js","sourceRoot":"","sources":["../../../../../nodes/Oracle/Sql/actions/versionDescription.ts"],"names":[],"mappings":";AAAA,oEAAoE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpE,+CAA8E;AAE9E,uEAAyD;AAE5C,QAAA,kBAAkB,GAAyB;IACvD,WAAW,EAAE,iBAAiB;IAC9B,IAAI,EAAE,gBAAgB;IACtB,IAAI,EAAE,iBAAiB;IACvB,KAAK,EAAE,CAAC,OAAO,CAAC;IAChB,OAAO,EAAE,CAAC,CAAC,CAAC;IACZ,QAAQ,EAAE,gCAAgC;IAC1C,WAAW,EAAE,6CAA6C;IAC1D,QAAQ,EAAE;QACT,IAAI,EAAE,iBAAiB;KACvB;IACD,MAAM,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;IAClC,OAAO,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;IACnC,YAAY,EAAE,IAAI;IAClB,WAAW,EAAE;QACZ;YACC,IAAI,EAAE,aAAa;YACnB,QAAQ,EAAE,IAAI;YACd,QAAQ,EAAE,wBAAwB;SAClC;KACD;IACD,UAAU,EAAE;QACX;YACC,WAAW,EAAE,UAAU;YACvB,IAAI,EAAE,UAAU;YAChB,IAAI,EAAE,QAAQ;YACd,gBAAgB,EAAE,IAAI;YACtB,OAAO,EAAE;gBACR;oBACC,IAAI,EAAE,UAAU;oBAChB,KAAK,EAAE,UAAU;iBACjB;aACD;YACD,OAAO,EAAE,UAAU;SACnB;QACD,GAAG,QAAQ,CAAC,WAAW;KACvB;CACD,CAAC"}
|