mirror of
https://github.com/grafana/grafana.git
synced 2025-07-28 13:32:24 +08:00
Requests for ds via backend blocked for users without permissions.
This commit is contained in:
@ -2,6 +2,7 @@ package api
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/pkg/errors"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/grafana/grafana/pkg/api/pluginproxy"
|
"github.com/grafana/grafana/pkg/api/pluginproxy"
|
||||||
@ -14,6 +15,20 @@ import (
|
|||||||
const HeaderNameNoBackendCache = "X-Grafana-NoCache"
|
const HeaderNameNoBackendCache = "X-Grafana-NoCache"
|
||||||
|
|
||||||
func (hs *HTTPServer) getDatasourceFromCache(id int64, c *m.ReqContext) (*m.DataSource, error) {
|
func (hs *HTTPServer) getDatasourceFromCache(id int64, c *m.ReqContext) (*m.DataSource, error) {
|
||||||
|
userPermissionsQuery := m.GetDataSourcePermissionsForUserQuery{
|
||||||
|
User: c.SignedInUser,
|
||||||
|
}
|
||||||
|
if err := bus.Dispatch(&userPermissionsQuery); err != nil {
|
||||||
|
if err != bus.ErrHandlerNotFound {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
permissionType, exists := userPermissionsQuery.Result[id]
|
||||||
|
if exists && permissionType != m.DsPermissionQuery {
|
||||||
|
return nil, errors.New("User not allowed to access datasource")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
nocache := c.Req.Header.Get(HeaderNameNoBackendCache) == "true"
|
nocache := c.Req.Header.Get(HeaderNameNoBackendCache) == "true"
|
||||||
cacheKey := fmt.Sprintf("ds-%d", id)
|
cacheKey := fmt.Sprintf("ds-%d", id)
|
||||||
|
|
||||||
@ -38,7 +53,10 @@ func (hs *HTTPServer) getDatasourceFromCache(id int64, c *m.ReqContext) (*m.Data
|
|||||||
func (hs *HTTPServer) ProxyDataSourceRequest(c *m.ReqContext) {
|
func (hs *HTTPServer) ProxyDataSourceRequest(c *m.ReqContext) {
|
||||||
c.TimeRequest(metrics.M_DataSource_ProxyReq_Timer)
|
c.TimeRequest(metrics.M_DataSource_ProxyReq_Timer)
|
||||||
|
|
||||||
ds, err := hs.getDatasourceFromCache(c.ParamsInt64(":id"), c)
|
dsId := c.ParamsInt64(":id")
|
||||||
|
ds, err := hs.getDatasourceFromCache(dsId, c)
|
||||||
|
hs.log.Debug("We are in the ds proxy", "dsId", dsId)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
c.JsonApiErr(500, "Unable to load datasource meta data", err)
|
c.JsonApiErr(500, "Unable to load datasource meta data", err)
|
||||||
return
|
return
|
||||||
|
Reference in New Issue
Block a user