2015-02-12 22:46:14 +08:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2021-06-14 23:36:48 +08:00
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
2021-01-15 21:43:20 +08:00
|
|
|
"github.com/grafana/grafana/pkg/api/response"
|
2016-01-25 13:18:17 +08:00
|
|
|
"github.com/grafana/grafana/pkg/bus"
|
2020-03-04 19:57:20 +08:00
|
|
|
"github.com/grafana/grafana/pkg/models"
|
2021-06-14 23:36:48 +08:00
|
|
|
"github.com/grafana/grafana/pkg/services/accesscontrol"
|
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
2015-02-12 22:46:14 +08:00
|
|
|
)
|
|
|
|
|
2021-06-14 23:36:48 +08:00
|
|
|
func (hs *HTTPServer) AdminGetSettings(c *models.ReqContext) response.Response {
|
|
|
|
settings, err := hs.getAuthorizedSettings(c.Req.Context(), c.SignedInUser, hs.SettingsProvider.Current())
|
|
|
|
if err != nil {
|
|
|
|
return response.Error(http.StatusForbidden, "Failed to authorize settings", err)
|
|
|
|
}
|
|
|
|
return response.JSON(http.StatusOK, settings)
|
2015-02-12 22:46:14 +08:00
|
|
|
}
|
2016-01-25 03:01:33 +08:00
|
|
|
|
2021-01-15 21:43:20 +08:00
|
|
|
func AdminGetStats(c *models.ReqContext) response.Response {
|
2020-03-04 19:57:20 +08:00
|
|
|
statsQuery := models.GetAdminStatsQuery{}
|
2016-01-25 03:01:33 +08:00
|
|
|
|
2016-01-25 13:18:17 +08:00
|
|
|
if err := bus.Dispatch(&statsQuery); err != nil {
|
2021-01-15 21:43:20 +08:00
|
|
|
return response.Error(500, "Failed to get admin stats from database", err)
|
2016-01-25 13:18:17 +08:00
|
|
|
}
|
|
|
|
|
2021-01-15 21:43:20 +08:00
|
|
|
return response.JSON(200, statsQuery.Result)
|
2016-01-25 03:01:33 +08:00
|
|
|
}
|
2021-06-14 23:36:48 +08:00
|
|
|
|
|
|
|
func (hs *HTTPServer) getAuthorizedSettings(ctx context.Context, user *models.SignedInUser, bag setting.SettingsBag) (setting.SettingsBag, error) {
|
|
|
|
if hs.AccessControl.IsDisabled() {
|
|
|
|
return bag, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
eval := func(scopes ...string) (bool, error) {
|
|
|
|
return hs.AccessControl.Evaluate(ctx, user, accesscontrol.ActionSettingsRead, scopes...)
|
|
|
|
}
|
|
|
|
|
|
|
|
ok, err := eval(accesscontrol.ScopeSettingsAll)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if ok {
|
|
|
|
return bag, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
authorizedBag := make(setting.SettingsBag)
|
|
|
|
|
|
|
|
for section, keys := range bag {
|
|
|
|
ok, err := eval(getSettingsScope(section, "*"))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if ok {
|
|
|
|
authorizedBag[section] = keys
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
for key := range keys {
|
|
|
|
ok, err := eval(getSettingsScope(section, key))
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if ok {
|
|
|
|
if _, exists := authorizedBag[section]; !exists {
|
|
|
|
authorizedBag[section] = make(map[string]string)
|
|
|
|
}
|
|
|
|
authorizedBag[section][key] = bag[section][key]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return authorizedBag, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func getSettingsScope(section, key string) string {
|
|
|
|
return fmt.Sprintf("settings:%s:%s", section, key)
|
|
|
|
}
|