/* * OpenAPI Petstore * * This is a sample server Petstore server. For this sample, you can use the api key `special-key` to test the authorization filters. * * API version: 1.0.0 * Generated by: OpenAPI Generator (https://openapi-generator.tech) */ package petstoreserver import ( "net/http" ) // ParsingError indicates that an error has occurred when parsing request parameters type ParsingError struct { Err error } func (e *ParsingError) Unwrap() error { return e.Err } func (e *ParsingError) Error() string { return e.Err.Error() } // ErrorHandler defines the required method for handling error. You may implement it and inject this into a controller if // you would like errors to be handled differently from the DefaultErrorHandler type ErrorHandler func(w http.ResponseWriter, r *http.Request, err error, result *ImplResponse) // DefaultErrorHandler defines the default logic on how to handle errors from the controller. Any errors from parsing // request params will return a StatusBadRequest. Otherwise, the error code originating from the servicer will be used. func DefaultErrorHandler(w http.ResponseWriter, r *http.Request, err error, result *ImplResponse) { if _, ok := err.(*ParsingError); ok { // Handle parsing errors EncodeJSONResponse(err.Error(), func(i int) *int { return &i }(http.StatusBadRequest), map[string][]string{}, w) } else { // Handle all other errors EncodeJSONResponse(err.Error(), &result.Code, result.Headers, w) } }