@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,2 +1,2 @@
|
|
|
1
|
-
import { ValidationKeys } from "./Validators";
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/validation/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAa,MAAM,cAAc,CAAC","sourcesContent":["import { DecoratorMetadata } from \"@decaf-ts/reflection\";\nimport { Constructor } from \"../model\";\nimport { ValidationKeys, Validator } from \"./Validators\";\nimport { IRegistry } from \"../utils\";\n\n/**\n * @description Type definition for metadata used by validation decorators\n * @summary Defines the structure of metadata attached to properties by validation decorators.\n * This metadata is used during validation to determine validation rules and error messages.\n *\n * @property {any[]} [args] - Optional arguments for the validator\n * @property {string} message - Error message to display when validation fails\n * @property {string[]} [types] - Array of type names that the property can have\n *\n * @typedef {Object} ValidationMetadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationMetadata = {\n  [indexer: string]: any;\n  args?: any[];\n  message: string;\n  types?: string[];\n};\n\n/**\n * @description Type definition for property-level validation decorator configuration\n * @summary Defines the structure that associates a property with its validation decorators.\n * This type is used to track which decorators are applied to a specific property during validation.\n *\n * @property {string|symbol} prop - The property name or symbol that the decorators are applied to\n * @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property\n *\n * @typedef {Object} ValidationPropertyDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationPropertyDecoratorDefinition = {\n  prop: string | symbol;\n  decorators: ValidationDecoratorDefinition[];\n};\n\n/**\n * @description Type definition for individual validation decorator metadata\n * @summary Extends the base DecoratorMetadata type with validation-specific properties.\n * This type represents the metadata for a single validation decorator applied to a property.\n *\n * @property {ValidationElementDefinition} props - The validation element properties and configuration\n *\n * @typedef {Object} ValidationDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationDecoratorDefinition = DecoratorMetadata & {\n  props: ValidationElementDefinition;\n};\n\n/**\n * @summary Type for a validator element metadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationElementDefinition = {\n  [indexer: string]: any;\n\n  value?: string | number;\n  message: string;\n  types?: string[];\n};\n\n/**\n * @summary Type for a model errors\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ModelErrors = Record<string, Record<string, string | undefined>>;\n\n/**\n * @summary Util type for {@link Validator} configuration\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorDefinition = {\n  validator: Constructor<Validator>;\n  validationKey: string;\n  save: boolean;\n};\n\n/**\n * @description Interface for a registry that manages validator instances\n * @summary Defines the contract for a registry that stores and retrieves validators.\n * The registry is responsible for maintaining a collection of validators and providing\n * access to them by key.\n *\n * @interface IValidatorRegistry\n * @template T Type of validator, must extend Validator\n * @extends IRegistry<T>\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {\n  /**\n   * @description Retrieves custom validation keys defined in the registry\n   * @summary Returns a mapping of custom validation keys to their corresponding standard keys.\n   * This allows for aliasing validation keys for specific use cases.\n   *\n   * @return {Record<string, string>} Object mapping custom keys to standard validation keys\n   */\n  getCustomKeys(): Record<string, string>;\n\n  /**\n   * @description Gets all registered validator keys\n   * @summary Returns an array of all validation keys that have registered validators.\n   *\n   * @return {string[]} Array of registered validator keys\n   */\n  getKeys(): string[];\n\n  /**\n   * @description Registers one or more validators with the registry\n   * @summary Adds validators to the registry, making them available for validation operations.\n   * Validators can be provided as instances or as validator definitions.\n   *\n   * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register\n   * @return {void}\n   */\n  register<T extends Validator>(\n    ...validator: (T | ValidatorDefinition)[]\n  ): void;\n\n  /**\n   * @description Retrieves a validator by its key\n   * @summary Looks up a validator in the registry using its validation key.\n   * Returns the validator if found, or undefined if no validator is registered for the key.\n   *\n   * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}\n   * @return {T|undefined} The registered validator or undefined if none matches the provided key\n   */\n  get<T extends Validator>(key: string): T | undefined;\n}\n\n/**\n * @description Base options type for all validators\n * @summary Defines the common properties available to all validators\n * @typedef ValidatorOptions\n * @property {string} [message] - Custom error message to display when validation fails\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorOptions = {\n  message?: string;\n};\n\n/**\n * @description URL validation options interface\n * @summary Defines options for URL validation, including allowed URL types\n * @interface URLValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface URLValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Type validation options interface\n * @summary Defines options for type validation, specifying allowed types\n * @interface TypeValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Step validation options interface\n * @summary Defines options for step validation, specifying the step increment\n * @interface StepValidatorOptions\n * @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface StepValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.STEP]: number | string;\n}\n\n/**\n * @description Pattern validation options interface\n * @summary Defines options for pattern validation using regular expressions\n * @interface PatternValidatorOptions\n * @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface PatternValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.PATTERN]?: RegExp | string;\n}\n\n/**\n * @description Minimum value validation options interface\n * @summary Defines options for minimum value validation\n * @interface MinValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN]: number | Date | string;\n}\n\n/**\n * @description Minimum length validation options interface\n * @summary Defines options for minimum length validation\n * @interface MinLengthValidatorOptions\n * @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN_LENGTH]: number;\n}\n\n/**\n * @description Maximum value validation options interface\n * @summary Defines options for maximum value validation\n * @interface MaxValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX]: number | Date | string;\n}\n\n/**\n * @description Maximum length validation options interface\n * @summary Defines options for maximum length validation\n * @interface MaxLengthValidatorOptions\n * @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX_LENGTH]: number;\n}\n\n/**\n * @description List validation options interface\n * @summary Defines options for list validation\n * @interface ListValidatorOptions\n * @property {string[]} clazz - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface ListValidatorOptions extends ValidatorOptions {\n  clazz: string[];\n}\n\n/**\n * @description Date validation options interface\n * @summary Defines options for date validation\n * @interface DateValidatorOptions\n * @property {string} [ValidationKeys.FORMAT] - The expected date format pattern\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface DateValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.FORMAT]?: string;\n}\n\nexport interface EqualsValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
|
|
1
|
+
import { ValidationKeys } from "./Validators/index.js";
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/validation/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAa,8BAAqB","sourcesContent":["import { DecoratorMetadata } from \"@decaf-ts/reflection\";\nimport { Constructor } from \"../model\";\nimport { ValidationKeys, Validator } from \"./Validators\";\nimport { IRegistry } from \"../utils\";\n\n/**\n * @description Type definition for metadata used by validation decorators\n * @summary Defines the structure of metadata attached to properties by validation decorators.\n * This metadata is used during validation to determine validation rules and error messages.\n *\n * @property {any[]} [args] - Optional arguments for the validator\n * @property {string} message - Error message to display when validation fails\n * @property {string[]} [types] - Array of type names that the property can have\n *\n * @typedef {Object} ValidationMetadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationMetadata = {\n  [indexer: string]: any;\n  args?: any[];\n  message: string;\n  types?: string[];\n};\n\n/**\n * @description Type definition for property-level validation decorator configuration\n * @summary Defines the structure that associates a property with its validation decorators.\n * This type is used to track which decorators are applied to a specific property during validation.\n *\n * @property {string|symbol} prop - The property name or symbol that the decorators are applied to\n * @property {ValidationDecoratorDefinition[]} decorators - Array of decorator definitions applied to the property\n *\n * @typedef {Object} ValidationPropertyDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationPropertyDecoratorDefinition = {\n  prop: string | symbol;\n  decorators: ValidationDecoratorDefinition[];\n};\n\n/**\n * @description Type definition for individual validation decorator metadata\n * @summary Extends the base DecoratorMetadata type with validation-specific properties.\n * This type represents the metadata for a single validation decorator applied to a property.\n *\n * @property {ValidationElementDefinition} props - The validation element properties and configuration\n *\n * @typedef {Object} ValidationDecoratorDefinition\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationDecoratorDefinition = DecoratorMetadata & {\n  props: ValidationElementDefinition;\n};\n\n/**\n * @summary Type for a validator element metadata\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidationElementDefinition = {\n  [indexer: string]: any;\n\n  value?: string | number;\n  message: string;\n  description: string;\n  types?: string[];\n};\n\n/**\n * @summary Type for a model errors\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ModelErrors = Record<string, Record<string, string | undefined>>;\n\n/**\n * @summary Util type for {@link Validator} configuration\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport type ValidatorDefinition = {\n  validator: Constructor<Validator>;\n  validationKey: string;\n  save: boolean;\n};\n\n/**\n * @description Interface for a registry that manages validator instances\n * @summary Defines the contract for a registry that stores and retrieves validators.\n * The registry is responsible for maintaining a collection of validators and providing\n * access to them by key.\n *\n * @interface IValidatorRegistry\n * @template T Type of validator, must extend Validator\n * @extends IRegistry<T>\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface IValidatorRegistry<T extends Validator> extends IRegistry<T> {\n  /**\n   * @description Retrieves custom validation keys defined in the registry\n   * @summary Returns a mapping of custom validation keys to their corresponding standard keys.\n   * This allows for aliasing validation keys for specific use cases.\n   *\n   * @return {Record<string, string>} Object mapping custom keys to standard validation keys\n   */\n  getCustomKeys(): Record<string, string>;\n\n  /**\n   * @description Gets all registered validator keys\n   * @summary Returns an array of all validation keys that have registered validators.\n   *\n   * @return {string[]} Array of registered validator keys\n   */\n  getKeys(): string[];\n\n  /**\n   * @description Registers one or more validators with the registry\n   * @summary Adds validators to the registry, making them available for validation operations.\n   * Validators can be provided as instances or as validator definitions.\n   *\n   * @param {...(T|ValidatorDefinition)} validator - Validator instances or definitions to register\n   * @return {void}\n   */\n  register<T extends Validator>(\n    ...validator: (T | ValidatorDefinition)[]\n  ): void;\n\n  /**\n   * @description Retrieves a validator by its key\n   * @summary Looks up a validator in the registry using its validation key.\n   * Returns the validator if found, or undefined if no validator is registered for the key.\n   *\n   * @param {string} key - The validation key to look up, typically one of the {@link ValidationKeys}\n   * @return {T|undefined} The registered validator or undefined if none matches the provided key\n   */\n  get<T extends Validator>(key: string): T | undefined;\n}\n\n/**\n * @description Base options type for all validators\n * @summary Defines the common properties available to all validators\n * @interface ValidatorOptions\n * @property {string} [message] - Custom error message to display when validation fails\n * @category Validation\n */\nexport interface ValidatorOptions {\n  message?: string;\n  description?: string;\n}\n\n/**\n * @description URL validation options interface\n * @summary Defines options for URL validation, including allowed URL types\n * @interface URLValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed URL types or patterns\n * @category Validation\n */\nexport interface URLValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Type validation options interface\n * @summary Defines options for type validation, specifying allowed types\n * @interface TypeValidatorOptions\n * @property {(string|string[]|{ name: string })} types - Specifies the allowed data types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface TypeValidatorOptions extends ValidatorOptions {\n  types: string | string[] | { name: string };\n}\n\n/**\n * @description Step validation options interface\n * @summary Defines options for step validation, specifying the step increment\n * @interface StepValidatorOptions\n * @property {(number|string)} [ValidationKeys.STEP] - The step value for numerical validation\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface StepValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.STEP]: number | string;\n  types?: string[];\n}\n\n/**\n * @description Pattern validation options interface\n * @summary Defines options for pattern validation using regular expressions\n * @interface PatternValidatorOptions\n * @property {(RegExp|string)} [ValidationKeys.PATTERN] - The pattern to match against\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface PatternValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.PATTERN]?: RegExp | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum value validation options interface\n * @summary Defines options for minimum value validation\n * @interface MinValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MIN] - The minimum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Minimum length validation options interface\n * @summary Defines options for minimum length validation\n * @interface MinLengthValidatorOptions\n * @property {number} [ValidationKeys.MIN_LENGTH] - The minimum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MinLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MIN_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description Maximum value validation options interface\n * @summary Defines options for maximum value validation\n * @interface MaxValidatorOptions\n * @property {(number|Date|string)} [ValidationKeys.MAX] - The maximum allowed value\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX]: number | Date | string;\n  types?: string[];\n}\n\n/**\n * @description Maximum length validation options interface\n * @summary Defines options for maximum length validation\n * @interface MaxLengthValidatorOptions\n * @property {number} [ValidationKeys.MAX_LENGTH] - The maximum allowed length\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface MaxLengthValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.MAX_LENGTH]: number;\n  types?: string[];\n}\n\n/**\n * @description List validation options interface\n * @summary Defines options for list validation\n * @interface ListValidatorOptions\n * @property {string[]} clazz - Array of allowed class names or types\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface ListValidatorOptions extends ValidatorOptions {\n  clazz: string[];\n}\n\n/**\n * @description Date validation options interface\n * @summary Defines options for date validation\n * @interface DateValidatorOptions\n * @property {string} [ValidationKeys.FORMAT] - The expected date format pattern\n * @memberOf module:decorator-validation\n * @category Validation\n */\nexport interface DateValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.FORMAT]?: string;\n}\n\nexport interface EqualsValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.EQUALS]: string;\n}\n\nexport interface DiffValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.DIFF]: string;\n}\n\nexport interface LessThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN]: string;\n}\n\nexport interface LessThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.LESS_THAN_OR_EQUAL]: string;\n}\n\nexport interface GreaterThanValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN]: string;\n}\n\nexport interface GreaterThanOrEqualValidatorOptions extends ValidatorOptions {\n  [ValidationKeys.GREATER_THAN_OR_EQUAL]: string;\n}\n"]}
|
package/lib/index.cjs
CHANGED
|
@@ -32,5 +32,5 @@ __exportStar(require("./model/index.cjs"), exports);
|
|
|
32
32
|
* @const VERSION
|
|
33
33
|
* @memberOf module:decorator-validation
|
|
34
34
|
*/
|
|
35
|
-
exports.VERSION = "1.7.
|
|
35
|
+
exports.VERSION = "1.7.6";
|
|
36
36
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7Ozs7O0dBTUc7QUFDSCx3REFBNEI7QUFDNUIsb0RBQXdCO0FBQ3hCLHlEQUE2QjtBQUM3QixvREFBd0I7QUFFeEI7Ozs7O0dBS0c7QUFDVSxRQUFBLE9BQU8sR0FBRyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBtb2R1bGUgZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqIEBkZXNjcmlwdGlvbiBUeXBlU2NyaXB0IGRlY29yYXRvci1iYXNlZCB2YWxpZGF0aW9uIGxpYnJhcnlcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIGEgY29tcHJlaGVuc2l2ZSB2YWxpZGF0aW9uIGZyYW1ld29yayB1c2luZyBUeXBlU2NyaXB0IGRlY29yYXRvcnMuXG4gKiBJdCBleHBvc2VzIHV0aWxpdHkgZnVuY3Rpb25zLCB2YWxpZGF0aW9uIGRlY29yYXRvcnMsIGFuZCBtb2RlbC1yZWxhdGVkIGZ1bmN0aW9uYWxpdHkgZm9yXG4gKiBpbXBsZW1lbnRpbmcgdHlwZS1zYWZlLCBkZWNsYXJhdGl2ZSB2YWxpZGF0aW9uIGluIFR5cGVTY3JpcHQgYXBwbGljYXRpb25zLlxuICovXG5leHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi92YWxpZGF0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RlbFwiO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBDdXJyZW50IHZlcnNpb24gb2YgdGhlIHJlZmxlY3Rpb24gcGFja2FnZVxuICogQHN1bW1hcnkgU3RvcmVzIHRoZSBzZW1hbnRpYyB2ZXJzaW9uIG51bWJlciBvZiB0aGUgcGFja2FnZVxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6ZGVjb3JhdG9yLXZhbGlkYXRpb25cbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG4iXX0=
|
package/lib/index.d.ts
CHANGED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ModelContextProtocol = void 0;
|
|
4
|
+
const fastmcp_1 = require("fastmcp");
|
|
5
|
+
const logging_1 = require("@decaf-ts/logging");
|
|
6
|
+
class ModelContextProtocol {
|
|
7
|
+
get log() {
|
|
8
|
+
return logging_1.Logging.for(this);
|
|
9
|
+
}
|
|
10
|
+
constructor(mcp) {
|
|
11
|
+
this.mcp = mcp;
|
|
12
|
+
}
|
|
13
|
+
static { this.Builder = class Builder {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.tools = {};
|
|
16
|
+
this.log = logging_1.Logging.for("MCP Builder");
|
|
17
|
+
}
|
|
18
|
+
setName(value) {
|
|
19
|
+
this.name = value;
|
|
20
|
+
this.log.debug(`name set to ${value}`);
|
|
21
|
+
return this;
|
|
22
|
+
}
|
|
23
|
+
setVersion(value) {
|
|
24
|
+
this.version = ModelContextProtocol.validateVersion(value);
|
|
25
|
+
this.log.debug(`version set to ${value}`);
|
|
26
|
+
return this;
|
|
27
|
+
}
|
|
28
|
+
addTool(config) {
|
|
29
|
+
const { name } = config;
|
|
30
|
+
if (name in this.tools)
|
|
31
|
+
throw new Error(`tool ${name} already registered`);
|
|
32
|
+
this.tools[name] = config;
|
|
33
|
+
this.log.debug(`tool ${name} added`);
|
|
34
|
+
return this;
|
|
35
|
+
}
|
|
36
|
+
build() {
|
|
37
|
+
if (!this.name)
|
|
38
|
+
throw new Error("name is required");
|
|
39
|
+
if (!this.version)
|
|
40
|
+
throw new Error("version is required");
|
|
41
|
+
const mcp = new fastmcp_1.FastMCP({
|
|
42
|
+
name: this.name,
|
|
43
|
+
version: this.version,
|
|
44
|
+
});
|
|
45
|
+
Object.values(this.tools).forEach((tool) => {
|
|
46
|
+
try {
|
|
47
|
+
mcp.addTool(tool);
|
|
48
|
+
}
|
|
49
|
+
catch (e) {
|
|
50
|
+
throw new Error(`Failed to add tool ${tool.name}: ${e}`);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
this.log.info(`${this.name} MCP built`);
|
|
54
|
+
this.log.debug(`${this.name} MCP - available tools: ${Object.keys(this.tools).join(", ")}`);
|
|
55
|
+
return new ModelContextProtocol(mcp);
|
|
56
|
+
}
|
|
57
|
+
}; }
|
|
58
|
+
static get builder() {
|
|
59
|
+
return new ModelContextProtocol.Builder();
|
|
60
|
+
}
|
|
61
|
+
static validateVersion(version) {
|
|
62
|
+
const regexp = /(\d+)\.(\d+)\.(\d+)/g;
|
|
63
|
+
const match = regexp.exec(version);
|
|
64
|
+
if (!match)
|
|
65
|
+
throw new Error(`Invalid version string. should obey semantic versioning: ${version}`);
|
|
66
|
+
return `${match[1]}.${match[2]}.${match[3]}`;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
exports.ModelContextProtocol = ModelContextProtocol;
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiTW9kZWxDb250ZXh0UHJvdG9jb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbWNwL01vZGVsQ29udGV4dFByb3RvY29sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFDQUF3QztBQUN4QywrQ0FBb0Q7QUFHcEQsTUFBYSxvQkFBb0I7SUFDL0IsSUFBYyxHQUFHO1FBQ2YsT0FBTyxpQkFBTyxDQUFDLEdBQUcsQ0FBQyxJQUFXLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsWUFBK0IsR0FBa0I7UUFBbEIsUUFBRyxHQUFILEdBQUcsQ0FBZTtJQUFHLENBQUM7YUFFckMsWUFBTyxHQUFHLE1BQU0sT0FBTztRQU9yQztZQUpBLFVBQUssR0FBbUMsRUFBRSxDQUFDO1lBRTNDLFFBQUcsR0FBRyxpQkFBTyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUVsQixDQUFDO1FBRWhCLE9BQU8sQ0FBQyxLQUFhO1lBQ25CLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1lBQ2xCLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLGVBQWUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUN2QyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxVQUFVLENBQUMsS0FBYTtZQUN0QixJQUFJLENBQUMsT0FBTyxHQUFHLG9CQUFvQixDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMzRCxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUMxQyxPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFFRCxPQUFPLENBQ0wsTUFBdUI7WUFFdkIsTUFBTSxFQUFFLElBQUksRUFBRSxHQUFHLE1BQU0sQ0FBQztZQUN4QixJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSztnQkFDcEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxRQUFRLElBQUkscUJBQXFCLENBQUMsQ0FBQztZQUNyRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLE1BQU0sQ0FBQztZQUMxQixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxRQUFRLElBQUksUUFBUSxDQUFDLENBQUM7WUFDckMsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBRUQsS0FBSztZQUdILElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSTtnQkFBRSxNQUFNLElBQUksS0FBSyxDQUFDLGtCQUFrQixDQUFDLENBQUM7WUFDcEQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPO2dCQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMscUJBQXFCLENBQUMsQ0FBQztZQUMxRCxNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFPLENBQU87Z0JBQzVCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtnQkFDZixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87YUFDdEIsQ0FBQyxDQUFDO1lBQ0gsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7Z0JBQ3pDLElBQUksQ0FBQztvQkFDSCxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNwQixDQUFDO2dCQUFDLE9BQU8sQ0FBVSxFQUFFLENBQUM7b0JBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLElBQUksQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDM0QsQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxZQUFZLENBQUMsQ0FBQztZQUN4QyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FDWixHQUFHLElBQUksQ0FBQyxJQUFJLDJCQUEyQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FDNUUsQ0FBQztZQUNGLE9BQU8sSUFBSSxvQkFBb0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN2QyxDQUFDO0tBQ0YsQ0FBQztJQUVGLE1BQU0sS0FBSyxPQUFPO1FBQ2hCLE9BQU8sSUFBSSxvQkFBb0IsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBRU8sTUFBTSxDQUFDLGVBQWUsQ0FDNUIsT0FBZTtRQUVmLE1BQU0sTUFBTSxHQUFHLHNCQUFzQixDQUFDO1FBQ3RDLE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbkMsSUFBSSxDQUFDLEtBQUs7WUFDUixNQUFNLElBQUksS0FBSyxDQUNiLDREQUE0RCxPQUFPLEVBQUUsQ0FDdEUsQ0FBQztRQUNKLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBcUMsQ0FBQztJQUNsRixDQUFDOztBQTdFSCxvREE4RUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGYXN0TUNQLCBUb29sIH0gZnJvbSBcImZhc3RtY3BcIjtcbmltcG9ydCB7IExvZ2dlciwgTG9nZ2luZyB9IGZyb20gXCJAZGVjYWYtdHMvbG9nZ2luZ1wiO1xuaW1wb3J0IHsgRmFzdE1DUFNlc3Npb25BdXRoIH0gZnJvbSBcIi4vdHlwZXNcIjtcblxuZXhwb3J0IGNsYXNzIE1vZGVsQ29udGV4dFByb3RvY29sPEF1dGggZXh0ZW5kcyBGYXN0TUNQU2Vzc2lvbkF1dGggPSB1bmRlZmluZWQ+IHtcbiAgcHJvdGVjdGVkIGdldCBsb2coKTogTG9nZ2VyIHtcbiAgICByZXR1cm4gTG9nZ2luZy5mb3IodGhpcyBhcyBhbnkpO1xuICB9XG5cbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIHJlYWRvbmx5IG1jcDogRmFzdE1DUDxBdXRoPikge31cblxuICBzdGF0aWMgcmVhZG9ubHkgQnVpbGRlciA9IGNsYXNzIEJ1aWxkZXIge1xuICAgIG5hbWUhOiBzdHJpbmc7XG4gICAgdmVyc2lvbiE6IGAke251bWJlcn0uJHtudW1iZXJ9LiR7bnVtYmVyfWA7XG4gICAgdG9vbHM6IFJlY29yZDxzdHJpbmcsIFRvb2w8YW55LCBhbnk+PiA9IHt9O1xuXG4gICAgbG9nID0gTG9nZ2luZy5mb3IoXCJNQ1AgQnVpbGRlclwiKTtcblxuICAgIGNvbnN0cnVjdG9yKCkge31cblxuICAgIHNldE5hbWUodmFsdWU6IHN0cmluZykge1xuICAgICAgdGhpcy5uYW1lID0gdmFsdWU7XG4gICAgICB0aGlzLmxvZy5kZWJ1ZyhgbmFtZSBzZXQgdG8gJHt2YWx1ZX1gKTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIHNldFZlcnNpb24odmFsdWU6IHN0cmluZykge1xuICAgICAgdGhpcy52ZXJzaW9uID0gTW9kZWxDb250ZXh0UHJvdG9jb2wudmFsaWRhdGVWZXJzaW9uKHZhbHVlKTtcbiAgICAgIHRoaXMubG9nLmRlYnVnKGB2ZXJzaW9uIHNldCB0byAke3ZhbHVlfWApO1xuICAgICAgcmV0dXJuIHRoaXM7XG4gICAgfVxuXG4gICAgYWRkVG9vbDxBdXRoIGV4dGVuZHMgRmFzdE1DUFNlc3Npb25BdXRoID0gdW5kZWZpbmVkPihcbiAgICAgIGNvbmZpZzogVG9vbDxBdXRoLCBhbnk+XG4gICAgKSB7XG4gICAgICBjb25zdCB7IG5hbWUgfSA9IGNvbmZpZztcbiAgICAgIGlmIChuYW1lIGluIHRoaXMudG9vbHMpXG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgdG9vbCAke25hbWV9IGFscmVhZHkgcmVnaXN0ZXJlZGApO1xuICAgICAgdGhpcy50b29sc1tuYW1lXSA9IGNvbmZpZztcbiAgICAgIHRoaXMubG9nLmRlYnVnKGB0b29sICR7bmFtZX0gYWRkZWRgKTtcbiAgICAgIHJldHVybiB0aGlzO1xuICAgIH1cblxuICAgIGJ1aWxkPFxuICAgICAgQXV0aCBleHRlbmRzIEZhc3RNQ1BTZXNzaW9uQXV0aCA9IHVuZGVmaW5lZCxcbiAgICA+KCk6IE1vZGVsQ29udGV4dFByb3RvY29sPEF1dGg+IHtcbiAgICAgIGlmICghdGhpcy5uYW1lKSB0aHJvdyBuZXcgRXJyb3IoXCJuYW1lIGlzIHJlcXVpcmVkXCIpO1xuICAgICAgaWYgKCF0aGlzLnZlcnNpb24pIHRocm93IG5ldyBFcnJvcihcInZlcnNpb24gaXMgcmVxdWlyZWRcIik7XG4gICAgICBjb25zdCBtY3AgPSBuZXcgRmFzdE1DUDxBdXRoPih7XG4gICAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgICAgdmVyc2lvbjogdGhpcy52ZXJzaW9uLFxuICAgICAgfSk7XG4gICAgICBPYmplY3QudmFsdWVzKHRoaXMudG9vbHMpLmZvckVhY2goKHRvb2wpID0+IHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBtY3AuYWRkVG9vbCh0b29sKTtcbiAgICAgICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGFkZCB0b29sICR7dG9vbC5uYW1lfTogJHtlfWApO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICAgIHRoaXMubG9nLmluZm8oYCR7dGhpcy5uYW1lfSBNQ1AgYnVpbHRgKTtcbiAgICAgIHRoaXMubG9nLmRlYnVnKFxuICAgICAgICBgJHt0aGlzLm5hbWV9IE1DUCAtIGF2YWlsYWJsZSB0b29sczogJHtPYmplY3Qua2V5cyh0aGlzLnRvb2xzKS5qb2luKFwiLCBcIil9YFxuICAgICAgKTtcbiAgICAgIHJldHVybiBuZXcgTW9kZWxDb250ZXh0UHJvdG9jb2wobWNwKTtcbiAgICB9XG4gIH07XG5cbiAgc3RhdGljIGdldCBidWlsZGVyKCkge1xuICAgIHJldHVybiBuZXcgTW9kZWxDb250ZXh0UHJvdG9jb2wuQnVpbGRlcigpO1xuICB9XG5cbiAgcHJpdmF0ZSBzdGF0aWMgdmFsaWRhdGVWZXJzaW9uKFxuICAgIHZlcnNpb246IHN0cmluZ1xuICApOiBgJHtudW1iZXJ9LiR7bnVtYmVyfS4ke251bWJlcn1gIHtcbiAgICBjb25zdCByZWdleHAgPSAvKFxcZCspXFwuKFxcZCspXFwuKFxcZCspL2c7XG4gICAgY29uc3QgbWF0Y2ggPSByZWdleHAuZXhlYyh2ZXJzaW9uKTtcbiAgICBpZiAoIW1hdGNoKVxuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBgSW52YWxpZCB2ZXJzaW9uIHN0cmluZy4gc2hvdWxkIG9iZXkgc2VtYW50aWMgdmVyc2lvbmluZzogJHt2ZXJzaW9ufWBcbiAgICAgICk7XG4gICAgcmV0dXJuIGAke21hdGNoWzFdfS4ke21hdGNoWzJdfS4ke21hdGNoWzNdfWAgYXMgYCR7bnVtYmVyfS4ke251bWJlcn0uJHtudW1iZXJ9YDtcbiAgfVxufVxuIl19
|
|
@@ -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
|
+
}
|
package/lib/mcp/mcp1.cjs
ADDED
|
@@ -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":"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","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
|