forked from shaba/openuds
* Added support for Android OS
* Updated HTML5 part a bit * Added printing support for guacamole
This commit is contained in:
parent
66d56dc6e5
commit
aba57d8400
@ -38,9 +38,10 @@ logger = logging.getLogger(__name__)
|
||||
Linux = 'Linux'
|
||||
Windows = 'Windows'
|
||||
Macintosh = 'Macintosh'
|
||||
Android = 'Android'
|
||||
|
||||
|
||||
knownOss = { 'Linux' : Linux, 'Windows' : Windows, 'Macintosh' : Macintosh }
|
||||
knownOss = { 'Linux' : Linux, 'Windows' : Windows, 'Macintosh' : Macintosh, 'Android': Android }
|
||||
|
||||
def getOsFromUA(ua):
|
||||
'''
|
||||
@ -54,6 +55,7 @@ def getOsFromUA(ua):
|
||||
break
|
||||
except Exception:
|
||||
pass
|
||||
logger.debug(res)
|
||||
logger.debug('User-Agent: {0}'.format(ua))
|
||||
logger.debug('Detected OS: {0}'.format(res))
|
||||
return res
|
||||
|
@ -1,9 +1,12 @@
|
||||
@CHARSET "UTF-8";
|
||||
|
||||
html, body {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
body {
|
||||
padding-top: 60px;
|
||||
padding-bottom: 40px;
|
||||
background-color: #ffffff;
|
||||
}
|
||||
|
||||
@media (max-width: 979px) {
|
||||
@ -14,6 +17,7 @@ body {
|
||||
|
||||
|
||||
footer {
|
||||
display: none;
|
||||
padding:1.6% 2%;
|
||||
margin-top:4em;
|
||||
text-align:right;
|
||||
@ -85,13 +89,9 @@ footer {
|
||||
}
|
||||
.profile-img
|
||||
{
|
||||
font-size: 96px;
|
||||
width: 96px;
|
||||
height: 96px;
|
||||
margin: 0 auto 10px;
|
||||
display: block;
|
||||
-moz-border-radius: 50%;
|
||||
-webkit-border-radius: 50%;
|
||||
border-radius: 50%;
|
||||
}
|
||||
|
||||
|
Binary file not shown.
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 5.6 KiB |
@ -1,33 +1,35 @@
|
||||
{% extends "uds/html5/internal_page.html" %}
|
||||
{% load i18n static html5 %}
|
||||
|
||||
{% block css %}
|
||||
<style>
|
||||
.testing {
|
||||
width: 95px;
|
||||
height: 95px;
|
||||
margin-bottom: 16px;
|
||||
margin-left: 16px;
|
||||
|
||||
background: rgb(255,255,255); /* Old browsers */
|
||||
background: -moz-linear-gradient(top, rgba(255,255,255,1) 0%, rgba(229,229,229,1) 100%); /* FF3.6+ */
|
||||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,1)), color-stop(100%,rgba(229,229,229,1))); /* Chrome,Safari4+ */
|
||||
background: -webkit-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(229,229,229,1) 100%); /* Chrome10+,Safari5.1+ */
|
||||
background: -o-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(229,229,229,1) 100%); /* Opera 11.10+ */
|
||||
background: -ms-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(229,229,229,1) 100%); /* IE10+ */
|
||||
background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(229,229,229,1) 100%); /* W3C */
|
||||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#e5e5e5',GradientType=0 ); /* IE6-9 */
|
||||
overflow: hidden;
|
||||
}
|
||||
</style>
|
||||
{% endblock %}
|
||||
|
||||
{% block js %}
|
||||
<script>
|
||||
function squarifyMe(element) {
|
||||
squareItUp();
|
||||
window.onresize = function(element) {
|
||||
squareItUp();
|
||||
}
|
||||
|
||||
function squareItUp() {
|
||||
$(element).height($(element).width());
|
||||
}
|
||||
}
|
||||
|
||||
$(function() {
|
||||
squarifyMe('.square');
|
||||
|
||||
{% if not java %}
|
||||
$('#jmessage').dialog({
|
||||
autoOpen: false,
|
||||
width: 500,
|
||||
buttons: {
|
||||
"Ok": function() {
|
||||
$(this).dialog("close");
|
||||
}
|
||||
}
|
||||
});
|
||||
$("a.nojava").click( function() {
|
||||
$('#jmessage').dialog('open');
|
||||
$('#no-java-dialog').modal({
|
||||
keyboard: false
|
||||
})
|
||||
return false;
|
||||
});
|
||||
|
||||
@ -38,16 +40,14 @@
|
||||
|
||||
{% block body %}
|
||||
<h2>{% trans "Services" %}</h2>
|
||||
<ul>
|
||||
<div class="row">
|
||||
{% for ser in services %}
|
||||
{% if forloop.counter0|divisibleby:2 == 1 %}
|
||||
</div><div class="row">
|
||||
{% endif %}
|
||||
<div class="clearfix">
|
||||
{% for ser in services %}
|
||||
{% if ser.transports %}
|
||||
{% with trans=ser.transports|first %}
|
||||
<div class="col-sm-6 col-md-4">
|
||||
<div class="thumbnail">
|
||||
{% if forloop.counter0 > 0 %}
|
||||
{% endif %}
|
||||
<div class="pull-left">
|
||||
<div class="thumbnail testing">
|
||||
<a class="{% if not java and trans.needsJava %} nojava{% endif %}" href="{% url "uds.web.views.service" idService=ser.id idTransport=trans.id %}">
|
||||
<img src="{% url "uds.web.views.transportIcon" idTrans=trans.id %}" class="" alt="{{ ser.name }}" />
|
||||
<div class="caption">{{ ser.name }}</div>
|
||||
@ -64,10 +64,23 @@
|
||||
</div>
|
||||
|
||||
{% if not java %}
|
||||
<div id="jmessage" title="{% trans "Java not found" %}">
|
||||
<p>{% trans "Java is not available on your browser, and the selected transport needs it." %}</p>
|
||||
<p>{% trans "Please, install latest version from" %} <a href="http://www.java.com">{% trans "Java website" %}</a> {% trans "and restart browser" %}</p>
|
||||
</div>
|
||||
<div class="modal fade" id="no-java-dialog">
|
||||
<div class="modal-dialog">
|
||||
<div class="modal-content">
|
||||
<div class="modal-header">
|
||||
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
|
||||
<h4 class="modal-title">{% trans "Java not found" %}</h4>
|
||||
</div>
|
||||
<div class="modal-body">
|
||||
<p>{% trans "Java is not available on your browser, and the selected transport needs it." %}</p>
|
||||
<p>{% trans "Please, install latest version from" %} <a href="http://www.java.com" target="_blank">{% trans "Java website" %}</a> {% trans "and restart browser" %}</p>
|
||||
</div>
|
||||
<div class="modal-footer">
|
||||
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
|
||||
</div>
|
||||
</div><!-- /.modal-content -->
|
||||
</div><!-- /.modal-dialog -->
|
||||
</div><!-- /.modal -->
|
||||
{% endif %}
|
||||
|
||||
{% if user.isStaff %}
|
||||
|
@ -69,10 +69,10 @@
|
||||
{% block body %}
|
||||
<div class="container">
|
||||
<div class="row" id="login">
|
||||
<div class="col-sm-6 col-md-4 col-md-offset-4">
|
||||
<div class="col-md-4 col-md-offset-4">
|
||||
<h1 class="text-center login-title">{% trans 'Welcome to UDS' %}</h1>
|
||||
<div class="account-wall">
|
||||
<span class="fa fa-user profile-img text-info"></span>
|
||||
<img class="profile-img" src="{% get_static_prefix %}img/login-img.png" alt="">
|
||||
<form id="loginform" class="form-signin" name="loginform" method="post">
|
||||
{% if form.errors %}
|
||||
<div class="alert alert-dismissable alert-danger">
|
||||
|
@ -39,6 +39,7 @@ from uds.core.util.Cache import Cache
|
||||
from uds.core.util import net
|
||||
from uds.core.transports.BaseTransport import Transport
|
||||
from uds.core.util import connection
|
||||
from uds.core.util import OsDetector
|
||||
|
||||
import logging
|
||||
|
||||
@ -56,6 +57,7 @@ class HTML5RDPTransport(Transport):
|
||||
typeDescription = _('RDP Transport using HTML5 client')
|
||||
iconFile = 'rdp.png'
|
||||
needsJava = False # If this transport needs java for rendering
|
||||
supportedOss = [OsDetector.Linux, OsDetector.Windows, OsDetector.Macintosh, OsDetector.Android]
|
||||
|
||||
guacamoleServer = gui.TextField(label=_('Tunnel Server'), order = 1, tooltip = _('Host of the tunnel server (use http/https & port if needed) as accesible from users'), defvalue = 'https://', length = 64)
|
||||
useEmptyCreds = gui.CheckBoxField(label = _('Empty creds'), order = 2, tooltip = _('If checked, the credentials used to connect will be emtpy'))
|
||||
@ -122,7 +124,7 @@ class HTML5RDPTransport(Transport):
|
||||
# Build params dict
|
||||
params = { 'protocol':'rdp',
|
||||
'hostname':ip, 'username': username, 'password': password,
|
||||
'ignore-cert': 'true',
|
||||
'ignore-cert': 'true', 'enable-printing': 'true'
|
||||
}
|
||||
|
||||
if self.enableAudio.isTrue() is False:
|
||||
|
@ -47,11 +47,11 @@ class CustomSelect(forms.Select):
|
||||
visible = 'style="display: none;"'
|
||||
else:
|
||||
visible = '';
|
||||
res = '<select id="id_{0}" name="{0}" class="form-control"{1}>'.format(name, visible)
|
||||
res = '<select id="id_{0}" name="{0}" class="form-control">'.format(name)
|
||||
for choice in self.choices:
|
||||
res += '<option value="{0}">{1}</option>'.format(choice[0], choice[1])
|
||||
res += '</select>'
|
||||
return mark_safe('<div class="form-group"><label>' + unicode(_('authenticator')) + '</label>' + res + '</div>')
|
||||
return mark_safe('<div class="form-group"{0}><label>'.format(visible) + unicode(_('authenticator')) + '</label>' + res + '</div>')
|
||||
|
||||
class BaseForm(forms.Form):
|
||||
|
||||
|
@ -161,6 +161,8 @@ def index(request):
|
||||
# Information for administrators
|
||||
nets = ''
|
||||
validTrans = ''
|
||||
|
||||
logger.debug('OS: {0}'.format(os['OS']))
|
||||
|
||||
if request.user.isStaff():
|
||||
nets = ','.join( [ n.name for n in Network.networksFor(request.ip) ])
|
||||
@ -205,10 +207,12 @@ def index(request):
|
||||
)
|
||||
|
||||
|
||||
return render_to_response(theme.template('index.html'),
|
||||
response = render_to_response(theme.template('index.html'),
|
||||
{'services' : services, 'java' : java, 'ip' : request.ip, 'nets' : nets,
|
||||
'transports' : validTrans },
|
||||
context_instance=RequestContext(request))
|
||||
return response
|
||||
|
||||
|
||||
@webLoginRequired
|
||||
def prefs(request):
|
||||
|
Loading…
Reference in New Issue
Block a user