73 lines
1.3 KiB
Go
73 lines
1.3 KiB
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"archive/tar"
|
||
|
"compress/gzip"
|
||
|
"io"
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"os"
|
||
|
)
|
||
|
|
||
|
func LogMiddleware(next http.Handler) http.Handler {
|
||
|
return http.HandlerFunc(
|
||
|
func(w http.ResponseWriter, r *http.Request) {
|
||
|
next.ServeHTTP(w, r)
|
||
|
log.Printf("%s %s %s %s\n", r.RemoteAddr, r.Method, r.URL, r.Header.Get("User-Agent"))
|
||
|
},
|
||
|
)
|
||
|
}
|
||
|
|
||
|
func bundle(buf io.Writer, paths []string, flat bool) error {
|
||
|
gw := gzip.NewWriter(buf)
|
||
|
defer gw.Close()
|
||
|
tw := tar.NewWriter(gw)
|
||
|
defer tw.Close()
|
||
|
|
||
|
for _, file := range paths {
|
||
|
if err := func(file string) error {
|
||
|
f, err := os.Open(file)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
defer f.Close()
|
||
|
|
||
|
info, err := f.Stat()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
header, err := tar.FileInfoHeader(info, info.Name())
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// Use full path as name (FileInfoHeader only takes the basename)
|
||
|
// If we don't do this the directory strucuture would
|
||
|
// not be preserved
|
||
|
// https://golang.org/src/archive/tar/common.go?#L626
|
||
|
if !flat {
|
||
|
header.Name = file
|
||
|
}
|
||
|
|
||
|
// Write file header to the tar archive
|
||
|
err = tw.WriteHeader(header)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// Copy file content to tar archive
|
||
|
_, err = io.Copy(tw, f)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return nil
|
||
|
|
||
|
}(file); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return nil
|
||
|
}
|