@steroidsjs/nest 3.2.5 → 3.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/infrastructure/applications/console/ConsoleApplication.d.ts +2 -1
- package/infrastructure/applications/console/ConsoleApplication.js.map +1 -1
- package/infrastructure/applications/rest/RestApplication.d.ts +6 -2
- package/infrastructure/applications/rest/RestApplication.js +3 -0
- package/infrastructure/applications/rest/RestApplication.js.map +1 -1
- package/infrastructure/decorators/ApiOkAutocompleteResponse.d.ts +6 -0
- package/infrastructure/decorators/ApiOkAutocompleteResponse.js +30 -0
- package/infrastructure/decorators/ApiOkAutocompleteResponse.js.map +1 -0
- package/infrastructure/decorators/fields/EnumField.js +19 -7
- package/infrastructure/decorators/fields/EnumField.js.map +1 -1
- package/infrastructure/decorators/fields/EnumField.test.js +31 -0
- package/infrastructure/decorators/fields/EnumField.test.js.map +1 -0
- package/infrastructure/decorators/fields/JSONBField.js +1 -0
- package/infrastructure/decorators/fields/JSONBField.js.map +1 -1
- package/package.json +3 -2
- package/tsconfig.tsbuildinfo +1 -1
- package/usecases/dtos/SearchInputDto.d.ts +2 -0
- package/usecases/dtos/SearchInputDto.js +19 -3
- package/usecases/dtos/SearchInputDto.js.map +1 -1
- package/usecases/services/ReadService.d.ts +13 -1
- package/usecases/services/ReadService.js +21 -1
- package/usecases/services/ReadService.js.map +1 -1
- package/usecases/useCases/AutocompleteSearch/AutoCompleteSearchUseCase.d.ts +10 -0
- package/usecases/useCases/AutocompleteSearch/AutoCompleteSearchUseCase.js +36 -0
- package/usecases/useCases/AutocompleteSearch/AutoCompleteSearchUseCase.js.map +1 -0
- package/usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseDto.d.ts +4 -0
- package/{infrastructure/tests/app/schemas/FileSchema.js → usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseDto.js} +13 -13
- package/usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseDto.js.map +1 -0
- package/usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseSchema.d.ts +9 -0
- package/usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseSchema.js +56 -0
- package/usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseSchema.js.map +1 -0
- package/infrastructure/tests/ModelTest.test.js +0 -146
- package/infrastructure/tests/ModelTest.test.js.map +0 -1
- package/infrastructure/tests/app/models/ArticleModel.d.ts +0 -15
- package/infrastructure/tests/app/models/ArticleModel.js +0 -79
- package/infrastructure/tests/app/models/ArticleModel.js.map +0 -1
- package/infrastructure/tests/app/models/CommentModel.d.ts +0 -11
- package/infrastructure/tests/app/models/CommentModel.js +0 -58
- package/infrastructure/tests/app/models/CommentModel.js.map +0 -1
- package/infrastructure/tests/app/models/FileModel.d.ts +0 -7
- package/infrastructure/tests/app/models/FileModel.js +0 -41
- package/infrastructure/tests/app/models/FileModel.js.map +0 -1
- package/infrastructure/tests/app/models/ImageModel.d.ts +0 -8
- package/infrastructure/tests/app/models/ImageModel.js +0 -45
- package/infrastructure/tests/app/models/ImageModel.js.map +0 -1
- package/infrastructure/tests/app/models/TagModel.d.ts +0 -4
- package/infrastructure/tests/app/models/TagModel.js +0 -25
- package/infrastructure/tests/app/models/TagModel.js.map +0 -1
- package/infrastructure/tests/app/models/UserInfoModel.d.ts +0 -10
- package/infrastructure/tests/app/models/UserInfoModel.js +0 -56
- package/infrastructure/tests/app/models/UserInfoModel.js.map +0 -1
- package/infrastructure/tests/app/models/UserModel.d.ts +0 -12
- package/infrastructure/tests/app/models/UserModel.js +0 -71
- package/infrastructure/tests/app/models/UserModel.js.map +0 -1
- package/infrastructure/tests/app/repositories/ArticleRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/ArticleRepository.js +0 -35
- package/infrastructure/tests/app/repositories/ArticleRepository.js.map +0 -1
- package/infrastructure/tests/app/repositories/CommentRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/CommentRepository.js +0 -35
- package/infrastructure/tests/app/repositories/CommentRepository.js.map +0 -1
- package/infrastructure/tests/app/repositories/FileRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/FileRepository.js +0 -35
- package/infrastructure/tests/app/repositories/FileRepository.js.map +0 -1
- package/infrastructure/tests/app/repositories/ImageRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/ImageRepository.js +0 -35
- package/infrastructure/tests/app/repositories/ImageRepository.js.map +0 -1
- package/infrastructure/tests/app/repositories/TagRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/TagRepository.js +0 -35
- package/infrastructure/tests/app/repositories/TagRepository.js.map +0 -1
- package/infrastructure/tests/app/repositories/UserRepository.d.ts +0 -9
- package/infrastructure/tests/app/repositories/UserRepository.js +0 -35
- package/infrastructure/tests/app/repositories/UserRepository.js.map +0 -1
- package/infrastructure/tests/app/schemas/ArticleSchema.d.ts +0 -11
- package/infrastructure/tests/app/schemas/ArticleSchema.js +0 -54
- package/infrastructure/tests/app/schemas/ArticleSchema.js.map +0 -1
- package/infrastructure/tests/app/schemas/FileSchema.d.ts +0 -4
- package/infrastructure/tests/app/schemas/FileSchema.js.map +0 -1
- package/infrastructure/tests/app/schemas/ImageSchema.d.ts +0 -5
- package/infrastructure/tests/app/schemas/ImageSchema.js +0 -30
- package/infrastructure/tests/app/schemas/ImageSchema.js.map +0 -1
- package/infrastructure/tests/app/schemas/UserInfoSchema.d.ts +0 -6
- package/infrastructure/tests/app/schemas/UserInfoSchema.js +0 -33
- package/infrastructure/tests/app/schemas/UserInfoSchema.js.map +0 -1
- package/infrastructure/tests/app/schemas/UserSchema.d.ts +0 -8
- package/infrastructure/tests/app/schemas/UserSchema.js +0 -40
- package/infrastructure/tests/app/schemas/UserSchema.js.map +0 -1
- package/infrastructure/tests/app/services/ArticleService.d.ts +0 -12
- package/infrastructure/tests/app/services/ArticleService.js +0 -31
- package/infrastructure/tests/app/services/ArticleService.js.map +0 -1
- package/infrastructure/tests/app/services/CommentService.d.ts +0 -12
- package/infrastructure/tests/app/services/CommentService.js +0 -31
- package/infrastructure/tests/app/services/CommentService.js.map +0 -1
- package/infrastructure/tests/app/services/FileService.d.ts +0 -12
- package/infrastructure/tests/app/services/FileService.js +0 -31
- package/infrastructure/tests/app/services/FileService.js.map +0 -1
- package/infrastructure/tests/app/services/ImageService.d.ts +0 -12
- package/infrastructure/tests/app/services/ImageService.js +0 -31
- package/infrastructure/tests/app/services/ImageService.js.map +0 -1
- package/infrastructure/tests/app/services/TagService.d.ts +0 -12
- package/infrastructure/tests/app/services/TagService.js +0 -31
- package/infrastructure/tests/app/services/TagService.js.map +0 -1
- package/infrastructure/tests/app/services/UserService.d.ts +0 -12
- package/infrastructure/tests/app/services/UserService.js +0 -31
- package/infrastructure/tests/app/services/UserService.js.map +0 -1
- package/infrastructure/tests/app/tables/ArticleTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/ArticleTable.js +0 -18
- package/infrastructure/tests/app/tables/ArticleTable.js.map +0 -1
- package/infrastructure/tests/app/tables/CommentTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/CommentTable.js +0 -18
- package/infrastructure/tests/app/tables/CommentTable.js.map +0 -1
- package/infrastructure/tests/app/tables/FileTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/FileTable.js +0 -18
- package/infrastructure/tests/app/tables/FileTable.js.map +0 -1
- package/infrastructure/tests/app/tables/ImageTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/ImageTable.js +0 -18
- package/infrastructure/tests/app/tables/ImageTable.js.map +0 -1
- package/infrastructure/tests/app/tables/TagTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/TagTable.js +0 -18
- package/infrastructure/tests/app/tables/TagTable.js.map +0 -1
- package/infrastructure/tests/app/tables/UserInfoTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/UserInfoTable.js +0 -18
- package/infrastructure/tests/app/tables/UserInfoTable.js.map +0 -1
- package/infrastructure/tests/app/tables/UserTable.d.ts +0 -3
- package/infrastructure/tests/app/tables/UserTable.js +0 -18
- package/infrastructure/tests/app/tables/UserTable.js.map +0 -1
- package/infrastructure/tests/bootstrap.d.ts +0 -1
- package/infrastructure/tests/bootstrap.js +0 -55
- package/infrastructure/tests/bootstrap.js.map +0 -1
- /package/infrastructure/{tests/ModelTest.test.d.ts → decorators/fields/EnumField.test.d.ts} +0 -0
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { INestApplicationContext } from "@nestjs/common";
|
|
1
2
|
import { BaseApplication } from '../BaseApplication';
|
|
2
3
|
import { AppModule } from '../AppModule';
|
|
3
4
|
/**
|
|
@@ -9,7 +10,7 @@ export declare class ConsoleApplication extends BaseApplication {
|
|
|
9
10
|
* An instance of an application built with NestJS.
|
|
10
11
|
* @protected
|
|
11
12
|
*/
|
|
12
|
-
protected _app:
|
|
13
|
+
protected _app: INestApplicationContext;
|
|
13
14
|
/**
|
|
14
15
|
* The class of the application module (default is `AppModule`).
|
|
15
16
|
* @protected
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConsoleApplication.js","sourceRoot":"","sources":["../../../../src/infrastructure/applications/console/ConsoleApplication.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;
|
|
1
|
+
{"version":3,"file":"ConsoleApplication.js","sourceRoot":"","sources":["../../../../src/infrastructure/applications/console/ConsoleApplication.ts"],"names":[],"mappings":";;;AAAA,uCAAyC;AAEzC,mDAA6D;AAC7D,wDAAmD;AACnD,4CAAuC;AAEvC;;;GAGG;AACH,MAAa,kBAAmB,SAAQ,iCAAe;IAanD,YAAY,WAAW,GAAG,qBAAS;QAC/B,KAAK,EAAE,CAAC;QAER,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IACpC,CAAC;IAED;;;;;OAKG;IACO,OAAO;QACb,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,GAAG,CAAC;QAE7B,KAAK,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,KAAK;QACd,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;QAElB,IAAI,CAAC,IAAI,GAAG,MAAM,kBAAW,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,EAAE;YACtE,MAAM,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,cAAc;SAC5C,CAAC,CAAC;QAEH,IAAI;YACA,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,8BAAa,CAAC,CAAC,GAAG,CAAC,+BAAc,CAAC,CAAC,IAAI,EAAE,CAAC;SACpE;QAAC,OAAO,KAAK,EAAE;YACZ,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,iCAAiC;SAC1D;QAED,MAAM,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;CACJ;AAnDD,gDAmDC"}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { INestApplication } from '@nestjs/common';
|
|
1
2
|
import { IRestAppModuleConfig } from './IRestAppModuleConfig';
|
|
2
3
|
import { BaseApplication } from '../BaseApplication';
|
|
3
4
|
import { AppModule } from '../AppModule';
|
|
@@ -9,7 +10,7 @@ export declare class RestApplication extends BaseApplication {
|
|
|
9
10
|
* An instance of an application built with NestJS.
|
|
10
11
|
* @protected
|
|
11
12
|
*/
|
|
12
|
-
protected _app:
|
|
13
|
+
protected _app: INestApplication;
|
|
13
14
|
/**
|
|
14
15
|
* The class of the application module (default is `AppModule`).
|
|
15
16
|
* @protected
|
|
@@ -54,6 +55,9 @@ export declare class RestApplication extends BaseApplication {
|
|
|
54
55
|
/**
|
|
55
56
|
* Initializes Sentry for error tracking and logging.
|
|
56
57
|
* If the environment variable `APP_SENTRY_DSN` is set, the filter `SentryExceptionFilter` is added.
|
|
58
|
+
*
|
|
59
|
+
* Sentry also automatically configures `process.on('uncaughtException')` and `process.on('unhandledRejection')` to log and handle these events,
|
|
60
|
+
* only on `uncaughtException` the process will be exited, but on `unhandledRejection` it will continue to work.
|
|
57
61
|
* @protected
|
|
58
62
|
*/
|
|
59
63
|
protected initSentry(): void;
|
|
@@ -84,5 +88,5 @@ export declare class RestApplication extends BaseApplication {
|
|
|
84
88
|
/**
|
|
85
89
|
* Getter for `_app`
|
|
86
90
|
*/
|
|
87
|
-
getApp():
|
|
91
|
+
getApp(): INestApplication;
|
|
88
92
|
}
|
|
@@ -117,6 +117,9 @@ class RestApplication extends BaseApplication_1.BaseApplication {
|
|
|
117
117
|
/**
|
|
118
118
|
* Initializes Sentry for error tracking and logging.
|
|
119
119
|
* If the environment variable `APP_SENTRY_DSN` is set, the filter `SentryExceptionFilter` is added.
|
|
120
|
+
*
|
|
121
|
+
* Sentry also automatically configures `process.on('uncaughtException')` and `process.on('unhandledRejection')` to log and handle these events,
|
|
122
|
+
* only on `uncaughtException` the process will be exited, but on `unhandledRejection` it will continue to work.
|
|
120
123
|
* @protected
|
|
121
124
|
*/
|
|
122
125
|
initSentry() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RestApplication.js","sourceRoot":"","sources":["../../../../src/infrastructure/applications/rest/RestApplication.ts"],"names":[],"mappings":";;;AAAA,uCAAoD;AACpD,6CAA6C;AAC7C,6CAA+D;AAC/D,
|
|
1
|
+
{"version":3,"file":"RestApplication.js","sourceRoot":"","sources":["../../../../src/infrastructure/applications/rest/RestApplication.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { IType } from '../../usecases/interfaces/IType';
|
|
2
|
+
interface ApiOkAutocompleteResponseOptions {
|
|
3
|
+
type: IType;
|
|
4
|
+
}
|
|
5
|
+
export declare function ApiOkAutocompleteResponse(options: ApiOkAutocompleteResponseOptions): <TFunction extends Function, Y>(target: object | TFunction, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
|
|
6
|
+
export {};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ApiOkAutocompleteResponse = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
6
|
+
const AutocompleteBaseSchema_1 = require("../../usecases/useCases/AutocompleteSearch/dtos/AutocompleteBaseSchema");
|
|
7
|
+
function ApiOkAutocompleteResponse(options) {
|
|
8
|
+
const itemType = options.type;
|
|
9
|
+
return (0, common_1.applyDecorators)((0, swagger_1.ApiExtraModels)(AutocompleteBaseSchema_1.AutocompleteBaseSchema, itemType), (0, swagger_1.ApiOkResponse)({
|
|
10
|
+
schema: {
|
|
11
|
+
allOf: [
|
|
12
|
+
{ $ref: (0, swagger_1.getSchemaPath)(AutocompleteBaseSchema_1.AutocompleteBaseSchema) },
|
|
13
|
+
{
|
|
14
|
+
properties: {
|
|
15
|
+
items: {
|
|
16
|
+
type: 'array',
|
|
17
|
+
items: { $ref: (0, swagger_1.getSchemaPath)(itemType) },
|
|
18
|
+
},
|
|
19
|
+
selectedItems: {
|
|
20
|
+
type: 'array',
|
|
21
|
+
items: { $ref: (0, swagger_1.getSchemaPath)(itemType) },
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
},
|
|
27
|
+
}));
|
|
28
|
+
}
|
|
29
|
+
exports.ApiOkAutocompleteResponse = ApiOkAutocompleteResponse;
|
|
30
|
+
//# sourceMappingURL=ApiOkAutocompleteResponse.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ApiOkAutocompleteResponse.js","sourceRoot":"","sources":["../../../src/infrastructure/decorators/ApiOkAutocompleteResponse.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAC/C,6CAA6E;AAC7E,mHAA8G;AAQ9G,SAAgB,yBAAyB,CAAC,OAAyC;IAC/E,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAC9B,OAAO,IAAA,wBAAe,EAClB,IAAA,wBAAc,EAAC,+CAAsB,EAAE,QAAQ,CAAC,EAChD,IAAA,uBAAa,EAAC;QACV,MAAM,EAAE;YACJ,KAAK,EAAE;gBACH,EAAC,IAAI,EAAE,IAAA,uBAAa,EAAC,+CAAsB,CAAC,EAAC;gBAC7C;oBACI,UAAU,EAAE;wBACR,KAAK,EAAE;4BACH,IAAI,EAAE,OAAO;4BACb,KAAK,EAAE,EAAC,IAAI,EAAE,IAAA,uBAAa,EAAC,QAAQ,CAAC,EAAC;yBACzC;wBACD,aAAa,EAAE;4BACX,IAAI,EAAE,OAAO;4BACb,KAAK,EAAE,EAAC,IAAI,EAAE,IAAA,uBAAa,EAAC,QAAQ,CAAC,EAAC;yBACzC;qBACJ;iBACJ;aACJ;SACJ;KACJ,CAAC,CACL,CAAC;AACN,CAAC;AAxBD,8DAwBC"}
|
|
@@ -6,9 +6,18 @@ const class_validator_1 = require("class-validator");
|
|
|
6
6
|
const swagger_1 = require("@nestjs/swagger");
|
|
7
7
|
const BaseField_1 = require("./BaseField");
|
|
8
8
|
const BaseEnum_1 = require("../../../domain/base/BaseEnum");
|
|
9
|
-
function
|
|
10
|
-
if (Array.isArray(
|
|
11
|
-
|
|
9
|
+
function getOpenApiEnum(enumEntity) {
|
|
10
|
+
if (Array.isArray(enumEntity)) {
|
|
11
|
+
return enumEntity;
|
|
12
|
+
}
|
|
13
|
+
if (typeof enumEntity === 'function' && enumEntity.prototype instanceof BaseEnum_1.default) {
|
|
14
|
+
return enumEntity.getKeys();
|
|
15
|
+
}
|
|
16
|
+
return Object.keys(enumEntity);
|
|
17
|
+
}
|
|
18
|
+
function getValidatorEnum(enumEntity) {
|
|
19
|
+
if (Array.isArray(enumEntity)) {
|
|
20
|
+
return enumEntity.reduce((obj, value) => {
|
|
12
21
|
if (value.prototype instanceof BaseEnum_1.default) {
|
|
13
22
|
obj = Object.assign(Object.assign({}, obj), value.toEnum());
|
|
14
23
|
}
|
|
@@ -18,9 +27,12 @@ function EnumField(options = {}) {
|
|
|
18
27
|
return obj;
|
|
19
28
|
}, {});
|
|
20
29
|
}
|
|
21
|
-
|
|
22
|
-
|
|
30
|
+
if (typeof enumEntity === 'function' && enumEntity.prototype instanceof BaseEnum_1.default) {
|
|
31
|
+
return enumEntity.toEnum();
|
|
23
32
|
}
|
|
33
|
+
return enumEntity;
|
|
34
|
+
}
|
|
35
|
+
function EnumField(options = {}) {
|
|
24
36
|
return (0, common_1.applyDecorators)(...[
|
|
25
37
|
(0, BaseField_1.BaseField)(options, {
|
|
26
38
|
decoratorName: 'EnumField',
|
|
@@ -28,10 +40,10 @@ function EnumField(options = {}) {
|
|
|
28
40
|
jsType: 'string',
|
|
29
41
|
}),
|
|
30
42
|
(0, swagger_1.ApiProperty)({
|
|
31
|
-
enum: options.enum,
|
|
43
|
+
enum: getOpenApiEnum(options.enum),
|
|
32
44
|
}),
|
|
33
45
|
options.nullable && (0, class_validator_1.ValidateIf)((object, value) => value !== null && typeof value !== 'undefined'),
|
|
34
|
-
(0, class_validator_1.IsEnum)(options.enum, {
|
|
46
|
+
(0, class_validator_1.IsEnum)(getValidatorEnum(options.enum), {
|
|
35
47
|
each: options.isArray,
|
|
36
48
|
message: options.isEnumConstraintMessage || 'Выберите одно из значений',
|
|
37
49
|
}),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EnumField.js","sourceRoot":"","sources":["../../../../src/infrastructure/decorators/fields/EnumField.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAC/C,qDAAmD;AACnD,6CAA4C;AAC5C,2CAAyD;AACzD,4DAAqD;
|
|
1
|
+
{"version":3,"file":"EnumField.js","sourceRoot":"","sources":["../../../../src/infrastructure/decorators/fields/EnumField.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAC/C,qDAAmD;AACnD,6CAA4C;AAC5C,2CAAyD;AACzD,4DAAqD;AAWrD,SAAS,cAAc,CAAC,UAA6C;IACjE,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;QAC3B,OAAO,UAAU,CAAC;KACrB;IAED,IAAI,OAAO,UAAU,KAAK,UAAU,IAAI,UAAU,CAAC,SAAS,YAAY,kBAAQ,EAAE;QAC9E,OAAQ,UAA4B,CAAC,OAAO,EAAE,CAAC;KAClD;IAED,OAAO,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;AACnC,CAAC;AAED,SAAS,gBAAgB,CAAC,UAAmC;IACzD,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;QAC3B,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACpC,IAAI,KAAK,CAAC,SAAS,YAAY,kBAAQ,EAAE;gBACrC,GAAG,mCACI,GAAG,GACH,KAAK,CAAC,MAAM,EAAE,CACpB,CAAC;aACL;iBAAM,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;gBAClC,GAAG,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;aACtB;YACD,OAAO,GAAG,CAAC;QACf,CAAC,EAAE,EAAE,CAAC,CAAC;KACV;IAED,IAAI,OAAO,UAAU,KAAK,UAAU,IAAI,UAAU,CAAC,SAAS,YAAY,kBAAQ,EAAE;QAC9E,OAAO,UAAU,CAAC,MAAM,EAAE,CAAC;KAC9B;IAED,OAAO,UAAU,CAAC;AACtB,CAAC;AAED,SAAgB,SAAS,CAAC,UAA6B,EAAE;IACrD,OAAO,IAAA,wBAAe,EAAC,GAAG;QACtB,IAAA,qBAAS,EAAC,OAAO,EAAE;YACf,aAAa,EAAE,WAAW;YAC1B,OAAO,EAAE,MAAM;YACf,MAAM,EAAE,QAAQ;SACnB,CAAC;QACF,IAAA,qBAAW,EAAC;YACR,IAAI,EAAE,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC;SACrC,CAAC;QACF,OAAO,CAAC,QAAQ,IAAI,IAAA,4BAAU,EAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,IAAI,OAAO,KAAK,KAAK,WAAW,CAAC;QACjG,IAAA,wBAAM,EACF,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAC9B;YACI,IAAI,EAAE,OAAO,CAAC,OAAO;YACrB,OAAO,EAAE,OAAO,CAAC,uBAAuB,IAAI,2BAA2B;SAC1E,CACJ;KACJ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;AACvB,CAAC;AAnBD,8BAmBC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const constants_1 = require("@nestjs/swagger/dist/constants");
|
|
5
|
+
const EnumField_1 = require("./EnumField");
|
|
6
|
+
const BaseEnum_1 = require("../../../domain/base/BaseEnum");
|
|
7
|
+
const fixtureColors = ['RED', 'GREEN', 'BLUE'];
|
|
8
|
+
// Create a simple BaseEnum subclass for testing
|
|
9
|
+
class ColorEnum extends BaseEnum_1.default {
|
|
10
|
+
static getKeys() {
|
|
11
|
+
return fixtureColors;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
const decorators = [
|
|
15
|
+
(0, EnumField_1.EnumField)({ enum: ColorEnum }),
|
|
16
|
+
(0, EnumField_1.EnumField)({ enum: fixtureColors }),
|
|
17
|
+
(0, EnumField_1.EnumField)({
|
|
18
|
+
enum: Object.fromEntries(fixtureColors.map(colorString => [colorString, colorString])),
|
|
19
|
+
}),
|
|
20
|
+
];
|
|
21
|
+
(0, globals_1.describe)('EnumField decorator', () => {
|
|
22
|
+
globals_1.it.each(decorators)('sets correct api properties to a field', (decorator) => {
|
|
23
|
+
const targetPropertyKey = 'enumField';
|
|
24
|
+
const targetObject = {};
|
|
25
|
+
decorator(targetObject, targetPropertyKey);
|
|
26
|
+
const fieldApiPropertyMeta = Reflect.getMetadata(constants_1.DECORATORS.API_MODEL_PROPERTIES, targetObject, targetPropertyKey);
|
|
27
|
+
(0, globals_1.expect)(fieldApiPropertyMeta.enum)
|
|
28
|
+
.toEqual(fixtureColors);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
//# sourceMappingURL=EnumField.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EnumField.test.js","sourceRoot":"","sources":["../../../../src/infrastructure/decorators/fields/EnumField.test.ts"],"names":[],"mappings":";;AAAA,2CAAmD;AACnD,8DAA0D;AAC1D,2CAAwC;AACxC,4DAAqD;AAIrD,MAAM,aAAa,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;AAE/C,gDAAgD;AAChD,MAAM,SAAU,SAAQ,kBAAQ;IAC5B,MAAM,CAAC,OAAO;QACV,OAAO,aAAa,CAAC;IACzB,CAAC;CACJ;AAED,MAAM,UAAU,GAAG;IACf,IAAA,qBAAS,EAAC,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;IAC9B,IAAA,qBAAS,EAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC;IAClC,IAAA,qBAAS,EAAC;QACN,IAAI,EAAE,MAAM,CAAC,WAAW,CACpB,aAAa,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAC/D;KACJ,CAAC;CACL,CAAC;AAEF,IAAA,kBAAQ,EAAC,qBAAqB,EAAE,GAAG,EAAE;IACjC,YAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,wCAAwC,EAAE,CAAC,SAAS,EAAE,EAAE;QACxE,MAAM,iBAAiB,GAAG,WAAW,CAAC;QACtC,MAAM,YAAY,GAAG,EAAE,CAAC;QAExB,SAAS,CAAC,YAAY,EAAE,iBAAiB,CAAC,CAAC;QAE3C,MAAM,oBAAoB,GAAG,OAAO,CAAC,WAAW,CAC5C,sBAAU,CAAC,oBAAoB,EAC/B,YAAY,EACZ,iBAAiB,CACpB,CAAC;QAEF,IAAA,gBAAM,EAAC,oBAAoB,CAAC,IAAI,CAAC;aAC5B,OAAO,CAAC,aAAa,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"JSONBField.js","sourceRoot":"","sources":["../../../../src/infrastructure/decorators/fields/JSONBField.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAC/C,qDAA2C;AAC3C,2CAAyD;AAIzD,SAAgB,UAAU,CAAC,UAA8B,EAAE;IACvD,OAAO,IAAA,wBAAe,EAAC,GAAG;QACtB,IAAA,qBAAS,EAAC,OAAO,EAAE;YACf,aAAa,EAAE,YAAY;YAC3B,OAAO,EAAE,QAAQ;YACjB,MAAM,EAAE,OAAO;
|
|
1
|
+
{"version":3,"file":"JSONBField.js","sourceRoot":"","sources":["../../../../src/infrastructure/decorators/fields/JSONBField.ts"],"names":[],"mappings":";;;AAAA,2CAA+C;AAC/C,qDAA2C;AAC3C,2CAAyD;AAIzD,SAAgB,UAAU,CAAC,UAA8B,EAAE;IACvD,OAAO,IAAA,wBAAe,EAAC,GAAG;QACtB,IAAA,qBAAS,EAAC,OAAO,EAAE;YACf,aAAa,EAAE,YAAY;YAC3B,OAAO,EAAE,QAAQ;YACjB,MAAM,EAAE,OAAO;YACf,WAAW,EAAE,QAAQ;SACxB,CAAC;QACF,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAA,4BAAU,GAAE;KACpC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;AACvB,CAAC;AAVD,gCAUC"}
|
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@steroidsjs/nest",
|
|
3
|
-
"version": "3.2.
|
|
3
|
+
"version": "3.2.7",
|
|
4
4
|
"scripts": {
|
|
5
5
|
"script": "nps",
|
|
6
6
|
"watch": "nps watch",
|
|
7
7
|
"build": "nps build",
|
|
8
|
-
"test": "nps test"
|
|
8
|
+
"test": "nps test",
|
|
9
|
+
"test-unit": "jest --config jest.unit.config.ts"
|
|
9
10
|
},
|
|
10
11
|
"description": "",
|
|
11
12
|
"main": "index.js",
|