add basic authorization
This commit is contained in:
parent
5705db4d60
commit
6f2a73f46e
3 changed files with 34 additions and 2 deletions
|
@ -1,3 +1,5 @@
|
||||||
USERNAME=*****
|
USERNAME=*****
|
||||||
HUE_URL=192.168.178.34
|
HUE_URL=192.168.178.34
|
||||||
LISTEN_ADDRESS=127.0.0.1:9773
|
LISTEN_ADDRESS=127.0.0.1:9773
|
||||||
|
AUTH_USER=user
|
||||||
|
AUTH_PASS=password
|
||||||
|
|
|
@ -12,4 +12,4 @@ COPY --from=build /hue_exporter /hue_exporter
|
||||||
COPY hue_metrics.json ./
|
COPY hue_metrics.json ./
|
||||||
EXPOSE 9773
|
EXPOSE 9773
|
||||||
|
|
||||||
ENTRYPOINT [ "sh", "-c", "/hue_exporter -username ${USERNAME} -hue-url ${HUE_URL} -metrics-file hue_metrics.json -listen-address ${LISTEN_ADDRESS}" ]
|
ENTRYPOINT [ "sh", "-c", "/hue_exporter -username ${USERNAME} -hue-url ${HUE_URL} -metrics-file hue_metrics.json -listen-address ${LISTEN_ADDRESS} -auth.user ${AUTH_USER} -auth.pass ${AUTH_PASS}" ]
|
||||||
|
|
32
main.go
32
main.go
|
@ -21,12 +21,31 @@ var (
|
||||||
flagUsername = flag.String("username", "", "The username token having bridge access")
|
flagUsername = flag.String("username", "", "The username token having bridge access")
|
||||||
flagAddress = flag.String("listen-address", "127.0.0.1:9773", "The address to listen on for HTTP requests.")
|
flagAddress = flag.String("listen-address", "127.0.0.1:9773", "The address to listen on for HTTP requests.")
|
||||||
flagMetricsFile = flag.String("metrics-file", "hue_metrics.json", "The JSON file with the metric definitions.")
|
flagMetricsFile = flag.String("metrics-file", "hue_metrics.json", "The JSON file with the metric definitions.")
|
||||||
|
authUser = flag.String("auth.user", "", "Username for basic auth.")
|
||||||
|
authPass = flag.String("auth.pass", "", "Password for basic auth. Enables basic auth if set.")
|
||||||
|
|
||||||
flagTest = flag.Bool("test", false, "Test configured metrics")
|
flagTest = flag.Bool("test", false, "Test configured metrics")
|
||||||
flagCollect = flag.Bool("collect", false, "Collect all available metrics")
|
flagCollect = flag.Bool("collect", false, "Collect all available metrics")
|
||||||
flagCollectFile = flag.String("collect-file", "", "The JSON file where to store collect results")
|
flagCollectFile = flag.String("collect-file", "", "The JSON file where to store collect results")
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type basicAuthHandler struct {
|
||||||
|
handler http.HandlerFunc
|
||||||
|
user string
|
||||||
|
password string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *basicAuthHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
user, password, ok := r.BasicAuth()
|
||||||
|
if !ok || password != h.password || user != h.user {
|
||||||
|
w.Header().Set("WWW-Authenticate", "Basic realm=\"metrics\"")
|
||||||
|
http.Error(w, "Invalid username or password", http.StatusUnauthorized)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
h.handler(w, r)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
@ -55,7 +74,18 @@ func main() {
|
||||||
hueCollector.Test()
|
hueCollector.Test()
|
||||||
} else {
|
} else {
|
||||||
prometheus.MustRegister(hueCollector)
|
prometheus.MustRegister(hueCollector)
|
||||||
http.Handle("/metrics", promhttp.Handler())
|
handler := promhttp.Handler()
|
||||||
|
if *authUser != "" || *authPass != "" {
|
||||||
|
if *authUser == "" || *authPass == "" {
|
||||||
|
log.Fatal("You need to specify -auth.user and -auth.pass to enable basic auth")
|
||||||
|
}
|
||||||
|
handler = &basicAuthHandler{
|
||||||
|
handler: promhttp.Handler().ServeHTTP,
|
||||||
|
user: *authUser,
|
||||||
|
password: *authPass,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
http.Handle("/metrics", handler)
|
||||||
fmt.Printf("metrics available at http://%s/metrics\n", *flagAddress)
|
fmt.Printf("metrics available at http://%s/metrics\n", *flagAddress)
|
||||||
log.Fatal(http.ListenAndServe(*flagAddress, nil))
|
log.Fatal(http.ListenAndServe(*flagAddress, nil))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue