I activate this card!
[aya.git] / serve.go
blobfc2398440f14414ea5f1ea9dd26cc6ba07ffbca1
1 // Taken from https://github.com/fogleman/serve and repurposed as a library
2 package aya
4 import (
5 "fmt"
6 "log"
7 "net/http"
10 // ResponseWriter wraps http.ResponseWriter to capture the HTTP status code
11 type ResponseWriter struct {
12 http.ResponseWriter
13 StatusCode int
16 func (w *ResponseWriter) WriteHeader(statusCode int) {
17 w.StatusCode = statusCode
18 w.ResponseWriter.WriteHeader(statusCode)
21 // Handler wraps http.Handler to log served files
22 type Handler struct {
23 http.Handler
26 func (h *Handler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
27 rw := &ResponseWriter{w, 0}
28 h.Handler.ServeHTTP(rw, r)
29 log.Println(r.RemoteAddr, r.Method, rw.StatusCode, r.URL)
32 // This function is called by the `aya serve` subcommand
33 func HttpServe(Dir string, Port int) {
34 handler := &Handler{http.FileServer(http.Dir(Dir))}
35 http.Handle("/", handler)
36 addr := fmt.Sprintf("127.0.0.1:%d", Port)
37 log.Printf("[aya.HttpServe] Listening on %s\n", addr)
38 log.Fatal(http.ListenAndServe(addr, nil))