Files
i2p.www/i2p2www/templatevars.py

125 lines
4.3 KiB
Python
Raw Normal View History

from flask import g, request, safe_join, url_for
import os.path
from i2p2www import CANONICAL_DOMAIN, CURRENT_I2P_VERSION, RTL_LANGS, SUPPORTED_LANGS, SUPPORTED_LANG_NAMES, STATIC_DIR, app
2015-01-20 10:32:47 +00:00
INPROXY = '.xyz' # http://zzz.i2p/topics/1771-i2p-xyz-inproxy
I2P_TO_CLEAR = {
'forum.i2p': 'forum.i2p', # Don't convert forum.i2p, it is not accessible outside I2P
'trac.i2p2.i2p': 'trac.i2p2.de',
'mail.i2p': 'i2pmail.org',
'lists.i2p2.i2p': 'lists.i2p2.de',
'stats.i2p': 'stats.i2p', # Inproxy disabled at request of site owner
'zzz.i2p': 'zzz.i2p', # Inproxy disabled at request of site owner
}
####################
# Template functions
@app.context_processor
def utility_processor():
# Shorthand for getting a site url
def get_site_url(path=None):
lang = 'en'
if hasattr(g, 'lang') and g.lang:
lang = g.lang
if path:
return url_for('site_show', lang=lang, page=path)
else:
return url_for('site_show', lang=lang)
2015-11-10 08:15:11 +00:00
def get_spec_url(name):
return url_for('spec_show', name=name, _external=True)
# Shorthand for getting a language-specific url
def get_url_with_lang(endpoint, **args):
lang = 'en'
if hasattr(g, 'lang') and g.lang:
lang = g.lang
return url_for(endpoint, lang=lang, **args)
def is_rtl_lang(lang=None):
if not lang:
if hasattr(g, 'lang') and g.lang:
lang = g.lang
else:
lang = 'en'
return lang in RTL_LANGS
# Get a specific language flag, or the flag for the current language
def get_flag(lang=None):
if not lang:
if hasattr(g, 'lang') and g.lang:
lang = g.lang
else:
lang = 'en'
return url_for('static', filename='images/flags/'+lang+'.png')
# Provide the canonical link to the current page
def get_canonical_link():
# Canonical domain should always be HTTPS
return 'https://' + CANONICAL_DOMAIN + request.path
# Convert an I2P url to an equivalent clearnet one
def convert_url_to_clearnet(value):
if not value.endswith('.i2p'):
# The url being passed in isn't an I2P url, so just return it
return value
if request.headers.get('X-I2P-Desthash') and not request.headers.get('X-Forwarded-Server'):
# The request is from within I2P, so use I2P url
return value
# The request is either directly from clearnet or through an inproxy
try:
# Return the known clearnet url corresponding to the I2P url
return I2P_TO_CLEAR[value]
except KeyError:
# The I2P site has no known clearnet address, so use an inproxy
return value + INPROXY
# Convert a paginated URL to that of another page
def url_for_other_page(page):
args = request.view_args.copy()
args['page'] = page
return url_for(request.endpoint, **args)
# Change the theme of the current page
def change_theme(theme):
args = {}
if request.view_args:
args = request.view_args.copy()
args['theme'] = theme
if request.endpoint:
return url_for(request.endpoint, **args)
# Probably a 404 error page
return url_for('main_index', **args)
# Shorthand for getting the logo for the current theme
def get_logo_for_theme():
logo = 'styles/' + g.theme + '/images/i2plogo.png'
if not os.path.isfile(safe_join(STATIC_DIR, logo)):
logo = 'images/i2plogo.png'
return logo
def get_current_version(string=None, ver=None):
if string:
if ver:
return string % ver
return string % CURRENT_I2P_VERSION
return CURRENT_I2P_VERSION
return dict(i2pconv=convert_url_to_clearnet,
url_for_other_page=url_for_other_page,
change_theme=change_theme,
logo_url=get_logo_for_theme,
site_url=get_site_url,
2015-11-10 08:15:11 +00:00
spec_url=get_spec_url,
get_url=get_url_with_lang,
is_rtl=is_rtl_lang,
get_flag=get_flag,
ver=get_current_version,
2013-12-12 06:16:00 +00:00
canonical=get_canonical_link,
supported_langs=SUPPORTED_LANGS,
lang_names=SUPPORTED_LANG_NAMES)