2017-06-21 15:23:33 -06:00
|
|
|
package restserver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
goji "goji.io"
|
|
|
|
|
|
|
|
"github.com/gorilla/handlers"
|
Add Prometheus metrics
Exposes a few metrics for Prometheus under /metrics if started with --prometheus.
Example:
# HELP rest_server_blob_read_bytes_total Total number of bytes read from blobs
# TYPE rest_server_blob_read_bytes_total counter
rest_server_blob_read_bytes_total{repo="test",type="data"} 2.13557024e+09
rest_server_blob_read_bytes_total{repo="test",type="index"} 1.198653e+06
rest_server_blob_read_bytes_total{repo="test",type="keys"} 5388
rest_server_blob_read_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_read_bytes_total{repo="test",type="snapshots"} 10018
# HELP rest_server_blob_read_total Total number of blobs read
# TYPE rest_server_blob_read_total counter
rest_server_blob_read_total{repo="test",type="data"} 3985
rest_server_blob_read_total{repo="test",type="index"} 21
rest_server_blob_read_total{repo="test",type="keys"} 12
rest_server_blob_read_total{repo="test",type="locks"} 12
rest_server_blob_read_total{repo="test",type="snapshots"} 32
# HELP rest_server_blob_write_bytes_total Total number of bytes written to blobs
# TYPE rest_server_blob_write_bytes_total counter
rest_server_blob_write_bytes_total{repo="test",type="data"} 1.063726179e+09
rest_server_blob_write_bytes_total{repo="test",type="index"} 395586
rest_server_blob_write_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_write_bytes_total{repo="test",type="snapshots"} 1933
# HELP rest_server_blob_write_total Total number of blobs written
# TYPE rest_server_blob_write_total counter
rest_server_blob_write_total{repo="test",type="data"} 226
rest_server_blob_write_total{repo="test",type="index"} 6
rest_server_blob_write_total{repo="test",type="locks"} 12
rest_server_blob_write_total{repo="test",type="snapshots"} 6
2017-10-24 23:03:50 +08:00
|
|
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
2017-06-21 15:23:33 -06:00
|
|
|
"goji.io/pat"
|
|
|
|
)
|
|
|
|
|
2017-10-25 18:14:07 +02:00
|
|
|
// Config struct holds program configuration.
|
2017-06-21 15:23:33 -06:00
|
|
|
var Config = struct {
|
|
|
|
Path string
|
|
|
|
Listen string
|
|
|
|
Log string
|
|
|
|
CPUProfile string
|
2017-10-25 18:16:14 +02:00
|
|
|
TLS bool
|
2017-09-02 20:16:21 -05:00
|
|
|
AppendOnly bool
|
Add Prometheus metrics
Exposes a few metrics for Prometheus under /metrics if started with --prometheus.
Example:
# HELP rest_server_blob_read_bytes_total Total number of bytes read from blobs
# TYPE rest_server_blob_read_bytes_total counter
rest_server_blob_read_bytes_total{repo="test",type="data"} 2.13557024e+09
rest_server_blob_read_bytes_total{repo="test",type="index"} 1.198653e+06
rest_server_blob_read_bytes_total{repo="test",type="keys"} 5388
rest_server_blob_read_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_read_bytes_total{repo="test",type="snapshots"} 10018
# HELP rest_server_blob_read_total Total number of blobs read
# TYPE rest_server_blob_read_total counter
rest_server_blob_read_total{repo="test",type="data"} 3985
rest_server_blob_read_total{repo="test",type="index"} 21
rest_server_blob_read_total{repo="test",type="keys"} 12
rest_server_blob_read_total{repo="test",type="locks"} 12
rest_server_blob_read_total{repo="test",type="snapshots"} 32
# HELP rest_server_blob_write_bytes_total Total number of bytes written to blobs
# TYPE rest_server_blob_write_bytes_total counter
rest_server_blob_write_bytes_total{repo="test",type="data"} 1.063726179e+09
rest_server_blob_write_bytes_total{repo="test",type="index"} 395586
rest_server_blob_write_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_write_bytes_total{repo="test",type="snapshots"} 1933
# HELP rest_server_blob_write_total Total number of blobs written
# TYPE rest_server_blob_write_total counter
rest_server_blob_write_total{repo="test",type="data"} 226
rest_server_blob_write_total{repo="test",type="index"} 6
rest_server_blob_write_total{repo="test",type="locks"} 12
rest_server_blob_write_total{repo="test",type="snapshots"} 6
2017-10-24 23:03:50 +08:00
|
|
|
Prometheus bool
|
2017-10-25 18:16:14 +02:00
|
|
|
Debug bool
|
2017-06-21 15:23:33 -06:00
|
|
|
}{
|
2017-09-03 07:51:46 -05:00
|
|
|
Path: "/tmp/restic",
|
|
|
|
Listen: ":8000",
|
2017-09-02 20:16:21 -05:00
|
|
|
AppendOnly: false,
|
2017-06-21 15:23:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func debugHandler(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(
|
|
|
|
func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
log.Printf("%s %s", r.Method, r.URL)
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func logHandler(next http.Handler) http.Handler {
|
|
|
|
accessLog, err := os.OpenFile(Config.Log, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644)
|
|
|
|
if err != nil {
|
2017-07-30 17:45:23 +02:00
|
|
|
log.Fatalf("error: %v", err)
|
2017-06-21 15:23:33 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return handlers.CombinedLoggingHandler(accessLog, next)
|
|
|
|
}
|
|
|
|
|
2017-10-25 18:14:07 +02:00
|
|
|
// NewMux is master HTTP multiplexer/router.
|
2017-06-21 15:23:33 -06:00
|
|
|
func NewMux() *goji.Mux {
|
|
|
|
mux := goji.NewMux()
|
|
|
|
|
|
|
|
if Config.Debug {
|
|
|
|
mux.Use(debugHandler)
|
|
|
|
}
|
|
|
|
|
|
|
|
if Config.Log != "" {
|
|
|
|
mux.Use(logHandler)
|
|
|
|
}
|
|
|
|
|
Add Prometheus metrics
Exposes a few metrics for Prometheus under /metrics if started with --prometheus.
Example:
# HELP rest_server_blob_read_bytes_total Total number of bytes read from blobs
# TYPE rest_server_blob_read_bytes_total counter
rest_server_blob_read_bytes_total{repo="test",type="data"} 2.13557024e+09
rest_server_blob_read_bytes_total{repo="test",type="index"} 1.198653e+06
rest_server_blob_read_bytes_total{repo="test",type="keys"} 5388
rest_server_blob_read_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_read_bytes_total{repo="test",type="snapshots"} 10018
# HELP rest_server_blob_read_total Total number of blobs read
# TYPE rest_server_blob_read_total counter
rest_server_blob_read_total{repo="test",type="data"} 3985
rest_server_blob_read_total{repo="test",type="index"} 21
rest_server_blob_read_total{repo="test",type="keys"} 12
rest_server_blob_read_total{repo="test",type="locks"} 12
rest_server_blob_read_total{repo="test",type="snapshots"} 32
# HELP rest_server_blob_write_bytes_total Total number of bytes written to blobs
# TYPE rest_server_blob_write_bytes_total counter
rest_server_blob_write_bytes_total{repo="test",type="data"} 1.063726179e+09
rest_server_blob_write_bytes_total{repo="test",type="index"} 395586
rest_server_blob_write_bytes_total{repo="test",type="locks"} 1975
rest_server_blob_write_bytes_total{repo="test",type="snapshots"} 1933
# HELP rest_server_blob_write_total Total number of blobs written
# TYPE rest_server_blob_write_total counter
rest_server_blob_write_total{repo="test",type="data"} 226
rest_server_blob_write_total{repo="test",type="index"} 6
rest_server_blob_write_total{repo="test",type="locks"} 12
rest_server_blob_write_total{repo="test",type="snapshots"} 6
2017-10-24 23:03:50 +08:00
|
|
|
if Config.Prometheus {
|
|
|
|
mux.Handle(pat.Get("/metrics"), promhttp.Handler())
|
|
|
|
}
|
|
|
|
|
2017-06-21 15:23:33 -06:00
|
|
|
mux.HandleFunc(pat.Head("/config"), CheckConfig)
|
|
|
|
mux.HandleFunc(pat.Head("/:repo/config"), CheckConfig)
|
|
|
|
mux.HandleFunc(pat.Get("/config"), GetConfig)
|
|
|
|
mux.HandleFunc(pat.Get("/:repo/config"), GetConfig)
|
|
|
|
mux.HandleFunc(pat.Post("/config"), SaveConfig)
|
|
|
|
mux.HandleFunc(pat.Post("/:repo/config"), SaveConfig)
|
|
|
|
mux.HandleFunc(pat.Delete("/config"), DeleteConfig)
|
|
|
|
mux.HandleFunc(pat.Delete("/:repo/config"), DeleteConfig)
|
|
|
|
mux.HandleFunc(pat.Get("/:type/"), ListBlobs)
|
|
|
|
mux.HandleFunc(pat.Get("/:repo/:type/"), ListBlobs)
|
|
|
|
mux.HandleFunc(pat.Head("/:type/:name"), CheckBlob)
|
|
|
|
mux.HandleFunc(pat.Head("/:repo/:type/:name"), CheckBlob)
|
|
|
|
mux.HandleFunc(pat.Get("/:type/:name"), GetBlob)
|
|
|
|
mux.HandleFunc(pat.Get("/:repo/:type/:name"), GetBlob)
|
|
|
|
mux.HandleFunc(pat.Post("/:type/:name"), SaveBlob)
|
|
|
|
mux.HandleFunc(pat.Post("/:repo/:type/:name"), SaveBlob)
|
|
|
|
mux.HandleFunc(pat.Delete("/:type/:name"), DeleteBlob)
|
|
|
|
mux.HandleFunc(pat.Delete("/:repo/:type/:name"), DeleteBlob)
|
|
|
|
mux.HandleFunc(pat.Post("/"), CreateRepo)
|
|
|
|
mux.HandleFunc(pat.Post("/:repo"), CreateRepo)
|
|
|
|
mux.HandleFunc(pat.Post("/:repo/"), CreateRepo)
|
|
|
|
|
|
|
|
return mux
|
|
|
|
}
|