@steroidsjs/nest 1.1.2 → 1.1.6
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/infrastructure/decorators/Context.d.ts +1 -0
- package/infrastructure/decorators/Context.js +12 -0
- package/infrastructure/decorators/Context.js.map +1 -0
- package/infrastructure/decorators/fields/BaseField.d.ts +7 -4
- package/infrastructure/decorators/fields/BaseField.js +22 -9
- package/infrastructure/decorators/fields/BaseField.js.map +1 -1
- package/infrastructure/decorators/fields/ExtendField.d.ts +2 -2
- package/infrastructure/decorators/fields/ExtendField.js +15 -14
- package/infrastructure/decorators/fields/ExtendField.js.map +1 -1
- package/infrastructure/decorators/schema/ExtractRelationId.d.ts +2 -0
- package/infrastructure/decorators/schema/ExtractRelationId.js +11 -0
- package/infrastructure/decorators/schema/ExtractRelationId.js.map +1 -0
- package/infrastructure/decorators/schema/SchemaSelect.d.ts +7 -0
- package/infrastructure/decorators/schema/SchemaSelect.js +13 -0
- package/infrastructure/decorators/schema/SchemaSelect.js.map +1 -0
- package/infrastructure/helpers/ModuleHelper.d.ts +3 -0
- package/infrastructure/helpers/ModuleHelper.js +25 -0
- package/infrastructure/helpers/ModuleHelper.js.map +1 -0
- package/infrastructure/repositories/CrudRepository.d.ts +8 -4
- package/infrastructure/repositories/CrudRepository.js +62 -11
- package/infrastructure/repositories/CrudRepository.js.map +1 -1
- package/package.json +1 -1
- package/tsconfig.tsbuildinfo +1 -1
- package/usecases/base/SearchQuery.d.ts +1 -2
- package/usecases/base/SearchQuery.js +30 -10
- package/usecases/base/SearchQuery.js.map +1 -1
- package/usecases/dtos/ContextDto.d.ts +15 -0
- package/usecases/dtos/ContextDto.js +7 -0
- package/usecases/dtos/ContextDto.js.map +1 -0
- package/usecases/exceptions/BadRequestException.d.ts +3 -0
- package/usecases/exceptions/BadRequestException.js +8 -0
- package/usecases/exceptions/BadRequestException.js.map +1 -0
- package/usecases/exceptions/ForbiddenException.d.ts +3 -0
- package/usecases/exceptions/ForbiddenException.js +8 -0
- package/usecases/exceptions/ForbiddenException.js.map +1 -0
- package/usecases/exceptions/UnauthorizedException.d.ts +3 -0
- package/usecases/exceptions/UnauthorizedException.js +8 -0
- package/usecases/exceptions/UnauthorizedException.js.map +1 -0
- package/usecases/exceptions/index.d.ts +4 -0
- package/usecases/exceptions/index.js +12 -0
- package/usecases/exceptions/index.js.map +1 -0
- package/{infrastructure → usecases}/helpers/ConditionHelper.d.ts +0 -0
- package/{infrastructure → usecases}/helpers/ConditionHelper.js +0 -0
- package/usecases/helpers/ConditionHelper.js.map +1 -0
- package/usecases/helpers/DataMapperHelper.d.ts +3 -1
- package/usecases/helpers/DataMapperHelper.js +53 -9
- package/usecases/helpers/DataMapperHelper.js.map +1 -1
- package/usecases/helpers/SearchHelper.d.ts +1 -1
- package/usecases/helpers/SearchHelper.js +2 -2
- package/usecases/helpers/SearchHelper.js.map +1 -1
- package/usecases/interfaces/ICrudRepository.d.ts +4 -4
- package/usecases/services/CrudService.d.ts +14 -9
- package/usecases/services/CrudService.js +36 -10
- package/usecases/services/CrudService.js.map +1 -1
- package/infrastructure/decorators/SteroidsSchema.d.ts +0 -6
- package/infrastructure/decorators/SteroidsSchema.js +0 -11
- package/infrastructure/decorators/SteroidsSchema.js.map +0 -1
- package/infrastructure/helpers/ConditionHelper.js.map +0 -1
- package/infrastructure/helpers/MetaHelper.d.ts +0 -15
- package/infrastructure/helpers/MetaHelper.js +0 -77
- package/infrastructure/helpers/MetaHelper.js.map +0 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { ICondition } from '../../infrastructure/helpers/ConditionHelper';
|
|
2
1
|
import { Repository } from 'typeorm';
|
|
3
2
|
import { SelectQueryBuilder } from 'typeorm/query-builder/SelectQueryBuilder';
|
|
3
|
+
import { ICondition } from '../helpers/ConditionHelper';
|
|
4
4
|
export interface IQueryRelation {
|
|
5
5
|
name: string;
|
|
6
6
|
alias?: string;
|
|
@@ -13,5 +13,4 @@ export default class SearchQuery {
|
|
|
13
13
|
condition?: ICondition;
|
|
14
14
|
static createFromSchema(SchemaClass: any): SearchQuery;
|
|
15
15
|
static prepare(dbRepository: Repository<any>, dbQuery: SelectQueryBuilder<any>, searchQuery: SearchQuery): void;
|
|
16
|
-
constructor(data?: SearchQuery);
|
|
17
16
|
}
|
|
@@ -1,16 +1,36 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const
|
|
4
|
-
const
|
|
3
|
+
const SchemaSelect_1 = require("../../infrastructure/decorators/schema/SchemaSelect");
|
|
4
|
+
const BaseField_1 = require("../../infrastructure/decorators/fields/BaseField");
|
|
5
|
+
const DataMapperHelper_1 = require("../helpers/DataMapperHelper");
|
|
6
|
+
const ConditionHelper_1 = require("../helpers/ConditionHelper");
|
|
5
7
|
class SearchQuery {
|
|
6
|
-
constructor(data = {}) {
|
|
7
|
-
this.select = data.select;
|
|
8
|
-
this.excludeSelect = data.excludeSelect;
|
|
9
|
-
this.relations = data.relations;
|
|
10
|
-
this.condition = data.condition;
|
|
11
|
-
}
|
|
12
8
|
static createFromSchema(SchemaClass) {
|
|
13
|
-
|
|
9
|
+
const searchQuery = new SearchQuery();
|
|
10
|
+
Object.assign(searchQuery, (0, SchemaSelect_1.getSchemaSelectOptions)(SchemaClass));
|
|
11
|
+
const relations = [];
|
|
12
|
+
(DataMapperHelper_1.DataMapperHelper.getKeys(SchemaClass) || []).forEach(fieldName => {
|
|
13
|
+
const modelMeta = (0, BaseField_1.getFieldOptions)(SchemaClass, fieldName);
|
|
14
|
+
if (modelMeta.appType === 'relation') {
|
|
15
|
+
if (/Ids?$/.exec(fieldName)) {
|
|
16
|
+
relations.push({
|
|
17
|
+
isId: true,
|
|
18
|
+
name: fieldName.replace(/Ids?$/, ''),
|
|
19
|
+
alias: fieldName,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
relations.push({
|
|
24
|
+
name: fieldName,
|
|
25
|
+
alias: fieldName,
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
if (relations.length > 0) {
|
|
31
|
+
searchQuery.relations = relations;
|
|
32
|
+
}
|
|
33
|
+
return searchQuery;
|
|
14
34
|
}
|
|
15
35
|
static prepare(dbRepository, dbQuery, searchQuery) {
|
|
16
36
|
const prefix = dbQuery.expressionMap.mainAlias.name + '.';
|
|
@@ -28,7 +48,7 @@ class SearchQuery {
|
|
|
28
48
|
dbQuery.loadRelationIdAndMap(prefix + (relation.alias || relation.name), prefix + relation.name);
|
|
29
49
|
}
|
|
30
50
|
else {
|
|
31
|
-
dbQuery.
|
|
51
|
+
dbQuery.leftJoinAndSelect(prefix + relation.name, prefix + relation.name);
|
|
32
52
|
}
|
|
33
53
|
});
|
|
34
54
|
if (searchQuery.condition) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SearchQuery.js","sourceRoot":"","sources":["../../../src/usecases/base/SearchQuery.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"SearchQuery.js","sourceRoot":"","sources":["../../../src/usecases/base/SearchQuery.ts"],"names":[],"mappings":";;AAGA,sFAA2F;AAC3F,gFAAiF;AACjF,kEAA6D;AAC7D,gEAAuE;AAQvE,MAAqB,WAAW;IAM5B,MAAM,CAAC,gBAAgB,CAAC,WAAW;QAC/B,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;QAEtC,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,IAAA,qCAAsB,EAAC,WAAW,CAAC,CAAC,CAAA;QAE/D,MAAM,SAAS,GAAqB,EAAE,CAAC;QACvC,CAAC,mCAAgB,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;YAC9D,MAAM,SAAS,GAAG,IAAA,2BAAe,EAAC,WAAW,EAAE,SAAS,CAA0B,CAAC;YACnF,IAAI,SAAS,CAAC,OAAO,KAAK,UAAU,EAAE;gBAClC,IAAI,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;oBACzB,SAAS,CAAC,IAAI,CAAC;wBACX,IAAI,EAAE,IAAI;wBACV,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC;wBACpC,KAAK,EAAE,SAAS;qBACnB,CAAC,CAAC;iBACN;qBAAM;oBACH,SAAS,CAAC,IAAI,CAAC;wBACX,IAAI,EAAE,SAAS;wBACf,KAAK,EAAE,SAAS;qBACnB,CAAC,CAAC;iBACN;aACJ;QACL,CAAC,CAAC,CAAC;QACH,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACtB,WAAW,CAAC,SAAS,GAAG,SAAS,CAAC;SACrC;QAED,OAAO,WAAW,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,OAAO,CACV,YAA6B,EAC7B,OAAgC,EAChC,WAAwB;QAGxB,MAAM,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,GAAG,GAAG,CAAC;QAG1D,IAAI,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;QAChC,IAAI,WAAW,CAAC,aAAa,EAAE;YAC3B,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO;iBACjC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC;iBAClC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;SAClE;QAED,IAAI,MAAM,EAAE;YACR,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC;SACrD;QAGD,CAAC,WAAW,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC7C,IAAI,QAAQ,CAAC,IAAI,EAAE;gBACf,OAAO,CAAC,oBAAoB,CACxB,MAAM,GAAG,CAAC,QAAQ,CAAC,KAAK,IAAI,QAAQ,CAAC,IAAI,CAAC,EAC1C,MAAM,GAAG,QAAQ,CAAC,IAAI,CACzB,CAAC;aACL;iBAAM;gBACH,OAAO,CAAC,iBAAiB,CAAC,MAAM,GAAG,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;aAE7E;QACL,CAAC,CAAC,CAAC;QAGH,IAAI,WAAW,CAAC,SAAS,EAAE;YACvB,OAAO,CAAC,QAAQ,CAAC,iCAAe,CAAC,SAAS,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC;SACtE;IACL,CAAC;CACJ;AA1ED,8BA0EC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface IContextDto {
|
|
2
|
+
user?: any | {
|
|
3
|
+
id?: number;
|
|
4
|
+
name?: string;
|
|
5
|
+
permissions?: string[];
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
export declare class ContextDto implements IContextDto {
|
|
9
|
+
user?: any | {
|
|
10
|
+
id?: number;
|
|
11
|
+
name?: string;
|
|
12
|
+
permissions?: string[];
|
|
13
|
+
};
|
|
14
|
+
language?: string;
|
|
15
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ContextDto.js","sourceRoot":"","sources":["../../../src/usecases/dtos/ContextDto.ts"],"names":[],"mappings":";;;AAQA,MAAa,UAAU;CAOtB;AAPD,gCAOC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BadRequestException = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
class BadRequestException extends common_1.BadRequestException {
|
|
6
|
+
}
|
|
7
|
+
exports.BadRequestException = BadRequestException;
|
|
8
|
+
//# sourceMappingURL=BadRequestException.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BadRequestException.js","sourceRoot":"","sources":["../../../src/usecases/exceptions/BadRequestException.ts"],"names":[],"mappings":";;;AAAA,2CAA8E;AAE9E,MAAa,mBAAoB,SAAQ,4BAAuB;CAE/D;AAFD,kDAEC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ForbiddenException = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
class ForbiddenException extends common_1.ForbiddenException {
|
|
6
|
+
}
|
|
7
|
+
exports.ForbiddenException = ForbiddenException;
|
|
8
|
+
//# sourceMappingURL=ForbiddenException.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ForbiddenException.js","sourceRoot":"","sources":["../../../src/usecases/exceptions/ForbiddenException.ts"],"names":[],"mappings":";;;AAAA,2CAA4E;AAE5E,MAAa,kBAAmB,SAAQ,2BAAsB;CAE7D;AAFD,gDAEC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UnauthorizedException = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
class UnauthorizedException extends common_1.UnauthorizedException {
|
|
6
|
+
}
|
|
7
|
+
exports.UnauthorizedException = UnauthorizedException;
|
|
8
|
+
//# sourceMappingURL=UnauthorizedException.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UnauthorizedException.js","sourceRoot":"","sources":["../../../src/usecases/exceptions/UnauthorizedException.ts"],"names":[],"mappings":";;;AAAA,2CAAkF;AAElF,MAAa,qBAAsB,SAAQ,8BAAyB;CAEnE;AAFD,sDAEC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidationException = exports.UnauthorizedException = exports.ForbiddenException = exports.BadRequestException = void 0;
|
|
4
|
+
var BadRequestException_1 = require("./BadRequestException");
|
|
5
|
+
Object.defineProperty(exports, "BadRequestException", { enumerable: true, get: function () { return BadRequestException_1.BadRequestException; } });
|
|
6
|
+
var ForbiddenException_1 = require("./ForbiddenException");
|
|
7
|
+
Object.defineProperty(exports, "ForbiddenException", { enumerable: true, get: function () { return ForbiddenException_1.ForbiddenException; } });
|
|
8
|
+
var UnauthorizedException_1 = require("./UnauthorizedException");
|
|
9
|
+
Object.defineProperty(exports, "UnauthorizedException", { enumerable: true, get: function () { return UnauthorizedException_1.UnauthorizedException; } });
|
|
10
|
+
var ValidationException_1 = require("./ValidationException");
|
|
11
|
+
Object.defineProperty(exports, "ValidationException", { enumerable: true, get: function () { return ValidationException_1.ValidationException; } });
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/usecases/exceptions/index.ts"],"names":[],"mappings":";;;AAAA,6DAA0D;AAAlD,0HAAA,mBAAmB,OAAA;AAC3B,2DAAwD;AAAhD,wHAAA,kBAAkB,OAAA;AAC1B,iEAA8D;AAAtD,8HAAA,qBAAqB,OAAA;AAC7B,6DAA0D;AAAlD,0HAAA,mBAAmB,OAAA"}
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConditionHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/ConditionHelper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
export declare class DataMapperHelper {
|
|
2
|
+
static hasFields(object: any): boolean;
|
|
2
3
|
static getKeys(object: any): any;
|
|
3
4
|
static anyToModel(source: any, ModelClass: any, fieldNames?: any): any;
|
|
4
5
|
static anyToSchema(source: any, SchemaClass: any): any;
|
|
5
6
|
static anyToPlain(source: any): any;
|
|
6
|
-
static
|
|
7
|
+
static exportModels(types: any[]): {};
|
|
8
|
+
static exportEnums(types: any[]): {};
|
|
7
9
|
}
|
|
@@ -3,10 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.DataMapperHelper = void 0;
|
|
4
4
|
const lodash_1 = require("lodash");
|
|
5
5
|
const BaseField_1 = require("../../infrastructure/decorators/fields/BaseField");
|
|
6
|
-
const
|
|
6
|
+
const constants_1 = require("@nestjs/swagger/dist/constants");
|
|
7
7
|
class DataMapperHelper {
|
|
8
|
+
static hasFields(object) {
|
|
9
|
+
return !!Reflect.getMetadata(BaseField_1.STEROIDS_META_KEYS, object.prototype);
|
|
10
|
+
}
|
|
8
11
|
static getKeys(object) {
|
|
9
|
-
return Reflect.getMetadata(BaseField_1.
|
|
12
|
+
return Reflect.getMetadata(BaseField_1.STEROIDS_META_KEYS, object.prototype) || [];
|
|
10
13
|
}
|
|
11
14
|
static anyToModel(source, ModelClass, fieldNames = null) {
|
|
12
15
|
if (!fieldNames) {
|
|
@@ -17,7 +20,7 @@ class DataMapperHelper {
|
|
|
17
20
|
if ((0, lodash_1.has)(source, fieldName)) {
|
|
18
21
|
const value = source[fieldName];
|
|
19
22
|
if ((0, lodash_1.isObject)(value)) {
|
|
20
|
-
const modelMeta =
|
|
23
|
+
const modelMeta = (0, BaseField_1.getFieldOptions)(ModelClass, fieldName);
|
|
21
24
|
if (modelMeta.appType === 'relation') {
|
|
22
25
|
model[fieldName] = this.anyToModel(value, modelMeta.modelClass());
|
|
23
26
|
}
|
|
@@ -38,7 +41,22 @@ class DataMapperHelper {
|
|
|
38
41
|
return model;
|
|
39
42
|
}
|
|
40
43
|
static anyToSchema(source, SchemaClass) {
|
|
41
|
-
|
|
44
|
+
const schema = new SchemaClass();
|
|
45
|
+
const keys = this.getKeys(SchemaClass);
|
|
46
|
+
keys.forEach(key => {
|
|
47
|
+
const meta = (0, BaseField_1.getFieldOptions)(SchemaClass, key);
|
|
48
|
+
if (meta.appType === 'relation' && !/Ids?$/.exec(key)) {
|
|
49
|
+
let subSchemaClass = Reflect.getOwnMetadata('design:type', SchemaClass.prototype, key);
|
|
50
|
+
if (!(typeof subSchemaClass === 'function')) {
|
|
51
|
+
subSchemaClass = meta.modelClass();
|
|
52
|
+
}
|
|
53
|
+
schema[key] = DataMapperHelper.anyToSchema((0, lodash_1.has)(source, key) ? source[key] : null, subSchemaClass);
|
|
54
|
+
}
|
|
55
|
+
else if ((0, lodash_1.has)(source, key)) {
|
|
56
|
+
schema[key] = source[key];
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
return schema;
|
|
42
60
|
}
|
|
43
61
|
static anyToPlain(source) {
|
|
44
62
|
if (Array.isArray(source)) {
|
|
@@ -48,7 +66,9 @@ class DataMapperHelper {
|
|
|
48
66
|
return source;
|
|
49
67
|
}
|
|
50
68
|
if ((0, lodash_1.isObject)(source)) {
|
|
51
|
-
const keys =
|
|
69
|
+
const keys = this.hasFields(source.constructor)
|
|
70
|
+
? this.getKeys(source.constructor)
|
|
71
|
+
: Object.keys(source);
|
|
52
72
|
return Object.keys(source).reduce((obj, key) => {
|
|
53
73
|
if (!keys || keys.includes(key)) {
|
|
54
74
|
obj[key] = DataMapperHelper.anyToPlain(source[key]);
|
|
@@ -58,10 +78,34 @@ class DataMapperHelper {
|
|
|
58
78
|
}
|
|
59
79
|
return source;
|
|
60
80
|
}
|
|
61
|
-
static
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
81
|
+
static exportModels(types) {
|
|
82
|
+
const result = {};
|
|
83
|
+
types.forEach(type => {
|
|
84
|
+
const fieldNames = DataMapperHelper.getKeys(type);
|
|
85
|
+
result[type.name] = {
|
|
86
|
+
attributes: fieldNames.map(fieldName => {
|
|
87
|
+
const apiMeta = Reflect.getMetadata(constants_1.DECORATORS.API_MODEL_PROPERTIES, type.prototype, fieldName);
|
|
88
|
+
const options = (0, BaseField_1.getFieldOptions)(type, fieldName);
|
|
89
|
+
const fieldData = Object.assign({ attribute: fieldName, type: options.appType || 'string', label: options.label || apiMeta.description, required: apiMeta.required }, (options.items ? { items: options.items } : {}));
|
|
90
|
+
if (fieldData.type === 'relation') {
|
|
91
|
+
fieldData['modelClass'] = options.modelClass().name;
|
|
92
|
+
}
|
|
93
|
+
return fieldData;
|
|
94
|
+
}),
|
|
95
|
+
};
|
|
96
|
+
});
|
|
97
|
+
return result;
|
|
98
|
+
}
|
|
99
|
+
static exportEnums(types) {
|
|
100
|
+
const result = {};
|
|
101
|
+
types.forEach(type => {
|
|
102
|
+
if (type.toArray) {
|
|
103
|
+
result[type.name] = {
|
|
104
|
+
labels: type.toArray(),
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
return result;
|
|
65
109
|
}
|
|
66
110
|
}
|
|
67
111
|
exports.DataMapperHelper = DataMapperHelper;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DataMapperHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/DataMapperHelper.ts"],"names":[],"mappings":";;;AAAA,mCAIgB;AAChB,
|
|
1
|
+
{"version":3,"file":"DataMapperHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/DataMapperHelper.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,5 +4,5 @@ import { SearchInputDto } from '../dtos/SearchInputDto';
|
|
|
4
4
|
import { SearchResultDto } from '../dtos/SearchResultDto';
|
|
5
5
|
import SearchQuery from '../base/SearchQuery';
|
|
6
6
|
export declare class SearchHelper {
|
|
7
|
-
static search<TTable>(repository: Repository<any>, dto: SearchInputDto,
|
|
7
|
+
static search<TTable>(repository: Repository<any>, dto: SearchInputDto, searchQuery: SearchQuery, prepareHandler?: (query: SelectQueryBuilder<TTable>) => void | null): Promise<SearchResultDto<TTable>>;
|
|
8
8
|
}
|
|
@@ -4,11 +4,11 @@ exports.SearchHelper = void 0;
|
|
|
4
4
|
const SearchResultDto_1 = require("../dtos/SearchResultDto");
|
|
5
5
|
const SearchQuery_1 = require("../base/SearchQuery");
|
|
6
6
|
class SearchHelper {
|
|
7
|
-
static async search(repository, dto,
|
|
7
|
+
static async search(repository, dto, searchQuery, prepareHandler = null) {
|
|
8
8
|
const result = new SearchResultDto_1.SearchResultDto();
|
|
9
9
|
dto = Object.assign({ page: 1, pageSize: 50 }, dto);
|
|
10
10
|
const dbQuery = repository.createQueryBuilder();
|
|
11
|
-
SearchQuery_1.default.prepare(repository, dbQuery,
|
|
11
|
+
SearchQuery_1.default.prepare(repository, dbQuery, searchQuery);
|
|
12
12
|
const sort = typeof dto.sort === 'string' ? dto.sort.split(',') : (dto.sort || []);
|
|
13
13
|
if (sort.length === 0) {
|
|
14
14
|
dbQuery.orderBy(sort.reduce((obj, value) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SearchHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/SearchHelper.ts"],"names":[],"mappings":";;;AAGA,6DAAwD;AACxD,qDAA8C;AAE9C,MAAa,YAAY;IAErB,MAAM,CAAC,KAAK,CAAC,MAAM,CACf,UAA2B,EAC3B,GAAmB,EACnB,
|
|
1
|
+
{"version":3,"file":"SearchHelper.js","sourceRoot":"","sources":["../../../src/usecases/helpers/SearchHelper.ts"],"names":[],"mappings":";;;AAGA,6DAAwD;AACxD,qDAA8C;AAE9C,MAAa,YAAY;IAErB,MAAM,CAAC,KAAK,CAAC,MAAM,CACf,UAA2B,EAC3B,GAAmB,EACnB,WAAwB,EACxB,iBAAqE,IAAI;QAEzE,MAAM,MAAM,GAAG,IAAI,iCAAe,EAAU,CAAC;QAG7C,GAAG,mBACC,IAAI,EAAE,CAAC,EACP,QAAQ,EAAE,EAAE,IACT,GAAG,CACT,CAAC;QAGF,MAAM,OAAO,GAAG,UAAU,CAAC,kBAAkB,EAAE,CAAC;QAEhD,qBAAW,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,EAAE,WAAW,CAAC,CAAC;QAGtD,MAAM,IAAI,GAAG,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACnF,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;gBACvC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;gBACxE,OAAO,GAAG,CAAC;YACf,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;SACX;QAGD,IAAI,cAAc,EAAE;YAChB,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;SACtC;QAGD,OAAO;aACF,MAAM,CAAC,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC;aACrC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAGzB,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,eAAe,EAAE,CAAC;QACvD,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QACrB,MAAM,CAAC,KAAK,GAAG,KAAK,CAAC;QAErB,OAAO,MAAM,CAAC;IAClB,CAAC;CACJ;AAhDD,oCAgDC"}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { Repository } from 'typeorm';
|
|
2
2
|
import { SearchResultDto } from '../dtos/SearchResultDto';
|
|
3
3
|
import { SearchInputDto } from '../dtos/SearchInputDto';
|
|
4
|
-
import { ICondition } from '../../infrastructure/helpers/ConditionHelper';
|
|
5
4
|
import { Type } from '@nestjs/common';
|
|
6
5
|
import SearchQuery from '../base/SearchQuery';
|
|
6
|
+
import { ICondition } from '../helpers/ConditionHelper';
|
|
7
7
|
export interface ICrudRepository<TModel> {
|
|
8
8
|
dbRepository: Repository<any>;
|
|
9
9
|
search: <TItem>(dto: SearchInputDto, searchQuery: SearchQuery) => Promise<SearchResultDto<TModel | Type<TItem>>>;
|
|
10
10
|
findOne: (conditionOrQuery: ICondition | SearchQuery) => Promise<TModel | null>;
|
|
11
11
|
findMany: (conditionOrQuery: ICondition | SearchQuery) => Promise<TModel[]>;
|
|
12
|
-
create: (model: TModel) => Promise<TModel>;
|
|
13
|
-
update: (id: number, model: TModel) => Promise<TModel>;
|
|
14
|
-
remove: (id: number) => Promise<void>;
|
|
12
|
+
create: (model: TModel, transactionHandler?: (callback: any) => Promise<void>) => Promise<TModel>;
|
|
13
|
+
update: (id: number, model: TModel, transactionHandler?: (callback: any) => Promise<void>) => Promise<TModel>;
|
|
14
|
+
remove: (id: number, transactionHandler?: (callback: any) => Promise<void>) => Promise<void>;
|
|
15
15
|
}
|
|
@@ -3,22 +3,27 @@ import { ICrudRepository } from '../interfaces/ICrudRepository';
|
|
|
3
3
|
import { ISearchInputDto } from '../dtos/SearchInputDto';
|
|
4
4
|
import { SearchResultDto } from '../dtos/SearchResultDto';
|
|
5
5
|
import SearchQuery from '../base/SearchQuery';
|
|
6
|
+
import { ContextDto } from '../dtos/ContextDto';
|
|
6
7
|
export declare class CrudService<TModel, TSearchDto = ISearchInputDto, TSaveDto = TModel> {
|
|
7
8
|
protected primaryKey: string;
|
|
8
9
|
protected repository: ICrudRepository<TModel>;
|
|
9
10
|
protected modelClass: any;
|
|
10
11
|
init(repository: ICrudRepository<TModel>, ModelClass: any): void;
|
|
11
|
-
search(dto: TSearchDto): Promise<SearchResultDto<TModel>>;
|
|
12
|
-
search<TSchema>(dto: TSearchDto, schemaClass
|
|
13
|
-
findById(id: number | string): Promise<TModel>;
|
|
14
|
-
findById<TSchema>(id: number | string, schemaClass
|
|
12
|
+
search(dto: TSearchDto, context?: ContextDto | null): Promise<SearchResultDto<TModel>>;
|
|
13
|
+
search<TSchema>(dto: TSearchDto, context?: ContextDto | null, schemaClass?: Type<TSchema>): Promise<SearchResultDto<Type<TSchema>>>;
|
|
14
|
+
findById(id: number | string, context?: ContextDto | null): Promise<TModel>;
|
|
15
|
+
findById<TSchema>(id: number | string, context?: ContextDto | null, schemaClass?: Type<TSchema>): Promise<Type<TSchema>>;
|
|
15
16
|
findOne(searchQuery: SearchQuery): Promise<TModel>;
|
|
16
17
|
findMany(searchQuery: SearchQuery): Promise<TModel[]>;
|
|
17
|
-
create(dto: TSaveDto): Promise<TModel>;
|
|
18
|
-
create<TSchema>(dto: TSaveDto, schemaClass
|
|
19
|
-
update<TSchema>(id: number | string, dto: TSaveDto): Promise<TModel>;
|
|
20
|
-
update<TSchema>(id: number | string, dto: TSaveDto, schemaClass
|
|
21
|
-
remove(
|
|
18
|
+
create(dto: TSaveDto, context?: ContextDto | null): Promise<TModel>;
|
|
19
|
+
create<TSchema>(dto: TSaveDto, context?: ContextDto | null, schemaClass?: Type<TSchema>): Promise<Type<TSchema>>;
|
|
20
|
+
update<TSchema>(id: number | string, dto: TSaveDto, context?: ContextDto | null): Promise<TModel>;
|
|
21
|
+
update<TSchema>(id: number | string, dto: TSaveDto, context?: ContextDto | null, schemaClass?: Type<TSchema>): Promise<Type<TSchema>>;
|
|
22
|
+
remove(rawId: number | string, context?: ContextDto): Promise<void>;
|
|
23
|
+
protected beforeSave(prevModel: TModel | null, nextModel: TModel): Promise<void>;
|
|
24
|
+
protected afterSave(prevModel: TModel | null, nextModel: TModel): Promise<void>;
|
|
25
|
+
protected beforeDelete(id: number): Promise<void>;
|
|
26
|
+
protected afterDelete(id: number): Promise<void>;
|
|
22
27
|
protected modelToSchema<TSchema>(model: TModel, schemaClass: Type<TSchema>): Type<TSchema>;
|
|
23
28
|
protected dtoToModel(dto: TSaveDto): Promise<TModel>;
|
|
24
29
|
}
|
|
@@ -13,7 +13,7 @@ class CrudService {
|
|
|
13
13
|
this.repository = repository;
|
|
14
14
|
this.modelClass = ModelClass;
|
|
15
15
|
}
|
|
16
|
-
async search(dto, schemaClass = null) {
|
|
16
|
+
async search(dto, context = null, schemaClass = null) {
|
|
17
17
|
await (0, ValidationHelper_1.validateOrReject)(dto);
|
|
18
18
|
const result = await this.repository.search(dto, SearchQuery_1.default.createFromSchema(schemaClass));
|
|
19
19
|
if (schemaClass) {
|
|
@@ -21,7 +21,7 @@ class CrudService {
|
|
|
21
21
|
}
|
|
22
22
|
return result;
|
|
23
23
|
}
|
|
24
|
-
async findById(id, schemaClass = null) {
|
|
24
|
+
async findById(id, context = null, schemaClass = null) {
|
|
25
25
|
const searchQuery = SearchQuery_1.default.createFromSchema(schemaClass);
|
|
26
26
|
searchQuery.condition = { [this.primaryKey]: (0, lodash_1.toInteger)(id) };
|
|
27
27
|
const model = await this.findOne(searchQuery);
|
|
@@ -33,18 +33,44 @@ class CrudService {
|
|
|
33
33
|
async findMany(searchQuery) {
|
|
34
34
|
return await this.repository.findMany(searchQuery);
|
|
35
35
|
}
|
|
36
|
-
async create(dto, schemaClass = null) {
|
|
36
|
+
async create(dto, context = null, schemaClass = null) {
|
|
37
37
|
await (0, ValidationHelper_1.validateOrReject)(dto);
|
|
38
|
-
const
|
|
39
|
-
|
|
38
|
+
const nextModel = await this.dtoToModel(dto);
|
|
39
|
+
let model;
|
|
40
|
+
await this.repository.create(nextModel, async (save) => {
|
|
41
|
+
await this.beforeSave(null, nextModel);
|
|
42
|
+
model = await save();
|
|
43
|
+
await this.afterSave(null, model);
|
|
44
|
+
});
|
|
45
|
+
return schemaClass ? this.findById(model[this.primaryKey], context, schemaClass) : model;
|
|
40
46
|
}
|
|
41
|
-
async update(id, dto, schemaClass = null) {
|
|
47
|
+
async update(id, dto, context = null, schemaClass = null) {
|
|
42
48
|
await (0, ValidationHelper_1.validateOrReject)(dto);
|
|
43
|
-
const
|
|
44
|
-
|
|
49
|
+
const prevModel = await this.findById(id);
|
|
50
|
+
const nextModel = await this.dtoToModel(dto);
|
|
51
|
+
let model;
|
|
52
|
+
await this.repository.update((0, lodash_1.toInteger)(id), nextModel, async (save) => {
|
|
53
|
+
await this.beforeSave(prevModel, nextModel);
|
|
54
|
+
model = await save();
|
|
55
|
+
await this.afterSave(prevModel, model);
|
|
56
|
+
});
|
|
57
|
+
return schemaClass ? this.findById(id, context, schemaClass) : model;
|
|
45
58
|
}
|
|
46
|
-
async remove(
|
|
47
|
-
|
|
59
|
+
async remove(rawId, context = null) {
|
|
60
|
+
const id = (0, lodash_1.toInteger)(rawId);
|
|
61
|
+
await this.repository.remove(id, async (remove) => {
|
|
62
|
+
await this.beforeDelete(id);
|
|
63
|
+
await remove();
|
|
64
|
+
await this.afterDelete(id);
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
async beforeSave(prevModel, nextModel) {
|
|
68
|
+
}
|
|
69
|
+
async afterSave(prevModel, nextModel) {
|
|
70
|
+
}
|
|
71
|
+
async beforeDelete(id) {
|
|
72
|
+
}
|
|
73
|
+
async afterDelete(id) {
|
|
48
74
|
}
|
|
49
75
|
modelToSchema(model, schemaClass) {
|
|
50
76
|
return DataMapperHelper_1.DataMapperHelper.anyToSchema(model, schemaClass);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CrudService.js","sourceRoot":"","sources":["../../../src/usecases/services/CrudService.ts"],"names":[],"mappings":";;;AACA,mCAA+C;AAE/C,kEAA6D;AAG7D,kEAA6D;AAC7D,qDAA8C;
|
|
1
|
+
{"version":3,"file":"CrudService.js","sourceRoot":"","sources":["../../../src/usecases/services/CrudService.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SteroidsSchema = exports.SCHEMA_META_KEY = void 0;
|
|
4
|
-
exports.SCHEMA_META_KEY = 'meta';
|
|
5
|
-
function SteroidsSchema(options = {}) {
|
|
6
|
-
return (target) => {
|
|
7
|
-
Reflect.defineMetadata(exports.SCHEMA_META_KEY, options, target);
|
|
8
|
-
};
|
|
9
|
-
}
|
|
10
|
-
exports.SteroidsSchema = SteroidsSchema;
|
|
11
|
-
//# sourceMappingURL=SteroidsSchema.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SteroidsSchema.js","sourceRoot":"","sources":["../../../src/infrastructure/decorators/SteroidsSchema.ts"],"names":[],"mappings":";;;AAAa,QAAA,eAAe,GAAG,MAAM,CAAC;AAOtC,SAAgB,cAAc,CAAC,UAA0B,EAAE;IACvD,OAAO,CAAC,MAAM,EAAE,EAAE;QACd,OAAO,CAAC,cAAc,CAAC,uBAAe,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IAC7D,CAAC,CAAC;AACN,CAAC;AAJD,wCAIC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ConditionHelper.js","sourceRoot":"","sources":["../../../src/infrastructure/helpers/ConditionHelper.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { IAllFieldOptions } from '../decorators/fields';
|
|
2
|
-
import { ISchemaOptions } from '../decorators/SteroidsSchema';
|
|
3
|
-
import { IQueryRelation } from '../../usecases/base/SearchQuery';
|
|
4
|
-
export declare class MetaHelper {
|
|
5
|
-
static getFieldOptions(ModelClass: any, fieldName: any): IAllFieldOptions;
|
|
6
|
-
static getFieldNames(AnyClass: any): string[];
|
|
7
|
-
static getSchemaOptions(SchemaClass: any): ISchemaOptions;
|
|
8
|
-
static getSchemaQueryData(SchemaClass: any): {
|
|
9
|
-
select: string[];
|
|
10
|
-
excludeSelect: string[];
|
|
11
|
-
relations: IQueryRelation[];
|
|
12
|
-
};
|
|
13
|
-
static exportModels(types: any[]): {};
|
|
14
|
-
static exportEnums(types: any[]): {};
|
|
15
|
-
}
|