A validation module for libopenapi.
libopenapi-validator will validate the following elements against an OpenAPI 3+ specification
- http.Request - Validates the request against the OpenAPI specification
- http.Response - Validates the response against the OpenAPI specification
- libopenapi.Document - Validates the OpenAPI document against the OpenAPI specification
- base.Schema - Validates a schema against a JSON or YAML blob / unmarshalled object
👉👉 Check out the full documentation 👈👈
go get github.com/pb33f/libopenapi-validatorgo run github.com/pb33f/libopenapi-validator/cmd/validate@latest [--regexengine] [--yaml2json] <file>🔍 Example: Use a custom regex engine/flag (e.g., ecmascript)
go run github.com/pb33f/libopenapi-validator/cmd/validate@latest --regexengine=ecmascript <file>🔧 Supported --regexengine flags/values (ℹ️ Default: re2)
- none
- ignorecase
- multiline
- explicitcapture
- compiled
- singleline
- ignorepatternwhitespace
- righttoleft
- debug
- ecmascript
- re2
- unicode
🔍 Convert YAML files to JSON before validation (ℹ️ Default: false)
libopenapi passes map[interface{}]interface{} structures for deeply nested objects or complex mappings in the OpenAPI specification, which are not allowed in JSON.
These structures cannot be properly converted to JSON by libopenapi and cannot be validated by jsonschema, resulting in ambiguous errors.
This flag allows pre-converting from YAML to JSON to bypass this limitation of the libopenapi.
When does this happen?
- OpenAPI specs with deeply nested schema definitions
- Complex
allOf,oneOf, oranyOfstructures with multiple levels - Specifications with intricate object mappings in examples or schema properties
Enabling this flag pre-converts the YAML document from YAML to JSON, ensuring a clean JSON structure before validation.
Example:
go run github.com/pb33f/libopenapi-validator/cmd/validate@latest --yaml2json <file>- The structure of the validator
- Validating http.Request
- Validating http.Request and http.Response
- Validating just http.Response
- Validating HTTP Parameters
- Validating an OpenAPI document
- Validating Schemas
libopenapi and libopenapi-validator are products of Princess Beef Heavy Industries, LLC
