Allow override of default options response

This commit is contained in:
Matthew Wratt 2017-04-07 16:04:37 +12:00
parent 91dea49fc7
commit 1f8bf12694
1 changed files with 12 additions and 0 deletions

View File

@ -138,6 +138,15 @@ func NewUnroutedHandler(config Config) (*UnroutedHandler, error) {
// directly you will need to wrap at least the POST and PATCH endpoints in // directly you will need to wrap at least the POST and PATCH endpoints in
// this middleware. // this middleware.
func (handler *UnroutedHandler) Middleware(h http.Handler) http.Handler { func (handler *UnroutedHandler) Middleware(h http.Handler) http.Handler {
return handler.MiddlewareWithOptionsCallback(h, func(w http.ResponseWriter, r *http.Request) {})
}
// MiddlewareWithOptionsCallback checks various aspects of the request and
// ensures that it conforms with the spec. Also handles method overriding for
// clients which cannot make PATCH AND DELETE requests. If you are using the
// tusd handlers directly you will need to wrap at least the POST and PATCH
// endpoints in this middleware.
func (handler *UnroutedHandler) MiddlewareWithOptionsCallback(h http.Handler, cb http.HandlerFunc) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
// Allow overriding the HTTP method. The reason for this is // Allow overriding the HTTP method. The reason for this is
// that some libraries/environments to not support PATCH and // that some libraries/environments to not support PATCH and
@ -183,6 +192,9 @@ func (handler *UnroutedHandler) Middleware(h http.Handler) http.Handler {
header.Set("Tus-Version", "1.0.0") header.Set("Tus-Version", "1.0.0")
header.Set("Tus-Extension", handler.extensions) header.Set("Tus-Extension", handler.extensions)
// Allow caller to override response headers etc.
cb(w, r)
// Although the 204 No Content status code is a better fit in this case, // Although the 204 No Content status code is a better fit in this case,
// since we do not have a response body included, we cannot use it here // since we do not have a response body included, we cannot use it here
// as some browsers only accept 200 OK as successful response to a // as some browsers only accept 200 OK as successful response to a