Moved logging middleware into its own package

This commit is contained in:
Matthew Holt 2015-01-29 22:05:21 -07:00
parent 1e4baa53f0
commit e6063fb26b

View file

@ -1,20 +1,23 @@
package middleware package log
import ( import (
"log" "log"
"net/http" "net/http"
"os" "os"
"github.com/mholt/caddy/middleware"
) )
func RequestLog(p parser) Middleware { // New instantiates a new instance of logging middleware.
func New(c middleware.Controller) (middleware.Middleware, error) {
var logWhat, outputFile, format string var logWhat, outputFile, format string
var logger *log.Logger var logger *log.Logger
for p.Next() { for c.Next() {
p.Args(&logWhat, &outputFile, &format) c.Args(&logWhat, &outputFile, &format)
if logWhat == "" { if logWhat == "" {
return p.ArgErr() return nil, c.ArgErr()
} }
if outputFile == "" { if outputFile == "" {
outputFile = defaultLogFilename outputFile = defaultLogFilename
@ -30,7 +33,7 @@ func RequestLog(p parser) Middleware {
} }
// Open the log file for writing when the server starts // Open the log file for writing when the server starts
p.Startup(func() error { c.Startup(func() error {
var err error var err error
var file *os.File var file *os.File
@ -51,17 +54,17 @@ func RequestLog(p parser) Middleware {
return func(next http.HandlerFunc) http.HandlerFunc { return func(next http.HandlerFunc) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) { return func(w http.ResponseWriter, r *http.Request) {
sw := newResponseRecorder(w) sw := middleware.NewResponseRecorder(w)
next(sw, r) next(sw, r)
rep := newReplacer(r, sw) rep := middleware.NewReplacer(r, sw)
logger.Println(rep.replace(format)) logger.Println(rep.Replace(format))
} }
} }, nil
} }
const ( const (
defaultLogFilename = "access.log" defaultLogFilename = "access.log"
commonLogFormat = `{remote} ` + emptyStringReplacer + ` [{when}] "{method} {uri} {proto}" {status} {size}` commonLogFormat = `{remote} ` + middleware.EmptyStringReplacer + ` [{when}] "{method} {uri} {proto}" {status} {size}`
combinedLogFormat = commonLogFormat + ` "{>Referer}" "{>User-Agent}"` combinedLogFormat = commonLogFormat + ` "{>Referer}" "{>User-Agent}"`
defaultReqLogFormat = commonLogFormat defaultReqLogFormat = commonLogFormat
) )