summaryrefslogtreecommitdiff
path: root/main/templatetags/pgp.py
diff options
context:
space:
mode:
authorLuke Shumaker <LukeShu@sbcglobal.net>2012-11-15 10:49:57 -0500
committerLuke Shumaker <LukeShu@sbcglobal.net>2012-11-15 10:49:57 -0500
commitbd86ba0d5f5b07ba114134b3c12f8f4843e52ec4 (patch)
tree27385dcfd8fa3ca609d44c9108a2b714a2ec56fa /main/templatetags/pgp.py
parent291c9eb72e9ca87748e263e9bb8101effaf78240 (diff)
parent314608aee372c890031cd89f556327a93a2538e6 (diff)
Merge commit '314608a' (update)parabolaweb-2012-11-15-1
Diffstat (limited to 'main/templatetags/pgp.py')
-rw-r--r--main/templatetags/pgp.py17
1 files changed, 14 insertions, 3 deletions
diff --git a/main/templatetags/pgp.py b/main/templatetags/pgp.py
index d69e2918..1ffc5241 100644
--- a/main/templatetags/pgp.py
+++ b/main/templatetags/pgp.py
@@ -16,17 +16,28 @@ def format_key(key_id):
return u'0x%s' % key_id
@register.simple_tag
-def pgp_key_link(key_id):
+def pgp_key_link(key_id, link_text=None):
if not key_id:
return "Unknown"
+ if isinstance(key_id, (int, long)):
+ key_id = '%X' % key_id
+ # zero-fill to nearest 8, 16, or 40 chars if necessary
+ if len(key_id) <= 8:
+ key_id = key_id.zfill(8)
+ elif len(key_id) <= 16:
+ key_id = key_id.zfill(16)
+ elif len(key_id) <= 40:
+ key_id = key_id.zfill(40)
# Something like 'pgp.mit.edu:11371'
pgp_server = getattr(settings, 'PGP_SERVER', None)
if not pgp_server:
return format_key(key_id)
url = 'http://%s/pks/lookup?op=vindex&amp;fingerprint=on&amp;exact=on&amp;search=0x%s' % \
(pgp_server, key_id)
- values = (url, format_key(key_id), key_id[-8:])
- return '<a href="%s" title="PGP key search for %s">0x%s</a>' % values
+ if link_text is None:
+ link_text = '0x%s' % key_id[-8:]
+ values = (url, format_key(key_id), link_text)
+ return '<a href="%s" title="PGP key search for %s">%s</a>' % values
@register.filter
def pgp_fingerprint(key_id, autoescape=True):