Documentation ¶
Index ¶
- type ErrorContextCarrier
- type JSONWriter
- func (h *JSONWriter) Write(w http.ResponseWriter, r *http.Request, e interface{})
- func (h *JSONWriter) WriteCode(w http.ResponseWriter, r *http.Request, code int, e interface{})
- func (h *JSONWriter) WriteCreated(w http.ResponseWriter, r *http.Request, location string, e interface{})
- func (h *JSONWriter) WriteError(w http.ResponseWriter, r *http.Request, err error)
- func (h *JSONWriter) WriteErrorCode(w http.ResponseWriter, r *http.Request, code int, err error)
- type StatusCodeCarrier
- type Writer
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ErrorContextCarrier ¶ added in v0.0.3
type ErrorContextCarrier interface { error StatusCodeCarrier // RequestID returns the ID of the request that caused the error, if applicable. RequestID() string // Reason returns the reason for the error, if applicable. Reason() string // ID returns the error id, if applicable. Status() string // Details returns details on the error, if applicable. Details() []map[string]interface{} }
ErrorContextCarrier can be implemented by an error to support error contexts.
type JSONWriter ¶
type JSONWriter struct { Reporter func(args ...interface{}) reporter // contains filtered or unexported fields }
JSONWriter outputs JSON.
func NewJSONWriter ¶
func NewJSONWriter(logger logrus.FieldLogger) *JSONWriter
NewJSONWriter returns a JSONWriter
func (*JSONWriter) Write ¶
func (h *JSONWriter) Write(w http.ResponseWriter, r *http.Request, e interface{})
Write a response object to the ResponseWriter with status code 200.
func (*JSONWriter) WriteCode ¶
func (h *JSONWriter) WriteCode(w http.ResponseWriter, r *http.Request, code int, e interface{})
WriteCode writes a response object to the ResponseWriter and sets a response code.
func (*JSONWriter) WriteCreated ¶
func (h *JSONWriter) WriteCreated(w http.ResponseWriter, r *http.Request, location string, e interface{})
WriteCreated writes a response object to the ResponseWriter with status code 201 and the Location header set to location.
func (*JSONWriter) WriteError ¶
func (h *JSONWriter) WriteError(w http.ResponseWriter, r *http.Request, err error)
WriteError writes an error to ResponseWriter and tries to extract the error's status code by asserting StatusCodeCarrier. If the error does not implement StatusCodeCarrier, the status code is set to 500.
func (*JSONWriter) WriteErrorCode ¶
func (h *JSONWriter) WriteErrorCode(w http.ResponseWriter, r *http.Request, code int, err error)
WriteErrorCode writes an error to ResponseWriter and forces an error code.
type StatusCodeCarrier ¶
type StatusCodeCarrier interface { // StatusCode returns the status code of this error. StatusCode() int }
StatusCodeCarrier can be implemented by an error to support setting status codes in the error itself.
type Writer ¶
type Writer interface { // Write a response object to the ResponseWriter with status code 200. Write(w http.ResponseWriter, r *http.Request, e interface{}) // WriteCode writes a response object to the ResponseWriter and sets a response code. WriteCode(w http.ResponseWriter, r *http.Request, code int, e interface{}) // WriteCreated writes a response object to the ResponseWriter with status code 201 and // the Location header set to location. WriteCreated(w http.ResponseWriter, r *http.Request, location string, e interface{}) // WriteError writes an error to ResponseWriter and tries to extract the error's status code by // asserting StatusCodeCarrier. If the error does not implement StatusCodeCarrier, the status code // is set to 500. WriteError(w http.ResponseWriter, r *http.Request, err error) // WriteErrorCode writes an error to ResponseWriter and forces an error code. WriteErrorCode(w http.ResponseWriter, r *http.Request, code int, err error) }
Writer is a helper to write arbitrary data to a ResponseWriter