1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-18 06:03:54 +03:00

Updated checkbrowser to recognize ie, new ie (11), opera, safari, firefox & webkit based browsers

This commit is contained in:
Adolfo Gómez 2013-11-13 22:52:14 +00:00
parent ae9f3c7e78
commit 6e0511add3
3 changed files with 74 additions and 26 deletions

View File

@ -32,6 +32,7 @@
'''
from __future__ import unicode_literals
import re
import logging
logger = logging.getLogger(__name__)
@ -73,39 +74,80 @@ def extractKey(dictionary, key, **kwargs):
value = default
return value
# Regular expressions for User Agents
# These both are for Internet Explorer
_msie = re.compile('MSIE ([0-9]+)\.([0-9]+)')
_trident = re.compile('Trident/.*rv:([0-9]+)\.([0-9]+)')
# Opera
_opera = re.compile('OPR/([0-9]+)\.([0-9]+)')
# Firefox
_firefox = re.compile('Firefox/([0-9]+)\.([0-9]+)')
# Chrome
_chrome = re.compile('Chrome/([0-9]+)\.([0-9]+)')
# Webkit in general
_webkit = re.compile('AppleWebKit/([0-9]+)\.([0-9]+)')
_browsers = {
'ie' : [_trident, _msie],
'opera': [_opera],
'firefox': [_firefox],
'chrome': [_chrome],
'webkit': [_webkit],
}
def checkBrowser(user_agent, browser):
'''
Known browsers right now:
ie[version]
ie<[version]
'''
import re
# Split brwosers we look for
needs_msie = False
needs_version = 6
needs = '='
needs_browser = None
needs_version = 0
needs = ''
if browser[:2] == 'ie':
needs_msie = True
if browser[2] == '<' or browser[2] == '>' or browser[2] == '=':
needs = browser[2]
needs_version = int(browser[3:])
regexs = None
for b, res in _browsers.iteritems():
if browser.startswith(b):
logger.debug('Found: {0}'.format(b))
regexs = res
browser = browser[len(b):]
if regexs is None:
return False
browser += ' ' # So we ensure we have at least beowser 0
if browser[0] == '<' or browser[0] == '>' or browser[0] == '=':
needs = browser[0]
needs_version = int(browser[1:])
else:
needs_version = int(browser[2:])
try:
needs = '='
needs_version = int(browser)
except:
needs = ''
needs_version = 0
try:
if needs_msie:
msie = re.compile('MSIE ([0-9]+)\.([0-9]+)')
matches = msie.search(user_agent)
matches = None
for r in regexs:
matches = r.search(user_agent)
if matches is not None:
break
if matches is None:
return False
version = int(matches.groups()[0])
if needs == '<':
return version < needs_version
elif needs == '>':
return version > needs_version
elif needs == '=':
return version == needs_version
return True
except:
return False

View File

@ -30,11 +30,13 @@
height: 48px;
}
{% ifbrowser ie<9 %}
/* We need to write under button */
.btn-group {
max-width: 114px;
}
{% ifbrowser firefox %}
{% else %}
.btn .caret {
margin-left: -4px;
}
@ -60,6 +62,9 @@
{% endblock %}
{% block body %}
{% ifbrowser webkit %}
webkit!!!
{% endifbrowser %}
<h2>{% trans "Services" %}</h2>
<div class="clearfix">
{% for ser in services %}
@ -121,7 +126,8 @@
<p>{% trans "Ip" %}: {{ ip }}</p>
<p>{% trans "Networks" %}: {{ nets }}</p>
<p>{% trans "Transports" %}: {{ transports }}</p>
<p>{% trans "User Agent" %}: {{ request.META.HTTP_USER_AGENT }}</p>
<p>{% trans "OS" %}: {{ request.session.OS.OS }}</p>
</div>
</div>
{% endif %}