@archi-code/domain 1.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/aggregate/aggregate-root.d.ts +6 -0
- package/dist/cjs/aggregate/aggregate-root.js +18 -0
- package/dist/cjs/aggregate/aggregate-root.js.map +1 -0
- package/dist/cjs/aggregate/aggregate-types.d.ts +9 -0
- package/dist/cjs/aggregate/aggregate-types.js +27 -0
- package/dist/cjs/aggregate/aggregate-types.js.map +1 -0
- package/dist/cjs/builder/builder.d.ts +8 -0
- package/dist/cjs/builder/builder.js +28 -0
- package/dist/cjs/builder/builder.js.map +1 -0
- package/dist/cjs/event/event-base.d.ts +3 -0
- package/dist/cjs/event/event-base.js +7 -0
- package/dist/cjs/event/event-base.js.map +1 -0
- package/dist/cjs/exceptions/abstract.exception.d.ts +17 -0
- package/dist/cjs/exceptions/abstract.exception.js +46 -0
- package/dist/cjs/exceptions/abstract.exception.js.map +1 -0
- package/dist/cjs/exceptions/application/application.exception.d.ts +5 -0
- package/dist/cjs/exceptions/application/application.exception.js +12 -0
- package/dist/cjs/exceptions/application/application.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.js +12 -0
- package/dist/cjs/exceptions/domain/aggregate-not-found.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/domain.exception.d.ts +5 -0
- package/dist/cjs/exceptions/domain/domain.exception.js +12 -0
- package/dist/cjs/exceptions/domain/domain.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.js +16 -0
- package/dist/cjs/exceptions/domain/type-primitive.exception.js.map +1 -0
- package/dist/cjs/exceptions/domain/validation.exception.d.ts +4 -0
- package/dist/cjs/exceptions/domain/validation.exception.js +12 -0
- package/dist/cjs/exceptions/domain/validation.exception.js.map +1 -0
- package/dist/cjs/exceptions/exception-code.d.ts +10 -0
- package/dist/cjs/exceptions/exception-code.js +15 -0
- package/dist/cjs/exceptions/exception-code.js.map +1 -0
- package/dist/cjs/exceptions/index.d.ts +7 -0
- package/dist/cjs/exceptions/index.js +24 -0
- package/dist/cjs/exceptions/index.js.map +1 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.d.ts +5 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.js +12 -0
- package/dist/cjs/exceptions/infrastructure/infrastructure.exception.js.map +1 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.d.ts +4 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.js +12 -0
- package/dist/cjs/exceptions/infrastructure/internal-error.exception.js.map +1 -0
- package/dist/cjs/index.d.ts +10 -0
- package/dist/cjs/index.js +27 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/level/level.decorator.d.ts +4 -0
- package/dist/cjs/level/level.decorator.js +36 -0
- package/dist/cjs/level/level.decorator.js.map +1 -0
- package/dist/cjs/primitive/primitive-type.d.ts +14 -0
- package/dist/cjs/primitive/primitive-type.js +3 -0
- package/dist/cjs/primitive/primitive-type.js.map +1 -0
- package/dist/cjs/primitive/primitive-types.d.ts +19 -0
- package/dist/cjs/primitive/primitive-types.js +3 -0
- package/dist/cjs/primitive/primitive-types.js.map +1 -0
- package/dist/cjs/type/abstract-array-type.d.ts +14 -0
- package/dist/cjs/type/abstract-array-type.js +88 -0
- package/dist/cjs/type/abstract-array-type.js.map +1 -0
- package/dist/cjs/type/abstract-boolean-type.d.ts +4 -0
- package/dist/cjs/type/abstract-boolean-type.js +34 -0
- package/dist/cjs/type/abstract-boolean-type.js.map +1 -0
- package/dist/cjs/type/abstract-date-type.d.ts +5 -0
- package/dist/cjs/type/abstract-date-type.js +33 -0
- package/dist/cjs/type/abstract-date-type.js.map +1 -0
- package/dist/cjs/type/abstract-enum-type.d.ts +5 -0
- package/dist/cjs/type/abstract-enum-type.js +19 -0
- package/dist/cjs/type/abstract-enum-type.js.map +1 -0
- package/dist/cjs/type/abstract-json-type.d.ts +5 -0
- package/dist/cjs/type/abstract-json-type.js +30 -0
- package/dist/cjs/type/abstract-json-type.js.map +1 -0
- package/dist/cjs/type/abstract-number-type.d.ts +4 -0
- package/dist/cjs/type/abstract-number-type.js +31 -0
- package/dist/cjs/type/abstract-number-type.js.map +1 -0
- package/dist/cjs/type/abstract-string-type.d.ts +4 -0
- package/dist/cjs/type/abstract-string-type.js +33 -0
- package/dist/cjs/type/abstract-string-type.js.map +1 -0
- package/dist/cjs/type/abstract-type.d.ts +13 -0
- package/dist/cjs/type/abstract-type.js +46 -0
- package/dist/cjs/type/abstract-type.js.map +1 -0
- package/dist/cjs/type/abstract-uuid-type.d.ts +6 -0
- package/dist/cjs/type/abstract-uuid-type.js +37 -0
- package/dist/cjs/type/abstract-uuid-type.js.map +1 -0
- package/dist/cjs/type/index.d.ts +48 -0
- package/dist/cjs/type/index.js +138 -0
- package/dist/cjs/type/index.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-boolean.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-date.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-json.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-number.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.js +24 -0
- package/dist/cjs/validator/decorator/custom/can-be-string.js.map +1 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.d.ts +2 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.js +52 -0
- package/dist/cjs/validator/decorator/custom/json-schema-validator.js.map +1 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.d.ts +7 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.js +8 -0
- package/dist/cjs/validator/decorator/json-fotmat-validate.js.map +1 -0
- package/dist/cjs/validator/decorator/type-validator.d.ts +6 -0
- package/dist/cjs/validator/decorator/type-validator.js +81 -0
- package/dist/cjs/validator/decorator/type-validator.js.map +1 -0
- package/dist/cjs/validator/decorator/validation-storage.d.ts +14 -0
- package/dist/cjs/validator/decorator/validation-storage.js +56 -0
- package/dist/cjs/validator/decorator/validation-storage.js.map +1 -0
- package/dist/cjs/validator/decorator/validators-doc.d.ts +25 -0
- package/dist/cjs/validator/decorator/validators-doc.js +479 -0
- package/dist/cjs/validator/decorator/validators-doc.js.map +1 -0
- package/dist/cjs/validator/decorator/validators-map.d.ts +114 -0
- package/dist/cjs/validator/decorator/validators-map.js +113 -0
- package/dist/cjs/validator/decorator/validators-map.js.map +1 -0
- package/dist/cjs/validator/domain-validator/domain-validator.d.ts +7 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.d.ts +3 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.js +26 -0
- package/dist/cjs/validator/domain-validator/domain-validator.dto.js.map +1 -0
- package/dist/cjs/validator/domain-validator/domain-validator.js +59 -0
- package/dist/cjs/validator/domain-validator/domain-validator.js.map +1 -0
- package/dist/cjs/validator/index.d.ts +10 -0
- package/dist/cjs/validator/index.js +27 -0
- package/dist/cjs/validator/index.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.js +24 -0
- package/dist/cjs/validator/primitive-validator/boolean.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/date.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/date.validator.js +21 -0
- package/dist/cjs/validator/primitive-validator/date.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/json.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/json.validator.js +37 -0
- package/dist/cjs/validator/primitive-validator/json.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/number.validator.d.ts +3 -0
- package/dist/cjs/validator/primitive-validator/number.validator.js +21 -0
- package/dist/cjs/validator/primitive-validator/number.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/string.validator.d.ts +4 -0
- package/dist/cjs/validator/primitive-validator/string.validator.js +22 -0
- package/dist/cjs/validator/primitive-validator/string.validator.js.map +1 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.d.ts +5 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.js +3 -0
- package/dist/cjs/validator/primitive-validator/type-validator-interface.js.map +1 -0
- package/dist/esm/aggregate/aggregate-root.d.ts +6 -0
- package/dist/esm/aggregate/aggregate-root.js +14 -0
- package/dist/esm/aggregate/aggregate-root.js.map +1 -0
- package/dist/esm/aggregate/aggregate-types.d.ts +9 -0
- package/dist/esm/aggregate/aggregate-types.js +23 -0
- package/dist/esm/aggregate/aggregate-types.js.map +1 -0
- package/dist/esm/builder/builder.d.ts +8 -0
- package/dist/esm/builder/builder.js +25 -0
- package/dist/esm/builder/builder.js.map +1 -0
- package/dist/esm/event/event-base.d.ts +3 -0
- package/dist/esm/event/event-base.js +3 -0
- package/dist/esm/event/event-base.js.map +1 -0
- package/dist/esm/exceptions/abstract.exception.d.ts +17 -0
- package/dist/esm/exceptions/abstract.exception.js +42 -0
- package/dist/esm/exceptions/abstract.exception.js.map +1 -0
- package/dist/esm/exceptions/application/application.exception.d.ts +5 -0
- package/dist/esm/exceptions/application/application.exception.js +8 -0
- package/dist/esm/exceptions/application/application.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.js +8 -0
- package/dist/esm/exceptions/domain/aggregate-not-found.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/domain.exception.d.ts +5 -0
- package/dist/esm/exceptions/domain/domain.exception.js +8 -0
- package/dist/esm/exceptions/domain/domain.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.js +12 -0
- package/dist/esm/exceptions/domain/type-primitive.exception.js.map +1 -0
- package/dist/esm/exceptions/domain/validation.exception.d.ts +4 -0
- package/dist/esm/exceptions/domain/validation.exception.js +8 -0
- package/dist/esm/exceptions/domain/validation.exception.js.map +1 -0
- package/dist/esm/exceptions/exception-code.d.ts +10 -0
- package/dist/esm/exceptions/exception-code.js +12 -0
- package/dist/esm/exceptions/exception-code.js.map +1 -0
- package/dist/esm/exceptions/index.d.ts +7 -0
- package/dist/esm/exceptions/index.js +8 -0
- package/dist/esm/exceptions/index.js.map +1 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.d.ts +5 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.js +8 -0
- package/dist/esm/exceptions/infrastructure/infrastructure.exception.js.map +1 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.d.ts +4 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.js +8 -0
- package/dist/esm/exceptions/infrastructure/internal-error.exception.js.map +1 -0
- package/dist/esm/index.d.ts +10 -0
- package/dist/esm/index.js +11 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/level/level.decorator.d.ts +4 -0
- package/dist/esm/level/level.decorator.js +31 -0
- package/dist/esm/level/level.decorator.js.map +1 -0
- package/dist/esm/primitive/primitive-type.d.ts +14 -0
- package/dist/esm/primitive/primitive-type.js +2 -0
- package/dist/esm/primitive/primitive-type.js.map +1 -0
- package/dist/esm/primitive/primitive-types.d.ts +19 -0
- package/dist/esm/primitive/primitive-types.js +2 -0
- package/dist/esm/primitive/primitive-types.js.map +1 -0
- package/dist/esm/type/abstract-array-type.d.ts +14 -0
- package/dist/esm/type/abstract-array-type.js +85 -0
- package/dist/esm/type/abstract-array-type.js.map +1 -0
- package/dist/esm/type/abstract-boolean-type.d.ts +4 -0
- package/dist/esm/type/abstract-boolean-type.js +31 -0
- package/dist/esm/type/abstract-boolean-type.js.map +1 -0
- package/dist/esm/type/abstract-date-type.d.ts +5 -0
- package/dist/esm/type/abstract-date-type.js +30 -0
- package/dist/esm/type/abstract-date-type.js.map +1 -0
- package/dist/esm/type/abstract-enum-type.d.ts +5 -0
- package/dist/esm/type/abstract-enum-type.js +15 -0
- package/dist/esm/type/abstract-enum-type.js.map +1 -0
- package/dist/esm/type/abstract-json-type.d.ts +5 -0
- package/dist/esm/type/abstract-json-type.js +27 -0
- package/dist/esm/type/abstract-json-type.js.map +1 -0
- package/dist/esm/type/abstract-number-type.d.ts +4 -0
- package/dist/esm/type/abstract-number-type.js +28 -0
- package/dist/esm/type/abstract-number-type.js.map +1 -0
- package/dist/esm/type/abstract-string-type.d.ts +4 -0
- package/dist/esm/type/abstract-string-type.js +30 -0
- package/dist/esm/type/abstract-string-type.js.map +1 -0
- package/dist/esm/type/abstract-type.d.ts +13 -0
- package/dist/esm/type/abstract-type.js +42 -0
- package/dist/esm/type/abstract-type.js.map +1 -0
- package/dist/esm/type/abstract-uuid-type.d.ts +6 -0
- package/dist/esm/type/abstract-uuid-type.js +34 -0
- package/dist/esm/type/abstract-uuid-type.js.map +1 -0
- package/dist/esm/type/index.d.ts +48 -0
- package/dist/esm/type/index.js +124 -0
- package/dist/esm/type/index.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-boolean.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-date.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-date.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-date.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-json.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-json.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-json.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-number.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-number.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-number.js.map +1 -0
- package/dist/esm/validator/decorator/custom/can-be-string.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/can-be-string.js +21 -0
- package/dist/esm/validator/decorator/custom/can-be-string.js.map +1 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.d.ts +2 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.js +49 -0
- package/dist/esm/validator/decorator/custom/json-schema-validator.js.map +1 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.d.ts +7 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.js +5 -0
- package/dist/esm/validator/decorator/json-fotmat-validate.js.map +1 -0
- package/dist/esm/validator/decorator/type-validator.d.ts +6 -0
- package/dist/esm/validator/decorator/type-validator.js +77 -0
- package/dist/esm/validator/decorator/type-validator.js.map +1 -0
- package/dist/esm/validator/decorator/validation-storage.d.ts +14 -0
- package/dist/esm/validator/decorator/validation-storage.js +52 -0
- package/dist/esm/validator/decorator/validation-storage.js.map +1 -0
- package/dist/esm/validator/decorator/validators-doc.d.ts +25 -0
- package/dist/esm/validator/decorator/validators-doc.js +475 -0
- package/dist/esm/validator/decorator/validators-doc.js.map +1 -0
- package/dist/esm/validator/decorator/validators-map.d.ts +114 -0
- package/dist/esm/validator/decorator/validators-map.js +110 -0
- package/dist/esm/validator/decorator/validators-map.js.map +1 -0
- package/dist/esm/validator/domain-validator/domain-validator.d.ts +7 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.d.ts +3 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.js +22 -0
- package/dist/esm/validator/domain-validator/domain-validator.dto.js.map +1 -0
- package/dist/esm/validator/domain-validator/domain-validator.js +56 -0
- package/dist/esm/validator/domain-validator/domain-validator.js.map +1 -0
- package/dist/esm/validator/index.d.ts +10 -0
- package/dist/esm/validator/index.js +11 -0
- package/dist/esm/validator/index.js.map +1 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.js +20 -0
- package/dist/esm/validator/primitive-validator/boolean.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/date.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/date.validator.js +17 -0
- package/dist/esm/validator/primitive-validator/date.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/json.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/json.validator.js +33 -0
- package/dist/esm/validator/primitive-validator/json.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/number.validator.d.ts +3 -0
- package/dist/esm/validator/primitive-validator/number.validator.js +17 -0
- package/dist/esm/validator/primitive-validator/number.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/string.validator.d.ts +4 -0
- package/dist/esm/validator/primitive-validator/string.validator.js +18 -0
- package/dist/esm/validator/primitive-validator/string.validator.js.map +1 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.d.ts +5 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.js +2 -0
- package/dist/esm/validator/primitive-validator/type-validator-interface.js.map +1 -0
- package/dist/tsconfig.cjs.tsbuildinfo +1 -0
- package/dist/tsconfig.esm.tsbuildinfo +1 -0
- package/package.json +83 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { ExceptionCode } from './exception-code';
|
|
2
|
+
export class AbstractException extends Error {
|
|
3
|
+
constructor(message, exceptionCodes) {
|
|
4
|
+
super(message);
|
|
5
|
+
this.name = this.constructor.name;
|
|
6
|
+
this.exceptionCodes = exceptionCodes;
|
|
7
|
+
this.code =
|
|
8
|
+
exceptionCodes.length > 0
|
|
9
|
+
? exceptionCodes[exceptionCodes.length - 1]
|
|
10
|
+
: ExceptionCode.ErrorException;
|
|
11
|
+
this.timestamp = new Date();
|
|
12
|
+
Error.captureStackTrace(this, this.constructor);
|
|
13
|
+
}
|
|
14
|
+
get description() {
|
|
15
|
+
return this.exceptionCodes
|
|
16
|
+
.map((code) => {
|
|
17
|
+
const codeString = AbstractException.ExceptionCodeStrings[code] ?? this.name;
|
|
18
|
+
return `${codeString} (${code})`;
|
|
19
|
+
})
|
|
20
|
+
.join(', ');
|
|
21
|
+
}
|
|
22
|
+
print() {
|
|
23
|
+
return `[${this.description}]: ${this.message}, ${this.timestamp}`;
|
|
24
|
+
}
|
|
25
|
+
toJSON() {
|
|
26
|
+
return {
|
|
27
|
+
name: this.name,
|
|
28
|
+
message: this.message,
|
|
29
|
+
code: this.code,
|
|
30
|
+
description: this.description,
|
|
31
|
+
timestamp: this.timestamp.toISOString(),
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
AbstractException.ExceptionCodeStrings = Object.keys(ExceptionCode)
|
|
36
|
+
.filter((key) => isNaN(Number(key)))
|
|
37
|
+
.reduce((acc, key) => {
|
|
38
|
+
const value = ExceptionCode[key];
|
|
39
|
+
acc[value] = key.replace(/([A-Z])/g, ' $1').trim();
|
|
40
|
+
return acc;
|
|
41
|
+
}, {});
|
|
42
|
+
//# sourceMappingURL=abstract.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract.exception.js","sourceRoot":"","sources":["../../../src/exceptions/abstract.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,MAAM,OAAgB,iBAAkB,SAAQ,KAAK;IAKnD,YAAY,OAAe,EAAE,cAA0C;QACrE,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;QAClC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,IAAI;YACP,cAAc,CAAC,MAAM,GAAG,CAAC;gBACvB,CAAC,CAAC,cAAc,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;gBAC3C,CAAC,CAAC,aAAa,CAAC,cAAc,CAAC;QACnC,IAAI,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;QAC5B,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAClD,CAAC;IAaD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,cAAc;aACvB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACZ,MAAM,UAAU,GAAG,iBAAiB,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC;YAC7E,OAAO,GAAG,UAAU,KAAK,IAAI,GAAG,CAAC;QACnC,CAAC,CAAC;aACD,IAAI,CAAC,IAAI,CAAC,CAAC;IAChB,CAAC;IAED,KAAK;QACH,OAAO,IAAI,IAAI,CAAC,WAAW,MAAM,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,SAAS,EAAE,CAAC;IACrE,CAAC;IAED,MAAM;QAOJ,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE;SACxC,CAAC;IACJ,CAAC;;AAtCe,sCAAoB,GAAkC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC;KAC7F,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;KACnC,MAAM,CACL,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;IACX,MAAM,KAAK,GAAG,aAAa,CAAC,GAAiC,CAAC,CAAC;IAC/D,GAAG,CAAC,KAAsB,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;IACpE,OAAO,GAAG,CAAC;AACb,CAAC,EACD,EAAmC,CACpC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AbstractException } from '../abstract.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class ApplicationException extends AbstractException {
|
|
4
|
+
constructor(message, exceptionCodes = []) {
|
|
5
|
+
super(message, [ExceptionCode.ApplicationException, ...exceptionCodes]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=application.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"application.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/application/application.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,oBAAqB,SAAQ,iBAAiB;IACzD,YAAY,OAAe,EAAE,iBAA6C,EAAE;QAC1E,KAAK,CAAC,OAAO,EAAE,CAAC,aAAa,CAAC,oBAAoB,EAAE,GAAG,cAAc,CAAC,CAAC,CAAC;IAC1E,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DomainException } from './domain.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class AggregateNotFoundException extends DomainException {
|
|
4
|
+
constructor(entity, id) {
|
|
5
|
+
super(`${entity} with ID ${id} not found.`, [ExceptionCode.AggregateNotFound]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=aggregate-not-found.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aggregate-not-found.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/domain/aggregate-not-found.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,0BAA2B,SAAQ,eAAe;IAC7D,YAAY,MAAc,EAAE,EAAU;QACpC,KAAK,CAAC,GAAG,MAAM,YAAY,EAAE,aAAa,EAAE,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,CAAC;IACjF,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AbstractException } from '../abstract.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class DomainException extends AbstractException {
|
|
4
|
+
constructor(message, exceptionCodes = []) {
|
|
5
|
+
super(message, [ExceptionCode.DomainException, ...exceptionCodes]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=domain.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"domain.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/domain/domain.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,eAAgB,SAAQ,iBAAiB;IACpD,YAAY,OAAe,EAAE,iBAA6C,EAAE;QAC1E,KAAK,CAAC,OAAO,EAAE,CAAC,aAAa,CAAC,eAAe,EAAE,GAAG,cAAc,CAAC,CAAC,CAAC;IACrE,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { DomainException } from './domain.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
import { universalToString } from '@archi-code/common';
|
|
4
|
+
export class TypePrimitiveException extends DomainException {
|
|
5
|
+
constructor(expectedType, receivedValue, template = 'Expected a valid ') {
|
|
6
|
+
if (typeof receivedValue === 'string') {
|
|
7
|
+
receivedValue = `"${receivedValue}"`;
|
|
8
|
+
}
|
|
9
|
+
super(`Validation Error: ${template}${expectedType}, but received ${universalToString(receivedValue)}.`, [ExceptionCode.TypeFailed]);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=type-primitive.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"type-primitive.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/domain/type-primitive.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAEvD,MAAM,OAAO,sBAAuB,SAAQ,eAAe;IACzD,YAAY,YAAoB,EAAE,aAAkB,EAAE,QAAQ,GAAG,mBAAmB;QAClF,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE,CAAC;YACtC,aAAa,GAAG,IAAI,aAAa,GAAG,CAAC;QACvC,CAAC;QACD,KAAK,CACH,qBAAqB,QAAQ,GAAG,YAAY,kBAAkB,iBAAiB,CAAC,aAAa,CAAC,GAAG,EACjG,CAAC,aAAa,CAAC,UAAU,CAAC,CAC3B,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { DomainException } from './domain.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class ValidationException extends DomainException {
|
|
4
|
+
constructor(errors) {
|
|
5
|
+
super(`Validation failed, ${errors.join(', ')}`, [ExceptionCode.ValidationFailed]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=validation.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/domain/validation.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,mBAAoB,SAAQ,eAAe;IACtD,YAAY,MAAgB;QAC1B,KAAK,CAAC,sBAAsB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACrF,CAAC;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare enum ExceptionCode {
|
|
2
|
+
DomainException = "DOM000",
|
|
3
|
+
ValidationFailed = "DOM001",
|
|
4
|
+
AggregateNotFound = "DOM002",
|
|
5
|
+
TypeFailed = "DOM003",
|
|
6
|
+
ApplicationException = "APP000",
|
|
7
|
+
InfrastructureException = "INF000",
|
|
8
|
+
InternalError = "INF001",
|
|
9
|
+
ErrorException = "E000"
|
|
10
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export var ExceptionCode;
|
|
2
|
+
(function (ExceptionCode) {
|
|
3
|
+
ExceptionCode["DomainException"] = "DOM000";
|
|
4
|
+
ExceptionCode["ValidationFailed"] = "DOM001";
|
|
5
|
+
ExceptionCode["AggregateNotFound"] = "DOM002";
|
|
6
|
+
ExceptionCode["TypeFailed"] = "DOM003";
|
|
7
|
+
ExceptionCode["ApplicationException"] = "APP000";
|
|
8
|
+
ExceptionCode["InfrastructureException"] = "INF000";
|
|
9
|
+
ExceptionCode["InternalError"] = "INF001";
|
|
10
|
+
ExceptionCode["ErrorException"] = "E000";
|
|
11
|
+
})(ExceptionCode || (ExceptionCode = {}));
|
|
12
|
+
//# sourceMappingURL=exception-code.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"exception-code.js","sourceRoot":"","sources":["../../../src/exceptions/exception-code.ts"],"names":[],"mappings":"AACA,MAAM,CAAN,IAAY,aAgCX;AAhCD,WAAY,aAAa;IAEvB,2CAA0B,CAAA;IAC1B,4CAA2B,CAAA;IAC3B,6CAA4B,CAAA;IAC5B,sCAAqB,CAAA;IAOrB,gDAA+B,CAAA;IAO/B,mDAAkC,CAAA;IAClC,yCAAwB,CAAA;IASxB,wCAAuB,CAAA;AAGzB,CAAC,EAhCW,aAAa,KAAb,aAAa,QAgCxB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './abstract.exception';
|
|
2
|
+
export * from './domain/aggregate-not-found.exception';
|
|
3
|
+
export * from './application/application.exception';
|
|
4
|
+
export * from './infrastructure/infrastructure.exception';
|
|
5
|
+
export * from './infrastructure/internal-error.exception';
|
|
6
|
+
export * from './domain/validation.exception';
|
|
7
|
+
export * from './domain/domain.exception';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './abstract.exception';
|
|
2
|
+
export * from './domain/aggregate-not-found.exception';
|
|
3
|
+
export * from './application/application.exception';
|
|
4
|
+
export * from './infrastructure/infrastructure.exception';
|
|
5
|
+
export * from './infrastructure/internal-error.exception';
|
|
6
|
+
export * from './domain/validation.exception';
|
|
7
|
+
export * from './domain/domain.exception';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/exceptions/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,wCAAwC,CAAC;AACvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+BAA+B,CAAC;AAC9C,cAAc,2BAA2B,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { AbstractException } from '../abstract.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class InfrastructureException extends AbstractException {
|
|
4
|
+
constructor(message, exceptionCodess = []) {
|
|
5
|
+
super(message, [ExceptionCode.InfrastructureException, ...exceptionCodess]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=infrastructure.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"infrastructure.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/infrastructure/infrastructure.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,uBAAwB,SAAQ,iBAAiB;IAC5D,YAAY,OAAe,EAAE,kBAA8C,EAAE;QAC3E,KAAK,CAAC,OAAO,EAAE,CAAC,aAAa,CAAC,uBAAuB,EAAE,GAAG,eAAe,CAAC,CAAC,CAAC;IAC9E,CAAC;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { InfrastructureException } from './infrastructure.exception';
|
|
2
|
+
import { ExceptionCode } from '../exception-code';
|
|
3
|
+
export class InternalErrorException extends InfrastructureException {
|
|
4
|
+
constructor(message) {
|
|
5
|
+
super(`Failed, internal error: ${message}`, [ExceptionCode.InternalError]);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=internal-error.exception.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"internal-error.exception.js","sourceRoot":"","sources":["../../../../src/exceptions/infrastructure/internal-error.exception.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,MAAM,OAAO,sBAAuB,SAAQ,uBAAuB;IACjE,YAAY,OAAe;QACzB,KAAK,CAAC,2BAA2B,OAAO,EAAE,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC;IAC7E,CAAC;CACF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './event/event-base';
|
|
2
|
+
export * from './aggregate/aggregate-root';
|
|
3
|
+
export * from './aggregate/aggregate-types';
|
|
4
|
+
export * from './type';
|
|
5
|
+
export * from './validator';
|
|
6
|
+
export * from './primitive/primitive-types';
|
|
7
|
+
export * from './exceptions';
|
|
8
|
+
export * from './level/level.decorator';
|
|
9
|
+
export * from './primitive/primitive-type';
|
|
10
|
+
export * from './builder/builder';
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export * from './event/event-base';
|
|
2
|
+
export * from './aggregate/aggregate-root';
|
|
3
|
+
export * from './aggregate/aggregate-types';
|
|
4
|
+
export * from './type';
|
|
5
|
+
export * from './validator';
|
|
6
|
+
export * from './primitive/primitive-types';
|
|
7
|
+
export * from './exceptions';
|
|
8
|
+
export * from './level/level.decorator';
|
|
9
|
+
export * from './primitive/primitive-type';
|
|
10
|
+
export * from './builder/builder';
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,6BAA6B,CAAC;AAC5C,cAAc,QAAQ,CAAC;AACvB,cAAc,aAAa,CAAC;AAC5B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,cAAc,CAAC;AAC7B,cAAc,yBAAyB,CAAC;AACxC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import 'reflect-metadata';
|
|
2
|
+
const LEVEL = 'level';
|
|
3
|
+
export function Level(level) {
|
|
4
|
+
return (target) => {
|
|
5
|
+
Reflect.defineMetadata(LEVEL, normalizeLevel(level), target);
|
|
6
|
+
if (level > 1) {
|
|
7
|
+
const staticEmpty = target['empty'];
|
|
8
|
+
if (typeof staticEmpty !== 'function') {
|
|
9
|
+
throw new Error(`Class ${target.name} with level ${level} must implement a static 'empty()' method as a function.`);
|
|
10
|
+
}
|
|
11
|
+
const instance = staticEmpty();
|
|
12
|
+
if (!(instance instanceof target)) {
|
|
13
|
+
throw new Error(`The static 'empty()' method of class ${target.name} must return a valid instance of the class.`);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export function getLevel(target) {
|
|
19
|
+
return Reflect.getMetadata(LEVEL, target) ?? 1;
|
|
20
|
+
}
|
|
21
|
+
export function normalizeLevel(level) {
|
|
22
|
+
if (typeof level === 'string' && !isNaN(Number(level))) {
|
|
23
|
+
level = Number(level);
|
|
24
|
+
}
|
|
25
|
+
if (typeof level === 'number' && isFinite(level)) {
|
|
26
|
+
const normalizedLevel = Math.floor(level);
|
|
27
|
+
return normalizedLevel >= 1 ? normalizedLevel : 1;
|
|
28
|
+
}
|
|
29
|
+
return 1;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=level.decorator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"level.decorator.js","sourceRoot":"","sources":["../../../src/level/level.decorator.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAE1B,MAAM,KAAK,GAAG,OAAO,CAAC;AAEtB,MAAM,UAAU,KAAK,CAAC,KAAa;IACjC,OAAO,CAAC,MAAgB,EAAE,EAAE;QAC1B,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,cAAc,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAC;QAE7D,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACd,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;YAGpC,IAAI,OAAO,WAAW,KAAK,UAAU,EAAE,CAAC;gBACtC,MAAM,IAAI,KAAK,CACb,SAAS,MAAM,CAAC,IAAI,eAAe,KAAK,0DAA0D,CACnG,CAAC;YACJ,CAAC;YAGD,MAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;YAC/B,IAAI,CAAC,CAAC,QAAQ,YAAY,MAAM,CAAC,EAAE,CAAC;gBAClC,MAAM,IAAI,KAAK,CACb,wCAAwC,MAAM,CAAC,IAAI,6CAA6C,CACjG,CAAC;YACJ,CAAC;QACH,CAAC;IACH,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,MAAW;IAClC,OAAO,OAAO,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;AACjD,CAAC;AAYD,MAAM,UAAU,cAAc,CAAC,KAAU;IAEvC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;QACvD,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAGD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACjD,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC1C,OAAO,eAAe,IAAI,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;IACpD,CAAC;IAGD,OAAO,CAAC,CAAC;AACX,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AbstractJsonType } from '../type/abstract-json-type';
|
|
2
|
+
import { AbstractArrayType, AbstractBooleanType, AbstractDateType, AbstractEnumType, AbstractNumberType, AbstractStringType, AbstractUuidType, IdType } from '../type';
|
|
3
|
+
type Nullable<T> = T | null;
|
|
4
|
+
type PrimitiveEnum<T> = T extends string ? string : T extends number ? number : never;
|
|
5
|
+
type BooleanType<T> = T extends AbstractBooleanType<undefined> ? boolean : T extends AbstractBooleanType<null> ? Nullable<boolean> : never;
|
|
6
|
+
type DateType<T> = T extends AbstractDateType<undefined> ? Date : T extends AbstractDateType<null> ? Nullable<Date> : never;
|
|
7
|
+
type NumberType<T> = T extends AbstractNumberType<undefined> ? number : T extends AbstractNumberType<null> ? Nullable<number> : never;
|
|
8
|
+
type StringType<T> = T extends AbstractStringType<undefined> ? string : T extends AbstractStringType<null> ? Nullable<string> : never;
|
|
9
|
+
type UuidType<T> = T extends AbstractUuidType<undefined> ? string : T extends AbstractUuidType<null> ? Nullable<string> : never;
|
|
10
|
+
type EnumType<T> = T extends AbstractEnumType<infer U, undefined> ? PrimitiveEnum<U> : T extends AbstractEnumType<infer U, null> ? Nullable<PrimitiveEnum<U>> : never;
|
|
11
|
+
type JsonType<T> = T extends AbstractJsonType<infer U> ? U : T extends AbstractJsonType<infer U, null> ? Nullable<U> : never;
|
|
12
|
+
type IdTypePrimitive<T> = T extends IdType ? string : never;
|
|
13
|
+
export type PrimitiveType<T> = T extends (infer U)[] ? PrimitiveType<U>[] : T extends AbstractArrayType<infer A, undefined> ? PrimitiveType<A>[] : T extends AbstractArrayType<infer A, null> ? Nullable<PrimitiveType<A>[]> : BooleanType<T> | DateType<T> | NumberType<T> | StringType<T> | UuidType<T> | EnumType<T> | JsonType<T> | IdTypePrimitive<T> | never;
|
|
14
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"primitive-type.js","sourceRoot":"","sources":["../../../src/primitive/primitive-type.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { PrimitiveType } from './primitive-type';
|
|
2
|
+
export type Methods<T> = {
|
|
3
|
+
[P in keyof T]: T[P] extends Function ? P : never;
|
|
4
|
+
}[keyof T];
|
|
5
|
+
export type MethodsAndProperties<T> = {
|
|
6
|
+
[key in keyof T]: T[key];
|
|
7
|
+
};
|
|
8
|
+
export type Properties<T> = Omit<MethodsAndProperties<T>, Methods<T>>;
|
|
9
|
+
export type MutablePropertiesData<T> = Mutable<Required<Properties<T>>>;
|
|
10
|
+
export type PropertiesData<T> = Required<Properties<T>>;
|
|
11
|
+
type RemoveUnderscore<S extends string> = S extends `_${infer R}` ? R : S;
|
|
12
|
+
type Mutable<T> = {
|
|
13
|
+
-readonly [P in keyof T]: T[P];
|
|
14
|
+
};
|
|
15
|
+
export type PrimitiveTypes<T> = {
|
|
16
|
+
[key in keyof Mutable<Properties<T>> as RemoveUnderscore<string & key>]: PrimitiveType<T[key]>;
|
|
17
|
+
};
|
|
18
|
+
export type DataTypes<T> = Partial<PrimitiveTypes<T>>;
|
|
19
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"primitive-types.js","sourceRoot":"","sources":["../../../src/primitive/primitive-types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AbstractType } from './abstract-type';
|
|
2
|
+
import { PrimitiveType } from '../primitive/primitive-type';
|
|
3
|
+
export declare abstract class AbstractArrayType<T extends AbstractType<any>, R extends null | undefined = undefined> extends AbstractType<PrimitiveType<T>[], R> {
|
|
4
|
+
abstract getItemClass(value: PrimitiveType<T>): T;
|
|
5
|
+
protected filter(value: any): any;
|
|
6
|
+
isValid(): boolean;
|
|
7
|
+
validatorMessageStr(separator?: string, customReplacement?: string): string;
|
|
8
|
+
get toString(): string;
|
|
9
|
+
get items(): T[] | null;
|
|
10
|
+
addItem(value: PrimitiveType<T>): void;
|
|
11
|
+
hasItem(value: PrimitiveType<T>): boolean;
|
|
12
|
+
removeItem(value: PrimitiveType<T>): void;
|
|
13
|
+
setItem(value: PrimitiveType<T>): void;
|
|
14
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { AbstractType } from './abstract-type';
|
|
8
|
+
import { AddValidate } from '../validator/decorator/type-validator';
|
|
9
|
+
import { DomainException } from '../exceptions';
|
|
10
|
+
let AbstractArrayType = class AbstractArrayType extends AbstractType {
|
|
11
|
+
filter(value) {
|
|
12
|
+
if (value === null) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
if (!Array.isArray(value)) {
|
|
16
|
+
throw new DomainException(`value ${value} is not a Array.`);
|
|
17
|
+
}
|
|
18
|
+
return value.map((item) => this.getItemClass(item)).map((item) => item.value);
|
|
19
|
+
}
|
|
20
|
+
isValid() {
|
|
21
|
+
if (this.isNull) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
return (super.isValid() &&
|
|
25
|
+
Array.isArray(this.value) &&
|
|
26
|
+
this.value.every((item) => this.getItemClass(item).isValid()));
|
|
27
|
+
}
|
|
28
|
+
validatorMessageStr(separator = ',', customReplacement = '') {
|
|
29
|
+
if (this.isNull) {
|
|
30
|
+
return 'Value must be an array';
|
|
31
|
+
}
|
|
32
|
+
let str = super.validatorMessageStr(separator, customReplacement);
|
|
33
|
+
const strItems = this.value?.map((item, index) => {
|
|
34
|
+
const txtItemMsg = this.getItemClass(item).validatorMessageStr(separator, customReplacement);
|
|
35
|
+
return txtItemMsg === '' ? '' : `Item ${index + 1}: ${txtItemMsg}`;
|
|
36
|
+
});
|
|
37
|
+
const filters = strItems?.filter((item) => item !== '');
|
|
38
|
+
if (filters && filters.length > 0) {
|
|
39
|
+
if (str === '') {
|
|
40
|
+
str = filters.join(`${separator} `);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
str += separator + filters.join(`${separator} `);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return str;
|
|
47
|
+
}
|
|
48
|
+
get toString() {
|
|
49
|
+
return !this.value ? '' : this.value.map((item) => this.getItemClass(item).toString).join(', ');
|
|
50
|
+
}
|
|
51
|
+
get items() {
|
|
52
|
+
if (this.value === null) {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
return this.value?.map((item) => this.getItemClass(item));
|
|
56
|
+
}
|
|
57
|
+
addItem(value) {
|
|
58
|
+
if (this.value === null) {
|
|
59
|
+
this._value = [];
|
|
60
|
+
}
|
|
61
|
+
this.value?.push(this.getItemClass(value).value);
|
|
62
|
+
}
|
|
63
|
+
hasItem(value) {
|
|
64
|
+
const item = this.getItemClass(value);
|
|
65
|
+
return this.value?.some((itemValue) => itemValue === item.value) ?? false;
|
|
66
|
+
}
|
|
67
|
+
removeItem(value) {
|
|
68
|
+
if (this.value === null) {
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
const item = this.getItemClass(value);
|
|
72
|
+
this._value = this.value?.filter((itemValue) => itemValue !== item.value) ?? [];
|
|
73
|
+
}
|
|
74
|
+
setItem(value) {
|
|
75
|
+
if (this.hasItem(value)) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
this.addItem(value);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
AbstractArrayType = __decorate([
|
|
82
|
+
AddValidate([{ validator: 'IsArray' }])
|
|
83
|
+
], AbstractArrayType);
|
|
84
|
+
export { AbstractArrayType };
|
|
85
|
+
//# sourceMappingURL=abstract-array-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-array-type.js","sourceRoot":"","sources":["../../../src/type/abstract-array-type.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { AbstractType } from './abstract-type';
|
|
8
|
+
import { AddValidate } from '../validator/decorator/type-validator';
|
|
9
|
+
import { CanBeBooleanValidator } from '../validator/decorator/custom/can-be-boolean';
|
|
10
|
+
import { BooleanValidator } from '../validator';
|
|
11
|
+
import { TypePrimitiveException } from '../exceptions/domain/type-primitive.exception';
|
|
12
|
+
let AbstractBooleanType = class AbstractBooleanType extends AbstractType {
|
|
13
|
+
filter(value) {
|
|
14
|
+
if (value === null) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
if (!BooleanValidator.canBeBoolean(value)) {
|
|
18
|
+
throw new TypePrimitiveException('Boolean', value);
|
|
19
|
+
}
|
|
20
|
+
if (typeof value === 'string') {
|
|
21
|
+
value = value.toLowerCase().trim();
|
|
22
|
+
return value === 'true' || value === '1';
|
|
23
|
+
}
|
|
24
|
+
return !!value;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
AbstractBooleanType = __decorate([
|
|
28
|
+
AddValidate([{ validator: CanBeBooleanValidator }])
|
|
29
|
+
], AbstractBooleanType);
|
|
30
|
+
export { AbstractBooleanType };
|
|
31
|
+
//# sourceMappingURL=abstract-boolean-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-boolean-type.js","sourceRoot":"","sources":["../../../src/type/abstract-boolean-type.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,uCAAuC,CAAC;AACpE,OAAO,EAAE,qBAAqB,EAAE,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AAGhF,IAAM,mBAAmB,GAAzB,MAAM,mBAA4D,SAAQ,YAGhF;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1C,MAAM,IAAI,sBAAsB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACrD,CAAC;QACD,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC9B,KAAK,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;YACnC,OAAO,KAAK,KAAK,MAAM,IAAI,KAAK,KAAK,GAAG,CAAC;QAC3C,CAAC;QACD,OAAO,CAAC,CAAC,KAAK,CAAC;IACjB,CAAC;CACF,CAAA;AAjBY,mBAAmB;IAD/B,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,qBAAqB,EAAE,CAAC,CAAC;GACvC,mBAAmB,CAiB/B"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
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;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
import { AbstractType } from './abstract-type';
|
|
8
|
+
import { AddValidate } from '../validator/decorator/type-validator';
|
|
9
|
+
import { CanBeDate } from '../validator/decorator/custom/can-be-date';
|
|
10
|
+
import { DateValidator } from '../validator';
|
|
11
|
+
import { TypePrimitiveException } from '../exceptions/domain/type-primitive.exception';
|
|
12
|
+
let AbstractDateType = class AbstractDateType extends AbstractType {
|
|
13
|
+
filter(value) {
|
|
14
|
+
if (value === null) {
|
|
15
|
+
return null;
|
|
16
|
+
}
|
|
17
|
+
if (!DateValidator.canBeDate(value)) {
|
|
18
|
+
throw new TypePrimitiveException('Date', value);
|
|
19
|
+
}
|
|
20
|
+
return typeof value === 'string' ? new Date(value) : value;
|
|
21
|
+
}
|
|
22
|
+
get toString() {
|
|
23
|
+
return this.value instanceof Date ? this.value.toISOString() : super.toString;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
AbstractDateType = __decorate([
|
|
27
|
+
AddValidate([{ validator: CanBeDate }])
|
|
28
|
+
], AbstractDateType);
|
|
29
|
+
export { AbstractDateType };
|
|
30
|
+
//# sourceMappingURL=abstract-date-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-date-type.js","sourceRoot":"","sources":["../../../src/type/abstract-date-type.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,uCAAuC,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,2CAA2C,CAAC;AACtE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AAGhF,IAAM,gBAAgB,GAAtB,MAAM,gBAAyD,SAAQ,YAG7E;IACW,MAAM,CAAC,KAAU;QACzB,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC;YACpC,MAAM,IAAI,sBAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAClD,CAAC;QACD,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC7D,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,KAAK,YAAY,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;IAChF,CAAC;CACF,CAAA;AAjBY,gBAAgB;IAD5B,WAAW,CAAC,CAAC,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;GAC3B,gBAAgB,CAiB5B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { AbstractType } from './abstract-type';
|
|
2
|
+
import { TypePrimitiveException } from '../exceptions/domain/type-primitive.exception';
|
|
3
|
+
export class AbstractEnumType extends AbstractType {
|
|
4
|
+
filter(value) {
|
|
5
|
+
if (value === null) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
const enumValues = Object.values(this.getEnum());
|
|
9
|
+
if (!enumValues.includes(value)) {
|
|
10
|
+
throw new TypePrimitiveException(`Expected one of [${enumValues.join(', ')}]`, value, '');
|
|
11
|
+
}
|
|
12
|
+
return value;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=abstract-enum-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"abstract-enum-type.js","sourceRoot":"","sources":["../../../src/type/abstract-enum-type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AAEvF,MAAM,OAAgB,gBAGpB,SAAQ,YAAkB;IAGhB,MAAM,CAAC,KAAe;QAC9B,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,sBAAsB,CAAC,oBAAoB,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QAC5F,CAAC;QAED,OAAO,KAAU,CAAC;IACpB,CAAC;CACF"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { AbstractType } from './abstract-type';
|
|
2
|
+
export type JsonTypeValue = Record<string, any>;
|
|
3
|
+
export declare class AbstractJsonType<T extends JsonTypeValue, R extends null | undefined = undefined> extends AbstractType<T, R> {
|
|
4
|
+
protected filter(value: any): any;
|
|
5
|
+
}
|