2018-04-09 13:02:14 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2018-04-09 14:12:54 +02:00
|
|
|
"fmt"
|
2018-04-09 15:27:21 +02:00
|
|
|
"github.com/micromata/swd/app"
|
|
|
|
"golang.org/x/net/webdav"
|
2018-04-09 15:24:57 +02:00
|
|
|
"log"
|
2018-04-09 15:27:21 +02:00
|
|
|
"net/http"
|
2018-04-09 13:02:14 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2018-04-09 14:12:54 +02:00
|
|
|
config := app.ParseConfig()
|
|
|
|
|
2018-04-09 13:02:14 +02:00
|
|
|
wdHandler := &webdav.Handler{
|
2018-04-10 22:02:48 +02:00
|
|
|
Prefix: config.Prefix,
|
|
|
|
FileSystem: &app.UserDir{
|
|
|
|
BaseDir: config.Dir,
|
|
|
|
},
|
2018-04-09 13:02:14 +02:00
|
|
|
LockSystem: webdav.NewMemLS(),
|
|
|
|
}
|
|
|
|
|
2018-04-11 15:22:42 +02:00
|
|
|
wdHandler.Logger = app.ModificationLogHandler
|
|
|
|
|
2018-04-10 15:20:23 +02:00
|
|
|
a := &app.App{
|
|
|
|
Config: config,
|
|
|
|
Handler: wdHandler,
|
|
|
|
}
|
|
|
|
|
2018-04-10 22:02:48 +02:00
|
|
|
http.Handle("/", app.NewBasicAuthWebdavHandler(a))
|
2018-04-10 15:20:23 +02:00
|
|
|
|
2018-04-09 14:12:54 +02:00
|
|
|
connAddr := fmt.Sprintf("%s:%s", config.Address, config.Port)
|
2018-04-09 15:24:57 +02:00
|
|
|
|
|
|
|
if config.TLS != nil {
|
|
|
|
fmt.Printf("TLS Server is starting and listening at: %s\n", connAddr)
|
2018-04-10 15:20:23 +02:00
|
|
|
log.Fatal(http.ListenAndServeTLS(connAddr, config.TLS.CertFile, config.TLS.KeyFile, nil))
|
2018-04-09 15:24:57 +02:00
|
|
|
} else {
|
|
|
|
fmt.Printf("Server is starting and listening at: %s\n", connAddr)
|
2018-04-10 15:20:23 +02:00
|
|
|
log.Fatal(http.ListenAndServe(connAddr, nil))
|
2018-04-09 15:24:57 +02:00
|
|
|
}
|
2018-04-09 13:02:14 +02:00
|
|
|
}
|