A Go package for handling common HTTP JSON responses.
go get github.com/nicklaw5/go-respond
The goal of go-respond
is to take most of the grunt work out preparing your JSON response. Here's a simple example:
package main
import (
"net/http"
resp "github.com/nicklaw5/go-respond"
)
type User struct {
ID int `json:"id"`
Name string `json:"name"`
Email string `json:"email"`
}
func main() {
http.HandleFunc("/api/users", func(w http.ResponseWriter, r *http.Request) {
users := []User{
{1, "Billy", "[email protected]"},
{2, "Joan", "[email protected]"},
}
resp.NewResponse(w).
Ok(users)
})
http.ListenAndServe(":8080", nil)
}
Response Code | Method Name |
---|---|
200 | Ok() |
201 | Created() |
202 | Accepted() |
204 | NoContent() |
400 | BadRequest() |
401 | Unauthorized() |
403 | Forbidden() |
404 | NotFound() |
405 | MethodNotAllowed() |
409 | Conflict() |
411 | LengthRequired() |
412 | PreconditionFailed() |
422 | UnprocessableEntity() |
500 | InternalServerError() |
501 | NotImplemented() |
See here for a complete list of HTTP responses, along with an explanation of each.
Please submit a PR if you want to add to this list. Only the most common response types have been included.
The best option for handling errors that may occur while marshalling the JSON response, is to use Negroni's Recovery middleware. Here's an example:
package main
import (
"net/http"
"github.com/urfave/negroni"
resp "github.com/nicklaw5/go-respond"
)
type Response struct {
Success bool `json:"success"`
}
func main() {
mux := http.NewServeMux()
mux.HandleFunc("/", func(w http.ResponseWriter, req *http.Request) {
resp.NewResponse(w).
Ok(&Response{true})
})
n := negroni.New()
recovery := negroni.NewRecovery()
recovery.ErrorHandlerFunc = func(error interface{}) {
// do something with the unexpected error
}
n.Use(recovery)
n.UseHandler(mux)
http.ListenAndServe(":8080", n)
}
This package is distributed under the terms of the MIT License.