mirror of https://github.com/portainer/portainer
Add dockerui server files and Dockerfile
parent
38f859f52d
commit
877effc6ad
|
@ -0,0 +1 @@
|
||||||
|
dockerui
|
|
@ -0,0 +1,14 @@
|
||||||
|
# Dockerfile for DockerUI
|
||||||
|
|
||||||
|
FROM ubuntu
|
||||||
|
|
||||||
|
MAINTAINER Michael Crosby http://crosbymichael.com
|
||||||
|
|
||||||
|
RUN echo "deb http://archive.ubuntu.com/ubuntu precise main universe" > /etc/apt/sources.list
|
||||||
|
RUN apt-get update
|
||||||
|
RUN apt-get upgrade
|
||||||
|
|
||||||
|
ADD . /dockerui
|
||||||
|
|
||||||
|
EXPOSE 9000:9000
|
||||||
|
|
|
@ -0,0 +1,77 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
"fmt"
|
||||||
|
"github.com/elazarl/goproxy"
|
||||||
|
"log"
|
||||||
|
"net/http"
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
endpoint = flag.String("e", "", "Docker d endpoint.")
|
||||||
|
verbose = flag.Bool("v", false, "Verbose logging.")
|
||||||
|
port = flag.String("p", "9000", "Port to serve dockerui.")
|
||||||
|
)
|
||||||
|
|
||||||
|
type multiHandler struct {
|
||||||
|
base http.Handler
|
||||||
|
proxy *goproxy.ProxyHttpServer
|
||||||
|
verbose bool
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *multiHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if h.verbose {
|
||||||
|
log.Printf("%s: %s\n", r.Method, r.URL.String())
|
||||||
|
}
|
||||||
|
if isDockerRequest(r.URL.String()) {
|
||||||
|
h.proxy.ServeHTTP(w, r)
|
||||||
|
} else {
|
||||||
|
h.base.ServeHTTP(w, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func isDockerRequest(url string) bool {
|
||||||
|
return strings.Contains(url, "dockerapi/")
|
||||||
|
}
|
||||||
|
|
||||||
|
func createHandler(dir string) http.Handler {
|
||||||
|
fileHandler := http.FileServer(http.Dir(dir))
|
||||||
|
proxy := goproxy.NewProxyHttpServer()
|
||||||
|
proxy.Verbose = *verbose
|
||||||
|
|
||||||
|
proxy.OnRequest().DoFunc(func(r *http.Request, ctx *goproxy.ProxyCtx) (*http.Request, *http.Response) {
|
||||||
|
c := http.Client{}
|
||||||
|
path := strings.Replace(r.URL.RequestURI(), "dockerapi/", "", -1)
|
||||||
|
n, err := http.NewRequest(r.Method, *endpoint+path, r.Body)
|
||||||
|
n.Header = r.Header
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
resp, err := c.Do(n)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
return r, resp
|
||||||
|
|
||||||
|
})
|
||||||
|
return &multiHandler{base: fileHandler, proxy: proxy, verbose: *verbose}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
path := fmt.Sprintf(":%s", *port)
|
||||||
|
|
||||||
|
cwd, err := os.Getwd()
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
handler := createHandler(cwd)
|
||||||
|
|
||||||
|
log.Fatal(http.ListenAndServe(path, handler))
|
||||||
|
}
|
|
@ -11,7 +11,8 @@ angular.module('dockerui', ['dockerui.services', 'dockerui.filters'])
|
||||||
$routeProvider.otherwise({redirectTo: '/'});
|
$routeProvider.otherwise({redirectTo: '/'});
|
||||||
}])
|
}])
|
||||||
// This is your docker url that the api will use to make requests
|
// This is your docker url that the api will use to make requests
|
||||||
.constant('DOCKER_ENDPOINT', 'http://192.168.1.9')
|
// You need to set this to the api endpoint without the port i.e. http://192.168.1.9
|
||||||
.constant('DOCKER_PORT', ':4243')
|
.constant('DOCKER_ENDPOINT', '/dockerapi')
|
||||||
|
.constant('DOCKER_PORT', '') // Docker port, leave as an empty string if no port is requred. i.e. 4243
|
||||||
.constant('UI_VERSION', 'v0.2')
|
.constant('UI_VERSION', 'v0.2')
|
||||||
.constant('DOCKER_API_VERSION', 'v1.2');
|
.constant('DOCKER_API_VERSION', 'v1.2');
|
||||||
|
|
Loading…
Reference in New Issue