mirror of https://github.com/grafana/grafana.git
				
				
				
			
		
			
				
	
	
		
			113 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			Go
		
	
	
	
| package api
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"net/http"
 | |
| 
 | |
| 	"github.com/grafana/grafana/pkg/api/response"
 | |
| 	"github.com/grafana/grafana/pkg/models"
 | |
| 	ac "github.com/grafana/grafana/pkg/services/accesscontrol"
 | |
| 	"github.com/grafana/grafana/pkg/services/user"
 | |
| 	"github.com/grafana/grafana/pkg/setting"
 | |
| )
 | |
| 
 | |
| // swagger:route GET /admin/settings admin adminGetSettings
 | |
| //
 | |
| // Fetch settings.
 | |
| //
 | |
| // If you are running Grafana Enterprise and have Fine-grained access control enabled, you need to have a permission with action `settings:read` and scopes: `settings:*`, `settings:auth.saml:` and `settings:auth.saml:enabled` (property level).
 | |
| //
 | |
| // Security:
 | |
| // - basic:
 | |
| //
 | |
| // Responses:
 | |
| // 200: adminGetSettingsResponse
 | |
| // 401: unauthorisedError
 | |
| // 403: forbiddenError
 | |
| 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)
 | |
| }
 | |
| 
 | |
| // swagger:route GET /admin/stats admin adminGetStats
 | |
| //
 | |
| // Fetch Grafana Stats.
 | |
| //
 | |
| // Only works with Basic Authentication (username and password). See introduction for an explanation.
 | |
| // If you are running Grafana Enterprise and have Fine-grained access control enabled, you need to have a permission with action `server:stats:read`.
 | |
| //
 | |
| // Responses:
 | |
| // 200: adminGetStatsResponse
 | |
| // 401: unauthorisedError
 | |
| // 403: forbiddenError
 | |
| // 500: internalServerError
 | |
| func (hs *HTTPServer) AdminGetStats(c *models.ReqContext) response.Response {
 | |
| 	statsQuery := models.GetAdminStatsQuery{}
 | |
| 
 | |
| 	if err := hs.SQLStore.GetAdminStats(c.Req.Context(), &statsQuery); err != nil {
 | |
| 		return response.Error(500, "Failed to get admin stats from database", err)
 | |
| 	}
 | |
| 
 | |
| 	return response.JSON(http.StatusOK, statsQuery.Result)
 | |
| }
 | |
| 
 | |
| func (hs *HTTPServer) getAuthorizedSettings(ctx context.Context, user *user.SignedInUser, bag setting.SettingsBag) (setting.SettingsBag, error) {
 | |
| 	if hs.AccessControl.IsDisabled() {
 | |
| 		return bag, nil
 | |
| 	}
 | |
| 
 | |
| 	eval := func(scope string) (bool, error) {
 | |
| 		return hs.AccessControl.Evaluate(ctx, user, ac.EvalPermission(ac.ActionSettingsRead, scope))
 | |
| 	}
 | |
| 
 | |
| 	ok, err := eval(ac.ScopeSettingsAll)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	if ok {
 | |
| 		return bag, nil
 | |
| 	}
 | |
| 
 | |
| 	authorizedBag := make(setting.SettingsBag)
 | |
| 
 | |
| 	for section, keys := range bag {
 | |
| 		ok, err := eval(ac.Scope("settings", section, "*"))
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 		if ok {
 | |
| 			authorizedBag[section] = keys
 | |
| 			continue
 | |
| 		}
 | |
| 
 | |
| 		for key := range keys {
 | |
| 			ok, err := eval(ac.Scope("settings", 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
 | |
| }
 | |
| 
 | |
| // swagger:response adminGetSettingsResponse
 | |
| type GetSettingsResponse struct {
 | |
| 	// in:body
 | |
| 	Body setting.SettingsBag `json:"body"`
 | |
| }
 | |
| 
 | |
| // swagger:response adminGetStatsResponse
 | |
| type GetStatsResponse struct {
 | |
| 	// in:body
 | |
| 	Body models.AdminStats `json:"body"`
 | |
| }
 |