Additionally I realized that even if I did get it to work in CLI, my
dashboard/horizon still is not able to list the users or projects for the
admin user in the default domain, with the adminRole on both adminproject
and default domain.
TQ
2016-11-02 9:35 GMT+01:00 Taisto Qvist <taisto.qvist(a)gmail.com>:
I've found parts of the problem, but here is my policy.json
excerpt:
"cloud_admin": "role:admin and (token.is_admin_project:True or
domain_id:d8aaf957fa5d4ced85cf308d464e0020)",
"admin_and_matching_domain_id": "rule:admin_required and
domain_id:%(domain_id)s",
"identity:get_domain": "rule:cloud_admin or
rule:admin_and_matching_domain_id
or token.project.domain.id:%(target.domain.id)s",
"identity:list_projects": "rule:cloud_admin or
rule:admin_and_matching_
domain_id",
"identity:list_user_projects": "rule:owner or
rule:admin_and_matching_
domain_id",
"identity:list_users": "rule:cloud_admin or rule:admin_and_matching_
domain_id",
"identity:list_groups": "rule:cloud_admin or rule:admin_and_matching_
domain_id",
"identity:list_users_in_group": "rule:cloud_admin or
rule:admin_and_matching_target_group_domain_id",
The cause of problem was the keystonerc-file I was sourcing, but I cant
help wondering wether this error should be possible to avoid, and it seems
I am still not all the way home...This was my inital keystonerc_admin:
export OS_PROJECT_DOMAIN_NAME=Default
export OS_USER_DOMAIN_NAME=Default
export OS_PROJECT_NAME=admin
export OS_USERNAME=admin
export OS_PASSWORD=admin00
export OS_AUTH_URL=http://172.16.12.100:35357/v3
export OS_IDENTITY_API_VERSION=3
export OS_IMAGE_API_VERSION=2
I realized from ngrepping on the keystone api at :35357, that openstack
was asking for a project scoped token, (which I thought I needed since my
belief was that a domain-local admin should only have admin-role on a
project in the domain but that doesnt seem to be the case?), but reading
the policy rule made me realise that the "admin_required and domain_id:"
wanted a domain-scoped token.
So I ran "openstack user list --os-domain-name default", trying to get a
domain scoped token, with the admin role, since my default admin user in
the default domain, has the admin role on both default domain, and the
admin project in the default domain. (Which seems to be a requirement, even
for a local-domain admin)
However, because of (I assume) the OS_PROJECT_NAME env, the token is
created with a:
{"auth": {"scope": {"project": {"domain":
{"name": "Default"}, "name":
"admin"}}, "identity": {"password": {"user":
{"domain": {"name":
"Default"}, "password": "admin00", "name":
"admin"}}, "methods":
["password"]}}}
Now, yes, defining *both* OS_PROJECT_NAME and using --os-domain-name
default is of course kinda stupid, but since I can only have EITHER
project scoped OR domain scoped tokens, isnt it kind of a bug that the
openstack CLI is trying to give me a project scoped token, using the DOMAIN
NAME???
However, it still doesnt work 100% correctly I think. Undefining
OS_PROJECT NAME, and running
"openstack user list --os-domain-name Default"
*Will still not work*. I have to do:
"openstack user list --os-domain-name Default --domain *default* "
And the reason I dont like that, is that I have to know the domain *UUID*(default),
which a normal project/domain-*local* admin cant find out, because of the
rule for identity:get_domain which said:
"identity:get_domain": "rule:cloud_admin or
rule:admin_and_matching_domain_id
or token.project.domain.id:%(target.domain.id)s",
The only way I can do openstack domain show <domain>, is if I already now
the uuid to begin with...
Running
openstack user list --os-domain-name Default --domain Default
openstack domain show --os-domain-name Default Default
result in: "Could not find resource Default"
So. Maybe I can fix this by allowing domain-names in the rule for
get_domain, but since I cant fathom that I would be the first to try to
list users with a domain local admin-user, I cant believe that I need to
change the recently downloaded policy file.
Surely the major users of Openstack have started using domains by now?
Best Regards
Taisto Qvist
2016-11-01 22:17 GMT+01:00 Taisto Qvist <taisto.qvist(a)gmail.com>:
> Hi folks,
>
> I've run into a wall with making openstack domain auth working, and I
> dont know where to get help, so I am trying here. I've created a question
> on:
>
>
https://ask.openstack.org/en/question/98429/project-specific
> -admin-unable-to-list-users-or-use-horizon/
>
> ..but no-one seems to be able to help.
>
> Since I wrote that, I've gotten as far as creating a working cloud-wide
> admin(the policy trigger for cloud_admin matching against domain_id, didnt
> seem to work for the default domain...?), and that user is now working fine
> as super-mega-admin.
>
> But my old admin user, that has admin rights only in the default domain,
> admin project, cant list users, or projects, in the default domain.
>
> And sureley he should be able to, with the rules:
>
> "admin_and_matching_domain_id": "rule:admin_required and
> domain_id:%(domain_id)s",
> "identity:list_users": "rule:cloud_admin or
> rule:admin_and_matching_domain_id",
>
> I've tried to find comprehensive and up2date references on how to read
> the policy.json syntax, but no success so I am unsure on how to interpret
> the rule exactly though.
> I tried changing to:
>
> "admin_and_matching_domain_id": "rule:admin_required and
domain_id:%(
> *target*.domain_id)s",
>
> after looking at the rule for:
>
> "identity:get_project": "rule:cloud_admin or
> rule:admin_and_matching_target_project_domain_id or project_id:%(
> target.project.id)s",
>
> But it didnt help. During the failure, I can see keystone logging:
>
> 2016-11-01 22:16:24.521 4824 INFO keystone.common.wsgi
> [req-46e3301f-f234-434b-a013-5aa2297b6119 admin_User
> admin_Prj - default default] GET
>
http://172.16.12.100:35357/v3/projects/admin_Prj
>
> (where admin_Prj/User is the UUID's regexped)
>
> What is wrong? Where can I learn how to do this???
>