Merge "Sync default policy rules"

This commit is contained in:
Zuul 2023-09-19 05:18:34 +00:00 committed by Gerrit Code Review
commit 12a76f73c7
6 changed files with 493 additions and 246 deletions

@ -1,7 +1,7 @@
- check_str: ''
deprecated_reason: null
deprecated_rule:
check_str: role:admin
check_str: rule:context_is_admin
name: default
deprecated_since: null
description: Defines the default rule used for policies that historically had an
@ -14,7 +14,8 @@
name: context_is_admin
operations: []
scope_types: null
- check_str: role:admin or (role:member and project_id:%(project_id)s and project_id:%(owner)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s and
project_id:%(owner)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -27,7 +28,7 @@
path: /v2/images
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -40,8 +41,9 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or project_id:%(member_id)s
or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s
or 'shared':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -54,7 +56,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:reader and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:reader and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -67,7 +69,7 @@
path: /v2/images
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -80,7 +82,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
description: Publicize given image
name: publicize_image
operations:
@ -88,7 +90,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -101,8 +103,9 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:member and (project_id:%(project_id)s or project_id:%(member_id)s
or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))
- check_str: rule:context_is_admin or (role:member and (project_id:%(project_id)s
or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s
or 'shared':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -115,7 +118,7 @@
path: /v2/images/{image_id}/file
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -128,7 +131,7 @@
path: /v2/images/{image_id}/file
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -141,7 +144,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:reader and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:reader and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -154,7 +157,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -167,7 +170,7 @@
path: /v2/images/{image_id}
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -180,7 +183,7 @@
path: /v2/images/{image_id}/members
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -193,7 +196,8 @@
path: /v2/images/{image_id}/members/{member_id}
scope_types:
- project
- check_str: role:admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)
- check_str: rule:context_is_admin or role:reader and (project_id:%(project_id)s or
project_id:%(member_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -206,7 +210,8 @@
path: /v2/images/{image_id}/members/{member_id}
scope_types:
- project
- check_str: role:admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)
- check_str: rule:context_is_admin or role:reader and (project_id:%(project_id)s or
project_id:%(member_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -219,7 +224,7 @@
path: /v2/images/{image_id}/members
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(member_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(member_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -232,13 +237,13 @@
path: /v2/images/{image_id}/members/{member_id}
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
description: Manage image cache
name: manage_image_cache
operations: []
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -251,7 +256,7 @@
path: /v2/images/{image_id}/actions/deactivate
scope_types:
- project
- check_str: role:admin or (role:member and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:default
@ -264,7 +269,7 @@
path: /v2/images/{image_id}/actions/reactivate
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
description: Copy existing image to other stores
name: copy_image
operations:
@ -373,7 +378,7 @@
path: /v2/tasks/{task_id}
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
description: '
This is a generic blanket policy for protecting all task APIs. It is not
@ -400,12 +405,13 @@
name: metadef_default
operations: []
scope_types: null
- check_str: role:admin
- check_str: rule:context_is_admin
description: null
name: metadef_admin
operations: []
scope_types: null
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -418,7 +424,7 @@
path: /v2/metadefs/namespaces/{namespace_name}
scope_types:
- project
- check_str: role:admin or (role:reader and project_id:%(project_id)s)
- check_str: rule:context_is_admin or (role:reader and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -455,7 +461,8 @@
path: /v2/metadefs/namespaces/{namespace_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -468,7 +475,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/objects/{object_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -505,7 +513,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/objects/{object_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -518,7 +527,8 @@
path: /v2/metadefs/resource_types
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -547,7 +557,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/resource_types/{name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -560,7 +571,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/properties/{property_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -597,7 +609,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/properties/{property_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -610,7 +623,8 @@
path: /v2/metadefs/namespaces/{namespace_name}/tags/{tag_name}
scope_types:
- project
- check_str: role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))
- check_str: rule:context_is_admin or (role:reader and (project_id:%(project_id)s
or 'public':%(visibility)s))
deprecated_reason: null
deprecated_rule:
check_str: rule:metadef_default
@ -663,7 +677,7 @@
path: /v2/metadefs/namespaces/{namespace_name}/tags
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
deprecated_reason: null
deprecated_rule:
check_str: rule:manage_image_cache
@ -676,7 +690,7 @@
path: /v2/cache/{image_id}
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
deprecated_reason: null
deprecated_rule:
check_str: rule:manage_image_cache
@ -689,7 +703,7 @@
path: /v2/cache
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
deprecated_reason: null
deprecated_rule:
check_str: rule:manage_image_cache
@ -704,7 +718,7 @@
path: /v2/cache/{image_id}
scope_types:
- project
- check_str: role:admin
- check_str: rule:context_is_admin
description: Expose store specific information
name: stores_info_detail
operations:

@ -344,7 +344,7 @@
path: /auto-allocated-topology/{project_id}
scope_types:
- project
- check_str: rule:admin_only
- check_str: role:reader
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -357,6 +357,47 @@
path: /availability_zones
scope_types:
- project
- check_str: rule:admin_only
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_only
name: create_default_security_group_rule
deprecated_since: null
description: Create a templated of the security group rule
name: create_default_security_group_rule
operations:
- method: POST
path: /default-security-group-rules
scope_types:
- project
- check_str: role:reader
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
name: get_default_security_group_rule
deprecated_since: null
description: Get a templated of the security group rule
name: get_default_security_group_rule
operations:
- method: GET
path: /default-security-group-rules
- method: GET
path: /default-security-group-rules/{id}
scope_types:
- project
- check_str: rule:admin_only
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_only
name: delete_default_security_group_rule
deprecated_since: null
description: Delete a templated of the security group rule
name: delete_default_security_group_rule
operations:
- method: DELETE
path: /default-security-group-rules/{id}
scope_types:
- project
- check_str: rule:admin_only
deprecated_reason: null
deprecated_rule:
@ -584,7 +625,7 @@
path: /floatingip_pools
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner
- check_str: (rule:admin_only) or (role:member and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_ext_parent_owner
@ -597,7 +638,7 @@
path: /floatingips/{floatingip_id}/port_forwardings
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s) or rule:ext_parent_owner
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_ext_parent_owner
@ -612,7 +653,7 @@
path: /floatingips/{floatingip_id}/port_forwardings/{port_forwarding_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner
- check_str: (rule:admin_only) or (role:member and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_ext_parent_owner
@ -625,7 +666,7 @@
path: /floatingips/{floatingip_id}/port_forwardings/{port_forwarding_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner
- check_str: (rule:admin_only) or (role:member and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_ext_parent_owner
@ -1339,6 +1380,38 @@
path: /network_segment_ranges/{id}
scope_types:
- project
- check_str: rule:admin_only
description: Get port binding information
name: get_port_binding
operations:
- method: GET
path: /ports/{port_id}/bindings/
scope_types:
- project
- check_str: rule:admin_only
description: Create port binding on the host
name: create_port_binding
operations:
- method: POST
path: /ports/{port_id}/bindings/
scope_types:
- project
- check_str: rule:admin_only
description: Delete port binding on the host
name: delete_port_binding
operations:
- method: DELETE
path: /ports/{port_id}/bindings/
scope_types:
- project
- check_str: rule:admin_only
description: Activate port binding on the host
name: activate
operations:
- method: PUT
path: /ports/{port_id}/bindings/{host}
scope_types:
- project
- check_str: 'field:port:device_owner=~^network:'
description: Definition of port with network device_owner
name: network_device
@ -1362,8 +1435,8 @@
path: /ports
scope_types:
- project
- check_str: not rule:network_device or rule:admin_only or rule:context_is_advsvc
or rule:network_owner
- check_str: not rule:network_device or rule:context_is_advsvc or (rule:admin_only)
or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: not rule:network_device or rule:context_is_advsvc or rule:admin_or_network_owner
@ -1374,7 +1447,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1385,7 +1458,8 @@
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
or rule:shared
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner or rule:shared
@ -1396,7 +1470,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1407,7 +1481,8 @@
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
or rule:shared
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner or rule:shared
@ -1418,7 +1493,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1462,7 +1537,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1473,7 +1548,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1485,7 +1560,7 @@
operations: *id004
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1497,7 +1572,14 @@
operations: *id004
scope_types:
- project
- check_str: rule:admin_only or rule:context_is_advsvc or role:reader and project_id:%(project_id)s
- check_str: rule:admin_only
description: Specify ``hints`` attribute when creating a port
name: create_port:hints
operations: *id004
scope_types:
- project
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:reader and rule:network_owner)
or role:reader and project_id:%(project_id)s
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_owner_or_network_owner
@ -1567,6 +1649,12 @@
operations: *id005
scope_types:
- project
- check_str: rule:admin_only
description: Get ``hints`` attribute of a port
name: get_port:hints
operations: *id005
scope_types:
- project
- check_str: rule:admin_only or role:member and project_id:%(project_id)s or rule:context_is_advsvc
deprecated_reason: null
deprecated_rule:
@ -1580,8 +1668,8 @@
path: /ports/{id}
scope_types:
- project
- check_str: not rule:network_device or rule:context_is_advsvc or rule:network_owner
or rule:admin_only
- check_str: not rule:network_device or rule:context_is_advsvc or (rule:admin_only)
or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: not rule:network_device or rule:context_is_advsvc or rule:admin_or_network_owner
@ -1603,7 +1691,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1614,7 +1702,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1625,7 +1713,8 @@
operations: *id006
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
or rule:shared
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner or rule:shared
@ -1636,7 +1725,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:context_is_advsvc or rule:network_owner or rule:admin_only
- check_str: rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_or_network_owner
@ -1680,7 +1769,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1691,7 +1780,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1703,7 +1792,7 @@
operations: *id006
scope_types:
- project
- check_str: rule:admin_only or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -1725,8 +1814,14 @@
operations: *id006
scope_types:
- project
- check_str: rule:admin_only or rule:context_is_advsvc or role:member and project_id:%(project_id)s
or rule:network_owner
- check_str: rule:admin_only
description: Update ``hints`` attribute of a port
name: update_port:hints
operations: *id006
scope_types:
- project
- check_str: rule:context_is_advsvc or role:member and project_id:%(project_id)s or
(rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:context_is_advsvc or rule:admin_owner_or_network_owner
@ -1798,7 +1893,7 @@
path: /qos/policies/{id}
scope_types:
- project
- check_str: rule:admin_only
- check_str: role:reader
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -1813,7 +1908,7 @@
path: /qos/rule-types/{rule_type}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -1867,7 +1962,7 @@
path: /qos/policies/{policy_id}/bandwidth_limit_rules/{rule_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
description: Get a QoS packet rate limit rule
name: get_policy_packet_rate_limit_rule
operations:
@ -1901,7 +1996,7 @@
path: /qos/policies/{policy_id}/packet_rate_limit_rules/{rule_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -1955,7 +2050,7 @@
path: /qos/policies/{policy_id}/dscp_marking_rules/{rule_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -2009,7 +2104,7 @@
path: /qos/policies/{policy_id}/minimum_bandwidth_rules/{rule_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
description: Get a QoS minimum packet rate rule
name: get_policy_minimum_packet_rate_rule
operations:
@ -2043,7 +2138,7 @@
path: /qos/policies/{policy_id}/minimum_packet_rate_rules/{rule_id}
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -2082,7 +2177,7 @@
path: /qos/alias_bandwidth_limit_rules/{rule_id}/
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -2121,7 +2216,7 @@
path: /qos/alias_dscp_marking_rules/{rule_id}/
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
- check_str: (rule:admin_only) or (role:reader and rule:ext_parent_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:regular_user
@ -2393,6 +2488,18 @@
operations: *id007
scope_types:
- project
- check_str: rule:admin_only
description: Specify ``enable_default_route_bfd`` attribute when creating a router
name: create_router:enable_default_route_bfd
operations: *id007
scope_types:
- project
- check_str: rule:admin_only
description: Specify ``enable_default_route_ecmp`` attribute when creating a router
name: create_router:enable_default_route_ecmp
operations: *id007
scope_types:
- project
- check_str: (rule:admin_only) or (role:reader and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
@ -2512,6 +2619,18 @@
operations: *id009
scope_types:
- project
- check_str: rule:admin_only
description: Specify ``enable_default_route_bfd`` attribute when updating a router
name: update_router:enable_default_route_bfd
operations: *id007
scope_types:
- project
- check_str: rule:admin_only
description: Specify ``enable_default_route_ecmp`` attribute when updating a router
name: update_router:enable_default_route_ecmp
operations: *id007
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s)
deprecated_reason: null
deprecated_rule:
@ -2754,7 +2873,7 @@
path: /service-providers
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -2815,7 +2934,7 @@
operations: *id011
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner
@ -2850,7 +2969,7 @@
operations: *id012
scope_types:
- project
- check_str: (rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner
- check_str: (rule:admin_only) or (role:member and rule:network_owner)
deprecated_reason: null
deprecated_rule:
check_str: rule:admin_or_network_owner

@ -1004,13 +1004,21 @@
scope_types:
- project
- check_str: rule:context_is_admin
description: Cold migrate a server to a host
description: Cold migrate a server without specifying a host
name: os_compute_api:os-migrate-server:migrate
operations:
- method: POST
path: /servers/{server_id}/action (migrate)
scope_types:
- project
- check_str: rule:context_is_admin
description: Cold migrate a server to a specified host
name: os_compute_api:os-migrate-server:migrate:host
operations:
- method: POST
path: /servers/{server_id}/action (migrate)
scope_types:
- project
- check_str: rule:context_is_admin
description: Live migrate a server to a new host without a reboot
name: os_compute_api:os-migrate-server:migrate_live

@ -3,8 +3,8 @@
#"default": ""
# DEPRECATED
# "default":"role:admin" has been deprecated since Ussuri in favor of
# "default":"".
# "default":"rule:context_is_admin" has been deprecated since Ussuri
# in favor of "default":"".
# In order to allow operators to accept the default policies from code
# by not defining them in the policy file, while still working with
# old policy files that rely on the ``default`` rule for policies that
@ -18,33 +18,33 @@
# Create new image
# POST /v2/images
# Intended scope(s): project
#"add_image": "role:admin or (role:member and project_id:%(project_id)s and project_id:%(owner)s)"
#"add_image": "rule:context_is_admin or (role:member and project_id:%(project_id)s and project_id:%(owner)s)"
# DEPRECATED
# "add_image":"rule:default" has been deprecated since W in favor of
# "add_image":"role:admin or (role:member and
# "add_image":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s and project_id:%(owner)s)".
# The image API now supports roles.
# Deletes the image
# DELETE /v2/images/{image_id}
# Intended scope(s): project
#"delete_image": "role:admin or (role:member and project_id:%(project_id)s)"
#"delete_image": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "delete_image":"rule:default" has been deprecated since W in favor
# of "delete_image":"role:admin or (role:member and
# of "delete_image":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Get specified image
# GET /v2/images/{image_id}
# Intended scope(s): project
#"get_image": "role:admin or (role:reader and (project_id:%(project_id)s or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))"
#"get_image": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))"
# DEPRECATED
# "get_image":"rule:default" has been deprecated since W in favor of
# "get_image":"role:admin or (role:reader and
# "get_image":"rule:context_is_admin or (role:reader and
# (project_id:%(project_id)s or project_id:%(member_id)s or
# 'community':%(visibility)s or 'public':%(visibility)s or
# 'shared':%(visibility)s))".
@ -53,49 +53,49 @@
# Get all available images
# GET /v2/images
# Intended scope(s): project
#"get_images": "role:admin or (role:reader and project_id:%(project_id)s)"
#"get_images": "rule:context_is_admin or (role:reader and project_id:%(project_id)s)"
# DEPRECATED
# "get_images":"rule:default" has been deprecated since W in favor of
# "get_images":"role:admin or (role:reader and
# "get_images":"rule:context_is_admin or (role:reader and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Updates given image
# PATCH /v2/images/{image_id}
# Intended scope(s): project
#"modify_image": "role:admin or (role:member and project_id:%(project_id)s)"
#"modify_image": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "modify_image":"rule:default" has been deprecated since W in favor
# of "modify_image":"role:admin or (role:member and
# of "modify_image":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Publicize given image
# PATCH /v2/images/{image_id}
# Intended scope(s): project
#"publicize_image": "role:admin"
#"publicize_image": "rule:context_is_admin"
# Communitize given image
# PATCH /v2/images/{image_id}
# Intended scope(s): project
#"communitize_image": "role:admin or (role:member and project_id:%(project_id)s)"
#"communitize_image": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "communitize_image":"rule:default" has been deprecated since W in
# favor of "communitize_image":"role:admin or (role:member and
# project_id:%(project_id)s)".
# favor of "communitize_image":"rule:context_is_admin or (role:member
# and project_id:%(project_id)s)".
# The image API now supports roles.
# Downloads given image
# GET /v2/images/{image_id}/file
# Intended scope(s): project
#"download_image": "role:admin or (role:member and (project_id:%(project_id)s or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))"
#"download_image": "rule:context_is_admin or (role:member and (project_id:%(project_id)s or project_id:%(member_id)s or 'community':%(visibility)s or 'public':%(visibility)s or 'shared':%(visibility)s))"
# DEPRECATED
# "download_image":"rule:default" has been deprecated since W in favor
# of "download_image":"role:admin or (role:member and
# of "download_image":"rule:context_is_admin or (role:member and
# (project_id:%(project_id)s or project_id:%(member_id)s or
# 'community':%(visibility)s or 'public':%(visibility)s or
# 'shared':%(visibility)s))".
@ -104,131 +104,131 @@
# Uploads data to specified image
# PUT /v2/images/{image_id}/file
# Intended scope(s): project
#"upload_image": "role:admin or (role:member and project_id:%(project_id)s)"
#"upload_image": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "upload_image":"rule:default" has been deprecated since W in favor
# of "upload_image":"role:admin or (role:member and
# of "upload_image":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Deletes the location of given image
# PATCH /v2/images/{image_id}
# Intended scope(s): project
#"delete_image_location": "role:admin"
#"delete_image_location": "rule:context_is_admin"
# DEPRECATED
# "delete_image_location":"rule:default" has been deprecated since W
# in favor of "delete_image_location":"role:admin".
# in favor of "delete_image_location":"rule:context_is_admin".
# The image API now supports roles.
# Reads the location of the image
# GET /v2/images/{image_id}
# Intended scope(s): project
#"get_image_location": "role:admin or (role:reader and project_id:%(project_id)s)"
#"get_image_location": "rule:context_is_admin or (role:reader and project_id:%(project_id)s)"
# DEPRECATED
# "get_image_location":"rule:default" has been deprecated since W in
# favor of "get_image_location":"role:admin or (role:reader and
# project_id:%(project_id)s)".
# favor of "get_image_location":"rule:context_is_admin or (role:reader
# and project_id:%(project_id)s)".
# The image API now supports roles.
# Sets location URI to given image
# PATCH /v2/images/{image_id}
# Intended scope(s): project
#"set_image_location": "role:admin or (role:member and project_id:%(project_id)s)"
#"set_image_location": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "set_image_location":"rule:default" has been deprecated since W in
# favor of "set_image_location":"role:admin or (role:member and
# project_id:%(project_id)s)".
# favor of "set_image_location":"rule:context_is_admin or (role:member
# and project_id:%(project_id)s)".
# The image API now supports roles.
# Create image member
# POST /v2/images/{image_id}/members
# Intended scope(s): project
#"add_member": "role:admin or (role:member and project_id:%(project_id)s)"
#"add_member": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "add_member":"rule:default" has been deprecated since W in favor of
# "add_member":"role:admin or (role:member and
# "add_member":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Delete image member
# DELETE /v2/images/{image_id}/members/{member_id}
# Intended scope(s): project
#"delete_member": "role:admin or (role:member and project_id:%(project_id)s)"
#"delete_member": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "delete_member":"rule:default" has been deprecated since W in favor
# of "delete_member":"role:admin or (role:member and
# of "delete_member":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Show image member details
# GET /v2/images/{image_id}/members/{member_id}
# Intended scope(s): project
#"get_member": "role:admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)"
#"get_member": "rule:context_is_admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)"
# DEPRECATED
# "get_member":"rule:default" has been deprecated since W in favor of
# "get_member":"role:admin or role:reader and
# "get_member":"rule:context_is_admin or role:reader and
# (project_id:%(project_id)s or project_id:%(member_id)s)".
# The image API now supports roles.
# List image members
# GET /v2/images/{image_id}/members
# Intended scope(s): project
#"get_members": "role:admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)"
#"get_members": "rule:context_is_admin or role:reader and (project_id:%(project_id)s or project_id:%(member_id)s)"
# DEPRECATED
# "get_members":"rule:default" has been deprecated since W in favor of
# "get_members":"role:admin or role:reader and
# "get_members":"rule:context_is_admin or role:reader and
# (project_id:%(project_id)s or project_id:%(member_id)s)".
# The image API now supports roles.
# Update image member
# PUT /v2/images/{image_id}/members/{member_id}
# Intended scope(s): project
#"modify_member": "role:admin or (role:member and project_id:%(member_id)s)"
#"modify_member": "rule:context_is_admin or (role:member and project_id:%(member_id)s)"
# DEPRECATED
# "modify_member":"rule:default" has been deprecated since W in favor
# of "modify_member":"role:admin or (role:member and
# of "modify_member":"rule:context_is_admin or (role:member and
# project_id:%(member_id)s)".
# The image API now supports roles.
# Manage image cache
# Intended scope(s): project
#"manage_image_cache": "role:admin"
#"manage_image_cache": "rule:context_is_admin"
# Deactivate image
# POST /v2/images/{image_id}/actions/deactivate
# Intended scope(s): project
#"deactivate": "role:admin or (role:member and project_id:%(project_id)s)"
#"deactivate": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "deactivate":"rule:default" has been deprecated since W in favor of
# "deactivate":"role:admin or (role:member and
# "deactivate":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Reactivate image
# POST /v2/images/{image_id}/actions/reactivate
# Intended scope(s): project
#"reactivate": "role:admin or (role:member and project_id:%(project_id)s)"
#"reactivate": "rule:context_is_admin or (role:member and project_id:%(project_id)s)"
# DEPRECATED
# "reactivate":"rule:default" has been deprecated since W in favor of
# "reactivate":"role:admin or (role:member and
# "reactivate":"rule:context_is_admin or (role:member and
# project_id:%(project_id)s)".
# The image API now supports roles.
# Copy existing image to other stores
# POST /v2/images/{image_id}/import
# Intended scope(s): project
#"copy_image": "role:admin"
#"copy_image": "rule:context_is_admin"
# Get an image task.
#
@ -313,33 +313,33 @@
# POST /v2/tasks
# DELETE /v2/tasks/{task_id}
# Intended scope(s): project
#"tasks_api_access": "role:admin"
#"tasks_api_access": "rule:context_is_admin"
#"metadef_default": ""
#"metadef_admin": "role:admin"
#"metadef_admin": "rule:context_is_admin"
# Get a specific namespace.
# GET /v2/metadefs/namespaces/{namespace_name}
# Intended scope(s): project
#"get_metadef_namespace": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_namespace": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_namespace":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_namespace":"role:admin or
# (role:reader and (project_id:%(project_id)s or
# since X in favor of "get_metadef_namespace":"rule:context_is_admin
# or (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# List namespace.
# GET /v2/metadefs/namespaces
# Intended scope(s): project
#"get_metadef_namespaces": "role:admin or (role:reader and project_id:%(project_id)s)"
#"get_metadef_namespaces": "rule:context_is_admin or (role:reader and project_id:%(project_id)s)"
# DEPRECATED
# "get_metadef_namespaces":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_namespaces":"role:admin or
# (role:reader and project_id:%(project_id)s)".
# since X in favor of "get_metadef_namespaces":"rule:context_is_admin
# or (role:reader and project_id:%(project_id)s)".
# The metadata API now supports project scope and default roles.
# Modify an existing namespace.
@ -360,22 +360,23 @@
# Get a specific object from a namespace.
# GET /v2/metadefs/namespaces/{namespace_name}/objects/{object_name}
# Intended scope(s): project
#"get_metadef_object": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_object": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_object":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_object":"role:admin or (role:reader
# and (project_id:%(project_id)s or 'public':%(visibility)s))".
# since X in favor of "get_metadef_object":"rule:context_is_admin or
# (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# Get objects from a namespace.
# GET /v2/metadefs/namespaces/{namespace_name}/objects
# Intended scope(s): project
#"get_metadef_objects": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_objects": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_objects":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_objects":"role:admin or
# since X in favor of "get_metadef_objects":"rule:context_is_admin or
# (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
@ -398,25 +399,25 @@
# List meta definition resource types.
# GET /v2/metadefs/resource_types
# Intended scope(s): project
#"list_metadef_resource_types": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"list_metadef_resource_types": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "list_metadef_resource_types":"rule:metadef_default" has been
# deprecated since X in favor of
# "list_metadef_resource_types":"role:admin or (role:reader and
# (project_id:%(project_id)s or 'public':%(visibility)s))".
# "list_metadef_resource_types":"rule:context_is_admin or (role:reader
# and (project_id:%(project_id)s or 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# Get meta definition resource types associations.
# GET /v2/metadefs/namespaces/{namespace_name}/resource_types
# Intended scope(s): project
#"get_metadef_resource_type": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_resource_type": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_resource_type":"rule:metadef_default" has been
# deprecated since X in favor of
# "get_metadef_resource_type":"role:admin or (role:reader and
# (project_id:%(project_id)s or 'public':%(visibility)s))".
# "get_metadef_resource_type":"rule:context_is_admin or (role:reader
# and (project_id:%(project_id)s or 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# Create meta definition resource types association.
@ -432,11 +433,11 @@
# Get a specific meta definition property.
# GET /v2/metadefs/namespaces/{namespace_name}/properties/{property_name}
# Intended scope(s): project
#"get_metadef_property": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_property": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_property":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_property":"role:admin or
# since X in favor of "get_metadef_property":"rule:context_is_admin or
# (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
@ -444,12 +445,12 @@
# List meta definition properties.
# GET /v2/metadefs/namespaces/{namespace_name}/properties
# Intended scope(s): project
#"get_metadef_properties": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_properties": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_properties":"rule:metadef_default" has been deprecated
# since X in favor of "get_metadef_properties":"role:admin or
# (role:reader and (project_id:%(project_id)s or
# since X in favor of "get_metadef_properties":"rule:context_is_admin
# or (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
@ -471,23 +472,24 @@
# Get tag definition.
# GET /v2/metadefs/namespaces/{namespace_name}/tags/{tag_name}
# Intended scope(s): project
#"get_metadef_tag": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_tag": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_tag":"rule:metadef_default" has been deprecated since X
# in favor of "get_metadef_tag":"role:admin or (role:reader and
# (project_id:%(project_id)s or 'public':%(visibility)s))".
# in favor of "get_metadef_tag":"rule:context_is_admin or (role:reader
# and (project_id:%(project_id)s or 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# List tag definitions.
# GET /v2/metadefs/namespaces/{namespace_name}/tags
# Intended scope(s): project
#"get_metadef_tags": "role:admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
#"get_metadef_tags": "rule:context_is_admin or (role:reader and (project_id:%(project_id)s or 'public':%(visibility)s))"
# DEPRECATED
# "get_metadef_tags":"rule:metadef_default" has been deprecated since
# X in favor of "get_metadef_tags":"role:admin or (role:reader and
# (project_id:%(project_id)s or 'public':%(visibility)s))".
# X in favor of "get_metadef_tags":"rule:context_is_admin or
# (role:reader and (project_id:%(project_id)s or
# 'public':%(visibility)s))".
# The metadata API now supports project scope and default roles.
# Update tag definition.
@ -518,36 +520,36 @@
# Queue image for caching
# PUT /v2/cache/{image_id}
# Intended scope(s): project
#"cache_image": "role:admin"
#"cache_image": "rule:context_is_admin"
# DEPRECATED
# "cache_image":"rule:manage_image_cache" has been deprecated since X
# in favor of "cache_image":"role:admin".
# in favor of "cache_image":"rule:context_is_admin".
# The image API now supports roles.
# List cache status
# GET /v2/cache
# Intended scope(s): project
#"cache_list": "role:admin"
#"cache_list": "rule:context_is_admin"
# DEPRECATED
# "cache_list":"rule:manage_image_cache" has been deprecated since X
# in favor of "cache_list":"role:admin".
# in favor of "cache_list":"rule:context_is_admin".
# The image API now supports roles.
# Delete image(s) from cache and/or queue
# DELETE /v2/cache
# DELETE /v2/cache/{image_id}
# Intended scope(s): project
#"cache_delete": "role:admin"
#"cache_delete": "rule:context_is_admin"
# DEPRECATED
# "cache_delete":"rule:manage_image_cache" has been deprecated since X
# in favor of "cache_delete":"role:admin".
# in favor of "cache_delete":"rule:context_is_admin".
# The image API now supports roles.
# Expose store specific information
# GET /v2/info/stores/detail
# Intended scope(s): project
#"stores_info_detail": "role:admin"
#"stores_info_detail": "rule:context_is_admin"

@ -265,14 +265,51 @@
# List availability zones
# GET /availability_zones
# Intended scope(s): project
#"get_availability_zone": "rule:admin_only"
#"get_availability_zone": "role:reader"
# DEPRECATED
# "get_availability_zone":"rule:regular_user" has been deprecated
# since W in favor of "get_availability_zone":"rule:admin_only".
# since W in favor of "get_availability_zone":"role:reader".
# The Availability Zone API now supports project scope and default
# roles.
# Create a templated of the security group rule
# POST /default-security-group-rules
# Intended scope(s): project
#"create_default_security_group_rule": "rule:admin_only"
# DEPRECATED
# "create_default_security_group_rule":"rule:admin_only" has been
# deprecated since 2023.2 in favor of
# "create_default_security_group_rule":"rule:admin_only".
# The default security group rules API supports system scope and
# default roles.
# Get a templated of the security group rule
# GET /default-security-group-rules
# GET /default-security-group-rules/{id}
# Intended scope(s): project
#"get_default_security_group_rule": "role:reader"
# DEPRECATED
# "get_default_security_group_rule":"rule:regular_user" has been
# deprecated since 2023.2 in favor of
# "get_default_security_group_rule":"role:reader".
# The default security group rules API supports system scope and
# default roles.
# Delete a templated of the security group rule
# DELETE /default-security-group-rules/{id}
# Intended scope(s): project
#"delete_default_security_group_rule": "rule:admin_only"
# DEPRECATED
# "delete_default_security_group_rule":"rule:admin_only" has been
# deprecated since 2023.2 in favor of
# "delete_default_security_group_rule":"rule:admin_only".
# The default security group rules API supports system scope and
# default roles.
# Create a flavor
# POST /flavors
# Intended scope(s): project
@ -460,14 +497,13 @@
# Create a floating IP port forwarding
# POST /floatingips/{floatingip_id}/port_forwardings
# Intended scope(s): project
#"create_floatingip_port_forwarding": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner"
#"create_floatingip_port_forwarding": "(rule:admin_only) or (role:member and rule:ext_parent_owner)"
# DEPRECATED
# "create_floatingip_port_forwarding":"rule:admin_or_ext_parent_owner"
# has been deprecated since W in favor of
# "create_floatingip_port_forwarding":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or
# rule:ext_parent_owner".
# (role:member and rule:ext_parent_owner)".
# The floating IP port forwarding API now supports system scope and
# default roles.
@ -475,41 +511,39 @@
# GET /floatingips/{floatingip_id}/port_forwardings
# GET /floatingips/{floatingip_id}/port_forwardings/{port_forwarding_id}
# Intended scope(s): project
#"get_floatingip_port_forwarding": "(rule:admin_only) or (role:reader and project_id:%(project_id)s) or rule:ext_parent_owner"
#"get_floatingip_port_forwarding": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_floatingip_port_forwarding":"rule:admin_or_ext_parent_owner"
# has been deprecated since W in favor of
# "get_floatingip_port_forwarding":"(rule:admin_only) or (role:reader
# and project_id:%(project_id)s) or rule:ext_parent_owner".
# and rule:ext_parent_owner)".
# The floating IP port forwarding API now supports system scope and
# default roles.
# Update a floating IP port forwarding
# PUT /floatingips/{floatingip_id}/port_forwardings/{port_forwarding_id}
# Intended scope(s): project
#"update_floatingip_port_forwarding": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner"
#"update_floatingip_port_forwarding": "(rule:admin_only) or (role:member and rule:ext_parent_owner)"
# DEPRECATED
# "update_floatingip_port_forwarding":"rule:admin_or_ext_parent_owner"
# has been deprecated since W in favor of
# "update_floatingip_port_forwarding":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or
# rule:ext_parent_owner".
# (role:member and rule:ext_parent_owner)".
# The floating IP port forwarding API now supports system scope and
# default roles.
# Delete a floating IP port forwarding
# DELETE /floatingips/{floatingip_id}/port_forwardings/{port_forwarding_id}
# Intended scope(s): project
#"delete_floatingip_port_forwarding": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:ext_parent_owner"
#"delete_floatingip_port_forwarding": "(rule:admin_only) or (role:member and rule:ext_parent_owner)"
# DEPRECATED
# "delete_floatingip_port_forwarding":"rule:admin_or_ext_parent_owner"
# has been deprecated since W in favor of
# "delete_floatingip_port_forwarding":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or
# rule:ext_parent_owner".
# (role:member and rule:ext_parent_owner)".
# The floating IP port forwarding API now supports system scope and
# default roles.
@ -1139,6 +1173,26 @@
# The network segment range API now supports project scope and default
# roles.
# Get port binding information
# GET /ports/{port_id}/bindings/
# Intended scope(s): project
#"get_port_binding": "rule:admin_only"
# Create port binding on the host
# POST /ports/{port_id}/bindings/
# Intended scope(s): project
#"create_port_binding": "rule:admin_only"
# Delete port binding on the host
# DELETE /ports/{port_id}/bindings/
# Intended scope(s): project
#"delete_port_binding": "rule:admin_only"
# Activate port binding on the host
# PUT /ports/{port_id}/bindings/{host}
# Intended scope(s): project
#"activate": "rule:admin_only"
# Definition of port with network device_owner
#"network_device": "field:port:device_owner=~^network:"
@ -1159,75 +1213,77 @@
# Specify ``device_owner`` attribute when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:device_owner": "not rule:network_device or rule:admin_only or rule:context_is_advsvc or rule:network_owner"
#"create_port:device_owner": "not rule:network_device or rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:device_owner":"not rule:network_device or
# rule:context_is_advsvc or rule:admin_or_network_owner" has been
# deprecated since W in favor of "create_port:device_owner":"not
# rule:network_device or rule:admin_only or rule:context_is_advsvc or
# rule:network_owner".
# rule:network_device or rule:context_is_advsvc or (rule:admin_only)
# or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``mac_address`` attribute when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:mac_address": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"create_port:mac_address": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:mac_address":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "create_port:mac_address":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# (rule:admin_only) or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``fixed_ips`` information when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:fixed_ips": "rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared"
#"create_port:fixed_ips": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner) or rule:shared"
# DEPRECATED
# "create_port:fixed_ips":"rule:context_is_advsvc or
# rule:admin_or_network_owner or rule:shared" has been deprecated
# since W in favor of "create_port:fixed_ips":"rule:context_is_advsvc
# or rule:network_owner or rule:admin_only or rule:shared".
# or (rule:admin_only) or (role:member and rule:network_owner) or
# rule:shared".
# The port API now supports project scope and default roles.
# Specify IP address in ``fixed_ips`` when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:fixed_ips:ip_address": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"create_port:fixed_ips:ip_address": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:fixed_ips:ip_address":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "create_port:fixed_ips:ip_address":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# (rule:admin_only) or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify subnet ID in ``fixed_ips`` when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:fixed_ips:subnet_id": "rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared"
#"create_port:fixed_ips:subnet_id": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner) or rule:shared"
# DEPRECATED
# "create_port:fixed_ips:subnet_id":"rule:context_is_advsvc or
# rule:admin_or_network_owner or rule:shared" has been deprecated
# since W in favor of
# "create_port:fixed_ips:subnet_id":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only or rule:shared".
# (rule:admin_only) or (role:member and rule:network_owner) or
# rule:shared".
# The port API now supports project scope and default roles.
# Specify ``port_security_enabled`` attribute when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:port_security_enabled": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"create_port:port_security_enabled": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:port_security_enabled":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "create_port:port_security_enabled":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# (rule:admin_only) or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``binding:host_id`` attribute when creating a port
@ -1265,52 +1321,58 @@
# Specify ``allowed_address_pairs`` attribute when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:allowed_address_pairs": "rule:admin_only or rule:network_owner"
#"create_port:allowed_address_pairs": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:allowed_address_pairs":"rule:admin_or_network_owner"
# has been deprecated since W in favor of
# "create_port:allowed_address_pairs":"rule:admin_only or
# rule:network_owner".
# "create_port:allowed_address_pairs":"(rule:admin_only) or
# (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``mac_address` of `allowed_address_pairs`` attribute when
# creating a port
# POST /ports
# Intended scope(s): project
#"create_port:allowed_address_pairs:mac_address": "rule:admin_only or rule:network_owner"
#"create_port:allowed_address_pairs:mac_address": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:allowed_address_pairs:mac_address":"rule:admin_or_netwo
# rk_owner" has been deprecated since W in favor of
# "create_port:allowed_address_pairs:mac_address":"rule:admin_only or
# rule:network_owner".
# "create_port:allowed_address_pairs:mac_address":"(rule:admin_only)
# or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``ip_address`` of ``allowed_address_pairs`` attribute when
# creating a port
# POST /ports
# Intended scope(s): project
#"create_port:allowed_address_pairs:ip_address": "rule:admin_only or rule:network_owner"
#"create_port:allowed_address_pairs:ip_address": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_port:allowed_address_pairs:ip_address":"rule:admin_or_networ
# k_owner" has been deprecated since W in favor of
# "create_port:allowed_address_pairs:ip_address":"rule:admin_only or
# rule:network_owner".
# "create_port:allowed_address_pairs:ip_address":"(rule:admin_only) or
# (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify ``hints`` attribute when creating a port
# POST /ports
# Intended scope(s): project
#"create_port:hints": "rule:admin_only"
# Get a port
# GET /ports
# GET /ports/{id}
# Intended scope(s): project
#"get_port": "rule:admin_only or rule:context_is_advsvc or role:reader and project_id:%(project_id)s"
#"get_port": "rule:context_is_advsvc or (rule:admin_only) or (role:reader and rule:network_owner) or role:reader and project_id:%(project_id)s"
# DEPRECATED
# "get_port":"rule:context_is_advsvc or
# rule:admin_owner_or_network_owner" has been deprecated since W in
# favor of "get_port":"rule:admin_only or rule:context_is_advsvc or
# role:reader and project_id:%(project_id)s".
# favor of "get_port":"rule:context_is_advsvc or (rule:admin_only) or
# (role:reader and rule:network_owner) or role:reader and
# project_id:%(project_id)s".
# The port API now supports project scope and default roles.
# Get ``binding:vif_type`` attribute of a port
@ -1369,6 +1431,12 @@
# since W in favor of "get_port:resource_request":"rule:admin_only".
# The port API now supports project scope and default roles.
# Get ``hints`` attribute of a port
# GET /ports
# GET /ports/{id}
# Intended scope(s): project
#"get_port:hints": "rule:admin_only"
# Update a port
# PUT /ports/{id}
# Intended scope(s): project
@ -1384,14 +1452,14 @@
# Update ``device_owner`` attribute of a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:device_owner": "not rule:network_device or rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"update_port:device_owner": "not rule:network_device or rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:device_owner":"not rule:network_device or
# rule:context_is_advsvc or rule:admin_or_network_owner" has been
# deprecated since W in favor of "update_port:device_owner":"not
# rule:network_device or rule:context_is_advsvc or rule:network_owner
# or rule:admin_only".
# rule:network_device or rule:context_is_advsvc or (rule:admin_only)
# or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Update ``mac_address`` attribute of a port
@ -1409,50 +1477,51 @@
# Specify ``fixed_ips`` information when updating a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:fixed_ips": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"update_port:fixed_ips": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:fixed_ips":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "update_port:fixed_ips":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# "update_port:fixed_ips":"rule:context_is_advsvc or (rule:admin_only)
# or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify IP address in ``fixed_ips`` information when updating a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:fixed_ips:ip_address": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"update_port:fixed_ips:ip_address": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:fixed_ips:ip_address":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "update_port:fixed_ips:ip_address":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# (rule:admin_only) or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Specify subnet ID in ``fixed_ips`` information when updating a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:fixed_ips:subnet_id": "rule:context_is_advsvc or rule:network_owner or rule:admin_only or rule:shared"
#"update_port:fixed_ips:subnet_id": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner) or rule:shared"
# DEPRECATED
# "update_port:fixed_ips:subnet_id":"rule:context_is_advsvc or
# rule:admin_or_network_owner or rule:shared" has been deprecated
# since W in favor of
# "update_port:fixed_ips:subnet_id":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only or rule:shared".
# (rule:admin_only) or (role:member and rule:network_owner) or
# rule:shared".
# The port API now supports project scope and default roles.
# Update ``port_security_enabled`` attribute of a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:port_security_enabled": "rule:context_is_advsvc or rule:network_owner or rule:admin_only"
#"update_port:port_security_enabled": "rule:context_is_advsvc or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:port_security_enabled":"rule:context_is_advsvc or
# rule:admin_or_network_owner" has been deprecated since W in favor of
# "update_port:port_security_enabled":"rule:context_is_advsvc or
# rule:network_owner or rule:admin_only".
# (rule:admin_only) or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Update ``binding:host_id`` attribute of a port
@ -1490,39 +1559,39 @@
# Update ``allowed_address_pairs`` attribute of a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:allowed_address_pairs": "rule:admin_only or rule:network_owner"
#"update_port:allowed_address_pairs": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:allowed_address_pairs":"rule:admin_or_network_owner"
# has been deprecated since W in favor of
# "update_port:allowed_address_pairs":"rule:admin_only or
# rule:network_owner".
# "update_port:allowed_address_pairs":"(rule:admin_only) or
# (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Update ``mac_address`` of ``allowed_address_pairs`` attribute of a
# port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:allowed_address_pairs:mac_address": "rule:admin_only or rule:network_owner"
#"update_port:allowed_address_pairs:mac_address": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:allowed_address_pairs:mac_address":"rule:admin_or_netwo
# rk_owner" has been deprecated since W in favor of
# "update_port:allowed_address_pairs:mac_address":"rule:admin_only or
# rule:network_owner".
# "update_port:allowed_address_pairs:mac_address":"(rule:admin_only)
# or (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Update ``ip_address`` of ``allowed_address_pairs`` attribute of a
# port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:allowed_address_pairs:ip_address": "rule:admin_only or rule:network_owner"
#"update_port:allowed_address_pairs:ip_address": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_port:allowed_address_pairs:ip_address":"rule:admin_or_networ
# k_owner" has been deprecated since W in favor of
# "update_port:allowed_address_pairs:ip_address":"rule:admin_only or
# rule:network_owner".
# "update_port:allowed_address_pairs:ip_address":"(rule:admin_only) or
# (role:member and rule:network_owner)".
# The port API now supports project scope and default roles.
# Update ``data_plane_status`` attribute of a port
@ -1537,16 +1606,22 @@
# role:data_plane_integrator".
# The port API now supports project scope and default roles.
# Update ``hints`` attribute of a port
# PUT /ports/{id}
# Intended scope(s): project
#"update_port:hints": "rule:admin_only"
# Delete a port
# DELETE /ports/{id}
# Intended scope(s): project
#"delete_port": "rule:admin_only or rule:context_is_advsvc or role:member and project_id:%(project_id)s or rule:network_owner"
#"delete_port": "rule:context_is_advsvc or role:member and project_id:%(project_id)s or (rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "delete_port":"rule:context_is_advsvc or
# rule:admin_owner_or_network_owner" has been deprecated since W in
# favor of "delete_port":"rule:admin_only or rule:context_is_advsvc or
# role:member and project_id:%(project_id)s or rule:network_owner".
# favor of "delete_port":"rule:context_is_advsvc or role:member and
# project_id:%(project_id)s or (rule:admin_only) or (role:member and
# rule:network_owner)".
# The port API now supports project scope and default roles.
# Rule of shared qos policy
@ -1598,24 +1673,24 @@
# GET /qos/rule-types
# GET /qos/rule-types/{rule_type}
# Intended scope(s): project
#"get_rule_type": "rule:admin_only"
#"get_rule_type": "role:reader"
# DEPRECATED
# "get_rule_type":"rule:regular_user" has been deprecated since W in
# favor of "get_rule_type":"rule:admin_only".
# favor of "get_rule_type":"role:reader".
# The QoS API now supports project scope and default roles.
# Get a QoS bandwidth limit rule
# GET /qos/policies/{policy_id}/bandwidth_limit_rules
# GET /qos/policies/{policy_id}/bandwidth_limit_rules/{rule_id}
# Intended scope(s): project
#"get_policy_bandwidth_limit_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_policy_bandwidth_limit_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_policy_bandwidth_limit_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_policy_bandwidth_limit_rule":"(rule:admin_only) or (role:reader
# and project_id:%(project_id)s)".
# and rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Create a QoS bandwidth limit rule
@ -1655,7 +1730,7 @@
# GET /qos/policies/{policy_id}/packet_rate_limit_rules
# GET /qos/policies/{policy_id}/packet_rate_limit_rules/{rule_id}
# Intended scope(s): project
#"get_policy_packet_rate_limit_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_policy_packet_rate_limit_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# Create a QoS packet rate limit rule
# POST /qos/policies/{policy_id}/packet_rate_limit_rules
@ -1676,13 +1751,13 @@
# GET /qos/policies/{policy_id}/dscp_marking_rules
# GET /qos/policies/{policy_id}/dscp_marking_rules/{rule_id}
# Intended scope(s): project
#"get_policy_dscp_marking_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_policy_dscp_marking_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_policy_dscp_marking_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_policy_dscp_marking_rule":"(rule:admin_only) or (role:reader
# and project_id:%(project_id)s)".
# and rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Create a QoS DSCP marking rule
@ -1722,13 +1797,13 @@
# GET /qos/policies/{policy_id}/minimum_bandwidth_rules
# GET /qos/policies/{policy_id}/minimum_bandwidth_rules/{rule_id}
# Intended scope(s): project
#"get_policy_minimum_bandwidth_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_policy_minimum_bandwidth_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_policy_minimum_bandwidth_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_policy_minimum_bandwidth_rule":"(rule:admin_only) or
# (role:reader and project_id:%(project_id)s)".
# (role:reader and rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Create a QoS minimum bandwidth rule
@ -1768,7 +1843,7 @@
# GET /qos/policies/{policy_id}/minimum_packet_rate_rules
# GET /qos/policies/{policy_id}/minimum_packet_rate_rules/{rule_id}
# Intended scope(s): project
#"get_policy_minimum_packet_rate_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_policy_minimum_packet_rate_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# Create a QoS minimum packet rate rule
# POST /qos/policies/{policy_id}/minimum_packet_rate_rules
@ -1788,13 +1863,13 @@
# Get a QoS bandwidth limit rule through alias
# GET /qos/alias_bandwidth_limit_rules/{rule_id}/
# Intended scope(s): project
#"get_alias_bandwidth_limit_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_alias_bandwidth_limit_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_alias_bandwidth_limit_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_alias_bandwidth_limit_rule":"(rule:admin_only) or (role:reader
# and project_id:%(project_id)s)".
# and rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Update a QoS bandwidth limit rule through alias
@ -1822,13 +1897,13 @@
# Get a QoS DSCP marking rule through alias
# GET /qos/alias_dscp_marking_rules/{rule_id}/
# Intended scope(s): project
#"get_alias_dscp_marking_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_alias_dscp_marking_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_alias_dscp_marking_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_alias_dscp_marking_rule":"(rule:admin_only) or (role:reader and
# project_id:%(project_id)s)".
# rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Update a QoS DSCP marking rule through alias
@ -1856,13 +1931,13 @@
# Get a QoS minimum bandwidth rule through alias
# GET /qos/alias_minimum_bandwidth_rules/{rule_id}/
# Intended scope(s): project
#"get_alias_minimum_bandwidth_rule": "(rule:admin_only) or (role:reader and project_id:%(project_id)s)"
#"get_alias_minimum_bandwidth_rule": "(rule:admin_only) or (role:reader and rule:ext_parent_owner)"
# DEPRECATED
# "get_alias_minimum_bandwidth_rule":"rule:regular_user" has been
# deprecated since W in favor of
# "get_alias_minimum_bandwidth_rule":"(rule:admin_only) or
# (role:reader and project_id:%(project_id)s)".
# (role:reader and rule:ext_parent_owner)".
# The QoS API now supports project scope and default roles.
# Update a QoS minimum bandwidth rule through alias
@ -2087,6 +2162,18 @@
# al_gateway_info:external_fixed_ips":"rule:admin_only".
# The router API now supports system scope and default roles.
# Specify ``enable_default_route_bfd`` attribute when creating a
# router
# POST /routers
# Intended scope(s): project
#"create_router:enable_default_route_bfd": "rule:admin_only"
# Specify ``enable_default_route_ecmp`` attribute when creating a
# router
# POST /routers
# Intended scope(s): project
#"create_router:enable_default_route_ecmp": "rule:admin_only"
# Get a router
# GET /routers
# GET /routers/{id}
@ -2201,6 +2288,18 @@
# al_gateway_info:external_fixed_ips":"rule:admin_only".
# The router API now supports system scope and default roles.
# Specify ``enable_default_route_bfd`` attribute when updating a
# router
# POST /routers
# Intended scope(s): project
#"update_router:enable_default_route_bfd": "rule:admin_only"
# Specify ``enable_default_route_ecmp`` attribute when updating a
# router
# POST /routers
# Intended scope(s): project
#"update_router:enable_default_route_ecmp": "rule:admin_only"
# Delete a router
# DELETE /routers/{id}
# Intended scope(s): project
@ -2402,12 +2501,12 @@
# Create a subnet
# POST /subnets
# Intended scope(s): project
#"create_subnet": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner"
#"create_subnet": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "create_subnet":"rule:admin_or_network_owner" has been deprecated
# since W in favor of "create_subnet":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or rule:network_owner".
# (role:member and rule:network_owner)".
# The subnet API now supports system scope and default roles.
# Specify ``segment_id`` attribute when creating a subnet
@ -2456,12 +2555,12 @@
# Update a subnet
# PUT /subnets/{id}
# Intended scope(s): project
#"update_subnet": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner"
#"update_subnet": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "update_subnet":"rule:admin_or_network_owner" has been deprecated
# since W in favor of "update_subnet":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or rule:network_owner".
# (role:member and rule:network_owner)".
# The subnet API now supports system scope and default roles.
# Update ``segment_id`` attribute of a subnet
@ -2487,12 +2586,12 @@
# Delete a subnet
# DELETE /subnets/{id}
# Intended scope(s): project
#"delete_subnet": "(rule:admin_only) or (role:member and project_id:%(project_id)s) or rule:network_owner"
#"delete_subnet": "(rule:admin_only) or (role:member and rule:network_owner)"
# DEPRECATED
# "delete_subnet":"rule:admin_or_network_owner" has been deprecated
# since W in favor of "delete_subnet":"(rule:admin_only) or
# (role:member and project_id:%(project_id)s) or rule:network_owner".
# (role:member and rule:network_owner)".
# The subnet API now supports system scope and default roles.
# Definition of a shared subnetpool

@ -1169,11 +1169,16 @@
# Intended scope(s): project
#"os_compute_api:os-lock-server:unlock:unlock_override": "rule:context_is_admin"
# Cold migrate a server to a host
# Cold migrate a server without specifying a host
# POST /servers/{server_id}/action (migrate)
# Intended scope(s): project
#"os_compute_api:os-migrate-server:migrate": "rule:context_is_admin"
# Cold migrate a server to a specified host
# POST /servers/{server_id}/action (migrate)
# Intended scope(s): project
#"os_compute_api:os-migrate-server:migrate:host": "rule:context_is_admin"
# Live migrate a server to a new host without a reboot
# POST /servers/{server_id}/action (os-migrateLive)
# Intended scope(s): project