@qrvey/data-persistence 0.1.6 → 0.1.7
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/cjs/error/NoRecordsAffectedException.js +11 -0
- package/dist/cjs/error/NoRecordsAffectedException.js.map +1 -0
- package/dist/cjs/helpers/errorHelper.js +25 -0
- package/dist/cjs/helpers/errorHelper.js.map +1 -0
- package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js +27 -19
- package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js +87 -6
- package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js +5 -2
- package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js.map +1 -1
- package/dist/esm/chunk-JJPS7Q3Y.mjs +55 -0
- package/dist/esm/chunk-JJPS7Q3Y.mjs.map +1 -0
- package/dist/esm/{dynamoDbCrud.service-RBH27HXM.mjs → dynamoDbCrud.service-CS264IQJ.mjs} +35 -26
- package/dist/esm/dynamoDbCrud.service-CS264IQJ.mjs.map +1 -0
- package/dist/esm/index.d.mts +2 -2
- package/dist/esm/index.mjs +2 -2
- package/dist/esm/{postgreSqlCrud.service-OEY7OEML.mjs → postgreSqlCrud.service-3ILHEXDN.mjs} +120 -6
- package/dist/esm/postgreSqlCrud.service-3ILHEXDN.mjs.map +1 -0
- package/dist/types/index.d.ts +2 -2
- package/package.json +1 -1
- package/dist/esm/chunk-RTYYBKND.mjs +0 -31
- package/dist/esm/chunk-RTYYBKND.mjs.map +0 -1
- package/dist/esm/dynamoDbCrud.service-RBH27HXM.mjs.map +0 -1
- package/dist/esm/postgreSqlCrud.service-OEY7OEML.mjs.map +0 -1
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NoRecordsAffectedException = void 0;
|
|
4
|
+
class NoRecordsAffectedException extends Error {
|
|
5
|
+
constructor() {
|
|
6
|
+
super('No records affected by update');
|
|
7
|
+
this.name = 'NoRecordsAffectedException';
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
exports.NoRecordsAffectedException = NoRecordsAffectedException;
|
|
11
|
+
//# sourceMappingURL=NoRecordsAffectedException.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NoRecordsAffectedException.js","sourceRoot":"","sources":["../../../src/error/NoRecordsAffectedException.ts"],"names":[],"mappings":";;;AAAA,MAAa,0BAA2B,SAAQ,KAAK;IACjD;QACI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACvC,IAAI,CAAC,IAAI,GAAG,4BAA4B,CAAC;IAC7C,CAAC;CACJ;AALD,gEAKC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PersistenceErrorWrapper = void 0;
|
|
4
|
+
const NoRecordsAffectedException_1 = require("../error/NoRecordsAffectedException");
|
|
5
|
+
function PersistenceErrorWrapper(queryResult) {
|
|
6
|
+
const dynamoNoRecordsAffectedExceptions = [
|
|
7
|
+
'ConditionalCheckFailedException',
|
|
8
|
+
];
|
|
9
|
+
//This is for Postgres scenario, where there is not error launched by updates
|
|
10
|
+
if (queryResult.rowCount == 0) {
|
|
11
|
+
throw new NoRecordsAffectedException_1.NoRecordsAffectedException();
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
//Checks for dynamodb errors also the ones that is included in NoRecordsAffectedExceptions list
|
|
15
|
+
if (queryResult.name &&
|
|
16
|
+
dynamoNoRecordsAffectedExceptions.includes(queryResult.name)) {
|
|
17
|
+
throw new NoRecordsAffectedException_1.NoRecordsAffectedException();
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
throw queryResult;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
exports.PersistenceErrorWrapper = PersistenceErrorWrapper;
|
|
25
|
+
//# sourceMappingURL=errorHelper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errorHelper.js","sourceRoot":"","sources":["../../../src/helpers/errorHelper.ts"],"names":[],"mappings":";;;AAAA,oFAAiF;AAEjF,SAAgB,uBAAuB,CAAC,WAAgB;IACpD,MAAM,iCAAiC,GAAG;QACtC,iCAAiC;KACpC,CAAC;IAEF,6EAA6E;IAC7E,IAAI,WAAW,CAAC,QAAQ,IAAI,CAAC,EAAE;QAC3B,MAAM,IAAI,uDAA0B,EAAE,CAAC;KAC1C;SAAM;QACH,+FAA+F;QAC/F,IACI,WAAW,CAAC,IAAI;YAChB,iCAAiC,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAC9D;YACE,MAAM,IAAI,uDAA0B,EAAE,CAAC;SAC1C;aAAM;YACH,MAAM,WAAW,CAAC;SACrB;KACJ;AACL,CAAC;AAnBD,0DAmBC"}
|
|
@@ -7,7 +7,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
7
7
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
8
8
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
9
9
|
};
|
|
10
|
-
var _DynamoDbCrudService_instances, _DynamoDbCrudService_buildUpdateExpressionQuery, _DynamoDbCrudService_getKeyObjectForUpdateExpression, _DynamoDbCrudService_getUpdateExpressionOptions, _DynamoDbCrudService_extractUpdateExpressionAttributesAndNames;
|
|
10
|
+
var _DynamoDbCrudService_instances, _DynamoDbCrudService_prepareAndExecuteUpdateExpression, _DynamoDbCrudService_buildUpdateExpressionQuery, _DynamoDbCrudService_getKeyObjectForUpdateExpression, _DynamoDbCrudService_getUpdateExpressionOptions, _DynamoDbCrudService_extractUpdateExpressionAttributesAndNames;
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.DynamoDbCrudService = void 0;
|
|
13
13
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
@@ -15,6 +15,7 @@ const dynamoDbClient_service_1 = __importDefault(require("./dynamoDbClient.servi
|
|
|
15
15
|
const queryBuilder_service_1 = __importDefault(require("./queryBuilder.service"));
|
|
16
16
|
const constants_1 = require("../../../utils/constants");
|
|
17
17
|
const tableHelper_1 = require("../../../helpers/tableHelper");
|
|
18
|
+
const errorHelper_1 = require("../../../helpers/errorHelper");
|
|
18
19
|
class DynamoDbCrudService {
|
|
19
20
|
constructor(tableSchema) {
|
|
20
21
|
_DynamoDbCrudService_instances.add(this);
|
|
@@ -278,29 +279,36 @@ class DynamoDbCrudService {
|
|
|
278
279
|
}
|
|
279
280
|
}
|
|
280
281
|
async updateExpressions(filters, actions, options) {
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
const keyObject = __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_getKeyObjectForUpdateExpression).call(this, queryObject, primaryKeys);
|
|
284
|
-
const updateExpressions = [];
|
|
285
|
-
Object.keys(actions).forEach((action) => {
|
|
286
|
-
const actionUpdateExpression = __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_extractUpdateExpressionAttributesAndNames).call(this, actions, action);
|
|
287
|
-
updateExpressions.push(actionUpdateExpression);
|
|
288
|
-
});
|
|
289
|
-
const dbParams = Object.assign({ UpdateExpression: updateExpressions.join(' ') }, __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_getUpdateExpressionOptions).call(this, options));
|
|
290
|
-
const { ExpressionAttributeValues, ExpressionAttributeNames } = queryObject;
|
|
291
|
-
if (Object.keys(ExpressionAttributeValues).length > 0) {
|
|
292
|
-
dbParams['ExpressionAttributeValues'] = Object.assign(Object.assign({}, ExpressionAttributeValues), dbParams.ExpressionAttributeValues);
|
|
282
|
+
try {
|
|
283
|
+
return await __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_prepareAndExecuteUpdateExpression).call(this, filters, actions, options);
|
|
293
284
|
}
|
|
294
|
-
|
|
295
|
-
|
|
285
|
+
catch (error) {
|
|
286
|
+
(0, errorHelper_1.PersistenceErrorWrapper)(error);
|
|
296
287
|
}
|
|
297
|
-
if (queryObject.FilterExpression)
|
|
298
|
-
dbParams['ConditionExpression'] = queryObject.FilterExpression;
|
|
299
|
-
return this.dynamoDbClientService.updateExpressions(keyObject, dbParams);
|
|
300
288
|
}
|
|
301
289
|
}
|
|
302
290
|
exports.DynamoDbCrudService = DynamoDbCrudService;
|
|
303
|
-
_DynamoDbCrudService_instances = new WeakSet(),
|
|
291
|
+
_DynamoDbCrudService_instances = new WeakSet(), _DynamoDbCrudService_prepareAndExecuteUpdateExpression = async function _DynamoDbCrudService_prepareAndExecuteUpdateExpression(filters, actions, options) {
|
|
292
|
+
const queryObject = __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_buildUpdateExpressionQuery).call(this, { filters }).get();
|
|
293
|
+
const primaryKeys = this.defaultPrimaryKeys;
|
|
294
|
+
const keyObject = __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_getKeyObjectForUpdateExpression).call(this, queryObject, primaryKeys);
|
|
295
|
+
const updateExpressions = [];
|
|
296
|
+
Object.keys(actions).forEach((action) => {
|
|
297
|
+
const actionUpdateExpression = __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_extractUpdateExpressionAttributesAndNames).call(this, actions, action);
|
|
298
|
+
updateExpressions.push(actionUpdateExpression);
|
|
299
|
+
});
|
|
300
|
+
const dbParams = Object.assign({ UpdateExpression: updateExpressions.join(' ') }, __classPrivateFieldGet(this, _DynamoDbCrudService_instances, "m", _DynamoDbCrudService_getUpdateExpressionOptions).call(this, options));
|
|
301
|
+
const { ExpressionAttributeValues, ExpressionAttributeNames } = queryObject;
|
|
302
|
+
if (Object.keys(ExpressionAttributeValues).length > 0) {
|
|
303
|
+
dbParams['ExpressionAttributeValues'] = Object.assign(Object.assign({}, ExpressionAttributeValues), dbParams.ExpressionAttributeValues);
|
|
304
|
+
}
|
|
305
|
+
if (Object.keys(ExpressionAttributeNames).length > 0) {
|
|
306
|
+
dbParams['ExpressionAttributeNames'] = Object.assign(Object.assign({}, ExpressionAttributeNames), dbParams.ExpressionAttributeNames);
|
|
307
|
+
}
|
|
308
|
+
if (queryObject.FilterExpression)
|
|
309
|
+
dbParams['ConditionExpression'] = queryObject.FilterExpression;
|
|
310
|
+
return this.dynamoDbClientService.updateExpressions(keyObject, dbParams);
|
|
311
|
+
}, _DynamoDbCrudService_buildUpdateExpressionQuery = function _DynamoDbCrudService_buildUpdateExpressionQuery(options) {
|
|
304
312
|
var _a;
|
|
305
313
|
const query = new queryBuilder_service_1.default();
|
|
306
314
|
if ((_a = options.index) === null || _a === void 0 ? void 0 : _a.indexName)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dynamoDbCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dynamoDbCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -231,12 +231,93 @@ class PostgresqlClientService extends query_service_1.default {
|
|
|
231
231
|
query(queryText, values) {
|
|
232
232
|
return this.runQuery(queryText, values);
|
|
233
233
|
}
|
|
234
|
-
async
|
|
235
|
-
// eslint-disable-next-line
|
|
236
|
-
filters,
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
234
|
+
async updateExpressionCommand(
|
|
235
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
236
|
+
filters, actions, options = {}) {
|
|
237
|
+
let query = `UPDATE ${pg_format_1.default.ident(this.dbSchema)}.${pg_format_1.default.ident(this.tableName)} SET`;
|
|
238
|
+
const set = actions.SET || [];
|
|
239
|
+
const add = actions.ADD || [];
|
|
240
|
+
const setValues = this.replacePathAndValueByAttributeNames(set, options, false);
|
|
241
|
+
const addValues = this.replacePathAndValueByAttributeNames(add, options, true);
|
|
242
|
+
const setValuesAndAddValues = setValues.concat(addValues);
|
|
243
|
+
const updateClauses = [];
|
|
244
|
+
const jsonSetExpressionGroup = {};
|
|
245
|
+
setValuesAndAddValues.forEach((expression) => {
|
|
246
|
+
const { path, value, createNewColumn } = expression;
|
|
247
|
+
if (path.includes('.')) {
|
|
248
|
+
const jsonExpr = this.getJSONBSetExpressionByAction(path, value, true);
|
|
249
|
+
const columnName = jsonExpr.columnName;
|
|
250
|
+
if (!jsonSetExpressionGroup[columnName]) {
|
|
251
|
+
jsonSetExpressionGroup[columnName] = [jsonExpr];
|
|
252
|
+
}
|
|
253
|
+
else {
|
|
254
|
+
jsonSetExpressionGroup[columnName].push(jsonExpr);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
else {
|
|
258
|
+
if (createNewColumn)
|
|
259
|
+
throw 'Set Expressions are not supported for non JSON-JSONB';
|
|
260
|
+
updateClauses.push(`${pg_format_1.default.ident(path)} = ${this.sanitizeValue(value)}`);
|
|
261
|
+
}
|
|
262
|
+
});
|
|
263
|
+
if (Object.keys(jsonSetExpressionGroup).length > 0) {
|
|
264
|
+
Object.keys(jsonSetExpressionGroup).forEach((groupIndex) => {
|
|
265
|
+
const jsonSetExpression = this.buildJSONBExpression(jsonSetExpressionGroup[groupIndex]);
|
|
266
|
+
updateClauses.push(`${groupIndex} = ${jsonSetExpression}`);
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
query += ` ${updateClauses.join(', ')}`;
|
|
270
|
+
query += ' WHERE ';
|
|
271
|
+
query += this.buildFilterClause(filters);
|
|
272
|
+
return this.runQuery(query);
|
|
273
|
+
}
|
|
274
|
+
buildJSONBExpression(jsonSetExpressions) {
|
|
275
|
+
let jsonSetStringExpr = '';
|
|
276
|
+
jsonSetExpressions.forEach((expression, index) => {
|
|
277
|
+
const { columnName, jsonExpr } = expression;
|
|
278
|
+
if (index === 0) {
|
|
279
|
+
jsonSetStringExpr = `jsonb_set(${columnName},${jsonExpr})`;
|
|
280
|
+
}
|
|
281
|
+
else {
|
|
282
|
+
jsonSetStringExpr = `jsonb_set(${jsonSetStringExpr},${jsonExpr})`;
|
|
283
|
+
}
|
|
284
|
+
});
|
|
285
|
+
return jsonSetStringExpr;
|
|
286
|
+
}
|
|
287
|
+
getJSONBSetExpressionByAction(path, value, createNewColumn) {
|
|
288
|
+
const pathSplitted = path.split('.');
|
|
289
|
+
const parentPath = pathSplitted[0];
|
|
290
|
+
const pathSerialized = pathSplitted.slice(1).join(',');
|
|
291
|
+
return {
|
|
292
|
+
jsonExpr: `'{${pathSerialized}}','${value}',${createNewColumn}`,
|
|
293
|
+
columnName: `"${parentPath}"`,
|
|
294
|
+
};
|
|
295
|
+
}
|
|
296
|
+
replacePathAndValueByAttributeNames(actions, options, createNewColumn) {
|
|
297
|
+
return actions.map((action) => {
|
|
298
|
+
action.path = this.replaceExpressionAttributeNames(action.path, options);
|
|
299
|
+
if (action.value)
|
|
300
|
+
action.value = this.replaceExpressionAttributeValues(action.value, options);
|
|
301
|
+
action.createNewColumn = createNewColumn;
|
|
302
|
+
return action;
|
|
303
|
+
});
|
|
304
|
+
}
|
|
305
|
+
replaceExpressionAttributeNames(path, options) {
|
|
306
|
+
const { expressionAttributeNames } = options;
|
|
307
|
+
Object.keys(expressionAttributeNames).forEach((attributeName) => {
|
|
308
|
+
const attributeNameValue = expressionAttributeNames[attributeName];
|
|
309
|
+
path = path.replace(attributeName, attributeNameValue);
|
|
310
|
+
});
|
|
311
|
+
return path;
|
|
312
|
+
}
|
|
313
|
+
replaceExpressionAttributeValues(value, options) {
|
|
314
|
+
const { expressionAttributeValues } = options;
|
|
315
|
+
Object.keys(expressionAttributeValues).forEach((attributeName) => {
|
|
316
|
+
const attributeNameValue = expressionAttributeValues[attributeName];
|
|
317
|
+
value = value.replace(attributeName, attributeNameValue);
|
|
318
|
+
value = typeof value == 'string' ? `\"${value}\"` : value;
|
|
319
|
+
});
|
|
320
|
+
return value;
|
|
240
321
|
}
|
|
241
322
|
}
|
|
242
323
|
exports.default = PostgresqlClientService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgreSqlClient.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlClient.service.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"postgreSqlClient.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlClient.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,7 @@ const postgreSqlClient_service_1 = __importDefault(require("./postgreSqlClient.s
|
|
|
9
9
|
const tableHelper_1 = require("../../../helpers/tableHelper");
|
|
10
10
|
const constants_1 = require("../../../utils/constants");
|
|
11
11
|
const queryHelpers_1 = require("../../../helpers/queryHelpers");
|
|
12
|
+
const errorHelper_1 = require("../../../helpers/errorHelper");
|
|
12
13
|
class PostgreSqlCrudService extends postgreSqlClient_service_1.default {
|
|
13
14
|
constructor(tableSchema) {
|
|
14
15
|
super(tableSchema);
|
|
@@ -96,8 +97,10 @@ class PostgreSqlCrudService extends postgreSqlClient_service_1.default {
|
|
|
96
97
|
runQuery(querySentence, values) {
|
|
97
98
|
return super.runQuery(querySentence, values);
|
|
98
99
|
}
|
|
99
|
-
async updateExpressions(filters, actions) {
|
|
100
|
-
|
|
100
|
+
async updateExpressions(filters, actions, options) {
|
|
101
|
+
const result = await this.updateExpressionCommand(filters, actions, options);
|
|
102
|
+
(0, errorHelper_1.PersistenceErrorWrapper)(result);
|
|
103
|
+
return result;
|
|
101
104
|
}
|
|
102
105
|
}
|
|
103
106
|
exports.PostgreSqlCrudService = PostgreSqlCrudService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgreSqlCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAuD;AACvD,0FAAiE;
|
|
1
|
+
{"version":3,"file":"postgreSqlCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
// src/helpers/tableHelper.ts
|
|
2
|
+
function getTableColumnNames(columns) {
|
|
3
|
+
return Object.keys(columns);
|
|
4
|
+
}
|
|
5
|
+
function findIdColumnName(columns) {
|
|
6
|
+
return getTableColumnNames(columns).find(
|
|
7
|
+
(columnName) => columns[columnName].columnId === true
|
|
8
|
+
);
|
|
9
|
+
}
|
|
10
|
+
function getTableName(table, property = "name") {
|
|
11
|
+
if (!table)
|
|
12
|
+
throw new Error("missing table property");
|
|
13
|
+
if (typeof table === "string")
|
|
14
|
+
return table;
|
|
15
|
+
const { name, alias } = table;
|
|
16
|
+
return property === "alias" && alias ? alias : name;
|
|
17
|
+
}
|
|
18
|
+
function getPrimaryKeyColumns(columns) {
|
|
19
|
+
return getTableColumnNames(columns).filter(
|
|
20
|
+
(columnName) => columns[columnName].primary === true
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
// src/helpers/queryHelpers.ts
|
|
25
|
+
function buildAggFunctionAlias(aggregateFunction) {
|
|
26
|
+
return `AGG_FN_${aggregateFunction}`;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
// src/error/NoRecordsAffectedException.ts
|
|
30
|
+
var NoRecordsAffectedException = class extends Error {
|
|
31
|
+
constructor() {
|
|
32
|
+
super("No records affected by update");
|
|
33
|
+
this.name = "NoRecordsAffectedException";
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
// src/helpers/errorHelper.ts
|
|
38
|
+
function PersistenceErrorWrapper(queryResult) {
|
|
39
|
+
const dynamoNoRecordsAffectedExceptions = [
|
|
40
|
+
"ConditionalCheckFailedException"
|
|
41
|
+
];
|
|
42
|
+
if (queryResult.rowCount == 0) {
|
|
43
|
+
throw new NoRecordsAffectedException();
|
|
44
|
+
} else {
|
|
45
|
+
if (queryResult.name && dynamoNoRecordsAffectedExceptions.includes(queryResult.name)) {
|
|
46
|
+
throw new NoRecordsAffectedException();
|
|
47
|
+
} else {
|
|
48
|
+
throw queryResult;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export { PersistenceErrorWrapper, buildAggFunctionAlias, findIdColumnName, getPrimaryKeyColumns, getTableName };
|
|
54
|
+
//# sourceMappingURL=out.js.map
|
|
55
|
+
//# sourceMappingURL=chunk-JJPS7Q3Y.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/helpers/tableHelper.ts","../../src/helpers/queryHelpers.ts","../../src/error/NoRecordsAffectedException.ts","../../src/helpers/errorHelper.ts"],"names":[],"mappings":";AAEO,SAAS,oBAAoB,SAAkC;AAClE,SAAO,OAAO,KAAK,OAAO;AAC9B;AAEO,SAAS,iBAAiB,SAA4C;AACzE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,aAAa;AAAA,EACrD;AACJ;AAEO,SAAS,aACZ,OACA,WAAW,QACL;AACN,MAAI,CAAC;AAAO,UAAM,IAAI,MAAM,wBAAwB;AAEpD,MAAI,OAAO,UAAU;AAAU,WAAO;AAEtC,QAAM,EAAE,MAAM,MAAM,IAAI;AACxB,SAAO,aAAa,WAAW,QAAQ,QAAQ;AACnD;AAEO,SAAS,qBAAqB,SAAkC;AACnE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,YAAY;AAAA,EACpD;AACJ;;;ACpBO,SAAS,sBACZ,mBACM;AACN,SAAO,UAAU,iBAAiB;AACtC;;;ACZO,IAAM,6BAAN,cAAyC,MAAM;AAAA,EAClD,cAAc;AACV,UAAM,+BAA+B;AACrC,SAAK,OAAO;AAAA,EAChB;AACJ;;;ACHO,SAAS,wBAAwB,aAAkB;AACtD,QAAM,oCAAoC;AAAA,IACtC;AAAA,EACJ;AAGA,MAAI,YAAY,YAAY,GAAG;AAC3B,UAAM,IAAI,2BAA2B;AAAA,EACzC,OAAO;AAEH,QACI,YAAY,QACZ,kCAAkC,SAAS,YAAY,IAAI,GAC7D;AACE,YAAM,IAAI,2BAA2B;AAAA,IACzC,OAAO;AACH,YAAM;AAAA,IACV;AAAA,EACJ;AACJ","sourcesContent":["import { ITableColumns, ITableName } from '../interfaces';\n\nexport function getTableColumnNames(columns: ITableColumns): string[] {\n return Object.keys(columns);\n}\n\nexport function findIdColumnName(columns: ITableColumns): string | undefined {\n return getTableColumnNames(columns).find(\n (columnName) => columns[columnName].columnId === true,\n );\n}\n\nexport function getTableName(\n table: string | ITableName,\n property = 'name',\n): string {\n if (!table) throw new Error('missing table property');\n\n if (typeof table === 'string') return table;\n\n const { name, alias } = table;\n return property === 'alias' && alias ? alias : name;\n}\n\nexport function getPrimaryKeyColumns(columns: ITableColumns): string[] {\n return getTableColumnNames(columns).filter(\n (columnName) => columns[columnName].primary === true,\n );\n}\n","import { AggregateFunction } from '../types';\n\nexport enum METHOD_TO_QUERY {\n where = 'where',\n filter = 'filter',\n update = 'update',\n}\n\nexport function buildAggFunctionAlias(\n aggregateFunction: AggregateFunction,\n): string {\n return `AGG_FN_${aggregateFunction}`;\n}\n","export class NoRecordsAffectedException extends Error {\n constructor() {\n super('No records affected by update');\n this.name = 'NoRecordsAffectedException';\n }\n}\n","import { NoRecordsAffectedException } from '../error/NoRecordsAffectedException';\n\nexport function PersistenceErrorWrapper(queryResult: any) {\n const dynamoNoRecordsAffectedExceptions = [\n 'ConditionalCheckFailedException',\n ];\n\n //This is for Postgres scenario, where there is not error launched by updates\n if (queryResult.rowCount == 0) {\n throw new NoRecordsAffectedException();\n } else {\n //Checks for dynamodb errors also the ones that is included in NoRecordsAffectedExceptions list\n if (\n queryResult.name &&\n dynamoNoRecordsAffectedExceptions.includes(queryResult.name)\n ) {\n throw new NoRecordsAffectedException();\n } else {\n throw queryResult;\n }\n }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { getTableName, findIdColumnName, getPrimaryKeyColumns } from './chunk-
|
|
1
|
+
import { getTableName, findIdColumnName, getPrimaryKeyColumns, PersistenceErrorWrapper } from './chunk-JJPS7Q3Y.mjs';
|
|
2
2
|
import { __privateAdd, __spreadProps, __spreadValues, FILTER_OPERATOR_MAP, DYNAMODB_OPERATORS, __privateMethod, DYNAMO_DB_UPDATE_ACTIONS } from './chunk-6MOAJFFY.mjs';
|
|
3
3
|
import { DynamoDBClient } from '@aws-sdk/client-dynamodb';
|
|
4
4
|
import { DynamoDBDocumentClient, GetCommand, QueryCommand, ScanCommand, PutCommand, UpdateCommand, DeleteCommand, BatchWriteCommand } from '@aws-sdk/lib-dynamodb';
|
|
@@ -445,10 +445,11 @@ var QueryBuilderService = class {
|
|
|
445
445
|
};
|
|
446
446
|
|
|
447
447
|
// src/services/cruds/dynamodb/dynamoDbCrud.service.ts
|
|
448
|
-
var _buildUpdateExpressionQuery, buildUpdateExpressionQuery_fn, _getKeyObjectForUpdateExpression, getKeyObjectForUpdateExpression_fn, _getUpdateExpressionOptions, getUpdateExpressionOptions_fn, _extractUpdateExpressionAttributesAndNames, extractUpdateExpressionAttributesAndNames_fn;
|
|
448
|
+
var _prepareAndExecuteUpdateExpression, prepareAndExecuteUpdateExpression_fn, _buildUpdateExpressionQuery, buildUpdateExpressionQuery_fn, _getKeyObjectForUpdateExpression, getKeyObjectForUpdateExpression_fn, _getUpdateExpressionOptions, getUpdateExpressionOptions_fn, _extractUpdateExpressionAttributesAndNames, extractUpdateExpressionAttributesAndNames_fn;
|
|
449
449
|
var DynamoDbCrudService = class {
|
|
450
450
|
constructor(tableSchema) {
|
|
451
451
|
this.tableSchema = tableSchema;
|
|
452
|
+
__privateAdd(this, _prepareAndExecuteUpdateExpression);
|
|
452
453
|
__privateAdd(this, _buildUpdateExpressionQuery);
|
|
453
454
|
__privateAdd(this, _getKeyObjectForUpdateExpression);
|
|
454
455
|
__privateAdd(this, _getUpdateExpressionOptions);
|
|
@@ -714,32 +715,40 @@ var DynamoDbCrudService = class {
|
|
|
714
715
|
}
|
|
715
716
|
}
|
|
716
717
|
async updateExpressions(filters, actions, options) {
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
Object.keys(actions).forEach((action) => {
|
|
722
|
-
const actionUpdateExpression = __privateMethod(this, _extractUpdateExpressionAttributesAndNames, extractUpdateExpressionAttributesAndNames_fn).call(this, actions, action);
|
|
723
|
-
updateExpressions.push(actionUpdateExpression);
|
|
724
|
-
});
|
|
725
|
-
const dbParams = __spreadValues({
|
|
726
|
-
UpdateExpression: updateExpressions.join(" ")
|
|
727
|
-
}, __privateMethod(this, _getUpdateExpressionOptions, getUpdateExpressionOptions_fn).call(this, options));
|
|
728
|
-
const { ExpressionAttributeValues, ExpressionAttributeNames } = queryObject;
|
|
729
|
-
if (Object.keys(ExpressionAttributeValues).length > 0) {
|
|
730
|
-
dbParams["ExpressionAttributeValues"] = __spreadValues(__spreadValues({}, ExpressionAttributeValues), dbParams.ExpressionAttributeValues);
|
|
731
|
-
}
|
|
732
|
-
if (Object.keys(ExpressionAttributeNames).length > 0) {
|
|
733
|
-
dbParams["ExpressionAttributeNames"] = __spreadValues(__spreadValues({}, ExpressionAttributeNames), dbParams.ExpressionAttributeNames);
|
|
718
|
+
try {
|
|
719
|
+
return await __privateMethod(this, _prepareAndExecuteUpdateExpression, prepareAndExecuteUpdateExpression_fn).call(this, filters, actions, options);
|
|
720
|
+
} catch (error) {
|
|
721
|
+
PersistenceErrorWrapper(error);
|
|
734
722
|
}
|
|
735
|
-
if (queryObject.FilterExpression)
|
|
736
|
-
dbParams["ConditionExpression"] = queryObject.FilterExpression;
|
|
737
|
-
return this.dynamoDbClientService.updateExpressions(
|
|
738
|
-
keyObject,
|
|
739
|
-
dbParams
|
|
740
|
-
);
|
|
741
723
|
}
|
|
742
724
|
};
|
|
725
|
+
_prepareAndExecuteUpdateExpression = new WeakSet();
|
|
726
|
+
prepareAndExecuteUpdateExpression_fn = async function(filters, actions, options) {
|
|
727
|
+
const queryObject = __privateMethod(this, _buildUpdateExpressionQuery, buildUpdateExpressionQuery_fn).call(this, { filters }).get();
|
|
728
|
+
const primaryKeys = this.defaultPrimaryKeys;
|
|
729
|
+
const keyObject = __privateMethod(this, _getKeyObjectForUpdateExpression, getKeyObjectForUpdateExpression_fn).call(this, queryObject, primaryKeys);
|
|
730
|
+
const updateExpressions = [];
|
|
731
|
+
Object.keys(actions).forEach((action) => {
|
|
732
|
+
const actionUpdateExpression = __privateMethod(this, _extractUpdateExpressionAttributesAndNames, extractUpdateExpressionAttributesAndNames_fn).call(this, actions, action);
|
|
733
|
+
updateExpressions.push(actionUpdateExpression);
|
|
734
|
+
});
|
|
735
|
+
const dbParams = __spreadValues({
|
|
736
|
+
UpdateExpression: updateExpressions.join(" ")
|
|
737
|
+
}, __privateMethod(this, _getUpdateExpressionOptions, getUpdateExpressionOptions_fn).call(this, options));
|
|
738
|
+
const { ExpressionAttributeValues, ExpressionAttributeNames } = queryObject;
|
|
739
|
+
if (Object.keys(ExpressionAttributeValues).length > 0) {
|
|
740
|
+
dbParams["ExpressionAttributeValues"] = __spreadValues(__spreadValues({}, ExpressionAttributeValues), dbParams.ExpressionAttributeValues);
|
|
741
|
+
}
|
|
742
|
+
if (Object.keys(ExpressionAttributeNames).length > 0) {
|
|
743
|
+
dbParams["ExpressionAttributeNames"] = __spreadValues(__spreadValues({}, ExpressionAttributeNames), dbParams.ExpressionAttributeNames);
|
|
744
|
+
}
|
|
745
|
+
if (queryObject.FilterExpression)
|
|
746
|
+
dbParams["ConditionExpression"] = queryObject.FilterExpression;
|
|
747
|
+
return this.dynamoDbClientService.updateExpressions(
|
|
748
|
+
keyObject,
|
|
749
|
+
dbParams
|
|
750
|
+
);
|
|
751
|
+
};
|
|
743
752
|
_buildUpdateExpressionQuery = new WeakSet();
|
|
744
753
|
buildUpdateExpressionQuery_fn = function(options) {
|
|
745
754
|
var _a;
|
|
@@ -806,4 +815,4 @@ extractUpdateExpressionAttributesAndNames_fn = function(actions, actionType) {
|
|
|
806
815
|
|
|
807
816
|
export { DynamoDbCrudService };
|
|
808
817
|
//# sourceMappingURL=out.js.map
|
|
809
|
-
//# sourceMappingURL=dynamoDbCrud.service-
|
|
818
|
+
//# sourceMappingURL=dynamoDbCrud.service-CS264IQJ.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/cruds/dynamodb/dynamoDbClient.service.ts","../../src/services/cruds/dynamodb/queryBuilderCondition.service.ts","../../src/services/cruds/dynamodb/queryBuilder.service.ts","../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":["_a","_b"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { DynamoDBClient } from '@aws-sdk/client-dynamodb';\nimport {\n DynamoDBDocumentClient,\n GetCommand,\n QueryCommand,\n PutCommand,\n UpdateCommand,\n DeleteCommand,\n GetCommandInput,\n QueryCommandInput,\n PutCommandInput,\n UpdateCommandInput,\n DeleteCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n ScanCommand,\n BatchWriteCommandInput,\n BatchWriteCommand,\n} from '@aws-sdk/lib-dynamodb';\nimport { IFilter } from '../../../interfaces';\n\nconst AWS_REGION = process.env.AWS_DEFAULT_REGION;\n\n/**\n * Ref:\n * - https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/DynamoDB/DocumentClient.html\n * - https://www.fernandomc.com/posts/eight-examples-of-fetching-data-from-dynamodb-with-node/\n */\nexport default class DynamoDbClientService {\n private tableName: string;\n protected dynamoDBClient: DynamoDBDocumentClient;\n\n constructor(tableName: string) {\n if (!tableName)\n throw new Error(\n 'The \"tableName\" is required to use a DynamoDbClientService.',\n );\n this.tableName = tableName;\n const client = new DynamoDBClient({ region: AWS_REGION });\n this.dynamoDBClient = DynamoDBDocumentClient.from(client, {\n marshallOptions: {\n removeUndefinedValues: true,\n },\n });\n }\n\n /**\n * Get an item by key\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {GetCommandInput} options\n */\n public async getByKey(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<GetCommandInput> = {},\n ) {\n const params: GetCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n const result = await this.dynamoDBClient.send(new GetCommand(params));\n return result.Item;\n }\n\n /**\n * Query a table\n * @param {QueryCommandInput} options\n */\n public async query(\n options: Omit<QueryCommandInput, 'TableName'> = {},\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: QueryCommandInput = {\n TableName: this.tableName,\n ...options,\n };\n const result: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(new QueryCommand(params));\n\n if (result.$metadata) delete result.$metadata;\n return result;\n }\n\n /**\n * Scan a table\n * @param {ScanInput} options\n */\n public async scan(\n input: ScanCommandInput,\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: ScanCommandInput = {\n ...input,\n TableName: this.tableName,\n };\n\n const command = new ScanCommand(params);\n const response: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(command);\n if (response.$metadata) delete response.$metadata;\n return response;\n }\n\n /**\n * Create/Replace a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} input\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async put(input: Record<string, any>) {\n const params: PutCommandInput = {\n TableName: this.tableName,\n Item: input,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new PutCommand(params));\n }\n\n /**\n * Update a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {UpdateCommandInput} updateObject\n */\n public async update(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n ...options,\n };\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n\n /**\n * Delete/Remove an item object\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async remove(keyObject: Record<string, any>) {\n const params: DeleteCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new DeleteCommand(params));\n }\n\n public batchWrittenPut(data: Record<string, any>) {\n const putRequests = data.map((item: any) => ({\n PutRequest: {\n Item: item,\n },\n }));\n const params = {\n RequestItems: {\n [this.tableName]: putRequests,\n },\n } as BatchWriteCommandInput;\n const insertCommand = new BatchWriteCommand(params);\n return this.dynamoDBClient.send(insertCommand);\n }\n\n private buildDeleteRequestKeys(filters: IFilter[]) {\n const deleteRequestKeys: any = {};\n filters.forEach((filter) => {\n deleteRequestKeys[filter.attribute] = filter.value;\n });\n return deleteRequestKeys;\n }\n\n async batchRemove(filterGroups: IFilter[][]): Promise<void> {\n if (!filterGroups?.length) return;\n\n const deleteRequests = filterGroups.map((filterGroup: IFilter[]) => ({\n DeleteRequest: {\n Key: this.buildDeleteRequestKeys(filterGroup),\n },\n }));\n\n const params = {\n RequestItems: {\n [this.tableName]: deleteRequests,\n },\n } as BatchWriteCommandInput;\n\n await this.dynamoDBClient.send(new BatchWriteCommand(params));\n }\n\n public async updateExpressions(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { QueryCommandInput } from '@aws-sdk/client-dynamodb';\nimport { UpdateCommandInput } from '@aws-sdk/lib-dynamodb';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\n\nexport default class QueryBuilderConditionService\n implements IQueryBuilderCondition\n{\n private query;\n private command: Pick<\n QueryCommandInput,\n | 'FilterExpression'\n | 'KeyConditionExpression'\n | 'ExpressionAttributeNames'\n | 'ExpressionAttributeValues'\n > &\n Pick<UpdateCommandInput, 'UpdateExpression'>;\n private queryFrom: METHOD_TO_QUERY | undefined;\n private tempKey: string = '';\n private tempLogicOperator: string | null = null;\n private config: any;\n private wheres: string[] = [];\n private filters: string[] = [];\n private updates: string[] = [];\n private attributeNames: Record<string, string> = {};\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private attributeValues: Record<string, any> = {};\n\n constructor(query: IQueryBuilder) {\n this.query = query;\n this.command = {};\n }\n\n public get() {\n this.build();\n return this.command;\n }\n\n public setKey(key: string) {\n this.tempKey = key;\n return this;\n }\n setTmpLogicOp(logicOp: string) {\n this.tempLogicOperator = logicOp;\n return this;\n }\n\n setConfig(config: any) {\n this.config = config;\n return this;\n }\n\n public from(methodName: METHOD_TO_QUERY) {\n this.queryFrom = methodName;\n return this;\n }\n\n eq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} = ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notEq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <> ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n contains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notContains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `NOT contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n in(keyValue: any) {\n const keyValues = Array.isArray(keyValue) ? keyValue : [keyValue];\n const { key, value } = this.generateKeyValue(keyValues);\n let expression: any = `${key} IN (${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n beginsWith(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `begins_with(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n project(keyValue: string): string {\n const key = `#${keyValue}`;\n this.attributeNames[key] = keyValue;\n return key;\n }\n\n gt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} > ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n gte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} >= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} < ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_not_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_not_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n between(keyValues: any) {\n const isValidValues =\n Array.isArray(keyValues) && keyValues?.length === 2;\n if (!isValidValues)\n throw new Error(\n 'The value for between filter operator should be an Array with 2 values.',\n );\n\n const { key, value } = this.generateKeyValue(keyValues, ' AND');\n let expression: any = `${key} between ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n private setExpression(expression: string): void {\n switch (this.queryFrom) {\n case METHOD_TO_QUERY.filter:\n this.filters.push(expression);\n break;\n case METHOD_TO_QUERY.update:\n this.updates.push(expression);\n break;\n default:\n this.wheres.push(expression);\n break;\n }\n }\n\n private generateKeyValue(\n value: string[] | string,\n separatorCharacter: string | null = ',',\n omitAttributeValues: boolean = false,\n ): {\n key: string;\n value: string;\n } {\n const keyExpression = `#${this.tempKey}1`;\n\n this.attributeNames[keyExpression] = this.tempKey;\n\n if (Array.isArray(value)) {\n const valueExpressions = value.map((val, index) => {\n let valueExpression = `:${this.tempKey}${index + 1}1`;\n for (const [i] of Object.entries(this.attributeValues)) {\n if (i === valueExpression) valueExpression += '1';\n }\n this.attributeValues[valueExpression] = val;\n return valueExpression;\n });\n return {\n key: keyExpression,\n value: valueExpressions.join(`${separatorCharacter} `),\n };\n } else {\n let valueExpression = `:${this.tempKey}1`;\n if (valueExpression in this.attributeValues) {\n for (const [index] of Object.entries(this.attributeValues)) {\n if (index === valueExpression) valueExpression += '1';\n }\n }\n if (!omitAttributeValues)\n this.attributeValues[valueExpression] = value;\n return { key: keyExpression, value: valueExpression };\n }\n }\n\n private build(): void {\n if (this.wheres.length > 0) {\n const keyConditionExpression = this.wheres.join(' AND ');\n this.command['KeyConditionExpression'] = keyConditionExpression;\n }\n if (this.filters.length > 0) {\n let filterExpression = '';\n\n this.filters?.forEach((filter: any, index) => {\n if (filter?.logicOperator) {\n if (filter?.config?.openExpression) {\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, ` ${filter.config.parentKey} (`);\n if (filterExpression === '') filterExpression += '('\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n } else if (filter?.config?.closeExpression) {\n filterExpression += `${filter.expression}) ${filter.config.parentKey} `; \n } else {\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n }\n }\n });\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, '');\n this.command['FilterExpression'] = filterExpression;\n }\n if (this.updates.length > 0) {\n const filterExpression = this.updates.join(', ');\n this.command['UpdateExpression'] = `SET ${filterExpression}`;\n }\n if (Object.values(this.attributeNames).length > 0)\n this.command['ExpressionAttributeNames'] = this.attributeNames;\n\n if (Object.values(this.attributeValues).length > 0)\n this.command['ExpressionAttributeValues'] = this.attributeValues;\n }\n}\n","import { QueryCommandInput, ScanCommandInput } from '@aws-sdk/client-dynamodb';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\nimport QueryBuilderConditionService from './queryBuilderCondition.service';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\n\nexport default class QueryBuilderService implements IQueryBuilder {\n private command: Omit<QueryCommandInput & ScanCommandInput, 'TableName'>;\n private condition: IQueryBuilderCondition;\n\n constructor(private useScan = false) {\n this.command = {};\n\n this.condition = new QueryBuilderConditionService(this);\n }\n\n get() {\n const condition = this.condition.get();\n return { ...this.command, ...condition };\n }\n\n limit(num: number): IQueryBuilder {\n this.command.Limit = num;\n return this;\n }\n\n usingIndex(indexName: string): IQueryBuilder {\n this.command.IndexName = indexName;\n return this;\n }\n\n ascending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = true;\n return this;\n }\n\n descending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = false;\n return this;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n startKey(lastEvaluatedKey: Record<string, any>): IQueryBuilder {\n this.command.ExclusiveStartKey = lastEvaluatedKey;\n return this;\n }\n\n projection(fields: string[] = []) {\n if (!fields.length) return this;\n\n const expression: string[] = [];\n fields.forEach((field) => {\n const key = this.condition.project(field);\n expression.push(key);\n });\n this.command.ProjectionExpression = expression.join(',');\n return this;\n }\n\n where(keyName: string): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(null)\n .from(METHOD_TO_QUERY.where);\n return this.condition;\n }\n\n filter(\n keyName: string,\n logicOperator: string = 'AND',\n config?: any\n ): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(logicOperator)\n .setConfig(config)\n .from(METHOD_TO_QUERY.filter);\n return this.condition;\n }\n\n update(attribute: Record<string, string>): IQueryBuilder {\n for (const [key, value] of Object.entries(attribute)) {\n this.condition.setKey(key).from(METHOD_TO_QUERY.update);\n this.condition.eq(value);\n }\n return this;\n }\n\n consistentRead(consistentRead: boolean): IQueryBuilder {\n this.command.ConsistentRead = consistentRead;\n return this;\n }\n\n count(): IQueryBuilder {\n this.command.Select = AGGREGATE_FUNCTIONS.COUNT;\n return this;\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport DynamoDbClientService from './dynamoDbClient.service';\nimport QueryBuilderService from './queryBuilder.service';\n\nimport {\n AGGREGATE_FUNCTIONS,\n DYNAMODB_OPERATORS,\n FILTER_OPERATOR_MAP,\n DYNAMO_DB_UPDATE_ACTIONS,\n} from '../../../utils/constants';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindPagination,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas/crudSchema';\nimport {\n findIdColumnName,\n getPrimaryKeyColumns,\n getTableName,\n} from '../../../helpers/tableHelper';\nimport { PersistenceErrorWrapper } from '../../../helpers/errorHelper';\nimport {\n QueryCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n} from '@aws-sdk/lib-dynamodb';\n\nexport class DynamoDbCrudService<T> implements ICrudService<T> {\n private dynamoDbClientService: DynamoDbClientService;\n\n constructor(private tableSchema: typeof CrudSchema) {\n this.dynamoDbClientService = new DynamoDbClientService(this.tableName);\n }\n\n private get tableName(): string {\n return getTableName(this.tableSchema.table);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n private get defaultPrimaryKeys(): string[] {\n return getPrimaryKeyColumns(this.tableSchema.columns);\n }\n\n async create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const response =\n await this.dynamoDbClientService.batchWrittenPut(data);\n return {\n unprocessedItems: response.UnprocessedItems ?? [],\n };\n } else {\n await this.dynamoDbClientService.put(data as Record<string, any>);\n return data as T;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars, no-unused-vars\n runQuery(queryCommand: any): Promise<any> {\n throw new Error('Method not implemented.');\n }\n\n find(options: IFindOptions = {}): Promise<any> {\n const query = new QueryBuilderService(options.useScan);\n\n if (options.index?.indexName)\n query.usingIndex(options.index?.indexName);\n\n this.applySorting(query, options.sorting, options.index?.indexName);\n this.applyPagination(query, options.pagination);\n\n if (options.consistentRead)\n query.consistentRead(options.consistentRead);\n\n if (options.fields) query.projection(options.fields);\n\n this.applyFilters(query, options);\n\n if (options.aggregateFunction === AGGREGATE_FUNCTIONS.COUNT)\n query.count();\n\n return this.fetchResults(\n query.get(),\n options.pagination?.limit,\n options.useScan,\n ).then((res: any) => {\n const pagination: IFindPagination = {};\n if (res.lastEvaluatedKey) pagination.from = res.lastEvaluatedKey;\n if (options.pagination?.limit)\n pagination.limit = options.pagination?.limit;\n return {\n items: res.items,\n pagination,\n count: res.count,\n };\n });\n }\n\n async fetchResults(\n command: ScanCommandInput | QueryCommandInput,\n limit: number = 100,\n useScan: boolean = false,\n ): Promise<unknown> {\n let results: unknown[] = [];\n let lastEvaluatedKey: Record<string, unknown> = {};\n let rowsCount = 0;\n\n do {\n const result = await this.fetchBatch(\n command,\n useScan,\n lastEvaluatedKey,\n );\n const rows = result.Items ?? [];\n results = results.concat(rows);\n lastEvaluatedKey = result.LastEvaluatedKey ?? {};\n rowsCount += result.Count || rows.length;\n } while (rowsCount < limit && this.isNotEmptyObject(lastEvaluatedKey));\n\n const encryptedLastEvaluatedKey = this.isNotEmptyObject(\n lastEvaluatedKey,\n )\n ? this.encryptPaginationKey(lastEvaluatedKey)\n : null;\n return {\n items: results,\n lastEvaluatedKey: encryptedLastEvaluatedKey,\n count: rowsCount,\n };\n }\n\n async fetchBatch(\n command: ScanCommandInput | QueryCommandInput,\n useScan: boolean,\n lastEvaluatedKey: Record<string, unknown>,\n ): Promise<Partial<QueryCommandOutput>> {\n if (this.isNotEmptyObject(lastEvaluatedKey))\n command.ExclusiveStartKey = lastEvaluatedKey;\n\n const result = await (useScan\n ? this.dynamoDbClientService.scan(command)\n : this.dynamoDbClientService.query(command));\n\n if (command.Select !== AGGREGATE_FUNCTIONS.COUNT) {\n command.Limit = (command.Limit ?? 0) - (result.Items?.length ?? 0);\n }\n\n return result;\n }\n\n applyPagination(\n query: QueryBuilderService,\n pagination: IFindPagination | undefined,\n ) {\n if (pagination?.limit) query.limit(pagination.limit);\n if (pagination?.from)\n query.startKey(this.decryptPaginationKey(pagination.from));\n }\n\n async findAll(\n options: IFindOptions = {},\n allResults: any[] = [],\n rowsCount: number = 0,\n ): Promise<any> {\n const { items, pagination, count } = await this.find(options);\n allResults.push(...items);\n rowsCount += count;\n\n if (pagination?.from)\n await this.findAll({ ...options, pagination }, allResults);\n\n return {\n items: allResults,\n pagination: null,\n count: rowsCount,\n };\n }\n\n async findCount(options: IFindOptions = {}): Promise<number> {\n const findOptions = {\n ...options,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n };\n if (options.pagination?.from) {\n return this.find(findOptions).then((res) => res.count);\n } else {\n return this.findAll(findOptions).then((res) => res.count);\n }\n }\n\n buildFindItemQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n\n this.applyFilters(query, options);\n query.projection(options.fields);\n query.limit(1);\n\n return query;\n }\n\n findItem(options: IFindOptions): Promise<T | null> {\n const query = this.buildFindItemQuery(options);\n return this.dynamoDbClientService.query(query.get()).then((result) => {\n if (result.Items?.length) return result.Items[0] as T;\n if (options.throwErrorIfNull) throw new Error('NOT_FOUND');\n return null;\n });\n }\n\n applyWhereFilter(query: QueryBuilderService, filter: IFilter) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.where(filter.attribute) as any)[operator](filter.value);\n }\n\n applyFilterFilter(\n query: QueryBuilderService,\n filter: IFilter,\n logicOperator: string = 'AND',\n config?: any,\n ) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.filter(filter.attribute, logicOperator, config) as any)[\n operator\n ](filter.value);\n }\n\n applyFilters(query: QueryBuilderService, options: IFindOptions) {\n if (Array.isArray(options.filters)) {\n this.applySimpleFilters(query, options);\n } else {\n this.applyCompoundFilters(query, options);\n }\n }\n\n applySimpleFilters(query: QueryBuilderService, options: IFindOptions) {\n const queryIndexColumns = options.index?.columns ?? [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties: string[] = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n const filters = options.filters as IFilter[];\n filters.forEach((filter: IFilter) => {\n const isWhereProperty = whereProperties.includes(filter.attribute);\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, filter)\n : this.applyFilterFilter(query, filter);\n });\n }\n\n applyCompoundFilters(query: QueryBuilderService, options: IFindOptions) {\n if (!options.filters) return;\n this.buildFilterExpression(query, options);\n }\n\n buildFilterExpression(\n query: QueryBuilderService,\n options: IFindOptions,\n parentKey?: string,\n ) {\n const compositeFilters = options.filters as ICompositeFilter;\n const queryIndexColumns = options.index?.columns || [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n\n for (const [key, value] of Object.entries(compositeFilters)) {\n value.forEach(\n (filter: IFilter | ICompositeFilter, index: number) => {\n const isCompositeFilter = 'OR' in filter || 'AND' in filter;\n if (isCompositeFilter) {\n const newOptions = {\n ...options,\n filters: filter,\n };\n this.buildFilterExpression(query, newOptions, key);\n } else {\n const simpleFilter = filter as IFilter;\n const isWhereProperty = whereProperties.includes(\n simpleFilter.attribute,\n );\n let config;\n if (parentKey) {\n config = {\n parentKey,\n openExpression: index === 0,\n closeExpression: index === value.length - 1,\n };\n }\n\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, simpleFilter)\n : this.applyFilterFilter(\n query,\n simpleFilter,\n key,\n config,\n );\n }\n },\n );\n }\n }\n\n applySorting(query: QueryBuilderService, sorting: any, sortIndex?: string) {\n if (sorting?.length) {\n if (sortIndex) query.usingIndex(sortIndex);\n if (sorting[0].direction === 'DESC') {\n query.descending();\n } else {\n query.ascending();\n }\n }\n }\n\n isNotEmptyObject(obj: unknown) {\n return (\n obj !== null &&\n typeof obj === 'object' &&\n Object.keys(obj).length > 0\n );\n }\n\n encryptPaginationKey(key: Record<string, any>): string {\n const jsonKey = JSON.stringify(key);\n return Buffer.from(jsonKey).toString('base64');\n }\n\n decryptPaginationKey(encodedKey: string): Record<string, any> {\n const decodedKey = Buffer.from(encodedKey, 'base64').toString('utf-8');\n return JSON.parse(decodedKey);\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n { replace = false },\n ): Promise<any> {\n const savedRecord = await this.findItem({\n filters: filters as IFilter[],\n });\n\n if (replace) {\n //delete all attributes of savedRecord except those that as marked as primary columns in the schema\n }\n\n const newData: any = {\n ...savedRecord,\n ...data,\n };\n\n await this.dynamoDbClientService.put(newData);\n return newData;\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ) {\n if (options?.filterGroups) {\n await this.dynamoDbClientService.batchRemove(\n filters as IFilter[][],\n );\n } else {\n const key = (filters as IFilter[]).reduce((obj: any, item: any) => {\n const property = item.attribute;\n obj[property] = item.value;\n return obj;\n }, {});\n await this.dynamoDbClientService.remove(key);\n }\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n try {\n return await this.#prepareAndExecuteUpdateExpression(\n filters,\n actions,\n options,\n );\n } catch (error: any) {\n PersistenceErrorWrapper(error);\n }\n }\n\n async #prepareAndExecuteUpdateExpression(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ) {\n const queryObject = this.#buildUpdateExpressionQuery({ filters }).get();\n const primaryKeys = this.defaultPrimaryKeys;\n\n const keyObject: any = this.#getKeyObjectForUpdateExpression(\n queryObject,\n primaryKeys,\n );\n\n const updateExpressions: any = [];\n\n Object.keys(actions).forEach((action: string) => {\n const actionUpdateExpression =\n this.#extractUpdateExpressionAttributesAndNames(\n actions,\n action,\n );\n updateExpressions.push(actionUpdateExpression);\n });\n\n const dbParams = {\n UpdateExpression: updateExpressions.join(' '),\n ...this.#getUpdateExpressionOptions(options),\n };\n\n const { ExpressionAttributeValues, ExpressionAttributeNames } =\n queryObject;\n if (Object.keys(ExpressionAttributeValues).length > 0) {\n dbParams['ExpressionAttributeValues'] = {\n ...ExpressionAttributeValues,\n ...dbParams.ExpressionAttributeValues,\n };\n }\n\n if (Object.keys(ExpressionAttributeNames).length > 0) {\n dbParams['ExpressionAttributeNames'] = {\n ...ExpressionAttributeNames,\n ...dbParams.ExpressionAttributeNames,\n };\n }\n if (queryObject.FilterExpression)\n dbParams['ConditionExpression'] = queryObject.FilterExpression;\n\n return this.dynamoDbClientService.updateExpressions(\n keyObject,\n dbParams,\n );\n }\n\n #buildUpdateExpressionQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n this.applyFilters(query, options);\n\n return query;\n }\n\n #getKeyObjectForUpdateExpression(queryObject: any, primaryKeys: any) {\n const keyObject: any = {};\n\n Object.keys(queryObject.ExpressionAttributeNames).forEach(\n (attribute) => {\n const sanitizedAttribute = attribute\n .replace('#', '')\n .replace('1', '');\n if (primaryKeys.includes(sanitizedAttribute)) {\n const valueName = `:${sanitizedAttribute}1`;\n keyObject[sanitizedAttribute] =\n queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeNames[attribute];\n }\n },\n );\n\n return keyObject;\n }\n\n #getUpdateExpressionOptions(options: IUpdateExpressionsOptions) {\n const updateExprOptions: any = {\n ReturnValues: options.returnValues,\n };\n\n if (options.expressionAttributeNames)\n updateExprOptions.ExpressionAttributeNames =\n options.expressionAttributeNames;\n if (options.expressionAttributeValues)\n updateExprOptions.ExpressionAttributeValues =\n options.expressionAttributeValues;\n\n return updateExprOptions;\n }\n\n #extractUpdateExpressionAttributesAndNames(\n actions: any,\n actionType: string,\n ) {\n const actionUpdateExpressions: any = [];\n\n actions[actionType].forEach((action: any) => {\n switch (actionType) {\n case DYNAMO_DB_UPDATE_ACTIONS.DELETE:\n case DYNAMO_DB_UPDATE_ACTIONS.REMOVE:\n actionUpdateExpressions.push(`${action.path}`);\n break;\n\n case DYNAMO_DB_UPDATE_ACTIONS.ADD:\n case DYNAMO_DB_UPDATE_ACTIONS.SET:\n {\n let operator = '';\n if (actionType == DYNAMO_DB_UPDATE_ACTIONS.SET)\n operator = '=';\n actionUpdateExpressions.push(\n `${action.path} ${operator}${action.value}`,\n );\n }\n break;\n }\n });\n\n const actionUpdateExpression = `${actionType} ${actionUpdateExpressions.join(\n ', ',\n )}`;\n\n return actionUpdateExpression;\n }\n}\n"]}
|
package/dist/esm/index.d.mts
CHANGED
|
@@ -87,8 +87,8 @@ interface IUpdateExpressions {
|
|
|
87
87
|
interface IUpdateExpressionsOptions {
|
|
88
88
|
returnValues?: string;
|
|
89
89
|
conditionExpression?: string;
|
|
90
|
-
expressionAttributeNames?:
|
|
91
|
-
expressionAttributeValues?:
|
|
90
|
+
expressionAttributeNames?: any;
|
|
91
|
+
expressionAttributeValues?: any;
|
|
92
92
|
}
|
|
93
93
|
|
|
94
94
|
interface ICrudService<T> {
|
package/dist/esm/index.mjs
CHANGED
|
@@ -29,10 +29,10 @@ var CrudFactory = class {
|
|
|
29
29
|
const isMultiPlatformMode2 = ((_a = process.env.PLATFORM_TYPE) == null ? void 0 : _a.toLowerCase()) === "container";
|
|
30
30
|
let DatabaseCrudService;
|
|
31
31
|
if (isMultiPlatformMode2) {
|
|
32
|
-
const module = await import('./postgreSqlCrud.service-
|
|
32
|
+
const module = await import('./postgreSqlCrud.service-3ILHEXDN.mjs');
|
|
33
33
|
DatabaseCrudService = module.PostgreSqlCrudService;
|
|
34
34
|
} else {
|
|
35
|
-
const module = await import('./dynamoDbCrud.service-
|
|
35
|
+
const module = await import('./dynamoDbCrud.service-CS264IQJ.mjs');
|
|
36
36
|
DatabaseCrudService = module.DynamoDbCrudService;
|
|
37
37
|
}
|
|
38
38
|
return new DatabaseCrudService(crudSchema, poolClient);
|
package/dist/esm/{postgreSqlCrud.service-OEY7OEML.mjs → postgreSqlCrud.service-3ILHEXDN.mjs}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { findIdColumnName, buildAggFunctionAlias, getTableName } from './chunk-
|
|
1
|
+
import { findIdColumnName, buildAggFunctionAlias, PersistenceErrorWrapper, getTableName } from './chunk-JJPS7Q3Y.mjs';
|
|
2
2
|
import { __spreadValues, __spreadProps, DEFAULT_PG_SCHEMA, POSTGRES_FILTER_OPERATOR_MAP } from './chunk-6MOAJFFY.mjs';
|
|
3
3
|
import format from 'pg-format';
|
|
4
4
|
import { Client } from 'pg';
|
|
@@ -285,8 +285,116 @@ var PostgresqlClientService = class extends QueryService {
|
|
|
285
285
|
query(queryText, values) {
|
|
286
286
|
return this.runQuery(queryText, values);
|
|
287
287
|
}
|
|
288
|
-
async
|
|
289
|
-
|
|
288
|
+
async updateExpressionCommand(filters, actions, options = {}) {
|
|
289
|
+
let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(
|
|
290
|
+
this.tableName
|
|
291
|
+
)} SET`;
|
|
292
|
+
const set = actions.SET || [];
|
|
293
|
+
const add = actions.ADD || [];
|
|
294
|
+
const setValues = this.replacePathAndValueByAttributeNames(
|
|
295
|
+
set,
|
|
296
|
+
options,
|
|
297
|
+
false
|
|
298
|
+
);
|
|
299
|
+
const addValues = this.replacePathAndValueByAttributeNames(
|
|
300
|
+
add,
|
|
301
|
+
options,
|
|
302
|
+
true
|
|
303
|
+
);
|
|
304
|
+
const setValuesAndAddValues = setValues.concat(addValues);
|
|
305
|
+
const updateClauses = [];
|
|
306
|
+
const jsonSetExpressionGroup = {};
|
|
307
|
+
setValuesAndAddValues.forEach((expression) => {
|
|
308
|
+
const { path, value, createNewColumn } = expression;
|
|
309
|
+
if (path.includes(".")) {
|
|
310
|
+
const jsonExpr = this.getJSONBSetExpressionByAction(
|
|
311
|
+
path,
|
|
312
|
+
value,
|
|
313
|
+
true
|
|
314
|
+
);
|
|
315
|
+
const columnName = jsonExpr.columnName;
|
|
316
|
+
if (!jsonSetExpressionGroup[columnName]) {
|
|
317
|
+
jsonSetExpressionGroup[columnName] = [jsonExpr];
|
|
318
|
+
} else {
|
|
319
|
+
jsonSetExpressionGroup[columnName].push(jsonExpr);
|
|
320
|
+
}
|
|
321
|
+
} else {
|
|
322
|
+
if (createNewColumn)
|
|
323
|
+
throw "Set Expressions are not supported for non JSON-JSONB";
|
|
324
|
+
updateClauses.push(
|
|
325
|
+
`${format.ident(path)} = ${this.sanitizeValue(value)}`
|
|
326
|
+
);
|
|
327
|
+
}
|
|
328
|
+
});
|
|
329
|
+
if (Object.keys(jsonSetExpressionGroup).length > 0) {
|
|
330
|
+
Object.keys(jsonSetExpressionGroup).forEach((groupIndex) => {
|
|
331
|
+
const jsonSetExpression = this.buildJSONBExpression(
|
|
332
|
+
jsonSetExpressionGroup[groupIndex]
|
|
333
|
+
);
|
|
334
|
+
updateClauses.push(`${groupIndex} = ${jsonSetExpression}`);
|
|
335
|
+
});
|
|
336
|
+
}
|
|
337
|
+
query += ` ${updateClauses.join(", ")}`;
|
|
338
|
+
query += " WHERE ";
|
|
339
|
+
query += this.buildFilterClause(filters);
|
|
340
|
+
return this.runQuery(query);
|
|
341
|
+
}
|
|
342
|
+
buildJSONBExpression(jsonSetExpressions) {
|
|
343
|
+
let jsonSetStringExpr = "";
|
|
344
|
+
jsonSetExpressions.forEach((expression, index) => {
|
|
345
|
+
const { columnName, jsonExpr } = expression;
|
|
346
|
+
if (index === 0) {
|
|
347
|
+
jsonSetStringExpr = `jsonb_set(${columnName},${jsonExpr})`;
|
|
348
|
+
} else {
|
|
349
|
+
jsonSetStringExpr = `jsonb_set(${jsonSetStringExpr},${jsonExpr})`;
|
|
350
|
+
}
|
|
351
|
+
});
|
|
352
|
+
return jsonSetStringExpr;
|
|
353
|
+
}
|
|
354
|
+
getJSONBSetExpressionByAction(path, value, createNewColumn) {
|
|
355
|
+
const pathSplitted = path.split(".");
|
|
356
|
+
const parentPath = pathSplitted[0];
|
|
357
|
+
const pathSerialized = pathSplitted.slice(1).join(",");
|
|
358
|
+
return {
|
|
359
|
+
jsonExpr: `'{${pathSerialized}}','${value}',${createNewColumn}`,
|
|
360
|
+
columnName: `"${parentPath}"`
|
|
361
|
+
};
|
|
362
|
+
}
|
|
363
|
+
replacePathAndValueByAttributeNames(actions, options, createNewColumn) {
|
|
364
|
+
return actions.map((action) => {
|
|
365
|
+
action.path = this.replaceExpressionAttributeNames(
|
|
366
|
+
action.path,
|
|
367
|
+
options
|
|
368
|
+
);
|
|
369
|
+
if (action.value)
|
|
370
|
+
action.value = this.replaceExpressionAttributeValues(
|
|
371
|
+
action.value,
|
|
372
|
+
options
|
|
373
|
+
);
|
|
374
|
+
action.createNewColumn = createNewColumn;
|
|
375
|
+
return action;
|
|
376
|
+
});
|
|
377
|
+
}
|
|
378
|
+
replaceExpressionAttributeNames(path, options) {
|
|
379
|
+
const { expressionAttributeNames } = options;
|
|
380
|
+
Object.keys(expressionAttributeNames).forEach(
|
|
381
|
+
(attributeName) => {
|
|
382
|
+
const attributeNameValue = expressionAttributeNames[attributeName];
|
|
383
|
+
path = path.replace(attributeName, attributeNameValue);
|
|
384
|
+
}
|
|
385
|
+
);
|
|
386
|
+
return path;
|
|
387
|
+
}
|
|
388
|
+
replaceExpressionAttributeValues(value, options) {
|
|
389
|
+
const { expressionAttributeValues } = options;
|
|
390
|
+
Object.keys(expressionAttributeValues).forEach(
|
|
391
|
+
(attributeName) => {
|
|
392
|
+
const attributeNameValue = expressionAttributeValues[attributeName];
|
|
393
|
+
value = value.replace(attributeName, attributeNameValue);
|
|
394
|
+
value = typeof value == "string" ? `"${value}"` : value;
|
|
395
|
+
}
|
|
396
|
+
);
|
|
397
|
+
return value;
|
|
290
398
|
}
|
|
291
399
|
};
|
|
292
400
|
|
|
@@ -380,11 +488,17 @@ var PostgreSqlCrudService = class extends PostgresqlClientService {
|
|
|
380
488
|
runQuery(querySentence, values) {
|
|
381
489
|
return super.runQuery(querySentence, values);
|
|
382
490
|
}
|
|
383
|
-
async updateExpressions(filters, actions) {
|
|
384
|
-
|
|
491
|
+
async updateExpressions(filters, actions, options) {
|
|
492
|
+
const result = await this.updateExpressionCommand(
|
|
493
|
+
filters,
|
|
494
|
+
actions,
|
|
495
|
+
options
|
|
496
|
+
);
|
|
497
|
+
PersistenceErrorWrapper(result);
|
|
498
|
+
return result;
|
|
385
499
|
}
|
|
386
500
|
};
|
|
387
501
|
|
|
388
502
|
export { PostgreSqlCrudService };
|
|
389
503
|
//# sourceMappingURL=out.js.map
|
|
390
|
-
//# sourceMappingURL=postgreSqlCrud.service-
|
|
504
|
+
//# sourceMappingURL=postgreSqlCrud.service-3ILHEXDN.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/cruds/postgresql/postgreSqlClient.service.ts","../../src/services/cruds/postgresql/connection.service.ts","../../src/services/cruds/postgresql/query.service.ts","../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable no-console */\n\nimport format from 'pg-format';\nimport { QueryResult } from 'pg';\nimport {\n AggregateFunction,\n DbPoolClient,\n FilterLogicOperator,\n} from '../../../types';\nimport {\n ICompositeFilter,\n IFilter,\n IFindOptions,\n IFindPagination,\n ISorting,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport QueryService from './query.service';\nimport {\n FILTER_LOGIC_OPERATORS,\n SORT_DIRECTIONS,\n POSTGRES_FILTER_OPERATOR_MAP,\n DEFAULT_PG_SCHEMA,\n FilterOperator,\n} from '../../../utils/constants';\nimport { CrudSchema } from '../../../schemas';\nimport { getTableName } from '../../../helpers/tableHelper';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\n\nexport default class PostgresqlClientService<T> extends QueryService {\n private crudSchema: typeof CrudSchema;\n constructor(tableSchema: typeof CrudSchema, poolClient?: DbPoolClient) {\n super(poolClient);\n this.crudSchema = tableSchema;\n }\n\n get dbSchema() {\n return this.crudSchema.schema || DEFAULT_PG_SCHEMA;\n }\n\n get tableName() {\n return (\n getTableName(this.crudSchema.table, 'alias') ||\n getTableName(this.crudSchema.table)\n );\n }\n\n getWildcardValue(operator: FilterOperator, value: string): string {\n if (\n operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS\n ) {\n return '%' + value + '%';\n } else if (operator === FilterOperator.STARTS_WITH) {\n return value + '%';\n } else {\n return value;\n }\n }\n\n private buildClause(\n operator: FilterOperator,\n attribute: string,\n value: any,\n ): string {\n const formattedValue = format.literal(value);\n operator = operator\n ? (operator.toUpperCase() as FilterOperator)\n : FilterOperator.EQUAL;\n const postgresOperator = POSTGRES_FILTER_OPERATOR_MAP[operator];\n\n if (!postgresOperator)\n throw new Error(`Unsupported filter operator: ${operator}`);\n\n const filterProperty = format.ident(attribute);\n const columnExists = !!this.crudSchema.columns[attribute];\n const property = columnExists\n ? filterProperty\n : `(\"qvAttributes\" ->> '${attribute}')`;\n\n if (operator === FilterOperator.IN) {\n const formattedValues = Array.isArray(value)\n ? value.map(format.literal)\n : [formattedValue];\n return `${property} ${postgresOperator} (${formattedValues.join(\n ', ',\n )})`;\n }\n\n if (operator === FilterOperator.BETWEEN) {\n return `${property} ${postgresOperator} ${value[0]} AND ${value[1]}`;\n }\n\n /**\n * ? Additional filter to avoid error when column accepts null values.\n */\n if (operator === FilterOperator.NOT_EQUAL && value !== null) {\n return `(${property} ${postgresOperator} ${format.literal(\n value,\n )} OR ${property} IS NULL)`;\n }\n\n if (\n operator === FilterOperator.NOT_EXIST ||\n operator === FilterOperator.EXIST\n ) {\n return `${property} ${postgresOperator}`;\n }\n\n const wildcardValue = this.getWildcardValue(operator, value);\n return `${property} ${postgresOperator} ${format.literal(\n wildcardValue,\n )}`;\n }\n\n private buildFilterClause(\n filters: IFilter[] | ICompositeFilter,\n logicOperator?: FilterLogicOperator,\n ): string {\n if (Array.isArray(filters)) {\n const filterClauses = filters.map((filter) => {\n return this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.value,\n );\n });\n return filterClauses.join(\n ` ${logicOperator ?? FILTER_LOGIC_OPERATORS.AND} `,\n );\n } else {\n return this.buildQueryByClause(filters);\n }\n }\n\n private isCompositeFilter = function (value: any) {\n return 'OR' in value || 'AND' in value;\n };\n\n buildQueryByClause(filters: IFilter[] | ICompositeFilter): string {\n let filterClauses: string = '';\n let isFirstFilter = true;\n\n for (const [key, value] of Object.entries(filters)) {\n if (!isFirstFilter) {\n filterClauses += key === 'AND' ? ' AND ' : ' OR ';\n }\n\n if (this.isCompositeFilter(value)) {\n filterClauses += '(';\n filterClauses += this.buildQueryByClause(\n value as ICompositeFilter,\n );\n filterClauses += ')';\n } else {\n (value as IFilter[]).forEach((filter: IFilter) => {\n let clause = '';\n if (this.isCompositeFilter(filter)) {\n clause = `(${this.buildQueryByClause(\n filter as ICompositeFilter,\n )})`;\n } else {\n clause = this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.value,\n );\n }\n filterClauses += `${clause} ${key} `;\n });\n }\n\n isFirstFilter = false;\n }\n\n filterClauses = filterClauses.replace(/\\s+(AND|OR)\\s*$/, '');\n return filterClauses;\n }\n\n private formatOrderByItem(sort: ISorting): string {\n return `${format.ident(sort.column)} ${\n sort.direction || SORT_DIRECTIONS.ASC\n }`;\n }\n\n private buildOrderByClause(querySorting: ISorting[]): string {\n try {\n return querySorting.map(this.formatOrderByItem).join(', ');\n } catch (error) {\n return '';\n }\n }\n\n async createCommand(data: any[]): Promise<any> {\n const keys = Object.keys(data[0]); // Assuming all objects have the same keys\n const values = data.map((item) => Object.values(item));\n\n const query = format(\n `INSERT INTO ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} (%I) VALUES %L RETURNING *;`,\n keys,\n values,\n );\n\n return this.runQuery(query);\n }\n\n private addFiltersToQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ): string {\n if (filters) query += ` WHERE ${this.buildFilterClause(filters)}`;\n return query;\n }\n\n addOrderByToQuery(query: string, orderBy?: ISorting[]): string {\n if (orderBy) query += ` ORDER BY ${this.buildOrderByClause(orderBy)}`;\n return query;\n }\n\n private addPaginationToQuery(\n query: string,\n pagination?: IFindPagination,\n ): string {\n if (pagination) {\n const { limit, from } = pagination;\n if (limit) query += ` LIMIT ${limit}`;\n if (from) query += ` OFFSET ${from}`;\n }\n return query;\n }\n\n private getSelectClause(\n aggregateFunction: AggregateFunction | undefined,\n fields: string[] = [],\n ) {\n if (aggregateFunction)\n return `CAST(${aggregateFunction}(1) AS INTEGER) AS \"${buildAggFunctionAlias(\n aggregateFunction,\n )}\"`;\n if (!fields?.length) return '*';\n\n return this.parseFields(fields).join(', ');\n }\n\n private parseFields(fields: String[]): String[] {\n const columnsFromSchema: String[] = Object.keys(\n this.crudSchema.columns,\n );\n const attributes: String[] = fields\n .filter((field) => columnsFromSchema.indexOf(field) !== -1)\n .map((field) => `\"${field}\"`);\n\n fields\n .filter((field) => columnsFromSchema.indexOf(field) === -1)\n .forEach((field) => {\n attributes.push(`\"qvAttributes\" ->> '${field}' as \"${field}\"`);\n });\n return attributes;\n }\n\n async findCommand(options: IFindOptions = {}): Promise<T[]> {\n let query = `SELECT ${this.getSelectClause(\n options.aggregateFunction,\n options.fields,\n )} FROM ${format.ident(this.dbSchema)}.${format.ident(this.tableName)}`;\n query = this.addFiltersToQuery(query, options.filters);\n if (!options.aggregateFunction) {\n query = this.addOrderByToQuery(query, options.sorting);\n query = this.addPaginationToQuery(query, options.pagination);\n }\n return (await this.runQuery(query)).rows;\n }\n\n sanitizeValue(value: any): string {\n if (Array.isArray(value)) {\n const formattedArray = value\n .map((item) => {\n if (typeof item === 'string') {\n return `'${item}'`;\n } else if (typeof item === 'object') {\n return JSON.stringify(item);\n } else {\n return item;\n }\n })\n .join(',');\n\n return JSON.stringify(formattedArray);\n } else {\n return format.literal(value);\n }\n }\n\n async updateCommand(\n filters: ICompositeFilter,\n data: Partial<any>,\n ): Promise<QueryResult<any>> {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const updateClauses = Object.entries(data).map(([key, value]) => {\n const dbValue = this.sanitizeValue(value);\n return `${format.ident(key)} = ${dbValue}`;\n });\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildFilterClauseForFilterGroups(\n filterGroups: IFilter[][],\n ): string {\n const filterClauses = filterGroups.map((filterGroup) => {\n return `(${this.buildFilterClause(filterGroup)})`;\n });\n return filterClauses.join(' OR ');\n }\n\n async deleteCommand(\n filters?: ICompositeFilter | IFilter[] | IFilter[][],\n useFilterGroups: boolean = false,\n ): Promise<QueryResult<any>> {\n let query = `DELETE FROM ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )}`;\n if (filters) {\n query += ' WHERE ';\n\n if (useFilterGroups) {\n query += this.buildFilterClauseForFilterGroups(\n filters as IFilter[][],\n );\n } else {\n query += this.buildFilterClause(\n filters as ICompositeFilter | IFilter[],\n );\n }\n }\n\n return this.runQuery(query);\n }\n\n query(queryText: string, values?: any[]) {\n return this.runQuery(queryText, values);\n }\n\n public async updateExpressionCommand(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: Partial<IUpdateExpressionsOptions> = {},\n ) {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const set = actions.SET || [];\n const add = actions.ADD || [];\n const setValues = this.replacePathAndValueByAttributeNames(\n set,\n options,\n false,\n );\n const addValues = this.replacePathAndValueByAttributeNames(\n add,\n options,\n true,\n );\n\n const setValuesAndAddValues: any = setValues.concat(addValues);\n\n const updateClauses: any = [];\n const jsonSetExpressionGroup: any = {};\n\n setValuesAndAddValues.forEach((expression: any) => {\n const { path, value, createNewColumn } = expression;\n\n if (path.includes('.')) {\n const jsonExpr = this.getJSONBSetExpressionByAction(\n path,\n value,\n true,\n );\n const columnName: string = jsonExpr.columnName;\n if (!jsonSetExpressionGroup[columnName]) {\n jsonSetExpressionGroup[columnName] = [jsonExpr];\n } else {\n jsonSetExpressionGroup[columnName].push(jsonExpr);\n }\n } else {\n if (createNewColumn)\n throw 'Set Expressions are not supported for non JSON-JSONB';\n updateClauses.push(\n `${format.ident(path)} = ${this.sanitizeValue(value)}`,\n );\n }\n });\n\n if (Object.keys(jsonSetExpressionGroup).length > 0) {\n Object.keys(jsonSetExpressionGroup).forEach((groupIndex) => {\n const jsonSetExpression = this.buildJSONBExpression(\n jsonSetExpressionGroup[groupIndex],\n );\n\n updateClauses.push(`${groupIndex} = ${jsonSetExpression}`);\n });\n }\n\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildJSONBExpression(jsonSetExpressions: any) {\n let jsonSetStringExpr = '';\n jsonSetExpressions.forEach((expression: any, index: number) => {\n const { columnName, jsonExpr } = expression;\n if (index === 0) {\n jsonSetStringExpr = `jsonb_set(${columnName},${jsonExpr})`;\n } else {\n jsonSetStringExpr = `jsonb_set(${jsonSetStringExpr},${jsonExpr})`;\n }\n });\n return jsonSetStringExpr;\n }\n\n private getJSONBSetExpressionByAction(\n path: string,\n value: any,\n createNewColumn: boolean,\n ) {\n const pathSplitted = path.split('.');\n const parentPath = pathSplitted[0];\n\n const pathSerialized = pathSplitted.slice(1).join(',');\n return {\n jsonExpr: `'{${pathSerialized}}','${value}',${createNewColumn}`,\n columnName: `\"${parentPath}\"`,\n };\n }\n\n private replacePathAndValueByAttributeNames(\n actions: any[],\n options: IUpdateExpressionsOptions,\n createNewColumn: boolean,\n ) {\n return actions.map((action) => {\n action.path = this.replaceExpressionAttributeNames(\n action.path,\n options,\n );\n if (action.value)\n action.value = this.replaceExpressionAttributeValues(\n action.value,\n options,\n );\n action.createNewColumn = createNewColumn;\n return action;\n });\n }\n\n private replaceExpressionAttributeNames(\n path: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeNames } = options;\n\n Object.keys(expressionAttributeNames).forEach(\n (attributeName: string) => {\n const attributeNameValue: string =\n expressionAttributeNames[attributeName];\n path = path.replace(attributeName, attributeNameValue);\n },\n );\n return path;\n }\n\n private replaceExpressionAttributeValues(\n value: string,\n options: IUpdateExpressionsOptions,\n ) {\n const { expressionAttributeValues } = options;\n\n Object.keys(expressionAttributeValues).forEach(\n (attributeName: string) => {\n const attributeNameValue: string =\n expressionAttributeValues[attributeName];\n value = value.replace(attributeName, attributeNameValue);\n value = typeof value == 'string' ? `\\\"${value}\\\"` : value;\n },\n );\n return value;\n }\n}\n","import { Client } from 'pg';\n\nexport default class ConnectionService {\n get connectionString() {\n const connectionString =\n process.env.MULTIPLATFORM_PG_CONNECTION_STRING || '';\n if (!connectionString) {\n throw new Error(\n 'MULTIPLATFORM_PG_CONNECTION_STRING environment variable must be configured',\n );\n }\n return connectionString;\n }\n\n async getClient(): Promise<Client> {\n const client: Client = new Client({\n connectionString: this.connectionString,\n });\n await client.connect();\n return client;\n }\n\n releaseClient(client: Client): void {\n try {\n client.end();\n } catch {\n // eslint-disable-next-line no-console\n console.log('Error releasing client');\n }\n }\n}\n","/* eslint-disable no-console */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Client, QueryResult } from 'pg';\nimport ConnectionService from './connection.service';\nimport { DbPoolClient } from '../../../types';\n\nexport default class QueryService {\n private connectionService: ConnectionService;\n\n constructor(private poolClient?: DbPoolClient) {\n this.connectionService = new ConnectionService();\n }\n\n async runQuery(\n queryText: string,\n values?: any[],\n ): Promise<QueryResult<any>> {\n const client = await (this.poolClient\n ? this.poolClient\n : this.connectionService.getClient());\n\n try {\n const result = await client.query(queryText, values);\n return result;\n } catch (error) {\n console.log('[Postgresql-Client] Query Execution Failed:', error);\n throw error;\n } finally {\n if (!this.poolClient)\n this.connectionService.releaseClient(client as Client);\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport PostgresqlClientService from './postgreSqlClient.service';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindResult,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas';\nimport { findIdColumnName } from '../../../helpers/tableHelper';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\nimport { PersistenceErrorWrapper } from '../../../helpers/errorHelper';\nexport class PostgreSqlCrudService<T>\n extends PostgresqlClientService<T>\n implements ICrudService<T>\n{\n constructor(private tableSchema: typeof CrudSchema) {\n super(tableSchema);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n normalizeInputData(inputData: any) {\n inputData.qvAttributes = {};\n for (const key in inputData) {\n if (!this.tableSchema.columns[key] && key !== 'qvAttributes') {\n inputData.qvAttributes[key] = inputData[key];\n delete inputData[key];\n } else if (Array.isArray(inputData[key])) {\n inputData[key] = JSON.stringify(inputData[key]);\n }\n }\n }\n\n getItem(data: { [key: string]: any }): any {\n const resultItem = { ...data, ...data.qvAttributes };\n delete resultItem['qvAttributes'];\n return resultItem;\n }\n\n prepareData(data: T): any {\n const inputData = { ...data } as { [key: string]: any };\n this.normalizeInputData(inputData);\n return inputData;\n }\n\n create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const inputDataArray = data.map((item) => this.prepareData(item));\n return this.createCommand(inputDataArray).then((result) => ({\n unprocessedItems: result\n .filter((r: any) => !r.success)\n .map((r: any) => r.inputData),\n }));\n } else {\n const inputData = this.prepareData(data);\n return this.createCommand([inputData]).then((result) =>\n result.rowCount ? this.getItem(result.rows[0]) : null,\n );\n }\n }\n\n findItem(findOptions: IFindOptions): Promise<T | null> {\n return this.findCommand(findOptions).then((data) => {\n return data?.length\n ? this.getItem(data[0] as { [key: string]: any })\n : null;\n });\n }\n\n private async processQueryResult(\n findOptions: IFindOptions,\n omitPagination: boolean = false,\n ): Promise<IFindResult<T>> {\n const { pagination } = findOptions;\n const rows = await this.findCommand(findOptions);\n const items = rows.map((row) =>\n this.getItem(row as { [key: string]: any }),\n );\n const result: IFindResult<T> = {\n items,\n pagination: omitPagination ? null : pagination,\n count: items.length,\n };\n return result;\n }\n\n async find(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions);\n }\n\n async findAll(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions, true);\n }\n\n async findCount(findOptions: IFindOptions): Promise<number> {\n const items = await this.findCommand({\n ...findOptions,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n });\n\n const aggFunctionProperty = buildAggFunctionAlias(\n AGGREGATE_FUNCTIONS.COUNT,\n );\n const item: any = items.length ? items[0] : {};\n return item[aggFunctionProperty] || 0;\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n ): Promise<any> {\n const savedRecord = await this.findItem({ filters });\n\n const inputData: { [key: string]: any } = {\n ...savedRecord,\n ...data,\n } as {\n [key: string]: any;\n };\n\n this.normalizeInputData(inputData);\n await this.updateCommand(filters as ICompositeFilter, inputData);\n return this.getItem(inputData);\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ): Promise<void> {\n await this.deleteCommand(filters, options?.filterGroups);\n }\n\n runQuery(querySentence: string, values?: any[]) {\n return super.runQuery(querySentence, values);\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n const result = await this.updateExpressionCommand(\n filters,\n actions,\n options,\n );\n PersistenceErrorWrapper(result);\n return result;\n }\n}\n"]}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -87,8 +87,8 @@ interface IUpdateExpressions {
|
|
|
87
87
|
interface IUpdateExpressionsOptions {
|
|
88
88
|
returnValues?: string;
|
|
89
89
|
conditionExpression?: string;
|
|
90
|
-
expressionAttributeNames?:
|
|
91
|
-
expressionAttributeValues?:
|
|
90
|
+
expressionAttributeNames?: any;
|
|
91
|
+
expressionAttributeValues?: any;
|
|
92
92
|
}
|
|
93
93
|
|
|
94
94
|
interface ICrudService<T> {
|
package/package.json
CHANGED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
// src/helpers/tableHelper.ts
|
|
2
|
-
function getTableColumnNames(columns) {
|
|
3
|
-
return Object.keys(columns);
|
|
4
|
-
}
|
|
5
|
-
function findIdColumnName(columns) {
|
|
6
|
-
return getTableColumnNames(columns).find(
|
|
7
|
-
(columnName) => columns[columnName].columnId === true
|
|
8
|
-
);
|
|
9
|
-
}
|
|
10
|
-
function getTableName(table, property = "name") {
|
|
11
|
-
if (!table)
|
|
12
|
-
throw new Error("missing table property");
|
|
13
|
-
if (typeof table === "string")
|
|
14
|
-
return table;
|
|
15
|
-
const { name, alias } = table;
|
|
16
|
-
return property === "alias" && alias ? alias : name;
|
|
17
|
-
}
|
|
18
|
-
function getPrimaryKeyColumns(columns) {
|
|
19
|
-
return getTableColumnNames(columns).filter(
|
|
20
|
-
(columnName) => columns[columnName].primary === true
|
|
21
|
-
);
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
// src/helpers/queryHelpers.ts
|
|
25
|
-
function buildAggFunctionAlias(aggregateFunction) {
|
|
26
|
-
return `AGG_FN_${aggregateFunction}`;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
export { buildAggFunctionAlias, findIdColumnName, getPrimaryKeyColumns, getTableName };
|
|
30
|
-
//# sourceMappingURL=out.js.map
|
|
31
|
-
//# sourceMappingURL=chunk-RTYYBKND.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/helpers/tableHelper.ts","../../src/helpers/queryHelpers.ts"],"names":[],"mappings":";AAEO,SAAS,oBAAoB,SAAkC;AAClE,SAAO,OAAO,KAAK,OAAO;AAC9B;AAEO,SAAS,iBAAiB,SAA4C;AACzE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,aAAa;AAAA,EACrD;AACJ;AAEO,SAAS,aACZ,OACA,WAAW,QACL;AACN,MAAI,CAAC;AAAO,UAAM,IAAI,MAAM,wBAAwB;AAEpD,MAAI,OAAO,UAAU;AAAU,WAAO;AAEtC,QAAM,EAAE,MAAM,MAAM,IAAI;AACxB,SAAO,aAAa,WAAW,QAAQ,QAAQ;AACnD;AAEO,SAAS,qBAAqB,SAAkC;AACnE,SAAO,oBAAoB,OAAO,EAAE;AAAA,IAChC,CAAC,eAAe,QAAQ,UAAU,EAAE,YAAY;AAAA,EACpD;AACJ;;;ACpBO,SAAS,sBACZ,mBACM;AACN,SAAO,UAAU,iBAAiB;AACtC","sourcesContent":["import { ITableColumns, ITableName } from '../interfaces';\n\nexport function getTableColumnNames(columns: ITableColumns): string[] {\n return Object.keys(columns);\n}\n\nexport function findIdColumnName(columns: ITableColumns): string | undefined {\n return getTableColumnNames(columns).find(\n (columnName) => columns[columnName].columnId === true,\n );\n}\n\nexport function getTableName(\n table: string | ITableName,\n property = 'name',\n): string {\n if (!table) throw new Error('missing table property');\n\n if (typeof table === 'string') return table;\n\n const { name, alias } = table;\n return property === 'alias' && alias ? alias : name;\n}\n\nexport function getPrimaryKeyColumns(columns: ITableColumns): string[] {\n return getTableColumnNames(columns).filter(\n (columnName) => columns[columnName].primary === true,\n );\n}\n","import { AggregateFunction } from '../types';\n\nexport enum METHOD_TO_QUERY {\n where = 'where',\n filter = 'filter',\n update = 'update',\n}\n\nexport function buildAggFunctionAlias(\n aggregateFunction: AggregateFunction,\n): string {\n return `AGG_FN_${aggregateFunction}`;\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/cruds/dynamodb/dynamoDbClient.service.ts","../../src/services/cruds/dynamodb/queryBuilderCondition.service.ts","../../src/services/cruds/dynamodb/queryBuilder.service.ts","../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":["_a","_b"],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { DynamoDBClient } from '@aws-sdk/client-dynamodb';\nimport {\n DynamoDBDocumentClient,\n GetCommand,\n QueryCommand,\n PutCommand,\n UpdateCommand,\n DeleteCommand,\n GetCommandInput,\n QueryCommandInput,\n PutCommandInput,\n UpdateCommandInput,\n DeleteCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n ScanCommand,\n BatchWriteCommandInput,\n BatchWriteCommand,\n} from '@aws-sdk/lib-dynamodb';\nimport { IFilter } from '../../../interfaces';\n\nconst AWS_REGION = process.env.AWS_DEFAULT_REGION;\n\n/**\n * Ref:\n * - https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/DynamoDB/DocumentClient.html\n * - https://www.fernandomc.com/posts/eight-examples-of-fetching-data-from-dynamodb-with-node/\n */\nexport default class DynamoDbClientService {\n private tableName: string;\n protected dynamoDBClient: DynamoDBDocumentClient;\n\n constructor(tableName: string) {\n if (!tableName)\n throw new Error(\n 'The \"tableName\" is required to use a DynamoDbClientService.',\n );\n this.tableName = tableName;\n const client = new DynamoDBClient({ region: AWS_REGION });\n this.dynamoDBClient = DynamoDBDocumentClient.from(client, {\n marshallOptions: {\n removeUndefinedValues: true,\n },\n });\n }\n\n /**\n * Get an item by key\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {GetCommandInput} options\n */\n public async getByKey(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<GetCommandInput> = {},\n ) {\n const params: GetCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n const result = await this.dynamoDBClient.send(new GetCommand(params));\n return result.Item;\n }\n\n /**\n * Query a table\n * @param {QueryCommandInput} options\n */\n public async query(\n options: Omit<QueryCommandInput, 'TableName'> = {},\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: QueryCommandInput = {\n TableName: this.tableName,\n ...options,\n };\n const result: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(new QueryCommand(params));\n\n if (result.$metadata) delete result.$metadata;\n return result;\n }\n\n /**\n * Scan a table\n * @param {ScanInput} options\n */\n public async scan(\n input: ScanCommandInput,\n ): Promise<Omit<QueryCommandOutput, '$metadata'>> {\n const params: ScanCommandInput = {\n ...input,\n TableName: this.tableName,\n };\n\n const command = new ScanCommand(params);\n const response: Partial<QueryCommandOutput> =\n await this.dynamoDBClient.send(command);\n if (response.$metadata) delete response.$metadata;\n return response;\n }\n\n /**\n * Create/Replace a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} input\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async put(input: Record<string, any>) {\n const params: PutCommandInput = {\n TableName: this.tableName,\n Item: input,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new PutCommand(params));\n }\n\n /**\n * Update a item object\n * To take care:\n * - https://stackoverflow.com/questions/43667229/difference-between-dynamodb-putitem-vs-updateitem\n * @param {Object} keyObject - Ex: { jobId: 1234 }\n * @param {UpdateCommandInput} updateObject\n */\n public async update(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n ...options,\n };\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n\n /**\n * Delete/Remove an item object\n */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n public async remove(keyObject: Record<string, any>) {\n const params: DeleteCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ReturnValues: 'NONE',\n };\n return await this.dynamoDBClient.send(new DeleteCommand(params));\n }\n\n public batchWrittenPut(data: Record<string, any>) {\n const putRequests = data.map((item: any) => ({\n PutRequest: {\n Item: item,\n },\n }));\n const params = {\n RequestItems: {\n [this.tableName]: putRequests,\n },\n } as BatchWriteCommandInput;\n const insertCommand = new BatchWriteCommand(params);\n return this.dynamoDBClient.send(insertCommand);\n }\n\n private buildDeleteRequestKeys(filters: IFilter[]) {\n const deleteRequestKeys: any = {};\n filters.forEach((filter) => {\n deleteRequestKeys[filter.attribute] = filter.value;\n });\n return deleteRequestKeys;\n }\n\n async batchRemove(filterGroups: IFilter[][]): Promise<void> {\n if (!filterGroups?.length) return;\n\n const deleteRequests = filterGroups.map((filterGroup: IFilter[]) => ({\n DeleteRequest: {\n Key: this.buildDeleteRequestKeys(filterGroup),\n },\n }));\n\n const params = {\n RequestItems: {\n [this.tableName]: deleteRequests,\n },\n } as BatchWriteCommandInput;\n\n await this.dynamoDBClient.send(new BatchWriteCommand(params));\n }\n\n public async updateExpressions(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n keyObject: Record<string, any>,\n options: Partial<UpdateCommandInput> = {},\n ) {\n const params: UpdateCommandInput = {\n TableName: this.tableName,\n Key: keyObject,\n ...options,\n };\n\n return await this.dynamoDBClient.send(new UpdateCommand(params));\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { QueryCommandInput } from '@aws-sdk/client-dynamodb';\nimport { UpdateCommandInput } from '@aws-sdk/lib-dynamodb';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\n\nexport default class QueryBuilderConditionService\n implements IQueryBuilderCondition\n{\n private query;\n private command: Pick<\n QueryCommandInput,\n | 'FilterExpression'\n | 'KeyConditionExpression'\n | 'ExpressionAttributeNames'\n | 'ExpressionAttributeValues'\n > &\n Pick<UpdateCommandInput, 'UpdateExpression'>;\n private queryFrom: METHOD_TO_QUERY | undefined;\n private tempKey: string = '';\n private tempLogicOperator: string | null = null;\n private config: any;\n private wheres: string[] = [];\n private filters: string[] = [];\n private updates: string[] = [];\n private attributeNames: Record<string, string> = {};\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n private attributeValues: Record<string, any> = {};\n\n constructor(query: IQueryBuilder) {\n this.query = query;\n this.command = {};\n }\n\n public get() {\n this.build();\n return this.command;\n }\n\n public setKey(key: string) {\n this.tempKey = key;\n return this;\n }\n setTmpLogicOp(logicOp: string) {\n this.tempLogicOperator = logicOp;\n return this;\n }\n\n setConfig(config: any) {\n this.config = config;\n return this;\n }\n\n public from(methodName: METHOD_TO_QUERY) {\n this.queryFrom = methodName;\n return this;\n }\n\n eq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} = ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notEq(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <> ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n contains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n notContains(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `NOT contains(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n in(keyValue: any) {\n const keyValues = Array.isArray(keyValue) ? keyValue : [keyValue];\n const { key, value } = this.generateKeyValue(keyValues);\n let expression: any = `${key} IN (${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n beginsWith(keyValue: string) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `begins_with(${key}, ${value})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n project(keyValue: string): string {\n const key = `#${keyValue}`;\n this.attributeNames[key] = keyValue;\n return key;\n }\n\n gt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} > ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n gte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} >= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lte(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} <= ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n lt(keyValue: any) {\n const { key, value } = this.generateKeyValue(keyValue);\n let expression: any = `${key} < ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n attribute_not_exists(keyValue: string) {\n const { key } = this.generateKeyValue(keyValue, null, true);\n let expression: any = `attribute_not_exists(${key})`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n between(keyValues: any) {\n const isValidValues =\n Array.isArray(keyValues) && keyValues?.length === 2;\n if (!isValidValues)\n throw new Error(\n 'The value for between filter operator should be an Array with 2 values.',\n );\n\n const { key, value } = this.generateKeyValue(keyValues, ' AND');\n let expression: any = `${key} between ${value}`;\n if (this.tempLogicOperator)\n expression = { expression, logicOperator: this.tempLogicOperator, config: this.config };\n this.setExpression(expression);\n return this.query;\n }\n\n private setExpression(expression: string): void {\n switch (this.queryFrom) {\n case METHOD_TO_QUERY.filter:\n this.filters.push(expression);\n break;\n case METHOD_TO_QUERY.update:\n this.updates.push(expression);\n break;\n default:\n this.wheres.push(expression);\n break;\n }\n }\n\n private generateKeyValue(\n value: string[] | string,\n separatorCharacter: string | null = ',',\n omitAttributeValues: boolean = false,\n ): {\n key: string;\n value: string;\n } {\n const keyExpression = `#${this.tempKey}1`;\n\n this.attributeNames[keyExpression] = this.tempKey;\n\n if (Array.isArray(value)) {\n const valueExpressions = value.map((val, index) => {\n let valueExpression = `:${this.tempKey}${index + 1}1`;\n for (const [i] of Object.entries(this.attributeValues)) {\n if (i === valueExpression) valueExpression += '1';\n }\n this.attributeValues[valueExpression] = val;\n return valueExpression;\n });\n return {\n key: keyExpression,\n value: valueExpressions.join(`${separatorCharacter} `),\n };\n } else {\n let valueExpression = `:${this.tempKey}1`;\n if (valueExpression in this.attributeValues) {\n for (const [index] of Object.entries(this.attributeValues)) {\n if (index === valueExpression) valueExpression += '1';\n }\n }\n if (!omitAttributeValues)\n this.attributeValues[valueExpression] = value;\n return { key: keyExpression, value: valueExpression };\n }\n }\n\n private build(): void {\n if (this.wheres.length > 0) {\n const keyConditionExpression = this.wheres.join(' AND ');\n this.command['KeyConditionExpression'] = keyConditionExpression;\n }\n if (this.filters.length > 0) {\n let filterExpression = '';\n\n this.filters?.forEach((filter: any, index) => {\n if (filter?.logicOperator) {\n if (filter?.config?.openExpression) {\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, ` ${filter.config.parentKey} (`);\n if (filterExpression === '') filterExpression += '('\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n } else if (filter?.config?.closeExpression) {\n filterExpression += `${filter.expression}) ${filter.config.parentKey} `; \n } else {\n filterExpression += `${filter.expression} ${filter.logicOperator} `;\n }\n }\n });\n filterExpression = filterExpression.replace(/\\s+(AND|OR)\\s*$/, '');\n this.command['FilterExpression'] = filterExpression;\n }\n if (this.updates.length > 0) {\n const filterExpression = this.updates.join(', ');\n this.command['UpdateExpression'] = `SET ${filterExpression}`;\n }\n if (Object.values(this.attributeNames).length > 0)\n this.command['ExpressionAttributeNames'] = this.attributeNames;\n\n if (Object.values(this.attributeValues).length > 0)\n this.command['ExpressionAttributeValues'] = this.attributeValues;\n }\n}\n","import { QueryCommandInput, ScanCommandInput } from '@aws-sdk/client-dynamodb';\nimport { IQueryBuilderCondition } from '../../../interfaces/queryBuilderCondition.interface';\nimport QueryBuilderConditionService from './queryBuilderCondition.service';\nimport { METHOD_TO_QUERY } from '../../../helpers/queryHelpers';\nimport { IQueryBuilder } from '../../../interfaces/queryBuilder.interface';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\n\nexport default class QueryBuilderService implements IQueryBuilder {\n private command: Omit<QueryCommandInput & ScanCommandInput, 'TableName'>;\n private condition: IQueryBuilderCondition;\n\n constructor(private useScan = false) {\n this.command = {};\n\n this.condition = new QueryBuilderConditionService(this);\n }\n\n get() {\n const condition = this.condition.get();\n return { ...this.command, ...condition };\n }\n\n limit(num: number): IQueryBuilder {\n this.command.Limit = num;\n return this;\n }\n\n usingIndex(indexName: string): IQueryBuilder {\n this.command.IndexName = indexName;\n return this;\n }\n\n ascending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = true;\n return this;\n }\n\n descending(): IQueryBuilder {\n if (!this.useScan) this.command.ScanIndexForward = false;\n return this;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n startKey(lastEvaluatedKey: Record<string, any>): IQueryBuilder {\n this.command.ExclusiveStartKey = lastEvaluatedKey;\n return this;\n }\n\n projection(fields: string[] = []) {\n if (!fields.length) return this;\n\n const expression: string[] = [];\n fields.forEach((field) => {\n const key = this.condition.project(field);\n expression.push(key);\n });\n this.command.ProjectionExpression = expression.join(',');\n return this;\n }\n\n where(keyName: string): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(null)\n .from(METHOD_TO_QUERY.where);\n return this.condition;\n }\n\n filter(\n keyName: string,\n logicOperator: string = 'AND',\n config?: any\n ): IQueryBuilderCondition {\n this.condition\n .setKey(keyName)\n .setTmpLogicOp(logicOperator)\n .setConfig(config)\n .from(METHOD_TO_QUERY.filter);\n return this.condition;\n }\n\n update(attribute: Record<string, string>): IQueryBuilder {\n for (const [key, value] of Object.entries(attribute)) {\n this.condition.setKey(key).from(METHOD_TO_QUERY.update);\n this.condition.eq(value);\n }\n return this;\n }\n\n consistentRead(consistentRead: boolean): IQueryBuilder {\n this.command.ConsistentRead = consistentRead;\n return this;\n }\n\n count(): IQueryBuilder {\n this.command.Select = AGGREGATE_FUNCTIONS.COUNT;\n return this;\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport DynamoDbClientService from './dynamoDbClient.service';\nimport QueryBuilderService from './queryBuilder.service';\n\nimport {\n AGGREGATE_FUNCTIONS,\n DYNAMODB_OPERATORS,\n FILTER_OPERATOR_MAP,\n DYNAMO_DB_UPDATE_ACTIONS,\n} from '../../../utils/constants';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindPagination,\n IRemoveOptions,\n IUpdateExpressions,\n IUpdateExpressionsOptions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas/crudSchema';\nimport {\n findIdColumnName,\n getPrimaryKeyColumns,\n getTableName,\n} from '../../../helpers/tableHelper';\nimport {\n QueryCommandInput,\n QueryCommandOutput,\n ScanCommandInput,\n} from '@aws-sdk/lib-dynamodb';\n\nexport class DynamoDbCrudService<T> implements ICrudService<T> {\n private dynamoDbClientService: DynamoDbClientService;\n\n constructor(private tableSchema: typeof CrudSchema) {\n this.dynamoDbClientService = new DynamoDbClientService(this.tableName);\n }\n\n private get tableName(): string {\n return getTableName(this.tableSchema.table);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n private get defaultPrimaryKeys(): string[] {\n return getPrimaryKeyColumns(this.tableSchema.columns);\n }\n\n async create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const response =\n await this.dynamoDbClientService.batchWrittenPut(data);\n return {\n unprocessedItems: response.UnprocessedItems ?? [],\n };\n } else {\n await this.dynamoDbClientService.put(data as Record<string, any>);\n return data as T;\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars, no-unused-vars\n runQuery(queryCommand: any): Promise<any> {\n throw new Error('Method not implemented.');\n }\n\n find(options: IFindOptions = {}): Promise<any> {\n const query = new QueryBuilderService(options.useScan);\n\n if (options.index?.indexName)\n query.usingIndex(options.index?.indexName);\n\n this.applySorting(query, options.sorting, options.index?.indexName);\n this.applyPagination(query, options.pagination);\n\n if (options.consistentRead)\n query.consistentRead(options.consistentRead);\n\n if (options.fields) query.projection(options.fields);\n\n this.applyFilters(query, options);\n\n if (options.aggregateFunction === AGGREGATE_FUNCTIONS.COUNT)\n query.count();\n\n return this.fetchResults(\n query.get(),\n options.pagination?.limit,\n options.useScan,\n ).then((res: any) => {\n const pagination: IFindPagination = {};\n if (res.lastEvaluatedKey) pagination.from = res.lastEvaluatedKey;\n if (options.pagination?.limit)\n pagination.limit = options.pagination?.limit;\n return {\n items: res.items,\n pagination,\n count: res.count,\n };\n });\n }\n\n async fetchResults(\n command: ScanCommandInput | QueryCommandInput,\n limit: number = 100,\n useScan: boolean = false,\n ): Promise<unknown> {\n let results: unknown[] = [];\n let lastEvaluatedKey: Record<string, unknown> = {};\n let rowsCount = 0;\n\n do {\n const result = await this.fetchBatch(\n command,\n useScan,\n lastEvaluatedKey,\n );\n const rows = result.Items ?? [];\n results = results.concat(rows);\n lastEvaluatedKey = result.LastEvaluatedKey ?? {};\n rowsCount += result.Count || rows.length;\n } while (rowsCount < limit && this.isNotEmptyObject(lastEvaluatedKey));\n\n const encryptedLastEvaluatedKey = this.isNotEmptyObject(\n lastEvaluatedKey,\n )\n ? this.encryptPaginationKey(lastEvaluatedKey)\n : null;\n return {\n items: results,\n lastEvaluatedKey: encryptedLastEvaluatedKey,\n count: rowsCount,\n };\n }\n\n async fetchBatch(\n command: ScanCommandInput | QueryCommandInput,\n useScan: boolean,\n lastEvaluatedKey: Record<string, unknown>,\n ): Promise<Partial<QueryCommandOutput>> {\n if (this.isNotEmptyObject(lastEvaluatedKey))\n command.ExclusiveStartKey = lastEvaluatedKey;\n\n const result = await (useScan\n ? this.dynamoDbClientService.scan(command)\n : this.dynamoDbClientService.query(command));\n\n if (command.Select !== AGGREGATE_FUNCTIONS.COUNT) {\n command.Limit = (command.Limit ?? 0) - (result.Items?.length ?? 0);\n }\n\n return result;\n }\n\n applyPagination(\n query: QueryBuilderService,\n pagination: IFindPagination | undefined,\n ) {\n if (pagination?.limit) query.limit(pagination.limit);\n if (pagination?.from)\n query.startKey(this.decryptPaginationKey(pagination.from));\n }\n\n async findAll(\n options: IFindOptions = {},\n allResults: any[] = [],\n rowsCount: number = 0,\n ): Promise<any> {\n const { items, pagination, count } = await this.find(options);\n allResults.push(...items);\n rowsCount += count;\n\n if (pagination?.from)\n await this.findAll({ ...options, pagination }, allResults);\n\n return {\n items: allResults,\n pagination: null,\n count: rowsCount,\n };\n }\n\n async findCount(options: IFindOptions = {}): Promise<number> {\n const findOptions = {\n ...options,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n };\n if (options.pagination?.from) {\n return this.find(findOptions).then((res) => res.count);\n } else {\n return this.findAll(findOptions).then((res) => res.count);\n }\n }\n\n buildFindItemQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n\n this.applyFilters(query, options);\n query.projection(options.fields);\n query.limit(1);\n\n return query;\n }\n\n findItem(options: IFindOptions): Promise<T | null> {\n const query = this.buildFindItemQuery(options);\n return this.dynamoDbClientService.query(query.get()).then((result) => {\n if (result.Items?.length) return result.Items[0] as T;\n if (options.throwErrorIfNull) throw new Error('NOT_FOUND');\n return null;\n });\n }\n\n applyWhereFilter(query: QueryBuilderService, filter: IFilter) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.where(filter.attribute) as any)[operator](filter.value);\n }\n\n applyFilterFilter(\n query: QueryBuilderService,\n filter: IFilter,\n logicOperator: string = 'AND',\n config?: any,\n ) {\n const operator =\n FILTER_OPERATOR_MAP[\n filter.operator?.toUpperCase() ?? DYNAMODB_OPERATORS.EQUAL\n ];\n (query.filter(filter.attribute, logicOperator, config) as any)[\n operator\n ](filter.value);\n }\n\n applyFilters(query: QueryBuilderService, options: IFindOptions) {\n if (Array.isArray(options.filters)) {\n this.applySimpleFilters(query, options);\n } else {\n this.applyCompoundFilters(query, options);\n }\n }\n\n applySimpleFilters(query: QueryBuilderService, options: IFindOptions) {\n const queryIndexColumns = options.index?.columns ?? [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties: string[] = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n const filters = options.filters as IFilter[];\n filters.forEach((filter: IFilter) => {\n const isWhereProperty = whereProperties.includes(filter.attribute);\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, filter)\n : this.applyFilterFilter(query, filter);\n });\n }\n\n applyCompoundFilters(query: QueryBuilderService, options: IFindOptions) {\n if (!options.filters) return;\n this.buildFilterExpression(query, options);\n }\n\n buildFilterExpression(\n query: QueryBuilderService,\n options: IFindOptions,\n parentKey?: string,\n ) {\n const compositeFilters = options.filters as ICompositeFilter;\n const queryIndexColumns = options.index?.columns || [];\n const defaultWhereProperties = this.defaultPrimaryKeys;\n\n const whereProperties = queryIndexColumns?.length\n ? queryIndexColumns\n : defaultWhereProperties;\n\n for (const [key, value] of Object.entries(compositeFilters)) {\n value.forEach(\n (filter: IFilter | ICompositeFilter, index: number) => {\n const isCompositeFilter = 'OR' in filter || 'AND' in filter;\n if (isCompositeFilter) {\n const newOptions = {\n ...options,\n filters: filter,\n };\n this.buildFilterExpression(query, newOptions, key);\n } else {\n const simpleFilter = filter as IFilter;\n const isWhereProperty = whereProperties.includes(\n simpleFilter.attribute,\n );\n let config;\n if (parentKey) {\n config = {\n parentKey,\n openExpression: index === 0,\n closeExpression: index === value.length - 1,\n };\n }\n\n isWhereProperty && !options.useScan\n ? this.applyWhereFilter(query, simpleFilter)\n : this.applyFilterFilter(\n query,\n simpleFilter,\n key,\n config,\n );\n }\n },\n );\n }\n }\n\n applySorting(query: QueryBuilderService, sorting: any, sortIndex?: string) {\n if (sorting?.length) {\n if (sortIndex) query.usingIndex(sortIndex);\n if (sorting[0].direction === 'DESC') {\n query.descending();\n } else {\n query.ascending();\n }\n }\n }\n\n isNotEmptyObject(obj: unknown) {\n return (\n obj !== null &&\n typeof obj === 'object' &&\n Object.keys(obj).length > 0\n );\n }\n\n encryptPaginationKey(key: Record<string, any>): string {\n const jsonKey = JSON.stringify(key);\n return Buffer.from(jsonKey).toString('base64');\n }\n\n decryptPaginationKey(encodedKey: string): Record<string, any> {\n const decodedKey = Buffer.from(encodedKey, 'base64').toString('utf-8');\n return JSON.parse(decodedKey);\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n { replace = false },\n ): Promise<any> {\n const savedRecord = await this.findItem({\n filters: filters as IFilter[],\n });\n\n if (replace) {\n //delete all attributes of savedRecord except those that as marked as primary columns in the schema\n }\n\n const newData: any = {\n ...savedRecord,\n ...data,\n };\n\n await this.dynamoDbClientService.put(newData);\n return newData;\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ) {\n if (options?.filterGroups) {\n await this.dynamoDbClientService.batchRemove(\n filters as IFilter[][],\n );\n } else {\n const key = (filters as IFilter[]).reduce((obj: any, item: any) => {\n const property = item.attribute;\n obj[property] = item.value;\n return obj;\n }, {});\n await this.dynamoDbClientService.remove(key);\n }\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n options: IUpdateExpressionsOptions,\n ): Promise<any> {\n const queryObject = this.#buildUpdateExpressionQuery({ filters }).get();\n const primaryKeys = this.defaultPrimaryKeys;\n\n const keyObject: any = this.#getKeyObjectForUpdateExpression(\n queryObject,\n primaryKeys,\n );\n\n const updateExpressions: any = [];\n\n Object.keys(actions).forEach((action: string) => {\n const actionUpdateExpression =\n this.#extractUpdateExpressionAttributesAndNames(\n actions,\n action,\n );\n updateExpressions.push(actionUpdateExpression);\n });\n\n const dbParams = {\n UpdateExpression: updateExpressions.join(' '),\n ...this.#getUpdateExpressionOptions(options),\n };\n\n const { ExpressionAttributeValues, ExpressionAttributeNames } =\n queryObject;\n if (Object.keys(ExpressionAttributeValues).length > 0) {\n dbParams['ExpressionAttributeValues'] = {\n ...ExpressionAttributeValues,\n ...dbParams.ExpressionAttributeValues,\n };\n }\n\n if (Object.keys(ExpressionAttributeNames).length > 0) {\n dbParams['ExpressionAttributeNames'] = {\n ...ExpressionAttributeNames,\n ...dbParams.ExpressionAttributeNames,\n };\n }\n if (queryObject.FilterExpression)\n dbParams['ConditionExpression'] = queryObject.FilterExpression;\n\n return this.dynamoDbClientService.updateExpressions(\n keyObject,\n dbParams,\n );\n }\n\n #buildUpdateExpressionQuery(options: IFindOptions): QueryBuilderService {\n const query = new QueryBuilderService();\n\n if (options.index?.indexName) query.usingIndex(options.index.indexName);\n this.applyFilters(query, options);\n\n return query;\n }\n\n #getKeyObjectForUpdateExpression(queryObject: any, primaryKeys: any) {\n const keyObject: any = {};\n\n Object.keys(queryObject.ExpressionAttributeNames).forEach(\n (attribute) => {\n const sanitizedAttribute = attribute\n .replace('#', '')\n .replace('1', '');\n if (primaryKeys.includes(sanitizedAttribute)) {\n const valueName = `:${sanitizedAttribute}1`;\n keyObject[sanitizedAttribute] =\n queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeValues[valueName];\n delete queryObject.ExpressionAttributeNames[attribute];\n }\n },\n );\n\n return keyObject;\n }\n\n #getUpdateExpressionOptions(options: IUpdateExpressionsOptions) {\n const updateExprOptions: any = {\n ReturnValues: options.returnValues,\n };\n\n if (options.expressionAttributeNames)\n updateExprOptions.ExpressionAttributeNames =\n options.expressionAttributeNames;\n if (options.expressionAttributeValues)\n updateExprOptions.ExpressionAttributeValues =\n options.expressionAttributeValues;\n\n return updateExprOptions;\n }\n\n #extractUpdateExpressionAttributesAndNames(\n actions: any,\n actionType: string,\n ) {\n const actionUpdateExpressions: any = [];\n\n actions[actionType].forEach((action: any) => {\n switch (actionType) {\n case DYNAMO_DB_UPDATE_ACTIONS.DELETE:\n case DYNAMO_DB_UPDATE_ACTIONS.REMOVE:\n actionUpdateExpressions.push(`${action.path}`);\n break;\n\n case DYNAMO_DB_UPDATE_ACTIONS.ADD:\n case DYNAMO_DB_UPDATE_ACTIONS.SET:\n {\n let operator = '';\n if (actionType == DYNAMO_DB_UPDATE_ACTIONS.SET)\n operator = '=';\n actionUpdateExpressions.push(\n `${action.path} ${operator}${action.value}`,\n );\n }\n break;\n }\n });\n\n const actionUpdateExpression = `${actionType} ${actionUpdateExpressions.join(\n ', ',\n )}`;\n\n return actionUpdateExpression;\n }\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/services/cruds/postgresql/postgreSqlClient.service.ts","../../src/services/cruds/postgresql/connection.service.ts","../../src/services/cruds/postgresql/query.service.ts","../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable no-console */\n\nimport format from 'pg-format';\nimport { QueryResult } from 'pg';\nimport {\n AggregateFunction,\n DbPoolClient,\n FilterLogicOperator,\n} from '../../../types';\nimport {\n ICompositeFilter,\n IFilter,\n IFindOptions,\n IFindPagination,\n ISorting,\n IUpdateExpressions,\n} from '../../../interfaces';\nimport QueryService from './query.service';\nimport {\n FILTER_LOGIC_OPERATORS,\n SORT_DIRECTIONS,\n POSTGRES_FILTER_OPERATOR_MAP,\n DEFAULT_PG_SCHEMA,\n FilterOperator,\n} from '../../../utils/constants';\nimport { CrudSchema } from '../../../schemas';\nimport { getTableName } from '../../../helpers/tableHelper';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\n\nexport default class PostgresqlClientService<T> extends QueryService {\n private crudSchema: typeof CrudSchema;\n constructor(tableSchema: typeof CrudSchema, poolClient?: DbPoolClient) {\n super(poolClient);\n this.crudSchema = tableSchema;\n }\n\n get dbSchema() {\n return this.crudSchema.schema || DEFAULT_PG_SCHEMA;\n }\n\n get tableName() {\n return (\n getTableName(this.crudSchema.table, 'alias') ||\n getTableName(this.crudSchema.table)\n );\n }\n\n getWildcardValue(operator: FilterOperator, value: string): string {\n if (\n operator === FilterOperator.CONTAINS ||\n operator === FilterOperator.NOT_CONTAINS\n ) {\n return '%' + value + '%';\n } else if (operator === FilterOperator.STARTS_WITH) {\n return value + '%';\n } else {\n return value;\n }\n }\n\n private buildClause(\n operator: FilterOperator,\n attribute: string,\n value: any,\n ): string {\n const formattedValue = format.literal(value);\n operator = operator\n ? (operator.toUpperCase() as FilterOperator)\n : FilterOperator.EQUAL;\n const postgresOperator = POSTGRES_FILTER_OPERATOR_MAP[operator];\n\n if (!postgresOperator)\n throw new Error(`Unsupported filter operator: ${operator}`);\n\n const filterProperty = format.ident(attribute);\n const columnExists = !!this.crudSchema.columns[attribute];\n const property = columnExists\n ? filterProperty\n : `(\"qvAttributes\" ->> '${attribute}')`;\n\n if (operator === FilterOperator.IN) {\n const formattedValues = Array.isArray(value)\n ? value.map(format.literal)\n : [formattedValue];\n return `${property} ${postgresOperator} (${formattedValues.join(\n ', ',\n )})`;\n }\n\n if (operator === FilterOperator.BETWEEN) {\n return `${property} ${postgresOperator} ${value[0]} AND ${value[1]}`;\n }\n\n /**\n * ? Additional filter to avoid error when column accepts null values.\n */\n if (operator === FilterOperator.NOT_EQUAL && value !== null) {\n return `(${property} ${postgresOperator} ${format.literal(\n value,\n )} OR ${property} IS NULL)`;\n }\n\n if (\n operator === FilterOperator.NOT_EXIST ||\n operator === FilterOperator.EXIST\n ) {\n return `${property} ${postgresOperator}`;\n }\n\n const wildcardValue = this.getWildcardValue(operator, value);\n return `${property} ${postgresOperator} ${format.literal(\n wildcardValue,\n )}`;\n }\n\n private buildFilterClause(\n filters: IFilter[] | ICompositeFilter,\n logicOperator?: FilterLogicOperator,\n ): string {\n if (Array.isArray(filters)) {\n const filterClauses = filters.map((filter) => {\n return this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.value,\n );\n });\n return filterClauses.join(\n ` ${logicOperator ?? FILTER_LOGIC_OPERATORS.AND} `,\n );\n } else {\n return this.buildQueryByClause(filters);\n }\n }\n\n private isCompositeFilter = function (value: any) {\n return 'OR' in value || 'AND' in value;\n };\n\n buildQueryByClause(filters: IFilter[] | ICompositeFilter): string {\n let filterClauses: string = '';\n let isFirstFilter = true;\n\n for (const [key, value] of Object.entries(filters)) {\n if (!isFirstFilter) {\n filterClauses += key === 'AND' ? ' AND ' : ' OR ';\n }\n\n if (this.isCompositeFilter(value)) {\n filterClauses += '(';\n filterClauses += this.buildQueryByClause(\n value as ICompositeFilter,\n );\n filterClauses += ')';\n } else {\n (value as IFilter[]).forEach((filter: IFilter) => {\n let clause = '';\n if (this.isCompositeFilter(filter)) {\n clause = `(${this.buildQueryByClause(\n filter as ICompositeFilter,\n )})`;\n } else {\n clause = this.buildClause(\n filter.operator as FilterOperator,\n filter.attribute,\n filter.value,\n );\n }\n filterClauses += `${clause} ${key} `;\n });\n }\n\n isFirstFilter = false;\n }\n\n filterClauses = filterClauses.replace(/\\s+(AND|OR)\\s*$/, '');\n return filterClauses;\n }\n\n private formatOrderByItem(sort: ISorting): string {\n return `${format.ident(sort.column)} ${\n sort.direction || SORT_DIRECTIONS.ASC\n }`;\n }\n\n private buildOrderByClause(querySorting: ISorting[]): string {\n try {\n return querySorting.map(this.formatOrderByItem).join(', ');\n } catch (error) {\n return '';\n }\n }\n\n async createCommand(data: any[]): Promise<any> {\n const keys = Object.keys(data[0]); // Assuming all objects have the same keys\n const values = data.map((item) => Object.values(item));\n\n const query = format(\n `INSERT INTO ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} (%I) VALUES %L RETURNING *;`,\n keys,\n values,\n );\n\n return this.runQuery(query);\n }\n\n private addFiltersToQuery(\n query: string,\n filters?: IFilter[] | ICompositeFilter,\n ): string {\n if (filters) query += ` WHERE ${this.buildFilterClause(filters)}`;\n return query;\n }\n\n addOrderByToQuery(query: string, orderBy?: ISorting[]): string {\n if (orderBy) query += ` ORDER BY ${this.buildOrderByClause(orderBy)}`;\n return query;\n }\n\n private addPaginationToQuery(\n query: string,\n pagination?: IFindPagination,\n ): string {\n if (pagination) {\n const { limit, from } = pagination;\n if (limit) query += ` LIMIT ${limit}`;\n if (from) query += ` OFFSET ${from}`;\n }\n return query;\n }\n\n private getSelectClause(\n aggregateFunction: AggregateFunction | undefined,\n fields: string[] = [],\n ) {\n if (aggregateFunction)\n return `CAST(${aggregateFunction}(1) AS INTEGER) AS \"${buildAggFunctionAlias(\n aggregateFunction,\n )}\"`;\n if (!fields?.length) return '*';\n\n return this.parseFields(fields).join(', ');\n }\n\n private parseFields(fields: String[]): String[] {\n const columnsFromSchema: String[] = Object.keys(\n this.crudSchema.columns,\n );\n const attributes: String[] = fields\n .filter((field) => columnsFromSchema.indexOf(field) !== -1)\n .map((field) => `\"${field}\"`);\n\n fields\n .filter((field) => columnsFromSchema.indexOf(field) === -1)\n .forEach((field) => {\n attributes.push(`\"qvAttributes\" ->> '${field}' as \"${field}\"`);\n });\n return attributes;\n }\n\n async findCommand(options: IFindOptions = {}): Promise<T[]> {\n let query = `SELECT ${this.getSelectClause(\n options.aggregateFunction,\n options.fields,\n )} FROM ${format.ident(this.dbSchema)}.${format.ident(this.tableName)}`;\n query = this.addFiltersToQuery(query, options.filters);\n if (!options.aggregateFunction) {\n query = this.addOrderByToQuery(query, options.sorting);\n query = this.addPaginationToQuery(query, options.pagination);\n }\n return (await this.runQuery(query)).rows;\n }\n\n sanitizeValue(value: any): string {\n if (Array.isArray(value)) {\n const formattedArray = value\n .map((item) => {\n if (typeof item === 'string') {\n return `'${item}'`;\n } else if (typeof item === 'object') {\n return JSON.stringify(item);\n } else {\n return item;\n }\n })\n .join(',');\n\n return JSON.stringify(formattedArray);\n } else {\n return format.literal(value);\n }\n }\n\n async updateCommand(\n filters: ICompositeFilter,\n data: Partial<any>,\n ): Promise<QueryResult<any>> {\n let query = `UPDATE ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )} SET`;\n\n const updateClauses = Object.entries(data).map(([key, value]) => {\n const dbValue = this.sanitizeValue(value);\n return `${format.ident(key)} = ${dbValue}`;\n });\n query += ` ${updateClauses.join(', ')}`;\n\n query += ' WHERE ';\n query += this.buildFilterClause(filters);\n\n return this.runQuery(query);\n }\n\n private buildFilterClauseForFilterGroups(\n filterGroups: IFilter[][],\n ): string {\n const filterClauses = filterGroups.map((filterGroup) => {\n return `(${this.buildFilterClause(filterGroup)})`;\n });\n return filterClauses.join(' OR ');\n }\n\n async deleteCommand(\n filters?: ICompositeFilter | IFilter[] | IFilter[][],\n useFilterGroups: boolean = false,\n ): Promise<QueryResult<any>> {\n let query = `DELETE FROM ${format.ident(this.dbSchema)}.${format.ident(\n this.tableName,\n )}`;\n if (filters) {\n query += ' WHERE ';\n\n if (useFilterGroups) {\n query += this.buildFilterClauseForFilterGroups(\n filters as IFilter[][],\n );\n } else {\n query += this.buildFilterClause(\n filters as ICompositeFilter | IFilter[],\n );\n }\n }\n\n return this.runQuery(query);\n }\n\n query(queryText: string, values?: any[]) {\n return this.runQuery(queryText, values);\n }\n\n async updateExpressions(\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n filters: ICompositeFilter,\n // eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars\n actions: IUpdateExpressions,\n ): Promise<QueryResult<any>> {\n return this.runQuery('');\n }\n}\n","import { Client } from 'pg';\n\nexport default class ConnectionService {\n get connectionString() {\n const connectionString =\n process.env.MULTIPLATFORM_PG_CONNECTION_STRING || '';\n if (!connectionString) {\n throw new Error(\n 'MULTIPLATFORM_PG_CONNECTION_STRING environment variable must be configured',\n );\n }\n return connectionString;\n }\n\n async getClient(): Promise<Client> {\n const client: Client = new Client({\n connectionString: this.connectionString,\n });\n await client.connect();\n return client;\n }\n\n releaseClient(client: Client): void {\n try {\n client.end();\n } catch {\n // eslint-disable-next-line no-console\n console.log('Error releasing client');\n }\n }\n}\n","/* eslint-disable no-console */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Client, QueryResult } from 'pg';\nimport ConnectionService from './connection.service';\nimport { DbPoolClient } from '../../../types';\n\nexport default class QueryService {\n private connectionService: ConnectionService;\n\n constructor(private poolClient?: DbPoolClient) {\n this.connectionService = new ConnectionService();\n }\n\n async runQuery(\n queryText: string,\n values?: any[],\n ): Promise<QueryResult<any>> {\n const client = await (this.poolClient\n ? this.poolClient\n : this.connectionService.getClient());\n\n try {\n const result = await client.query(queryText, values);\n return result;\n } catch (error) {\n console.log('[Postgresql-Client] Query Execution Failed:', error);\n throw error;\n } finally {\n if (!this.poolClient)\n this.connectionService.releaseClient(client as Client);\n }\n }\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport PostgresqlClientService from './postgreSqlClient.service';\nimport {\n ICompositeFilter,\n ICreateMultipleResponse,\n ICrudService,\n IFilter,\n IFindOptions,\n IFindResult,\n IRemoveOptions,\n IUpdateExpressions,\n} from '../../../interfaces';\nimport { CrudSchema } from '../../../schemas';\nimport { findIdColumnName } from '../../../helpers/tableHelper';\nimport { AGGREGATE_FUNCTIONS } from '../../../utils/constants';\nimport { buildAggFunctionAlias } from '../../../helpers/queryHelpers';\n\nexport class PostgreSqlCrudService<T>\n extends PostgresqlClientService<T>\n implements ICrudService<T>\n{\n constructor(private tableSchema: typeof CrudSchema) {\n super(tableSchema);\n }\n\n private get idColumnName(): string | undefined {\n return findIdColumnName(this.tableSchema.columns);\n }\n\n normalizeInputData(inputData: any) {\n inputData.qvAttributes = {};\n for (const key in inputData) {\n if (!this.tableSchema.columns[key] && key !== 'qvAttributes') {\n inputData.qvAttributes[key] = inputData[key];\n delete inputData[key];\n } else if (Array.isArray(inputData[key])) {\n inputData[key] = JSON.stringify(inputData[key]);\n }\n }\n }\n\n getItem(data: { [key: string]: any }): any {\n const resultItem = { ...data, ...data.qvAttributes };\n delete resultItem['qvAttributes'];\n return resultItem;\n }\n\n prepareData(data: T): any {\n const inputData = { ...data } as { [key: string]: any };\n this.normalizeInputData(inputData);\n return inputData;\n }\n\n create(data: T | T[]): Promise<T | ICreateMultipleResponse> {\n if (Array.isArray(data)) {\n const inputDataArray = data.map((item) => this.prepareData(item));\n return this.createCommand(inputDataArray).then((result) => ({\n unprocessedItems: result\n .filter((r: any) => !r.success)\n .map((r: any) => r.inputData),\n }));\n } else {\n const inputData = this.prepareData(data);\n return this.createCommand([inputData]).then((result) =>\n result.rowCount ? this.getItem(result.rows[0]) : null,\n );\n }\n }\n\n findItem(findOptions: IFindOptions): Promise<T | null> {\n return this.findCommand(findOptions).then((data) => {\n return data?.length\n ? this.getItem(data[0] as { [key: string]: any })\n : null;\n });\n }\n\n private async processQueryResult(\n findOptions: IFindOptions,\n omitPagination: boolean = false,\n ): Promise<IFindResult<T>> {\n const { pagination } = findOptions;\n const rows = await this.findCommand(findOptions);\n const items = rows.map((row) =>\n this.getItem(row as { [key: string]: any }),\n );\n const result: IFindResult<T> = {\n items,\n pagination: omitPagination ? null : pagination,\n count: items.length,\n };\n return result;\n }\n\n async find(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions);\n }\n\n async findAll(findOptions: IFindOptions): Promise<IFindResult<T>> {\n return this.processQueryResult(findOptions, true);\n }\n\n async findCount(findOptions: IFindOptions): Promise<number> {\n const items = await this.findCommand({\n ...findOptions,\n aggregateFunction: AGGREGATE_FUNCTIONS.COUNT,\n });\n\n const aggFunctionProperty = buildAggFunctionAlias(\n AGGREGATE_FUNCTIONS.COUNT,\n );\n const item: any = items.length ? items[0] : {};\n return item[aggFunctionProperty] || 0;\n }\n\n async update(\n filters: IFilter[] | ICompositeFilter,\n data: Partial<T>,\n ): Promise<any> {\n const savedRecord = await this.findItem({ filters });\n\n const inputData: { [key: string]: any } = {\n ...savedRecord,\n ...data,\n } as {\n [key: string]: any;\n };\n\n this.normalizeInputData(inputData);\n await this.updateCommand(filters as ICompositeFilter, inputData);\n return this.getItem(inputData);\n }\n\n async remove(\n filters: IFilter[] | ICompositeFilter | IFilter[][],\n options: IRemoveOptions,\n ): Promise<void> {\n await this.deleteCommand(filters, options?.filterGroups);\n }\n\n runQuery(querySentence: string, values?: any[]) {\n return super.runQuery(querySentence, values);\n }\n\n async updateExpressions(\n filters: IFilter[] | ICompositeFilter,\n actions: IUpdateExpressions,\n ): Promise<any> {\n return {};\n }\n}\n"]}
|