@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
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./errors";
|
|
2
|
-
export * from "./validation";
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from "./errors.js";
|
|
2
|
+
export * from "./validation.js";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29uc3RhbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDRCQUF5QjtBQUN6QixnQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9lcnJvcnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZhbGlkYXRpb25cIjtcbiJdfQ==
|
package/lib/esm/index.d.ts
CHANGED
package/lib/esm/index.js
CHANGED
|
@@ -5,15 +5,15 @@
|
|
|
5
5
|
* It exposes utility functions, validation decorators, and model-related functionality for
|
|
6
6
|
* implementing type-safe, declarative validation in TypeScript applications.
|
|
7
7
|
*/
|
|
8
|
-
export * from "./constants";
|
|
9
|
-
export * from "./utils";
|
|
10
|
-
export * from "./validation";
|
|
11
|
-
export * from "./model";
|
|
8
|
+
export * from "./constants/index.js";
|
|
9
|
+
export * from "./utils/index.js";
|
|
10
|
+
export * from "./validation/index.js";
|
|
11
|
+
export * from "./model/index.js";
|
|
12
12
|
/**
|
|
13
13
|
* @description Current version of the reflection package
|
|
14
14
|
* @summary Stores the semantic version number of the package
|
|
15
15
|
* @const VERSION
|
|
16
16
|
* @memberOf module:decorator-validation
|
|
17
17
|
*/
|
|
18
|
-
export const VERSION = "1.7.
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
export const VERSION = "1.7.6";
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gscUNBQTRCO0FBQzVCLGlDQUF3QjtBQUN4QixzQ0FBNkI7QUFDN0IsaUNBQXdCO0FBRXhCOzs7OztHQUtHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQG1vZHVsZSBkZWNvcmF0b3ItdmFsaWRhdGlvblxuICogQGRlc2NyaXB0aW9uIFR5cGVTY3JpcHQgZGVjb3JhdG9yLWJhc2VkIHZhbGlkYXRpb24gbGlicmFyeVxuICogQHN1bW1hcnkgVGhpcyBtb2R1bGUgcHJvdmlkZXMgYSBjb21wcmVoZW5zaXZlIHZhbGlkYXRpb24gZnJhbWV3b3JrIHVzaW5nIFR5cGVTY3JpcHQgZGVjb3JhdG9ycy5cbiAqIEl0IGV4cG9zZXMgdXRpbGl0eSBmdW5jdGlvbnMsIHZhbGlkYXRpb24gZGVjb3JhdG9ycywgYW5kIG1vZGVsLXJlbGF0ZWQgZnVuY3Rpb25hbGl0eSBmb3JcbiAqIGltcGxlbWVudGluZyB0eXBlLXNhZmUsIGRlY2xhcmF0aXZlIHZhbGlkYXRpb24gaW4gVHlwZVNjcmlwdCBhcHBsaWNhdGlvbnMuXG4gKi9cbmV4cG9ydCAqIGZyb20gXCIuL2NvbnN0YW50c1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3ZhbGlkYXRpb25cIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZGVsXCI7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEN1cnJlbnQgdmVyc2lvbiBvZiB0aGUgcmVmbGVjdGlvbiBwYWNrYWdlXG4gKiBAc3VtbWFyeSBTdG9yZXMgdGhlIHNlbWFudGljIHZlcnNpb24gbnVtYmVyIG9mIHRoZSBwYWNrYWdlXG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTpkZWNvcmF0b3ItdmFsaWRhdGlvblxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiIyNWRVJTSU9OIyNcIjtcbiJdfQ==
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { FastMCP, Tool } from "fastmcp";
|
|
2
|
+
import { Logger } from "@decaf-ts/logging";
|
|
3
|
+
import { FastMCPSessionAuth } from "./types";
|
|
4
|
+
export declare class ModelContextProtocol<Auth extends FastMCPSessionAuth = undefined> {
|
|
5
|
+
protected readonly mcp: FastMCP<Auth>;
|
|
6
|
+
protected get log(): Logger;
|
|
7
|
+
constructor(mcp: FastMCP<Auth>);
|
|
8
|
+
static readonly Builder: {
|
|
9
|
+
new (): {
|
|
10
|
+
name: string;
|
|
11
|
+
version: `${number}.${number}.${number}`;
|
|
12
|
+
tools: Record<string, Tool<any, any>>;
|
|
13
|
+
log: Logger;
|
|
14
|
+
setName(value: string): /*elided*/ any;
|
|
15
|
+
setVersion(value: string): /*elided*/ any;
|
|
16
|
+
addTool<Auth_1 extends FastMCPSessionAuth = undefined>(config: Tool<Auth_1, any>): /*elided*/ any;
|
|
17
|
+
build<Auth_1 extends FastMCPSessionAuth = undefined>(): ModelContextProtocol<Auth_1>;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
static get builder(): {
|
|
21
|
+
name: string;
|
|
22
|
+
version: `${number}.${number}.${number}`;
|
|
23
|
+
tools: Record<string, Tool<any, any>>;
|
|
24
|
+
log: Logger;
|
|
25
|
+
setName(value: string): /*elided*/ any;
|
|
26
|
+
setVersion(value: string): /*elided*/ any;
|
|
27
|
+
addTool<Auth extends FastMCPSessionAuth = undefined>(config: Tool<Auth, any>): /*elided*/ any;
|
|
28
|
+
build<Auth extends FastMCPSessionAuth = undefined>(): ModelContextProtocol<Auth>;
|
|
29
|
+
};
|
|
30
|
+
private static validateVersion;
|
|
31
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { FastMCP } from "fastmcp";
|
|
2
|
+
import { Logging } from "@decaf-ts/logging";
|
|
3
|
+
export class ModelContextProtocol {
|
|
4
|
+
get log() {
|
|
5
|
+
return Logging.for(this);
|
|
6
|
+
}
|
|
7
|
+
constructor(mcp) {
|
|
8
|
+
this.mcp = mcp;
|
|
9
|
+
}
|
|
10
|
+
static { this.Builder = class Builder {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.tools = {};
|
|
13
|
+
this.log = Logging.for("MCP Builder");
|
|
14
|
+
}
|
|
15
|
+
setName(value) {
|
|
16
|
+
this.name = value;
|
|
17
|
+
this.log.debug(`name set to ${value}`);
|
|
18
|
+
return this;
|
|
19
|
+
}
|
|
20
|
+
setVersion(value) {
|
|
21
|
+
this.version = ModelContextProtocol.validateVersion(value);
|
|
22
|
+
this.log.debug(`version set to ${value}`);
|
|
23
|
+
return this;
|
|
24
|
+
}
|
|
25
|
+
addTool(config) {
|
|
26
|
+
const { name } = config;
|
|
27
|
+
if (name in this.tools)
|
|
28
|
+
throw new Error(`tool ${name} already registered`);
|
|
29
|
+
this.tools[name] = config;
|
|
30
|
+
this.log.debug(`tool ${name} added`);
|
|
31
|
+
return this;
|
|
32
|
+
}
|
|
33
|
+
build() {
|
|
34
|
+
if (!this.name)
|
|
35
|
+
throw new Error("name is required");
|
|
36
|
+
if (!this.version)
|
|
37
|
+
throw new Error("version is required");
|
|
38
|
+
const mcp = new FastMCP({
|
|
39
|
+
name: this.name,
|
|
40
|
+
version: this.version,
|
|
41
|
+
});
|
|
42
|
+
Object.values(this.tools).forEach((tool) => {
|
|
43
|
+
try {
|
|
44
|
+
mcp.addTool(tool);
|
|
45
|
+
}
|
|
46
|
+
catch (e) {
|
|
47
|
+
throw new Error(`Failed to add tool ${tool.name}: ${e}`);
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
this.log.info(`${this.name} MCP built`);
|
|
51
|
+
this.log.debug(`${this.name} MCP - available tools: ${Object.keys(this.tools).join(", ")}`);
|
|
52
|
+
return new ModelContextProtocol(mcp);
|
|
53
|
+
}
|
|
54
|
+
}; }
|
|
55
|
+
static get builder() {
|
|
56
|
+
return new ModelContextProtocol.Builder();
|
|
57
|
+
}
|
|
58
|
+
static validateVersion(version) {
|
|
59
|
+
const regexp = /(\d+)\.(\d+)\.(\d+)/g;
|
|
60
|
+
const match = regexp.exec(version);
|
|
61
|
+
if (!match)
|
|
62
|
+
throw new Error(`Invalid version string. should obey semantic versioning: ${version}`);
|
|
63
|
+
return `${match[1]}.${match[2]}.${match[3]}`;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTW9kZWxDb250ZXh0UHJvdG9jb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWNwL01vZGVsQ29udGV4dFByb3RvY29sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQVEsTUFBTSxTQUFTLENBQUM7QUFDeEMsT0FBTyxFQUFVLE9BQU8sRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBR3BELE1BQU0sT0FBTyxvQkFBb0I7SUFDL0IsSUFBYyxHQUFHO1FBQ2YsT0FBTyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQVcsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxZQUErQixHQUFrQjtRQUFsQixRQUFHLEdBQUgsR0FBRyxDQUFlO0lBQUcsQ0FBQzthQUVyQyxZQUFPLEdBQUcsTUFBTSxPQUFPO1FBT3JDO1lBSkEsVUFBSyxHQUFtQyxFQUFFLENBQUM7WUFFM0MsUUFBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLENBQUM7UUFFbEIsQ0FBQztRQUVoQixPQUFPLENBQUMsS0FBYTtZQUNuQixJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztZQUNsQixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxlQUFlLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDdkMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsVUFBVSxDQUFDLEtBQWE7WUFDdEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDM0QsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsa0JBQWtCLEtBQUssRUFBRSxDQUFDLENBQUM7WUFDMUMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsT0FBTyxDQUNMLE1BQXVCO1lBRXZCLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxNQUFNLENBQUM7WUFDeEIsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUs7Z0JBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLHFCQUFxQixDQUFDLENBQUM7WUFDckQsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUM7WUFDMUIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQyxDQUFDO1lBQ3JDLE9BQU8sSUFBSSxDQUFDO1FBQ2QsQ0FBQztRQUVELEtBQUs7WUFHSCxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUk7Z0JBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1lBQ3BELElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTztnQkFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7WUFDMUQsTUFBTSxHQUFHLEdBQUcsSUFBSSxPQUFPLENBQU87Z0JBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtnQkFDZixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87YUFDdEIsQ0FBQyxDQUFDO1lBQ0gsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7Z0JBQ3pDLElBQUksQ0FBQztvQkFDSCxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNwQixDQUFDO2dCQUFDLE9BQU8sQ0FBVSxFQUFFLENBQUM7b0JBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDM0QsQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxZQUFZLENBQUMsQ0FBQztZQUN4QyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FDWixHQUFHLElBQUksQ0FBQyxJQUFJLDJCQUEyQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FDNUUsQ0FBQztZQUNGLE9BQU8sSUFBSSxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN2QyxDQUFDO0tBQ0YsQ0FBQztJQUVGLE1BQU0sS0FBSyxPQUFPO1FBQ2hCLE9BQU8sSUFBSSxvQkFBb0IsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRU8sTUFBTSxDQUFDLGVBQWUsQ0FDNUIsT0FBZTtRQUVmLE1BQU0sTUFBTSxHQUFHLHNCQUFzQixDQUFDO1FBQ3RDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLEtBQUs7WUFDUixNQUFNLElBQUksS0FBSyxDQUNiLDREQUE0RCxPQUFPLEVBQUUsQ0FDdEUsQ0FBQztRQUNKLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBcUMsQ0FBQztJQUNsRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRmFzdE1DUCwgVG9vbCB9IGZyb20gXCJmYXN0bWNwXCI7XG5pbXBvcnQgeyBMb2dnZXIsIExvZ2dpbmcgfSBmcm9tIFwiQGRlY2FmLXRzL2xvZ2dpbmdcIjtcbmltcG9ydCB7IEZhc3RNQ1BTZXNzaW9uQXV0aCB9IGZyb20gXCIuL3R5cGVzXCI7XG5cbmV4cG9ydCBjbGFzcyBNb2RlbENvbnRleHRQcm90b2NvbDxBdXRoIGV4dGVuZHMgRmFzdE1DUFNlc3Npb25BdXRoID0gdW5kZWZpbmVkPiB7XG4gIHByb3RlY3RlZCBnZXQgbG9nKCk6IExvZ2dlciB7XG4gICAgcmV0dXJuIExvZ2dpbmcuZm9yKHRoaXMgYXMgYW55KTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCByZWFkb25seSBtY3A6IEZhc3RNQ1A8QXV0aD4pIHt9XG5cbiAgc3RhdGljIHJlYWRvbmx5IEJ1aWxkZXIgPSBjbGFzcyBCdWlsZGVyIHtcbiAgICBuYW1lITogc3RyaW5nO1xuICAgIHZlcnNpb24hOiBgJHtudW1iZXJ9LiR7bnVtYmVyfS4ke251bWJlcn1gO1xuICAgIHRvb2xzOiBSZWNvcmQ8c3RyaW5nLCBUb29sPGFueSwgYW55Pj4gPSB7fTtcblxuICAgIGxvZyA9IExvZ2dpbmcuZm9yKFwiTUNQIEJ1aWxkZXJcIik7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgICBzZXROYW1lKHZhbHVlOiBzdHJpbmcpIHtcbiAgICAgIHRoaXMubmFtZSA9IHZhbHVlO1xuICAgICAgdGhpcy5sb2cuZGVidWcoYG5hbWUgc2V0IHRvICR7dmFsdWV9YCk7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBzZXRWZXJzaW9uKHZhbHVlOiBzdHJpbmcpIHtcbiAgICAgIHRoaXMudmVyc2lvbiA9IE1vZGVsQ29udGV4dFByb3RvY29sLnZhbGlkYXRlVmVyc2lvbih2YWx1ZSk7XG4gICAgICB0aGlzLmxvZy5kZWJ1ZyhgdmVyc2lvbiBzZXQgdG8gJHt2YWx1ZX1gKTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGFkZFRvb2w8QXV0aCBleHRlbmRzIEZhc3RNQ1BTZXNzaW9uQXV0aCA9IHVuZGVmaW5lZD4oXG4gICAgICBjb25maWc6IFRvb2w8QXV0aCwgYW55PlxuICAgICkge1xuICAgICAgY29uc3QgeyBuYW1lIH0gPSBjb25maWc7XG4gICAgICBpZiAobmFtZSBpbiB0aGlzLnRvb2xzKVxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYHRvb2wgJHtuYW1lfSBhbHJlYWR5IHJlZ2lzdGVyZWRgKTtcbiAgICAgIHRoaXMudG9vbHNbbmFtZV0gPSBjb25maWc7XG4gICAgICB0aGlzLmxvZy5kZWJ1ZyhgdG9vbCAke25hbWV9IGFkZGVkYCk7XG4gICAgICByZXR1cm4gdGhpcztcbiAgICB9XG5cbiAgICBidWlsZDxcbiAgICAgIEF1dGggZXh0ZW5kcyBGYXN0TUNQU2Vzc2lvbkF1dGggPSB1bmRlZmluZWQsXG4gICAgPigpOiBNb2RlbENvbnRleHRQcm90b2NvbDxBdXRoPiB7XG4gICAgICBpZiAoIXRoaXMubmFtZSkgdGhyb3cgbmV3IEVycm9yKFwibmFtZSBpcyByZXF1aXJlZFwiKTtcbiAgICAgIGlmICghdGhpcy52ZXJzaW9uKSB0aHJvdyBuZXcgRXJyb3IoXCJ2ZXJzaW9uIGlzIHJlcXVpcmVkXCIpO1xuICAgICAgY29uc3QgbWNwID0gbmV3IEZhc3RNQ1A8QXV0aD4oe1xuICAgICAgICBuYW1lOiB0aGlzLm5hbWUsXG4gICAgICAgIHZlcnNpb246IHRoaXMudmVyc2lvbixcbiAgICAgIH0pO1xuICAgICAgT2JqZWN0LnZhbHVlcyh0aGlzLnRvb2xzKS5mb3JFYWNoKCh0b29sKSA9PiB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgbWNwLmFkZFRvb2wodG9vbCk7XG4gICAgICAgIH0gY2F0Y2ggKGU6IHVua25vd24pIHtcbiAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYEZhaWxlZCB0byBhZGQgdG9vbCAke3Rvb2wubmFtZX06ICR7ZX1gKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgICB0aGlzLmxvZy5pbmZvKGAke3RoaXMubmFtZX0gTUNQIGJ1aWx0YCk7XG4gICAgICB0aGlzLmxvZy5kZWJ1ZyhcbiAgICAgICAgYCR7dGhpcy5uYW1lfSBNQ1AgLSBhdmFpbGFibGUgdG9vbHM6ICR7T2JqZWN0LmtleXModGhpcy50b29scykuam9pbihcIiwgXCIpfWBcbiAgICAgICk7XG4gICAgICByZXR1cm4gbmV3IE1vZGVsQ29udGV4dFByb3RvY29sKG1jcCk7XG4gICAgfVxuICB9O1xuXG4gIHN0YXRpYyBnZXQgYnVpbGRlcigpIHtcbiAgICByZXR1cm4gbmV3IE1vZGVsQ29udGV4dFByb3RvY29sLkJ1aWxkZXIoKTtcbiAgfVxuXG4gIHByaXZhdGUgc3RhdGljIHZhbGlkYXRlVmVyc2lvbihcbiAgICB2ZXJzaW9uOiBzdHJpbmdcbiAgKTogYCR7bnVtYmVyfS4ke251bWJlcn0uJHtudW1iZXJ9YCB7XG4gICAgY29uc3QgcmVnZXhwID0gLyhcXGQrKVxcLihcXGQrKVxcLihcXGQrKS9nO1xuICAgIGNvbnN0IG1hdGNoID0gcmVnZXhwLmV4ZWModmVyc2lvbik7XG4gICAgaWYgKCFtYXRjaClcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYEludmFsaWQgdmVyc2lvbiBzdHJpbmcuIHNob3VsZCBvYmV5IHNlbWFudGljIHZlcnNpb25pbmc6ICR7dmVyc2lvbn1gXG4gICAgICApO1xuICAgIHJldHVybiBgJHttYXRjaFsxXX0uJHttYXRjaFsyXX0uJHttYXRjaFszXX1gIGFzIGAke251bWJlcn0uJHtudW1iZXJ9LiR7bnVtYmVyfWA7XG4gIH1cbn1cbiJdfQ==
|
|
File without changes
|
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// import { FastMCP } from "fastmcp";
|
|
3
|
+
// import { z } from "zod";
|
|
4
|
+
// import { version } from "../../package.json";
|
|
5
|
+
// import { ModelContextProtocol } from "./ModelContextProtocol";
|
|
6
|
+
// import { Model } from "../model";
|
|
7
|
+
// import {
|
|
8
|
+
// email,
|
|
9
|
+
// max,
|
|
10
|
+
// maxlength,
|
|
11
|
+
// min,
|
|
12
|
+
// minlength,
|
|
13
|
+
// pattern,
|
|
14
|
+
// required,
|
|
15
|
+
// } from "../validation";
|
|
16
|
+
// import { createModelTool } from "./tools/createModel.tool";
|
|
17
|
+
//
|
|
18
|
+
// const DecoratorValidatonMCP = ModelContextProtocol.builder
|
|
19
|
+
// .setName("decaf-validation-server")
|
|
20
|
+
// .setVersion(version)
|
|
21
|
+
// .addTool(createModelTool)
|
|
22
|
+
// .build();
|
|
23
|
+
//
|
|
24
|
+
// // Initialize FastMCP server
|
|
25
|
+
// const server = new FastMCP({
|
|
26
|
+
// name: "decaf-validation-server",
|
|
27
|
+
// // @ts-ignore
|
|
28
|
+
// version: version,
|
|
29
|
+
// });
|
|
30
|
+
//
|
|
31
|
+
// // Model registry for dynamic model management
|
|
32
|
+
// const modelRegistry = new Map<string, any>();
|
|
33
|
+
//
|
|
34
|
+
// // Tool: Validate a model instance
|
|
35
|
+
// server.addTool({
|
|
36
|
+
// name: "validate-model",
|
|
37
|
+
// description: "Validate a model instance against its decorators",
|
|
38
|
+
// parameters: z.object({
|
|
39
|
+
// modelName: z.string().describe("Name of the model class"),
|
|
40
|
+
// data: z.record(z.any()).describe("Data to validate"),
|
|
41
|
+
// options: z
|
|
42
|
+
// .object({
|
|
43
|
+
// partial: z.boolean().optional().describe("Allow partial validation"),
|
|
44
|
+
// })
|
|
45
|
+
// .optional(),
|
|
46
|
+
// }),
|
|
47
|
+
// execute: async (args) => {
|
|
48
|
+
// const { modelName, data, options } = args;
|
|
49
|
+
//
|
|
50
|
+
// const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);
|
|
51
|
+
// if (!ModelClass) {
|
|
52
|
+
// throw new Error(`Model "${modelName}" not found`);
|
|
53
|
+
// }
|
|
54
|
+
//
|
|
55
|
+
// try {
|
|
56
|
+
// const instance = new ModelClass(data);
|
|
57
|
+
// const errors = instance.hasErrors();
|
|
58
|
+
//
|
|
59
|
+
// return {
|
|
60
|
+
// isValid: !errors,
|
|
61
|
+
// errors: errors || null,
|
|
62
|
+
// validatedData: errors ? null : instance.serialize(),
|
|
63
|
+
// };
|
|
64
|
+
// } catch (error) {
|
|
65
|
+
// return {
|
|
66
|
+
// isValid: false,
|
|
67
|
+
// errors: [{ message: error.message }],
|
|
68
|
+
// validatedData: null,
|
|
69
|
+
// };
|
|
70
|
+
// }
|
|
71
|
+
// },
|
|
72
|
+
// });
|
|
73
|
+
//
|
|
74
|
+
// // Tool: Get model schema information
|
|
75
|
+
// server.addTool({
|
|
76
|
+
// name: "get-model-schema",
|
|
77
|
+
// description: "Get the validation schema for a model",
|
|
78
|
+
// parameters: z.object({
|
|
79
|
+
// modelName: z.string().describe("Name of the model class"),
|
|
80
|
+
// }),
|
|
81
|
+
// execute: async (args) => {
|
|
82
|
+
// const { modelName } = args;
|
|
83
|
+
//
|
|
84
|
+
// const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);
|
|
85
|
+
// if (!ModelClass) {
|
|
86
|
+
// throw new Error(`Model "${modelName}" not found`);
|
|
87
|
+
// }
|
|
88
|
+
//
|
|
89
|
+
// // Extract validation metadata
|
|
90
|
+
// const instance = new ModelClass();
|
|
91
|
+
// const metadata = Reflect.getMetadata("validation", instance) || {};
|
|
92
|
+
//
|
|
93
|
+
// return {
|
|
94
|
+
// modelName,
|
|
95
|
+
// properties: Object.keys(metadata).map((key) => ({
|
|
96
|
+
// name: key,
|
|
97
|
+
// validators: metadata[key] || [],
|
|
98
|
+
// })),
|
|
99
|
+
// capabilities: {
|
|
100
|
+
// serialization: !!instance.serialize,
|
|
101
|
+
// hashing: !!instance.hash,
|
|
102
|
+
// comparison: !!instance.equals,
|
|
103
|
+
// },
|
|
104
|
+
// };
|
|
105
|
+
// },
|
|
106
|
+
// });
|
|
107
|
+
//
|
|
108
|
+
// // Tool: Serialize model
|
|
109
|
+
// server.addTool({
|
|
110
|
+
// name: "serialize-model",
|
|
111
|
+
// description: "Serialize a model instance to string",
|
|
112
|
+
// parameters: z.object({
|
|
113
|
+
// modelName: z.string().describe("Name of the model class"),
|
|
114
|
+
// data: z.record(z.any()).describe("Model data to serialize"),
|
|
115
|
+
// format: z.enum(["json", "yaml"]).optional().default("json"),
|
|
116
|
+
// }),
|
|
117
|
+
// execute: async (args) => {
|
|
118
|
+
// const { modelName, data, format } = args;
|
|
119
|
+
//
|
|
120
|
+
// const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);
|
|
121
|
+
// if (!ModelClass) {
|
|
122
|
+
// throw new Error(`Model "${modelName}" not found`);
|
|
123
|
+
// }
|
|
124
|
+
//
|
|
125
|
+
// const instance = new ModelClass(data);
|
|
126
|
+
// const errors = instance.hasErrors();
|
|
127
|
+
//
|
|
128
|
+
// if (errors) {
|
|
129
|
+
// throw new Error(
|
|
130
|
+
// `Cannot serialize invalid model: ${JSON.stringify(errors)}`
|
|
131
|
+
// );
|
|
132
|
+
// }
|
|
133
|
+
//
|
|
134
|
+
// return {
|
|
135
|
+
// serialized: instance.serialize(),
|
|
136
|
+
// format,
|
|
137
|
+
// modelName,
|
|
138
|
+
// };
|
|
139
|
+
// },
|
|
140
|
+
// });
|
|
141
|
+
//
|
|
142
|
+
// // Tool: Deserialize model
|
|
143
|
+
// server.addTool({
|
|
144
|
+
// name: "deserialize-model",
|
|
145
|
+
// description: "Deserialize a string to model instance",
|
|
146
|
+
// parameters: z.object({
|
|
147
|
+
// serializedData: z.string().describe("Serialized model data"),
|
|
148
|
+
// modelName: z
|
|
149
|
+
// .string()
|
|
150
|
+
// .optional()
|
|
151
|
+
// .describe("Expected model name for validation"),
|
|
152
|
+
// }),
|
|
153
|
+
// execute: async (args) => {
|
|
154
|
+
// const { serializedData, modelName } = args;
|
|
155
|
+
//
|
|
156
|
+
// try {
|
|
157
|
+
// const instance = Model.deserialize(serializedData);
|
|
158
|
+
//
|
|
159
|
+
// if (modelName && instance.constructor.name !== modelName) {
|
|
160
|
+
// throw new Error(
|
|
161
|
+
// `Expected model "${modelName}", got "${instance.constructor.name}"`
|
|
162
|
+
// );
|
|
163
|
+
// }
|
|
164
|
+
//
|
|
165
|
+
// return {
|
|
166
|
+
// modelName: instance.constructor.name,
|
|
167
|
+
// data: JSON.parse(instance.serialize()),
|
|
168
|
+
// isValid: !instance.hasErrors(),
|
|
169
|
+
// };
|
|
170
|
+
// } catch (error) {
|
|
171
|
+
// throw new Error(`Deserialization failed: ${error.message}`);
|
|
172
|
+
// }
|
|
173
|
+
// },
|
|
174
|
+
// });
|
|
175
|
+
//
|
|
176
|
+
// // Tool: Compare models
|
|
177
|
+
// server.addTool({
|
|
178
|
+
// name: "compare-models",
|
|
179
|
+
// description: "Compare two model instances for equality",
|
|
180
|
+
// parameters: z.object({
|
|
181
|
+
// modelName: z.string().describe("Name of the model class"),
|
|
182
|
+
// data1: z.record(z.any()).describe("First model data"),
|
|
183
|
+
// data2: z.record(z.any()).describe("Second model data"),
|
|
184
|
+
// excludeFields: z
|
|
185
|
+
// .array(z.string())
|
|
186
|
+
// .optional()
|
|
187
|
+
// .describe("Fields to exclude from comparison"),
|
|
188
|
+
// }),
|
|
189
|
+
// execute: async (args) => {
|
|
190
|
+
// const { modelName, data1, data2, excludeFields } = args;
|
|
191
|
+
//
|
|
192
|
+
// const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);
|
|
193
|
+
// if (!ModelClass) {
|
|
194
|
+
// throw new Error(`Model "${modelName}" not found`);
|
|
195
|
+
// }
|
|
196
|
+
//
|
|
197
|
+
// const instance1 = new ModelClass(data1);
|
|
198
|
+
// const instance2 = new ModelClass(data2);
|
|
199
|
+
//
|
|
200
|
+
// const isEqual = excludeFields
|
|
201
|
+
// ? instance1.equals(instance2, ...excludeFields)
|
|
202
|
+
// : instance1.equals(instance2);
|
|
203
|
+
//
|
|
204
|
+
// return {
|
|
205
|
+
// isEqual,
|
|
206
|
+
// hash1: instance1.hash(),
|
|
207
|
+
// hash2: instance2.hash(),
|
|
208
|
+
// differences: isEqual ? null : await findDifferences(instance1, instance2),
|
|
209
|
+
// };
|
|
210
|
+
// },
|
|
211
|
+
// });
|
|
212
|
+
//
|
|
213
|
+
// // Tool: List available decorators
|
|
214
|
+
// server.addTool({
|
|
215
|
+
// name: "list-decorators",
|
|
216
|
+
// description: "List all available validation decorators",
|
|
217
|
+
// parameters: z.object({
|
|
218
|
+
// category: z
|
|
219
|
+
// .enum(["basic", "type-specific", "comparison", "all"])
|
|
220
|
+
// .optional()
|
|
221
|
+
// .default("all"),
|
|
222
|
+
// }),
|
|
223
|
+
// execute: async (args) => {
|
|
224
|
+
// const { category } = args;
|
|
225
|
+
//
|
|
226
|
+
// const decorators = {
|
|
227
|
+
// basic: [
|
|
228
|
+
// {
|
|
229
|
+
// name: "required",
|
|
230
|
+
// description: "Marks field as required",
|
|
231
|
+
// args: ["message?"],
|
|
232
|
+
// },
|
|
233
|
+
// {
|
|
234
|
+
// name: "min",
|
|
235
|
+
// description: "Minimum value validation",
|
|
236
|
+
// args: ["value", "message?"],
|
|
237
|
+
// },
|
|
238
|
+
// {
|
|
239
|
+
// name: "max",
|
|
240
|
+
// description: "Maximum value validation",
|
|
241
|
+
// args: ["value", "message?"],
|
|
242
|
+
// },
|
|
243
|
+
// {
|
|
244
|
+
// name: "minlength",
|
|
245
|
+
// description: "Minimum length validation",
|
|
246
|
+
// args: ["length", "message?"],
|
|
247
|
+
// },
|
|
248
|
+
// {
|
|
249
|
+
// name: "maxlength",
|
|
250
|
+
// description: "Maximum length validation",
|
|
251
|
+
// args: ["length", "message?"],
|
|
252
|
+
// },
|
|
253
|
+
// {
|
|
254
|
+
// name: "pattern",
|
|
255
|
+
// description: "Regex pattern validation",
|
|
256
|
+
// args: ["pattern", "message?"],
|
|
257
|
+
// },
|
|
258
|
+
// {
|
|
259
|
+
// name: "step",
|
|
260
|
+
// description: "Step value validation",
|
|
261
|
+
// args: ["step", "message?"],
|
|
262
|
+
// },
|
|
263
|
+
// ],
|
|
264
|
+
// "type-specific": [
|
|
265
|
+
// {
|
|
266
|
+
// name: "email",
|
|
267
|
+
// description: "Email format validation",
|
|
268
|
+
// args: ["message?"],
|
|
269
|
+
// },
|
|
270
|
+
// {
|
|
271
|
+
// name: "url",
|
|
272
|
+
// description: "URL format validation",
|
|
273
|
+
// args: ["message?"],
|
|
274
|
+
// },
|
|
275
|
+
// {
|
|
276
|
+
// name: "date",
|
|
277
|
+
// description: "Date format validation",
|
|
278
|
+
// args: ["format?", "message?"],
|
|
279
|
+
// },
|
|
280
|
+
// {
|
|
281
|
+
// name: "password",
|
|
282
|
+
// description: "Password strength validation",
|
|
283
|
+
// args: ["message?"],
|
|
284
|
+
// },
|
|
285
|
+
// {
|
|
286
|
+
// name: "type",
|
|
287
|
+
// description: "Type validation",
|
|
288
|
+
// args: ["type", "message?"],
|
|
289
|
+
// },
|
|
290
|
+
// {
|
|
291
|
+
// name: "list",
|
|
292
|
+
// description: "Array validation",
|
|
293
|
+
// args: ["itemType", "message?"],
|
|
294
|
+
// },
|
|
295
|
+
// {
|
|
296
|
+
// name: "set",
|
|
297
|
+
// description: "Set validation",
|
|
298
|
+
// args: ["itemType", "message?"],
|
|
299
|
+
// },
|
|
300
|
+
// ],
|
|
301
|
+
// comparison: [
|
|
302
|
+
// {
|
|
303
|
+
// name: "eq",
|
|
304
|
+
// description: "Equal to another field",
|
|
305
|
+
// args: ["fieldName", "message?"],
|
|
306
|
+
// },
|
|
307
|
+
// {
|
|
308
|
+
// name: "diff",
|
|
309
|
+
// description: "Different from another field",
|
|
310
|
+
// args: ["fieldName", "message?"],
|
|
311
|
+
// },
|
|
312
|
+
// {
|
|
313
|
+
// name: "lt",
|
|
314
|
+
// description: "Less than another field",
|
|
315
|
+
// args: ["fieldName", "message?"],
|
|
316
|
+
// },
|
|
317
|
+
// {
|
|
318
|
+
// name: "lte",
|
|
319
|
+
// description: "Less than or equal to another field",
|
|
320
|
+
// args: ["fieldName", "message?"],
|
|
321
|
+
// },
|
|
322
|
+
// {
|
|
323
|
+
// name: "gt",
|
|
324
|
+
// description: "Greater than another field",
|
|
325
|
+
// args: ["fieldName", "message?"],
|
|
326
|
+
// },
|
|
327
|
+
// {
|
|
328
|
+
// name: "gte",
|
|
329
|
+
// description: "Greater than or equal to another field",
|
|
330
|
+
// args: ["fieldName", "message?"],
|
|
331
|
+
// },
|
|
332
|
+
// ],
|
|
333
|
+
// };
|
|
334
|
+
//
|
|
335
|
+
// if (category === "all") {
|
|
336
|
+
// return {
|
|
337
|
+
// categories: decorators,
|
|
338
|
+
// total: Object.values(decorators).reduce(
|
|
339
|
+
// (sum, arr) => sum + arr.length,
|
|
340
|
+
// 0
|
|
341
|
+
// ),
|
|
342
|
+
// };
|
|
343
|
+
// }
|
|
344
|
+
//
|
|
345
|
+
// return {
|
|
346
|
+
// category,
|
|
347
|
+
// decorators: decorators[category] || [],
|
|
348
|
+
// count: decorators[category]?.length || 0,
|
|
349
|
+
// };
|
|
350
|
+
// },
|
|
351
|
+
// });
|
|
352
|
+
//
|
|
353
|
+
// // Utility function to get decorator function by name
|
|
354
|
+
// function getDecoratorFunction(name: string): Function | null {
|
|
355
|
+
// const decoratorMap = {
|
|
356
|
+
// required,
|
|
357
|
+
// email,
|
|
358
|
+
// min,
|
|
359
|
+
// max,
|
|
360
|
+
// minlength,
|
|
361
|
+
// maxlength,
|
|
362
|
+
// pattern,
|
|
363
|
+
// url,
|
|
364
|
+
// date,
|
|
365
|
+
// password,
|
|
366
|
+
// list,
|
|
367
|
+
// set,
|
|
368
|
+
// eq,
|
|
369
|
+
// diff,
|
|
370
|
+
// lt,
|
|
371
|
+
// lte,
|
|
372
|
+
// gt,
|
|
373
|
+
// gte,
|
|
374
|
+
// type,
|
|
375
|
+
// step,
|
|
376
|
+
// };
|
|
377
|
+
// return decoratorMap[name] || null;
|
|
378
|
+
// }
|
|
379
|
+
//
|
|
380
|
+
// // Utility function to find differences between models
|
|
381
|
+
// async function findDifferences(instance1: any, instance2: any): Promise<any[]> {
|
|
382
|
+
// const differences = [];
|
|
383
|
+
// const serialized1 = JSON.parse(instance1.serialize());
|
|
384
|
+
// const serialized2 = JSON.parse(instance2.serialize());
|
|
385
|
+
//
|
|
386
|
+
// for (const key in serialized1) {
|
|
387
|
+
// if (serialized1[key] !== serialized2[key]) {
|
|
388
|
+
// differences.push({
|
|
389
|
+
// field: key,
|
|
390
|
+
// value1: serialized1[key],
|
|
391
|
+
// value2: serialized2[key],
|
|
392
|
+
// });
|
|
393
|
+
// }
|
|
394
|
+
// }
|
|
395
|
+
//
|
|
396
|
+
// return differences;
|
|
397
|
+
// }
|
|
398
|
+
//
|
|
399
|
+
// // Start the server
|
|
400
|
+
// server.start({
|
|
401
|
+
// transportType: "stdio",
|
|
402
|
+
// });
|
|
403
|
+
//
|
|
404
|
+
// export { server };
|
|
405
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mcp1.js","sourceRoot":"","sources":["../../../src/mcp/mcp1.ts"],"names":[],"mappings":";AAAA,qCAAqC;AACrC,2BAA2B;AAC3B,gDAAgD;AAChD,iEAAiE;AACjE,oCAAoC;AACpC,WAAW;AACX,WAAW;AACX,SAAS;AACT,eAAe;AACf,SAAS;AACT,eAAe;AACf,aAAa;AACb,cAAc;AACd,0BAA0B;AAC1B,8DAA8D;AAC9D,EAAE;AACF,6DAA6D;AAC7D,wCAAwC;AACxC,yBAAyB;AACzB,8BAA8B;AAC9B,cAAc;AACd,EAAE;AACF,+BAA+B;AAC/B,+BAA+B;AAC/B,qCAAqC;AACrC,kBAAkB;AAClB,sBAAsB;AACtB,MAAM;AACN,EAAE;AACF,iDAAiD;AACjD,gDAAgD;AAChD,EAAE;AACF,qCAAqC;AACrC,mBAAmB;AACnB,4BAA4B;AAC5B,qEAAqE;AACrE,2BAA2B;AAC3B,iEAAiE;AACjE,4DAA4D;AAC5D,iBAAiB;AACjB,kBAAkB;AAClB,gFAAgF;AAChF,WAAW;AACX,qBAAqB;AACrB,QAAQ;AACR,+BAA+B;AAC/B,iDAAiD;AACjD,EAAE;AACF,+EAA+E;AAC/E,yBAAyB;AACzB,2DAA2D;AAC3D,QAAQ;AACR,EAAE;AACF,YAAY;AACZ,+CAA+C;AAC/C,6CAA6C;AAC7C,EAAE;AACF,iBAAiB;AACjB,4BAA4B;AAC5B,kCAAkC;AAClC,+DAA+D;AAC/D,WAAW;AACX,wBAAwB;AACxB,iBAAiB;AACjB,0BAA0B;AAC1B,gDAAgD;AAChD,+BAA+B;AAC/B,WAAW;AACX,QAAQ;AACR,OAAO;AACP,MAAM;AACN,EAAE;AACF,wCAAwC;AACxC,mBAAmB;AACnB,8BAA8B;AAC9B,0DAA0D;AAC1D,2BAA2B;AAC3B,iEAAiE;AACjE,QAAQ;AACR,+BAA+B;AAC/B,kCAAkC;AAClC,EAAE;AACF,+EAA+E;AAC/E,yBAAyB;AACzB,2DAA2D;AAC3D,QAAQ;AACR,EAAE;AACF,qCAAqC;AACrC,yCAAyC;AACzC,0EAA0E;AAC1E,EAAE;AACF,eAAe;AACf,mBAAmB;AACnB,0DAA0D;AAC1D,qBAAqB;AACrB,2CAA2C;AAC3C,aAAa;AACb,wBAAwB;AACxB,+CAA+C;AAC/C,oCAAoC;AACpC,yCAAyC;AACzC,WAAW;AACX,SAAS;AACT,OAAO;AACP,MAAM;AACN,EAAE;AACF,2BAA2B;AAC3B,mBAAmB;AACnB,6BAA6B;AAC7B,yDAAyD;AACzD,2BAA2B;AAC3B,iEAAiE;AACjE,mEAAmE;AACnE,mEAAmE;AACnE,QAAQ;AACR,+BAA+B;AAC/B,gDAAgD;AAChD,EAAE;AACF,+EAA+E;AAC/E,yBAAyB;AACzB,2DAA2D;AAC3D,QAAQ;AACR,EAAE;AACF,6CAA6C;AAC7C,2CAA2C;AAC3C,EAAE;AACF,oBAAoB;AACpB,yBAAyB;AACzB,sEAAsE;AACtE,WAAW;AACX,QAAQ;AACR,EAAE;AACF,eAAe;AACf,0CAA0C;AAC1C,gBAAgB;AAChB,mBAAmB;AACnB,SAAS;AACT,OAAO;AACP,MAAM;AACN,EAAE;AACF,6BAA6B;AAC7B,mBAAmB;AACnB,+BAA+B;AAC/B,2DAA2D;AAC3D,2BAA2B;AAC3B,oEAAoE;AACpE,mBAAmB;AACnB,kBAAkB;AAClB,oBAAoB;AACpB,yDAAyD;AACzD,QAAQ;AACR,+BAA+B;AAC/B,kDAAkD;AAClD,EAAE;AACF,YAAY;AACZ,4DAA4D;AAC5D,EAAE;AACF,oEAAoE;AACpE,2BAA2B;AAC3B,gFAAgF;AAChF,aAAa;AACb,UAAU;AACV,EAAE;AACF,iBAAiB;AACjB,gDAAgD;AAChD,kDAAkD;AAClD,0CAA0C;AAC1C,WAAW;AACX,wBAAwB;AACxB,qEAAqE;AACrE,QAAQ;AACR,OAAO;AACP,MAAM;AACN,EAAE;AACF,0BAA0B;AAC1B,mBAAmB;AACnB,4BAA4B;AAC5B,6DAA6D;AAC7D,2BAA2B;AAC3B,iEAAiE;AACjE,6DAA6D;AAC7D,8DAA8D;AAC9D,uBAAuB;AACvB,2BAA2B;AAC3B,oBAAoB;AACpB,wDAAwD;AACxD,QAAQ;AACR,+BAA+B;AAC/B,+DAA+D;AAC/D,EAAE;AACF,+EAA+E;AAC/E,yBAAyB;AACzB,2DAA2D;AAC3D,QAAQ;AACR,EAAE;AACF,+CAA+C;AAC/C,+CAA+C;AAC/C,EAAE;AACF,oCAAoC;AACpC,wDAAwD;AACxD,uCAAuC;AACvC,EAAE;AACF,eAAe;AACf,iBAAiB;AACjB,iCAAiC;AACjC,iCAAiC;AACjC,mFAAmF;AACnF,SAAS;AACT,OAAO;AACP,MAAM;AACN,EAAE;AACF,qCAAqC;AACrC,mBAAmB;AACnB,6BAA6B;AAC7B,6DAA6D;AAC7D,2BAA2B;AAC3B,kBAAkB;AAClB,+DAA+D;AAC/D,oBAAoB;AACpB,yBAAyB;AACzB,QAAQ;AACR,+BAA+B;AAC/B,iCAAiC;AACjC,EAAE;AACF,2BAA2B;AAC3B,iBAAiB;AACjB,YAAY;AACZ,8BAA8B;AAC9B,oDAAoD;AACpD,gCAAgC;AAChC,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,qDAAqD;AACrD,yCAAyC;AACzC,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,qDAAqD;AACrD,yCAAyC;AACzC,aAAa;AACb,YAAY;AACZ,+BAA+B;AAC/B,sDAAsD;AACtD,0CAA0C;AAC1C,aAAa;AACb,YAAY;AACZ,+BAA+B;AAC/B,sDAAsD;AACtD,0CAA0C;AAC1C,aAAa;AACb,YAAY;AACZ,6BAA6B;AAC7B,qDAAqD;AACrD,2CAA2C;AAC3C,aAAa;AACb,YAAY;AACZ,0BAA0B;AAC1B,kDAAkD;AAClD,wCAAwC;AACxC,aAAa;AACb,WAAW;AACX,2BAA2B;AAC3B,YAAY;AACZ,2BAA2B;AAC3B,oDAAoD;AACpD,gCAAgC;AAChC,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,kDAAkD;AAClD,gCAAgC;AAChC,aAAa;AACb,YAAY;AACZ,0BAA0B;AAC1B,mDAAmD;AACnD,2CAA2C;AAC3C,aAAa;AACb,YAAY;AACZ,8BAA8B;AAC9B,yDAAyD;AACzD,gCAAgC;AAChC,aAAa;AACb,YAAY;AACZ,0BAA0B;AAC1B,4CAA4C;AAC5C,wCAAwC;AACxC,aAAa;AACb,YAAY;AACZ,0BAA0B;AAC1B,6CAA6C;AAC7C,4CAA4C;AAC5C,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,2CAA2C;AAC3C,4CAA4C;AAC5C,aAAa;AACb,WAAW;AACX,sBAAsB;AACtB,YAAY;AACZ,wBAAwB;AACxB,mDAAmD;AACnD,6CAA6C;AAC7C,aAAa;AACb,YAAY;AACZ,0BAA0B;AAC1B,yDAAyD;AACzD,6CAA6C;AAC7C,aAAa;AACb,YAAY;AACZ,wBAAwB;AACxB,oDAAoD;AACpD,6CAA6C;AAC7C,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,gEAAgE;AAChE,6CAA6C;AAC7C,aAAa;AACb,YAAY;AACZ,wBAAwB;AACxB,uDAAuD;AACvD,6CAA6C;AAC7C,aAAa;AACb,YAAY;AACZ,yBAAyB;AACzB,mEAAmE;AACnE,6CAA6C;AAC7C,aAAa;AACb,WAAW;AACX,SAAS;AACT,EAAE;AACF,gCAAgC;AAChC,iBAAiB;AACjB,kCAAkC;AAClC,mDAAmD;AACnD,4CAA4C;AAC5C,cAAc;AACd,aAAa;AACb,WAAW;AACX,QAAQ;AACR,EAAE;AACF,eAAe;AACf,kBAAkB;AAClB,gDAAgD;AAChD,kDAAkD;AAClD,SAAS;AACT,OAAO;AACP,MAAM;AACN,EAAE;AACF,wDAAwD;AACxD,iEAAiE;AACjE,2BAA2B;AAC3B,gBAAgB;AAChB,aAAa;AACb,WAAW;AACX,WAAW;AACX,iBAAiB;AACjB,iBAAiB;AACjB,eAAe;AACf,WAAW;AACX,YAAY;AACZ,gBAAgB;AAChB,YAAY;AACZ,WAAW;AACX,UAAU;AACV,YAAY;AACZ,UAAU;AACV,WAAW;AACX,UAAU;AACV,WAAW;AACX,YAAY;AACZ,YAAY;AACZ,OAAO;AACP,uCAAuC;AACvC,IAAI;AACJ,EAAE;AACF,yDAAyD;AACzD,mFAAmF;AACnF,4BAA4B;AAC5B,2DAA2D;AAC3D,2DAA2D;AAC3D,EAAE;AACF,qCAAqC;AACrC,mDAAmD;AACnD,2BAA2B;AAC3B,sBAAsB;AACtB,oCAAoC;AACpC,oCAAoC;AACpC,YAAY;AACZ,QAAQ;AACR,MAAM;AACN,EAAE;AACF,wBAAwB;AACxB,IAAI;AACJ,EAAE;AACF,sBAAsB;AACtB,iBAAiB;AACjB,4BAA4B;AAC5B,MAAM;AACN,EAAE;AACF,qBAAqB","sourcesContent":["// import { FastMCP } from \"fastmcp\";\n// import { z } from \"zod\";\n// import { version } from \"../../package.json\";\n// import { ModelContextProtocol } from \"./ModelContextProtocol\";\n// import { Model } from \"../model\";\n// import {\n//   email,\n//   max,\n//   maxlength,\n//   min,\n//   minlength,\n//   pattern,\n//   required,\n// } from \"../validation\";\n// import { createModelTool } from \"./tools/createModel.tool\";\n//\n// const DecoratorValidatonMCP = ModelContextProtocol.builder\n//   .setName(\"decaf-validation-server\")\n//   .setVersion(version)\n//   .addTool(createModelTool)\n//   .build();\n//\n// // Initialize FastMCP server\n// const server = new FastMCP({\n//   name: \"decaf-validation-server\",\n//   // @ts-ignore\n//   version: version,\n// });\n//\n// // Model registry for dynamic model management\n// const modelRegistry = new Map<string, any>();\n//\n// // Tool: Validate a model instance\n// server.addTool({\n//   name: \"validate-model\",\n//   description: \"Validate a model instance against its decorators\",\n//   parameters: z.object({\n//     modelName: z.string().describe(\"Name of the model class\"),\n//     data: z.record(z.any()).describe(\"Data to validate\"),\n//     options: z\n//       .object({\n//         partial: z.boolean().optional().describe(\"Allow partial validation\"),\n//       })\n//       .optional(),\n//   }),\n//   execute: async (args) => {\n//     const { modelName, data, options } = args;\n//\n//     const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);\n//     if (!ModelClass) {\n//       throw new Error(`Model \"${modelName}\" not found`);\n//     }\n//\n//     try {\n//       const instance = new ModelClass(data);\n//       const errors = instance.hasErrors();\n//\n//       return {\n//         isValid: !errors,\n//         errors: errors || null,\n//         validatedData: errors ? null : instance.serialize(),\n//       };\n//     } catch (error) {\n//       return {\n//         isValid: false,\n//         errors: [{ message: error.message }],\n//         validatedData: null,\n//       };\n//     }\n//   },\n// });\n//\n// // Tool: Get model schema information\n// server.addTool({\n//   name: \"get-model-schema\",\n//   description: \"Get the validation schema for a model\",\n//   parameters: z.object({\n//     modelName: z.string().describe(\"Name of the model class\"),\n//   }),\n//   execute: async (args) => {\n//     const { modelName } = args;\n//\n//     const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);\n//     if (!ModelClass) {\n//       throw new Error(`Model \"${modelName}\" not found`);\n//     }\n//\n//     // Extract validation metadata\n//     const instance = new ModelClass();\n//     const metadata = Reflect.getMetadata(\"validation\", instance) || {};\n//\n//     return {\n//       modelName,\n//       properties: Object.keys(metadata).map((key) => ({\n//         name: key,\n//         validators: metadata[key] || [],\n//       })),\n//       capabilities: {\n//         serialization: !!instance.serialize,\n//         hashing: !!instance.hash,\n//         comparison: !!instance.equals,\n//       },\n//     };\n//   },\n// });\n//\n// // Tool: Serialize model\n// server.addTool({\n//   name: \"serialize-model\",\n//   description: \"Serialize a model instance to string\",\n//   parameters: z.object({\n//     modelName: z.string().describe(\"Name of the model class\"),\n//     data: z.record(z.any()).describe(\"Model data to serialize\"),\n//     format: z.enum([\"json\", \"yaml\"]).optional().default(\"json\"),\n//   }),\n//   execute: async (args) => {\n//     const { modelName, data, format } = args;\n//\n//     const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);\n//     if (!ModelClass) {\n//       throw new Error(`Model \"${modelName}\" not found`);\n//     }\n//\n//     const instance = new ModelClass(data);\n//     const errors = instance.hasErrors();\n//\n//     if (errors) {\n//       throw new Error(\n//         `Cannot serialize invalid model: ${JSON.stringify(errors)}`\n//       );\n//     }\n//\n//     return {\n//       serialized: instance.serialize(),\n//       format,\n//       modelName,\n//     };\n//   },\n// });\n//\n// // Tool: Deserialize model\n// server.addTool({\n//   name: \"deserialize-model\",\n//   description: \"Deserialize a string to model instance\",\n//   parameters: z.object({\n//     serializedData: z.string().describe(\"Serialized model data\"),\n//     modelName: z\n//       .string()\n//       .optional()\n//       .describe(\"Expected model name for validation\"),\n//   }),\n//   execute: async (args) => {\n//     const { serializedData, modelName } = args;\n//\n//     try {\n//       const instance = Model.deserialize(serializedData);\n//\n//       if (modelName && instance.constructor.name !== modelName) {\n//         throw new Error(\n//           `Expected model \"${modelName}\", got \"${instance.constructor.name}\"`\n//         );\n//       }\n//\n//       return {\n//         modelName: instance.constructor.name,\n//         data: JSON.parse(instance.serialize()),\n//         isValid: !instance.hasErrors(),\n//       };\n//     } catch (error) {\n//       throw new Error(`Deserialization failed: ${error.message}`);\n//     }\n//   },\n// });\n//\n// // Tool: Compare models\n// server.addTool({\n//   name: \"compare-models\",\n//   description: \"Compare two model instances for equality\",\n//   parameters: z.object({\n//     modelName: z.string().describe(\"Name of the model class\"),\n//     data1: z.record(z.any()).describe(\"First model data\"),\n//     data2: z.record(z.any()).describe(\"Second model data\"),\n//     excludeFields: z\n//       .array(z.string())\n//       .optional()\n//       .describe(\"Fields to exclude from comparison\"),\n//   }),\n//   execute: async (args) => {\n//     const { modelName, data1, data2, excludeFields } = args;\n//\n//     const ModelClass = modelRegistry.get(modelName) || Model.get(modelName);\n//     if (!ModelClass) {\n//       throw new Error(`Model \"${modelName}\" not found`);\n//     }\n//\n//     const instance1 = new ModelClass(data1);\n//     const instance2 = new ModelClass(data2);\n//\n//     const isEqual = excludeFields\n//       ? instance1.equals(instance2, ...excludeFields)\n//       : instance1.equals(instance2);\n//\n//     return {\n//       isEqual,\n//       hash1: instance1.hash(),\n//       hash2: instance2.hash(),\n//       differences: isEqual ? null : await findDifferences(instance1, instance2),\n//     };\n//   },\n// });\n//\n// // Tool: List available decorators\n// server.addTool({\n//   name: \"list-decorators\",\n//   description: \"List all available validation decorators\",\n//   parameters: z.object({\n//     category: z\n//       .enum([\"basic\", \"type-specific\", \"comparison\", \"all\"])\n//       .optional()\n//       .default(\"all\"),\n//   }),\n//   execute: async (args) => {\n//     const { category } = args;\n//\n//     const decorators = {\n//       basic: [\n//         {\n//           name: \"required\",\n//           description: \"Marks field as required\",\n//           args: [\"message?\"],\n//         },\n//         {\n//           name: \"min\",\n//           description: \"Minimum value validation\",\n//           args: [\"value\", \"message?\"],\n//         },\n//         {\n//           name: \"max\",\n//           description: \"Maximum value validation\",\n//           args: [\"value\", \"message?\"],\n//         },\n//         {\n//           name: \"minlength\",\n//           description: \"Minimum length validation\",\n//           args: [\"length\", \"message?\"],\n//         },\n//         {\n//           name: \"maxlength\",\n//           description: \"Maximum length validation\",\n//           args: [\"length\", \"message?\"],\n//         },\n//         {\n//           name: \"pattern\",\n//           description: \"Regex pattern validation\",\n//           args: [\"pattern\", \"message?\"],\n//         },\n//         {\n//           name: \"step\",\n//           description: \"Step value validation\",\n//           args: [\"step\", \"message?\"],\n//         },\n//       ],\n//       \"type-specific\": [\n//         {\n//           name: \"email\",\n//           description: \"Email format validation\",\n//           args: [\"message?\"],\n//         },\n//         {\n//           name: \"url\",\n//           description: \"URL format validation\",\n//           args: [\"message?\"],\n//         },\n//         {\n//           name: \"date\",\n//           description: \"Date format validation\",\n//           args: [\"format?\", \"message?\"],\n//         },\n//         {\n//           name: \"password\",\n//           description: \"Password strength validation\",\n//           args: [\"message?\"],\n//         },\n//         {\n//           name: \"type\",\n//           description: \"Type validation\",\n//           args: [\"type\", \"message?\"],\n//         },\n//         {\n//           name: \"list\",\n//           description: \"Array validation\",\n//           args: [\"itemType\", \"message?\"],\n//         },\n//         {\n//           name: \"set\",\n//           description: \"Set validation\",\n//           args: [\"itemType\", \"message?\"],\n//         },\n//       ],\n//       comparison: [\n//         {\n//           name: \"eq\",\n//           description: \"Equal to another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//         {\n//           name: \"diff\",\n//           description: \"Different from another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//         {\n//           name: \"lt\",\n//           description: \"Less than another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//         {\n//           name: \"lte\",\n//           description: \"Less than or equal to another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//         {\n//           name: \"gt\",\n//           description: \"Greater than another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//         {\n//           name: \"gte\",\n//           description: \"Greater than or equal to another field\",\n//           args: [\"fieldName\", \"message?\"],\n//         },\n//       ],\n//     };\n//\n//     if (category === \"all\") {\n//       return {\n//         categories: decorators,\n//         total: Object.values(decorators).reduce(\n//           (sum, arr) => sum + arr.length,\n//           0\n//         ),\n//       };\n//     }\n//\n//     return {\n//       category,\n//       decorators: decorators[category] || [],\n//       count: decorators[category]?.length || 0,\n//     };\n//   },\n// });\n//\n// // Utility function to get decorator function by name\n// function getDecoratorFunction(name: string): Function | null {\n//   const decoratorMap = {\n//     required,\n//     email,\n//     min,\n//     max,\n//     minlength,\n//     maxlength,\n//     pattern,\n//     url,\n//     date,\n//     password,\n//     list,\n//     set,\n//     eq,\n//     diff,\n//     lt,\n//     lte,\n//     gt,\n//     gte,\n//     type,\n//     step,\n//   };\n//   return decoratorMap[name] || null;\n// }\n//\n// // Utility function to find differences between models\n// async function findDifferences(instance1: any, instance2: any): Promise<any[]> {\n//   const differences = [];\n//   const serialized1 = JSON.parse(instance1.serialize());\n//   const serialized2 = JSON.parse(instance2.serialize());\n//\n//   for (const key in serialized1) {\n//     if (serialized1[key] !== serialized2[key]) {\n//       differences.push({\n//         field: key,\n//         value1: serialized1[key],\n//         value2: serialized2[key],\n//       });\n//     }\n//   }\n//\n//   return differences;\n// }\n//\n// // Start the server\n// server.start({\n//   transportType: \"stdio\",\n// });\n//\n// export { server };\n"]}
|
|
File without changes
|