add some request logging
This commit is contained in:
parent
cbde81e759
commit
cecb29f382
@ -35,13 +35,19 @@ var responseCodes = map[string]int{
|
|||||||
"CERTIFICATENOTVALID": 62,
|
"CERTIFICATENOTVALID": 62,
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewResponse(conn net.Conn) *Response {
|
type log interface {
|
||||||
|
Info(...interface{})
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewResponse(conn net.Conn, logger log) *Response {
|
||||||
return &Response{
|
return &Response{
|
||||||
conn: conn,
|
logger: logger,
|
||||||
|
conn: conn,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
type Response struct {
|
type Response struct {
|
||||||
|
logger log
|
||||||
statusSent bool
|
statusSent bool
|
||||||
status int
|
status int
|
||||||
meta string
|
meta string
|
||||||
@ -50,7 +56,7 @@ type Response struct {
|
|||||||
|
|
||||||
func (w *Response) WriteStatus(code int, meta string) (int, error) {
|
func (w *Response) WriteStatus(code int, meta string) (int, error) {
|
||||||
if w.statusSent {
|
if w.statusSent {
|
||||||
return 0, fmt.Errorf("Cannot set status after start of response")
|
return 0, fmt.Errorf("cannot set status after start of response")
|
||||||
}
|
}
|
||||||
w.status = code
|
w.status = code
|
||||||
w.meta = meta
|
w.meta = meta
|
||||||
@ -83,6 +89,7 @@ type StaticHandler struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (h StaticHandler) Handle(w *Response, r *Request) {
|
func (h StaticHandler) Handle(w *Response, r *Request) {
|
||||||
|
w.logger.Info(fmt.Sprintf("static response: %v", r.url))
|
||||||
w.WriteStatus(responseCodes["SUCCESS"], "text/gemini")
|
w.WriteStatus(responseCodes["SUCCESS"], "text/gemini")
|
||||||
w.Write([]byte(h.Response))
|
w.Write([]byte(h.Response))
|
||||||
}
|
}
|
||||||
@ -133,9 +140,11 @@ func (h FileHandler) Handle(w *Response, r *Request) {
|
|||||||
} else if h.DirectoryListing {
|
} else if h.DirectoryListing {
|
||||||
b, err := genIndex(req, filepath.Clean(r.GetURL().Path))
|
b, err := genIndex(req, filepath.Clean(r.GetURL().Path))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
w.logger.Info(fmt.Sprintf("request: %v; result: %d", r.url, responseCodes["NOTFOUND"]))
|
||||||
w.WriteStatus(responseCodes["NOTFOUND"], "File not found")
|
w.WriteStatus(responseCodes["NOTFOUND"], "File not found")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
w.logger.Info(fmt.Sprintf("request: %v; result: %d", r.url, responseCodes["SUCCESS"]))
|
||||||
w.WriteStatus(responseCodes["SUCCESS"], "text/gemini")
|
w.WriteStatus(responseCodes["SUCCESS"], "text/gemini")
|
||||||
w.Write(b)
|
w.Write(b)
|
||||||
return
|
return
|
||||||
@ -143,18 +152,21 @@ func (h FileHandler) Handle(w *Response, r *Request) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if !sourceFileStat.Mode().IsRegular() {
|
if !sourceFileStat.Mode().IsRegular() {
|
||||||
|
w.logger.Info(fmt.Sprintf("request: %v; result: %d", r.url, responseCodes["NOTFOUND"]))
|
||||||
w.WriteStatus(responseCodes["NOTFOUND"], "File not found")
|
w.WriteStatus(responseCodes["NOTFOUND"], "File not found")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
source, err := os.Open(req)
|
source, err := os.Open(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
w.logger.Info(fmt.Sprintf("request: %v; result: %d", r.url, responseCodes["TEMPORARYFAILURE"]))
|
||||||
w.WriteStatus(responseCodes["TEMPORARYFAILURE"], "Internal Error")
|
w.WriteStatus(responseCodes["TEMPORARYFAILURE"], "Internal Error")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer source.Close()
|
defer source.Close()
|
||||||
|
|
||||||
mime := mime.TypeByExtension(filepath.Ext(req))
|
mime := mime.TypeByExtension(filepath.Ext(req))
|
||||||
|
w.logger.Info(fmt.Sprintf("request: %v; result: %d", r.url, responseCodes["SUCCESS"]))
|
||||||
w.WriteStatus(responseCodes["SUCCESS"], mime)
|
w.WriteStatus(responseCodes["SUCCESS"], mime)
|
||||||
io.Copy(w, source)
|
io.Copy(w, source)
|
||||||
}
|
}
|
||||||
|
2
main.go
2
main.go
@ -23,7 +23,7 @@ func handleConnection(log logger.Logger, conn net.Conn, h handlers.Handler) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
log.Debug(err)
|
log.Debug(err)
|
||||||
}
|
}
|
||||||
w := handlers.NewResponse(conn)
|
w := handlers.NewResponse(conn, log)
|
||||||
r := handlers.NewRequest(u)
|
r := handlers.NewRequest(u)
|
||||||
handlers.RecoveryHandler(log, h).Handle(w, r)
|
handlers.RecoveryHandler(log, h).Handle(w, r)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user