Opened 18 years ago

Closed 17 years ago

#4074 closed (fixed)

admin interface filter.html does not encode url attributes properly

Reported by: tony.perkins@… Owned by: nobody
Component: contrib.admin Version: newforms-admin
Severity: Keywords: ampersand filter
Cc: robert@… Triage Stage: Ready for checkin
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

If you filter on a field that has a value that includes an ampersand when selecting that value to filter on it does not work.

The output of filter.html for an example


<li>
    <a href="?title=Escapade%20-%20Adult%20Kayak%20&amp;%20Snorkel,%20Northwest%20Maui">Escapade - Adult Kayak &amp; Snorkel, Northwest Maui</a></li>

I tried using the urlencode filter, but it encodes the ? as well which causes it to fail also.

<a href="{{ choice.query_string|urlencode }}">{{ choice.display|escape }}</a></li>

If I change the following it works. I know this is not the right place.

In filter.html
change

<a href="{{ choice.query_string }}">{{ choice.display|escape }}</a></li>

to

<a href="{{ choice.query_string|fix_ampersands }}">{{ choice.display|escape }}</a></li>

in html.py
change

def fix_ampersands(value):
    "Returns the given HTML with all unencoded ampersands encoded correctly"
    return unencoded_ampersands_re.sub('&amp;', value)

to

  def fix_ampersands(value):
    "Returns the given HTML with all unencoded ampersands encoded correctly"
    return unencoded_ampersands_re.sub('%26', value)

Attachments (4)

django-4074-admin-querystring-quote.patch (768 bytes ) - added by Robert Bunting 18 years ago.
One way to patch it - saves lots of potential problems with the query string
django-4074-admin-querystring-quote2.patch (776 bytes ) - added by Robert Bunting 18 years ago.
better unicode version
4074.diff (1.2 KB ) - added by Chris Beaven 17 years ago.
4074-nfa.diff (1.1 KB ) - added by Karen Tracey <kmtracey@…> 17 years ago.
Same patch, only against newforms-admin

Download all attachments as: .zip

Change History (12)

comment:1 by Adrian Holovaty, 18 years ago

Version: new-adminSVN

by Robert Bunting, 18 years ago

One way to patch it - saves lots of potential problems with the query string

by Robert Bunting, 18 years ago

better unicode version

comment:2 by Robert Bunting, 18 years ago

Has patch: set

Not sure if this would be acceptable, but it's a patch which will make sure the querystring is more useable everywhere. It solves '&', and also a problem I have been having with '>' (which when used in another form confuses the CSRF substitution regexp!)

comment:3 by anonymous, 18 years ago

Cc: robert@… added

comment:4 by Chris Beaven, 17 years ago

Patch needs improvement: set
Summary: admin interface filter.html does not encode & properlyadmin interface filter.html does not encode url attributes properly
Triage Stage: UnreviewedAccepted

by Chris Beaven, 17 years ago

Attachment: 4074.diff added

comment:5 by Chris Beaven, 17 years ago

Patch needs improvement: unset
Triage Stage: AcceptedReady for checkin

New patch (against SVN trunk, not newforms-admin branch) which fixes the issue at the core. I also added a small optimization.

The code in question hasn't changed in newforms, it may as well be fixed on trunk, yes?

comment:6 by Malcolm Tredinnick, 17 years ago

Triage Stage: Ready for checkinAccepted
Version: SVNnewforms-admin

Not worth fixing on trunk, since newforms-admin is so close. Pushing to the newforms-admin branch, though, so they can check it's been fixed over there.

by Karen Tracey <kmtracey@…>, 17 years ago

Attachment: 4074-nfa.diff added

Same patch, only against newforms-admin

comment:7 by Karen Tracey <kmtracey@…>, 17 years ago

Triage Stage: AcceptedReady for checkin

No, it hasn't been fixed in newforms-admin. Verified the problem and that the patch (rebased since the trunk version would not apply) fixes it.

comment:8 by Brian Rosner, 17 years ago

Resolution: fixed
Status: newclosed

(In [7810]) newforms-admin: Fixed #4074 -- Properly urlencode the ChangeList query string when the value has an ampersand. Thanks Tony Perkins and SmileyChris.

Note: See TracTickets for help on using tickets.
Back to Top