Go HTTP Tool Package
The HTTP tool is a simple extension of the net/http package written in Go.
It is not a Framework and offers additional. This package provides a slightly different handling of the Handler type by
exploiting the return to handle potential errors.
The ResponseWriter type has been increased to retrieve the state of the HTTP response such as
code, length and whether the header has been written.
```shell script
go get github.com/nanoninja/httptool
## Getting Started
```go
package main
import (
"log"
"net/http"
"os"
"github.com/nanoninja/httptool"
)
func logAccess(next http.Handler, logger *log.Logger) http.Handler {
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
next.ServeHTTP(w, r)
ip := httptool.ClientIP(r)
rw := w.(httptool.ResponseWriter)
logger.Printf("[nanoninja] %s %s %s %d\n", ip, r.Method, r.RequestURI, rw.Status())
})
}
func logError(next httptool.HandlerFunc, logger *log.Logger) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
if err := next.ServeHTTP(w, r); err != nil {
logger.Println(err)
}
}
}
func greeting(w http.ResponseWriter, _ *http.Request) error {
w.WriteHeader(http.StatusOK)
_, err := w.Write([]byte("Hello, Gophers"))
return err
}
func main() {
errLogger := log.New(os.Stderr, "", log.Lshortfile)
accessLogger := log.New(os.Stdout, "", log.Lshortfile)
mux := http.NewServeMux()
mux.Handle("/", logError(greeting, errLogger))
handler := logAccess(mux, accessLogger)
handler = httptool.ResponseHandler(handler)
handler = httptool.RecoveryHandler(handler, errLogger)
log.Fatalln(http.ListenAndServe(":3000", handler))
}
HTTPTool is licensed under the Creative Commons Attribution 3.0 License, and code is licensed under a BSD license.