2016-08-01 01:40:12 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2016-08-03 03:12:53 +00:00
|
|
|
"golang.org/x/net/websocket"
|
2016-08-01 01:40:12 +00:00
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"net/http/httputil"
|
|
|
|
"net/url"
|
|
|
|
"os"
|
|
|
|
)
|
|
|
|
|
|
|
|
// newHandler creates a new http.Handler with CSRF protection
|
2016-08-03 09:12:46 +00:00
|
|
|
func (a *api) newHandler(settings *Settings) http.Handler {
|
2016-08-01 01:40:12 +00:00
|
|
|
var (
|
|
|
|
mux = http.NewServeMux()
|
2016-08-03 03:12:53 +00:00
|
|
|
fileHandler = http.FileServer(http.Dir(a.assetPath))
|
2016-08-01 01:40:12 +00:00
|
|
|
)
|
|
|
|
|
2016-08-03 03:12:53 +00:00
|
|
|
handler := a.newAPIHandler()
|
2016-08-01 01:40:12 +00:00
|
|
|
|
|
|
|
mux.Handle("/", fileHandler)
|
2016-08-03 03:12:53 +00:00
|
|
|
mux.Handle("/dockerapi/", http.StripPrefix("/dockerapi", handler))
|
|
|
|
mux.Handle("/ws/exec", websocket.Handler(a.execContainer))
|
2016-08-03 09:12:46 +00:00
|
|
|
mux.HandleFunc("/settings", func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
settingsHandler(w, r, settings)
|
2016-08-01 01:40:12 +00:00
|
|
|
})
|
2016-08-23 06:09:14 +00:00
|
|
|
mux.HandleFunc("/templates", func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
templatesHandler(w, r, a.templatesURL)
|
|
|
|
})
|
2016-11-03 02:56:10 +00:00
|
|
|
// CSRF protection is disabled for the moment
|
|
|
|
// CSRFHandler := newCSRFHandler(a.dataPath)
|
|
|
|
// return CSRFHandler(newCSRFWrapper(mux))
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
mux.ServeHTTP(w, r)
|
|
|
|
})
|
2016-08-01 01:40:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// newAPIHandler initializes a new http.Handler based on the URL scheme
|
2016-08-03 03:12:53 +00:00
|
|
|
func (a *api) newAPIHandler() http.Handler {
|
2016-08-01 01:40:12 +00:00
|
|
|
var handler http.Handler
|
2016-08-03 03:12:53 +00:00
|
|
|
var endpoint = *a.endpoint
|
|
|
|
if endpoint.Scheme == "tcp" {
|
|
|
|
if a.tlsConfig != nil {
|
|
|
|
handler = a.newTCPHandlerWithTLS(&endpoint)
|
2016-08-01 01:40:12 +00:00
|
|
|
} else {
|
2016-08-03 03:12:53 +00:00
|
|
|
handler = a.newTCPHandler(&endpoint)
|
2016-08-01 01:40:12 +00:00
|
|
|
}
|
2016-08-03 03:12:53 +00:00
|
|
|
} else if endpoint.Scheme == "unix" {
|
|
|
|
socketPath := endpoint.Path
|
2016-08-01 01:40:12 +00:00
|
|
|
if _, err := os.Stat(socketPath); err != nil {
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
log.Fatalf("Unix socket %s does not exist", socketPath)
|
|
|
|
}
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
2016-08-03 03:12:53 +00:00
|
|
|
handler = a.newUnixHandler(socketPath)
|
2016-08-01 01:40:12 +00:00
|
|
|
} else {
|
2016-08-03 03:12:53 +00:00
|
|
|
log.Fatalf("Bad Docker enpoint: %v. Only unix:// and tcp:// are supported.", &endpoint)
|
2016-08-01 01:40:12 +00:00
|
|
|
}
|
|
|
|
return handler
|
|
|
|
}
|
|
|
|
|
|
|
|
// newUnixHandler initializes a new UnixHandler
|
2016-08-03 03:12:53 +00:00
|
|
|
func (a *api) newUnixHandler(e string) http.Handler {
|
2016-08-01 01:40:12 +00:00
|
|
|
return &unixHandler{e}
|
|
|
|
}
|
|
|
|
|
|
|
|
// newTCPHandler initializes a HTTP reverse proxy
|
2016-08-03 03:12:53 +00:00
|
|
|
func (a *api) newTCPHandler(u *url.URL) http.Handler {
|
2016-08-01 01:40:12 +00:00
|
|
|
u.Scheme = "http"
|
|
|
|
return httputil.NewSingleHostReverseProxy(u)
|
|
|
|
}
|
|
|
|
|
|
|
|
// newTCPHandlerWithL initializes a HTTPS reverse proxy with a TLS configuration
|
2016-08-03 03:12:53 +00:00
|
|
|
func (a *api) newTCPHandlerWithTLS(u *url.URL) http.Handler {
|
2016-08-01 01:40:12 +00:00
|
|
|
u.Scheme = "https"
|
|
|
|
proxy := httputil.NewSingleHostReverseProxy(u)
|
|
|
|
proxy.Transport = &http.Transport{
|
2016-08-03 03:12:53 +00:00
|
|
|
TLSClientConfig: a.tlsConfig,
|
2016-08-01 01:40:12 +00:00
|
|
|
}
|
|
|
|
return proxy
|
|
|
|
}
|