happyDomain/main.go

94 lines
2.3 KiB
Go
Raw Normal View History

2019-07-16 09:07:03 +00:00
package main
import (
"flag"
"log"
"net/http"
"net/url"
"path"
"strings"
"git.happydns.org/happydns/api"
"git.happydns.org/happydns/storage"
"git.happydns.org/happydns/storage/mysql"
2019-07-16 09:07:03 +00:00
)
type ResponseWriterPrefix struct {
real http.ResponseWriter
prefix string
}
func (r ResponseWriterPrefix) Header() http.Header {
return r.real.Header()
}
func (r ResponseWriterPrefix) WriteHeader(s int) {
if v, exists := r.real.Header()["Location"]; exists {
r.real.Header().Set("Location", r.prefix+v[0])
}
r.real.WriteHeader(s)
}
func (r ResponseWriterPrefix) Write(z []byte) (int, error) {
return r.real.Write(z)
}
func StripPrefix(prefix string, h http.Handler) http.Handler {
if prefix == "" {
return h
}
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
if prefix != "/" && r.URL.Path == "/" {
http.Redirect(w, r, prefix+"/", http.StatusFound)
} else if p := strings.TrimPrefix(r.URL.Path, prefix); len(p) < len(r.URL.Path) {
r2 := new(http.Request)
*r2 = *r
r2.URL = new(url.URL)
*r2.URL = *r.URL
r2.URL.Path = p
h.ServeHTTP(ResponseWriterPrefix{w, prefix}, r2)
} else {
h.ServeHTTP(w, r)
}
})
}
func main() {
// Read parameters from command line
flag.StringVar(&DevProxy, "dev", DevProxy, "Proxify traffic to this host for static assets")
2019-07-16 09:07:03 +00:00
var bind = flag.String("bind", ":8081", "Bind port/socket")
var dsn = flag.String("dsn", database.DSNGenerator(), "DSN to connect to the MySQL server")
2019-07-16 09:07:03 +00:00
var baseURL = flag.String("baseurl", "/", "URL prepended to each URL")
flag.StringVar(&api.DefaultNameServer, "defaultns", api.DefaultNameServer, "Adress to the default name server")
2019-07-16 09:07:03 +00:00
flag.Parse()
// Sanitize options
if *baseURL != "/" {
tmp := path.Clean(*baseURL)
baseURL = &tmp
} else {
tmp := ""
baseURL = &tmp
}
// Initialize contents
log.Println("Opening database...")
if store, err := database.NewMySQLStorage(*dsn); err != nil {
2019-07-16 09:07:03 +00:00
log.Fatal("Cannot open the database: ", err)
} else {
storage.MainStore = store
2019-07-16 09:07:03 +00:00
}
defer storage.MainStore.Close()
2019-07-16 09:07:03 +00:00
log.Println("Do database migrations...")
if err := storage.MainStore.DoMigration(); err != nil {
log.Fatal("Cannot migrate database: ", err)
2019-07-16 09:07:03 +00:00
}
// Serve content
log.Println("Ready, listening on", *bind)
if err := http.ListenAndServe(*bind, StripPrefix(*baseURL, api.Router())); err != nil {
log.Fatal("Unable to listen and serve: ", err)
}
}