[all][tc][goals] Migrate RBAC Policy Format from JSON to YAML: Week R-16 Update
Thomas Goirand
zigo at debian.org
Tue Jan 19 23:25:46 UTC 2021
On 1/19/21 9:04 PM, Ben Nemec wrote:
> There was also a security concern with potentially having multiple
> policy files and it not being clear which was in use. If someone
> converted their JSON policy to YAML, but left the JSON one in place, it
> could result in oslo.policy using the wrong one (or not the one they
> expect). We decided it was better for each project to make a clean
> switchover, which allows for things like upgrade checks that oslo.policy
> couldn't have itself, than to try to handle it all in oslo.policy.
IMO, that's a downstream distro thing.
What I did in Debian (and for Victoria already) was having the postinst
of each package to rename any existing policy.json into a disabled
version. Here's an example with Cinder:
if [ -r /etc/cinder/policy.json ] ; then
mv /etc/cinder/policy.json /etc/cinder/disabled.policy.json.old
fi
and then package the yaml file as (example from Nova):
/etc/nova/policy.d/00_default_policy.yaml
and then setting-up this:
policy_dirs = /etc/nova/policy.d
The reason I'm doing this way, is that I'm expecting upstream to
generate a commented-only yaml file, and final users to drop non-default
supplementary files without touching the package default file.
So, someone upgrading to Victoria with a non-default policy.json will
see its manual tweaks go away, but not completely gone (ie: recoverable
from disabled.policy.json.old).
Does this seem to be a correct approach?
Cheers,
Thomas Goirand (zigo)
More information about the openstack-discuss
mailing list