1
0
mirror of https://github.com/dkmstr/openuds.git synced 2024-12-31 17:17:53 +03:00

Fixed so UDS now works correctly with versiones newer that OCATA

This commit is contained in:
Adolfo Gómez García 2018-09-18 23:40:16 +02:00
parent 5fbdb6834d
commit 8c85639dfe
2 changed files with 23 additions and 15 deletions

View File

@ -44,7 +44,7 @@ from . import openStack
import logging import logging
__updated__ = '2016-04-25' __updated__ = '2018-09-18'
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
@ -54,6 +54,7 @@ INTERFACE_VALUES = [
gui.choiceItem('admin', 'admin'), gui.choiceItem('admin', 'admin'),
] ]
class Provider(ServiceProvider): class Provider(ServiceProvider):
''' '''
This class represents the sample services provider This class represents the sample services provider
@ -97,9 +98,10 @@ class Provider(ServiceProvider):
# "random" # "random"
host = gui.TextField(length=64, label=_('Host'), order=1, tooltip=_('OpenStack Host'), required=True) host = gui.TextField(length=64, label=_('Host'), order=1, tooltip=_('OpenStack Host'), required=True)
port = gui.NumericField(length=5, label=_('Port'), defvalue='5000', order=2, tooltip=_('OpenStack Port'), required=True) port = gui.NumericField(length=5, label=_('Port'), defvalue='5000', order=2, tooltip=_('OpenStack Port'), required=True)
ssl = gui.CheckBoxField(label=_('Use SSL'), order=3, tooltip=_('If checked, the connection will be forced to be ssl (will not work if server is not providing ssl)')) newVersion = gui.CheckBoxField(label=_('Newer Openstack'), order=3, tooltip=_('Check this if your openstack is newer than OCATA'))
ssl = gui.CheckBoxField(label=_('Use SSL'), order=4, tooltip=_('If checked, the connection will be forced to be ssl (will not work if server is not providing ssl)'))
access = gui.ChoiceField(label=_('Access interface'), order=4, tooltip=_('Access interface to be used'), values=INTERFACE_VALUES, defvalue='public') access = gui.ChoiceField(label=_('Access interface'), order=5, tooltip=_('Access interface to be used'), values=INTERFACE_VALUES, defvalue='public')
domain = gui.TextField(length=64, label=_('Domain'), order=8, tooltip=_('Domain name (default is Default)'), required=True, defvalue='Default') domain = gui.TextField(length=64, label=_('Domain'), order=8, tooltip=_('Domain name (default is Default)'), required=True, defvalue='Default')
username = gui.TextField(length=64, label=_('Username'), order=9, tooltip=_('User with valid privileges on OpenStack'), required=True, defvalue='admin') username = gui.TextField(length=64, label=_('Username'), order=9, tooltip=_('User with valid privileges on OpenStack'), required=True, defvalue='admin')
@ -110,7 +112,6 @@ class Provider(ServiceProvider):
timeout = gui.NumericField(length=3, label=_('Timeout'), defvalue='10', minValue=1, maxValue=128, order=99, tooltip=_('Timeout in seconds of connection to OpenStack'), required=True, tab=gui.ADVANCED_TAB) timeout = gui.NumericField(length=3, label=_('Timeout'), defvalue='10', minValue=1, maxValue=128, order=99, tooltip=_('Timeout in seconds of connection to OpenStack'), required=True, tab=gui.ADVANCED_TAB)
# tenant = gui.TextField(length=64, label=_('Project'), order=6, tooltip=_('Project (tenant) for this provider'), required=True, defvalue='') # tenant = gui.TextField(length=64, label=_('Project'), order=6, tooltip=_('Project (tenant) for this provider'), required=True, defvalue='')
# region = gui.TextField(length=64, label=_('Region'), order=7, tooltip=_('Region for this provider'), required=True, defvalue='RegionOne') # region = gui.TextField(length=64, label=_('Region'), order=7, tooltip=_('Region for this provider'), required=True, defvalue='RegionOne')
@ -129,6 +130,7 @@ class Provider(ServiceProvider):
def api(self, projectId=None, region=None): def api(self, projectId=None, region=None):
return openStack.Client(self.host.value, self.port.value, return openStack.Client(self.host.value, self.port.value,
self.domain.value, self.username.value, self.password.value, self.domain.value, self.username.value, self.password.value,
newVersion=self.newVersion.isTrue(),
useSSL=self.ssl.isTrue(), useSSL=self.ssl.isTrue(),
projectId=projectId, projectId=projectId,
region=region, region=region,

View File

@ -39,7 +39,7 @@ import json
import dateutil.parser import dateutil.parser
import six import six
__updated__ = '2018-06-29' __updated__ = '2018-09-18'
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
@ -117,7 +117,8 @@ class Client(object):
PRIVATE = 'private' PRIVATE = 'private'
INTERNAL = 'url' INTERNAL = 'url'
def __init__(self, host, port, domain, username, password, useSSL=False, projectId=None, region=None, access=None): # NewVersion is True for versions >= Ocata
def __init__(self, host, port, domain, username, password, newVersion=False, useSSL=False, projectId=None, region=None, access=None):
self._authenticated = False self._authenticated = False
self._tokenId = None self._tokenId = None
self._catalog = None self._catalog = None
@ -131,7 +132,7 @@ class Client(object):
self._region = region self._region = region
self._timeout = 10 self._timeout = 10
self._authUrl = 'http{}://{}:{}/'.format('s' if useSSL else '', host, port) self._authUrl = 'http{}://{}:{}/{}'.format('s' if useSSL else '', host, port, 'identity/' if newVersion else '')
def _getEndpointFor(self, type_): # If no region is indicatad, first endpoint is returned def _getEndpointFor(self, type_): # If no region is indicatad, first endpoint is returned
for i in self._catalog: for i in self._catalog:
@ -543,13 +544,18 @@ class Client(object):
except Exception: except Exception:
raise Exception('Connection error') raise Exception('Connection error')
for v in r.json()['versions']['values']: try:
if v['id'] >= 'v3.2': for v in r.json()['versions']['values']:
# Tries to authenticate if v['id'] >= 'v3.1':
try: # Tries to authenticate
self.authPassword() try:
return True self.authPassword()
except Exception: return True
raise Exception(_('Authentication error')) except Exception:
logger.exception('Authenticating')
raise Exception(_('Authentication error'))
except Exception: # Not json
# logger.exception('xx')
raise Exception('Invalid endpoint (maybe invalid version selected?)')
raise Exception(_('Openstack does not support identity API 3.2 or newer. This OpenStack server is not compatible with UDS.')) raise Exception(_('Openstack does not support identity API 3.2 or newer. This OpenStack server is not compatible with UDS.'))