ExMCP.Content.SchemaValidator (ex_mcp v0.9.2)
View SourceSchema validation for MCP content.
This module handles all schema-based validation, including JSON Schema validation and custom schema rules. Extracted from the original Content.Validation module to follow Single Responsibility Principle.
Summary
Functions
Validates content format and structure.
Validates content size against maximum limits.
Validates MIME types against allowed types.
Validates that required fields are present and non-empty.
Validates content against a JSON Schema.
Types
@type validation_result() :: :ok | {:error, [validation_error()]}
Functions
@spec validate_format(ExMCP.Content.Protocol.content()) :: validation_result()
Validates content format and structure.
@spec validate_max_size(ExMCP.Content.Protocol.content(), pos_integer()) :: validation_result()
Validates content size against maximum limits.
@spec validate_mime_types(ExMCP.Content.Protocol.content(), [String.t()]) :: validation_result()
Validates MIME types against allowed types.
@spec validate_required_fields(ExMCP.Content.Protocol.content()) :: validation_result()
Validates that required fields are present and non-empty.
@spec validate_schema(ExMCP.Content.Protocol.content(), map()) :: validation_result()
Validates content against a JSON Schema.
Examples
schema = %{
type: "object",
properties: %{
name: %{type: "string"},
age: %{type: "integer", minimum: 0}
},
required: ["name"]
}
case SchemaValidator.validate_schema(content, schema) do
:ok -> :valid
{:error, errors} -> handle_errors(errors)
end