@rafikidota/iroh 0.22.0 → 0.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/common/database/data-source.provider.js.map +1 -0
- package/dist/common/database/index.d.ts +3 -0
- package/dist/common/database/index.js +3 -0
- package/dist/common/database/index.js.map +1 -1
- package/dist/common/database/query-builder/constant/index.d.ts +1 -0
- package/dist/common/database/query-builder/constant/index.js +18 -0
- package/dist/common/database/query-builder/constant/index.js.map +1 -0
- package/dist/common/database/query-builder/constant/sql-keys.d.ts +20 -0
- package/dist/common/database/query-builder/constant/sql-keys.js +24 -0
- package/dist/common/database/query-builder/constant/sql-keys.js.map +1 -0
- package/dist/common/database/query-builder/enum/filter.operator.enum.d.ts +20 -0
- package/dist/common/database/query-builder/enum/filter.operator.enum.js +25 -0
- package/dist/common/database/query-builder/enum/filter.operator.enum.js.map +1 -0
- package/dist/common/database/query-builder/enum/index.d.ts +2 -0
- package/dist/common/database/query-builder/enum/index.js +19 -0
- package/dist/common/database/query-builder/enum/index.js.map +1 -0
- package/dist/common/database/query-builder/enum/logical.operator.enum.d.ts +5 -0
- package/dist/common/database/query-builder/enum/logical.operator.enum.js +10 -0
- package/dist/common/database/query-builder/enum/logical.operator.enum.js.map +1 -0
- package/dist/common/database/query-builder/index.d.ts +7 -0
- package/dist/common/database/query-builder/index.js +24 -0
- package/dist/common/database/query-builder/index.js.map +1 -0
- package/dist/common/database/query-builder/options/find.option.d.ts +18 -0
- package/dist/common/database/query-builder/options/find.option.js +105 -0
- package/dist/common/database/query-builder/options/find.option.js.map +1 -0
- package/dist/common/database/query-builder/options/index.d.ts +5 -0
- package/dist/common/database/query-builder/options/index.js +22 -0
- package/dist/common/database/query-builder/options/index.js.map +1 -0
- package/dist/common/database/query-builder/options/order.option.d.ts +4 -0
- package/dist/common/database/query-builder/options/order.option.js +3 -0
- package/dist/common/database/query-builder/options/order.option.js.map +1 -0
- package/dist/common/database/query-builder/options/relation.option.d.ts +4 -0
- package/dist/common/database/query-builder/options/relation.option.js +3 -0
- package/dist/common/database/query-builder/options/relation.option.js.map +1 -0
- package/dist/common/database/query-builder/options/select.option.d.ts +3 -0
- package/dist/common/database/query-builder/options/select.option.js +3 -0
- package/dist/common/database/query-builder/options/select.option.js.map +1 -0
- package/dist/common/database/query-builder/options/where.option.d.ts +33 -0
- package/dist/common/database/query-builder/options/where.option.js +3 -0
- package/dist/common/database/query-builder/options/where.option.js.map +1 -0
- package/dist/common/database/query-builder/query-builder.d.ts +22 -0
- package/dist/common/database/query-builder/query-builder.js +105 -0
- package/dist/common/database/query-builder/query-builder.js.map +1 -0
- package/dist/common/database/query-builder/query-builder.module.d.ts +2 -0
- package/dist/common/database/query-builder/query-builder.module.js +31 -0
- package/dist/common/database/query-builder/query-builder.module.js.map +1 -0
- package/dist/common/database/query-builder/query-builder.provider.d.ts +26 -0
- package/dist/common/database/query-builder/query-builder.provider.js +126 -0
- package/dist/common/database/query-builder/query-builder.provider.js.map +1 -0
- package/dist/common/database/query-builder/query-form.d.ts +10 -0
- package/dist/common/database/query-builder/query-form.js +3 -0
- package/dist/common/database/query-builder/query-form.js.map +1 -0
- package/dist/common/database/query-builder/utils/add-and-operator.util.d.ts +2 -0
- package/dist/common/database/query-builder/utils/add-and-operator.util.js +26 -0
- package/dist/common/database/query-builder/utils/add-and-operator.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/add-equal-operator.util.d.ts +2 -0
- package/dist/common/database/query-builder/utils/add-equal-operator.util.js +25 -0
- package/dist/common/database/query-builder/utils/add-equal-operator.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/build-sql-where.util.d.ts +5 -0
- package/dist/common/database/query-builder/utils/build-sql-where.util.js +100 -0
- package/dist/common/database/query-builder/utils/build-sql-where.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/convert-to-dot-notation.util.d.ts +1 -0
- package/dist/common/database/query-builder/utils/convert-to-dot-notation.util.js +30 -0
- package/dist/common/database/query-builder/utils/convert-to-dot-notation.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/format-where.util.d.ts +2 -0
- package/dist/common/database/query-builder/utils/format-where.util.js +14 -0
- package/dist/common/database/query-builder/utils/format-where.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/map-to-and-conditions.utils.d.ts +5 -0
- package/dist/common/database/query-builder/utils/map-to-and-conditions.utils.js +12 -0
- package/dist/common/database/query-builder/utils/map-to-and-conditions.utils.js.map +1 -0
- package/dist/common/database/query-builder/utils/qet-prop-selection.utils.d.ts +2 -0
- package/dist/common/database/query-builder/utils/qet-prop-selection.utils.js +25 -0
- package/dist/common/database/query-builder/utils/qet-prop-selection.utils.js.map +1 -0
- package/dist/common/database/query-builder/utils/qet-truthy-props.utils.d.ts +3 -0
- package/dist/common/database/query-builder/utils/qet-truthy-props.utils.js +10 -0
- package/dist/common/database/query-builder/utils/qet-truthy-props.utils.js.map +1 -0
- package/dist/common/database/query-builder/utils/query-builder.util.d.ts +13 -0
- package/dist/common/database/query-builder/utils/query-builder.util.js +31 -0
- package/dist/common/database/query-builder/utils/query-builder.util.js.map +1 -0
- package/dist/common/database/query-builder/utils/translate-query.utill.d.ts +4 -0
- package/dist/common/database/query-builder/utils/translate-query.utill.js +45 -0
- package/dist/common/database/query-builder/utils/translate-query.utill.js.map +1 -0
- package/dist/common/database/typeorm-connection.provider.js.map +1 -0
- package/dist/common/database/typeorm-unit-of-work/index.d.ts +0 -2
- package/dist/common/database/typeorm-unit-of-work/index.js +0 -2
- package/dist/common/database/typeorm-unit-of-work/index.js.map +1 -1
- package/dist/common/database/typeorm-unit-of-work/typeorm-unit-of-work.module.js +2 -2
- package/dist/common/database/typeorm-unit-of-work/typeorm-unit-of-work.module.js.map +1 -1
- package/dist/common/decorators/generic-get-by-id.decorator.js +4 -1
- package/dist/common/decorators/generic-get-by-id.decorator.js.map +1 -1
- package/dist/common/decorators/generic-get.decorator.js +4 -1
- package/dist/common/decorators/generic-get.decorator.js.map +1 -1
- package/dist/common/decorators/index.d.ts +1 -0
- package/dist/common/decorators/index.js +1 -0
- package/dist/common/decorators/index.js.map +1 -1
- package/dist/common/decorators/query-option.decorator.d.ts +1 -0
- package/dist/common/decorators/query-option.decorator.js +9 -0
- package/dist/common/decorators/query-option.decorator.js.map +1 -0
- package/dist/common/dto/search.dto.d.ts +5 -0
- package/dist/common/dto/search.dto.js +31 -1
- package/dist/common/dto/search.dto.js.map +1 -1
- package/dist/common/interceptors/index.d.ts +1 -0
- package/dist/common/interceptors/index.js +1 -0
- package/dist/common/interceptors/index.js.map +1 -1
- package/dist/common/interceptors/query.options.interceptor.d.ts +8 -0
- package/dist/common/interceptors/query.options.interceptor.js +31 -0
- package/dist/common/interceptors/query.options.interceptor.js.map +1 -0
- package/dist/common/interfaces/crud.controller.d.ts +3 -2
- package/dist/common/interfaces/crud.repository.d.ts +2 -2
- package/dist/common/interfaces/crud.service.d.ts +2 -2
- package/dist/common/parsers/index.d.ts +1 -0
- package/dist/common/parsers/index.js +18 -0
- package/dist/common/parsers/index.js.map +1 -0
- package/dist/common/parsers/query.parser.d.ts +10 -0
- package/dist/common/parsers/query.parser.js +40 -0
- package/dist/common/parsers/query.parser.js.map +1 -0
- package/dist/core/domain/generic.domain.factory.d.ts +1 -0
- package/dist/core/domain/generic.domain.factory.js +5 -0
- package/dist/core/domain/generic.domain.factory.js.map +1 -1
- package/dist/core/infra/iroh.repository.d.ts +7 -2
- package/dist/core/infra/iroh.repository.js +36 -28
- package/dist/core/infra/iroh.repository.js.map +1 -1
- package/dist/core/iroh.controller.js +3 -1
- package/dist/core/iroh.controller.js.map +1 -1
- package/dist/core/iroh.service.d.ts +2 -2
- package/dist/core/iroh.service.js.map +1 -1
- package/package.json +12 -12
- package/dist/common/database/typeorm-unit-of-work/data-source.provider.js.map +0 -1
- package/dist/common/database/typeorm-unit-of-work/typeorm-connection.provider.js.map +0 -1
- /package/dist/common/database/{typeorm-unit-of-work/data-source.provider.d.ts → data-source.provider.d.ts} +0 -0
- /package/dist/common/database/{typeorm-unit-of-work/data-source.provider.js → data-source.provider.js} +0 -0
- /package/dist/common/database/{typeorm-unit-of-work/typeorm-connection.provider.d.ts → typeorm-connection.provider.d.ts} +0 -0
- /package/dist/common/database/{typeorm-unit-of-work/typeorm-connection.provider.js → typeorm-connection.provider.js} +0 -0
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.translateQuery = exports.getTruthyProps = void 0;
|
|
4
|
+
const enum_1 = require("../enum");
|
|
5
|
+
const convert_to_dot_notation_util_1 = require("./convert-to-dot-notation.util");
|
|
6
|
+
const getTruthyProps = (obj) => {
|
|
7
|
+
if (!obj)
|
|
8
|
+
return {};
|
|
9
|
+
return Object.fromEntries(Object.entries(obj).filter(([, value]) => value === true));
|
|
10
|
+
};
|
|
11
|
+
exports.getTruthyProps = getTruthyProps;
|
|
12
|
+
const translateQuery = (query) => {
|
|
13
|
+
const clonedQuery = { ...query };
|
|
14
|
+
for (const field in clonedQuery) {
|
|
15
|
+
const castedField = field;
|
|
16
|
+
if (castedField === enum_1.Op.and || castedField === enum_1.Op.or) {
|
|
17
|
+
if (!Array.isArray(clonedQuery[field]))
|
|
18
|
+
throw new Error(`${field} Should be an array`);
|
|
19
|
+
clonedQuery[field].forEach((subQuery, indexsubQuery) => {
|
|
20
|
+
clonedQuery[field][indexsubQuery] = (0, exports.translateQuery)(subQuery);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
else if (castedField === enum_1.Op.not) {
|
|
24
|
+
query[field] = (0, exports.translateQuery)(query[field]);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
const result = (0, convert_to_dot_notation_util_1.convertToDotNotation)({
|
|
28
|
+
[field]: clonedQuery[field],
|
|
29
|
+
});
|
|
30
|
+
delete clonedQuery[field];
|
|
31
|
+
if (result.length === 1) {
|
|
32
|
+
const key = Object.keys(result[0])[0];
|
|
33
|
+
clonedQuery[key] = result[0][key];
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
if (!clonedQuery[enum_1.Op.and])
|
|
37
|
+
clonedQuery[enum_1.Op.and] = [];
|
|
38
|
+
clonedQuery[enum_1.Op.and].push(...result);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return clonedQuery;
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.translateQuery = translateQuery;
|
|
45
|
+
//# sourceMappingURL=translate-query.utill.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"translate-query.utill.js","sourceRoot":"","sources":["../../../../../src/common/database/query-builder/utils/translate-query.utill.ts"],"names":[],"mappings":";;;AAAA,kCAA6B;AAC7B,iFAAsE;AAE/D,MAAM,cAAc,GAAG,CAAC,GAAQ,EAAE,EAAE;IACzC,IAAI,CAAC,GAAG;QAAE,OAAO,EAAE,CAAC;IACpB,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,CAC1D,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,cAAc,kBAKzB;AAEK,MAAM,cAAc,GAAG,CAAC,KAAU,EAAO,EAAE;IAChD,MAAM,WAAW,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IACjC,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE,CAAC;QAChC,MAAM,WAAW,GAAG,KAAW,CAAC;QAChC,IAAI,WAAW,KAAK,SAAE,CAAC,GAAG,IAAI,WAAW,KAAK,SAAE,CAAC,EAAE,EAAE,CAAC;YACpD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;gBACpC,MAAM,IAAI,KAAK,CAAC,GAAG,KAAK,qBAAqB,CAAC,CAAC;YAEjD,WAAW,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,QAAa,EAAE,aAAa,EAAE,EAAE;gBAC1D,WAAW,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,GAAG,IAAA,sBAAc,EAAC,QAAQ,CAAC,CAAC;YAC/D,CAAC,CAAC,CAAC;QACL,CAAC;aAAM,IAAI,WAAW,KAAK,SAAE,CAAC,GAAG,EAAE,CAAC;YAClC,KAAK,CAAC,KAAK,CAAC,GAAG,IAAA,sBAAc,EAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YAEN,MAAM,MAAM,GAAG,IAAA,mDAAoB,EAAC;gBAClC,CAAC,KAAK,CAAC,EAAE,WAAW,CAAC,KAAK,CAAC;aAC5B,CAAC,CAAC;YACH,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC;YAG1B,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACxB,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACtC,WAAW,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACpC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,CAAC,SAAE,CAAC,GAAG,CAAC;oBAAE,WAAW,CAAC,SAAE,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;gBAClD,WAAW,CAAC,SAAE,CAAC,GAAG,CAAW,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC;YACjD,CAAC;QACH,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;AACH,CAAC,CAAC;AAhCW,QAAA,cAAc,kBAgCzB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"typeorm-connection.provider.js","sourceRoot":"","sources":["../../../src/common/database/typeorm-connection.provider.ts"],"names":[],"mappings":";;;AAAA,qCAAqC;AAExB,QAAA,iBAAiB,GAAG;IAC/B,OAAO,EAAE,oBAAoB;IAC7B,WAAW,EAAE,oBAAU;CACxB,CAAC"}
|
|
@@ -1,6 +1,4 @@
|
|
|
1
|
-
export * from './data-source.provider';
|
|
2
1
|
export * from './interfaces/IUnitOfWork';
|
|
3
|
-
export * from './typeorm-connection.provider';
|
|
4
2
|
export * from './typeorm-unit-of-work.module';
|
|
5
3
|
export * from './typeorm-unit-of-work.provider';
|
|
6
4
|
export * from './unit-of-work.response.type';
|
|
@@ -14,9 +14,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./data-source.provider"), exports);
|
|
18
17
|
__exportStar(require("./interfaces/IUnitOfWork"), exports);
|
|
19
|
-
__exportStar(require("./typeorm-connection.provider"), exports);
|
|
20
18
|
__exportStar(require("./typeorm-unit-of-work.module"), exports);
|
|
21
19
|
__exportStar(require("./typeorm-unit-of-work.provider"), exports);
|
|
22
20
|
__exportStar(require("./unit-of-work.response.type"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/common/database/typeorm-unit-of-work/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/common/database/typeorm-unit-of-work/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAyC;AACzC,gEAA8C;AAC9C,kEAAgD;AAChD,+DAA6C"}
|
|
@@ -10,9 +10,9 @@ exports.TypeOrmUnitOfWorkModule = void 0;
|
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
11
|
const common_2 = require("@nestjs/common");
|
|
12
12
|
const config_1 = require("@nestjs/config");
|
|
13
|
-
const data_source_provider_1 = require("
|
|
13
|
+
const data_source_provider_1 = require("../data-source.provider");
|
|
14
14
|
const typeorm_unit_of_work_provider_1 = require("./typeorm-unit-of-work.provider");
|
|
15
|
-
const typeorm_connection_provider_1 = require("
|
|
15
|
+
const typeorm_connection_provider_1 = require("../typeorm-connection.provider");
|
|
16
16
|
let TypeOrmUnitOfWorkModule = class TypeOrmUnitOfWorkModule {
|
|
17
17
|
};
|
|
18
18
|
exports.TypeOrmUnitOfWorkModule = TypeOrmUnitOfWorkModule;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"typeorm-unit-of-work.module.js","sourceRoot":"","sources":["../../../../src/common/database/typeorm-unit-of-work/typeorm-unit-of-work.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,2CAAwC;AACxC,2CAA8C;AAE9C,
|
|
1
|
+
{"version":3,"file":"typeorm-unit-of-work.module.js","sourceRoot":"","sources":["../../../../src/common/database/typeorm-unit-of-work/typeorm-unit-of-work.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,2CAAwC;AACxC,2CAA8C;AAE9C,kEAA6D;AAC7D,mFAAoE;AACpE,gFAAmE;AAY5D,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;CAAG,CAAA;AAA1B,0DAAuB;kCAAvB,uBAAuB;IAVnC,IAAA,eAAM,GAAE;IACR,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,qBAAY,CAAC,OAAO,CAAC;gBACnB,QAAQ,EAAE,IAAI;aACf,CAAC;SACH;QACD,SAAS,EAAE,CAAC,yCAAkB,EAAE,iDAAiB,EAAE,+CAAiB,CAAC;QACrE,OAAO,EAAE,CAAC,yCAAkB,EAAE,iDAAiB,EAAE,+CAAiB,CAAC;KACpE,CAAC;GACW,uBAAuB,CAAG"}
|
|
@@ -3,8 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.GenericGetById = GenericGetById;
|
|
4
4
|
const common_1 = require("@nestjs/common");
|
|
5
5
|
const common_2 = require("@nestjs/common");
|
|
6
|
+
const common_3 = require("@nestjs/common");
|
|
6
7
|
const swagger_1 = require("@nestjs/swagger");
|
|
8
|
+
const validation_pipe_1 = require("../pipes/validation.pipe");
|
|
9
|
+
const search_dto_1 = require("../dto/search.dto");
|
|
7
10
|
function GenericGetById(View) {
|
|
8
|
-
return (0, common_1.applyDecorators)((0, common_2.Get)(':id'), (0, swagger_1.ApiResponse)({ status: 200, description: `Entity found by id`, type: View }), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }));
|
|
11
|
+
return (0, common_1.applyDecorators)((0, common_2.Get)(':id'), (0, swagger_1.ApiResponse)({ status: 200, description: `Entity found by id`, type: View }), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, swagger_1.ApiResponse)({ status: 404, description: 'Not found' }), (0, common_3.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)));
|
|
9
12
|
}
|
|
10
13
|
//# sourceMappingURL=generic-get-by-id.decorator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-get-by-id.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get-by-id.decorator.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"generic-get-by-id.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get-by-id.decorator.ts"],"names":[],"mappings":";;AAQA,wCAUC;AAlBD,2CAAiD;AACjD,2CAAqC;AAErC,2CAA0C;AAC1C,6CAA8C;AAC9C,8DAAiE;AACjE,kDAA8C;AAE9C,SAAgB,cAAc,CAAI,IAAa;IAC7C,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAG,EAAC,KAAK,CAAC,EACV,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,oBAAoB,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAC3E,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
|
|
@@ -3,13 +3,16 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.GenericGet = GenericGet;
|
|
4
4
|
const common_1 = require("@nestjs/common");
|
|
5
5
|
const common_2 = require("@nestjs/common");
|
|
6
|
+
const common_3 = require("@nestjs/common");
|
|
6
7
|
const swagger_1 = require("@nestjs/swagger");
|
|
8
|
+
const validation_pipe_1 = require("../pipes/validation.pipe");
|
|
9
|
+
const search_dto_1 = require("../dto/search.dto");
|
|
7
10
|
function GenericGet(View) {
|
|
8
11
|
return (0, common_1.applyDecorators)((0, common_2.Get)(), (0, swagger_1.ApiResponse)({
|
|
9
12
|
status: 200,
|
|
10
13
|
description: `List of paginated entities`,
|
|
11
14
|
type: View,
|
|
12
15
|
isArray: true,
|
|
13
|
-
}), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }));
|
|
16
|
+
}), (0, swagger_1.ApiResponse)({ status: 400, description: 'Bad request' }), (0, swagger_1.ApiResponse)({ status: 401, description: 'Unauthorized' }), (0, swagger_1.ApiResponse)({ status: 403, description: 'Forbidden' }), (0, common_3.UsePipes)((0, validation_pipe_1.GenericValidationPipe)(search_dto_1.SearchDto)));
|
|
14
17
|
}
|
|
15
18
|
//# sourceMappingURL=generic-get.decorator.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-get.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get.decorator.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"generic-get.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/generic-get.decorator.ts"],"names":[],"mappings":";;AAQA,gCAcC;AAtBD,2CAAiD;AACjD,2CAAqC;AAErC,2CAA0C;AAC1C,6CAA8C;AAC9C,8DAAiE;AACjE,kDAA8C;AAE9C,SAAgB,UAAU,CAAI,IAAa;IACzC,OAAO,IAAA,wBAAe,EACpB,IAAA,YAAG,GAAE,EACL,IAAA,qBAAW,EAAC;QACV,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,4BAA4B;QACzC,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,IAAI;KACd,CAAC,EACF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,EACxD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,EACzD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,EACtD,IAAA,iBAAQ,EAAC,IAAA,uCAAqB,EAAC,sBAAS,CAAC,CAAC,CAC3C,CAAC;AACJ,CAAC"}
|
|
@@ -4,5 +4,6 @@ export * from './generic-get-by-id.decorator';
|
|
|
4
4
|
export * from './generic-get.decorator';
|
|
5
5
|
export * from './generic-patch.decorator';
|
|
6
6
|
export * from './generic-post.decorator';
|
|
7
|
+
export * from './query-option.decorator';
|
|
7
8
|
export * from './soft-unique.decorator';
|
|
8
9
|
export * from './use-dto.decorator';
|
|
@@ -20,6 +20,7 @@ __exportStar(require("./generic-get-by-id.decorator"), exports);
|
|
|
20
20
|
__exportStar(require("./generic-get.decorator"), exports);
|
|
21
21
|
__exportStar(require("./generic-patch.decorator"), exports);
|
|
22
22
|
__exportStar(require("./generic-post.decorator"), exports);
|
|
23
|
+
__exportStar(require("./query-option.decorator"), exports);
|
|
23
24
|
__exportStar(require("./soft-unique.decorator"), exports);
|
|
24
25
|
__exportStar(require("./use-dto.decorator"), exports);
|
|
25
26
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,6DAA2C;AAC3C,gEAA8C;AAC9C,0DAAwC;AACxC,4DAA0C;AAC1C,2DAAyC;AACzC,0DAAwC;AACxC,sDAAoC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/decorators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAmC;AACnC,6DAA2C;AAC3C,gEAA8C;AAC9C,0DAAwC;AACxC,4DAA0C;AAC1C,2DAAyC;AACzC,2DAAyC;AACzC,0DAAwC;AACxC,sDAAoC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const QueryOption: (...dataOrPipes: unknown[]) => ParameterDecorator;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.QueryOption = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
exports.QueryOption = (0, common_1.createParamDecorator)((data, ctx) => {
|
|
6
|
+
const request = ctx.switchToHttp().getRequest();
|
|
7
|
+
return request.options;
|
|
8
|
+
});
|
|
9
|
+
//# sourceMappingURL=query-option.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query-option.decorator.js","sourceRoot":"","sources":["../../../src/common/decorators/query-option.decorator.ts"],"names":[],"mappings":";;;AAAA,2CAAsD;AAGzC,QAAA,WAAW,GAAG,IAAA,6BAAoB,EAC7C,CAAC,IAAa,EAAE,GAAqB,EAAE,EAAE;IACvC,MAAM,OAAO,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;IAChD,OAAO,OAAO,CAAC,OAAO,CAAC;AACzB,CAAC,CACF,CAAC"}
|
|
@@ -1,3 +1,8 @@
|
|
|
1
1
|
import { PaginationDto } from './pagination.dto';
|
|
2
|
+
import { QueryForm } from '../database/query-builder/query-form';
|
|
2
3
|
export declare class SearchDto extends PaginationDto {
|
|
4
|
+
options?: any;
|
|
5
|
+
}
|
|
6
|
+
export declare class ParsedSearchDto<T> extends PaginationDto {
|
|
7
|
+
options?: QueryForm<T>;
|
|
3
8
|
}
|
|
@@ -1,8 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
2
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SearchDto = void 0;
|
|
12
|
+
exports.ParsedSearchDto = exports.SearchDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const class_validator_2 = require("class-validator");
|
|
15
|
+
const class_validator_3 = require("class-validator");
|
|
16
|
+
const class_validator_4 = require("class-validator");
|
|
17
|
+
const class_validator_5 = require("class-validator");
|
|
4
18
|
const pagination_dto_1 = require("./pagination.dto");
|
|
5
19
|
class SearchDto extends pagination_dto_1.PaginationDto {
|
|
6
20
|
}
|
|
7
21
|
exports.SearchDto = SearchDto;
|
|
22
|
+
__decorate([
|
|
23
|
+
(0, class_validator_3.IsOptional)(),
|
|
24
|
+
(0, class_validator_1.IsNotEmpty)(),
|
|
25
|
+
(0, class_validator_4.IsString)(),
|
|
26
|
+
__metadata("design:type", Object)
|
|
27
|
+
], SearchDto.prototype, "options", void 0);
|
|
28
|
+
class ParsedSearchDto extends pagination_dto_1.PaginationDto {
|
|
29
|
+
}
|
|
30
|
+
exports.ParsedSearchDto = ParsedSearchDto;
|
|
31
|
+
__decorate([
|
|
32
|
+
(0, class_validator_3.IsOptional)(),
|
|
33
|
+
(0, class_validator_1.IsNotEmpty)(),
|
|
34
|
+
(0, class_validator_5.IsObject)(),
|
|
35
|
+
(0, class_validator_2.IsNotEmptyObject)(),
|
|
36
|
+
__metadata("design:type", Object)
|
|
37
|
+
], ParsedSearchDto.prototype, "options", void 0);
|
|
8
38
|
//# sourceMappingURL=search.dto.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"search.dto.js","sourceRoot":"","sources":["../../../src/common/dto/search.dto.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"search.dto.js","sourceRoot":"","sources":["../../../src/common/dto/search.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAA6C;AAC7C,qDAAmD;AACnD,qDAA6C;AAC7C,qDAA2C;AAC3C,qDAA2C;AAC3C,qDAAiD;AAGjD,MAAa,SAAU,SAAQ,8BAAa;CAK3C;AALD,8BAKC;AADC;IAHC,IAAA,4BAAU,GAAE;IACZ,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;0CACG;AAGhB,MAAa,eAAmB,SAAQ,8BAAa;CAMpD;AAND,0CAMC;AADC;IAJC,IAAA,4BAAU,GAAE;IACZ,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,kCAAgB,GAAE;;gDACI"}
|
|
@@ -17,5 +17,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./body.logger.interceptor"), exports);
|
|
18
18
|
__exportStar(require("./logging.interceptor"), exports);
|
|
19
19
|
__exportStar(require("./query.logger.interceptor"), exports);
|
|
20
|
+
__exportStar(require("./query.options.interceptor"), exports);
|
|
20
21
|
__exportStar(require("./response.interceptor"), exports);
|
|
21
22
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,wDAAsC;AACtC,6DAA2C;AAC3C,yDAAuC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/interceptors/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4DAA0C;AAC1C,wDAAsC;AACtC,6DAA2C;AAC3C,8DAA4C;AAC5C,yDAAuC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NestInterceptor } from '@nestjs/common';
|
|
2
|
+
import { ExecutionContext } from '@nestjs/common';
|
|
3
|
+
import { CallHandler } from '@nestjs/common';
|
|
4
|
+
import { Observable } from 'rxjs';
|
|
5
|
+
export declare class QueryOptionsInterceptor implements NestInterceptor {
|
|
6
|
+
private readonly logger;
|
|
7
|
+
intercept(context: ExecutionContext, next: CallHandler): Observable<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var QueryOptionsInterceptor_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.QueryOptionsInterceptor = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const common_2 = require("@nestjs/common");
|
|
13
|
+
const query_parser_1 = require("../parsers/query.parser");
|
|
14
|
+
let QueryOptionsInterceptor = QueryOptionsInterceptor_1 = class QueryOptionsInterceptor {
|
|
15
|
+
constructor() {
|
|
16
|
+
this.logger = new common_2.Logger(QueryOptionsInterceptor_1.name);
|
|
17
|
+
}
|
|
18
|
+
intercept(context, next) {
|
|
19
|
+
const request = context.switchToHttp().getRequest();
|
|
20
|
+
const { query } = request;
|
|
21
|
+
const options = query_parser_1.QueryParser.parse(query);
|
|
22
|
+
Object.assign(request, { options });
|
|
23
|
+
this.logger.log(`Query options parsed successfully`);
|
|
24
|
+
return next.handle();
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
exports.QueryOptionsInterceptor = QueryOptionsInterceptor;
|
|
28
|
+
exports.QueryOptionsInterceptor = QueryOptionsInterceptor = QueryOptionsInterceptor_1 = __decorate([
|
|
29
|
+
(0, common_1.Injectable)()
|
|
30
|
+
], QueryOptionsInterceptor);
|
|
31
|
+
//# sourceMappingURL=query.options.interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.options.interceptor.js","sourceRoot":"","sources":["../../../src/common/interceptors/query.options.interceptor.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAA4C;AAI5C,2CAAwC;AAGxC,0DAAsD;AAG/C,IAAM,uBAAuB,+BAA7B,MAAM,uBAAuB;IAA7B;QACY,WAAM,GAAG,IAAI,eAAM,CAAC,yBAAuB,CAAC,IAAI,CAAC,CAAC;IAUrE,CAAC;IARC,SAAS,CAAC,OAAyB,EAAE,IAAiB;QACpD,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,CAAC;QACpD,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;QAC1B,MAAM,OAAO,GAAc,0BAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACpD,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QACpC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,mCAAmC,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;CACF,CAAA;AAXY,0DAAuB;kCAAvB,uBAAuB;IADnC,IAAA,mBAAU,GAAE;GACA,uBAAuB,CAWnC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { SearchDto } from '../../common/dto';
|
|
2
|
-
import { GenericDomain } from '../../core/domain';
|
|
3
|
-
import { GenericView
|
|
2
|
+
import { GenericDomain } from '../../core/domain/generic.domain';
|
|
3
|
+
import { GenericView } from '../../core/app/dto/generic.view';
|
|
4
|
+
import { DtoMapper } from '../../core/app/dto/generic.create.dto';
|
|
4
5
|
export type IGenericController<D extends GenericDomain, V extends GenericView, DTO extends DtoMapper<D, DTO>> = {
|
|
5
6
|
create(body: DTO): Promise<Partial<V>>;
|
|
6
7
|
paginate(query: SearchDto): Promise<Partial<V>[]>;
|
|
@@ -3,7 +3,7 @@ import { Repository } from 'typeorm';
|
|
|
3
3
|
import { EntityMetadata } from 'typeorm';
|
|
4
4
|
import { EntityManager } from 'typeorm';
|
|
5
5
|
import { FindOneOptions } from 'typeorm';
|
|
6
|
-
import {
|
|
6
|
+
import { ParsedSearchDto } from '../dto';
|
|
7
7
|
import { TimestampLogger } from '../loggers';
|
|
8
8
|
import { LoggerOptions } from '../loggers';
|
|
9
9
|
import { IEntityMapper } from './generic.mapper';
|
|
@@ -17,7 +17,7 @@ export type IGenericRepository<T extends GenericPersistence, D extends GenericDo
|
|
|
17
17
|
save(domain: D): Promise<D>;
|
|
18
18
|
saveList(domains: D[]): Promise<D[]>;
|
|
19
19
|
create(domain: D): Promise<D>;
|
|
20
|
-
paginate(query:
|
|
20
|
+
paginate(query: ParsedSearchDto<T>): Promise<D[]>;
|
|
21
21
|
findAll(): Promise<D[]>;
|
|
22
22
|
findById(id: string, options?: LoggerOptions): Promise<D>;
|
|
23
23
|
findOne(query: FindOneOptions<T>, options?: LoggerOptions): Promise<D>;
|
|
@@ -6,12 +6,12 @@ import { GenericPersistence } from '../../core/infra';
|
|
|
6
6
|
import { GenericDomain } from '../../core/domain';
|
|
7
7
|
import { DtoMapper, GenericView } from '../../core/app';
|
|
8
8
|
import { Result } from '../../core/app/result';
|
|
9
|
-
import {
|
|
9
|
+
import { ParsedSearchDto } from '../../common/dto';
|
|
10
10
|
import { LoggerOptions } from '../../common/loggers';
|
|
11
11
|
export type IGenericService<T extends GenericPersistence, D extends GenericDomain, V extends GenericView, DTO extends DtoMapper<D, DTO>> = {
|
|
12
12
|
mapper: IEntityMapper<T, D, V>;
|
|
13
13
|
create(createDto: DeepPartial<DTO>): Promise<Result<D>>;
|
|
14
|
-
paginate(query:
|
|
14
|
+
paginate(query: ParsedSearchDto<T>): Promise<Result<D[]>>;
|
|
15
15
|
findAll(): Promise<Result<D[]>>;
|
|
16
16
|
findById(id: string, options?: LoggerOptions): Promise<Result<D>>;
|
|
17
17
|
findOne(query: FindOneOptions<T>, options?: LoggerOptions): Promise<Result<D>>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './query.parser';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./query.parser"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/parsers/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.QueryParser = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const common_2 = require("@nestjs/common");
|
|
6
|
+
class QueryParser {
|
|
7
|
+
static parse(query) {
|
|
8
|
+
if (query.limit) {
|
|
9
|
+
query.limit = Number(query.limit);
|
|
10
|
+
}
|
|
11
|
+
if (query.offset) {
|
|
12
|
+
query.offset = Number(query.offset);
|
|
13
|
+
}
|
|
14
|
+
if (query.page) {
|
|
15
|
+
query.page = Number(query.page);
|
|
16
|
+
}
|
|
17
|
+
if (query?.options) {
|
|
18
|
+
if (typeof query.options === 'string') {
|
|
19
|
+
try {
|
|
20
|
+
const parsedOptions = JSON.parse(query.options);
|
|
21
|
+
query = { ...query, options: parsedOptions };
|
|
22
|
+
}
|
|
23
|
+
catch (error) {
|
|
24
|
+
if (error instanceof Error) {
|
|
25
|
+
this.logger.error(error.message);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
this.logger.error('Unknown error occurred while parsing options');
|
|
29
|
+
}
|
|
30
|
+
throw new common_2.BadRequestException('Invalid JSON in query param');
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
this.logger.log(`Query parsed successfully`);
|
|
35
|
+
return { ...query };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.QueryParser = QueryParser;
|
|
39
|
+
QueryParser.logger = new common_1.Logger(QueryParser.name);
|
|
40
|
+
//# sourceMappingURL=query.parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query.parser.js","sourceRoot":"","sources":["../../../src/common/parsers/query.parser.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AACxC,2CAAqD;AAGrD,MAAa,WAAW;IAEtB,MAAM,CAAC,KAAK,CAAC,KAAgB;QAC3B,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,KAAK,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACjB,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,KAAK,EAAE,OAAO,EAAE,CAAC;YACnB,IAAI,OAAO,KAAK,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;gBACtC,IAAI,CAAC;oBACH,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAChD,KAAK,GAAG,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC;gBAC/C,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACxB,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;wBAC3B,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBACnC,CAAC;yBAAM,CAAC;wBACN,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,8CAA8C,CAAC,CAAC;oBACpE,CAAC;oBACD,MAAM,IAAI,4BAAmB,CAAC,6BAA6B,CAAC,CAAC;gBAC/D,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;QAC7C,OAAO,EAAE,GAAG,KAAK,EAAE,CAAC;IACtB,CAAC;;AA7BH,kCA8BC;AA7ByB,kBAAM,GAAG,IAAI,eAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC"}
|
|
@@ -3,4 +3,5 @@ import { DomainProps } from './generic.domain';
|
|
|
3
3
|
import { GenericDomain } from './generic.domain';
|
|
4
4
|
export declare abstract class DomainFactory {
|
|
5
5
|
static create<D extends GenericDomain>(domain: Type<D>, args: Partial<DomainProps<D>>, id?: string): D;
|
|
6
|
+
static instance<D extends GenericDomain>(domain: Type<D>, args: Partial<DomainProps<D>>): D;
|
|
6
7
|
}
|
|
@@ -14,6 +14,11 @@ class DomainFactory {
|
|
|
14
14
|
};
|
|
15
15
|
return Object.assign(instance, { ...args, ...props });
|
|
16
16
|
}
|
|
17
|
+
static instance(domain, args) {
|
|
18
|
+
const instance = Object.create(domain.prototype);
|
|
19
|
+
const validArgs = Object.fromEntries(Object.entries(args).filter(([, value]) => value !== null && value !== undefined));
|
|
20
|
+
return Object.assign(instance, { ...validArgs });
|
|
21
|
+
}
|
|
17
22
|
}
|
|
18
23
|
exports.DomainFactory = DomainFactory;
|
|
19
24
|
//# sourceMappingURL=generic.domain.factory.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic.domain.factory.js","sourceRoot":"","sources":["../../../src/core/domain/generic.domain.factory.ts"],"names":[],"mappings":";;;AACA,+BAAkC;AAIlC,MAAsB,aAAa;IACjC,MAAM,CAAC,MAAM,CACX,MAAe,EACf,IAA6B,EAC7B,EAAW;QAEX,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,KAAK,GAA2B;YACpC,EAAE,EAAE,EAAE,IAAI,IAAI,CAAC,EAAE,IAAI,IAAA,SAAI,GAAE;YAC3B,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,GAAG;YAChC,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,GAAG;YAChC,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI;SAClC,CAAC;QACF,OAAO,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IACxD,CAAC;CACF;
|
|
1
|
+
{"version":3,"file":"generic.domain.factory.js","sourceRoot":"","sources":["../../../src/core/domain/generic.domain.factory.ts"],"names":[],"mappings":";;;AACA,+BAAkC;AAIlC,MAAsB,aAAa;IACjC,MAAM,CAAC,MAAM,CACX,MAAe,EACf,IAA6B,EAC7B,EAAW;QAEX,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,KAAK,GAA2B;YACpC,EAAE,EAAE,EAAE,IAAI,IAAI,CAAC,EAAE,IAAI,IAAA,SAAI,GAAE;YAC3B,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,GAAG;YAChC,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,GAAG;YAChC,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI;SAClC,CAAC;QACF,OAAO,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;IACxD,CAAC;IACD,MAAM,CAAC,QAAQ,CACb,MAAe,EACf,IAA6B;QAE7B,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAClC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CACzB,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,CACrD,CACF,CAAC;QACF,OAAO,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,GAAG,SAAS,EAAE,CAAC,CAAC;IACnD,CAAC;CACF;AA5BD,sCA4BC"}
|
|
@@ -10,17 +10,20 @@ import { GenericDomain } from '../domain';
|
|
|
10
10
|
import { GenericView } from '../app';
|
|
11
11
|
import { IEntityMapper } from '../../common';
|
|
12
12
|
import { IGenericRepository } from '../../common';
|
|
13
|
-
import {
|
|
13
|
+
import { ParsedSearchDto } from '../../common';
|
|
14
|
+
import { QueryBuilder } from '../../common';
|
|
14
15
|
export declare abstract class IrohRepository<M extends IEntityMapper<T, D, V>, T extends GenericPersistence = ReturnType<M['DomainToPersistence']>, D extends GenericDomain = ReturnType<M['PersistenceToDomain']>, V extends GenericView = ReturnType<M['DomainToView']>> implements IGenericRepository<T, D, V> {
|
|
15
16
|
repository: Repository<T>;
|
|
16
17
|
readonly logger: TimestampLogger;
|
|
17
18
|
Entity: Type<T>;
|
|
18
19
|
mapper: IEntityMapper<T, D, V>;
|
|
20
|
+
builder: QueryBuilder<T>;
|
|
21
|
+
private alias;
|
|
19
22
|
constructor(repository: Repository<T>);
|
|
20
23
|
save(domain: D): Promise<D>;
|
|
21
24
|
saveList(domains: D[]): Promise<D[]>;
|
|
22
25
|
create(domain: D): Promise<D>;
|
|
23
|
-
paginate(query
|
|
26
|
+
paginate(query?: ParsedSearchDto<T>): Promise<D[]>;
|
|
24
27
|
findAll(): Promise<D[]>;
|
|
25
28
|
findById(id: string, options?: LoggerOptions): Promise<D>;
|
|
26
29
|
findOne(query: FindOneOptions<T>, options?: LoggerOptions): Promise<D>;
|
|
@@ -28,5 +31,7 @@ export declare abstract class IrohRepository<M extends IEntityMapper<T, D, V>, T
|
|
|
28
31
|
remove(id: string): Promise<D>;
|
|
29
32
|
getRepository(): Repository<T>;
|
|
30
33
|
getMetadata(): EntityMetadata;
|
|
34
|
+
private prepare;
|
|
31
35
|
setTransactionalRepository(entityManager: EntityManager): void;
|
|
36
|
+
private logCount;
|
|
32
37
|
}
|
|
@@ -16,9 +16,11 @@ exports.IrohRepository = void 0;
|
|
|
16
16
|
const typeorm_1 = require("@nestjs/typeorm");
|
|
17
17
|
const typeorm_2 = require("typeorm");
|
|
18
18
|
const common_1 = require("../../common");
|
|
19
|
+
const common_2 = require("../../common");
|
|
19
20
|
let IrohRepository = class IrohRepository {
|
|
20
21
|
constructor(repository) {
|
|
21
22
|
this.repository = repository;
|
|
23
|
+
this.alias = 'alias';
|
|
22
24
|
this.logger = new common_1.TimestampLogger(this.constructor.name);
|
|
23
25
|
}
|
|
24
26
|
async save(domain) {
|
|
@@ -50,7 +52,7 @@ let IrohRepository = class IrohRepository {
|
|
|
50
52
|
this.logger.debug(`${id} saved successfully`);
|
|
51
53
|
return savedDomain;
|
|
52
54
|
}
|
|
53
|
-
async paginate(query) {
|
|
55
|
+
async paginate(query = {}) {
|
|
54
56
|
this.logger.start();
|
|
55
57
|
const options = {};
|
|
56
58
|
const { limit, page, offset } = query;
|
|
@@ -63,41 +65,25 @@ let IrohRepository = class IrohRepository {
|
|
|
63
65
|
if (offset) {
|
|
64
66
|
options.skip = offset;
|
|
65
67
|
}
|
|
68
|
+
if (query.options) {
|
|
69
|
+
this.prepare();
|
|
70
|
+
this.builder.addOptions(query.options);
|
|
71
|
+
this.builder.addLimit(options.take);
|
|
72
|
+
this.builder.addOffset(options.skip);
|
|
73
|
+
const data = await this.builder.getMany();
|
|
74
|
+
this.logCount(data.length);
|
|
75
|
+
return data.map((p) => this.mapper.PersistenceToDomain(p));
|
|
76
|
+
}
|
|
66
77
|
const persistenceList = await this.repository.find(options);
|
|
67
|
-
const count = persistenceList.length;
|
|
68
78
|
const domains = persistenceList.map((p) => this.mapper.PersistenceToDomain(p));
|
|
69
|
-
|
|
70
|
-
case 0:
|
|
71
|
-
this.logger.log(`No entities found`);
|
|
72
|
-
break;
|
|
73
|
-
case 1:
|
|
74
|
-
this.logger.log(`Successfully retrieved one entity with pagination`);
|
|
75
|
-
break;
|
|
76
|
-
default: {
|
|
77
|
-
const message = `Successfully retrieved ${count} entities with pagination`;
|
|
78
|
-
this.logger.log(message);
|
|
79
|
-
break;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
79
|
+
this.logCount(persistenceList.length);
|
|
82
80
|
return domains;
|
|
83
81
|
}
|
|
84
82
|
async findAll() {
|
|
85
83
|
this.logger.start();
|
|
86
84
|
const persistenceList = await this.repository.find();
|
|
87
85
|
const count = persistenceList.length;
|
|
88
|
-
|
|
89
|
-
case 0:
|
|
90
|
-
this.logger.log(`No entities found`);
|
|
91
|
-
break;
|
|
92
|
-
case 1:
|
|
93
|
-
this.logger.log(`Successfully retrieved one entity with pagination`);
|
|
94
|
-
break;
|
|
95
|
-
default: {
|
|
96
|
-
const message = `Successfully retrieved ${count} entities with pagination`;
|
|
97
|
-
this.logger.log(message);
|
|
98
|
-
break;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
86
|
+
this.logCount(count);
|
|
101
87
|
return persistenceList.map((p) => this.mapper.PersistenceToDomain(p));
|
|
102
88
|
}
|
|
103
89
|
async findById(id, options = { logging: false }) {
|
|
@@ -161,10 +147,32 @@ let IrohRepository = class IrohRepository {
|
|
|
161
147
|
getMetadata() {
|
|
162
148
|
return this.repository.metadata;
|
|
163
149
|
}
|
|
150
|
+
prepare() {
|
|
151
|
+
if (this.repository && this.Entity) {
|
|
152
|
+
const dataSource = this.repository.manager.connection;
|
|
153
|
+
const qb = dataSource.createQueryBuilder().from(this.Entity, this.alias);
|
|
154
|
+
this.builder = new common_2.QueryBuilder(qb);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
164
157
|
setTransactionalRepository(entityManager) {
|
|
165
158
|
this.repository = entityManager.getRepository(this.Entity);
|
|
166
159
|
this.logger.setContext(this.constructor.name);
|
|
167
160
|
}
|
|
161
|
+
logCount(count) {
|
|
162
|
+
switch (count) {
|
|
163
|
+
case 0:
|
|
164
|
+
this.logger.log(`No entities found`);
|
|
165
|
+
break;
|
|
166
|
+
case 1:
|
|
167
|
+
this.logger.log(`Successfully retrieved one entity`);
|
|
168
|
+
break;
|
|
169
|
+
default: {
|
|
170
|
+
const message = `Successfully retrieved ${count} entities`;
|
|
171
|
+
this.logger.log(message);
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
168
176
|
};
|
|
169
177
|
exports.IrohRepository = IrohRepository;
|
|
170
178
|
exports.IrohRepository = IrohRepository = __decorate([
|