Enhanced RBAC Policies

About this task

The standard OpenStack RBAC roles and policies can be enhanced by updating policy configuration in individual OpenStack Services’ Helm charts. StarlingX provides an optional set of updated policy configurations for Nova, Neutron, Glance, Cinder, Keystone and Horizon services that introduce two new roles (‘project_admin’ and ‘project_readonly’) and modify the capabilities of the default ‘member’ role. A high-level summary of the new roles’ capabilities and the modified ‘default’ role capabilities are in the following table; a detailed description is provided at end of page.

Note

All the overrides files should be applied, some of the rules in a policy from one service might depend on other services to work (e.g. Nova commands might depend on Glance/Cinder/Neutron permissions), and they should not be used separately.

Design

Roles

Permissions summary

Default Role:

member

Users with role ‘member’ may have a limited management of project resources

New Role to add:

project_admin

Users with role ‘project_admin’ can fully manage all resources of the project

New Role to add:

project_readonly

Users with role ‘project_readonly’ can only list and display details of resources of the project, and shared resources of other projects

Make sure you have access to the StarlingX OpenStack CLI and follow the instructions in this document.

Procedure

  1. Log into your active controller.

  2. Set up admin credentials for the containerized OpenStack application:

    $ source /etc/platform/openrc
    $ OS_AUTH_URL=http://keystone.openstack.svc.cluster.local/v3
    
  3. Transfer the enhanced policies yml files to the active controller:

    1. Download the openstack-armada repo from StarlingX in opendev (StarlingX OpenStack Armada App) to a remote workstation.

    2. Copy the contents of the ‘enhanced-policies’ folder from remote workstation to controller.

      $ cd /home/sysadmin
      $ scp -r <remote-workstation-with-download-of-openstack-armada-app-REPO>/enhanced-policies   openstack-enhanced-policies-0.1.0
      
  4. Create the custom roles:

    ~(keystone_admin)]$ openstack role list
    ~(keystone_admin)]$ openstack role create project_admin
    ~(keystone_admin)]$ openstack role create project_readonly
    
  5. In order to enable the extensions required for some of the neutron tests, include the following configuration to the neutron Helm override yml file:

    cat <<EOF >neutron-extensions.yml
    conf:
    neutron:
    
        DEFAULT:
            service_plugins:
            - router
            - network_segment_range
            - qos
            - segments
            - port_forwarding
            - trunk
    plugins:
        ml2_conf:
            ml2:
                extension_drivers:
                - port_security
                - qos
    openvswitch_agent:
        agent:
            extensions:
            - qos
            - port_forwarding
    EOF
    
    system helm-override-update --reuse-values --values=./neutron-extensions.yml stx-openstack neutron openstack
  6. Apply the policy overrides for each service to your cloud:

    $ source /etc/platform/openrc
    
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/keystone-policy-overrides.yml stx-openstack keystone openstack
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/cinder-policy-overrides.yml stx-openstack cinder openstack
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/nova-policy-overrides.yml stx-openstack nova openstack
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/neutron-policy-overrides.yml stx-openstack neutron openstack
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/glance-policy-overrides.yml stx-openstack glance openstack
    ~(keystone_admin)]$ system helm-override-update --reuse-values --values=/home/sysadmin/openstack-enhanced-policies-0.1.0/horizon-policy-overrides.yml stx-openstack horizon openstack
    
    ~(keystone_admin)]$ system application-apply stx-openstack
  7. Watch for application overrides to finish applying:

    $ watch system application-show stx-openstack

Running Tests

Please follow the instructions below to test the enhanced policies on your system. We assume that the new roles were created on your system and the overrides were successfully applied.

Procedure

  1. Change directory to the openstack-enhanced-policies-0.1.0 you transferred to your controller node:

    $ cd /home/sysadmin/openstack-enhanced-policies-0.1.0
    
  2. IMPORTANT: Create a venv and install the test dependencies:

    if [ ! -d .venv ]; then
    python3 -m venv .venv
    fi
    
    $ source .venv/bin/activate
    $ pip install --upgrade pip
    $ pip install -r test-requirements.txt
    
  3. Download CirrOS image (dependency for nova and cinder tests):

    $ wget http://download.cirros-cloud.net/0.3.4/cirros-0.3.4-x86_64-disk.img
    
  4. Execute the tests on StarlingX:

    $ source /etc/platform/openrc
    $ OS_AUTH_URL=http://keystone.openstack.svc.cluster.local/v3
    $ pytest tests/
    

To cleanup after testing

You can use the run-cleanup-all.sh script to remove any leftovers from the test on the environment:

$ source /etc/platform/openrc
$ OS_AUTH_URL=http://keystone.openstack.svc.cluster.local/v3
$ bash tests/run-cleanup-all.sh

Role Permission Details

Role Permissions

identity(keystone)

compute(nova)

networking(neutron)

image(glance)

volume(cinder)

member

All operations that legacy role ‘member’ can do

  • Can get list and detail of instances

  • Can create instance/Can open console of instance

  • Can access log of instance

  • Can manage keypairs of his/her own

  • Can only create/update/delete port

  • Can get list and detail of resources: subnetpool, address scope, networks, subnets, etc.

  • Can create and update image, upload image content

  • Can create volume

  • Can create volume from image

  • Can create volume snapshot

  • Can create volume-backup

project_admin

All operations that legacy role ‘member’ can do

All operations that legacy role ‘member’ can do

  • All operations that legacy role ‘member’ can do

  • Can create/update/delete ‘shared’ subnetpool

  • Can create/update/delete address scope

  • Can create/update/delete shared network

  • All operations that legacy role ‘member’ can do

  • Can publicize image

  • Can communitize image

  • All operations that legacy role ‘member’ can do

project_readonly

All operations that legacy role ‘member’ can do

  • Can only get list and detail of instances

  • Can manage key-pairs of his/her own

  • Can only get list and detail of resources: subnetpool, address scopes, networks, subnets,etc.

  • Can only get list and detail of images

  • Can only get list and detail of volumes, backups, snapshots