Red Hat did really good documentation on security (and policies) which can be easily used with kolla - thanks to that my policies now work: https://access.redhat.com/documentation/en-us/red_hat_openstack_platform/13/... <https://access.redhat.com/documentation/en-us/red_hat_openstack_platform/13/pdf/security_and_hardening_guide/Red_Hat_OpenStack_Platform-13-Security_and_Hardening_Guide-en-US.pdf> Best regards, Adam
Wiadomość napisana przez Mark Goddard <mark@stackhpc.com> w dniu 30.03.2021, o godz. 12:51:
On Tue, 30 Mar 2021 at 10:52, Adam Tomas <bkslash@poczta.onet.pl> wrote:
Hi, thank you for the answers, but I still have more questions :)
Without any custom policies when I look inside the horizon container I see (in /etc/openstack-dashboard) current/default policies. If I override (for example keystone_policy.json) with a file placed in /etc/kolla/config/horizon which contains only 3 rules, then after kolla-ansible reconfigure inside horizon container there is of course keystone_police.json file, but only with my 3 rules - should I assume, that previously seen default rules (other than the ones overridden by my rules) still works, whether I see them in the file or not?
I'd assume Horizon works in the same way as other services, and you only need to include changes. Please test and report back.
And another question - I need a rule, that will allow some „special” user (which I call project_admin) to see,create, update and delete users inside a project (but not elsewhere). How should the policy look like?
„project_admin_required”: „role:project_admin and default_project_id:%(target.project_id)s" „identity:list_user”: „rule: admin_required or project_admin_required” „identity:create_user”: „rule: admin_required or project_admin_required” „identity:update_user”: „rule: admin_required or project_admin_required” „identity:delete_user”: „rule: admin_required or project_admin_required”
As I mentioned before, admin is global in OpenStack for now. There may be various ways to achieve what you want. One is to introduce a role, and use it in the rules. It's a bit of a can of worms though, since there are many API endpoints which might need to be updated to catch all corner cases. I added keystone to the subject, in case anyone from that team wants to comment.
? Best regards, Adam
Wiadomość napisana przez Mark Goddard <mark@stackhpc.com> w dniu 30.03.2021, o godz. 11:05:
On Tue, 30 Mar 2021 at 09:24, Mark Goddard <mark@stackhpc.com> wrote:
On Mon, 29 Mar 2021 at 15:36, Adam Tomas <bkslash@poczta.onet.pl> wrote:
Hi,
Hi, Looks like we need some more/better docs on this in Kolla.
Proposed some docs improvements: https://review.opendev.org/c/openstack/kolla-ansible/+/783809
Im not quite clear about policy.yaml/json files in kolla-ansible. Let assume, that I need to allow one of project users to add other users to the project. So I create „project_admin” role and assign it to this user. Then I found /etc/kolla/keystone/policy.json.test file, which I use as template. There is rule „identity:create_credential” : „(role:admin and system_scope:all)” so I add „or role:project_admin” and put file in /etc/kolla/config/keystone/ and reconfigure kolla. And now few questions:
1. policy.json (or policy.yaml) always overwrite all default policies? I mean if I only add one rule to this file then other rules will „disappear” or will have default values? Is there any way to only overwrite some default rules and leave rest with defaults? Like with .conf files
For a few releases now, OpenStack supports policy in code. This means that you only need to include the rules you want to override in your JSON/YAML file.
2. what about Horizon and visibility of options? In mentioned case putting the same policy.json file in /etc/kolla/config/keystone/ and /etc/kolla/config/horizon/ should „unblock” Add User button for user with project_admin role? Or how to achieve it?
For keystone policy in horizon, you need to use:
/etc/kolla/config/horizon/keystone_policy.json
3. does Horizon need the duplicated policy.json files from other services in it’s configuration folder or is it enough to write policy.json for services I want to change?
Only the ones you want to change.
4. when I assign admin role to a user with projectID (openstack role add —project PROJECT_ID —user SOME_USER admin) this user sees in Horizon everything systemwide, not only inside this project… Which rules should be created to allow him to see only users and resources which belongs to this project?
Currently admin is generally global in OpenStack. It's a known limitation, and currently being worked on.
Best regards Adam