You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							360 lines
						
					
					
						
							19 KiB
						
					
					
				
			
		
		
	
	
							360 lines
						
					
					
						
							19 KiB
						
					
					
				| // Copyright 2015 go-swagger maintainers
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //    http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package validate
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 
 | |
| 	"github.com/go-openapi/errors"
 | |
| )
 | |
| 
 | |
| // Error messages related to spec validation and returned as results.
 | |
| const (
 | |
| 	// ArrayRequiresItemsError ...
 | |
| 	ArrayRequiresItemsError = "%s for %q is a collection without an element type (array requires items definition)"
 | |
| 
 | |
| 	// ArrayInParamRequiresItemsError ...
 | |
| 	ArrayInParamRequiresItemsError = "param %q for %q is a collection without an element type (array requires item definition)"
 | |
| 
 | |
| 	// ArrayInHeaderRequiresItemsError ...
 | |
| 	ArrayInHeaderRequiresItemsError = "header %q for %q is a collection without an element type (array requires items definition)"
 | |
| 
 | |
| 	// BothFormDataAndBodyError indicates that an operation specifies both a body and a formData parameter, which is forbidden
 | |
| 	BothFormDataAndBodyError = "operation %q has both formData and body parameters. Only one such In: type may be used for a given operation"
 | |
| 
 | |
| 	// CannotResolveRefError when a $ref could not be resolved
 | |
| 	CannotResolveReferenceError = "could not resolve reference in %s to $ref %s: %v"
 | |
| 
 | |
| 	// CircularAncestryDefinitionError ...
 | |
| 	CircularAncestryDefinitionError = "definition %q has circular ancestry: %v"
 | |
| 
 | |
| 	// DefaultValueDoesNotValidateError results from an invalid default value provided
 | |
| 	DefaultValueDoesNotValidateError = "default value for %s in %s does not validate its schema"
 | |
| 
 | |
| 	// DefaultValueItemsDoesNotValidateError results from an invalid default value provided for Items
 | |
| 	DefaultValueItemsDoesNotValidateError = "default value for %s.items in %s does not validate its schema"
 | |
| 
 | |
| 	// DefaultValueHeaderDoesNotValidateError results from an invalid default value provided in header
 | |
| 	DefaultValueHeaderDoesNotValidateError = "in operation %q, default value in header %s for %s does not validate its schema"
 | |
| 
 | |
| 	// DefaultValueHeaderItemsDoesNotValidateError results from an invalid default value provided in header.items
 | |
| 	DefaultValueHeaderItemsDoesNotValidateError = "in operation %q, default value in header.items %s for %s does not validate its schema"
 | |
| 
 | |
| 	// DefaultValueInDoesNotValidateError ...
 | |
| 	DefaultValueInDoesNotValidateError = "in operation %q, default value in %s does not validate its schema"
 | |
| 
 | |
| 	// DuplicateParamNameError ...
 | |
| 	DuplicateParamNameError = "duplicate parameter name %q for %q in operation %q"
 | |
| 
 | |
| 	// DuplicatePropertiesError ...
 | |
| 	DuplicatePropertiesError = "definition %q contains duplicate properties: %v"
 | |
| 
 | |
| 	// ExampleValueDoesNotValidateError results from an invalid example value provided
 | |
| 	ExampleValueDoesNotValidateError = "example value for %s in %s does not validate its schema"
 | |
| 
 | |
| 	// ExampleValueItemsDoesNotValidateError results from an invalid example value provided for Items
 | |
| 	ExampleValueItemsDoesNotValidateError = "example value for %s.items in %s does not validate its schema"
 | |
| 
 | |
| 	// ExampleValueHeaderDoesNotValidateError results from an invalid example value provided in header
 | |
| 	ExampleValueHeaderDoesNotValidateError = "in operation %q, example value in header %s for %s does not validate its schema"
 | |
| 
 | |
| 	// ExampleValueHeaderItemsDoesNotValidateError results from an invalid example value provided in header.items
 | |
| 	ExampleValueHeaderItemsDoesNotValidateError = "in operation %q, example value in header.items %s for %s does not validate its schema"
 | |
| 
 | |
| 	// ExampleValueInDoesNotValidateError ...
 | |
| 	ExampleValueInDoesNotValidateError = "in operation %q, example value in %s does not validate its schema"
 | |
| 
 | |
| 	// EmptyPathParameterError means that a path parameter was found empty (e.g. "{}")
 | |
| 	EmptyPathParameterError = "%q contains an empty path parameter"
 | |
| 
 | |
| 	// InvalidDocumentError states that spec validation only processes spec.Document objects
 | |
| 	InvalidDocumentError = "spec validator can only validate spec.Document objects"
 | |
| 
 | |
| 	// InvalidItemsPatternError indicates an Items definition with invalid pattern
 | |
| 	InvalidItemsPatternError = "%s for %q has invalid items pattern: %q"
 | |
| 
 | |
| 	// InvalidParameterDefinitionError indicates an error detected on a parameter definition
 | |
| 	InvalidParameterDefinitionError = "invalid definition for parameter %s in %s in operation %q"
 | |
| 
 | |
| 	// InvalidParameterDefinitionAsSchemaError indicates an error detected on a parameter definition, which was mistaken with a schema definition.
 | |
| 	// Most likely, this situation is encountered whenever a $ref has been added as a sibling of the parameter definition.
 | |
| 	InvalidParameterDefinitionAsSchemaError = "invalid definition as Schema for parameter %s in %s in operation %q"
 | |
| 
 | |
| 	// InvalidPatternError ...
 | |
| 	InvalidPatternError = "pattern %q is invalid in %s"
 | |
| 
 | |
| 	// InvalidPatternInError indicates an invalid pattern in a schema or items definition
 | |
| 	InvalidPatternInError = "%s in %s has invalid pattern: %q"
 | |
| 
 | |
| 	// InvalidPatternInHeaderError indicates a header definition with an invalid pattern
 | |
| 	InvalidPatternInHeaderError = "in operation %q, header %s for %s has invalid pattern %q: %v"
 | |
| 
 | |
| 	// InvalidPatternInParamError ...
 | |
| 	InvalidPatternInParamError = "operation %q has invalid pattern in param %q: %q"
 | |
| 
 | |
| 	// InvalidReferenceError indicates that a $ref property could not be resolved
 | |
| 	InvalidReferenceError = "invalid ref %q"
 | |
| 
 | |
| 	// InvalidResponseDefinitionAsSchemaError indicates an error detected on a response definition, which was mistaken with a schema definition.
 | |
| 	// Most likely, this situation is encountered whenever a $ref has been added as a sibling of the response definition.
 | |
| 	InvalidResponseDefinitionAsSchemaError = "invalid definition as Schema for response %s in %s"
 | |
| 
 | |
| 	// MultipleBodyParamError indicates that an operation specifies multiple parameter with in: body
 | |
| 	MultipleBodyParamError = "operation %q has more than 1 body param: %v"
 | |
| 
 | |
| 	// NonUniqueOperationIDError indicates that the same operationId has been specified several times
 | |
| 	NonUniqueOperationIDError = "%q is defined %d times"
 | |
| 
 | |
| 	// NoParameterInPathError indicates that a path was found without any parameter
 | |
| 	NoParameterInPathError = "path param %q has no parameter definition"
 | |
| 
 | |
| 	// NoValidPathErrorOrWarning indicates that no single path could be validated. If Paths is empty, this message is only a warning.
 | |
| 	NoValidPathErrorOrWarning = "spec has no valid path defined"
 | |
| 
 | |
| 	// NoValidResponseError indicates that no valid response description could be found for an operation
 | |
| 	NoValidResponseError = "operation %q has no valid response"
 | |
| 
 | |
| 	// PathOverlapError ...
 | |
| 	PathOverlapError = "path %s overlaps with %s"
 | |
| 
 | |
| 	// PathParamNotInPathError indicates that a parameter specified with in: path was not found in the path specification
 | |
| 	PathParamNotInPathError = "path param %q is not present in path %q"
 | |
| 
 | |
| 	// PathParamNotUniqueError ...
 | |
| 	PathParamNotUniqueError = "params in path %q must be unique: %q conflicts with %q"
 | |
| 
 | |
| 	// PathParamNotRequiredError ...
 | |
| 	PathParamRequiredError = "in operation %q,path param %q must be declared as required"
 | |
| 
 | |
| 	// RefNotAllowedInHeaderError indicates a $ref was found in a header definition, which is not allowed by Swagger
 | |
| 	RefNotAllowedInHeaderError = "IMPORTANT!in %q: $ref are not allowed in headers. In context for header %q%s"
 | |
| 
 | |
| 	// RequiredButNotDefinedError ...
 | |
| 	RequiredButNotDefinedError = "%q is present in required but not defined as property in definition %q"
 | |
| 
 | |
| 	// SomeParametersBrokenError indicates that some parameters could not be resolved, which might result in partial checks to be carried on
 | |
| 	SomeParametersBrokenError = "some parameters definitions are broken in %q.%s. Cannot carry on full checks on parameters for operation %s"
 | |
| 
 | |
| 	// UnresolvedReferencesError indicates that at least one $ref could not be resolved
 | |
| 	UnresolvedReferencesError = "some references could not be resolved in spec. First found: %v"
 | |
| )
 | |
| 
 | |
| // Warning messages related to spec validation and returned as results
 | |
| const (
 | |
| 	// ExamplesWithoutSchemaWarning indicates that examples are provided for a response,but not schema to validate the example against
 | |
| 	ExamplesWithoutSchemaWarning = "Examples provided without schema in operation %q, %s"
 | |
| 
 | |
| 	// ExamplesMimeNotSupportedWarning indicates that examples are provided with a mime type different than application/json, which
 | |
| 	// the validator dos not support yetl
 | |
| 	ExamplesMimeNotSupportedWarning = "No validation attempt for examples for media types other than application/json, in operation %q, %s"
 | |
| 
 | |
| 	// PathParamGarbledWarning ...
 | |
| 	PathParamGarbledWarning = "in path %q, param %q contains {,} or white space. Albeit not stricly illegal, this is probably no what you want"
 | |
| 
 | |
| 	// ParamValidationTypeMismatch indicates that parameter has validation which does not match its type
 | |
| 	ParamValidationTypeMismatch = "validation keywords of parameter %q in path %q don't match its type %s"
 | |
| 
 | |
| 	// PathStrippedParamGarbledWarning ...
 | |
| 	PathStrippedParamGarbledWarning = "path stripped from path parameters %s contains {,} or white space. This is probably no what you want."
 | |
| 
 | |
| 	// ReadOnlyAndRequiredWarning ...
 | |
| 	ReadOnlyAndRequiredWarning = "Required property %s in %q should not be marked as both required and readOnly"
 | |
| 
 | |
| 	// RefShouldNotHaveSiblingsWarning indicates that a $ref was found with a sibling definition. This results in the $ref taking over its siblings,
 | |
| 	// which is most likely not wanted.
 | |
| 	RefShouldNotHaveSiblingsWarning = "$ref property should have no sibling in %q.%s"
 | |
| 
 | |
| 	// RequiredHasDefaultWarning indicates that a required parameter property should not have a default
 | |
| 	RequiredHasDefaultWarning = "%s in %s has a default value and is required as parameter"
 | |
| 
 | |
| 	// UnusedDefinitionWarning ...
 | |
| 	UnusedDefinitionWarning = "definition %q is not used anywhere"
 | |
| 
 | |
| 	// UnusedParamWarning ...
 | |
| 	UnusedParamWarning = "parameter %q is not used anywhere"
 | |
| 
 | |
| 	// UnusedResponseWarning ...
 | |
| 	UnusedResponseWarning = "response %q is not used anywhere"
 | |
| )
 | |
| 
 | |
| // Additional error codes
 | |
| const (
 | |
| 	// InternalErrorCode reports an internal technical error
 | |
| 	InternalErrorCode = http.StatusInternalServerError
 | |
| 	// NotFoundErrorCode indicates that a resource (e.g. a $ref) could not be found
 | |
| 	NotFoundErrorCode = http.StatusNotFound
 | |
| )
 | |
| 
 | |
| func invalidDocumentMsg() errors.Error {
 | |
| 	return errors.New(InternalErrorCode, InvalidDocumentError)
 | |
| }
 | |
| func invalidRefMsg(path string) errors.Error {
 | |
| 	return errors.New(NotFoundErrorCode, InvalidReferenceError, path)
 | |
| }
 | |
| func unresolvedReferencesMsg(err error) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, UnresolvedReferencesError, err)
 | |
| }
 | |
| func noValidPathMsg() errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, NoValidPathErrorOrWarning)
 | |
| }
 | |
| func emptyPathParameterMsg(path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, EmptyPathParameterError, path)
 | |
| }
 | |
| func nonUniqueOperationIDMsg(path string, i int) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, NonUniqueOperationIDError, path, i)
 | |
| }
 | |
| func circularAncestryDefinitionMsg(path string, args interface{}) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, CircularAncestryDefinitionError, path, args)
 | |
| }
 | |
| func duplicatePropertiesMsg(path string, args interface{}) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DuplicatePropertiesError, path, args)
 | |
| }
 | |
| func pathParamNotInPathMsg(path, param string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathParamNotInPathError, param, path)
 | |
| }
 | |
| func arrayRequiresItemsMsg(path, operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ArrayRequiresItemsError, path, operation)
 | |
| }
 | |
| func arrayInParamRequiresItemsMsg(path, operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ArrayInParamRequiresItemsError, path, operation)
 | |
| }
 | |
| func arrayInHeaderRequiresItemsMsg(path, operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ArrayInHeaderRequiresItemsError, path, operation)
 | |
| }
 | |
| func invalidItemsPatternMsg(path, operation, pattern string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidItemsPatternError, path, operation, pattern)
 | |
| }
 | |
| func invalidPatternMsg(pattern, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidPatternError, pattern, path)
 | |
| }
 | |
| func requiredButNotDefinedMsg(path, definition string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, RequiredButNotDefinedError, path, definition)
 | |
| }
 | |
| func pathParamGarbledMsg(path, param string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathParamGarbledWarning, path, param)
 | |
| }
 | |
| func pathStrippedParamGarbledMsg(path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathStrippedParamGarbledWarning, path)
 | |
| }
 | |
| func pathOverlapMsg(path, arg string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathOverlapError, path, arg)
 | |
| }
 | |
| func invalidPatternInParamMsg(operation, param, pattern string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidPatternInParamError, operation, param, pattern)
 | |
| }
 | |
| func pathParamRequiredMsg(operation, param string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathParamRequiredError, operation, param)
 | |
| }
 | |
| func bothFormDataAndBodyMsg(operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, BothFormDataAndBodyError, operation)
 | |
| }
 | |
| func multipleBodyParamMsg(operation string, args interface{}) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, MultipleBodyParamError, operation, args)
 | |
| }
 | |
| func pathParamNotUniqueMsg(path, param, arg string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, PathParamNotUniqueError, path, param, arg)
 | |
| }
 | |
| func duplicateParamNameMsg(path, param, operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DuplicateParamNameError, param, path, operation)
 | |
| }
 | |
| func unusedParamMsg(arg string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, UnusedParamWarning, arg)
 | |
| }
 | |
| func unusedDefinitionMsg(arg string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, UnusedDefinitionWarning, arg)
 | |
| }
 | |
| func unusedResponseMsg(arg string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, UnusedResponseWarning, arg)
 | |
| }
 | |
| func readOnlyAndRequiredMsg(path, param string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ReadOnlyAndRequiredWarning, param, path)
 | |
| }
 | |
| func noParameterInPathMsg(param string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, NoParameterInPathError, param)
 | |
| }
 | |
| func requiredHasDefaultMsg(param, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, RequiredHasDefaultWarning, param, path)
 | |
| }
 | |
| func defaultValueDoesNotValidateMsg(param, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DefaultValueDoesNotValidateError, param, path)
 | |
| }
 | |
| func defaultValueItemsDoesNotValidateMsg(param, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DefaultValueItemsDoesNotValidateError, param, path)
 | |
| }
 | |
| func noValidResponseMsg(operation string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, NoValidResponseError, operation)
 | |
| }
 | |
| func defaultValueHeaderDoesNotValidateMsg(operation, header, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DefaultValueHeaderDoesNotValidateError, operation, header, path)
 | |
| }
 | |
| func defaultValueHeaderItemsDoesNotValidateMsg(operation, header, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DefaultValueHeaderItemsDoesNotValidateError, operation, header, path)
 | |
| }
 | |
| func invalidPatternInHeaderMsg(operation, header, path, pattern string, args interface{}) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidPatternInHeaderError, operation, header, path, pattern, args)
 | |
| }
 | |
| func invalidPatternInMsg(path, in, pattern string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidPatternInError, path, in, pattern)
 | |
| }
 | |
| func defaultValueInDoesNotValidateMsg(operation, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, DefaultValueInDoesNotValidateError, operation, path)
 | |
| }
 | |
| func exampleValueDoesNotValidateMsg(param, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExampleValueDoesNotValidateError, param, path)
 | |
| }
 | |
| func exampleValueItemsDoesNotValidateMsg(param, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExampleValueItemsDoesNotValidateError, param, path)
 | |
| }
 | |
| func exampleValueHeaderDoesNotValidateMsg(operation, header, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExampleValueHeaderDoesNotValidateError, operation, header, path)
 | |
| }
 | |
| func exampleValueHeaderItemsDoesNotValidateMsg(operation, header, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExampleValueHeaderItemsDoesNotValidateError, operation, header, path)
 | |
| }
 | |
| func exampleValueInDoesNotValidateMsg(operation, path string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExampleValueInDoesNotValidateError, operation, path)
 | |
| }
 | |
| func examplesWithoutSchemaMsg(operation, response string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExamplesWithoutSchemaWarning, operation, response)
 | |
| }
 | |
| func examplesMimeNotSupportedMsg(operation, response string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ExamplesMimeNotSupportedWarning, operation, response)
 | |
| }
 | |
| func refNotAllowedInHeaderMsg(path, header, ref string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, RefNotAllowedInHeaderError, path, header, ref)
 | |
| }
 | |
| func cannotResolveRefMsg(path, ref string, err error) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, CannotResolveReferenceError, path, ref, err)
 | |
| }
 | |
| func invalidParameterDefinitionMsg(path, method, operationID string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidParameterDefinitionError, path, method, operationID)
 | |
| }
 | |
| func invalidParameterDefinitionAsSchemaMsg(path, method, operationID string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, InvalidParameterDefinitionAsSchemaError, path, method, operationID)
 | |
| }
 | |
| func parameterValidationTypeMismatchMsg(param, path, typ string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, ParamValidationTypeMismatch, param, path, typ)
 | |
| }
 | |
| 
 | |
| // disabled
 | |
| // func invalidResponseDefinitionAsSchemaMsg(path, method string) errors.Error {
 | |
| //	return errors.New(errors.CompositeErrorCode, InvalidResponseDefinitionAsSchemaError, path, method)
 | |
| // }
 | |
| func someParametersBrokenMsg(path, method, operationID string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, SomeParametersBrokenError, path, method, operationID)
 | |
| }
 | |
| func refShouldNotHaveSiblingsMsg(path, operationID string) errors.Error {
 | |
| 	return errors.New(errors.CompositeErrorCode, RefShouldNotHaveSiblingsWarning, operationID, path)
 | |
| }
 | |
| 
 |