X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=apps%2Fpatchwork%2Ffilters.py;h=8c9690eeaf22de4fbe152354ce1bdccea946cc8e;hb=a48f76a2d3a98c21d4b37f19cf84073e77db55c8;hp=228c9c2ac2da2c21c8b88ce30ff70b3da297031d;hpb=e472cd43637c3b30b45ace46146addb46b8a5980;p=patchwork diff --git a/apps/patchwork/filters.py b/apps/patchwork/filters.py index 228c9c2..8c9690e 100644 --- a/apps/patchwork/filters.py +++ b/apps/patchwork/filters.py @@ -22,6 +22,7 @@ from patchwork.models import Person, State from django.utils.safestring import mark_safe from django.utils.html import escape from django.contrib.auth.models import User +from urllib import quote class Filter(object): def __init__(self, filters): @@ -188,8 +189,18 @@ class StateFilter(Filter): def _form(self): str = '' @@ -367,7 +378,7 @@ class DelegateFilter(Filter): selected = ' selected' str += '' % (selected, - d.id, d.get_profile().name()) + d.id, d.profile.name()) str += '' return mark_safe(str) @@ -428,13 +439,21 @@ class Filters: for (k, v) in self.dict.iteritems(): if k not in params: - params[k] = v[0] + params[k] = v if remove is not None: if remove.param in params.keys(): del params[remove.param] - return '?' + '&'.join(['%s=%s' % x for x in params.iteritems()]) + pairs = params.iteritems() + + def sanitise(s): + if not isinstance(s, basestring): + s = unicode(s) + return quote(s.encode('utf-8')) + + return '?' + '&'.join(['%s=%s' % (sanitise(k), sanitise(v)) + for (k, v) in pairs]) def querystring_without_filter(self, filter): return self.querystring(filter)