@qrvey/data-persistence 0.0.2-3 → 0.0.2-4-rev1
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/helpers/queryHelpers.js +5 -1
- package/dist/cjs/helpers/queryHelpers.js.map +1 -1
- package/dist/cjs/services/crud.service.js +7 -2
- package/dist/cjs/services/crud.service.js.map +1 -1
- package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js +42 -38
- package/dist/cjs/services/cruds/dynamodb/dynamoDbCrud.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js +9 -6
- package/dist/cjs/services/cruds/postgresql/postgreSqlClient.service.js.map +1 -1
- package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js +22 -9
- package/dist/cjs/services/cruds/postgresql/postgreSqlCrud.service.js.map +1 -1
- package/dist/cjs/types/aggregateFunction.type.js +5 -0
- package/dist/cjs/types/aggregateFunction.type.js.map +1 -0
- package/dist/cjs/types/index.js +1 -0
- package/dist/cjs/types/index.js.map +1 -1
- package/dist/cjs/utils/constants.js +5 -1
- package/dist/cjs/utils/constants.js.map +1 -1
- package/dist/types/index.d.ts +10 -1
- package/package.json +1 -1
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.METHOD_TO_QUERY = void 0;
|
|
3
|
+
exports.buildAggFunctionAlias = exports.METHOD_TO_QUERY = void 0;
|
|
4
4
|
var METHOD_TO_QUERY;
|
|
5
5
|
(function (METHOD_TO_QUERY) {
|
|
6
6
|
METHOD_TO_QUERY["where"] = "where";
|
|
7
7
|
METHOD_TO_QUERY["filter"] = "filter";
|
|
8
8
|
METHOD_TO_QUERY["update"] = "update";
|
|
9
9
|
})(METHOD_TO_QUERY || (exports.METHOD_TO_QUERY = METHOD_TO_QUERY = {}));
|
|
10
|
+
function buildAggFunctionAlias(aggregateFunction) {
|
|
11
|
+
return `AGG_FN_${aggregateFunction}`;
|
|
12
|
+
}
|
|
13
|
+
exports.buildAggFunctionAlias = buildAggFunctionAlias;
|
|
10
14
|
//# sourceMappingURL=queryHelpers.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"queryHelpers.js","sourceRoot":"","sources":["../../../src/helpers/queryHelpers.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"queryHelpers.js","sourceRoot":"","sources":["../../../src/helpers/queryHelpers.ts"],"names":[],"mappings":";;;AAEA,IAAY,eAIX;AAJD,WAAY,eAAe;IACvB,kCAAe,CAAA;IACf,oCAAiB,CAAA;IACjB,oCAAiB,CAAA;AACrB,CAAC,EAJW,eAAe,+BAAf,eAAe,QAI1B;AAED,SAAgB,qBAAqB,CACjC,iBAAoC;IAEpC,OAAO,UAAU,iBAAiB,EAAE,CAAC;AACzC,CAAC;AAJD,sDAIC"}
|
|
@@ -37,8 +37,13 @@ class CrudService {
|
|
|
37
37
|
const { pagination } = options, findAllOptions = __rest(options, ["pagination"]);
|
|
38
38
|
return this.crudService.findAll(findAllOptions);
|
|
39
39
|
}
|
|
40
|
-
|
|
41
|
-
|
|
40
|
+
findCount(options) {
|
|
41
|
+
// eslint-disable-next-line no-unused-vars, @typescript-eslint/no-unused-vars
|
|
42
|
+
const { pagination } = options, findAllOptions = __rest(options, ["pagination"]);
|
|
43
|
+
return this.crudService.findCount(findAllOptions);
|
|
44
|
+
}
|
|
45
|
+
buildFilter(attribute, value, operator = 'EQUAL', options = {}) {
|
|
46
|
+
return (0, crudHelpers_1.buildFilter)(attribute, value, operator, options);
|
|
42
47
|
}
|
|
43
48
|
buildQueryIndex(indexName, columns) {
|
|
44
49
|
return (0, crudHelpers_1.buildQueryIndex)(indexName, columns);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crud.service.js","sourceRoot":"","sources":["../../../src/services/crud.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,wDAIgC;AAUhC,+DAAoD;AAEpD,MAAM,WAAW;IAGb,YAAY,UAA6B;QACrC,IAAI,CAAC,WAAW,GAAG,iCAAW,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACrE,CAAC;IAED,MAAM,CAAC,MAAS;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED,IAAI,CAAC,OAAqB;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,QAAQ,CAAC,OAAqB;QAC1B,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,MAAM,CACF,OAAoC,EACpC,IAAgB;QAEhB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,OAAoC;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,OAAqB;QACzB,6EAA6E;QAC7E,MAAM,EAAE,UAAU,KAAwB,OAAO,EAA1B,cAAc,UAAK,OAAO,EAA3C,cAAiC,CAAU,CAAC;QAClD,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACpD,CAAC;IAED,WAAW,CAAC,SAAiB,
|
|
1
|
+
{"version":3,"file":"crud.service.js","sourceRoot":"","sources":["../../../src/services/crud.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,wDAIgC;AAUhC,+DAAoD;AAEpD,MAAM,WAAW;IAGb,YAAY,UAA6B;QACrC,IAAI,CAAC,WAAW,GAAG,iCAAW,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC;IACrE,CAAC;IAED,MAAM,CAAC,MAAS;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED,IAAI,CAAC,OAAqB;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,QAAQ,CAAC,OAAqB;QAC1B,OAAO,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,MAAM,CACF,OAAoC,EACpC,IAAgB;QAEhB,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,CAAC,OAAoC;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,OAAqB;QACzB,6EAA6E;QAC7E,MAAM,EAAE,UAAU,KAAwB,OAAO,EAA1B,cAAc,UAAK,OAAO,EAA3C,cAAiC,CAAU,CAAC;QAClD,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACpD,CAAC;IAED,SAAS,CAAC,OAAqB;QAC3B,6EAA6E;QAC7E,MAAM,EAAE,UAAU,KAAwB,OAAO,EAA1B,cAAc,UAAK,OAAO,EAA3C,cAAiC,CAAU,CAAC;QAClD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;IACtD,CAAC;IAED,WAAW,CACP,SAAiB,EACjB,KAAa,EACb,QAAQ,GAAG,OAAO,EAClB,OAAO,GAAG,EAAE;QAEZ,OAAO,IAAA,yBAAW,EAAC,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;IAED,eAAe,CAAC,SAAiB,EAAE,OAAiB;QAChD,OAAO,IAAA,6BAAe,EAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC;IAED,SAAS,CAAC,MAAc,EAAE,SAAwB;QAC9C,OAAO,IAAA,uBAAS,EAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACxC,CAAC;CACJ;AAED,kBAAe,WAAW,CAAC"}
|
|
@@ -64,6 +64,48 @@ class DynamoDbCrudService {
|
|
|
64
64
|
};
|
|
65
65
|
});
|
|
66
66
|
}
|
|
67
|
+
async fetchResults(command, limit = 100, useScan = false) {
|
|
68
|
+
var _a, _b, _c, _d, _e;
|
|
69
|
+
let results = [];
|
|
70
|
+
let LastEvaluatedKey = {};
|
|
71
|
+
do {
|
|
72
|
+
if (this.isNotEmptyObject(LastEvaluatedKey))
|
|
73
|
+
command.ExclusiveStartKey = LastEvaluatedKey;
|
|
74
|
+
const result = await (useScan
|
|
75
|
+
? this.dynamoDbClientService.scan(command)
|
|
76
|
+
: this.dynamoDbClientService.query(command));
|
|
77
|
+
command.Limit = ((_a = command.Limit) !== null && _a !== void 0 ? _a : 0) - ((_c = (_b = result.Items) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : 0);
|
|
78
|
+
const rows = (_d = result.Items) !== null && _d !== void 0 ? _d : [];
|
|
79
|
+
results = [...results, ...rows];
|
|
80
|
+
LastEvaluatedKey = (_e = result.LastEvaluatedKey) !== null && _e !== void 0 ? _e : {};
|
|
81
|
+
} while (results.length < limit &&
|
|
82
|
+
this.isNotEmptyObject(LastEvaluatedKey));
|
|
83
|
+
const lastEvaluatedKey = this.isNotEmptyObject(LastEvaluatedKey)
|
|
84
|
+
? this.encryptPaginationKey(LastEvaluatedKey)
|
|
85
|
+
: null;
|
|
86
|
+
return { items: results, lastEvaluatedKey };
|
|
87
|
+
}
|
|
88
|
+
applyPagination(query, pagination) {
|
|
89
|
+
if (pagination === null || pagination === void 0 ? void 0 : pagination.limit)
|
|
90
|
+
query.limit(pagination.limit);
|
|
91
|
+
if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
|
|
92
|
+
query.startKey(this.decryptPaginationKey(pagination.from));
|
|
93
|
+
}
|
|
94
|
+
async findAll(options = {}, allResults = []) {
|
|
95
|
+
const { items, pagination } = await this.find(options);
|
|
96
|
+
allResults.push(...items);
|
|
97
|
+
if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
|
|
98
|
+
await this.findAll(Object.assign(Object.assign({}, options), { pagination }), allResults);
|
|
99
|
+
return {
|
|
100
|
+
items: allResults,
|
|
101
|
+
pagination: null,
|
|
102
|
+
count: allResults.length,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
async findCount(options = {}) {
|
|
106
|
+
const { items } = await this.find(options);
|
|
107
|
+
return items.length;
|
|
108
|
+
}
|
|
67
109
|
async findItem(options) {
|
|
68
110
|
var _a, _b, _c;
|
|
69
111
|
const query = new queryBuilder_service_1.default();
|
|
@@ -134,44 +176,6 @@ class DynamoDbCrudService {
|
|
|
134
176
|
const decodedKey = Buffer.from(encodedKey, 'base64').toString('utf-8');
|
|
135
177
|
return JSON.parse(decodedKey);
|
|
136
178
|
}
|
|
137
|
-
async fetchResults(command, limit = 100, useScan = false) {
|
|
138
|
-
var _a, _b, _c, _d, _e;
|
|
139
|
-
let results = [];
|
|
140
|
-
let LastEvaluatedKey = {};
|
|
141
|
-
do {
|
|
142
|
-
if (this.isNotEmptyObject(LastEvaluatedKey))
|
|
143
|
-
command.ExclusiveStartKey = LastEvaluatedKey;
|
|
144
|
-
const result = await (useScan
|
|
145
|
-
? this.dynamoDbClientService.scan(command)
|
|
146
|
-
: this.dynamoDbClientService.query(command));
|
|
147
|
-
command.Limit = ((_a = command.Limit) !== null && _a !== void 0 ? _a : 0) - ((_c = (_b = result.Items) === null || _b === void 0 ? void 0 : _b.length) !== null && _c !== void 0 ? _c : 0);
|
|
148
|
-
const rows = (_d = result.Items) !== null && _d !== void 0 ? _d : [];
|
|
149
|
-
results = [...results, ...rows];
|
|
150
|
-
LastEvaluatedKey = (_e = result.LastEvaluatedKey) !== null && _e !== void 0 ? _e : {};
|
|
151
|
-
} while (results.length < limit &&
|
|
152
|
-
this.isNotEmptyObject(LastEvaluatedKey));
|
|
153
|
-
const lastEvaluatedKey = this.isNotEmptyObject(LastEvaluatedKey)
|
|
154
|
-
? this.encryptPaginationKey(LastEvaluatedKey)
|
|
155
|
-
: null;
|
|
156
|
-
return { items: results, lastEvaluatedKey };
|
|
157
|
-
}
|
|
158
|
-
applyPagination(query, pagination) {
|
|
159
|
-
if (pagination === null || pagination === void 0 ? void 0 : pagination.limit)
|
|
160
|
-
query.limit(pagination.limit);
|
|
161
|
-
if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
|
|
162
|
-
query.startKey(this.decryptPaginationKey(pagination.from));
|
|
163
|
-
}
|
|
164
|
-
async findAll(options = {}, allResults = []) {
|
|
165
|
-
const { items, pagination } = await this.find(options);
|
|
166
|
-
allResults.push(...items);
|
|
167
|
-
if (pagination === null || pagination === void 0 ? void 0 : pagination.from)
|
|
168
|
-
await this.findAll(Object.assign(Object.assign({}, options), { pagination }), allResults);
|
|
169
|
-
return {
|
|
170
|
-
items: allResults,
|
|
171
|
-
pagination: null,
|
|
172
|
-
count: allResults.length,
|
|
173
|
-
};
|
|
174
|
-
}
|
|
175
179
|
async update(filters, data, { replace = false }) {
|
|
176
180
|
const savedRecord = await this.findItem({
|
|
177
181
|
filters: filters,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dynamoDbCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAuD;AACvD,mDAAuC;AAEvC,sFAA6D;AAC7D,kFAAyD;AAEzD,wDAGkC;AASlC,8DAIsC;AAEtC,MAAa,mBAAmB;IAG5B,YAAoB,WAA8B;QAA9B,gBAAW,GAAX,WAAW,CAAmB;QAC9C,IAAI,CAAC,qBAAqB,GAAG,IAAI,gCAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC3E,CAAC;IAED,IAAY,SAAS;QACjB,OAAO,IAAA,0BAAY,EAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;IAED,IAAY,YAAY;QACpB,OAAO,IAAA,8BAAgB,EAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,IAAY,kBAAkB;QAC1B,OAAO,IAAA,kCAAoB,EAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAS;;QAClB,IAAI,SAAS,GAAM,MAAM,CAAC;QAC1B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,OAAO,GACT,CAAA,MAAC,MAAc,CAAC,IAAI,CAAC,YAAY,CAAC,0CAAE,QAAQ,EAAE,KAAI,IAAA,sBAAK,GAAE,CAAC;YAC9D,SAAS,mCAAQ,MAAM,KAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,OAAO,GAAE,CAAC;QAC5D,CAAC;QAED,MAAM,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAgC,CAAC,CAAC;QACvE,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,6EAA6E;IAC7E,QAAQ,CAAC,YAAiB;QACtB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC/C,CAAC;
|
|
1
|
+
{"version":3,"file":"dynamoDbCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/dynamodb/dynamoDbCrud.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,6 +9,7 @@ const pg_format_1 = __importDefault(require("pg-format"));
|
|
|
9
9
|
const query_service_1 = __importDefault(require("./query.service"));
|
|
10
10
|
const constants_1 = require("../../../utils/constants");
|
|
11
11
|
const tableHelper_1 = require("../../../helpers/tableHelper");
|
|
12
|
+
const queryHelpers_1 = require("../../../helpers/queryHelpers");
|
|
12
13
|
class PostgresqlClientService extends query_service_1.default {
|
|
13
14
|
constructor(tableSchema) {
|
|
14
15
|
const useConnectionPool = tableSchema.usePool || false;
|
|
@@ -104,16 +105,18 @@ class PostgresqlClientService extends query_service_1.default {
|
|
|
104
105
|
}
|
|
105
106
|
return query;
|
|
106
107
|
}
|
|
107
|
-
getSelectClause(fields) {
|
|
108
|
+
getSelectClause(aggregateFunction, fields = []) {
|
|
109
|
+
if (aggregateFunction)
|
|
110
|
+
return `${aggregateFunction}(1) ${(0, queryHelpers_1.buildAggFunctionAlias)(aggregateFunction)}`;
|
|
108
111
|
if (!(fields === null || fields === void 0 ? void 0 : fields.length))
|
|
109
112
|
return '*';
|
|
110
113
|
return fields.join(', ');
|
|
111
114
|
}
|
|
112
|
-
async findCommand(options) {
|
|
113
|
-
let query = `SELECT ${this.getSelectClause(options
|
|
114
|
-
query = this.addFiltersToQuery(query, options
|
|
115
|
-
query = this.addOrderByToQuery(query, options
|
|
116
|
-
query = this.addPaginationToQuery(query, options
|
|
115
|
+
async findCommand(options = {}) {
|
|
116
|
+
let query = `SELECT ${this.getSelectClause(options.aggregateFunction, options.fields)} FROM ${pg_format_1.default.ident(this.dbSchema)}.${pg_format_1.default.ident(this.tableName)}`;
|
|
117
|
+
query = this.addFiltersToQuery(query, options.filters);
|
|
118
|
+
query = this.addOrderByToQuery(query, options.sorting);
|
|
119
|
+
query = this.addPaginationToQuery(query, options.pagination);
|
|
117
120
|
return (await this.runQuery(query)).rows;
|
|
118
121
|
}
|
|
119
122
|
sanitizeValue(value) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgreSqlClient.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlClient.service.ts"],"names":[],"mappings":";AAAA,uDAAuD;AACvD,+BAA+B;;;;;AAE/B,0DAA+B;AAU/B,oEAA2C;AAC3C,wDAMkC;AAElC,8DAA4D;
|
|
1
|
+
{"version":3,"file":"postgreSqlClient.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlClient.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,8 @@ exports.PostgreSqlCrudService = void 0;
|
|
|
8
8
|
const q_id_generator_1 = require("q-id-generator");
|
|
9
9
|
const postgreSqlClient_service_1 = __importDefault(require("./postgreSqlClient.service"));
|
|
10
10
|
const tableHelper_1 = require("../../../helpers/tableHelper");
|
|
11
|
+
const constants_1 = require("../../../utils/constants");
|
|
12
|
+
const queryHelpers_1 = require("../../../helpers/queryHelpers");
|
|
11
13
|
class PostgreSqlCrudService extends postgreSqlClient_service_1.default {
|
|
12
14
|
constructor(tableSchema) {
|
|
13
15
|
super(tableSchema);
|
|
@@ -47,17 +49,28 @@ class PostgreSqlCrudService extends postgreSqlClient_service_1.default {
|
|
|
47
49
|
: null;
|
|
48
50
|
});
|
|
49
51
|
}
|
|
50
|
-
|
|
52
|
+
async processQueryResult(findOptions, omitPagination = false) {
|
|
51
53
|
const { pagination } = findOptions;
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
54
|
+
const rows = await this.findCommand(findOptions);
|
|
55
|
+
const items = rows.map((row) => this.getItem(row));
|
|
56
|
+
const result = {
|
|
57
|
+
items,
|
|
58
|
+
pagination: omitPagination ? null : pagination,
|
|
59
|
+
count: items.length,
|
|
60
|
+
};
|
|
61
|
+
return result;
|
|
55
62
|
}
|
|
56
|
-
|
|
57
|
-
return this.
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
63
|
+
async find(findOptions) {
|
|
64
|
+
return this.processQueryResult(findOptions);
|
|
65
|
+
}
|
|
66
|
+
async findAll(findOptions) {
|
|
67
|
+
return this.processQueryResult(findOptions, true);
|
|
68
|
+
}
|
|
69
|
+
async findCount(findOptions) {
|
|
70
|
+
const items = await this.findCommand(Object.assign(Object.assign({}, findOptions), { aggregateFunction: constants_1.AGGREGATE_FUNCTIONS.COUNT }));
|
|
71
|
+
const aggFunctionProperty = (0, queryHelpers_1.buildAggFunctionAlias)(constants_1.AGGREGATE_FUNCTIONS.COUNT);
|
|
72
|
+
const item = items.length ? items[0] : {};
|
|
73
|
+
return item[aggFunctionProperty] || 0;
|
|
61
74
|
}
|
|
62
75
|
async update(filters, data) {
|
|
63
76
|
const savedRecord = await this.findItem({ filters });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgreSqlCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAuD;AACvD,mDAAuC;AACvC,0FAAiE;AASjE,8DAAgE;
|
|
1
|
+
{"version":3,"file":"postgreSqlCrud.service.js","sourceRoot":"","sources":["../../../../../src/services/cruds/postgresql/postgreSqlCrud.service.ts"],"names":[],"mappings":";;;;;;AAAA,uDAAuD;AACvD,mDAAuC;AACvC,0FAAiE;AASjE,8DAAgE;AAChE,wDAA+D;AAC/D,gEAAsE;AAEtE,MAAa,qBACT,SAAQ,kCAA0B;IAGlC,YAAoB,WAA8B;QAC9C,KAAK,CAAC,WAAW,CAAC,CAAC;QADH,gBAAW,GAAX,WAAW,CAAmB;IAElD,CAAC;IAED,IAAY,YAAY;QACpB,OAAO,IAAA,8BAAgB,EAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IACtD,CAAC;IAED,kCAAkC,CAAC,SAAc;QAC7C,SAAS,CAAC,YAAY,GAAG,EAAE,CAAC;QAC5B,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,KAAK,cAAc,EAAE,CAAC;gBAC3D,SAAS,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC;gBAC7C,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC;YAC1B,CAAC;QACL,CAAC;IACL,CAAC;IAED,OAAO,CAAC,IAA4B;QAChC,MAAM,UAAU,mCAAQ,IAAI,GAAK,IAAI,CAAC,YAAY,CAAE,CAAC;QACrD,OAAO,UAAU,CAAC,cAAc,CAAC,CAAC;QAClC,OAAO,UAAU,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,MAAS;;QACZ,IAAI,SAAS,GAA2B,kBAAK,MAAM,CAElD,CAAC;QACF,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,OAAO,GACT,CAAA,MAAC,MAAc,CAAC,IAAI,CAAC,YAAY,CAAC,0CAAE,QAAQ,EAAE,KAAI,IAAA,sBAAK,GAAE,CAAC;YAC9D,SAAS,mCAAQ,MAAM,KAAE,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,OAAO,GAAE,CAAC;QAC5D,CAAC;QACD,IAAI,CAAC,kCAAkC,CAAC,SAAS,CAAC,CAAC;QAEnD,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAM,CAAC,CAAC;IAC3E,CAAC;IAED,QAAQ,CAAC,WAAyB;QAC9B,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,OAAO,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,MAAM;gBACf,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAA2B,CAAC;gBACjD,CAAC,CAAC,IAAI,CAAC;QACf,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAC5B,WAAyB,EACzB,iBAA0B,KAAK;QAE/B,MAAM,EAAE,UAAU,EAAE,GAAG,WAAW,CAAC;QACnC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAC3B,IAAI,CAAC,OAAO,CAAC,GAA6B,CAAC,CAC9C,CAAC;QACF,MAAM,MAAM,GAAmB;YAC3B,KAAK;YACL,UAAU,EAAE,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU;YAC9C,KAAK,EAAE,KAAK,CAAC,MAAM;SACtB,CAAC;QACF,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,WAAyB;QAChC,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAChD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,WAAyB;QACnC,OAAO,IAAI,CAAC,kBAAkB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,WAAyB;QACrC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,WAAW,iCAC7B,WAAW,KACd,iBAAiB,EAAE,+BAAmB,CAAC,KAAK,IAC9C,CAAC;QAEH,MAAM,mBAAmB,GAAG,IAAA,oCAAqB,EAC7C,+BAAmB,CAAC,KAAK,CAC5B,CAAC;QACF,MAAM,IAAI,GAAQ,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/C,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,MAAM,CACR,OAAoC,EACpC,IAAgB;QAEhB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;QAErD,MAAM,SAAS,GAA2B,gCACnC,WAAW,GACX,IAAI,CAGV,CAAC;QAEF,IAAI,CAAC,kCAAkC,CAAC,SAAS,CAAC,CAAC;QACnD,MAAM,IAAI,CAAC,aAAa,CAAC,OAA0B,EAAE,SAAS,CAAC,CAAC;QAChE,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,OAAoC;QAC7C,MAAM,IAAI,CAAC,aAAa,CAAC,OAA0B,CAAC,CAAC;IACzD,CAAC;IAED,QAAQ,CAAC,aAAqB,EAAE,MAAc;QAC1C,OAAO,KAAK,CAAC,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;IACjD,CAAC;CACJ;AAjHD,sDAiHC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aggregateFunction.type.js","sourceRoot":"","sources":["../../../src/types/aggregateFunction.type.ts"],"names":[],"mappings":";;AAAA,kDAAyD;AAEzD,MAAM,yBAAyB,GAC3B,MAAM,CAAC,MAAM,CAAC,+BAAmB,CAAC,CAAC"}
|
package/dist/cjs/types/index.js
CHANGED
|
@@ -18,4 +18,5 @@ __exportStar(require("./filterInput.type"), exports);
|
|
|
18
18
|
__exportStar(require("./sortDirection.type"), exports);
|
|
19
19
|
__exportStar(require("./filterLogicOperator.type"), exports);
|
|
20
20
|
__exportStar(require("./connectionClosingMode.type"), exports);
|
|
21
|
+
__exportStar(require("./aggregateFunction.type"), exports);
|
|
21
22
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,uDAAqC;AACrC,6DAA2C;AAC3C,+DAA6C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,uDAAqC;AACrC,6DAA2C;AAC3C,+DAA6C;AAC7C,2DAAyC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DEFAULT_PG_SCHEMA = exports.POSTGRES_FILTER_OPERATOR_MAP = exports.FilterOperator = exports.FILTER_LOGIC_OPERATORS = exports.CONNECTION_CLOSING_MODES = exports.SORT_DIRECTIONS = exports.DYNAMODB_OPERATORS = exports.FILTER_OPERATOR_MAP = void 0;
|
|
3
|
+
exports.AGGREGATE_FUNCTIONS = exports.DEFAULT_PG_SCHEMA = exports.POSTGRES_FILTER_OPERATOR_MAP = exports.FilterOperator = exports.FILTER_LOGIC_OPERATORS = exports.CONNECTION_CLOSING_MODES = exports.SORT_DIRECTIONS = exports.DYNAMODB_OPERATORS = exports.FILTER_OPERATOR_MAP = void 0;
|
|
4
4
|
exports.FILTER_OPERATOR_MAP = {
|
|
5
5
|
CONTAINS: 'contains',
|
|
6
6
|
NOT_CONTAINS: 'notContains',
|
|
@@ -65,4 +65,8 @@ exports.POSTGRES_FILTER_OPERATOR_MAP = {
|
|
|
65
65
|
NOT_CONTAINS: 'NOT LIKE',
|
|
66
66
|
};
|
|
67
67
|
exports.DEFAULT_PG_SCHEMA = 'public';
|
|
68
|
+
var AGGREGATE_FUNCTIONS;
|
|
69
|
+
(function (AGGREGATE_FUNCTIONS) {
|
|
70
|
+
AGGREGATE_FUNCTIONS["COUNT"] = "COUNT";
|
|
71
|
+
})(AGGREGATE_FUNCTIONS || (exports.AGGREGATE_FUNCTIONS = AGGREGATE_FUNCTIONS = {}));
|
|
68
72
|
//# sourceMappingURL=constants.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/utils/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,mBAAmB,GAA8B;IAC1D,QAAQ,EAAE,UAAU;IACpB,YAAY,EAAE,aAAa;IAC3B,KAAK,EAAE,IAAI;IACX,WAAW,EAAE,YAAY;IACzB,SAAS,EAAE,OAAO;IAClB,EAAE,EAAE,IAAI;IACR,YAAY,EAAE,IAAI;IAClB,EAAE,EAAE,IAAI;IACR,kBAAkB,EAAE,KAAK;IACzB,GAAG,EAAE,KAAK;IACV,SAAS,EAAE,IAAI;IACf,EAAE,EAAE,IAAI;IACR,eAAe,EAAE,KAAK;IACtB,GAAG,EAAE,KAAK;CACb,CAAC;AAEW,QAAA,kBAAkB,GAA8B;IACzD,KAAK,EAAE,OAAO;CACjB,CAAC;AAEF,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,8BAAW,CAAA;IACX,gCAAa,CAAA;AACjB,CAAC,EAHW,eAAe,+BAAf,eAAe,QAG1B;AAED,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAChC,yCAAa,CAAA;IACb,6CAAiB,CAAA;AACrB,CAAC,EAHW,wBAAwB,wCAAxB,wBAAwB,QAGnC;AAED,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAC9B,qCAAW,CAAA;IACX,mCAAS,CAAA;AACb,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAED,IAAY,cAWX;AAXD,WAAY,cAAc;IACtB,iCAAe,CAAA;IACf,yCAAuB,CAAA;IACvB,uCAAqB,CAAA;IACrB,+CAA6B,CAAA;IAC7B,2DAAyC,CAAA;IACzC,yCAAuB,CAAA;IACvB,qDAAmC,CAAA;IACnC,2BAAS,CAAA;IACT,6CAA2B,CAAA;IAC3B,+CAA6B,CAAA;AACjC,CAAC,EAXW,cAAc,8BAAd,cAAc,QAWzB;AAEY,QAAA,4BAA4B,GAAG;IACxC,KAAK,EAAE,GAAG;IACV,SAAS,EAAE,IAAI;IACf,YAAY,EAAE,GAAG;IACjB,EAAE,EAAE,GAAG;IACP,GAAG,EAAE,IAAI;IACT,kBAAkB,EAAE,IAAI;IACxB,GAAG,EAAE,IAAI;IACT,eAAe,EAAE,IAAI;IACrB,SAAS,EAAE,GAAG;IACd,EAAE,EAAE,GAAG;IACP,EAAE,EAAE,IAAI;IACR,WAAW,EAAE,MAAM;IACnB,QAAQ,EAAE,MAAM;IAChB,YAAY,EAAE,UAAU;CAC3B,CAAC;AAEW,QAAA,iBAAiB,GAAG,QAAQ,CAAC"}
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/utils/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,mBAAmB,GAA8B;IAC1D,QAAQ,EAAE,UAAU;IACpB,YAAY,EAAE,aAAa;IAC3B,KAAK,EAAE,IAAI;IACX,WAAW,EAAE,YAAY;IACzB,SAAS,EAAE,OAAO;IAClB,EAAE,EAAE,IAAI;IACR,YAAY,EAAE,IAAI;IAClB,EAAE,EAAE,IAAI;IACR,kBAAkB,EAAE,KAAK;IACzB,GAAG,EAAE,KAAK;IACV,SAAS,EAAE,IAAI;IACf,EAAE,EAAE,IAAI;IACR,eAAe,EAAE,KAAK;IACtB,GAAG,EAAE,KAAK;CACb,CAAC;AAEW,QAAA,kBAAkB,GAA8B;IACzD,KAAK,EAAE,OAAO;CACjB,CAAC;AAEF,IAAY,eAGX;AAHD,WAAY,eAAe;IACvB,8BAAW,CAAA;IACX,gCAAa,CAAA;AACjB,CAAC,EAHW,eAAe,+BAAf,eAAe,QAG1B;AAED,IAAY,wBAGX;AAHD,WAAY,wBAAwB;IAChC,yCAAa,CAAA;IACb,6CAAiB,CAAA;AACrB,CAAC,EAHW,wBAAwB,wCAAxB,wBAAwB,QAGnC;AAED,IAAY,sBAGX;AAHD,WAAY,sBAAsB;IAC9B,qCAAW,CAAA;IACX,mCAAS,CAAA;AACb,CAAC,EAHW,sBAAsB,sCAAtB,sBAAsB,QAGjC;AAED,IAAY,cAWX;AAXD,WAAY,cAAc;IACtB,iCAAe,CAAA;IACf,yCAAuB,CAAA;IACvB,uCAAqB,CAAA;IACrB,+CAA6B,CAAA;IAC7B,2DAAyC,CAAA;IACzC,yCAAuB,CAAA;IACvB,qDAAmC,CAAA;IACnC,2BAAS,CAAA;IACT,6CAA2B,CAAA;IAC3B,+CAA6B,CAAA;AACjC,CAAC,EAXW,cAAc,8BAAd,cAAc,QAWzB;AAEY,QAAA,4BAA4B,GAAG;IACxC,KAAK,EAAE,GAAG;IACV,SAAS,EAAE,IAAI;IACf,YAAY,EAAE,GAAG;IACjB,EAAE,EAAE,GAAG;IACP,GAAG,EAAE,IAAI;IACT,kBAAkB,EAAE,IAAI;IACxB,GAAG,EAAE,IAAI;IACT,eAAe,EAAE,IAAI;IACrB,SAAS,EAAE,GAAG;IACd,EAAE,EAAE,GAAG;IACP,EAAE,EAAE,IAAI;IACR,WAAW,EAAE,MAAM;IACnB,QAAQ,EAAE,MAAM;IAChB,YAAY,EAAE,UAAU;CAC3B,CAAC;AAEW,QAAA,iBAAiB,GAAG,QAAQ,CAAC;AAE1C,IAAY,mBAEX;AAFD,WAAY,mBAAmB;IAC3B,sCAAe,CAAA;AACnB,CAAC,EAFW,mBAAmB,mCAAnB,mBAAmB,QAE9B"}
|
package/dist/types/index.d.ts
CHANGED
|
@@ -23,6 +23,7 @@ interface IFindPagination {
|
|
|
23
23
|
interface IFindOptions {
|
|
24
24
|
fields?: string[];
|
|
25
25
|
filters?: IFilter[] | ICompoundFilter;
|
|
26
|
+
aggregateFunction?: AggregateFunction;
|
|
26
27
|
sorting?: ISorting[];
|
|
27
28
|
pagination?: IFindPagination;
|
|
28
29
|
throwErrorIfNull?: boolean;
|
|
@@ -34,6 +35,7 @@ interface IFindOptions {
|
|
|
34
35
|
interface IFindResult<T> {
|
|
35
36
|
items: T[];
|
|
36
37
|
pagination?: IFindPagination | null;
|
|
38
|
+
count: number;
|
|
37
39
|
}
|
|
38
40
|
|
|
39
41
|
declare enum SORT_DIRECTIONS {
|
|
@@ -44,6 +46,9 @@ declare enum FILTER_LOGIC_OPERATORS {
|
|
|
44
46
|
AND = "AND",
|
|
45
47
|
OR = "OR"
|
|
46
48
|
}
|
|
49
|
+
declare enum AGGREGATE_FUNCTIONS {
|
|
50
|
+
COUNT = "COUNT"
|
|
51
|
+
}
|
|
47
52
|
|
|
48
53
|
declare const VALID_SORT_DIRECTIONS: SORT_DIRECTIONS[];
|
|
49
54
|
type SortDirection = (typeof VALID_SORT_DIRECTIONS)[number];
|
|
@@ -64,6 +69,9 @@ interface ITableColumns {
|
|
|
64
69
|
declare const VALID_FILTER_LOGIC_OPERATORS: FILTER_LOGIC_OPERATORS[];
|
|
65
70
|
type FilterLogicOperator = (typeof VALID_FILTER_LOGIC_OPERATORS)[number];
|
|
66
71
|
|
|
72
|
+
declare const VALID_AGGREGATE_FUNCTIONS: AGGREGATE_FUNCTIONS[];
|
|
73
|
+
type AggregateFunction = (typeof VALID_AGGREGATE_FUNCTIONS)[number];
|
|
74
|
+
|
|
67
75
|
interface ISorting {
|
|
68
76
|
column: string;
|
|
69
77
|
direction?: SortDirection;
|
|
@@ -85,7 +93,8 @@ declare class CrudService<T> {
|
|
|
85
93
|
update(filters: IFilter[] | ICompoundFilter, data: Partial<T>): Promise<T | null>;
|
|
86
94
|
remove(filters: IFilter[] | ICompoundFilter): Promise<void>;
|
|
87
95
|
findAll(options: IFindOptions): Promise<IFindResult<T>>;
|
|
88
|
-
|
|
96
|
+
findCount(options: IFindOptions): Promise<number>;
|
|
97
|
+
buildFilter(attribute: string, value: string, operator?: string, options?: {}): {
|
|
89
98
|
attribute: string;
|
|
90
99
|
operator: string;
|
|
91
100
|
value: string;
|