@codylabs/nestjs-common 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/decorators/index.d.ts +8 -0
- package/dist/decorators/index.js +25 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/decorators/is-boolean-field.decorator.d.ts +2 -0
- package/dist/decorators/is-boolean-field.decorator.js +25 -0
- package/dist/decorators/is-boolean-field.decorator.js.map +1 -0
- package/dist/decorators/is-date-field.decorator.d.ts +2 -0
- package/dist/decorators/is-date-field.decorator.js +37 -0
- package/dist/decorators/is-date-field.decorator.js.map +1 -0
- package/dist/decorators/is-enum-field.decorator.d.ts +2 -0
- package/dist/decorators/is-enum-field.decorator.js +23 -0
- package/dist/decorators/is-enum-field.decorator.js.map +1 -0
- package/dist/decorators/is-nested-field.decorator.d.ts +2 -0
- package/dist/decorators/is-nested-field.decorator.js +25 -0
- package/dist/decorators/is-nested-field.decorator.js.map +1 -0
- package/dist/decorators/is-number-field.decorator.d.ts +2 -0
- package/dist/decorators/is-number-field.decorator.js +51 -0
- package/dist/decorators/is-number-field.decorator.js.map +1 -0
- package/dist/decorators/is-string-field.decorator.d.ts +2 -0
- package/dist/decorators/is-string-field.decorator.js +74 -0
- package/dist/decorators/is-string-field.decorator.js.map +1 -0
- package/dist/decorators/min-max-length.decorator.d.ts +2 -0
- package/dist/decorators/min-max-length.decorator.js +26 -0
- package/dist/decorators/min-max-length.decorator.js.map +1 -0
- package/dist/decorators/transform.decorator.d.ts +4 -0
- package/dist/decorators/transform.decorator.js +25 -0
- package/dist/decorators/transform.decorator.js.map +1 -0
- package/dist/filters/http-exception.filter.d.ts +4 -0
- package/dist/filters/http-exception.filter.js +30 -0
- package/dist/filters/http-exception.filter.js.map +1 -0
- package/dist/filters/index.d.ts +2 -0
- package/dist/filters/index.js +19 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/filters/unprocessable-entity-exception.filter.d.ts +5 -0
- package/dist/filters/unprocessable-entity-exception.filter.js +43 -0
- package/dist/filters/unprocessable-entity-exception.filter.js.map +1 -0
- package/dist/guards/and.guard.d.ts +3 -0
- package/dist/guards/and.guard.js +43 -0
- package/dist/guards/and.guard.js.map +1 -0
- package/dist/guards/index.d.ts +3 -0
- package/dist/guards/index.js +20 -0
- package/dist/guards/index.js.map +1 -0
- package/dist/guards/or.guard.d.ts +3 -0
- package/dist/guards/or.guard.js +42 -0
- package/dist/guards/or.guard.js.map +1 -0
- package/dist/guards/sequential.guard.d.ts +3 -0
- package/dist/guards/sequential.guard.js +42 -0
- package/dist/guards/sequential.guard.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/interceptors/index.d.ts +1 -0
- package/dist/interceptors/index.js +18 -0
- package/dist/interceptors/index.js.map +1 -0
- package/dist/interceptors/update-selective-validation.interceptor.d.ts +7 -0
- package/dist/interceptors/update-selective-validation.interceptor.js +52 -0
- package/dist/interceptors/update-selective-validation.interceptor.js.map +1 -0
- package/dist/interfaces/guard.interface.d.ts +10 -0
- package/dist/interfaces/guard.interface.js +3 -0
- package/dist/interfaces/guard.interface.js.map +1 -0
- package/dist/interfaces/index.d.ts +2 -0
- package/dist/interfaces/index.js +19 -0
- package/dist/interfaces/index.js.map +1 -0
- package/dist/interfaces/validator.interface.d.ts +38 -0
- package/dist/interfaces/validator.interface.js +3 -0
- package/dist/interfaces/validator.interface.js.map +1 -0
- package/dist/pipes/abstract-validation.pipe.d.ts +11 -0
- package/dist/pipes/abstract-validation.pipe.js +42 -0
- package/dist/pipes/abstract-validation.pipe.js.map +1 -0
- package/dist/pipes/index.d.ts +3 -0
- package/dist/pipes/index.js +20 -0
- package/dist/pipes/index.js.map +1 -0
- package/dist/pipes/required.pipe.d.ts +4 -0
- package/dist/pipes/required.pipe.js +30 -0
- package/dist/pipes/required.pipe.js.map +1 -0
- package/dist/pipes/snowflake-id-param-validation.pipe.d.ts +8 -0
- package/dist/pipes/snowflake-id-param-validation.pipe.js +45 -0
- package/dist/pipes/snowflake-id-param-validation.pipe.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/utils/decorator.util.d.ts +1 -0
- package/dist/utils/decorator.util.js +36 -0
- package/dist/utils/decorator.util.js.map +1 -0
- package/dist/utils/guard.util.d.ts +6 -0
- package/dist/utils/guard.util.js +35 -0
- package/dist/utils/guard.util.js.map +1 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +19 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/validators/index.d.ts +5 -0
- package/dist/validators/index.js +22 -0
- package/dist/validators/index.js.map +1 -0
- package/dist/validators/is-after.validator.d.ts +2 -0
- package/dist/validators/is-after.validator.js +43 -0
- package/dist/validators/is-after.validator.js.map +1 -0
- package/dist/validators/is-date-format.validator.d.ts +3 -0
- package/dist/validators/is-date-format.validator.js +54 -0
- package/dist/validators/is-date-format.validator.js.map +1 -0
- package/dist/validators/is-equal-to.validator.d.ts +2 -0
- package/dist/validators/is-equal-to.validator.js +36 -0
- package/dist/validators/is-equal-to.validator.js.map +1 -0
- package/dist/validators/is-greater-than.validator.d.ts +2 -0
- package/dist/validators/is-greater-than.validator.js +36 -0
- package/dist/validators/is-greater-than.validator.js.map +1 -0
- package/dist/validators/is-lower-than.validator.d.ts +2 -0
- package/dist/validators/is-lower-than.validator.js +36 -0
- package/dist/validators/is-lower-than.validator.js.map +1 -0
- package/package.json +36 -0
@@ -0,0 +1 @@
|
|
1
|
+
export declare const applyCommonDecorators: (options: any, decoratorsToApply: any[]) => <TFunction extends Function, Y>(target: TFunction | object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
|
@@ -0,0 +1,36 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.applyCommonDecorators = void 0;
|
4
|
+
const common_1 = require("@nestjs/common");
|
5
|
+
const class_validator_1 = require("class-validator");
|
6
|
+
const decorators_1 = require("../decorators");
|
7
|
+
const applyCommonDecorators = (options, decoratorsToApply) => {
|
8
|
+
if (options.required) {
|
9
|
+
decoratorsToApply.push((0, class_validator_1.IsNotEmpty)({
|
10
|
+
each: options.each,
|
11
|
+
message: 'This field is required',
|
12
|
+
}));
|
13
|
+
if (options.each) {
|
14
|
+
decoratorsToApply.push((0, class_validator_1.ArrayNotEmpty)({
|
15
|
+
message: 'The array must not be empty',
|
16
|
+
}));
|
17
|
+
}
|
18
|
+
}
|
19
|
+
else {
|
20
|
+
decoratorsToApply.push((0, class_validator_1.IsOptional)({
|
21
|
+
message: 'This field is optional',
|
22
|
+
}));
|
23
|
+
}
|
24
|
+
if (options.each) {
|
25
|
+
decoratorsToApply.push((0, decorators_1.ToArray)(), (0, class_validator_1.IsArray)({
|
26
|
+
message: 'The value must be an array',
|
27
|
+
}), (0, class_validator_1.ArrayMinSize)(options.arrayMinSize, {
|
28
|
+
message: `The array must contain at least ${options.arrayMinSize} items`,
|
29
|
+
}), (0, class_validator_1.ArrayMaxSize)(options.arrayMaxSize, {
|
30
|
+
message: `The array must contain no more than ${options.arrayMaxSize} items`,
|
31
|
+
}));
|
32
|
+
}
|
33
|
+
return (0, common_1.applyDecorators)(...decoratorsToApply);
|
34
|
+
};
|
35
|
+
exports.applyCommonDecorators = applyCommonDecorators;
|
36
|
+
//# sourceMappingURL=decorator.util.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"decorator.util.js","sourceRoot":"","sources":["../../src/utils/decorator.util.ts"],"names":[],"mappings":";;;AAAA,2CAAiD;AACjD,qDAA6G;AAE7G,8CAAwC;AAEjC,MAAM,qBAAqB,GAAG,CAAC,OAAY,EAAE,iBAAwB,EAAE,EAAE;IAC9E,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACrB,iBAAiB,CAAC,IAAI,CACpB,IAAA,4BAAU,EAAC;YACT,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,wBAAwB;SAClC,CAAC,CACH,CAAC;QAEF,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,iBAAiB,CAAC,IAAI,CACpB,IAAA,+BAAa,EAAC;gBACZ,OAAO,EAAE,6BAA6B;aACvC,CAAC,CACH,CAAC;QACJ,CAAC;IACH,CAAC;SAAM,CAAC;QACN,iBAAiB,CAAC,IAAI,CACpB,IAAA,4BAAU,EAAC;YACT,OAAO,EAAE,wBAAwB;SAClC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,iBAAiB,CAAC,IAAI,CACpB,IAAA,oBAAO,GAAE,EACT,IAAA,yBAAO,EAAC;YACN,OAAO,EAAE,4BAA4B;SACtC,CAAC,EACF,IAAA,8BAAY,EAAC,OAAO,CAAC,YAAY,EAAE;YACjC,OAAO,EAAE,mCAAmC,OAAO,CAAC,YAAY,QAAQ;SACzE,CAAC,EACF,IAAA,8BAAY,EAAC,OAAO,CAAC,YAAY,EAAE;YACjC,OAAO,EAAE,uCAAuC,OAAO,CAAC,YAAY,QAAQ;SAC7E,CAAC,CACH,CAAC;IACJ,CAAC;IAED,OAAO,IAAA,wBAAe,EAAC,GAAG,iBAAiB,CAAC,CAAC;AAC/C,CAAC,CAAC;AAxCW,QAAA,qBAAqB,yBAwChC"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { CanActivate, ExecutionContext } from '@nestjs/common';
|
2
|
+
import { Observable, OperatorFunction } from 'rxjs';
|
3
|
+
export declare function deferGuard(guard: CanActivate, context: ExecutionContext): Observable<boolean>;
|
4
|
+
export declare function handleError(throwOnError?: boolean): OperatorFunction<boolean, boolean>;
|
5
|
+
export declare function guardIsPromise(guard: boolean | Promise<boolean> | Observable<boolean>): guard is Promise<boolean>;
|
6
|
+
export declare function guardIsObservable(guard: boolean | Observable<boolean>): guard is Observable<boolean>;
|
@@ -0,0 +1,35 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.deferGuard = deferGuard;
|
4
|
+
exports.handleError = handleError;
|
5
|
+
exports.guardIsPromise = guardIsPromise;
|
6
|
+
exports.guardIsObservable = guardIsObservable;
|
7
|
+
const rxjs_1 = require("rxjs");
|
8
|
+
const operators_1 = require("rxjs/operators");
|
9
|
+
function deferGuard(guard, context) {
|
10
|
+
return (0, rxjs_1.defer)(() => {
|
11
|
+
const guardVal = guard.canActivate(context);
|
12
|
+
if (guardIsPromise(guardVal)) {
|
13
|
+
return (0, rxjs_1.from)(guardVal);
|
14
|
+
}
|
15
|
+
if (guardIsObservable(guardVal)) {
|
16
|
+
return guardVal;
|
17
|
+
}
|
18
|
+
return (0, rxjs_1.of)(guardVal);
|
19
|
+
});
|
20
|
+
}
|
21
|
+
function handleError(throwOnError) {
|
22
|
+
return (0, operators_1.catchError)((err) => {
|
23
|
+
if (throwOnError) {
|
24
|
+
return (0, rxjs_1.throwError)(() => err);
|
25
|
+
}
|
26
|
+
return (0, rxjs_1.of)(false);
|
27
|
+
});
|
28
|
+
}
|
29
|
+
function guardIsPromise(guard) {
|
30
|
+
return !!guard.then;
|
31
|
+
}
|
32
|
+
function guardIsObservable(guard) {
|
33
|
+
return !!guard.pipe;
|
34
|
+
}
|
35
|
+
//# sourceMappingURL=guard.util.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"guard.util.js","sourceRoot":"","sources":["../../src/utils/guard.util.ts"],"names":[],"mappings":";;AAIA,gCAcC;AAED,kCAQC;AAED,wCAEC;AAED,8CAEC;AAnCD,+BAAiF;AACjF,8CAA4C;AAE5C,SAAgB,UAAU,CAAC,KAAkB,EAAE,OAAyB;IACtE,OAAO,IAAA,YAAK,EAAC,GAAG,EAAE;QAChB,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAE5C,IAAI,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC7B,OAAO,IAAA,WAAI,EAAC,QAAQ,CAAC,CAAC;QACxB,CAAC;QAED,IAAI,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC;YAChC,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,OAAO,IAAA,SAAE,EAAC,QAAQ,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,WAAW,CAAC,YAAsB;IAChD,OAAO,IAAA,sBAAU,EAAC,CAAC,GAAG,EAAE,EAAE;QACxB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,IAAA,iBAAU,EAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC;QAC/B,CAAC;QAED,OAAO,IAAA,SAAE,EAAC,KAAK,CAAC,CAAC;IACnB,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,cAAc,CAAC,KAAuD;IACpF,OAAO,CAAC,CAAE,KAA0B,CAAC,IAAI,CAAC;AAC5C,CAAC;AAED,SAAgB,iBAAiB,CAAC,KAAoC;IACpE,OAAO,CAAC,CAAE,KAA6B,CAAC,IAAI,CAAC;AAC/C,CAAC"}
|
@@ -0,0 +1,19 @@
|
|
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("./decorator.util"), exports);
|
18
|
+
__exportStar(require("./guard.util"), exports);
|
19
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,+CAA6B"}
|
@@ -0,0 +1,22 @@
|
|
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("./is-after.validator"), exports);
|
18
|
+
__exportStar(require("./is-date-format.validator"), exports);
|
19
|
+
__exportStar(require("./is-equal-to.validator"), exports);
|
20
|
+
__exportStar(require("./is-greater-than.validator"), exports);
|
21
|
+
__exportStar(require("./is-lower-than.validator"), exports);
|
22
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/validators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC;AACrC,6DAA2C;AAC3C,0DAAwC;AACxC,8DAA4C;AAC5C,4DAA0C"}
|
@@ -0,0 +1,43 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
9
|
+
exports.IsAfterField = void 0;
|
10
|
+
const class_validator_1 = require("class-validator");
|
11
|
+
let IsAfterConstraint = class IsAfterConstraint {
|
12
|
+
validate(value, args) {
|
13
|
+
const [comparisonDate] = args.constraints;
|
14
|
+
if (!value || !comparisonDate) {
|
15
|
+
return false;
|
16
|
+
}
|
17
|
+
const dateValue = new Date(value);
|
18
|
+
const dateComparison = new Date(comparisonDate);
|
19
|
+
if (Number.isNaN(dateValue.getTime()) || Number.isNaN(dateComparison.getTime())) {
|
20
|
+
return false;
|
21
|
+
}
|
22
|
+
return dateValue > dateComparison;
|
23
|
+
}
|
24
|
+
defaultMessage(args) {
|
25
|
+
const property = args.property;
|
26
|
+
const [relatedPropertyName] = args.constraints;
|
27
|
+
return `${property} should be after ${relatedPropertyName}`;
|
28
|
+
}
|
29
|
+
};
|
30
|
+
IsAfterConstraint = __decorate([
|
31
|
+
(0, class_validator_1.ValidatorConstraint)({ async: false })
|
32
|
+
], IsAfterConstraint);
|
33
|
+
const IsAfterField = (property, validationOptions) => (object, propertyName) => {
|
34
|
+
(0, class_validator_1.registerDecorator)({
|
35
|
+
target: object.constructor,
|
36
|
+
propertyName: propertyName,
|
37
|
+
options: validationOptions,
|
38
|
+
constraints: [property],
|
39
|
+
validator: IsAfterConstraint,
|
40
|
+
});
|
41
|
+
};
|
42
|
+
exports.IsAfterField = IsAfterField;
|
43
|
+
//# sourceMappingURL=is-after.validator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"is-after.validator.js","sourceRoot":"","sources":["../../src/validators/is-after.validator.ts"],"names":[],"mappings":";;;;;;;;;AAAA,qDAMyB;AAGzB,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IACrB,QAAQ,CAAC,KAAa,EAAE,IAAyB;QAC/C,MAAM,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC;QAE1C,IAAI,CAAC,KAAK,IAAI,CAAC,cAAc,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,MAAM,cAAc,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC;QAEhD,IAAI,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;YAChF,OAAO,KAAK,CAAC;QACf,CAAC;QAED,OAAO,SAAS,GAAG,cAAc,CAAC;IACpC,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAE5D,OAAO,GAAG,QAAQ,oBAAoB,mBAA6B,EAAE,CAAC;IACxE,CAAC;CACF,CAAA;AAxBK,iBAAiB;IADtB,IAAA,qCAAmB,EAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChC,iBAAiB,CAwBtB;AAEM,MAAM,YAAY,GACvB,CAAU,QAAiB,EAAE,iBAAqC,EAAqB,EAAE,CACzF,CAAC,MAA2B,EAAE,YAA6B,EAAE,EAAE;IAC7D,IAAA,mCAAiB,EAAC;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW;QAC1B,YAAY,EAAE,YAAsB;QACpC,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,CAAC,QAAQ,CAAC;QACvB,SAAS,EAAE,iBAAiB;KAC7B,CAAC,CAAC;AACL,CAAC,CAAC;AAVS,QAAA,YAAY,gBAUrB"}
|
@@ -0,0 +1,3 @@
|
|
1
|
+
import { ValidationOptions } from 'class-validator';
|
2
|
+
export type DateFormats = 'yyyy-MM-dd' | 'dd/MM/yyyy' | 'MM/dd/yyyy' | 'yyyy-MM-dd HH:mm:ss' | 'yyyy-MM-dd' | 'yyyy/MM/dd' | 'yyyy.MM.dd' | 'MM-dd-yyyy' | 'dd MMM yyyy' | 'yyyy-MM-ddTHH:mm:ss' | "yyyy-MM-dd'T'HH:mm:ss.SSSZ";
|
3
|
+
export declare const IsDateInFormat: (format: DateFormats, validationOptions?: ValidationOptions) => PropertyDecorator;
|
@@ -0,0 +1,54 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
9
|
+
exports.IsDateInFormat = void 0;
|
10
|
+
const class_validator_1 = require("class-validator");
|
11
|
+
const dateFormatRegex = {
|
12
|
+
'yyyy-MM-dd': /^\d{4}-\d{2}-\d{2}$/,
|
13
|
+
'dd/MM/yyyy': /^\d{2}\/\d{2}\/\d{4}$/,
|
14
|
+
'MM/dd/yyyy': /^\d{2}\/\d{2}\/\d{4}$/,
|
15
|
+
'yyyy-MM-dd HH:mm:ss': /^\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}$/,
|
16
|
+
'yyyy/MM/dd': /^\d{4}\/\d{2}\/\d{2}$/,
|
17
|
+
'yyyy.MM.dd': /^\d{4}\.\d{2}\.\d{2}$/,
|
18
|
+
'MM-dd-yyyy': /^\d{2}-\d{2}-\d{4}$/,
|
19
|
+
'dd MMM yyyy': /^\d{2} \w{3} \d{4}$/,
|
20
|
+
'yyyy-MM-ddTHH:mm:ss': /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}$/,
|
21
|
+
"yyyy-MM-dd'T'HH:mm:ss.SSSZ": /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}\.\d{3}Z$/,
|
22
|
+
};
|
23
|
+
let IsDateInFormatConstraint = class IsDateInFormatConstraint {
|
24
|
+
validate(value, args) {
|
25
|
+
const [format] = args.constraints;
|
26
|
+
if (!dateFormatRegex[format]) {
|
27
|
+
return false;
|
28
|
+
}
|
29
|
+
const regex = dateFormatRegex[format];
|
30
|
+
if (Array.isArray(value)) {
|
31
|
+
return value.some((v) => regex.test(v));
|
32
|
+
}
|
33
|
+
return regex.test(value);
|
34
|
+
}
|
35
|
+
defaultMessage(args) {
|
36
|
+
const property = args.property;
|
37
|
+
const [format] = args.constraints;
|
38
|
+
return `${property} should be in ${format} format`;
|
39
|
+
}
|
40
|
+
};
|
41
|
+
IsDateInFormatConstraint = __decorate([
|
42
|
+
(0, class_validator_1.ValidatorConstraint)({ async: false })
|
43
|
+
], IsDateInFormatConstraint);
|
44
|
+
const IsDateInFormat = (format, validationOptions) => (object, propertyName) => {
|
45
|
+
(0, class_validator_1.registerDecorator)({
|
46
|
+
target: object.constructor,
|
47
|
+
propertyName: propertyName,
|
48
|
+
options: validationOptions,
|
49
|
+
constraints: [format],
|
50
|
+
validator: IsDateInFormatConstraint,
|
51
|
+
});
|
52
|
+
};
|
53
|
+
exports.IsDateInFormat = IsDateInFormat;
|
54
|
+
//# sourceMappingURL=is-date-format.validator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"is-date-format.validator.js","sourceRoot":"","sources":["../../src/validators/is-date-format.validator.ts"],"names":[],"mappings":";;;;;;;;;AAAA,qDAMyB;AAezB,MAAM,eAAe,GAAgC;IACnD,YAAY,EAAE,qBAAqB;IACnC,YAAY,EAAE,uBAAuB;IACrC,YAAY,EAAE,uBAAuB;IACrC,qBAAqB,EAAE,uCAAuC;IAC9D,YAAY,EAAE,uBAAuB;IACrC,YAAY,EAAE,uBAAuB;IACrC,YAAY,EAAE,qBAAqB;IACnC,aAAa,EAAE,qBAAqB;IACpC,qBAAqB,EAAE,uCAAuC;IAC9D,4BAA4B,EAAE,+CAA+C;CAC9E,CAAC;AAGF,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAC5B,QAAQ,CAAC,KAAwB,EAAE,IAAyB;QAC1D,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,WAA4B,CAAC;QAEnD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC;QACf,CAAC;QAED,MAAM,KAAK,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;QAEtC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,CAAC;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAuB,CAAC;QAE9C,OAAO,GAAG,QAAQ,iBAAiB,MAAM,SAAS,CAAC;IACrD,CAAC;CACF,CAAA;AAvBK,wBAAwB;IAD7B,IAAA,qCAAmB,EAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChC,wBAAwB,CAuB7B;AAEM,MAAM,cAAc,GACzB,CAAC,MAAmB,EAAE,iBAAqC,EAAqB,EAAE,CAClF,CAAC,MAA2B,EAAE,YAA6B,EAAE,EAAE;IAC7D,IAAA,mCAAiB,EAAC;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW;QAC1B,YAAY,EAAE,YAAsB;QACpC,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,CAAC,MAAM,CAAC;QACrB,SAAS,EAAE,wBAAwB;KACpC,CAAC,CAAC;AACL,CAAC,CAAC;AAVS,QAAA,cAAc,kBAUvB"}
|
@@ -0,0 +1,36 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
9
|
+
exports.IsEqualToField = void 0;
|
10
|
+
const class_validator_1 = require("class-validator");
|
11
|
+
let IsEqualToConstraint = class IsEqualToConstraint {
|
12
|
+
validate(value, args) {
|
13
|
+
const [relatedPropertyName] = args.constraints;
|
14
|
+
const relatedValue = args.object[relatedPropertyName];
|
15
|
+
return value === relatedValue;
|
16
|
+
}
|
17
|
+
defaultMessage(args) {
|
18
|
+
const property = args.property;
|
19
|
+
const [relatedPropertyName] = args.constraints;
|
20
|
+
return `${property} should be equal to ${relatedPropertyName}`;
|
21
|
+
}
|
22
|
+
};
|
23
|
+
IsEqualToConstraint = __decorate([
|
24
|
+
(0, class_validator_1.ValidatorConstraint)({ async: false })
|
25
|
+
], IsEqualToConstraint);
|
26
|
+
const IsEqualToField = (property, validationOptions) => (object, propertyName) => {
|
27
|
+
(0, class_validator_1.registerDecorator)({
|
28
|
+
target: object.constructor,
|
29
|
+
propertyName: propertyName,
|
30
|
+
options: validationOptions,
|
31
|
+
constraints: [property],
|
32
|
+
validator: IsEqualToConstraint,
|
33
|
+
});
|
34
|
+
};
|
35
|
+
exports.IsEqualToField = IsEqualToField;
|
36
|
+
//# sourceMappingURL=is-equal-to.validator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"is-equal-to.validator.js","sourceRoot":"","sources":["../../src/validators/is-equal-to.validator.ts"],"names":[],"mappings":";;;;;;;;;AAAA,qDAMyB;AAGzB,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IACvB,QAAQ,CAAC,KAAa,EAAE,IAAyB;QAC/C,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAC5D,MAAM,YAAY,GAAI,IAAI,CAAC,MAA8B,CAAC,mBAA6B,CAG7E,CAAC;QAEX,OAAO,KAAK,KAAK,YAAY,CAAC;IAChC,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAE5D,OAAO,GAAG,QAAQ,uBAAuB,mBAA6B,EAAE,CAAC;IAC3E,CAAC;CACF,CAAA;AAjBK,mBAAmB;IADxB,IAAA,qCAAmB,EAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChC,mBAAmB,CAiBxB;AAEM,MAAM,cAAc,GACzB,CAAU,QAAiB,EAAE,iBAAqC,EAAqB,EAAE,CACzF,CAAC,MAA2B,EAAE,YAA6B,EAAE,EAAE;IAC7D,IAAA,mCAAiB,EAAC;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW;QAC1B,YAAY,EAAE,YAAsB;QACpC,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,CAAC,QAAQ,CAAC;QACvB,SAAS,EAAE,mBAAmB;KAC/B,CAAC,CAAC;AACL,CAAC,CAAC;AAVS,QAAA,cAAc,kBAUvB"}
|
@@ -0,0 +1,36 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
9
|
+
exports.IsGreaterThan = void 0;
|
10
|
+
const class_validator_1 = require("class-validator");
|
11
|
+
let IsGreaterThanConstraint = class IsGreaterThanConstraint {
|
12
|
+
validate(value, args) {
|
13
|
+
const [relatedPropertyName] = args.constraints;
|
14
|
+
const relatedValue = args.object[relatedPropertyName];
|
15
|
+
return Number.parseFloat(value) > Number.parseFloat(relatedValue);
|
16
|
+
}
|
17
|
+
defaultMessage(args) {
|
18
|
+
const property = args.property;
|
19
|
+
const [relatedPropertyName] = args.constraints;
|
20
|
+
return `${property} should be greater than ${relatedPropertyName}`;
|
21
|
+
}
|
22
|
+
};
|
23
|
+
IsGreaterThanConstraint = __decorate([
|
24
|
+
(0, class_validator_1.ValidatorConstraint)({ async: false })
|
25
|
+
], IsGreaterThanConstraint);
|
26
|
+
const IsGreaterThan = (property, validationOptions) => (object, propertyName) => {
|
27
|
+
(0, class_validator_1.registerDecorator)({
|
28
|
+
target: object.constructor,
|
29
|
+
propertyName: propertyName,
|
30
|
+
options: validationOptions,
|
31
|
+
constraints: [property],
|
32
|
+
validator: IsGreaterThanConstraint,
|
33
|
+
});
|
34
|
+
};
|
35
|
+
exports.IsGreaterThan = IsGreaterThan;
|
36
|
+
//# sourceMappingURL=is-greater-than.validator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"is-greater-than.validator.js","sourceRoot":"","sources":["../../src/validators/is-greater-than.validator.ts"],"names":[],"mappings":";;;;;;;;;AAAA,qDAMyB;AAGzB,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAC3B,QAAQ,CAAC,KAAa,EAAE,IAAyB;QAC/C,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAC5D,MAAM,YAAY,GAAI,IAAI,CAAC,MAAiC,CAAC,mBAA6B,CAAW,CAAC;QAEtG,OAAO,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IACpE,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAE5D,OAAO,GAAG,QAAQ,2BAA2B,mBAA6B,EAAE,CAAC;IAC/E,CAAC;CACF,CAAA;AAdK,uBAAuB;IAD5B,IAAA,qCAAmB,EAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChC,uBAAuB,CAc5B;AAEM,MAAM,aAAa,GACxB,CAAU,QAAiB,EAAE,iBAAqC,EAAqB,EAAE,CACzF,CAAC,MAA2B,EAAE,YAA6B,EAAE,EAAE;IAC7D,IAAA,mCAAiB,EAAC;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW;QAC1B,YAAY,EAAE,YAAsB;QACpC,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,CAAC,QAAQ,CAAC;QACvB,SAAS,EAAE,uBAAuB;KACnC,CAAC,CAAC;AACL,CAAC,CAAC;AAVS,QAAA,aAAa,iBAUtB"}
|
@@ -0,0 +1,36 @@
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
9
|
+
exports.IsLowerThan = void 0;
|
10
|
+
const class_validator_1 = require("class-validator");
|
11
|
+
let IsLowerThanConstraint = class IsLowerThanConstraint {
|
12
|
+
validate(value, args) {
|
13
|
+
const [relatedPropertyName] = args.constraints;
|
14
|
+
const relatedValue = args.object[relatedPropertyName];
|
15
|
+
return Number.parseFloat(value) < Number.parseFloat(relatedValue);
|
16
|
+
}
|
17
|
+
defaultMessage(args) {
|
18
|
+
const property = args.property;
|
19
|
+
const [relatedPropertyName] = args.constraints;
|
20
|
+
return `${property} should be lower than ${relatedPropertyName}`;
|
21
|
+
}
|
22
|
+
};
|
23
|
+
IsLowerThanConstraint = __decorate([
|
24
|
+
(0, class_validator_1.ValidatorConstraint)({ async: false })
|
25
|
+
], IsLowerThanConstraint);
|
26
|
+
const IsLowerThan = (property, validationOptions) => (object, propertyName) => {
|
27
|
+
(0, class_validator_1.registerDecorator)({
|
28
|
+
target: object.constructor,
|
29
|
+
propertyName: propertyName,
|
30
|
+
options: validationOptions,
|
31
|
+
constraints: [property],
|
32
|
+
validator: IsLowerThanConstraint,
|
33
|
+
});
|
34
|
+
};
|
35
|
+
exports.IsLowerThan = IsLowerThan;
|
36
|
+
//# sourceMappingURL=is-lower-than.validator.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"is-lower-than.validator.js","sourceRoot":"","sources":["../../src/validators/is-lower-than.validator.ts"],"names":[],"mappings":";;;;;;;;;AAAA,qDAMyB;AAGzB,IAAM,qBAAqB,GAA3B,MAAM,qBAAqB;IACzB,QAAQ,CAAC,KAAa,EAAE,IAAyB;QAC/C,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAC5D,MAAM,YAAY,GAAI,IAAI,CAAC,MAAiC,CAAC,mBAA6B,CAAW,CAAC;QAEtG,OAAO,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;IACpE,CAAC;IAED,cAAc,CAAC,IAAyB;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC/B,MAAM,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAwB,CAAC;QAE5D,OAAO,GAAG,QAAQ,yBAAyB,mBAA6B,EAAE,CAAC;IAC7E,CAAC;CACF,CAAA;AAdK,qBAAqB;IAD1B,IAAA,qCAAmB,EAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;GAChC,qBAAqB,CAc1B;AAEM,MAAM,WAAW,GACtB,CAAU,QAAiB,EAAE,iBAAqC,EAAqB,EAAE,CACzF,CAAC,MAA2B,EAAE,YAA6B,EAAE,EAAE;IAC7D,IAAA,mCAAiB,EAAC;QAChB,MAAM,EAAE,MAAM,CAAC,WAAW;QAC1B,YAAY,EAAE,YAAsB;QACpC,OAAO,EAAE,iBAAiB;QAC1B,WAAW,EAAE,CAAC,QAAQ,CAAC;QACvB,SAAS,EAAE,qBAAqB;KACjC,CAAC,CAAC;AACL,CAAC,CAAC;AAVS,QAAA,WAAW,eAUpB"}
|
package/package.json
ADDED
@@ -0,0 +1,36 @@
|
|
1
|
+
{
|
2
|
+
"name": "@codylabs/nestjs-common",
|
3
|
+
"version": "0.0.1",
|
4
|
+
"description": "Common utilities for NestJS applications",
|
5
|
+
"license": "MIT",
|
6
|
+
"author": "Cody Nguyen",
|
7
|
+
"main": "./dist/index.js",
|
8
|
+
"types": "./dist/index.d.ts",
|
9
|
+
"files": [
|
10
|
+
"dist/**"
|
11
|
+
],
|
12
|
+
"devDependencies": {
|
13
|
+
"@nestjs/platform-express": "^10.4.8",
|
14
|
+
"@types/express": "^5.0.0",
|
15
|
+
"class-transformer": "^0.5.1",
|
16
|
+
"class-validator": "^0.14.1",
|
17
|
+
"express": "^4.21.1",
|
18
|
+
"reflect-metadata": "^0.2.2",
|
19
|
+
"rxjs": "^7.8.1",
|
20
|
+
"@codylabs/helper-fns": "0.0.1",
|
21
|
+
"@codylabs/typescript-configs": "0.0.6"
|
22
|
+
},
|
23
|
+
"peerDependencies": {
|
24
|
+
"@nestjs/common": "^10.0.0",
|
25
|
+
"@nestjs/core": "^10.0.0"
|
26
|
+
},
|
27
|
+
"publishConfig": {
|
28
|
+
"access": "public"
|
29
|
+
},
|
30
|
+
"scripts": {
|
31
|
+
"build": "tsc -p tsconfig.build.json",
|
32
|
+
"clean": "rm -rf .turbo node_modules dist",
|
33
|
+
"test": "jest --passWithNoTests",
|
34
|
+
"test:watch": "jest --watch"
|
35
|
+
}
|
36
|
+
}
|