@decaf-ts/decorator-validation 1.7.4 → 1.7.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decorator-validation.cjs +145 -57
- package/dist/decorator-validation.esm.cjs +144 -58
- package/lib/esm/constants/index.js +3 -3
- package/lib/esm/index.d.ts +1 -1
- package/lib/esm/index.js +6 -6
- package/lib/esm/mcp/ModelContextProtocol.d.ts +31 -0
- package/lib/esm/mcp/ModelContextProtocol.js +66 -0
- package/lib/esm/mcp/mcp1.d.ts +0 -0
- package/lib/esm/mcp/mcp1.js +405 -0
- package/lib/esm/mcp/tools/createModel.tool.d.ts +0 -0
- package/lib/esm/mcp/tools/createModel.tool.js +67 -0
- package/lib/esm/mcp/tools/validateModel.tool.d.ts +0 -0
- package/lib/esm/mcp/tools/validateModel.tool.js +2 -0
- package/lib/esm/mcp/types.d.ts +3 -0
- package/lib/esm/mcp/types.js +2 -0
- package/lib/esm/model/Builder.d.ts +0 -0
- package/lib/esm/model/Builder.js +130 -0
- package/lib/esm/model/Model.d.ts +1 -0
- package/lib/esm/model/Model.js +21 -10
- package/lib/esm/model/construction.js +2 -2
- package/lib/esm/model/decorators.d.ts +10 -0
- package/lib/esm/model/decorators.js +16 -4
- package/lib/esm/model/index.js +9 -9
- package/lib/esm/model/utils.js +2 -2
- package/lib/esm/model/validation.js +15 -12
- package/lib/esm/utils/Decoration.js +2 -2
- package/lib/esm/utils/PathProxy.js +3 -3
- package/lib/esm/utils/constants.d.ts +1 -0
- package/lib/esm/utils/constants.js +2 -1
- package/lib/esm/utils/dates.js +3 -3
- package/lib/esm/utils/decorators.js +2 -2
- package/lib/esm/utils/index.js +11 -11
- package/lib/esm/utils/serialization.js +4 -4
- package/lib/esm/validation/Validation.d.ts +3 -0
- package/lib/esm/validation/Validation.js +14 -3
- package/lib/esm/validation/Validators/DateValidator.js +4 -4
- package/lib/esm/validation/Validators/DiffValidator.js +4 -4
- package/lib/esm/validation/Validators/EmailValidator.js +4 -4
- package/lib/esm/validation/Validators/EqualsValidator.js +4 -4
- package/lib/esm/validation/Validators/GreaterThanOrEqualValidator.js +5 -5
- package/lib/esm/validation/Validators/GreaterThanValidator.js +5 -5
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.d.ts +1 -1
- package/lib/esm/validation/Validators/LessThanOrEqualValidator.js +5 -5
- package/lib/esm/validation/Validators/LessThanValidator.d.ts +1 -1
- package/lib/esm/validation/Validators/LessThanValidator.js +5 -5
- package/lib/esm/validation/Validators/ListValidator.js +4 -4
- package/lib/esm/validation/Validators/MaxLengthValidator.js +4 -4
- package/lib/esm/validation/Validators/MaxValidator.js +4 -4
- package/lib/esm/validation/Validators/MinLengthValidator.js +4 -4
- package/lib/esm/validation/Validators/MinValidator.js +4 -4
- package/lib/esm/validation/Validators/PasswordValidator.js +4 -4
- package/lib/esm/validation/Validators/PatternValidator.js +4 -4
- package/lib/esm/validation/Validators/RequiredValidator.js +4 -4
- package/lib/esm/validation/Validators/StepValidator.js +4 -4
- package/lib/esm/validation/Validators/TypeValidator.js +6 -6
- package/lib/esm/validation/Validators/URLValidator.js +4 -4
- package/lib/esm/validation/Validators/Validator.js +3 -3
- package/lib/esm/validation/Validators/ValidatorRegistry.js +2 -2
- package/lib/esm/validation/Validators/constants.js +2 -2
- package/lib/esm/validation/Validators/decorators.js +3 -3
- package/lib/esm/validation/Validators/index.js +25 -25
- package/lib/esm/validation/Validators/utils.js +3 -3
- package/lib/esm/validation/decorators.d.ts +26 -3
- package/lib/esm/validation/decorators.js +107 -58
- package/lib/esm/validation/index.js +5 -5
- package/lib/esm/validation/types.d.ts +11 -5
- package/lib/esm/validation/types.js +2 -2
- package/lib/index.cjs +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/mcp/ModelContextProtocol.cjs +70 -0
- package/lib/mcp/ModelContextProtocol.d.ts +31 -0
- package/lib/mcp/mcp1.cjs +405 -0
- package/lib/mcp/mcp1.d.ts +0 -0
- package/lib/mcp/tools/createModel.tool.cjs +67 -0
- package/lib/mcp/tools/createModel.tool.d.ts +0 -0
- package/lib/mcp/tools/validateModel.tool.cjs +2 -0
- package/lib/mcp/tools/validateModel.tool.d.ts +0 -0
- package/lib/mcp/types.cjs +3 -0
- package/lib/mcp/types.d.ts +3 -0
- package/lib/model/Builder.cjs +130 -0
- package/lib/model/Builder.d.ts +0 -0
- package/lib/model/Model.cjs +14 -3
- package/lib/model/Model.d.ts +1 -0
- package/lib/model/decorators.cjs +14 -1
- package/lib/model/decorators.d.ts +10 -0
- package/lib/model/validation.cjs +6 -3
- package/lib/utils/constants.cjs +2 -1
- package/lib/utils/constants.d.ts +1 -0
- package/lib/validation/Validation.cjs +12 -1
- package/lib/validation/Validation.d.ts +3 -0
- package/lib/validation/Validators/LessThanOrEqualValidator.cjs +1 -1
- package/lib/validation/Validators/LessThanOrEqualValidator.d.ts +1 -1
- package/lib/validation/Validators/LessThanValidator.cjs +1 -1
- package/lib/validation/Validators/LessThanValidator.d.ts +1 -1
- package/lib/validation/decorators.cjs +102 -52
- package/lib/validation/decorators.d.ts +26 -3
- package/lib/validation/types.cjs +1 -1
- package/lib/validation/types.d.ts +11 -5
- package/package.json +15 -4
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// import { z } from "zod/index";
|
|
3
|
+
// import { hashedBy, Model, ModelArg, serializedBy } from "../../model";
|
|
4
|
+
// import { Tool, ToolParameters } from "fastmcp";
|
|
5
|
+
//
|
|
6
|
+
// export const createModelParameters = z
|
|
7
|
+
// .array(
|
|
8
|
+
// z.object({
|
|
9
|
+
// name: z.string(),
|
|
10
|
+
// type: z.enum(["string", "number", "boolean", "Date"]),
|
|
11
|
+
// decorators: z.array(
|
|
12
|
+
// z.object({
|
|
13
|
+
// name: z.string(),
|
|
14
|
+
// args: z.array(z.any()).optional(),
|
|
15
|
+
// })
|
|
16
|
+
// ),
|
|
17
|
+
// })
|
|
18
|
+
// )
|
|
19
|
+
// .describe("Model properties with their decorators");
|
|
20
|
+
//
|
|
21
|
+
// type T = z.infer<typeof createModelParameters> & ToolParameters;
|
|
22
|
+
//
|
|
23
|
+
// export const createModelTool: Tool<undefined, T> = {
|
|
24
|
+
// name: "create-model",
|
|
25
|
+
// description: "Create a new model class with validation decorators",
|
|
26
|
+
// parameters: createModelParameters,
|
|
27
|
+
// execute: async (args: T) => {
|
|
28
|
+
// const { name, properties, options } = args;
|
|
29
|
+
//
|
|
30
|
+
// // Create dynamic model class
|
|
31
|
+
// const dynamicModel = class extends Model {
|
|
32
|
+
// constructor(data?: ModelArg<typeof dynamicModel>) {
|
|
33
|
+
// super(data);
|
|
34
|
+
// Model.fromModel(this, data);
|
|
35
|
+
// }
|
|
36
|
+
// };
|
|
37
|
+
//
|
|
38
|
+
// // Apply model-level decorators
|
|
39
|
+
// if (options?.hashAlgorithm) {
|
|
40
|
+
// hashedBy(options.hashAlgorithm)(dynamicModel);
|
|
41
|
+
// }
|
|
42
|
+
// if (options?.serializer) {
|
|
43
|
+
// serializedBy(options.serializer)(dynamicModel);
|
|
44
|
+
// }
|
|
45
|
+
//
|
|
46
|
+
// // Apply property decorators
|
|
47
|
+
// properties.forEach((prop) => {
|
|
48
|
+
// prop.decorators.forEach((decorator) => {
|
|
49
|
+
// const decoratorFn = getDecoratorFunction(decorator.name);
|
|
50
|
+
// if (decoratorFn) {
|
|
51
|
+
// decoratorFn(...(decorator.args || []))(
|
|
52
|
+
// dynamicModel.prototype,
|
|
53
|
+
// prop.name
|
|
54
|
+
// );
|
|
55
|
+
// }
|
|
56
|
+
// });
|
|
57
|
+
// });
|
|
58
|
+
//
|
|
59
|
+
// // Register the model
|
|
60
|
+
// Object.defineProperty(dynamicModel, "name", { value: name });
|
|
61
|
+
// Model.register(dynamicModel);
|
|
62
|
+
// modelRegistry.set(name, dynamicModel);
|
|
63
|
+
//
|
|
64
|
+
// return `Model "${name}" created and registered successfully`;
|
|
65
|
+
// },
|
|
66
|
+
// };
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlTW9kZWwudG9vbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9tY3AvdG9vbHMvY3JlYXRlTW9kZWwudG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsaUNBQWlDO0FBQ2pDLHlFQUF5RTtBQUN6RSxrREFBa0Q7QUFDbEQsRUFBRTtBQUNGLHlDQUF5QztBQUN6QyxZQUFZO0FBQ1osaUJBQWlCO0FBQ2pCLDBCQUEwQjtBQUMxQiwrREFBK0Q7QUFDL0QsNkJBQTZCO0FBQzdCLHFCQUFxQjtBQUNyQiw4QkFBOEI7QUFDOUIsK0NBQStDO0FBQy9DLGFBQWE7QUFDYixXQUFXO0FBQ1gsU0FBUztBQUNULE1BQU07QUFDTix5REFBeUQ7QUFDekQsRUFBRTtBQUNGLG1FQUFtRTtBQUNuRSxFQUFFO0FBQ0YsdURBQXVEO0FBQ3ZELDBCQUEwQjtBQUMxQix3RUFBd0U7QUFDeEUsdUNBQXVDO0FBQ3ZDLGtDQUFrQztBQUNsQyxrREFBa0Q7QUFDbEQsRUFBRTtBQUNGLG9DQUFvQztBQUNwQyxpREFBaUQ7QUFDakQsNERBQTREO0FBQzVELHVCQUF1QjtBQUN2Qix1Q0FBdUM7QUFDdkMsVUFBVTtBQUNWLFNBQVM7QUFDVCxFQUFFO0FBQ0Ysc0NBQXNDO0FBQ3RDLG9DQUFvQztBQUNwQyx1REFBdUQ7QUFDdkQsUUFBUTtBQUNSLGlDQUFpQztBQUNqQyx3REFBd0Q7QUFDeEQsUUFBUTtBQUNSLEVBQUU7QUFDRixtQ0FBbUM7QUFDbkMscUNBQXFDO0FBQ3JDLGlEQUFpRDtBQUNqRCxvRUFBb0U7QUFDcEUsNkJBQTZCO0FBQzdCLG9EQUFvRDtBQUNwRCxzQ0FBc0M7QUFDdEMsd0JBQXdCO0FBQ3hCLGVBQWU7QUFDZixZQUFZO0FBQ1osWUFBWTtBQUNaLFVBQVU7QUFDVixFQUFFO0FBQ0YsNEJBQTRCO0FBQzVCLG9FQUFvRTtBQUNwRSxvQ0FBb0M7QUFDcEMsNkNBQTZDO0FBQzdDLEVBQUU7QUFDRixvRUFBb0U7QUFDcEUsT0FBTztBQUNQLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBpbXBvcnQgeyB6IH0gZnJvbSBcInpvZC9pbmRleFwiO1xuLy8gaW1wb3J0IHsgaGFzaGVkQnksIE1vZGVsLCBNb2RlbEFyZywgc2VyaWFsaXplZEJ5IH0gZnJvbSBcIi4uLy4uL21vZGVsXCI7XG4vLyBpbXBvcnQgeyBUb29sLCBUb29sUGFyYW1ldGVycyB9IGZyb20gXCJmYXN0bWNwXCI7XG4vL1xuLy8gZXhwb3J0IGNvbnN0IGNyZWF0ZU1vZGVsUGFyYW1ldGVycyA9IHpcbi8vICAgLmFycmF5KFxuLy8gICAgIHoub2JqZWN0KHtcbi8vICAgICAgIG5hbWU6IHouc3RyaW5nKCksXG4vLyAgICAgICB0eXBlOiB6LmVudW0oW1wic3RyaW5nXCIsIFwibnVtYmVyXCIsIFwiYm9vbGVhblwiLCBcIkRhdGVcIl0pLFxuLy8gICAgICAgZGVjb3JhdG9yczogei5hcnJheShcbi8vICAgICAgICAgei5vYmplY3Qoe1xuLy8gICAgICAgICAgIG5hbWU6IHouc3RyaW5nKCksXG4vLyAgICAgICAgICAgYXJnczogei5hcnJheSh6LmFueSgpKS5vcHRpb25hbCgpLFxuLy8gICAgICAgICB9KVxuLy8gICAgICAgKSxcbi8vICAgICB9KVxuLy8gICApXG4vLyAgIC5kZXNjcmliZShcIk1vZGVsIHByb3BlcnRpZXMgd2l0aCB0aGVpciBkZWNvcmF0b3JzXCIpO1xuLy9cbi8vIHR5cGUgVCA9IHouaW5mZXI8dHlwZW9mIGNyZWF0ZU1vZGVsUGFyYW1ldGVycz4gJiBUb29sUGFyYW1ldGVycztcbi8vXG4vLyBleHBvcnQgY29uc3QgY3JlYXRlTW9kZWxUb29sOiBUb29sPHVuZGVmaW5lZCwgVD4gPSB7XG4vLyAgIG5hbWU6IFwiY3JlYXRlLW1vZGVsXCIsXG4vLyAgIGRlc2NyaXB0aW9uOiBcIkNyZWF0ZSBhIG5ldyBtb2RlbCBjbGFzcyB3aXRoIHZhbGlkYXRpb24gZGVjb3JhdG9yc1wiLFxuLy8gICBwYXJhbWV0ZXJzOiBjcmVhdGVNb2RlbFBhcmFtZXRlcnMsXG4vLyAgIGV4ZWN1dGU6IGFzeW5jIChhcmdzOiBUKSA9PiB7XG4vLyAgICAgY29uc3QgeyBuYW1lLCBwcm9wZXJ0aWVzLCBvcHRpb25zIH0gPSBhcmdzO1xuLy9cbi8vICAgICAvLyBDcmVhdGUgZHluYW1pYyBtb2RlbCBjbGFzc1xuLy8gICAgIGNvbnN0IGR5bmFtaWNNb2RlbCA9IGNsYXNzIGV4dGVuZHMgTW9kZWwge1xuLy8gICAgICAgY29uc3RydWN0b3IoZGF0YT86IE1vZGVsQXJnPHR5cGVvZiBkeW5hbWljTW9kZWw+KSB7XG4vLyAgICAgICAgIHN1cGVyKGRhdGEpO1xuLy8gICAgICAgICBNb2RlbC5mcm9tTW9kZWwodGhpcywgZGF0YSk7XG4vLyAgICAgICB9XG4vLyAgICAgfTtcbi8vXG4vLyAgICAgLy8gQXBwbHkgbW9kZWwtbGV2ZWwgZGVjb3JhdG9yc1xuLy8gICAgIGlmIChvcHRpb25zPy5oYXNoQWxnb3JpdGhtKSB7XG4vLyAgICAgICBoYXNoZWRCeShvcHRpb25zLmhhc2hBbGdvcml0aG0pKGR5bmFtaWNNb2RlbCk7XG4vLyAgICAgfVxuLy8gICAgIGlmIChvcHRpb25zPy5zZXJpYWxpemVyKSB7XG4vLyAgICAgICBzZXJpYWxpemVkQnkob3B0aW9ucy5zZXJpYWxpemVyKShkeW5hbWljTW9kZWwpO1xuLy8gICAgIH1cbi8vXG4vLyAgICAgLy8gQXBwbHkgcHJvcGVydHkgZGVjb3JhdG9yc1xuLy8gICAgIHByb3BlcnRpZXMuZm9yRWFjaCgocHJvcCkgPT4ge1xuLy8gICAgICAgcHJvcC5kZWNvcmF0b3JzLmZvckVhY2goKGRlY29yYXRvcikgPT4ge1xuLy8gICAgICAgICBjb25zdCBkZWNvcmF0b3JGbiA9IGdldERlY29yYXRvckZ1bmN0aW9uKGRlY29yYXRvci5uYW1lKTtcbi8vICAgICAgICAgaWYgKGRlY29yYXRvckZuKSB7XG4vLyAgICAgICAgICAgZGVjb3JhdG9yRm4oLi4uKGRlY29yYXRvci5hcmdzIHx8IFtdKSkoXG4vLyAgICAgICAgICAgICBkeW5hbWljTW9kZWwucHJvdG90eXBlLFxuLy8gICAgICAgICAgICAgcHJvcC5uYW1lXG4vLyAgICAgICAgICAgKTtcbi8vICAgICAgICAgfVxuLy8gICAgICAgfSk7XG4vLyAgICAgfSk7XG4vL1xuLy8gICAgIC8vIFJlZ2lzdGVyIHRoZSBtb2RlbFxuLy8gICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShkeW5hbWljTW9kZWwsIFwibmFtZVwiLCB7IHZhbHVlOiBuYW1lIH0pO1xuLy8gICAgIE1vZGVsLnJlZ2lzdGVyKGR5bmFtaWNNb2RlbCk7XG4vLyAgICAgbW9kZWxSZWdpc3RyeS5zZXQobmFtZSwgZHluYW1pY01vZGVsKTtcbi8vXG4vLyAgICAgcmV0dXJuIGBNb2RlbCBcIiR7bmFtZX1cIiBjcmVhdGVkIGFuZCByZWdpc3RlcmVkIHN1Y2Nlc3NmdWxseWA7XG4vLyAgIH0sXG4vLyB9O1xuIl19
|
|
File without changes
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGVNb2RlbC50b29sLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL21jcC90b29scy92YWxpZGF0ZU1vZGVsLnRvb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWNwL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUb29sLCBUb29sUGFyYW1ldGVycyB9IGZyb20gXCJmYXN0bWNwXCI7XG5cbmV4cG9ydCB0eXBlIFRvb2xQYXJhbWV0ZXJzVHlwZTxcbiAgVCBleHRlbmRzIEZhc3RNQ1BTZXNzaW9uQXV0aCxcbiAgUGFyYW1zIGV4dGVuZHMgVG9vbFBhcmFtZXRlcnMsXG4+ID0gVG9vbDxULCBQYXJhbXM+O1xuXG5leHBvcnQgdHlwZSBGYXN0TUNQU2Vzc2lvbkF1dGggPSBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPiB8IHVuZGVmaW5lZDtcbiJdfQ==
|
|
File without changes
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// import { Model } from "./Model";
|
|
3
|
+
// import { Constructor, ModelArg } from "./types";
|
|
4
|
+
// import { ObjectAccumulator } from "typed-object-accumulator";
|
|
5
|
+
//
|
|
6
|
+
// export interface DecorateOption<M extends Model> {
|
|
7
|
+
// decorate(...decorators: PropertyDecorator[]): ModelBuilder<M>;
|
|
8
|
+
// }
|
|
9
|
+
//
|
|
10
|
+
// export class AttributeBuilder<M extends Model, N extends keyof M, T>
|
|
11
|
+
// implements DecorateOption<M>
|
|
12
|
+
// {
|
|
13
|
+
// constructor(
|
|
14
|
+
// protected parent: ModelBuilder<M>,
|
|
15
|
+
// readonly attr: keyof M,
|
|
16
|
+
// readonly type: T
|
|
17
|
+
// ) {}
|
|
18
|
+
//
|
|
19
|
+
// private decorators: Set<PropertyDecorator> = new Set();
|
|
20
|
+
//
|
|
21
|
+
// decorate(...decorators: PropertyDecorator[]): ModelBuilder<M> {
|
|
22
|
+
// for (const decorator of decorators) {
|
|
23
|
+
// if (this.decorators.has(decorator))
|
|
24
|
+
// throw new Error(`Decorator "${decorator}" has already been used`);
|
|
25
|
+
// this.decorators.add(decorator);
|
|
26
|
+
// }
|
|
27
|
+
// return this.parent;
|
|
28
|
+
// }
|
|
29
|
+
//
|
|
30
|
+
// undecorate(...decorators: PropertyDecorator[]) {
|
|
31
|
+
// for (const decorator of decorators) {
|
|
32
|
+
// if (!this.decorators.has(decorator))
|
|
33
|
+
// throw new Error(
|
|
34
|
+
// `Decorator "${decorator}" is not applied to ${this.attr as string}`
|
|
35
|
+
// );
|
|
36
|
+
// this.decorators.delete(decorator);
|
|
37
|
+
// }
|
|
38
|
+
// return this.parent;
|
|
39
|
+
// }
|
|
40
|
+
//
|
|
41
|
+
// apply(obj: Constructor<M>): ModelBuilder<M> {
|
|
42
|
+
// Object.defineProperty(obj, this.attr, {
|
|
43
|
+
// value: undefined,
|
|
44
|
+
// });
|
|
45
|
+
// this.decorators.forEach((decorator) => {
|
|
46
|
+
// try {
|
|
47
|
+
// decorator(obj, this.attr as any);
|
|
48
|
+
// } catch (e: unknown) {
|
|
49
|
+
// throw new Error(
|
|
50
|
+
// `Failed to apply decorator to property "${this.attr as any}": ${e}`
|
|
51
|
+
// );
|
|
52
|
+
// }
|
|
53
|
+
// });
|
|
54
|
+
// //
|
|
55
|
+
// // const c = `${this.attr.toString()}` as const;
|
|
56
|
+
// //
|
|
57
|
+
// // const temp: {
|
|
58
|
+
// // [c]: T
|
|
59
|
+
// // } = {
|
|
60
|
+
// // [this.attr]: 0
|
|
61
|
+
// // }
|
|
62
|
+
//
|
|
63
|
+
// return this.parent.accumulate() as unknown as ModelBuilder<M & Record<N, T>>;
|
|
64
|
+
// }
|
|
65
|
+
// }
|
|
66
|
+
//
|
|
67
|
+
// export class ModelBuilder<M extends Model = Model> extends ObjectAccumulator<M>{
|
|
68
|
+
// private attributes: Map<string, AttributeBuilder<M, any, any>> = new Map();
|
|
69
|
+
// private _name?: string;
|
|
70
|
+
//
|
|
71
|
+
// private _parent?: Constructor<M>;
|
|
72
|
+
//
|
|
73
|
+
// setName(name: string) {
|
|
74
|
+
// this._name = name;
|
|
75
|
+
// return this;
|
|
76
|
+
// }
|
|
77
|
+
//
|
|
78
|
+
// private attribute<T, N extends symbol>(
|
|
79
|
+
// attr: string,
|
|
80
|
+
// type: T
|
|
81
|
+
// ): AttributeBuilder<M, N, T> {
|
|
82
|
+
// return new AttributeBuilder<M, N, T>(this, attr as any, type);
|
|
83
|
+
// }
|
|
84
|
+
//
|
|
85
|
+
// string(attr: string) {
|
|
86
|
+
// return this.attribute(attr, String.name);
|
|
87
|
+
// }
|
|
88
|
+
//
|
|
89
|
+
// number(attr: string) {
|
|
90
|
+
// return this.attribute(attr, Number.name);
|
|
91
|
+
// }
|
|
92
|
+
//
|
|
93
|
+
// date(attr: string) {
|
|
94
|
+
// return this.attribute(attr, Date.name);
|
|
95
|
+
// }
|
|
96
|
+
//
|
|
97
|
+
// bigint(attr: string) {
|
|
98
|
+
// return this.attribute(attr, BigInt.name);
|
|
99
|
+
// }
|
|
100
|
+
//
|
|
101
|
+
// instance(clazz: Constructor<any>, attr: string) {
|
|
102
|
+
// return this.attribute(attr, clazz.name);
|
|
103
|
+
// }
|
|
104
|
+
//
|
|
105
|
+
// build(): Constructor<M> {
|
|
106
|
+
// if (!this._name) throw new Error("name is required");
|
|
107
|
+
//
|
|
108
|
+
// const DynamicBuiltClass = class<M> extends Model {
|
|
109
|
+
// constructor(arg?: ModelArg<M>) {
|
|
110
|
+
// super(arg as any);
|
|
111
|
+
// }
|
|
112
|
+
// };
|
|
113
|
+
//
|
|
114
|
+
// Object.defineProperty(DynamicBuiltClass, "name", {
|
|
115
|
+
// value: this._name,
|
|
116
|
+
// writable: false,
|
|
117
|
+
// });
|
|
118
|
+
//
|
|
119
|
+
// this.attributes.forEach((attribute) => {
|
|
120
|
+
// attribute.apply(DynamicBuiltClass as any);
|
|
121
|
+
// });
|
|
122
|
+
//
|
|
123
|
+
// return DynamicBuiltClass as unknown as Constructor<M>;
|
|
124
|
+
// }
|
|
125
|
+
//
|
|
126
|
+
// static get builder() {
|
|
127
|
+
// return new ModelBuilder();
|
|
128
|
+
// }
|
|
129
|
+
// }
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2RlbC9CdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxtQ0FBbUM7QUFDbkMsbURBQW1EO0FBQ25ELGdFQUFnRTtBQUNoRSxFQUFFO0FBQ0YscURBQXFEO0FBQ3JELG1FQUFtRTtBQUNuRSxJQUFJO0FBQ0osRUFBRTtBQUNGLHVFQUF1RTtBQUN2RSxpQ0FBaUM7QUFDakMsSUFBSTtBQUNKLGlCQUFpQjtBQUNqQix5Q0FBeUM7QUFDekMsOEJBQThCO0FBQzlCLHVCQUF1QjtBQUN2QixTQUFTO0FBQ1QsRUFBRTtBQUNGLDREQUE0RDtBQUM1RCxFQUFFO0FBQ0Ysb0VBQW9FO0FBQ3BFLDRDQUE0QztBQUM1Qyw0Q0FBNEM7QUFDNUMsNkVBQTZFO0FBQzdFLHdDQUF3QztBQUN4QyxRQUFRO0FBQ1IsMEJBQTBCO0FBQzFCLE1BQU07QUFDTixFQUFFO0FBQ0YscURBQXFEO0FBQ3JELDRDQUE0QztBQUM1Qyw2Q0FBNkM7QUFDN0MsMkJBQTJCO0FBQzNCLGdGQUFnRjtBQUNoRixhQUFhO0FBQ2IsMkNBQTJDO0FBQzNDLFFBQVE7QUFDUiwwQkFBMEI7QUFDMUIsTUFBTTtBQUNOLEVBQUU7QUFDRixrREFBa0Q7QUFDbEQsOENBQThDO0FBQzlDLDBCQUEwQjtBQUMxQixVQUFVO0FBQ1YsK0NBQStDO0FBQy9DLGNBQWM7QUFDZCw0Q0FBNEM7QUFDNUMsK0JBQStCO0FBQy9CLDJCQUEyQjtBQUMzQixnRkFBZ0Y7QUFDaEYsYUFBYTtBQUNiLFVBQVU7QUFDVixVQUFVO0FBQ1YsU0FBUztBQUNULHVEQUF1RDtBQUN2RCxTQUFTO0FBQ1QsdUJBQXVCO0FBQ3ZCLGtCQUFrQjtBQUNsQixlQUFlO0FBQ2YsMEJBQTBCO0FBQzFCLFdBQVc7QUFDWCxFQUFFO0FBQ0Ysb0ZBQW9GO0FBQ3BGLE1BQU07QUFDTixJQUFJO0FBQ0osRUFBRTtBQUNGLG1GQUFtRjtBQUNuRixnRkFBZ0Y7QUFDaEYsNEJBQTRCO0FBQzVCLEVBQUU7QUFDRixzQ0FBc0M7QUFDdEMsRUFBRTtBQUNGLDRCQUE0QjtBQUM1Qix5QkFBeUI7QUFDekIsbUJBQW1CO0FBQ25CLE1BQU07QUFDTixFQUFFO0FBQ0YsNENBQTRDO0FBQzVDLG9CQUFvQjtBQUNwQixjQUFjO0FBQ2QsbUNBQW1DO0FBQ25DLHFFQUFxRTtBQUNyRSxNQUFNO0FBQ04sRUFBRTtBQUNGLDJCQUEyQjtBQUMzQixnREFBZ0Q7QUFDaEQsTUFBTTtBQUNOLEVBQUU7QUFDRiwyQkFBMkI7QUFDM0IsZ0RBQWdEO0FBQ2hELE1BQU07QUFDTixFQUFFO0FBQ0YseUJBQXlCO0FBQ3pCLDhDQUE4QztBQUM5QyxNQUFNO0FBQ04sRUFBRTtBQUNGLDJCQUEyQjtBQUMzQixnREFBZ0Q7QUFDaEQsTUFBTTtBQUNOLEVBQUU7QUFDRixzREFBc0Q7QUFDdEQsK0NBQStDO0FBQy9DLE1BQU07QUFDTixFQUFFO0FBQ0YsOEJBQThCO0FBQzlCLDREQUE0RDtBQUM1RCxFQUFFO0FBQ0YseURBQXlEO0FBQ3pELHlDQUF5QztBQUN6Qyw2QkFBNkI7QUFDN0IsVUFBVTtBQUNWLFNBQVM7QUFDVCxFQUFFO0FBQ0YseURBQXlEO0FBQ3pELDJCQUEyQjtBQUMzQix5QkFBeUI7QUFDekIsVUFBVTtBQUNWLEVBQUU7QUFDRiwrQ0FBK0M7QUFDL0MsbURBQW1EO0FBQ25ELFVBQVU7QUFDVixFQUFFO0FBQ0YsNkRBQTZEO0FBQzdELE1BQU07QUFDTixFQUFFO0FBQ0YsMkJBQTJCO0FBQzNCLGlDQUFpQztBQUNqQyxNQUFNO0FBQ04sSUFBSSIsInNvdXJjZXNDb250ZW50IjpbIi8vIGltcG9ydCB7IE1vZGVsIH0gZnJvbSBcIi4vTW9kZWxcIjtcbi8vIGltcG9ydCB7IENvbnN0cnVjdG9yLCBNb2RlbEFyZyB9IGZyb20gXCIuL3R5cGVzXCI7XG4vLyBpbXBvcnQgeyBPYmplY3RBY2N1bXVsYXRvciB9IGZyb20gXCJ0eXBlZC1vYmplY3QtYWNjdW11bGF0b3JcIjtcbi8vXG4vLyBleHBvcnQgaW50ZXJmYWNlIERlY29yYXRlT3B0aW9uPE0gZXh0ZW5kcyBNb2RlbD4ge1xuLy8gICBkZWNvcmF0ZSguLi5kZWNvcmF0b3JzOiBQcm9wZXJ0eURlY29yYXRvcltdKTogTW9kZWxCdWlsZGVyPE0+O1xuLy8gfVxuLy9cbi8vIGV4cG9ydCBjbGFzcyBBdHRyaWJ1dGVCdWlsZGVyPE0gZXh0ZW5kcyBNb2RlbCwgTiBleHRlbmRzIGtleW9mIE0sIFQ+XG4vLyAgIGltcGxlbWVudHMgRGVjb3JhdGVPcHRpb248TT5cbi8vIHtcbi8vICAgY29uc3RydWN0b3IoXG4vLyAgICAgcHJvdGVjdGVkIHBhcmVudDogTW9kZWxCdWlsZGVyPE0+LFxuLy8gICAgIHJlYWRvbmx5IGF0dHI6IGtleW9mIE0sXG4vLyAgICAgcmVhZG9ubHkgdHlwZTogVFxuLy8gICApIHt9XG4vL1xuLy8gICBwcml2YXRlIGRlY29yYXRvcnM6IFNldDxQcm9wZXJ0eURlY29yYXRvcj4gPSBuZXcgU2V0KCk7XG4vL1xuLy8gICBkZWNvcmF0ZSguLi5kZWNvcmF0b3JzOiBQcm9wZXJ0eURlY29yYXRvcltdKTogTW9kZWxCdWlsZGVyPE0+IHtcbi8vICAgICBmb3IgKGNvbnN0IGRlY29yYXRvciBvZiBkZWNvcmF0b3JzKSB7XG4vLyAgICAgICBpZiAodGhpcy5kZWNvcmF0b3JzLmhhcyhkZWNvcmF0b3IpKVxuLy8gICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYERlY29yYXRvciBcIiR7ZGVjb3JhdG9yfVwiIGhhcyBhbHJlYWR5IGJlZW4gdXNlZGApO1xuLy8gICAgICAgdGhpcy5kZWNvcmF0b3JzLmFkZChkZWNvcmF0b3IpO1xuLy8gICAgIH1cbi8vICAgICByZXR1cm4gdGhpcy5wYXJlbnQ7XG4vLyAgIH1cbi8vXG4vLyAgIHVuZGVjb3JhdGUoLi4uZGVjb3JhdG9yczogUHJvcGVydHlEZWNvcmF0b3JbXSkge1xuLy8gICAgIGZvciAoY29uc3QgZGVjb3JhdG9yIG9mIGRlY29yYXRvcnMpIHtcbi8vICAgICAgIGlmICghdGhpcy5kZWNvcmF0b3JzLmhhcyhkZWNvcmF0b3IpKVxuLy8gICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4vLyAgICAgICAgICAgYERlY29yYXRvciBcIiR7ZGVjb3JhdG9yfVwiIGlzIG5vdCBhcHBsaWVkIHRvICR7dGhpcy5hdHRyIGFzIHN0cmluZ31gXG4vLyAgICAgICAgICk7XG4vLyAgICAgICB0aGlzLmRlY29yYXRvcnMuZGVsZXRlKGRlY29yYXRvcik7XG4vLyAgICAgfVxuLy8gICAgIHJldHVybiB0aGlzLnBhcmVudDtcbi8vICAgfVxuLy9cbi8vICAgYXBwbHkob2JqOiBDb25zdHJ1Y3RvcjxNPik6IE1vZGVsQnVpbGRlcjxNPiB7XG4vLyAgICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KG9iaiwgdGhpcy5hdHRyLCB7XG4vLyAgICAgICB2YWx1ZTogdW5kZWZpbmVkLFxuLy8gICAgIH0pO1xuLy8gICAgIHRoaXMuZGVjb3JhdG9ycy5mb3JFYWNoKChkZWNvcmF0b3IpID0+IHtcbi8vICAgICAgIHRyeSB7XG4vLyAgICAgICAgIGRlY29yYXRvcihvYmosIHRoaXMuYXR0ciBhcyBhbnkpO1xuLy8gICAgICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuLy8gICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXG4vLyAgICAgICAgICAgYEZhaWxlZCB0byBhcHBseSBkZWNvcmF0b3IgdG8gcHJvcGVydHkgXCIke3RoaXMuYXR0ciBhcyBhbnl9XCI6ICR7ZX1gXG4vLyAgICAgICAgICk7XG4vLyAgICAgICB9XG4vLyAgICAgfSk7XG4vLyAgICAgLy9cbi8vICAgICAvLyBjb25zdCBjID0gYCR7dGhpcy5hdHRyLnRvU3RyaW5nKCl9YCBhcyBjb25zdDtcbi8vICAgICAvL1xuLy8gICAgIC8vIGNvbnN0IHRlbXA6IHtcbi8vICAgICAvLyAgIFtjXTogVFxuLy8gICAgIC8vIH0gPSB7XG4vLyAgICAgLy8gICBbdGhpcy5hdHRyXTogMFxuLy8gICAgIC8vIH1cbi8vXG4vLyAgICAgcmV0dXJuIHRoaXMucGFyZW50LmFjY3VtdWxhdGUoKSBhcyB1bmtub3duIGFzIE1vZGVsQnVpbGRlcjxNICYgUmVjb3JkPE4sIFQ+Pjtcbi8vICAgfVxuLy8gfVxuLy9cbi8vIGV4cG9ydCBjbGFzcyBNb2RlbEJ1aWxkZXI8TSBleHRlbmRzIE1vZGVsID0gTW9kZWw+IGV4dGVuZHMgT2JqZWN0QWNjdW11bGF0b3I8TT57XG4vLyAgIHByaXZhdGUgYXR0cmlidXRlczogTWFwPHN0cmluZywgQXR0cmlidXRlQnVpbGRlcjxNLCBhbnksIGFueT4+ID0gbmV3IE1hcCgpO1xuLy8gICBwcml2YXRlIF9uYW1lPzogc3RyaW5nO1xuLy9cbi8vICAgcHJpdmF0ZSBfcGFyZW50PzogQ29uc3RydWN0b3I8TT47XG4vL1xuLy8gICBzZXROYW1lKG5hbWU6IHN0cmluZykge1xuLy8gICAgIHRoaXMuX25hbWUgPSBuYW1lO1xuLy8gICAgIHJldHVybiB0aGlzO1xuLy8gICB9XG4vL1xuLy8gICBwcml2YXRlIGF0dHJpYnV0ZTxULCBOIGV4dGVuZHMgc3ltYm9sPihcbi8vICAgICBhdHRyOiBzdHJpbmcsXG4vLyAgICAgdHlwZTogVFxuLy8gICApOiBBdHRyaWJ1dGVCdWlsZGVyPE0sIE4sIFQ+IHtcbi8vICAgICByZXR1cm4gbmV3IEF0dHJpYnV0ZUJ1aWxkZXI8TSwgTiwgVD4odGhpcywgYXR0ciBhcyBhbnksIHR5cGUpO1xuLy8gICB9XG4vL1xuLy8gICBzdHJpbmcoYXR0cjogc3RyaW5nKSB7XG4vLyAgICAgcmV0dXJuIHRoaXMuYXR0cmlidXRlKGF0dHIsIFN0cmluZy5uYW1lKTtcbi8vICAgfVxuLy9cbi8vICAgbnVtYmVyKGF0dHI6IHN0cmluZykge1xuLy8gICAgIHJldHVybiB0aGlzLmF0dHJpYnV0ZShhdHRyLCBOdW1iZXIubmFtZSk7XG4vLyAgIH1cbi8vXG4vLyAgIGRhdGUoYXR0cjogc3RyaW5nKSB7XG4vLyAgICAgcmV0dXJuIHRoaXMuYXR0cmlidXRlKGF0dHIsIERhdGUubmFtZSk7XG4vLyAgIH1cbi8vXG4vLyAgIGJpZ2ludChhdHRyOiBzdHJpbmcpIHtcbi8vICAgICByZXR1cm4gdGhpcy5hdHRyaWJ1dGUoYXR0ciwgQmlnSW50Lm5hbWUpO1xuLy8gICB9XG4vL1xuLy8gICBpbnN0YW5jZShjbGF6ejogQ29uc3RydWN0b3I8YW55PiwgYXR0cjogc3RyaW5nKSB7XG4vLyAgICAgcmV0dXJuIHRoaXMuYXR0cmlidXRlKGF0dHIsIGNsYXp6Lm5hbWUpO1xuLy8gICB9XG4vL1xuLy8gICBidWlsZCgpOiBDb25zdHJ1Y3RvcjxNPiB7XG4vLyAgICAgaWYgKCF0aGlzLl9uYW1lKSB0aHJvdyBuZXcgRXJyb3IoXCJuYW1lIGlzIHJlcXVpcmVkXCIpO1xuLy9cbi8vICAgICBjb25zdCBEeW5hbWljQnVpbHRDbGFzcyA9IGNsYXNzPE0+IGV4dGVuZHMgTW9kZWwge1xuLy8gICAgICAgY29uc3RydWN0b3IoYXJnPzogTW9kZWxBcmc8TT4pIHtcbi8vICAgICAgICAgc3VwZXIoYXJnIGFzIGFueSk7XG4vLyAgICAgICB9XG4vLyAgICAgfTtcbi8vXG4vLyAgICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KER5bmFtaWNCdWlsdENsYXNzLCBcIm5hbWVcIiwge1xuLy8gICAgICAgdmFsdWU6IHRoaXMuX25hbWUsXG4vLyAgICAgICB3cml0YWJsZTogZmFsc2UsXG4vLyAgICAgfSk7XG4vL1xuLy8gICAgIHRoaXMuYXR0cmlidXRlcy5mb3JFYWNoKChhdHRyaWJ1dGUpID0+IHtcbi8vICAgICAgIGF0dHJpYnV0ZS5hcHBseShEeW5hbWljQnVpbHRDbGFzcyBhcyBhbnkpO1xuLy8gICAgIH0pO1xuLy9cbi8vICAgICByZXR1cm4gRHluYW1pY0J1aWx0Q2xhc3MgYXMgdW5rbm93biBhcyBDb25zdHJ1Y3RvcjxNPjtcbi8vICAgfVxuLy9cbi8vICAgc3RhdGljIGdldCBidWlsZGVyKCkge1xuLy8gICAgIHJldHVybiBuZXcgTW9kZWxCdWlsZGVyKCk7XG4vLyAgIH1cbi8vIH1cbiJdfQ==
|
package/lib/esm/model/Model.d.ts
CHANGED
|
@@ -397,4 +397,5 @@ export declare abstract class Model implements Validatable, Serializable, Hashab
|
|
|
397
397
|
* the model name if the property has a model type, or undefined if not a model
|
|
398
398
|
*/
|
|
399
399
|
static isPropertyModel<M extends Model>(target: M, attribute: string): boolean | string | undefined;
|
|
400
|
+
static describe<M extends Model>(model: M | Constructor<M>, key?: keyof M): any;
|
|
400
401
|
}
|
package/lib/esm/model/Model.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { Serialization } from "
|
|
1
|
+
import { Serialization } from "./../utils/serialization.js";
|
|
2
2
|
import { isEqual, Reflection } from "@decaf-ts/reflection";
|
|
3
|
-
import { validate } from "./validation";
|
|
4
|
-
import { Hashing } from "
|
|
5
|
-
import { ModelKeys } from "
|
|
6
|
-
import { ValidationKeys } from "
|
|
7
|
-
import { jsTypes, ReservedModels } from "./constants";
|
|
8
|
-
import { getModelKey, getMetadata } from "./utils";
|
|
3
|
+
import { validate } from "./validation.js";
|
|
4
|
+
import { Hashing } from "./../utils/hashing.js";
|
|
5
|
+
import { ModelKeys } from "./../utils/constants.js";
|
|
6
|
+
import { ValidationKeys } from "./../validation/Validators/constants.js";
|
|
7
|
+
import { jsTypes, ReservedModels } from "./constants.js";
|
|
8
|
+
import { getModelKey, getMetadata } from "./utils.js";
|
|
9
9
|
let modelBuilderFunction;
|
|
10
10
|
let actingModelRegistry;
|
|
11
11
|
/**
|
|
@@ -335,7 +335,8 @@ export class Model {
|
|
|
335
335
|
}
|
|
336
336
|
break;
|
|
337
337
|
default:
|
|
338
|
-
if (self[prop]
|
|
338
|
+
if (typeof self[prop] !== "undefined" &&
|
|
339
|
+
Model.get(c))
|
|
339
340
|
self[prop] = Model.build(self[prop], c);
|
|
340
341
|
}
|
|
341
342
|
}
|
|
@@ -364,7 +365,7 @@ export class Model {
|
|
|
364
365
|
* @return {ModelBuilderFunction | undefined} - The current global builder function or undefined if not set
|
|
365
366
|
*/
|
|
366
367
|
static getBuilder() {
|
|
367
|
-
return modelBuilderFunction;
|
|
368
|
+
return modelBuilderFunction || Model.fromModel;
|
|
368
369
|
}
|
|
369
370
|
/**
|
|
370
371
|
* @description Provides access to the current model registry
|
|
@@ -573,5 +574,15 @@ export class Model {
|
|
|
573
574
|
const metadata = Reflect.getMetadata(ModelKeys.TYPE, target, attribute);
|
|
574
575
|
return Model.get(metadata.name) ? metadata.name : undefined;
|
|
575
576
|
}
|
|
577
|
+
static describe(model, key) {
|
|
578
|
+
const descKey = Model.key(ModelKeys.DESCRIPTION);
|
|
579
|
+
if (key) {
|
|
580
|
+
model = model instanceof Model ? model : new model();
|
|
581
|
+
return (Reflect.getMetadataKeys(model.constructor, key.toString())
|
|
582
|
+
.find((k) => k === descKey)
|
|
583
|
+
?.toString() || model.toString());
|
|
584
|
+
}
|
|
585
|
+
return (Reflect.getMetadata(Model.key(ModelKeys.DESCRIPTION), model instanceof Model ? model.constructor : model) || model.toString());
|
|
586
|
+
}
|
|
576
587
|
}
|
|
577
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Model.js","sourceRoot":"","sources":["../../../src/model/Model.ts"],"names":[],"mappings":"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","sourcesContent":["import { Serialization } from \"../utils/serialization\";\nimport { BuilderRegistry } from \"../utils/registry\";\nimport { ModelErrorDefinition } from \"./ModelErrorDefinition\";\nimport {\n  Comparable,\n  Constructor,\n  Hashable,\n  ModelArg,\n  ModelBuilderFunction,\n  ModelConstructor,\n  Serializable,\n  Validatable,\n} from \"./types\";\nimport { DecoratorMetadata, isEqual, Reflection } from \"@decaf-ts/reflection\";\nimport { validate } from \"./validation\";\nimport { Hashing } from \"../utils/hashing\";\nimport { ModelKeys } from \"../utils/constants\";\nimport { ValidationKeys } from \"../validation/Validators/constants\";\nimport { jsTypes, ReservedModels } from \"./constants\";\nimport { getModelKey, getMetadata } from \"./utils\";\n\nlet modelBuilderFunction: ModelBuilderFunction | undefined;\nlet actingModelRegistry: BuilderRegistry<any>;\n\n/**\n * @description Registry type for storing and retrieving model constructors\n * @summary The ModelRegistry type defines a registry for model constructors that extends\n * the BuilderRegistry interface. It provides a standardized way to register, retrieve,\n * and build model instances, enabling the model system to work with different types of models.\n *\n * @interface ModelRegistry\n * @template T Type of model that can be registered, must extend Model\n * @extends BuilderRegistry<T>\n * @memberOf module:decorator-validation\n * @category Model\n */\nexport type ModelRegistry<T extends Model> = BuilderRegistry<T>;\n\n/**\n * @description Registry manager for model constructors that enables serialization and rebuilding\n * @summary The ModelRegistryManager implements the ModelRegistry interface and provides\n * functionality for registering, retrieving, and building model instances. It maintains\n * a cache of model constructors indexed by name, allowing for efficient lookup and instantiation.\n * This class is essential for the serialization and deserialization of model objects.\n *\n * @param {function(Record<string, any>): boolean} [testFunction] - Function to test if an object is a model, defaults to {@link Model#isModel}\n *\n * @class ModelRegistryManager\n * @template M Type of model that can be registered, must extend Model\n * @implements ModelRegistry<M>\n * @category Model\n *\n * @example\n * ```typescript\n * // Create a model registry\n * const registry = new ModelRegistryManager();\n *\n * // Register a model class\n * registry.register(User);\n *\n * // Retrieve a model constructor by name\n * const UserClass = registry.get(\"User\");\n *\n * // Build a model instance from a plain object\n * const userData = { name: \"John\", age: 30 };\n * const user = registry.build(userData, \"User\");\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant R as ModelRegistryManager\n *   participant M as Model Class\n *\n *   C->>R: new ModelRegistryManager(testFunction)\n *   C->>R: register(ModelClass)\n *   R->>R: Store in cache\n *   C->>R: get(\"ModelName\")\n *   R-->>C: ModelClass constructor\n *   C->>R: build(data, \"ModelName\")\n *   R->>R: Get constructor from cache\n *   R->>M: new ModelClass(data)\n *   M-->>R: Model instance\n *   R-->>C: Model instance\n */\nexport class ModelRegistryManager<M extends Model> implements ModelRegistry<M> {\n  private cache: Record<string, ModelConstructor<M>> = {};\n  private readonly testFunction: (obj: object) => boolean;\n\n  constructor(\n    testFunction: (obj: Record<string, any>) => boolean = Model.isModel\n  ) {\n    this.testFunction = testFunction;\n  }\n\n  /**\n   * @description Registers a model constructor with the registry\n   * @summary Adds a model constructor to the registry cache, making it available for\n   * later retrieval and instantiation. If no name is provided, the constructor's name\n   * property is used as the key in the registry.\n   *\n   * @param {ModelConstructor<M>} constructor - The model constructor to register\n   * @param {string} [name] - Optional name to register the constructor under, defaults to constructor.name\n   * @return {void}\n   * @throws {Error} If the constructor is not a function\n   */\n  register(constructor: ModelConstructor<M>, name?: string): void {\n    if (typeof constructor !== \"function\")\n      throw new Error(\n        \"Model registering failed. Missing Class name or constructor\"\n      );\n    name = name || constructor.name;\n    this.cache[name] = constructor;\n  }\n\n  /**\n   * @summary Gets a registered Model {@link ModelConstructor}\n   * @param {string} name\n   */\n  get(name: string): ModelConstructor<M> | undefined {\n    try {\n      return this.cache[name];\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      return undefined;\n    }\n  }\n\n  /**\n   * @param {Record<string, any>} obj\n   * @param {string} [clazz] when provided, it will attempt to find the matching constructor\n   *\n   * @throws Error If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n   */\n  build(obj: Record<string, any> = {}, clazz?: string): M {\n    if (!clazz && !this.testFunction(obj))\n      throw new Error(\"Provided obj is not a Model object\");\n    const name = clazz || Model.getMetadata(obj as any);\n    if (!(name in this.cache))\n      throw new Error(\n        `Provided class ${name} is not a registered Model object`\n      );\n    return new this.cache[name](obj);\n  }\n}\n\n/**\n * @summary Bulk Registers Models\n * @description Useful when using bundlers that might not evaluate all the code at once\n *\n * @template M extends Model\n * @param {Array<Constructor<M>> | Array<{name: string, constructor: Constructor<M>}>} [models]\n *\n * @memberOf module:decorator-validation\n * @category Model\n */\nexport function bulkModelRegister<M extends Model>(\n  ...models: (Constructor<M> | { name: string; constructor: Constructor<M> })[]\n) {\n  models.forEach(\n    (m: Constructor<M> | { name: string; constructor: Constructor<M> }) => {\n      const constructor: Constructor<M> = (\n        m.constructor ? m.constructor : m\n      ) as Constructor<M>;\n      Model.register(constructor, (m as Constructor<M>).name);\n    }\n  );\n}\n\n/**\n * @summary Abstract class representing a Validatable Model object\n * @description Meant to be used as a base class for all Model classes\n *\n * Model objects must:\n *  - Have all their required properties marked with '!';\n *  - Have all their optional properties marked as '?':\n *\n * @param {ModelArg<Model>} model base object from which to populate properties from\n *\n * @class Model\n * @category Model\n * @abstract\n * @implements Validatable\n * @implements Serializable\n *\n * @example\n *      class ClassName {\n *          @required()\n *          requiredPropertyName!: PropertyType;\n *\n *          optionalPropertyName?: PropertyType;\n *      }\n */\nexport abstract class Model\n  implements Validatable, Serializable, Hashable, Comparable<Model>\n{\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected constructor(arg?: ModelArg<Model>) {}\n\n  /**\n   * @description Validates the model object against its defined validation rules\n   * @summary Validates the object according to its decorated properties, returning any validation errors\n   *\n   * @param {any[]} [exceptions] - Properties in the object to be ignored for the validation. Marked as 'any' to allow for extension but expects strings\n   * @return {ModelErrorDefinition | undefined} - Returns a ModelErrorDefinition object if validation errors exist, otherwise undefined\n   */\n  public hasErrors(...exceptions: any[]): ModelErrorDefinition | undefined {\n    return validate(this, ...exceptions);\n  }\n\n  /**\n   * @description Determines if this model is equal to another object\n   * @summary Compare object equality recursively, checking all properties unless excluded\n   *\n   * @param {any} obj - Object to compare to\n   * @param {string[]} [exceptions] - Property names to be excluded from the comparison\n   * @return {boolean} - True if objects are equal, false otherwise\n   */\n  public equals(obj: any, ...exceptions: string[]): boolean {\n    return isEqual(this, obj, ...exceptions);\n  }\n\n  /**\n   * @description Converts the model to a serialized string representation\n   * @summary Returns the serialized model according to the currently defined {@link Serializer}\n   * \n   * @return {string} - The serialized string representation of the model\n   */\n  serialize(): string {\n    return Model.serialize(this);\n  }\n\n  /**\n   * @description Provides a human-readable string representation of the model\n   * @summary Override the implementation for js's 'toString()' to provide a more useful representation\n   * \n   * @return {string} - A string representation of the model including its class name and JSON representation\n   * @override\n   */\n  public toString(): string {\n    return this.constructor.name + \": \" + JSON.stringify(this, undefined, 2);\n  }\n\n  /**\n   * @description Generates a hash string for the model object\n   * @summary Defines a default implementation for object hash, relying on a basic implementation based on Java's string hash\n   * \n   * @return {string} - A hash string representing the model\n   */\n  public hash(): string {\n    return Model.hash(this);\n  }\n\n  /**\n   * @description Converts a serialized string back into a model instance\n   * @summary Deserializes a Model from its string representation\n   *\n   * @param {string} str - The serialized string to convert back to a model\n   * @return {any} - The deserialized model instance\n   * @throws {Error} If it fails to parse the string, or if it fails to build the model\n   */\n  static deserialize(str: string) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.SERIALIZATION),\n      this.constructor\n    );\n\n    if (metadata && metadata.serializer)\n      return Serialization.deserialize(\n        str,\n        metadata.serializer,\n        ...(metadata.args || [])\n      );\n    return Serialization.deserialize(str);\n  }\n\n  /**\n   * @description Copies properties from a source object to a model instance\n   * @summary Repopulates the Object properties with the ones from the new object\n   *\n   * @template T\n   * @param {T} self - The target model instance to update\n   * @param {T | Record<string, any>} [obj] - The source object containing properties to copy\n   * @return {T} - The updated model instance\n   */\n  static fromObject<T extends Model>(\n    self: T,\n    obj?: T | Record<string, any>\n  ): T {\n    if (!obj) obj = {};\n    for (const prop of Model.getAttributes(self)) {\n      (self as any)[prop] = (obj as any)[prop] || undefined;\n    }\n    return self;\n  }\n\n  /**\n   * @description Copies and rebuilds properties from a source object to a model instance, handling nested models\n   * @summary Repopulates the instance with properties from the new Model Object, recursively rebuilding nested models\n   *\n   * @template T\n   * @param {T} self - The target model instance to update\n   * @param {T | Record<string, any>} [obj] - The source object containing properties to copy\n   * @return {T} - The updated model instance with rebuilt nested models\n   * \n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Client\n   *   participant M as Model.fromModel\n   *   participant B as Model.build\n   *   participant R as Reflection\n   *   \n   *   C->>M: fromModel(self, obj)\n   *   M->>M: Get attributes from self\n   *   loop For each property\n   *     M->>M: Copy property from obj to self\n   *     alt Property is a model\n   *       M->>M: Check if property is a model\n   *       M->>B: build(property, modelType)\n   *       B-->>M: Return built model\n   *     else Property is a complex type\n   *       M->>R: Get property decorators\n   *       R-->>M: Return decorators\n   *       M->>M: Filter type decorators\n   *       alt Property is Array/Set with list decorator\n   *         M->>M: Process each item in collection\n   *         loop For each item\n   *           M->>B: build(item, itemModelType)\n   *           B-->>M: Return built model\n   *         end\n   *       else Property is another model type\n   *         M->>B: build(property, propertyType)\n   *         B-->>M: Return built model\n   *       end\n   *     end\n   *   end\n   *   M-->>C: Return updated self\n   */\n  static fromModel<T extends Model>(self: T, obj?: T | Record<string, any>): T {\n    if (!obj) obj = {};\n\n    let decorators: DecoratorMetadata[], dec: DecoratorMetadata;\n\n    const props = Model.getAttributes(self);\n\n    for (const prop of props) {\n      (self as Record<string, any>)[prop] =\n        (obj as Record<string, any>)[prop] ?? undefined;\n      if (typeof (self as any)[prop] !== \"object\") continue;\n      const propM = Model.isPropertyModel(self, prop);\n      if (propM) {\n        try {\n          (self as Record<string, any>)[prop] = Model.build(\n            (self as Record<string, any>)[prop],\n            typeof propM === \"string\" ? propM : undefined\n          );\n        } catch (e: any) {\n          console.log(e);\n        }\n        continue;\n      }\n\n      const allDecorators: DecoratorMetadata[] =\n        Reflection.getPropertyDecorators(\n          ValidationKeys.REFLECT,\n          self,\n          prop\n        ).decorators;\n      decorators = allDecorators.filter(\n        (d: DecoratorMetadata) =>\n          [ModelKeys.TYPE, ValidationKeys.TYPE as string].indexOf(d.key) !== -1\n      );\n      if (!decorators || !decorators.length)\n        throw new Error(`failed to find decorators for property ${prop}`);\n      dec = decorators.pop() as DecoratorMetadata;\n      const clazz = dec.props.name\n        ? [dec.props.name]\n        : Array.isArray(dec.props.customTypes)\n          ? dec.props.customTypes\n          : [dec.props.customTypes];\n      const reserved = Object.values(ReservedModels).map((v) =>\n        v.toLowerCase()\n      ) as string[];\n\n      clazz.forEach((c) => {\n        if (reserved.indexOf(c.toLowerCase()) === -1)\n          try {\n            switch (c) {\n              case \"Array\":\n              case \"Set\":\n                if (allDecorators.length) {\n                  const listDec = allDecorators.find(\n                    (d) => d.key === ValidationKeys.LIST\n                  );\n                  if (listDec) {\n                    const clazzName = (listDec.props.clazz as string[]).find(\n                      (t: string) => !jsTypes.includes(t.toLowerCase())\n                    );\n                    if (c === \"Array\")\n                      (self as Record<string, any>)[prop] = (\n                        self as Record<string, any>\n                      )[prop].map((el: any) => {\n                        return [\"object\", \"function\"].includes(typeof el) &&\n                          clazzName\n                          ? Model.build(el, clazzName)\n                          : el;\n                      });\n                    if (c === \"Set\") {\n                      const s = new Set();\n                      for (const v of (self as Record<string, any>)[prop]) {\n                        if (\n                          [\"object\", \"function\"].includes(typeof v) &&\n                          clazzName\n                        ) {\n                          s.add(Model.build(v, clazzName));\n                        } else {\n                          s.add(v);\n                        }\n                      }\n                      (self as Record<string, any>)[prop] = s;\n                    }\n                  }\n                }\n                break;\n              default:\n                if ((self as Record<string, any>)[prop])\n                  (self as Record<string, any>)[prop] = Model.build(\n                    (self as any)[prop],\n                    c\n                  );\n            }\n          } catch (e: any) {\n            console.log(e);\n            // do nothing. we have no registry of this class\n          }\n      });\n    }\n    return self;\n  }\n\n  /**\n   * @description Configures the global model builder function\n   * @summary Sets the Global {@link ModelBuilderFunction} used for building model instances\n   *\n   * @param {ModelBuilderFunction} [builder] - The builder function to set as the global builder\n   * @return {void}\n   */\n  static setBuilder(builder?: ModelBuilderFunction) {\n    modelBuilderFunction = builder;\n  }\n\n  /**\n   * @description Retrieves the currently configured global model builder function\n   * @summary Returns the current global {@link ModelBuilderFunction} used for building model instances\n   *\n   * @return {ModelBuilderFunction | undefined} - The current global builder function or undefined if not set\n   */\n  static getBuilder(): ModelBuilderFunction | undefined {\n    return modelBuilderFunction;\n  }\n\n  /**\n   * @description Provides access to the current model registry\n   * @summary Returns the current {@link ModelRegistryManager} instance, creating one if it doesn't exist\n   *\n   * @return {ModelRegistry<any>} - The current model registry, defaults to a new {@link ModelRegistryManager} if not set\n   * @private\n   */\n  private static getRegistry() {\n    if (!actingModelRegistry) actingModelRegistry = new ModelRegistryManager();\n    return actingModelRegistry;\n  }\n\n  /**\n   * @description Configures the model registry to be used by the Model system\n   * @summary Sets the current model registry to a custom implementation\n   *\n   * @param {BuilderRegistry<any>} modelRegistry - The new implementation of Registry to use\n   * @return {void}\n   */\n  static setRegistry(modelRegistry: BuilderRegistry<any>) {\n    actingModelRegistry = modelRegistry;\n  }\n\n  /**\n   * @description Registers a model constructor with the model registry\n   * @summary Registers new model classes to make them available for serialization and deserialization\n   *\n   * @template T\n   * @param {ModelConstructor<T>} constructor - The model constructor to register\n   * @param {string} [name] - Optional name to register the constructor under, defaults to constructor.name\n   * @return {void}\n   * \n   * @see ModelRegistry\n   */\n  static register<T extends Model>(\n    constructor: ModelConstructor<T>,\n    name?: string\n  ): void {\n    return Model.getRegistry().register(constructor, name);\n  }\n\n  /**\n   * @description Retrieves a registered model constructor by name\n   * @summary Gets a registered Model {@link ModelConstructor} from the model registry\n   *\n   * @template T\n   * @param {string} name - The name of the model constructor to retrieve\n   * @return {ModelConstructor<T> | undefined} - The model constructor if found, undefined otherwise\n   * \n   * @see ModelRegistry\n   */\n  static get<T extends Model>(name: string): ModelConstructor<T> | undefined {\n    return Model.getRegistry().get(name);\n  }\n\n  /**\n   * @description Creates a model instance from a plain object\n   * @summary Builds a model instance using the model registry, optionally specifying the model class\n   *\n   * @template T\n   * @param {Record<string, any>} obj - The source object to build the model from\n   * @param {string} [clazz] - When provided, it will attempt to find the matching constructor by name\n   * @return {T} - The built model instance\n   * @throws {Error} If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n   *\n   * @see ModelRegistry\n   */\n  static build<T extends Model>(\n    obj: Record<string, any> = {},\n    clazz?: string\n  ): T {\n    return Model.getRegistry().build(obj, clazz);\n  }\n\n  /**\n   * @description Retrieves the model metadata from a model instance\n   * @summary Gets the metadata associated with a model instance, typically the model class name\n   *\n   * @template M\n   * @param {M} model - The model instance to get metadata from\n   * @return {string} - The model metadata (typically the class name)\n   */\n  static getMetadata<M extends Model>(model: M) {\n    return getMetadata<M>(model);\n  }\n\n  /**\n   * @description Retrieves all attribute names from a model class or instance\n   * @summary Gets all attributes defined in a model, traversing the prototype chain to include inherited attributes\n   *\n   * @template V\n   * @param {Constructor<V> | V} model - The model class or instance to get attributes from\n   * @return {string[]} - Array of attribute names defined in the model\n   */\n  static getAttributes<V extends Model>(model: Constructor<V> | V) {\n    const result: string[] = [];\n    let prototype =\n      model instanceof Model\n        ? Object.getPrototypeOf(model)\n        : (model as any).prototype;\n    while (prototype != null) {\n      const props: string[] = prototype[ModelKeys.ATTRIBUTE];\n      if (props) {\n        result.push(...props);\n      }\n      prototype = Object.getPrototypeOf(prototype);\n    }\n    return result;\n  }\n\n  /**\n   * @description Compares two model instances for equality\n   * @summary Determines if two model instances are equal by comparing their properties\n   *\n   * @template M\n   * @param {M} obj1 - First model instance to compare\n   * @param {M} obj2 - Second model instance to compare\n   * @param {any[]} [exceptions] - Property names to exclude from comparison\n   * @return {boolean} - True if the models are equal, false otherwise\n   */\n  static equals<M extends Model>(obj1: M, obj2: M, ...exceptions: any[]) {\n    return isEqual(obj1, obj2, ...exceptions);\n  }\n\n  /**\n   * @description Validates a model instance against its validation rules\n   * @summary Checks if a model has validation errors, optionally ignoring specified properties\n   *\n   * @template M\n   * @param {M} model - The model instance to validate\n   * @param {string[]} [propsToIgnore] - Properties to exclude from validation\n   * @return {ModelErrorDefinition | undefined} - Returns validation errors if any, otherwise undefined\n   */\n  static hasErrors<M extends Model>(model: M, ...propsToIgnore: string[]) {\n    return validate(model, ...propsToIgnore);\n  }\n\n  /**\n   * @description Converts a model instance to a serialized string\n   * @summary Serializes a model instance using the configured serializer or the default one\n   *\n   * @template M\n   * @param {M} model - The model instance to serialize\n   * @return {string} - The serialized string representation of the model\n   */\n  static serialize<M extends Model>(model: M) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.SERIALIZATION),\n      model.constructor\n    );\n\n    if (metadata && metadata.serializer)\n      return Serialization.serialize(\n        this,\n        metadata.serializer,\n        ...(metadata.args || [])\n      );\n    return Serialization.serialize(model);\n  }\n\n  /**\n   * @description Generates a hash string for a model instance\n   * @summary Creates a hash representation of a model using the configured algorithm or the default one\n   *\n   * @template M\n   * @param {M} model - The model instance to hash\n   * @return {string} - The hash string representing the model\n   */\n  static hash<M extends Model>(model: M) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.HASHING),\n      model.constructor\n    );\n\n    if (metadata && metadata.algorithm)\n      return Hashing.hash(model, metadata.algorithm, ...(metadata.args || []));\n    return Hashing.hash(model);\n  }\n  /**\n   * @description Creates a metadata key for use with the Reflection API\n   * @summary Builds the key to store as Metadata under Reflections\n   *\n   * @param {string} str - The base key to concatenate with the model reflection prefix\n   * @return {string} - The complete metadata key\n   */\n  static key(str: string) {\n    return getModelKey(str);\n  }\n\n  /**\n   * @description Determines if an object is a model instance or has model metadata\n   * @summary Checks whether a given object is either an instance of the Model class or\n   * has model metadata attached to it. This function is essential for serialization and\n   * deserialization processes, as it helps identify model objects that need special handling.\n   * It safely handles potential errors during metadata retrieval.\n   *\n   * @param {Record<string, any>} target - The object to check\n   * @return {boolean} True if the object is a model instance or has model metadata, false otherwise\n   *\n   * @example\n   * ```typescript\n   * // Check if an object is a model\n   * const user = new User({ name: \"John\" });\n   * const isUserModel = isModel(user); // true\n   *\n   * // Check a plain object\n   * const plainObject = { name: \"John\" };\n   * const isPlainObjectModel = isModel(plainObject); // false\n   * ```\n   */\n  static isModel(target: Record<string, any>) {\n    try {\n      return target instanceof Model || !!Model.getMetadata(target as any);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      return false;\n    }\n  }\n\n  /**\n   * @description Checks if a property of a model is itself a model or has a model type\n   * @summary Determines whether a specific property of a model instance is either a model instance\n   * or has a type that is registered as a model\n   *\n   * @template M\n   * @param {M} target - The model instance to check\n   * @param {string} attribute - The property name to check\n   * @return {boolean | string | undefined} - Returns true if the property is a model instance,\n   * the model name if the property has a model type, or undefined if not a model\n   */\n  static isPropertyModel<M extends Model>(\n    target: M,\n    attribute: string\n  ): boolean | string | undefined {\n    if (Model.isModel((target as Record<string, any>)[attribute])) return true;\n    const metadata = Reflect.getMetadata(ModelKeys.TYPE, target, attribute);\n    return Model.get(metadata.name) ? metadata.name : undefined;\n  }\n}\n"]}
|
|
588
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Model.js","sourceRoot":"","sources":["../../../src/model/Model.ts"],"names":[],"mappings":"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","sourcesContent":["import { Serialization } from \"../utils/serialization\";\nimport { BuilderRegistry } from \"../utils/registry\";\nimport { ModelErrorDefinition } from \"./ModelErrorDefinition\";\nimport {\n  Comparable,\n  Constructor,\n  Hashable,\n  ModelArg,\n  ModelBuilderFunction,\n  ModelConstructor,\n  Serializable,\n  Validatable,\n} from \"./types\";\nimport { DecoratorMetadata, isEqual, Reflection } from \"@decaf-ts/reflection\";\nimport { validate } from \"./validation\";\nimport { Hashing } from \"../utils/hashing\";\nimport { ModelKeys } from \"../utils/constants\";\nimport { ValidationKeys } from \"../validation/Validators/constants\";\nimport { jsTypes, ReservedModels } from \"./constants\";\nimport { getModelKey, getMetadata } from \"./utils\";\n\nlet modelBuilderFunction: ModelBuilderFunction | undefined;\nlet actingModelRegistry: BuilderRegistry<any>;\n\n/**\n * @description Registry type for storing and retrieving model constructors\n * @summary The ModelRegistry type defines a registry for model constructors that extends\n * the BuilderRegistry interface. It provides a standardized way to register, retrieve,\n * and build model instances, enabling the model system to work with different types of models.\n *\n * @interface ModelRegistry\n * @template T Type of model that can be registered, must extend Model\n * @extends BuilderRegistry<T>\n * @memberOf module:decorator-validation\n * @category Model\n */\nexport type ModelRegistry<T extends Model> = BuilderRegistry<T>;\n\n/**\n * @description Registry manager for model constructors that enables serialization and rebuilding\n * @summary The ModelRegistryManager implements the ModelRegistry interface and provides\n * functionality for registering, retrieving, and building model instances. It maintains\n * a cache of model constructors indexed by name, allowing for efficient lookup and instantiation.\n * This class is essential for the serialization and deserialization of model objects.\n *\n * @param {function(Record<string, any>): boolean} [testFunction] - Function to test if an object is a model, defaults to {@link Model#isModel}\n *\n * @class ModelRegistryManager\n * @template M Type of model that can be registered, must extend Model\n * @implements ModelRegistry<M>\n * @category Model\n *\n * @example\n * ```typescript\n * // Create a model registry\n * const registry = new ModelRegistryManager();\n *\n * // Register a model class\n * registry.register(User);\n *\n * // Retrieve a model constructor by name\n * const UserClass = registry.get(\"User\");\n *\n * // Build a model instance from a plain object\n * const userData = { name: \"John\", age: 30 };\n * const user = registry.build(userData, \"User\");\n * ```\n *\n * @mermaid\n * sequenceDiagram\n *   participant C as Client\n *   participant R as ModelRegistryManager\n *   participant M as Model Class\n *\n *   C->>R: new ModelRegistryManager(testFunction)\n *   C->>R: register(ModelClass)\n *   R->>R: Store in cache\n *   C->>R: get(\"ModelName\")\n *   R-->>C: ModelClass constructor\n *   C->>R: build(data, \"ModelName\")\n *   R->>R: Get constructor from cache\n *   R->>M: new ModelClass(data)\n *   M-->>R: Model instance\n *   R-->>C: Model instance\n */\nexport class ModelRegistryManager<M extends Model> implements ModelRegistry<M> {\n  private cache: Record<string, ModelConstructor<M>> = {};\n  private readonly testFunction: (obj: object) => boolean;\n\n  constructor(\n    testFunction: (obj: Record<string, any>) => boolean = Model.isModel\n  ) {\n    this.testFunction = testFunction;\n  }\n\n  /**\n   * @description Registers a model constructor with the registry\n   * @summary Adds a model constructor to the registry cache, making it available for\n   * later retrieval and instantiation. If no name is provided, the constructor's name\n   * property is used as the key in the registry.\n   *\n   * @param {ModelConstructor<M>} constructor - The model constructor to register\n   * @param {string} [name] - Optional name to register the constructor under, defaults to constructor.name\n   * @return {void}\n   * @throws {Error} If the constructor is not a function\n   */\n  register(constructor: ModelConstructor<M>, name?: string): void {\n    if (typeof constructor !== \"function\")\n      throw new Error(\n        \"Model registering failed. Missing Class name or constructor\"\n      );\n    name = name || constructor.name;\n    this.cache[name] = constructor;\n  }\n\n  /**\n   * @summary Gets a registered Model {@link ModelConstructor}\n   * @param {string} name\n   */\n  get(name: string): ModelConstructor<M> | undefined {\n    try {\n      return this.cache[name];\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      return undefined;\n    }\n  }\n\n  /**\n   * @param {Record<string, any>} obj\n   * @param {string} [clazz] when provided, it will attempt to find the matching constructor\n   *\n   * @throws Error If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n   */\n  build(obj: Record<string, any> = {}, clazz?: string): M {\n    if (!clazz && !this.testFunction(obj))\n      throw new Error(\"Provided obj is not a Model object\");\n    const name = clazz || Model.getMetadata(obj as any);\n    if (!(name in this.cache))\n      throw new Error(\n        `Provided class ${name} is not a registered Model object`\n      );\n    return new this.cache[name](obj);\n  }\n}\n\n/**\n * @summary Bulk Registers Models\n * @description Useful when using bundlers that might not evaluate all the code at once\n *\n * @template M extends Model\n * @param {Array<Constructor<M>> | Array<{name: string, constructor: Constructor<M>}>} [models]\n *\n * @memberOf module:decorator-validation\n * @category Model\n */\nexport function bulkModelRegister<M extends Model>(\n  ...models: (Constructor<M> | { name: string; constructor: Constructor<M> })[]\n) {\n  models.forEach(\n    (m: Constructor<M> | { name: string; constructor: Constructor<M> }) => {\n      const constructor: Constructor<M> = (\n        m.constructor ? m.constructor : m\n      ) as Constructor<M>;\n      Model.register(constructor, (m as Constructor<M>).name);\n    }\n  );\n}\n\n/**\n * @summary Abstract class representing a Validatable Model object\n * @description Meant to be used as a base class for all Model classes\n *\n * Model objects must:\n *  - Have all their required properties marked with '!';\n *  - Have all their optional properties marked as '?':\n *\n * @param {ModelArg<Model>} model base object from which to populate properties from\n *\n * @class Model\n * @category Model\n * @abstract\n * @implements Validatable\n * @implements Serializable\n *\n * @example\n *      class ClassName {\n *          @required()\n *          requiredPropertyName!: PropertyType;\n *\n *          optionalPropertyName?: PropertyType;\n *      }\n */\nexport abstract class Model\n  implements Validatable, Serializable, Hashable, Comparable<Model>\n{\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  protected constructor(arg?: ModelArg<Model>) {}\n\n  /**\n   * @description Validates the model object against its defined validation rules\n   * @summary Validates the object according to its decorated properties, returning any validation errors\n   *\n   * @param {any[]} [exceptions] - Properties in the object to be ignored for the validation. Marked as 'any' to allow for extension but expects strings\n   * @return {ModelErrorDefinition | undefined} - Returns a ModelErrorDefinition object if validation errors exist, otherwise undefined\n   */\n  public hasErrors(...exceptions: any[]): ModelErrorDefinition | undefined {\n    return validate(this, ...exceptions);\n  }\n\n  /**\n   * @description Determines if this model is equal to another object\n   * @summary Compare object equality recursively, checking all properties unless excluded\n   *\n   * @param {any} obj - Object to compare to\n   * @param {string[]} [exceptions] - Property names to be excluded from the comparison\n   * @return {boolean} - True if objects are equal, false otherwise\n   */\n  public equals(obj: any, ...exceptions: string[]): boolean {\n    return isEqual(this, obj, ...exceptions);\n  }\n\n  /**\n   * @description Converts the model to a serialized string representation\n   * @summary Returns the serialized model according to the currently defined {@link Serializer}\n   *\n   * @return {string} - The serialized string representation of the model\n   */\n  serialize(): string {\n    return Model.serialize(this);\n  }\n\n  /**\n   * @description Provides a human-readable string representation of the model\n   * @summary Override the implementation for js's 'toString()' to provide a more useful representation\n   *\n   * @return {string} - A string representation of the model including its class name and JSON representation\n   * @override\n   */\n  public toString(): string {\n    return this.constructor.name + \": \" + JSON.stringify(this, undefined, 2);\n  }\n\n  /**\n   * @description Generates a hash string for the model object\n   * @summary Defines a default implementation for object hash, relying on a basic implementation based on Java's string hash\n   *\n   * @return {string} - A hash string representing the model\n   */\n  public hash(): string {\n    return Model.hash(this);\n  }\n\n  /**\n   * @description Converts a serialized string back into a model instance\n   * @summary Deserializes a Model from its string representation\n   *\n   * @param {string} str - The serialized string to convert back to a model\n   * @return {any} - The deserialized model instance\n   * @throws {Error} If it fails to parse the string, or if it fails to build the model\n   */\n  static deserialize(str: string) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.SERIALIZATION),\n      this.constructor\n    );\n\n    if (metadata && metadata.serializer)\n      return Serialization.deserialize(\n        str,\n        metadata.serializer,\n        ...(metadata.args || [])\n      );\n    return Serialization.deserialize(str);\n  }\n\n  /**\n   * @description Copies properties from a source object to a model instance\n   * @summary Repopulates the Object properties with the ones from the new object\n   *\n   * @template T\n   * @param {T} self - The target model instance to update\n   * @param {T | Record<string, any>} [obj] - The source object containing properties to copy\n   * @return {T} - The updated model instance\n   */\n  static fromObject<T extends Model>(\n    self: T,\n    obj?: T | Record<string, any>\n  ): T {\n    if (!obj) obj = {};\n    for (const prop of Model.getAttributes(self)) {\n      (self as any)[prop] = (obj as any)[prop] || undefined;\n    }\n    return self;\n  }\n\n  /**\n   * @description Copies and rebuilds properties from a source object to a model instance, handling nested models\n   * @summary Repopulates the instance with properties from the new Model Object, recursively rebuilding nested models\n   *\n   * @template T\n   * @param {T} self - The target model instance to update\n   * @param {T | Record<string, any>} [obj] - The source object containing properties to copy\n   * @return {T} - The updated model instance with rebuilt nested models\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant C as Client\n   *   participant M as Model.fromModel\n   *   participant B as Model.build\n   *   participant R as Reflection\n   *\n   *   C->>M: fromModel(self, obj)\n   *   M->>M: Get attributes from self\n   *   loop For each property\n   *     M->>M: Copy property from obj to self\n   *     alt Property is a model\n   *       M->>M: Check if property is a model\n   *       M->>B: build(property, modelType)\n   *       B-->>M: Return built model\n   *     else Property is a complex type\n   *       M->>R: Get property decorators\n   *       R-->>M: Return decorators\n   *       M->>M: Filter type decorators\n   *       alt Property is Array/Set with list decorator\n   *         M->>M: Process each item in collection\n   *         loop For each item\n   *           M->>B: build(item, itemModelType)\n   *           B-->>M: Return built model\n   *         end\n   *       else Property is another model type\n   *         M->>B: build(property, propertyType)\n   *         B-->>M: Return built model\n   *       end\n   *     end\n   *   end\n   *   M-->>C: Return updated self\n   */\n  static fromModel<T extends Model>(self: T, obj?: T | Record<string, any>): T {\n    if (!obj) obj = {};\n\n    let decorators: DecoratorMetadata[], dec: DecoratorMetadata;\n\n    const props = Model.getAttributes(self);\n\n    for (const prop of props) {\n      (self as Record<string, any>)[prop] =\n        (obj as Record<string, any>)[prop] ?? undefined;\n      if (typeof (self as any)[prop] !== \"object\") continue;\n      const propM = Model.isPropertyModel(self, prop);\n      if (propM) {\n        try {\n          (self as Record<string, any>)[prop] = Model.build(\n            (self as Record<string, any>)[prop],\n            typeof propM === \"string\" ? propM : undefined\n          );\n        } catch (e: any) {\n          console.log(e);\n        }\n        continue;\n      }\n\n      const allDecorators: DecoratorMetadata[] =\n        Reflection.getPropertyDecorators(\n          ValidationKeys.REFLECT,\n          self,\n          prop\n        ).decorators;\n      decorators = allDecorators.filter(\n        (d: DecoratorMetadata) =>\n          [ModelKeys.TYPE, ValidationKeys.TYPE as string].indexOf(d.key) !== -1\n      );\n      if (!decorators || !decorators.length)\n        throw new Error(`failed to find decorators for property ${prop}`);\n      dec = decorators.pop() as DecoratorMetadata;\n      const clazz = dec.props.name\n        ? [dec.props.name]\n        : Array.isArray(dec.props.customTypes)\n          ? dec.props.customTypes\n          : [dec.props.customTypes];\n      const reserved = Object.values(ReservedModels).map((v) =>\n        v.toLowerCase()\n      ) as string[];\n\n      clazz.forEach((c) => {\n        if (reserved.indexOf(c.toLowerCase()) === -1)\n          try {\n            switch (c) {\n              case \"Array\":\n              case \"Set\":\n                if (allDecorators.length) {\n                  const listDec = allDecorators.find(\n                    (d) => d.key === ValidationKeys.LIST\n                  );\n                  if (listDec) {\n                    const clazzName = (listDec.props.clazz as string[]).find(\n                      (t: string) => !jsTypes.includes(t.toLowerCase())\n                    );\n                    if (c === \"Array\")\n                      (self as Record<string, any>)[prop] = (\n                        self as Record<string, any>\n                      )[prop].map((el: any) => {\n                        return [\"object\", \"function\"].includes(typeof el) &&\n                          clazzName\n                          ? Model.build(el, clazzName)\n                          : el;\n                      });\n                    if (c === \"Set\") {\n                      const s = new Set();\n                      for (const v of (self as Record<string, any>)[prop]) {\n                        if (\n                          [\"object\", \"function\"].includes(typeof v) &&\n                          clazzName\n                        ) {\n                          s.add(Model.build(v, clazzName));\n                        } else {\n                          s.add(v);\n                        }\n                      }\n                      (self as Record<string, any>)[prop] = s;\n                    }\n                  }\n                }\n                break;\n              default:\n                if (\n                  typeof self[prop as keyof typeof self] !== \"undefined\" &&\n                  Model.get(c)\n                )\n                  (self as Record<string, any>)[prop] = Model.build(\n                    (self as any)[prop],\n                    c\n                  );\n            }\n          } catch (e: any) {\n            console.log(e);\n            // do nothing. we have no registry of this class\n          }\n      });\n    }\n    return self;\n  }\n\n  /**\n   * @description Configures the global model builder function\n   * @summary Sets the Global {@link ModelBuilderFunction} used for building model instances\n   *\n   * @param {ModelBuilderFunction} [builder] - The builder function to set as the global builder\n   * @return {void}\n   */\n  static setBuilder(builder?: ModelBuilderFunction) {\n    modelBuilderFunction = builder;\n  }\n\n  /**\n   * @description Retrieves the currently configured global model builder function\n   * @summary Returns the current global {@link ModelBuilderFunction} used for building model instances\n   *\n   * @return {ModelBuilderFunction | undefined} - The current global builder function or undefined if not set\n   */\n  static getBuilder(): ModelBuilderFunction | undefined {\n    return modelBuilderFunction || Model.fromModel;\n  }\n\n  /**\n   * @description Provides access to the current model registry\n   * @summary Returns the current {@link ModelRegistryManager} instance, creating one if it doesn't exist\n   *\n   * @return {ModelRegistry<any>} - The current model registry, defaults to a new {@link ModelRegistryManager} if not set\n   * @private\n   */\n  private static getRegistry() {\n    if (!actingModelRegistry) actingModelRegistry = new ModelRegistryManager();\n    return actingModelRegistry;\n  }\n\n  /**\n   * @description Configures the model registry to be used by the Model system\n   * @summary Sets the current model registry to a custom implementation\n   *\n   * @param {BuilderRegistry<any>} modelRegistry - The new implementation of Registry to use\n   * @return {void}\n   */\n  static setRegistry(modelRegistry: BuilderRegistry<any>) {\n    actingModelRegistry = modelRegistry;\n  }\n\n  /**\n   * @description Registers a model constructor with the model registry\n   * @summary Registers new model classes to make them available for serialization and deserialization\n   *\n   * @template T\n   * @param {ModelConstructor<T>} constructor - The model constructor to register\n   * @param {string} [name] - Optional name to register the constructor under, defaults to constructor.name\n   * @return {void}\n   *\n   * @see ModelRegistry\n   */\n  static register<T extends Model>(\n    constructor: ModelConstructor<T>,\n    name?: string\n  ): void {\n    return Model.getRegistry().register(constructor, name);\n  }\n\n  /**\n   * @description Retrieves a registered model constructor by name\n   * @summary Gets a registered Model {@link ModelConstructor} from the model registry\n   *\n   * @template T\n   * @param {string} name - The name of the model constructor to retrieve\n   * @return {ModelConstructor<T> | undefined} - The model constructor if found, undefined otherwise\n   *\n   * @see ModelRegistry\n   */\n  static get<T extends Model>(name: string): ModelConstructor<T> | undefined {\n    return Model.getRegistry().get(name);\n  }\n\n  /**\n   * @description Creates a model instance from a plain object\n   * @summary Builds a model instance using the model registry, optionally specifying the model class\n   *\n   * @template T\n   * @param {Record<string, any>} obj - The source object to build the model from\n   * @param {string} [clazz] - When provided, it will attempt to find the matching constructor by name\n   * @return {T} - The built model instance\n   * @throws {Error} If clazz is not found, or obj is not a {@link Model} meaning it has no {@link ModelKeys.ANCHOR} property\n   *\n   * @see ModelRegistry\n   */\n  static build<T extends Model>(\n    obj: Record<string, any> = {},\n    clazz?: string\n  ): T {\n    return Model.getRegistry().build(obj, clazz);\n  }\n\n  /**\n   * @description Retrieves the model metadata from a model instance\n   * @summary Gets the metadata associated with a model instance, typically the model class name\n   *\n   * @template M\n   * @param {M} model - The model instance to get metadata from\n   * @return {string} - The model metadata (typically the class name)\n   */\n  static getMetadata<M extends Model>(model: M) {\n    return getMetadata<M>(model);\n  }\n\n  /**\n   * @description Retrieves all attribute names from a model class or instance\n   * @summary Gets all attributes defined in a model, traversing the prototype chain to include inherited attributes\n   *\n   * @template V\n   * @param {Constructor<V> | V} model - The model class or instance to get attributes from\n   * @return {string[]} - Array of attribute names defined in the model\n   */\n  static getAttributes<V extends Model>(model: Constructor<V> | V) {\n    const result: string[] = [];\n    let prototype =\n      model instanceof Model\n        ? Object.getPrototypeOf(model)\n        : (model as any).prototype;\n    while (prototype != null) {\n      const props: string[] = prototype[ModelKeys.ATTRIBUTE];\n      if (props) {\n        result.push(...props);\n      }\n      prototype = Object.getPrototypeOf(prototype);\n    }\n    return result;\n  }\n\n  /**\n   * @description Compares two model instances for equality\n   * @summary Determines if two model instances are equal by comparing their properties\n   *\n   * @template M\n   * @param {M} obj1 - First model instance to compare\n   * @param {M} obj2 - Second model instance to compare\n   * @param {any[]} [exceptions] - Property names to exclude from comparison\n   * @return {boolean} - True if the models are equal, false otherwise\n   */\n  static equals<M extends Model>(obj1: M, obj2: M, ...exceptions: any[]) {\n    return isEqual(obj1, obj2, ...exceptions);\n  }\n\n  /**\n   * @description Validates a model instance against its validation rules\n   * @summary Checks if a model has validation errors, optionally ignoring specified properties\n   *\n   * @template M\n   * @param {M} model - The model instance to validate\n   * @param {string[]} [propsToIgnore] - Properties to exclude from validation\n   * @return {ModelErrorDefinition | undefined} - Returns validation errors if any, otherwise undefined\n   */\n  static hasErrors<M extends Model>(model: M, ...propsToIgnore: string[]) {\n    return validate(model, ...propsToIgnore);\n  }\n\n  /**\n   * @description Converts a model instance to a serialized string\n   * @summary Serializes a model instance using the configured serializer or the default one\n   *\n   * @template M\n   * @param {M} model - The model instance to serialize\n   * @return {string} - The serialized string representation of the model\n   */\n  static serialize<M extends Model>(model: M) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.SERIALIZATION),\n      model.constructor\n    );\n\n    if (metadata && metadata.serializer)\n      return Serialization.serialize(\n        this,\n        metadata.serializer,\n        ...(metadata.args || [])\n      );\n    return Serialization.serialize(model);\n  }\n\n  /**\n   * @description Generates a hash string for a model instance\n   * @summary Creates a hash representation of a model using the configured algorithm or the default one\n   *\n   * @template M\n   * @param {M} model - The model instance to hash\n   * @return {string} - The hash string representing the model\n   */\n  static hash<M extends Model>(model: M) {\n    const metadata = Reflect.getMetadata(\n      Model.key(ModelKeys.HASHING),\n      model.constructor\n    );\n\n    if (metadata && metadata.algorithm)\n      return Hashing.hash(model, metadata.algorithm, ...(metadata.args || []));\n    return Hashing.hash(model);\n  }\n  /**\n   * @description Creates a metadata key for use with the Reflection API\n   * @summary Builds the key to store as Metadata under Reflections\n   *\n   * @param {string} str - The base key to concatenate with the model reflection prefix\n   * @return {string} - The complete metadata key\n   */\n  static key(str: string) {\n    return getModelKey(str);\n  }\n\n  /**\n   * @description Determines if an object is a model instance or has model metadata\n   * @summary Checks whether a given object is either an instance of the Model class or\n   * has model metadata attached to it. This function is essential for serialization and\n   * deserialization processes, as it helps identify model objects that need special handling.\n   * It safely handles potential errors during metadata retrieval.\n   *\n   * @param {Record<string, any>} target - The object to check\n   * @return {boolean} True if the object is a model instance or has model metadata, false otherwise\n   *\n   * @example\n   * ```typescript\n   * // Check if an object is a model\n   * const user = new User({ name: \"John\" });\n   * const isUserModel = isModel(user); // true\n   *\n   * // Check a plain object\n   * const plainObject = { name: \"John\" };\n   * const isPlainObjectModel = isModel(plainObject); // false\n   * ```\n   */\n  static isModel(target: Record<string, any>) {\n    try {\n      return target instanceof Model || !!Model.getMetadata(target as any);\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    } catch (e: any) {\n      return false;\n    }\n  }\n\n  /**\n   * @description Checks if a property of a model is itself a model or has a model type\n   * @summary Determines whether a specific property of a model instance is either a model instance\n   * or has a type that is registered as a model\n   *\n   * @template M\n   * @param {M} target - The model instance to check\n   * @param {string} attribute - The property name to check\n   * @return {boolean | string | undefined} - Returns true if the property is a model instance,\n   * the model name if the property has a model type, or undefined if not a model\n   */\n  static isPropertyModel<M extends Model>(\n    target: M,\n    attribute: string\n  ): boolean | string | undefined {\n    if (Model.isModel((target as Record<string, any>)[attribute])) return true;\n    const metadata = Reflect.getMetadata(ModelKeys.TYPE, target, attribute);\n    return Model.get(metadata.name) ? metadata.name : undefined;\n  }\n\n  static describe<M extends Model>(model: M | Constructor<M>, key?: keyof M) {\n    const descKey = Model.key(ModelKeys.DESCRIPTION);\n    if (key) {\n      model = model instanceof Model ? model : new model();\n      return (\n        Reflect.getMetadataKeys(model.constructor, key.toString())\n          .find((k) => k === descKey)\n          ?.toString() || model.toString()\n      );\n    }\n\n    return (\n      Reflect.getMetadata(\n        Model.key(ModelKeys.DESCRIPTION),\n        model instanceof Model ? model.constructor : model\n      ) || model.toString()\n    );\n  }\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Model } from "./Model";
|
|
1
|
+
import { Model } from "./Model.js";
|
|
2
2
|
/**
|
|
3
3
|
* @summary Helper Function to override constructors
|
|
4
4
|
*
|
|
@@ -63,4 +63,4 @@ export function bindModelPrototype(obj) {
|
|
|
63
63
|
}
|
|
64
64
|
throw new Error("Could not find proper prototype to bind");
|
|
65
65
|
}
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RydWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21vZGVsL2NvbnN0cnVjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsS0FBSyxFQUFFLG1CQUFnQjtBQUVoQzs7Ozs7Ozs7Ozs7R0FXRztBQUNILE1BQU0sVUFBVSxTQUFTLENBQ3ZCLFdBQWdCLEVBQ2hCLEdBQUcsSUFBVztJQUVkLE1BQU0sT0FBTyxHQUFHLENBQUMsR0FBRyxJQUFXLEVBQUUsRUFBRSxDQUFDLElBQUksV0FBVyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7SUFDN0QsT0FBTyxDQUFDLFNBQVMsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDO0lBQzFDLE9BQU8sT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUM7QUFDMUIsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSx5QkFBeUIsQ0FBQyxHQUFXO0lBQ25ELElBQUksU0FBUyxHQUFRLE1BQU0sQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDaEQsSUFBSSxTQUFTLEtBQUssTUFBTSxDQUFDLFNBQVM7UUFBRSxPQUFPLEdBQUcsQ0FBQztJQUMvQyxPQUFPLFNBQVMsS0FBSyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDdEMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDN0MsSUFBSSxTQUFTLEtBQUssTUFBTSxDQUFDLFNBQVM7WUFBRSxPQUFPLFNBQVMsQ0FBQztRQUNyRCxJQUFJLE1BQU0sQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLEtBQUssTUFBTSxDQUFDLFNBQVM7WUFBRSxPQUFPLFNBQVMsQ0FBQztJQUM5RSxDQUFDO0lBQ0QsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBQ3JELENBQUM7QUFFRDs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEdBQVk7SUFDN0MsSUFBSSxHQUFHLFlBQVksS0FBSztRQUFFLE9BQU87SUFFakMsU0FBUyxhQUFhLENBQUMsYUFBc0IsRUFBRSxTQUFpQjtRQUM5RCxNQUFNLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsTUFBTSxTQUFTLEdBQVEsTUFBTSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNsRCxJQUFJLFNBQVMsS0FBSyxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDbkMsT0FBTyxhQUFhLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBQ0QsT0FBTyxTQUFTLEtBQUssTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO1FBQ3RDLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDOUMsSUFDRSxJQUFJLEtBQUssTUFBTSxDQUFDLFNBQVM7WUFDekIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxNQUFNLENBQUMsU0FBUyxFQUNoRCxDQUFDO1lBQ0QsT0FBTyxhQUFhLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNuRCxDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sSUFBSSxLQUFLLENBQUMseUNBQXlDLENBQUMsQ0FBQztBQUM3RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWwgfSBmcm9tIFwiLi9Nb2RlbFwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IEhlbHBlciBGdW5jdGlvbiB0byBvdmVycmlkZSBjb25zdHJ1Y3RvcnNcbiAqXG4gKiBAdGVtcGxhdGUgTSB0aGUgbW9kZWwgaW5zdGFuY2UgdHlwZVxuICpcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGNvbnN0cnVjdG9yXG4gKiBAcGFyYW0ge2FueVtdfSBbYXJnc11cbiAqIEByZXR1cm4ge019IHRoZSBuZXcgaW5zdGFuY2VcbiAqXG4gKiBAZnVuY3Rpb24gY29uc3RydWN0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb25zdHJ1Y3Q8TSBleHRlbmRzIE1vZGVsPihcbiAgY29uc3RydWN0b3I6IGFueSxcbiAgLi4uYXJnczogYW55W11cbik6IE0ge1xuICBjb25zdCBfY29uc3RyID0gKC4uLmFyZ3o6IGFueVtdKSA9PiBuZXcgY29uc3RydWN0b3IoLi4uYXJneik7XG4gIF9jb25zdHIucHJvdG90eXBlID0gY29uc3RydWN0b3IucHJvdG90eXBlO1xuICByZXR1cm4gX2NvbnN0ciguLi5hcmdzKTtcbn1cblxuLyoqXG4gKiBAc3VtbWFyeSBSZWN1cnNpdmVseSBmaW5kcyB0aGUgbGFzdCBwcm90b3R5cGUgYmVmb3JlIE9iamVjdFxuICogQHBhcmFtIHtvYmplY3R9IG9ialxuICpcbiAqIEBmdW5jdGlvbiBmaW5kTGFzdFByb3RvQmVmb3JlT2JqZWN0XG4gKiBAbWVtYmVyT2YgbW9kdWxlOmRlY29yYXRvci12YWxpZGF0aW9uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBmaW5kTGFzdFByb3RvQmVmb3JlT2JqZWN0KG9iajogb2JqZWN0KTogb2JqZWN0IHtcbiAgbGV0IHByb3RvdHlwZTogYW55ID0gT2JqZWN0LmdldFByb3RvdHlwZU9mKG9iaik7XG4gIGlmIChwcm90b3R5cGUgPT09IE9iamVjdC5wcm90b3R5cGUpIHJldHVybiBvYmo7XG4gIHdoaWxlIChwcm90b3R5cGUgIT09IE9iamVjdC5wcm90b3R5cGUpIHtcbiAgICBwcm90b3R5cGUgPSBPYmplY3QuZ2V0UHJvdG90eXBlT2YocHJvdG90eXBlKTtcbiAgICBpZiAocHJvdG90eXBlID09PSBPYmplY3QucHJvdG90eXBlKSByZXR1cm4gcHJvdG90eXBlO1xuICAgIGlmIChPYmplY3QuZ2V0UHJvdG90eXBlT2YocHJvdG90eXBlKSA9PT0gT2JqZWN0LnByb3RvdHlwZSkgcmV0dXJuIHByb3RvdHlwZTtcbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoXCJDb3VsZCBub3QgZmluZCBwcm9wZXIgcHJvdG90eXBlXCIpO1xufVxuXG4vKipcbiAqIEBzdW1hcnkgYmluZHMgdGhlIHtAbGluayBNb2RlbH0gY2xhc3MgYXMgYSByb290IHByb3RvdHlwZSBvZiB0aGUgcHJvdmlkZWQgaW5zdGFuY2VcbiAqXG4gKiBAcGFyYW0ge3Vua25vd259IG9ialxuICpcbiAqIEBmdW5jdGlvbiBiaW5kTW9kZWxQcm90b3R5cGVcbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGJpbmRNb2RlbFByb3RvdHlwZShvYmo6IHVua25vd24pIHtcbiAgaWYgKG9iaiBpbnN0YW5jZW9mIE1vZGVsKSByZXR1cm47XG5cbiAgZnVuY3Rpb24gYmluZFByb3RvdHlwZShvYmpUb092ZXJyaWRlOiB1bmtub3duLCBwcm90b3R5cGU6IG9iamVjdCkge1xuICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZihvYmpUb092ZXJyaWRlLCBwcm90b3R5cGUpO1xuICB9XG5cbiAgY29uc3QgcHJvdG90eXBlOiBhbnkgPSBPYmplY3QuZ2V0UHJvdG90eXBlT2Yob2JqKTtcbiAgaWYgKHByb3RvdHlwZSA9PT0gT2JqZWN0LnByb3RvdHlwZSkge1xuICAgIHJldHVybiBiaW5kUHJvdG90eXBlKG9iaiwgTW9kZWwucHJvdG90eXBlKTtcbiAgfVxuICB3aGlsZSAocHJvdG90eXBlICE9PSBPYmplY3QucHJvdG90eXBlKSB7XG4gICAgY29uc3QgcHJvdCA9IE9iamVjdC5nZXRQcm90b3R5cGVPZihwcm90b3R5cGUpO1xuICAgIGlmIChcbiAgICAgIHByb3QgPT09IE9iamVjdC5wcm90b3R5cGUgfHxcbiAgICAgIE9iamVjdC5nZXRQcm90b3R5cGVPZihwcm90KSA9PT0gT2JqZWN0LnByb3RvdHlwZVxuICAgICkge1xuICAgICAgcmV0dXJuIGJpbmRQcm90b3R5cGUocHJvdG90eXBlLCBNb2RlbC5wcm90b3R5cGUpO1xuICAgIH1cbiAgfVxuICB0aHJvdyBuZXcgRXJyb3IoXCJDb3VsZCBub3QgZmluZCBwcm9wZXIgcHJvdG90eXBlIHRvIGJpbmRcIik7XG59XG4iXX0=
|
|
@@ -47,3 +47,13 @@ export declare function hashedBy(algorithm: string, ...args: any[]): (target: ob
|
|
|
47
47
|
* @category Class Decorators
|
|
48
48
|
*/
|
|
49
49
|
export declare function serializedBy(serializer: string, ...args: any[]): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|
|
50
|
+
/**
|
|
51
|
+
* @summary Applies descriptive metadata to a class, property or method
|
|
52
|
+
*
|
|
53
|
+
* @param {string} description the description to apply
|
|
54
|
+
*
|
|
55
|
+
* @function description
|
|
56
|
+
*
|
|
57
|
+
* @category Decorators
|
|
58
|
+
*/
|
|
59
|
+
export declare function description(description: string): (target: object, propertyKey?: string | symbol | unknown, descriptor?: PropertyDescriptor) => void;
|