<div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr">Thanks for looping keystone into this, Ben.<div><br></div><div>This sounds very similar, and related, to the default roles work keystone implemented in Rocky [0]. TL;DR, keystone ensures the ``member`` and ``reader`` roles are available during ``keystone-manage bootstrap``, which is typically done during installation and sometimes on upgrade. Pre-Rocky, only the ``admin`` role existed in keystone.</div><div><br></div><div>The idea is to make it easier for other services, like cinder, to rely on these roles by default. As opposed to cinder changing a policy default to something like ``role:reader`` and another service using something like ``role:auditor``, but they both mean the same thing. We want to avoid the case where operators would need to make sure both roles exist in keystone and users have both if they're expected to perform read-only operations from each service.</div><div><br></div><div>The work keystone did in Rocky made it possible for cinder to start making those assumptions about the existence of roles called ``member`` and ``reader``.</div><div><br></div><div>As far as testing goes, I remember there being a cinder session in Denver about policy changes, regression, and making sure we can protect against it happening, especially late in the release. Ideally, it would be fantastic to have protection tests in each service that assert the default policies work as expected for protecting APIs. Unfortunately, testing this in its entirety makes it an integration test that requires keystone. Luckily, there are some ways for services to expand protection testing without having that dependency, which falls within the parameters of unit tests. I proposed a couple of changes to cinder that show how to do this [1], and it requires modeling an API request similar to what keystonemiddleware/oslo.context do and ensuring the actual defaults are tested by removing overridden test policies [2] that leave APIs unprotected. We attempted to document a generalized approach to this sort of testing in oslo.policy [3].</div><div><br></div><div>[0] <a href="http://specs.openstack.org/openstack/keystone-specs/specs/keystone/rocky/define-default-roles.html">http://specs.openstack.org/openstack/keystone-specs/specs/keystone/rocky/define-default-roles.html</a></div><div>[1] <a href="https://review.openstack.org/#/c/602489/">https://review.openstack.org/#/c/602489/</a></div><div>[2] <a href="https://review.openstack.org/#/c/609498/">https://review.openstack.org/#/c/609498/</a></div><div>[3] <a href="https://docs.openstack.org/oslo.policy/latest/user/usage.html#testing-default-policies">https://docs.openstack.org/oslo.policy/latest/user/usage.html#testing-default-policies</a></div></div></div></div></div></div><br><div class="gmail_quote"><div dir="ltr">On Thu, Dec 13, 2018 at 8:10 AM Ben Nemec <<a href="mailto:openstack@nemebean.com">openstack@nemebean.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">cc Keystone. It would be interesting to know how this fits in with the <br>
new default roles work.<br>
<br>
On 12/12/18 8:21 PM, Brian Rosmaita wrote:<br>
> At last week's cinder meeting (5 December) we had a discussion about<br>
> policy checks at the database layer. While these checks seem to make it<br>
> difficult to perform some policy configurations, there are too many of<br>
> them to simply remove them without impacting stability given our current<br>
> test coverage (at least that's my feeling). Additionally, it's possible<br>
> to handle the proposed use case (a read-only administrator) without<br>
> making any code changes. So we decided to fix this issue by documenting<br>
> how this could work.<br>
> <br>
> I've got a patch up for the documentation. I've flagged this email for<br>
> cinder people to read for accuracy, operators to read to make sure the<br>
> instructions are clear and detailed, and docs people to read for<br>
> felicity of expression. Please leave comments on the patch:<br>
> <br>
> <a href="https://review.openstack.org/#/c/624424/" rel="noreferrer" target="_blank">https://review.openstack.org/#/c/624424/</a><br>
> <br>
> cheers,<br>
> brian<br>
> <br>
<br>
</blockquote></div>