1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-11 05:17:55 +03:00

Fixed UserInterface new guiField acceptance of values

This commit is contained in:
Adolfo Gómez García 2022-09-12 12:37:21 +02:00
parent 88c3f9077b
commit f90f108869
No known key found for this signature in database
GPG Key ID: DD1ABF20724CDA23
4 changed files with 25 additions and 16 deletions

View File

@ -1,4 +0,0 @@
Linux:
python3-prctl (recommended, but not required in fact)
python3-pyqt5

View File

@ -217,7 +217,7 @@
<string>UDS Service Token</string> <string>UDS Service Token</string>
</property> </property>
<property name="whatsThis"> <property name="whatsThis">
<string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Administrator user on UDS Server.&lt;/p&gt;&lt;p&gt;Note: This credential will not be stored on client. Will be used to obtain an unique token for this image.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string> <string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Token of the service on UDS platform&lt;/p&gt;&lt;p&gt;This token can be obtainend from the service configuration on UDS.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property> </property>
</widget> </widget>
</item> </item>
@ -268,10 +268,10 @@
<item row="3" column="1"> <item row="3" column="1">
<widget class="QLineEdit" name="restrictNet"> <widget class="QLineEdit" name="restrictNet">
<property name="toolTip"> <property name="toolTip">
<string>UDS user with administration rights (Will not be stored on template)</string> <string>Restrict valid detection of network interfaces to this network.</string>
</property> </property>
<property name="whatsThis"> <property name="whatsThis">
<string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Administrator user on UDS Server.&lt;/p&gt;&lt;p&gt;Note: This credential will not be stored on client. Will be used to obtain an unique token for this image.&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string> <string>&lt;html&gt;&lt;head/&gt;&lt;body&gt;&lt;p&gt;Restrics valid detection of network interfaces.&lt;/p&gt;&lt;p&gt;Note: Use this field only in case of several network interfaces, so UDS knows which one is the interface where the user will be connected..&lt;/p&gt;&lt;/body&gt;&lt;/html&gt;</string>
</property> </property>
</widget> </widget>
</item> </item>

View File

@ -37,6 +37,7 @@ import pickle
import copy import copy
import typing import typing
import logging import logging
from collections import abc
from django.utils.translation import get_language, ugettext as _, ugettext_noop from django.utils.translation import get_language, ugettext as _, ugettext_noop
@ -112,19 +113,30 @@ class gui:
# Helpers # Helpers
@staticmethod @staticmethod
def convertToChoices( def convertToChoices(
vals: typing.Union[typing.List[str], typing.MutableMapping[str, str]] vals: typing.Union[typing.Iterable[typing.Union[str, typing.Dict[str, str]]], typing.Dict[str, str]]
) -> typing.List[typing.Dict[str, str]]: ) -> typing.List[typing.Dict[str, str]]:
""" """
Helper to convert from array of strings to the same dict used in choice, Helper to convert from array of strings (or dictionaries) to the same dict used in choice,
multichoice, .. multichoice, ..
""" """
if not vals: if not vals:
return [] return []
if isinstance(vals, (list, tuple)): # Helper to convert an item to a dict
return [{'id': v, 'text': v} for v in vals] def choiceFromValue(val: typing.Union[str, typing.Dict[str, str]]) -> typing.Dict[str, str]:
if isinstance(val, str):
return {'id': val, 'name': val}
# Return a deepcopy
return copy.deepcopy(val)
# Dictionary # If is an iterator
return [{'id': str(k), 'text': v} for k, v in vals.items()] if isinstance(vals, abc.Iterable):
return [choiceFromValue(v) for v in vals]
# If is a dict
if isinstance(vals, abc.Mapping):
return [{'id': str(k), 'text': v} for k, v in vals.items()]
raise ValueError('Invalid type for convertToChoices: {}'.format(type(vals)))
@staticmethod @staticmethod
def convertToList(vals: typing.Iterable[str]) -> typing.List[str]: def convertToList(vals: typing.Iterable[str]) -> typing.List[str]:
@ -770,7 +782,8 @@ class gui:
def __init__(self, **options): def __init__(self, **options):
super().__init__(**options) super().__init__(**options)
if options.get('values') and isinstance(options.get('values'), (dict, list, tuple)): vals = options.get('values')
if vals and isinstance(vals, (dict, list, tuple)):
options['values'] = gui.convertToChoices(options['values']) options['values'] = gui.convertToChoices(options['values'])
self._data['values'] = options.get('values', []) self._data['values'] = options.get('values', [])
if 'fills' in options: if 'fills' in options:
@ -782,7 +795,7 @@ class gui:
gui.callbacks[fills['callbackName']] = fnc gui.callbacks[fills['callbackName']] = fnc
self._type(gui.InputField.CHOICE_TYPE) self._type(gui.InputField.CHOICE_TYPE)
def setValues(self, values: typing.List[typing.Any]): def setValues(self, values: typing.List[typing.Dict[str, typing.Any]]):
""" """
Set the values for this choice field Set the values for this choice field
""" """

View File

@ -173,7 +173,7 @@ class LinuxOsManager(osmanagers.OSManager):
pass pass
def loginNotified(self, userService, userName=None): def loginNotified(self, userService, userName=None):
if '\\' not in userName: if userName and '\\' not in userName:
osmanagers.OSManager.loggedIn(userService, userName) osmanagers.OSManager.loggedIn(userService, userName)
def logoutNotified(self, userService, userName=None): def logoutNotified(self, userService, userName=None):