Add logs and a verbose mode
git-svn-id: file:///srv/svn/repo/marisa/trunk@29 d6811dac-2434-b64a-9ddc-f563ab233461
This commit is contained in:
39
partage.go
39
partage.go
@@ -5,6 +5,7 @@ import (
|
|||||||
"flag"
|
"flag"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"os/user"
|
"os/user"
|
||||||
@@ -48,6 +49,8 @@ var conf struct {
|
|||||||
expiry int64
|
expiry int64
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var verbose bool
|
||||||
|
|
||||||
func writefile(f *os.File, s io.ReadCloser, contentlength int64) error {
|
func writefile(f *os.File, s io.ReadCloser, contentlength int64) error {
|
||||||
buffer := make([]byte, 4096)
|
buffer := make([]byte, 4096)
|
||||||
eof := false
|
eof := false
|
||||||
@@ -93,6 +96,10 @@ func writemeta(filename string, expiry int64) error {
|
|||||||
Expiry: time.Now().Unix() + expiry,
|
Expiry: time.Now().Unix() + expiry,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Saving metadata for %s in %s", meta.Filename, conf.metapath + "/" + meta.Filename + ".json")
|
||||||
|
}
|
||||||
|
|
||||||
f, err := os.Create(conf.metapath + "/" + meta.Filename + ".json")
|
f, err := os.Create(conf.metapath + "/" + meta.Filename + ".json")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@@ -116,6 +123,10 @@ func servetemplate(w http.ResponseWriter, f string, d templatedata) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Serving template %s", t.Name())
|
||||||
|
}
|
||||||
|
|
||||||
err = t.Execute(w, d)
|
err = t.Execute(w, d)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
@@ -136,6 +147,10 @@ func uploaderPut(w http.ResponseWriter, r *http.Request) {
|
|||||||
}
|
}
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Writing %d bytes to %s", r.ContentLength, tmp)
|
||||||
|
}
|
||||||
|
|
||||||
if err = writefile(f, r.Body, r.ContentLength); err != nil {
|
if err = writefile(f, r.Body, r.ContentLength); err != nil {
|
||||||
http.Error(w, "Internal error", http.StatusInternalServerError)
|
http.Error(w, "Internal error", http.StatusInternalServerError)
|
||||||
defer os.Remove(tmp.Name())
|
defer os.Remove(tmp.Name())
|
||||||
@@ -206,10 +221,18 @@ func uploaderGet(w http.ResponseWriter, r *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Serving file %s", conf.rootdir + filename)
|
||||||
|
}
|
||||||
|
|
||||||
http.ServeFile(w, r, conf.rootdir + filename)
|
http.ServeFile(w, r, conf.rootdir + filename)
|
||||||
}
|
}
|
||||||
|
|
||||||
func uploader(w http.ResponseWriter, r *http.Request) {
|
func uploader(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if verbose {
|
||||||
|
log.Printf("%s: <%s> %s %s %s", r.Host, r.RemoteAddr, r.Method, r.RequestURI, r.Proto)
|
||||||
|
}
|
||||||
|
|
||||||
switch r.Method {
|
switch r.Method {
|
||||||
case "POST":
|
case "POST":
|
||||||
uploaderPost(w, r)
|
uploaderPost(w, r)
|
||||||
@@ -237,7 +260,14 @@ func main() {
|
|||||||
|
|
||||||
iniflags.Parse()
|
iniflags.Parse()
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Applied configuration:\n%s", conf)
|
||||||
|
}
|
||||||
|
|
||||||
if (conf.chroot != "") {
|
if (conf.chroot != "") {
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Changing root to %s", conf.chroot)
|
||||||
|
}
|
||||||
syscall.Chroot(conf.chroot)
|
syscall.Chroot(conf.chroot)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -260,11 +290,20 @@ func main() {
|
|||||||
gid, _ = strconv.Atoi(g.Gid)
|
gid, _ = strconv.Atoi(g.Gid)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Dropping privileges to %s", conf.user)
|
||||||
|
}
|
||||||
|
|
||||||
syscall.Setuid(uid)
|
syscall.Setuid(uid)
|
||||||
syscall.Setgid(gid)
|
syscall.Setgid(gid)
|
||||||
}
|
}
|
||||||
|
|
||||||
http.HandleFunc("/", uploader)
|
http.HandleFunc("/", uploader)
|
||||||
http.Handle(conf.filectx, http.StripPrefix(conf.filectx, http.FileServer(http.Dir(conf.filepath))))
|
http.Handle(conf.filectx, http.StripPrefix(conf.filectx, http.FileServer(http.Dir(conf.filepath))))
|
||||||
|
|
||||||
|
if verbose {
|
||||||
|
log.Printf("Listening on %s", conf.bind)
|
||||||
|
}
|
||||||
|
|
||||||
http.ListenAndServe(conf.bind, nil)
|
http.ListenAndServe(conf.bind, nil)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user