Merge "Updates horizon's copy of the cinder policy file"
This commit is contained in:
commit
9d7cff5d96
@ -1,65 +1,113 @@
|
|||||||
{
|
{
|
||||||
"context_is_admin": [["role:admin"]],
|
"context_is_admin": "role:admin",
|
||||||
"admin_or_owner": [["is_admin:True"], ["project_id:%(project_id)s"]],
|
"admin_or_owner": "is_admin:True or project_id:%(project_id)s",
|
||||||
"default": [["rule:admin_or_owner"]],
|
"default": "rule:admin_or_owner",
|
||||||
|
|
||||||
"admin_api": [["is_admin:True"]],
|
"admin_api": "is_admin:True",
|
||||||
|
|
||||||
"volume:create": [],
|
"volume:create": "",
|
||||||
"volume:update": [],
|
"volume:delete": "rule:admin_or_owner",
|
||||||
"volume:delete": [["rule:default"]],
|
"volume:get": "rule:admin_or_owner",
|
||||||
"volume:get_all": [],
|
"volume:get_all": "rule:admin_or_owner",
|
||||||
"volume:get_volume_metadata": [],
|
"volume:get_volume_metadata": "rule:admin_or_owner",
|
||||||
"volume:get_volume_admin_metadata": [["rule:admin_api"]],
|
"volume:delete_volume_metadata": "rule:admin_or_owner",
|
||||||
"volume:delete_volume_admin_metadata": [["rule:admin_api"]],
|
"volume:update_volume_metadata": "rule:admin_or_owner",
|
||||||
"volume:update_volume_admin_metadata": [["rule:admin_api"]],
|
"volume:get_volume_admin_metadata": "rule:admin_api",
|
||||||
"volume:create_snapshot": [["rule:default"]],
|
"volume:update_volume_admin_metadata": "rule:admin_api",
|
||||||
"volume:delete_snapshot": [["rule:default"]],
|
"volume:get_snapshot": "rule:admin_or_owner",
|
||||||
"volume:get_snapshot": [],
|
"volume:get_all_snapshots": "rule:admin_or_owner",
|
||||||
"volume:update_snapshot": [["rule:default"]],
|
"volume:create_snapshot": "rule:admin_or_owner",
|
||||||
"volume:get_all_snapshots": [],
|
"volume:delete_snapshot": "rule:admin_or_owner",
|
||||||
"volume:extend": [],
|
"volume:update_snapshot": "rule:admin_or_owner",
|
||||||
"volume:retype": [],
|
"volume:get_snapshot_metadata": "rule:admin_or_owner",
|
||||||
"volume:upload_to_image": [],
|
"volume:delete_snapshot_metadata": "rule:admin_or_owner",
|
||||||
|
"volume:update_snapshot_metadata": "rule:admin_or_owner",
|
||||||
|
"volume:extend": "rule:admin_or_owner",
|
||||||
|
"volume:update_readonly_flag": "rule:admin_or_owner",
|
||||||
|
"volume:retype": "rule:admin_or_owner",
|
||||||
|
"volume:update": "rule:admin_or_owner",
|
||||||
|
|
||||||
"volume_extension:types_manage": [["rule:admin_api"]],
|
"volume_extension:types_manage": "rule:admin_api",
|
||||||
"volume_extension:types_extra_specs": [["rule:admin_api"]],
|
"volume_extension:types_extra_specs": "rule:admin_api",
|
||||||
"volume_extension:volume_type_encryption": [["rule:admin_api"]],
|
"volume_extension:access_types_qos_specs_id": "rule:admin_api",
|
||||||
"volume_extension:volume_encryption_metadata": [["rule:admin_api"]],
|
"volume_extension:access_types_extra_specs": "rule:admin_api",
|
||||||
"volume_extension:extended_snapshot_attributes": [],
|
"volume_extension:volume_type_access": "rule:admin_or_owner",
|
||||||
"volume_extension:volume_image_metadata": [],
|
"volume_extension:volume_type_access:addProjectAccess": "rule:admin_api",
|
||||||
|
"volume_extension:volume_type_access:removeProjectAccess": "rule:admin_api",
|
||||||
|
"volume_extension:volume_type_encryption": "rule:admin_api",
|
||||||
|
"volume_extension:volume_encryption_metadata": "rule:admin_or_owner",
|
||||||
|
"volume_extension:extended_snapshot_attributes": "rule:admin_or_owner",
|
||||||
|
"volume_extension:volume_image_metadata": "rule:admin_or_owner",
|
||||||
|
|
||||||
"volume_extension:quotas:show": [],
|
"volume_extension:quotas:show": "",
|
||||||
"volume_extension:quotas:update": [["rule:admin_api"]],
|
"volume_extension:quotas:update": "rule:admin_api",
|
||||||
"volume_extension:quota_classes": [],
|
"volume_extension:quotas:delete": "rule:admin_api",
|
||||||
|
"volume_extension:quota_classes": "rule:admin_api",
|
||||||
|
"volume_extension:quota_classes:validate_setup_for_nested_quota_use": "rule:admin_api",
|
||||||
|
|
||||||
"volume_extension:volume_manage": [["rule:admin_api"]],
|
"volume_extension:volume_admin_actions:reset_status": "rule:admin_api",
|
||||||
"volume_extension:volume_unmanage": [["rule:admin_api"]],
|
"volume_extension:snapshot_admin_actions:reset_status": "rule:admin_api",
|
||||||
|
"volume_extension:backup_admin_actions:reset_status": "rule:admin_api",
|
||||||
|
"volume_extension:volume_admin_actions:force_delete": "rule:admin_api",
|
||||||
|
"volume_extension:volume_admin_actions:force_detach": "rule:admin_api",
|
||||||
|
"volume_extension:snapshot_admin_actions:force_delete": "rule:admin_api",
|
||||||
|
"volume_extension:backup_admin_actions:force_delete": "rule:admin_api",
|
||||||
|
"volume_extension:volume_admin_actions:migrate_volume": "rule:admin_api",
|
||||||
|
"volume_extension:volume_admin_actions:migrate_volume_completion": "rule:admin_api",
|
||||||
|
|
||||||
"volume_extension:volume_admin_actions:reset_status": [["rule:admin_api"]],
|
"volume_extension:volume_actions:upload_public": "rule:admin_api",
|
||||||
"volume_extension:snapshot_admin_actions:reset_status": [["rule:admin_api"]],
|
"volume_extension:volume_actions:upload_image": "rule:admin_or_owner",
|
||||||
"volume_extension:volume_admin_actions:force_delete": [["rule:admin_api"]],
|
|
||||||
"volume_extension:snapshot_admin_actions:force_delete": [["rule:admin_api"]],
|
|
||||||
"volume_extension:volume_admin_actions:migrate_volume": [["rule:admin_api"]],
|
|
||||||
"volume_extension:volume_admin_actions:migrate_volume_completion": [["rule:admin_api"]],
|
|
||||||
|
|
||||||
"volume_extension:volume_host_attribute": [["rule:admin_api"]],
|
"volume_extension:volume_host_attribute": "rule:admin_api",
|
||||||
"volume_extension:volume_tenant_attribute": [["rule:admin_api"]],
|
"volume_extension:volume_tenant_attribute": "rule:admin_or_owner",
|
||||||
"volume_extension:volume_mig_status_attribute": [["rule:admin_api"]],
|
"volume_extension:volume_mig_status_attribute": "rule:admin_api",
|
||||||
"volume_extension:hosts": [["rule:admin_api"]],
|
"volume_extension:hosts": "rule:admin_api",
|
||||||
"volume_extension:services": [["rule:admin_api"]],
|
"volume_extension:services:index": "rule:admin_api",
|
||||||
"volume:services": [["rule:admin_api"]],
|
"volume_extension:services:update" : "rule:admin_api",
|
||||||
|
|
||||||
"volume:create_transfer": [],
|
"volume_extension:volume_manage": "rule:admin_api",
|
||||||
"volume:accept_transfer": [],
|
"volume_extension:volume_unmanage": "rule:admin_api",
|
||||||
"volume:delete_transfer": [],
|
|
||||||
"volume:get_all_transfers": [],
|
|
||||||
|
|
||||||
"backup:create" : ["rule:default"],
|
"volume_extension:capabilities": "rule:admin_api",
|
||||||
"backup:delete": ["rule:default"],
|
|
||||||
"backup:get": [],
|
|
||||||
"backup:get_all": [],
|
|
||||||
"backup:restore": ["rule:default"],
|
|
||||||
|
|
||||||
"snapshot_extension:snapshot_actions:update_snapshot_status": []
|
"volume:create_transfer": "rule:admin_or_owner",
|
||||||
|
"volume:accept_transfer": "",
|
||||||
|
"volume:delete_transfer": "rule:admin_or_owner",
|
||||||
|
"volume:get_transfer": "rule:admin_or_owner",
|
||||||
|
"volume:get_all_transfers": "rule:admin_or_owner",
|
||||||
|
|
||||||
|
"volume_extension:replication:promote": "rule:admin_api",
|
||||||
|
"volume_extension:replication:reenable": "rule:admin_api",
|
||||||
|
|
||||||
|
"volume:failover_host": "rule:admin_api",
|
||||||
|
"volume:freeze_host": "rule:admin_api",
|
||||||
|
"volume:thaw_host": "rule:admin_api",
|
||||||
|
|
||||||
|
"backup:create" : "",
|
||||||
|
"backup:delete": "rule:admin_or_owner",
|
||||||
|
"backup:get": "rule:admin_or_owner",
|
||||||
|
"backup:get_all": "rule:admin_or_owner",
|
||||||
|
"backup:restore": "rule:admin_or_owner",
|
||||||
|
"backup:backup-import": "rule:admin_api",
|
||||||
|
"backup:backup-export": "rule:admin_api",
|
||||||
|
|
||||||
|
"snapshot_extension:snapshot_actions:update_snapshot_status": "",
|
||||||
|
"snapshot_extension:snapshot_manage": "rule:admin_api",
|
||||||
|
"snapshot_extension:snapshot_unmanage": "rule:admin_api",
|
||||||
|
|
||||||
|
"consistencygroup:create" : "group:nobody",
|
||||||
|
"consistencygroup:delete": "group:nobody",
|
||||||
|
"consistencygroup:update": "group:nobody",
|
||||||
|
"consistencygroup:get": "group:nobody",
|
||||||
|
"consistencygroup:get_all": "group:nobody",
|
||||||
|
|
||||||
|
"consistencygroup:create_cgsnapshot" : "group:nobody",
|
||||||
|
"consistencygroup:delete_cgsnapshot": "group:nobody",
|
||||||
|
"consistencygroup:get_cgsnapshot": "group:nobody",
|
||||||
|
"consistencygroup:get_all_cgsnapshots": "group:nobody",
|
||||||
|
|
||||||
|
"scheduler_extension:scheduler_stats:get_pools" : "rule:admin_api",
|
||||||
|
"message:delete": "rule:admin_or_owner",
|
||||||
|
"message:get": "rule:admin_or_owner",
|
||||||
|
"message:get_all": "rule:admin_or_owner"
|
||||||
}
|
}
|
||||||
|
@ -242,7 +242,8 @@ class UploadToImage(VolumePolicyTargetMixin, tables.LinkAction):
|
|||||||
url = "horizon:project:volumes:volumes:upload_to_image"
|
url = "horizon:project:volumes:volumes:upload_to_image"
|
||||||
classes = ("ajax-modal",)
|
classes = ("ajax-modal",)
|
||||||
icon = "cloud-upload"
|
icon = "cloud-upload"
|
||||||
policy_rules = (("volume", "volume:upload_to_image"),)
|
policy_rules = (("volume",
|
||||||
|
"volume_extension:volume_actions:upload_image"),)
|
||||||
|
|
||||||
def allowed(self, request, volume=None):
|
def allowed(self, request, volume=None):
|
||||||
has_image_service_perm = \
|
has_image_service_perm = \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user