2021-08-04 07:44:37 -05:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2021-09-01 08:18:17 -05:00
|
|
|
"github.com/grafana/grafana/pkg/models"
|
2021-08-04 07:44:37 -05:00
|
|
|
"github.com/grafana/grafana/pkg/services/accesscontrol"
|
|
|
|
)
|
|
|
|
|
|
|
|
// API related actions
|
|
|
|
const (
|
|
|
|
ActionProvisioningReload = "provisioning:reload"
|
2021-09-01 08:18:17 -05:00
|
|
|
|
|
|
|
ActionDatasourcesRead = "datasources:read"
|
2021-10-21 08:41:40 -05:00
|
|
|
ActionDatasourcesQuery = "datasources:query"
|
2021-09-01 08:18:17 -05:00
|
|
|
ActionDatasourcesCreate = "datasources:create"
|
|
|
|
ActionDatasourcesWrite = "datasources:write"
|
|
|
|
ActionDatasourcesDelete = "datasources:delete"
|
2021-10-05 02:39:00 -05:00
|
|
|
ActionDatasourcesIDRead = "datasources.id:read"
|
2021-10-27 04:01:21 -05:00
|
|
|
|
|
|
|
ActionOrgsRead = "orgs:read"
|
|
|
|
ActionOrgsPreferencesRead = "orgs.preferences:read"
|
|
|
|
ActionOrgsQuotasRead = "orgs.quotas:read"
|
|
|
|
ActionOrgsWrite = "orgs:write"
|
|
|
|
ActionOrgsPreferencesWrite = "orgs.preferences:write"
|
|
|
|
ActionOrgsQuotasWrite = "orgs.quotas:write"
|
|
|
|
ActionOrgsDelete = "orgs:delete"
|
|
|
|
ActionOrgsCreate = "orgs:create"
|
2022-01-11 04:58:40 -06:00
|
|
|
|
|
|
|
ActionTeamsCreate = "teams:create"
|
2021-08-04 07:44:37 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// API related scopes
|
2021-10-06 06:15:09 -05:00
|
|
|
var (
|
|
|
|
ScopeProvisionersAll = accesscontrol.Scope("provisioners", "*")
|
|
|
|
ScopeProvisionersDashboards = accesscontrol.Scope("provisioners", "dashboards")
|
|
|
|
ScopeProvisionersPlugins = accesscontrol.Scope("provisioners", "plugins")
|
|
|
|
ScopeProvisionersDatasources = accesscontrol.Scope("provisioners", "datasources")
|
|
|
|
ScopeProvisionersNotifications = accesscontrol.Scope("provisioners", "notifications")
|
2021-09-01 08:18:17 -05:00
|
|
|
|
2021-10-06 06:15:09 -05:00
|
|
|
ScopeDatasourcesAll = accesscontrol.Scope("datasources", "*")
|
|
|
|
ScopeDatasourceID = accesscontrol.Scope("datasources", "id", accesscontrol.Parameter(":id"))
|
|
|
|
ScopeDatasourceUID = accesscontrol.Scope("datasources", "uid", accesscontrol.Parameter(":uid"))
|
|
|
|
ScopeDatasourceName = accesscontrol.Scope("datasources", "name", accesscontrol.Parameter(":name"))
|
2021-08-04 07:44:37 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// declareFixedRoles declares to the AccessControl service fixed roles and their
|
|
|
|
// grants to organization roles ("Viewer", "Editor", "Admin") or "Grafana Admin"
|
|
|
|
// that HTTPServer needs
|
|
|
|
func (hs *HTTPServer) declareFixedRoles() error {
|
2021-11-17 08:40:39 -06:00
|
|
|
provisioningWriterRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-18 03:16:18 -06:00
|
|
|
Version: 3,
|
2021-11-17 08:40:39 -06:00
|
|
|
Name: "fixed:provisioning:writer",
|
|
|
|
DisplayName: "Provisioning writer",
|
|
|
|
Description: "Reload provisioning.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Provisioning",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{
|
|
|
|
Action: ActionProvisioningReload,
|
|
|
|
Scope: ScopeProvisionersAll,
|
2021-09-01 08:18:17 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
Grants: []string{accesscontrol.RoleGrafanaAdmin},
|
|
|
|
}
|
|
|
|
|
|
|
|
datasourcesReaderRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-18 03:16:18 -06:00
|
|
|
Version: 3,
|
2021-11-17 08:40:39 -06:00
|
|
|
Name: "fixed:datasources:reader",
|
|
|
|
DisplayName: "Data source reader",
|
|
|
|
Description: "Read and query all data sources.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Data sources",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{
|
|
|
|
Action: ActionDatasourcesRead,
|
|
|
|
Scope: ScopeDatasourcesAll,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Action: ActionDatasourcesQuery,
|
|
|
|
Scope: ScopeDatasourcesAll,
|
2021-09-01 08:18:17 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
Grants: []string{string(models.ROLE_ADMIN)},
|
|
|
|
}
|
|
|
|
|
|
|
|
datasourcesWriterRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-18 03:16:18 -06:00
|
|
|
Version: 3,
|
2021-11-17 08:40:39 -06:00
|
|
|
Name: "fixed:datasources:writer",
|
|
|
|
DisplayName: "Data source writer",
|
|
|
|
Description: "Create, update, delete, read, or query data sources.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Data sources",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: accesscontrol.ConcatPermissions(datasourcesReaderRole.Role.Permissions, []accesscontrol.Permission{
|
|
|
|
{
|
|
|
|
Action: ActionDatasourcesWrite,
|
|
|
|
Scope: ScopeDatasourcesAll,
|
2021-08-04 07:44:37 -05:00
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
{
|
|
|
|
Action: ActionDatasourcesCreate,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Action: ActionDatasourcesDelete,
|
|
|
|
Scope: ScopeDatasourcesAll,
|
|
|
|
},
|
|
|
|
}),
|
2021-08-04 07:44:37 -05:00
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
Grants: []string{string(models.ROLE_ADMIN)},
|
|
|
|
}
|
|
|
|
|
|
|
|
datasourcesIdReaderRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-18 03:16:18 -06:00
|
|
|
Version: 4,
|
2021-11-17 08:40:39 -06:00
|
|
|
Name: "fixed:datasources.id:reader",
|
|
|
|
DisplayName: "Data source ID reader",
|
|
|
|
Description: "Read the ID of a data source based on its name.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Infrequently used",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{
|
|
|
|
Action: ActionDatasourcesIDRead,
|
|
|
|
Scope: ScopeDatasourcesAll,
|
2021-10-21 08:41:40 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
Grants: []string{string(models.ROLE_VIEWER)},
|
|
|
|
}
|
|
|
|
|
|
|
|
datasourcesCompatibilityReaderRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-18 03:16:18 -06:00
|
|
|
Version: 3,
|
2021-11-17 08:40:39 -06:00
|
|
|
Name: "fixed:datasources:compatibility:querier",
|
|
|
|
DisplayName: "Data source compatibility querier",
|
|
|
|
Description: "Only used for open source compatibility. Query data sources.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Infrequently used",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{Action: ActionDatasourcesQuery},
|
2022-01-17 03:16:12 -06:00
|
|
|
{Action: ActionDatasourcesRead},
|
2021-10-27 04:01:21 -05:00
|
|
|
},
|
|
|
|
},
|
2021-11-17 08:40:39 -06:00
|
|
|
Grants: []string{string(models.ROLE_VIEWER)},
|
|
|
|
}
|
|
|
|
|
2021-11-24 03:08:42 -06:00
|
|
|
orgReaderRole := accesscontrol.RoleRegistration{
|
2021-11-17 08:40:39 -06:00
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-24 03:08:42 -06:00
|
|
|
Version: 5,
|
|
|
|
Name: "fixed:organization:reader",
|
|
|
|
DisplayName: "Organization reader",
|
|
|
|
Description: "Read an organization, such as its ID, name, address, or quotas.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Organizations",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{Action: ActionOrgsRead},
|
|
|
|
{Action: ActionOrgsQuotasRead},
|
2021-10-27 04:01:21 -05:00
|
|
|
},
|
|
|
|
},
|
2021-11-24 03:08:42 -06:00
|
|
|
Grants: []string{string(models.ROLE_VIEWER), accesscontrol.RoleGrafanaAdmin},
|
2021-11-17 08:40:39 -06:00
|
|
|
}
|
|
|
|
|
2021-11-24 03:08:42 -06:00
|
|
|
orgWriterRole := accesscontrol.RoleRegistration{
|
2021-11-17 08:40:39 -06:00
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-24 03:08:42 -06:00
|
|
|
Version: 5,
|
|
|
|
Name: "fixed:organization:writer",
|
|
|
|
DisplayName: "Organization writer",
|
|
|
|
Description: "Read an organization, its quotas, or its preferences. Update organization properties, or its preferences.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Organizations",
|
2021-11-24 03:08:42 -06:00
|
|
|
Permissions: accesscontrol.ConcatPermissions(orgReaderRole.Role.Permissions, []accesscontrol.Permission{
|
2021-11-17 08:40:39 -06:00
|
|
|
{Action: ActionOrgsPreferencesRead},
|
|
|
|
{Action: ActionOrgsWrite},
|
|
|
|
{Action: ActionOrgsPreferencesWrite},
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
Grants: []string{string(models.ROLE_ADMIN)},
|
|
|
|
}
|
|
|
|
|
2021-11-24 03:08:42 -06:00
|
|
|
orgMaintainerRole := accesscontrol.RoleRegistration{
|
2021-11-17 08:40:39 -06:00
|
|
|
Role: accesscontrol.RoleDTO{
|
2021-11-24 03:08:42 -06:00
|
|
|
Version: 5,
|
|
|
|
Name: "fixed:organization:maintainer",
|
|
|
|
DisplayName: "Organization maintainer",
|
|
|
|
Description: "Create, read, write, or delete an organization. Read or write an organization's quotas. Needs to be assigned globally.",
|
2021-11-18 03:16:18 -06:00
|
|
|
Group: "Organizations",
|
2021-11-17 08:40:39 -06:00
|
|
|
Permissions: accesscontrol.ConcatPermissions(orgReaderRole.Role.Permissions, []accesscontrol.Permission{
|
|
|
|
{Action: ActionOrgsCreate},
|
|
|
|
{Action: ActionOrgsWrite},
|
|
|
|
{Action: ActionOrgsDelete},
|
|
|
|
{Action: ActionOrgsQuotasWrite},
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
Grants: []string{string(accesscontrol.RoleGrafanaAdmin)},
|
2021-08-04 07:44:37 -05:00
|
|
|
}
|
|
|
|
|
2022-01-11 04:58:40 -06:00
|
|
|
teamWriterGrants := []string{string(models.ROLE_ADMIN)}
|
|
|
|
if hs.Cfg.EditorsCanAdmin {
|
|
|
|
teamWriterGrants = append(teamWriterGrants, string(models.ROLE_EDITOR))
|
|
|
|
}
|
|
|
|
teamsWriterRole := accesscontrol.RoleRegistration{
|
|
|
|
Role: accesscontrol.RoleDTO{
|
|
|
|
Name: "fixed:teams:writer",
|
|
|
|
DisplayName: "Team writer",
|
|
|
|
Description: "Create teams.",
|
|
|
|
Group: "Teams",
|
|
|
|
Version: 1,
|
|
|
|
Permissions: []accesscontrol.Permission{
|
|
|
|
{
|
|
|
|
Action: ActionTeamsCreate,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Grants: teamWriterGrants,
|
|
|
|
}
|
|
|
|
|
2021-11-17 08:40:39 -06:00
|
|
|
return hs.AccessControl.DeclareFixedRoles(
|
|
|
|
provisioningWriterRole, datasourcesReaderRole, datasourcesWriterRole, datasourcesIdReaderRole,
|
2022-01-11 04:58:40 -06:00
|
|
|
datasourcesCompatibilityReaderRole, orgReaderRole, orgWriterRole, orgMaintainerRole, teamsWriterRole,
|
2021-11-17 08:40:39 -06:00
|
|
|
)
|
2021-08-04 07:44:37 -05:00
|
|
|
}
|
2021-09-22 06:50:21 -05:00
|
|
|
|
|
|
|
// Evaluators
|
|
|
|
// here is the list of complex evaluators we use in this package
|
|
|
|
|
|
|
|
// dataSourcesConfigurationAccessEvaluator is used to protect the "Configure > Data sources" tab access
|
|
|
|
var dataSourcesConfigurationAccessEvaluator = accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesRead, ScopeDatasourcesAll),
|
|
|
|
accesscontrol.EvalAny(
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesCreate),
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesDelete),
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesWrite),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
// dataSourcesNewAccessEvaluator is used to protect the "Configure > Data sources > New" page access
|
|
|
|
var dataSourcesNewAccessEvaluator = accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesRead, ScopeDatasourcesAll),
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesCreate),
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesWrite),
|
|
|
|
)
|
|
|
|
|
|
|
|
// dataSourcesEditAccessEvaluator is used to protect the "Configure > Data sources > Edit" page access
|
|
|
|
var dataSourcesEditAccessEvaluator = accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesRead, ScopeDatasourcesAll),
|
|
|
|
accesscontrol.EvalPermission(ActionDatasourcesWrite),
|
|
|
|
)
|
2021-11-18 07:10:38 -06:00
|
|
|
|
|
|
|
// orgPreferencesAccessEvaluator is used to protect the "Configure > Preferences" page access
|
|
|
|
var orgPreferencesAccessEvaluator = accesscontrol.EvalAny(
|
|
|
|
accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsRead),
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsWrite),
|
|
|
|
),
|
|
|
|
accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsPreferencesRead),
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsPreferencesWrite),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
|
|
|
|
// orgsAccessEvaluator is used to protect the "Server Admin > Orgs" page access
|
|
|
|
// (you need to have read access to update or delete orgs; read is the minimum)
|
|
|
|
var orgsAccessEvaluator = accesscontrol.EvalPermission(ActionOrgsRead)
|
|
|
|
|
|
|
|
// orgsCreateAccessEvaluator is used to protect the "Server Admin > Orgs > New Org" page access
|
|
|
|
var orgsCreateAccessEvaluator = accesscontrol.EvalAll(
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsRead),
|
|
|
|
accesscontrol.EvalPermission(ActionOrgsCreate),
|
|
|
|
)
|