mirror of https://github.com/grafana/grafana
Chore: clean up access control for data sources (#73010)
* move DS guardian interfaces to OSS, move allow guardian to OSS * update codeowner filepull/73486/head^2
parent
f7355668e7
commit
ec9c35fae5
@ -0,0 +1,19 @@ |
||||
package guardian |
||||
|
||||
import ( |
||||
"github.com/grafana/grafana/pkg/services/datasources" |
||||
) |
||||
|
||||
var _ DatasourceGuardian = new(AllowGuardian) |
||||
|
||||
// AllowGuardian is used whenever an enterprise build is running without a license.
|
||||
// It allows every one to Query all data sources and will not filter out any of them
|
||||
type AllowGuardian struct{} |
||||
|
||||
func (n AllowGuardian) CanQuery(datasourceID int64) (bool, error) { |
||||
return true, nil |
||||
} |
||||
|
||||
func (n AllowGuardian) FilterDatasourcesByQueryPermissions(ds []*datasources.DataSource) ([]*datasources.DataSource, error) { |
||||
return ds, nil |
||||
} |
||||
@ -0,0 +1,25 @@ |
||||
package guardian |
||||
|
||||
import ( |
||||
"github.com/grafana/grafana/pkg/services/datasources" |
||||
"github.com/grafana/grafana/pkg/services/user" |
||||
) |
||||
|
||||
type DatasourceGuardianProvider interface { |
||||
New(orgID int64, user *user.SignedInUser, dataSources ...datasources.DataSource) DatasourceGuardian |
||||
} |
||||
|
||||
type DatasourceGuardian interface { |
||||
CanQuery(datasourceID int64) (bool, error) |
||||
FilterDatasourcesByQueryPermissions([]*datasources.DataSource) ([]*datasources.DataSource, error) |
||||
} |
||||
|
||||
func ProvideGuardian() *OSSProvider { |
||||
return &OSSProvider{} |
||||
} |
||||
|
||||
type OSSProvider struct{} |
||||
|
||||
func (p *OSSProvider) New(orgID int64, user *user.SignedInUser, dataSources ...datasources.DataSource) DatasourceGuardian { |
||||
return &AllowGuardian{} |
||||
} |
||||
@ -1,25 +0,0 @@ |
||||
package permissions |
||||
|
||||
import ( |
||||
"context" |
||||
"errors" |
||||
|
||||
"github.com/grafana/grafana/pkg/services/datasources" |
||||
) |
||||
|
||||
var ErrNotImplemented = errors.New("not implemented") |
||||
|
||||
type DatasourcePermissionsService interface { |
||||
FilterDatasourcesBasedOnQueryPermissions(ctx context.Context, cmd *datasources.DatasourcesPermissionFilterQuery) ([]*datasources.DataSource, error) |
||||
} |
||||
|
||||
// dummy method
|
||||
func (hs *OSSDatasourcePermissionsService) FilterDatasourcesBasedOnQueryPermissions(ctx context.Context, cmd *datasources.DatasourcesPermissionFilterQuery) ([]*datasources.DataSource, error) { |
||||
return nil, ErrNotImplemented |
||||
} |
||||
|
||||
type OSSDatasourcePermissionsService struct{} |
||||
|
||||
func ProvideDatasourcePermissionsService() *OSSDatasourcePermissionsService { |
||||
return &OSSDatasourcePermissionsService{} |
||||
} |
||||
@ -1,21 +0,0 @@ |
||||
package permissions |
||||
|
||||
import ( |
||||
"context" |
||||
|
||||
"github.com/grafana/grafana/pkg/services/datasources" |
||||
) |
||||
|
||||
type mockDatasourcePermissionService struct { |
||||
DsResult []*datasources.DataSource |
||||
DsUidResult []string |
||||
ErrResult error |
||||
} |
||||
|
||||
func (m *mockDatasourcePermissionService) FilterDatasourcesBasedOnQueryPermissions(ctx context.Context, cmd *datasources.DatasourcesPermissionFilterQuery) ([]*datasources.DataSource, error) { |
||||
return m.DsResult, m.ErrResult |
||||
} |
||||
|
||||
func NewMockDatasourcePermissionService() *mockDatasourcePermissionService { |
||||
return &mockDatasourcePermissionService{} |
||||
} |
||||
Loading…
Reference in new issue