forked from TrueCloudLab/distribution
15b0204758
This fixes registry endpoints to return the proper `application/json` content-type for JSON content, also updating spec examples for that. As per IETF specification and IANA registry [0], the `application/json` type is a binary media, so the content-type label does not need any text-charset selector. Additionally, the media type definition explicitly states that it has no required nor optional parameters, which makes the current registry headers non-compliant. [0]: https://www.iana.org/assignments/media-types/application/json Signed-off-by: Luca Bruno <lucab@debian.org>
40 lines
935 B
Go
40 lines
935 B
Go
package errcode
|
|
|
|
import (
|
|
"encoding/json"
|
|
"net/http"
|
|
)
|
|
|
|
// ServeJSON attempts to serve the errcode in a JSON envelope. It marshals err
|
|
// and sets the content-type header to 'application/json'. It will handle
|
|
// ErrorCoder and Errors, and if necessary will create an envelope.
|
|
func ServeJSON(w http.ResponseWriter, err error) error {
|
|
w.Header().Set("Content-Type", "application/json")
|
|
var sc int
|
|
|
|
switch errs := err.(type) {
|
|
case Errors:
|
|
if len(errs) < 1 {
|
|
break
|
|
}
|
|
|
|
if err, ok := errs[0].(ErrorCoder); ok {
|
|
sc = err.ErrorCode().Descriptor().HTTPStatusCode
|
|
}
|
|
case ErrorCoder:
|
|
sc = errs.ErrorCode().Descriptor().HTTPStatusCode
|
|
err = Errors{err} // create an envelope.
|
|
default:
|
|
// We just have an unhandled error type, so just place in an envelope
|
|
// and move along.
|
|
err = Errors{err}
|
|
}
|
|
|
|
if sc == 0 {
|
|
sc = http.StatusInternalServerError
|
|
}
|
|
|
|
w.WriteHeader(sc)
|
|
|
|
return json.NewEncoder(w).Encode(err)
|
|
}
|