Isolate project scope and system scope

This change updates the default policies implemented in Heat, to follow
the updated guideline[1] to implement SRBAC.

The main change is that system users are no longer allowed to perform
any operations about project-level resources like alarms, while project
admin(*1) is still allowed to perform operations about project-level
resources BEYOND project (like getting alarms for all projects)

[1] https://governance.openstack.org/tc/goals/selected/consistent-and-secure-rbac.html#direction-change

Change-Id: I0a59e3f892aff306e47812b69dbf82066411a542
This commit is contained in:
Takashi Kajinami 2024-07-18 01:09:01 +09:00
parent f43e903117
commit 807e65e352
2 changed files with 33 additions and 41 deletions

View File

@ -22,24 +22,10 @@ RULE_ADMIN_OR_OWNER = 'rule:context_is_admin or project_id:%(project_id)s'
UNPROTECTED = '' UNPROTECTED = ''
# Constants that represent common personas. # Constants that represent common personas.
SYSTEM_ADMIN = 'role:admin and system_scope:all' PROJECT_ADMIN = 'role:admin and project_id:%(project_id)s'
SYSTEM_READER = 'role:reader and system_scope:all'
PROJECT_MEMBER = 'role:member and project_id:%(project_id)s' PROJECT_MEMBER = 'role:member and project_id:%(project_id)s'
PROJECT_READER = 'role:reader and project_id:%(project_id)s' PROJECT_READER = 'role:reader and project_id:%(project_id)s'
# Composite check strings built using the personas defined above, where a
# particular API is designed to work with multiple scopes. For example,
# listing alarms for all projects (system-scope) or listing alarms for a single
# project (project-scope).
SYSTEM_ADMIN_OR_PROJECT_MEMBER = (
'(' + SYSTEM_ADMIN + ')'
' or (' + PROJECT_MEMBER + ')'
)
SYSTEM_OR_PROJECT_READER = (
'(' + SYSTEM_READER + ')'
' or (' + PROJECT_READER + ')'
)
DEPRECATED_REASON = """ DEPRECATED_REASON = """
The alarm and quota APIs now support system-scope and default roles. The alarm and quota APIs now support system-scope and default roles.
""" """
@ -153,8 +139,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:get_alarm", name="telemetry:get_alarm",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Get an alarm.', description='Get an alarm.',
operations=[ operations=[
{ {
@ -167,8 +153,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:get_alarms", name="telemetry:get_alarms",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Get all alarms, based on the query provided.', description='Get all alarms, based on the query provided.',
operations=[ operations=[
{ {
@ -180,8 +166,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:get_alarms:all_projects", name="telemetry:get_alarms:all_projects",
check_str=SYSTEM_READER, check_str=PROJECT_ADMIN,
scope_types=['system', 'project'], scope_types=['project'],
description='Get alarms of all projects.', description='Get alarms of all projects.',
operations=[ operations=[
{ {
@ -193,8 +179,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:query_alarm", name="telemetry:query_alarm",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Get all alarms, based on the query provided.', description='Get all alarms, based on the query provided.',
operations=[ operations=[
{ {
@ -206,8 +192,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:create_alarm", name="telemetry:create_alarm",
check_str=SYSTEM_ADMIN_OR_PROJECT_MEMBER, check_str=PROJECT_MEMBER,
scope_types=['system', 'project'], scope_types=['project'],
description='Create a new alarm.', description='Create a new alarm.',
operations=[ operations=[
{ {
@ -219,8 +205,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:change_alarm", name="telemetry:change_alarm",
check_str=SYSTEM_ADMIN_OR_PROJECT_MEMBER, check_str=PROJECT_MEMBER,
scope_types=['system', 'project'], scope_types=['project'],
description='Modify this alarm.', description='Modify this alarm.',
operations=[ operations=[
{ {
@ -232,8 +218,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:delete_alarm", name="telemetry:delete_alarm",
check_str=SYSTEM_ADMIN_OR_PROJECT_MEMBER, check_str=PROJECT_MEMBER,
scope_types=['system', 'project'], scope_types=['project'],
description='Delete this alarm.', description='Delete this alarm.',
operations=[ operations=[
{ {
@ -245,8 +231,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:get_alarm_state", name="telemetry:get_alarm_state",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Get the state of this alarm.', description='Get the state of this alarm.',
operations=[ operations=[
{ {
@ -258,8 +244,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:change_alarm_state", name="telemetry:change_alarm_state",
check_str=SYSTEM_ADMIN_OR_PROJECT_MEMBER, check_str=PROJECT_MEMBER,
scope_types=['system', 'project'], scope_types=['project'],
description='Set the state of this alarm.', description='Set the state of this alarm.',
operations=[ operations=[
{ {
@ -271,8 +257,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:alarm_history", name="telemetry:alarm_history",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Assembles the alarm history requested.', description='Assembles the alarm history requested.',
operations=[ operations=[
{ {
@ -284,8 +270,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:query_alarm_history", name="telemetry:query_alarm_history",
check_str=SYSTEM_OR_PROJECT_READER, check_str=PROJECT_READER,
scope_types=['system', 'project'], scope_types=['project'],
description='Define query for retrieving AlarmChange data.', description='Define query for retrieving AlarmChange data.',
operations=[ operations=[
{ {
@ -297,8 +283,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:update_quotas", name="telemetry:update_quotas",
check_str=SYSTEM_ADMIN, check_str=PROJECT_ADMIN,
scope_types=['system'], scope_types=['project'],
description='Update resources quotas for project.', description='Update resources quotas for project.',
operations=[ operations=[
{ {
@ -310,8 +296,8 @@ rules = [
), ),
policy.DocumentedRuleDefault( policy.DocumentedRuleDefault(
name="telemetry:delete_quotas", name="telemetry:delete_quotas",
check_str=SYSTEM_ADMIN, check_str=PROJECT_ADMIN,
scope_types=['system'], scope_types=['project'],
description='Delete resources quotas for project.', description='Delete resources quotas for project.',
operations=[ operations=[
{ {

View File

@ -0,0 +1,6 @@
---
features:
- |
Aodh policies have been modified to isolate the system and project level
APIs policy. Because of this change, system users will not be allowed to
perform any operations on project level resources.