forked from cadey/xesite
36 lines
848 B
Go
36 lines
848 B
Go
|
package negroni
|
||
|
|
||
|
import (
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"os"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
// ALogger interface
|
||
|
type ALogger interface {
|
||
|
Println(v ...interface{})
|
||
|
Printf(format string, v ...interface{})
|
||
|
}
|
||
|
|
||
|
// Logger is a middleware handler that logs the request as it goes in and the response as it goes out.
|
||
|
type Logger struct {
|
||
|
// ALogger implements just enough log.Logger interface to be compatible with other implementations
|
||
|
ALogger
|
||
|
}
|
||
|
|
||
|
// NewLogger returns a new Logger instance
|
||
|
func NewLogger() *Logger {
|
||
|
return &Logger{log.New(os.Stdout, "[negroni] ", 0)}
|
||
|
}
|
||
|
|
||
|
func (l *Logger) ServeHTTP(rw http.ResponseWriter, r *http.Request, next http.HandlerFunc) {
|
||
|
start := time.Now()
|
||
|
l.Printf("Started %s %s", r.Method, r.URL.Path)
|
||
|
|
||
|
next(rw, r)
|
||
|
|
||
|
res := rw.(ResponseWriter)
|
||
|
l.Printf("Completed %v %s in %v", res.Status(), http.StatusText(res.Status()), time.Since(start))
|
||
|
}
|