mirror of
https://github.com/dkmstr/openuds.git
synced 2025-01-08 21:18:00 +03:00
Merged & fixed 2.2 changes
This commit is contained in:
commit
b5887ad1df
@ -1,3 +1,9 @@
|
|||||||
|
udsclient (2.2.0) stable; urgency=medium
|
||||||
|
|
||||||
|
* Updated release
|
||||||
|
|
||||||
|
-- Adolfo Gómez García <agomez@virtualcable.es> Thu, 27 Aug 2017 14:18:18 +0200
|
||||||
|
|
||||||
udsclient (2.1.0) stable; urgency=medium
|
udsclient (2.1.0) stable; urgency=medium
|
||||||
|
|
||||||
* Updated release
|
* Updated release
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
udsclient_2.1.0_all.deb admin optional
|
udsclient_2.2.0_all.deb admin optional
|
||||||
udsclient_2.1.0_amd64.buildinfo admin optional
|
udsclient_2.2.0_amd64.buildinfo admin optional
|
||||||
|
@ -49,7 +49,8 @@ import six
|
|||||||
|
|
||||||
from UDSWindow import Ui_MainWindow
|
from UDSWindow import Ui_MainWindow
|
||||||
|
|
||||||
OLD_METHOD_VERSION = '2.1.0'
|
# Server before this version uses "unsigned" scripts
|
||||||
|
OLD_METHOD_VERSION = '2.4.0'
|
||||||
|
|
||||||
class RetryException(Exception):
|
class RetryException(Exception):
|
||||||
pass
|
pass
|
||||||
@ -269,7 +270,6 @@ def approveHost(host, parentWindow=None):
|
|||||||
settings.endGroup()
|
settings.endGroup()
|
||||||
return approved
|
return approved
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
logger.debug('Initializing connector')
|
logger.debug('Initializing connector')
|
||||||
# Initialize app
|
# Initialize app
|
||||||
|
@ -74,14 +74,13 @@ def approveHost(host):
|
|||||||
except Exception:
|
except Exception:
|
||||||
logger.warn('Got exception writing to {}'.format(hostsFile))
|
logger.warn('Got exception writing to {}'.format(hostsFile))
|
||||||
|
|
||||||
|
|
||||||
return approved
|
return approved
|
||||||
|
|
||||||
|
|
||||||
def getWithRetry(rest, url):
|
def getWithRetry(rest, url, params=None):
|
||||||
while True:
|
while True:
|
||||||
try:
|
try:
|
||||||
res = rest.get(url)
|
res = rest.get(url, params)
|
||||||
return res
|
return res
|
||||||
except RetryException as e:
|
except RetryException as e:
|
||||||
if ui.question('Service not available', '{}\nPlease, wait a minute and press "OK" to retry, or CANCEL to abort') is True:
|
if ui.question('Service not available', '{}\nPlease, wait a minute and press "OK" to retry, or CANCEL to abort') is True:
|
||||||
@ -125,16 +124,38 @@ if __name__ == "__main__":
|
|||||||
try:
|
try:
|
||||||
res = getWithRetry(rest, '')
|
res = getWithRetry(rest, '')
|
||||||
|
|
||||||
|
logger.debug('Got information {}'.format(res))
|
||||||
|
|
||||||
if res['requiredVersion'] > VERSION:
|
if res['requiredVersion'] > VERSION:
|
||||||
ui.message("New UDS Client available", "A new uds version is needed in order to access this version of UDS. A browser will be openend for this download.")
|
ui.message("New UDS Client available", "A new uds version is needed in order to access this version of UDS. A browser will be opened for this download.")
|
||||||
webbrowser.open(res['downloadUrl'])
|
webbrowser.open(res['downloadUrl'])
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# Now get ticket
|
|
||||||
res = getWithRetry(rest, '/{}/{}'.format(ticket, scrambler), params={'hostname': tools.getHostName(), 'version': VERSION})
|
res = getWithRetry(rest, '/{}/{}'.format(ticket, scrambler), params={'hostname': tools.getHostName(), 'version': VERSION})
|
||||||
|
|
||||||
|
script = res.decode('base64').decode('bz2')
|
||||||
|
|
||||||
|
logger.debug('Script: {}'.format(script))
|
||||||
|
|
||||||
|
six.exec_(script, globals(), {'parent': None})
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
error = 'ERROR: {}'.format(e)
|
error = 'ERROR: {}'.format(e)
|
||||||
logger.error(error)
|
logger.error(error)
|
||||||
ui.message('Error', error)
|
ui.message('Error', error)
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
|
|
||||||
|
# Finalize
|
||||||
|
try:
|
||||||
|
tools.waitForTasks()
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
|
||||||
|
try:
|
||||||
|
tools.unlinkFiles()
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
|
||||||
|
try:
|
||||||
|
tools.execBeforeExit()
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
@ -37,7 +37,7 @@ from . import VERSION
|
|||||||
|
|
||||||
import json
|
import json
|
||||||
import six
|
import six
|
||||||
import urllib
|
import osDetector
|
||||||
|
|
||||||
|
|
||||||
from .log import logger
|
from .log import logger
|
||||||
@ -55,16 +55,17 @@ class RestRequest(object):
|
|||||||
|
|
||||||
self.host = host
|
self.host = host
|
||||||
self.ssl = ssl
|
self.ssl = ssl
|
||||||
self.restApiUrl = RestRequest('{}://{}/rest/client'.format(['http', 'https'][ssl], host))
|
self.restApiUrl = '{}://{}/rest/client'.format(['http', 'https'][ssl], host)
|
||||||
|
|
||||||
def get(self, url, params=None):
|
def get(self, url, params=None):
|
||||||
url = self.restApiUrl + url
|
url = self.restApiUrl + url
|
||||||
if params is not None:
|
if params is not None:
|
||||||
url += '?' + '&'.join('{}={}'.format(k, urllib.quote(six.text_type(v).encode('utf8'))) for k, v in params.iteritems())
|
url += '?' + '&'.join('{}={}'.format(k, six.moves.urllib.parse.quote(six.text_type(v).encode('utf8'))) for k, v in params.iteritems()) # @UndefinedVariable
|
||||||
|
|
||||||
logger.debug('Requesting {}'.format(url))
|
logger.debug('Requesting {}'.format(url))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
r = requests.get(url, headers={'Content-type': 'application/json'})
|
r = requests.get(url, headers={'Content-type': 'application/json', 'User-Agent': osDetector.getOs() + " - UDS Connector " + VERSION })
|
||||||
except requests.exceptions.ConnectionError as e:
|
except requests.exceptions.ConnectionError as e:
|
||||||
raise Exception('Error connecting to UDS Server at {}'.format(self.restApiUrl[0:-11]))
|
raise Exception('Error connecting to UDS Server at {}'.format(self.restApiUrl[0:-11]))
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ from __future__ import unicode_literals
|
|||||||
try:
|
try:
|
||||||
import gtkui as theUI
|
import gtkui as theUI
|
||||||
except Exception:
|
except Exception:
|
||||||
import consoleui as theUI
|
import consoleui as theUI # @Reimport
|
||||||
|
|
||||||
def message(title, message):
|
def message(title, message):
|
||||||
theUI.message(title, message)
|
theUI.message(title, message)
|
||||||
|
@ -31,11 +31,19 @@
|
|||||||
'''
|
'''
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
import sys
|
import sys
|
||||||
|
import time
|
||||||
from uds.log import logger
|
from uds.log import logger
|
||||||
|
|
||||||
|
counter = 0
|
||||||
|
|
||||||
def message(title, message):
|
def message(title, message):
|
||||||
sys.stderr.write("** {} **\n {}\n".format(title, message))
|
sys.stderr.write("** {} **\n {}\n".format(title, message))
|
||||||
|
|
||||||
def question(title, message):
|
def question(title, message):
|
||||||
sys.stderr.write("** {} **\n{}\nReturned YES\n".format(title, message))
|
global counter
|
||||||
|
if counter > 100: # 5 minutes
|
||||||
|
return False
|
||||||
|
counter += 1
|
||||||
|
sys.stderr.write("** {} **\n{}\nReturning YES in 3 seconds. (counter is {})\n".format(title, message, counter))
|
||||||
|
time.sleep(3) # Wait 3 seconds before returning
|
||||||
return True
|
return True
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
Steps:
|
Steps:
|
||||||
1.- Copy the folder "udsclient" to /build/packages inside the thinstation build environment
|
1.- If building from repository, full copy (recursive) the "src" folder of "udsclient/thin" inside the "udsclient" folder. If building from the .tar.gz, simply ignor4e this step
|
||||||
2.- enter the chroot of thinstation
|
2.- Copy the folder "udsclient" to /build/packages inside the thinstation build environment
|
||||||
3.- go to the udsclient folder (/build/packages/udsclient)
|
3.- enter the chroot of thinstation
|
||||||
4.- Execute "build.sh"
|
4.- go to the udsclient folder (/build/packages/udsclient)
|
||||||
5.- Edit the file /build/build.conf, and add this line:
|
5.- Execute "build.sh"
|
||||||
|
6.- Edit the file /build/build.conf, and add this line:
|
||||||
package udsclient
|
package udsclient
|
||||||
6.- Execute the build process
|
7.- Execute the build process
|
||||||
|
|
||||||
Ready!!!
|
Ready!!!
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
#
|
#
|
||||||
# Copyright (c) 2012 Virtual Cable S.L.
|
# Copyright (c) 2016 Virtual Cable S.L.
|
||||||
# All rights reserved.
|
# All rights reserved.
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without modification,
|
# Redistribution and use in source and binary forms, with or without modification,
|
||||||
@ -30,6 +30,7 @@
|
|||||||
'''
|
'''
|
||||||
@author: Adolfo Gómez, dkmaster at dkmon dot com
|
@author: Adolfo Gómez, dkmaster at dkmon dot com
|
||||||
'''
|
'''
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from uds.core import services
|
from uds.core import services
|
||||||
|
@ -78,7 +78,7 @@ class HTML5RDPTransport(Transport):
|
|||||||
smooth = gui.CheckBoxField(label=_('Font Smoothing'), order=23, tooltip=_('If checked, fonts smoothing will be allowed (windows clients only)'), tab=gui.PARAMETERS_TAB)
|
smooth = gui.CheckBoxField(label=_('Font Smoothing'), order=23, tooltip=_('If checked, fonts smoothing will be allowed (windows clients only)'), tab=gui.PARAMETERS_TAB)
|
||||||
enableAudio = gui.CheckBoxField(label=_('Enable Audio'), order=24, tooltip=_('If checked, the audio will be redirected to client (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
enableAudio = gui.CheckBoxField(label=_('Enable Audio'), order=24, tooltip=_('If checked, the audio will be redirected to client (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
||||||
enablePrinting = gui.CheckBoxField(label=_('Enable Printing'), order=25, tooltip=_('If checked, the printing will be redirected to client (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
enablePrinting = gui.CheckBoxField(label=_('Enable Printing'), order=25, tooltip=_('If checked, the printing will be redirected to client (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
||||||
# enableFileSharing = gui.CheckBoxField(label=_('Enable File Sharing'), order=8, tooltip=_('If checked, the user will be able to upload/download files (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
enableFileSharing = gui.CheckBoxField(label=_('Enable File Sharing'), order=8, tooltip=_('If checked, the user will be able to upload/download files (if client browser supports it)'), tab=gui.PARAMETERS_TAB)
|
||||||
serverLayout = gui.ChoiceField(order=26,
|
serverLayout = gui.ChoiceField(order=26,
|
||||||
label=_('Layout'),
|
label=_('Layout'),
|
||||||
tooltip=_('Keyboards Layout of server'),
|
tooltip=_('Keyboards Layout of server'),
|
||||||
@ -188,8 +188,8 @@ class HTML5RDPTransport(Transport):
|
|||||||
'create-drive-path': 'true'
|
'create-drive-path': 'true'
|
||||||
}
|
}
|
||||||
|
|
||||||
# if self.enableFileSharing.isTrue():
|
if self.enableFileSharing.isTrue():
|
||||||
# params['enable-drive'] = 'true'
|
params['enable-drive'] = 'true'
|
||||||
|
|
||||||
if self.serverLayout.value != '-':
|
if self.serverLayout.value != '-':
|
||||||
params['server-layout'] = self.serverLayout.value
|
params['server-layout'] = self.serverLayout.value
|
||||||
|
@ -40,7 +40,7 @@ from uds.core.util import OsDetector
|
|||||||
import six
|
import six
|
||||||
import os
|
import os
|
||||||
|
|
||||||
__updated__ = '2017-07-06'
|
__updated__ = '2017-07-26'
|
||||||
|
|
||||||
|
|
||||||
class RDPFile(object):
|
class RDPFile(object):
|
||||||
@ -95,7 +95,7 @@ class RDPFile(object):
|
|||||||
Parameters for xfreerdp >= 1.1.0 with self rdp description
|
Parameters for xfreerdp >= 1.1.0 with self rdp description
|
||||||
Note that server is not added
|
Note that server is not added
|
||||||
'''
|
'''
|
||||||
params = ['/clipboard', '/t:UDS-Connection', '/cert-ignore', '/sec:rdp']
|
params = ['/clipboard', '/t:UDS-Connection', '/cert-ignore'] # , '/sec:rdp']
|
||||||
|
|
||||||
if self.redirectSmartcards and self.smartcardString not in (None, ''):
|
if self.redirectSmartcards and self.smartcardString not in (None, ''):
|
||||||
params.append('/smartcard:{}'.format(self.smartcardString))
|
params.append('/smartcard:{}'.format(self.smartcardString))
|
||||||
|
@ -44,7 +44,7 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
READY_CACHE_TIMEOUT = 30
|
READY_CACHE_TIMEOUT = 30
|
||||||
|
|
||||||
__updated__ = '2017-06-05'
|
__updated__ = '2017-08-02'
|
||||||
|
|
||||||
|
|
||||||
class RDPTransport(BaseRDPTransport):
|
class RDPTransport(BaseRDPTransport):
|
||||||
@ -134,10 +134,11 @@ class RDPTransport(BaseRDPTransport):
|
|||||||
OsDetector.Linux: 'linux',
|
OsDetector.Linux: 'linux',
|
||||||
OsDetector.Macintosh: 'macosx'
|
OsDetector.Macintosh: 'macosx'
|
||||||
|
|
||||||
}.get(os['OS'])
|
}.get(m.os)
|
||||||
|
|
||||||
if os is None:
|
if os is None:
|
||||||
return super(self.__class__, self).getUDSTransportScript(userService, transport, ip, os, user, password, request)
|
logger.ERROR('Os not detected for RDP Transport: {}'.format(request.META.get('HTTP_USER_AGENT', 'Unknown')))
|
||||||
|
return super(RDPTransport, self).getUDSTransportScript(userService, transport, ip, os, user, password, request)
|
||||||
|
|
||||||
sp = {
|
sp = {
|
||||||
'password': password,
|
'password': password,
|
||||||
|
@ -11,9 +11,12 @@ from uds import tools # @UnresolvedImport
|
|||||||
|
|
||||||
import six
|
import six
|
||||||
|
|
||||||
|
theFile = '''{m.r.as_file}'''
|
||||||
|
|
||||||
# First, try to locate Remote Desktop Connection (version 2, from Microsoft website, not the app store one)
|
# First, try to locate Remote Desktop Connection (version 2, from Microsoft website, not the app store one)
|
||||||
|
|
||||||
|
|
||||||
|
filename = tools.saveTempFile(theFile)
|
||||||
msrdc = '/Applications/Remote Desktop Connection.app/Contents/MacOS/Remote Desktop Connection'
|
msrdc = '/Applications/Remote Desktop Connection.app/Contents/MacOS/Remote Desktop Connection'
|
||||||
cord = "/Applications/CoRD.app/Contents/MacOS/CoRD"
|
cord = "/Applications/CoRD.app/Contents/MacOS/CoRD"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user