From 92b5b3c7aaf0ba0fc28367b603582fe47d854e5d Mon Sep 17 00:00:00 2001 From: str4d Date: Sat, 10 Mar 2018 16:21:32 +0000 Subject: [PATCH] Convert proposal thread URLs to clearnet with HTTPS --- i2p2www/pages/spec/proposal-show.html | 2 +- i2p2www/templatevars.py | 28 +++++++++++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/i2p2www/pages/spec/proposal-show.html b/i2p2www/pages/spec/proposal-show.html index 0ed30577..78f7e632 100644 --- a/i2p2www/pages/spec/proposal-show.html +++ b/i2p2www/pages/spec/proposal-show.html @@ -19,7 +19,7 @@
Created
Thread
-
{{ meta.thread }}
+
{{ i2pclr(meta.thread) }}
Last updated
Status
{{ meta.status }}
diff --git a/i2p2www/templatevars.py b/i2p2www/templatevars.py index 7f91f9f7..c910545e 100644 --- a/i2p2www/templatevars.py +++ b/i2p2www/templatevars.py @@ -1,6 +1,7 @@ import ctags from flask import g, request, safe_join, url_for import os.path +from urlparse import urlsplit, urlunsplit from i2p2www import ( CANONICAL_DOMAIN, @@ -26,6 +27,11 @@ I2P_TO_CLEAR = { 'zzz.i2p': 'zzz.i2p', # Inproxy disabled at request of site owner } +CLEAR_HTTP = [ + 'stats.i2p', + 'zzz.i2p', + ] + #################### # Template functions @@ -136,6 +142,27 @@ def utility_processor(): # The I2P site has no known clearnet address, so use an inproxy return value + INPROXY + # Convert an I2P url to an equivalent clearnet one, including HTTPS if necessary + def convert_url_to_clearnet_inc_https(value): + parts = urlsplit(value) + if not parts[1].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 + scheme = parts[0] + host = I2P_TO_CLEAR[parts[1]] + if scheme == 'http' and host not in CLEAR_HTTP: + scheme = 'https' + return urlunsplit([scheme, host] + list(parts[2:])) + except KeyError: + # The I2P site has no known clearnet address, so use an inproxy + return urlunsplit([parts[0], parts[1] + INPROXY] + list(parts[2:])) + # Convert a paginated URL to that of another page def url_for_other_page(page): args = request.view_args.copy() @@ -168,6 +195,7 @@ def utility_processor(): return CURRENT_I2P_VERSION return dict(i2pconv=convert_url_to_clearnet, + i2pclr=convert_url_to_clearnet_inc_https, url_for_other_page=url_for_other_page, change_theme=change_theme, logo_url=get_logo_for_theme,