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.

63 lines
1.9 KiB

  1. // Copyright 2015 go-swagger maintainers
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package runtime
  15. import (
  16. "fmt"
  17. "io"
  18. )
  19. // A ClientResponse represents a client response
  20. // This bridges between responses obtained from different transports
  21. type ClientResponse interface {
  22. Code() int
  23. Message() string
  24. GetHeader(string) string
  25. Body() io.ReadCloser
  26. }
  27. // A ClientResponseReaderFunc turns a function into a ClientResponseReader interface implementation
  28. type ClientResponseReaderFunc func(ClientResponse, Consumer) (interface{}, error)
  29. // ReadResponse reads the response
  30. func (read ClientResponseReaderFunc) ReadResponse(resp ClientResponse, consumer Consumer) (interface{}, error) {
  31. return read(resp, consumer)
  32. }
  33. // A ClientResponseReader is an interface for things want to read a response.
  34. // An application of this is to create structs from response values
  35. type ClientResponseReader interface {
  36. ReadResponse(ClientResponse, Consumer) (interface{}, error)
  37. }
  38. // NewAPIError creates a new API error
  39. func NewAPIError(opName string, payload interface{}, code int) *APIError {
  40. return &APIError{
  41. OperationName: opName,
  42. Response: payload,
  43. Code: code,
  44. }
  45. }
  46. // APIError wraps an error model and captures the status code
  47. type APIError struct {
  48. OperationName string
  49. Response interface{}
  50. Code int
  51. }
  52. func (a *APIError) Error() string {
  53. return fmt.Sprintf("%s (status %d): %+v ", a.OperationName, a.Code, a.Response)
  54. }