This commit is contained in:
parent
0a1b9c1305
commit
5dd38b7f18
3 changed files with 42 additions and 1 deletions
2
.vscode/launch.json
vendored
2
.vscode/launch.json
vendored
|
@ -29,7 +29,7 @@
|
|||
"env": {
|
||||
"DUMP_PATH": "../tmp/nodes.json",
|
||||
"CONFIG_PATH": "../tmp/config.json",
|
||||
"NODE_DIR_PATH": "../tmp/node"
|
||||
"NODE_PATH": "../tmp/node"
|
||||
},
|
||||
"args": [
|
||||
"node"
|
||||
|
|
36
api/main.go
36
api/main.go
|
@ -3,6 +3,7 @@ package api
|
|||
import (
|
||||
"log"
|
||||
"net/http"
|
||||
"strings"
|
||||
|
||||
_ "gitea.ceperka.net/rosti/lobby2/docs" // This line is necessary for swag to find your docs!
|
||||
"gitea.ceperka.net/rosti/lobby2/nodes"
|
||||
|
@ -53,6 +54,7 @@ func (a *API) Run() error {
|
|||
a.e.GET("/nodes", a.listHandler)
|
||||
a.e.GET("/nodes/:hostname", a.getHandler)
|
||||
a.e.POST("/nodes/:hostname", a.refreshHandler)
|
||||
a.e.GET("/prometheus/:service", a.prometheusHandler)
|
||||
|
||||
// Start the server in a goroutine so that it doesn't block the signal listening
|
||||
return a.e.Start(a.listen)
|
||||
|
@ -111,3 +113,37 @@ func (a *API) refreshHandler(c echo.Context) error {
|
|||
|
||||
return c.NoContent(http.StatusNoContent)
|
||||
}
|
||||
|
||||
// @Summary Prometheus service discovery
|
||||
// @Description Return one nodes based on given hostname
|
||||
// @Produce application/json
|
||||
// @Success 200 {array} []prometheusDiscovery "Node details"
|
||||
// @Failure 401 {object} Message "Forbidden access"
|
||||
// @Security Bearer
|
||||
// @Router /nodes/{hostname} [get]
|
||||
func (a *API) prometheusHandler(c echo.Context) error {
|
||||
ss := c.QueryParam("service")
|
||||
|
||||
ns := a.np.List()
|
||||
|
||||
pds := []prometheusDiscovery{
|
||||
{
|
||||
Labels: nodes.Labels{},
|
||||
Targets: []string{},
|
||||
},
|
||||
}
|
||||
|
||||
for _, node := range ns {
|
||||
v, ok := node.KV["prometheus_exporters"]
|
||||
if ok {
|
||||
services := strings.Split(v, ",")
|
||||
for _, service := range services {
|
||||
if ss == service {
|
||||
pds[0].Targets = append(pds[0].Targets, node.HostName)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return c.JSONPretty(http.StatusOK, pds, " ")
|
||||
}
|
||||
|
|
|
@ -10,3 +10,8 @@ type params struct {
|
|||
Labels nodes.Labels `json:"labels"`
|
||||
KV nodes.KV `json:"kv"`
|
||||
}
|
||||
|
||||
type prometheusDiscovery struct {
|
||||
Labels nodes.Labels `json:"labels"`
|
||||
Targets []string `json:"targets"`
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue