Skip to content

Latest commit

 

History

History
59 lines (50 loc) · 2.14 KB

README.md

File metadata and controls

59 lines (50 loc) · 2.14 KB

go-httphandler Actions Status Coverage Status PkgGoDev GoDoc go-report

go-httphandler is an http middleware that can be used to simplify the error response. In case of error go-httphandler renders the error based on its Content-Type, or (if its not set) based on the clients Accept header.

go get -u github.com/talon-one/go-httphandler

Example

package main

import (
	"errors"
	"io"
	"io/ioutil"
	"net/http"

	"github.com/talon-one/go-httphandler"
)

func main() {
	http.HandleFunc("/", httphandler.HandleFunc(func(w http.ResponseWriter, r *http.Request) *httphandler.HandlerError {
		if r.Method != http.MethodPost {
			// return with bad request if the method is not POST
			// respond with the clients Accept header content type
			return &httphandler.HandlerError{
				StatusCode:    http.StatusBadRequest,
				PublicError:   errors.New("only POST method is allowed"),
				InternalError: nil,
				ContentType:   "",
			}
		}

		if r.Body == nil {
			// return with internal server error if body is not available
			// respond with the clients Accept header content type
			return &httphandler.HandlerError{
				InternalError: errors.New("body was nil"),
			}
		}
		if _, err := ioutil.ReadAll(r.Body); err != nil {
			return &httphandler.HandlerError{
				InternalError: err,
			}
		}

		w.WriteHeader(http.StatusOK)
		if _, err := io.WriteString(w, "ok"); err != nil {
			return &httphandler.HandlerError{
				InternalError: err,
			}
		}
		return nil
	}))
	http.ListenAndServe(":8000", nil)
}