2013-02-08 05:49:55 -08:00
|
|
|
// Copyright 2013 Prometheus Team
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package web
|
|
|
|
|
|
|
|
import (
|
|
|
|
"code.google.com/p/gorest"
|
2013-02-08 06:38:50 -08:00
|
|
|
"flag"
|
2013-02-08 05:49:55 -08:00
|
|
|
"github.com/prometheus/client_golang"
|
2013-04-05 04:24:50 -07:00
|
|
|
"github.com/prometheus/client_golang/exp"
|
2013-02-12 04:15:40 -08:00
|
|
|
"github.com/prometheus/prometheus/appstate"
|
2013-02-08 05:49:55 -08:00
|
|
|
"github.com/prometheus/prometheus/web/api"
|
2013-03-18 09:48:50 -07:00
|
|
|
"github.com/prometheus/prometheus/web/blob"
|
2013-03-27 09:40:01 -07:00
|
|
|
"html/template"
|
|
|
|
"log"
|
2013-02-08 05:49:55 -08:00
|
|
|
"net/http"
|
|
|
|
_ "net/http/pprof"
|
|
|
|
)
|
|
|
|
|
2013-02-08 06:38:50 -08:00
|
|
|
// Commandline flags.
|
|
|
|
var (
|
2013-03-21 10:11:34 -07:00
|
|
|
listenAddress = flag.String("listenAddress", ":9090", "Address to listen on for web interface.")
|
2013-03-25 04:09:39 -07:00
|
|
|
useLocalAssets = flag.Bool("useLocalAssets", false, "Read assets/templates from file instead of binary.")
|
2013-02-08 06:38:50 -08:00
|
|
|
)
|
|
|
|
|
2013-02-12 04:15:40 -08:00
|
|
|
func StartServing(appState *appstate.ApplicationState) {
|
2013-02-22 12:07:35 -08:00
|
|
|
gorest.RegisterService(api.NewMetricsService(appState))
|
2013-02-08 05:49:55 -08:00
|
|
|
|
2013-04-05 04:24:50 -07:00
|
|
|
exp.Handle("/", &StatusHandler{appState: appState})
|
|
|
|
exp.HandleFunc("/graph", graphHandler)
|
|
|
|
exp.HandleFunc("/console", consoleHandler)
|
2013-04-02 10:14:02 -07:00
|
|
|
|
2013-04-05 04:24:50 -07:00
|
|
|
exp.Handle("/api/", gorest.Handle())
|
|
|
|
exp.Handle("/metrics.json", registry.DefaultHandler)
|
2013-03-21 07:55:48 -07:00
|
|
|
if *useLocalAssets {
|
2013-04-05 04:24:50 -07:00
|
|
|
exp.Handle("/static/", http.StripPrefix("/static/", http.FileServer(http.Dir("web/static"))))
|
2013-03-21 05:55:59 -07:00
|
|
|
} else {
|
2013-04-05 04:24:50 -07:00
|
|
|
exp.Handle("/static/", http.StripPrefix("/static/", new(blob.Handler)))
|
2013-03-21 05:55:59 -07:00
|
|
|
}
|
2013-02-08 05:49:55 -08:00
|
|
|
|
2013-04-05 04:24:50 -07:00
|
|
|
go http.ListenAndServe(*listenAddress, exp.DefaultCoarseMux)
|
2013-02-08 05:49:55 -08:00
|
|
|
}
|
2013-03-27 09:40:01 -07:00
|
|
|
|
|
|
|
func getTemplate(name string) (t *template.Template, err error) {
|
|
|
|
if *useLocalAssets {
|
|
|
|
return template.ParseFiles("web/templates/_base.html", "web/templates/"+name+".html")
|
|
|
|
}
|
|
|
|
|
|
|
|
t = template.New("_base")
|
|
|
|
|
|
|
|
file, err := blob.GetFile(blob.TemplateFiles, "_base.html")
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Could not read base template: %s", err)
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
t.Parse(string(file))
|
|
|
|
|
|
|
|
file, err = blob.GetFile(blob.TemplateFiles, name+".html")
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("Could not read %s template: %s", name, err)
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
t.Parse(string(file))
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
func executeTemplate(w http.ResponseWriter, name string, data interface{}) {
|
|
|
|
tpl, err := getTemplate(name)
|
|
|
|
if err != nil {
|
2013-04-04 10:19:58 -07:00
|
|
|
log.Printf("Error preparing layout template: %s", err)
|
2013-03-27 09:40:01 -07:00
|
|
|
return
|
|
|
|
}
|
|
|
|
tpl.Execute(w, data)
|
|
|
|
}
|