Advancing on Mac OS RDP TRansport and a couple minor fixes to UDS Plugin

This commit is contained in:
Adolfo Gómez García 2015-04-02 09:36:46 +02:00
parent c5138dbc9c
commit 2f655dce16
4 changed files with 77 additions and 27 deletions

View File

@ -45,6 +45,7 @@
<key>CFBundleURLSchemes</key> <key>CFBundleURLSchemes</key>
<array> <array>
<string>uds</string> <string>uds</string>
<string>udss</string>
</array> </array>
</dict> </dict>
</array> </array>

View File

@ -168,8 +168,8 @@ if __name__ == "__main__":
sys.exit(1) sys.exit(1)
# Setup REST api endpoint # Setup REST api endpoint
# RestRequest.restApiUrl = '{}://{}/rest/client'.format(['http', 'https'][ssl], host) RestRequest.restApiUrl = '{}://{}/rest/client'.format(['http', 'https'][ssl], host)
RestRequest.restApiUrl = 'https://172.27.0.1/rest/client' # RestRequest.restApiUrl = 'https://172.27.0.1/rest/client'
try: try:
win = UDSClient() win = UDSClient()
@ -178,18 +178,25 @@ if __name__ == "__main__":
exitVal = app.exec_() exitVal = app.exec_()
win.showMinimized() # This is a top most window, minimize to bar win.showMinimized() # This is a top most window, minimize to bar because it is not closed in fact until app exit
tools.waitForTasks() tools.waitForTasks()
time.sleep(3)
tools.unlinkFiles()
tools.execBeforeExit()
sys.exit(exitVal) sys.exit(exitVal)
except Exception as e: except Exception as e:
QtGui.QMessageBox.critical(None, 'Error', six.text_type(e), QtGui.QMessageBox.Ok) QtGui.QMessageBox.critical(None, 'Error', six.text_type(e), QtGui.QMessageBox.Ok)
time.sleep(3)
try:
tools.unlinkFiles()
except Exception:
pass
try:
tools.execBeforeExit()
except Exception:
pass
# Build base REST # Build base REST
# v = RestRequest('', done) # v = RestRequest('', done)

View File

@ -132,6 +132,9 @@ class RDPFile(object):
<integer>{}</integer> <integer>{}</integer>
</dict>'''.format(self.width, self.height) </dict>'''.format(self.width, self.height)
drives = self.redirectDrives and "1" or "0"
audioMode = self.redirectAudio and "0" or "2"
return ''' return '''
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
@ -142,7 +145,7 @@ class RDPFile(object):
<key>ApplicationPath</key> <key>ApplicationPath</key>
<string></string> <string></string>
<key>AudioRedirectionMode</key> <key>AudioRedirectionMode</key>
<integer>0</integer> <integer>{audioMode}</integer>
<key>AuthenticateLevel</key> <key>AuthenticateLevel</key>
<integer>0</integer> <integer>0</integer>
<key>AutoReconnect</key> <key>AutoReconnect</key>
@ -166,7 +169,7 @@ class RDPFile(object):
<key>DontWarnOnQuit</key> <key>DontWarnOnQuit</key>
<true/> <true/>
<key>DriveRedirectionMode</key> <key>DriveRedirectionMode</key>
<integer>0</integer> <integer>{drives}</integer>
<key>FontSmoothing</key> <key>FontSmoothing</key>
<true/> <true/>
<key>FullWindowDrag</key> <key>FullWindowDrag</key>
@ -314,6 +317,8 @@ class RDPFile(object):
</dict> </dict>
</plist>'''.format( </plist>'''.format(
desktopSize=desktopSize, desktopSize=desktopSize,
drives=drives,
audioMode=audioMode,
host=self.address, host=self.address,
domain=self.domain, domain=self.domain,
username=self.username username=self.username

View File

@ -123,6 +123,7 @@ from __future__ import unicode_literals
from PyQt4 import QtCore, QtGui from PyQt4 import QtCore, QtGui
import subprocess import subprocess
import os
from uds import tools from uds import tools
@ -130,8 +131,19 @@ import six
file = \'\'\'{file}\'\'\' file = \'\'\'{file}\'\'\'
# First, try to locate Remote Desktop Connection (version 2, from Microsoft website, not the app store one)
filename = tools.saveTempFile(file) filename = tools.saveTempFile(file)
executable = '/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"
if os.path.isfile(msrdc):
executable = msrdc
elif os.path.isfile(cord):
executable = cord
else:
executable = None
def onExit(): def onExit():
import subprocess import subprocess
@ -141,26 +153,50 @@ def onExit():
'-s', 'Remote Desktop Connection 2 Password for {ip}', '-s', 'Remote Desktop Connection 2 Password for {ip}',
]) ])
try: if executable is None:
subprocess.call(['security', QtGui.QMessageBox.critical(parent, 'Notice', \'\'\'
'add-generic-password', <p><b>Microsoft Remote Desktop Connection not found</b></p>
'-w', '{password}', <p>In order to connect to UDS RDP Sessions, you need to have at least one of the following:<p>
'-U', <ul>
'-a', '{username}', <li>
'-s', 'Remote Desktop Connection 2 Password for {ip}', <p><b>Microsoft Remote Desktop Connection version 2.</b> (Recommended)</p>
]) <p>You can get it from <a href="http://www.microsoft.com/es-es/download/details.aspx?id=18140">this link</a></p>
# Call but do not wait for exit <p>Remember that you need to use the One from the Microsoft site (the link provided), not the one from the AppStore</p>
tools.addTaskToWait(subprocess.Popen([executable, filename])) </li>
tools.addExecBeforeExit(onExit) <li>
<p><b>CoRD</b> (A bit unstable from 10.7 onwards)</p>
<p>You can get it from <a href="{this_server}static/other/CoRD.pkg">this link</a></p>
</li>
</ul>
<p>If both apps are installed, Remote Desktop Connection will be used as first option</p>
\'\'\', QtGui.QMessageBox.Ok)
elif executable == msrdc:
try:
subprocess.call(['security',
'add-generic-password',
'-w', '{password}',
'-U',
'-a', '{username}',
'-s', 'Remote Desktop Connection 2 Password for {ip}',
'-T', '/Applications/Remote Desktop Connection.app',
])
# Call but do not wait for exit
tools.addTaskToWait(subprocess.Popen([executable, filename]))
tools.addExecBeforeExit(onExit)
tools.addFileToUnlink(filename)
except Exception as e:
QtGui.QMessageBox.critical(parent, 'Notice', six.text_type(e), QtGui.QMessageBox.Ok)
else: # CoRD
pass
tools.addFileToUnlink(filename)
except Exception as e:
QtGui.QMessageBox.critical(parent, 'Notice', six.text_type(e), QtGui.QMessageBox.Ok)
'''.format(os=data['os'], '''.format(os=data['os'],
file=r.get(), file=r.get(),
password=data['password'], password=data['password'],
username=username, username=username,
ip=data['ip'] ip=data['ip'],
this_server=data['this_server']
) )
def getUDSTransportScript(self, userService, transport, ip, os, user, password, request): def getUDSTransportScript(self, userService, transport, ip, os, user, password, request):
@ -191,7 +227,8 @@ except Exception as e:
'compression': True, 'compression': True,
'wallpaper': self.wallpaper.isTrue(), 'wallpaper': self.wallpaper.isTrue(),
'multimon': self.multimon.isTrue(), 'multimon': self.multimon.isTrue(),
'fullScreen': width == -1 or height == -1 'fullScreen': width == -1 or height == -1,
'this_server': request.build_absolute_uri('/')
} }
logger.debug('Detected os: {}'.format(data['os'])) logger.debug('Detected os: {}'.format(data['os']))