Add domains for v3 authentication
I was having trouble authenticating with devstack identity v3 without domain. These options make it possible. Change-Id: I2a968a89136e72898dc086b8f5330608c31ec66f
This commit is contained in:
parent
2e2a92719f
commit
cdd8dc7a60
@ -54,6 +54,9 @@ def make_authenticate(opts):
|
||||
auth_url=opts.os_auth_url,
|
||||
version=opts.os_identity_api_version,
|
||||
project_name=opts.os_project_name,
|
||||
domain_name=opts.os_domain_name,
|
||||
project_domain_name=opts.os_project_domain_name,
|
||||
user_domain_name=opts.os_user_domain_name,
|
||||
)
|
||||
|
||||
|
||||
|
@ -129,6 +129,27 @@ def option_parser():
|
||||
help='Project name of the requested project-level'
|
||||
'authorization scope (Env: OS_PROJECT_NAME)',
|
||||
)
|
||||
parser.add_argument(
|
||||
'--os-domain-name',
|
||||
metavar='<auth-domain-name>',
|
||||
default=env('OS_DOMAIN_NAME'),
|
||||
help='Domain name for scope of '
|
||||
'authorization (Env: OS_DOMAIN_NAME)',
|
||||
)
|
||||
parser.add_argument(
|
||||
'--os-project-domain-name',
|
||||
metavar='<auth-project-domain-name>',
|
||||
default=env('OS_PROJECT_DOMAIN_NAME'),
|
||||
help='Project domain name for scope of '
|
||||
'authorization (Env: OS_PROJECT_DOMAIN_NAME)',
|
||||
)
|
||||
parser.add_argument(
|
||||
'--os-user-domain-name',
|
||||
metavar='<auth-user-domain-name>',
|
||||
default=env('OS_USER_DOMAIN_NAME'),
|
||||
help='User domain name for scope of '
|
||||
'authorization (Env: OS_USER_DOMAIN_NAME)',
|
||||
)
|
||||
parser.add_argument(
|
||||
'--os-username',
|
||||
metavar='<auth-username>',
|
||||
|
@ -35,6 +35,9 @@ def make_session(opts):
|
||||
auth_url=opts.os_auth_url,
|
||||
version=opts.os_identity_api_version,
|
||||
project_name=opts.os_project_name,
|
||||
domain_name=opts.os_domain_name,
|
||||
project_domain_name=opts.os_project_domain_name,
|
||||
user_domain_name=opts.os_user_domain_name,
|
||||
cacert=opts.os_cacert,
|
||||
insecure=opts.insecure,
|
||||
user_agent='SDKExample',
|
||||
|
@ -16,7 +16,8 @@ from openstack import exceptions
|
||||
|
||||
|
||||
def create(username=None, password=None, token=None, auth_url=None,
|
||||
version='3', project_name=None):
|
||||
version='3', project_name=None, domain_name=None,
|
||||
project_domain_name=None, user_domain_name=None):
|
||||
"""Temporary code for creating an authenticator
|
||||
|
||||
This is temporary code to create an authenticator. This code will be
|
||||
@ -28,6 +29,9 @@ def create(username=None, password=None, token=None, auth_url=None,
|
||||
:param string auth_url: The URL to use for authentication.
|
||||
:param string version: Version of authentication to use.
|
||||
:param string project_name: Project name to athenticate.
|
||||
:param string domain_name: Domain name to athenticate.
|
||||
:param string project_domain_name: Project domain name to athenticate.
|
||||
:param string user_domain_name: User domain name to athenticate.
|
||||
|
||||
:returns string: An authenticator.
|
||||
"""
|
||||
@ -38,6 +42,12 @@ def create(username=None, password=None, token=None, auth_url=None,
|
||||
args = {'username': username, 'password': password}
|
||||
if project_name:
|
||||
args['project_name'] = project_name
|
||||
if domain_name:
|
||||
args['domain_name'] = domain_name
|
||||
if project_domain_name:
|
||||
args['project_domain_name'] = project_domain_name
|
||||
if user_domain_name:
|
||||
args['user_domain_name'] = user_domain_name
|
||||
return v3.Password(auth_url, **args)
|
||||
else:
|
||||
return v3.Token(auth_url, token=token)
|
||||
|
@ -41,7 +41,8 @@ class Session(object):
|
||||
@classmethod
|
||||
def create(cls, username=None, password=None, token=None, auth_url=None,
|
||||
version=None, project_name=None, cacert=None, insecure=False,
|
||||
user_agent=None, region=None):
|
||||
user_agent=None, region=None, domain_name=None,
|
||||
project_domain_name=None, user_domain_name=None):
|
||||
xport = transport.Transport.create(
|
||||
cacert=cacert,
|
||||
insecure=insecure,
|
||||
@ -52,7 +53,10 @@ class Session(object):
|
||||
'password': password,
|
||||
'token': token,
|
||||
'auth_url': auth_url,
|
||||
'project_name': project_name
|
||||
'project_name': project_name,
|
||||
'domain_name': domain_name,
|
||||
'project_domain_name': project_domain_name,
|
||||
'user_domain_name': user_domain_name,
|
||||
}
|
||||
if version:
|
||||
args['version'] = version
|
||||
|
@ -24,11 +24,17 @@ class TestAuthenticatorCreate(base.TestCase):
|
||||
auth_url='4',
|
||||
version='3',
|
||||
project_name='6',
|
||||
domain_name='7',
|
||||
project_domain_name='8',
|
||||
user_domain_name='9',
|
||||
)
|
||||
self.assertEqual('1', auth.auth_methods[0].username)
|
||||
self.assertEqual('2', auth.auth_methods[0].password)
|
||||
self.assertEqual('4', auth.auth_url)
|
||||
self.assertEqual('6', auth.project_name)
|
||||
self.assertEqual('7', auth.domain_name)
|
||||
self.assertEqual('8', auth.project_domain_name)
|
||||
self.assertEqual('9', auth.auth_methods[0].user_domain_name)
|
||||
|
||||
def test_create_3_token(self):
|
||||
auth = authenticator.create(
|
||||
|
Loading…
x
Reference in New Issue
Block a user