[Zope-dev] ZTUtils make_query and unicode

Michael McFadden mcfaddenm at rfa.org
Tue Oct 29 20:18:45 CET 2013


Hello list.

I'm having an issue with ZTUtils.Zope.make_query when providing Unicode 
values.

Specifically, We're building search results pagination using 
CMFPlone.PloneBatch

Here's the scenario:

The search form is provided a Unicode string.  The query is properly 
written as "?search_text:utf8:ustring=value"
The search will return many results.

Our searchResults browser view will provide a PloneBatch object, making 
it very easy to display only, for example, 30 results, then provide page 
links at the bottom of the page for the next 30 results, or whatever.

These links will contain the original query string, but when they are 
built using make_query(), the result is "?search_text=value"
   - What follows is Unicode decode errors when the 'next' link is 
followed - the search_text is marshaled as a 'str', not as a 'unicode'

The bottom line is that make_query (actually, complex_marshal & 
simple_marshal) doesn't seem to apply the ':ustring' type prefix when 
creating query strings.

Kind of important to us at Radio Free Asia, considering we host 
Cantonese and Korean languages, for example.

This was fixed by using sys.setdefaultencoding('utf-8'), but that seems 
like quite a sledgehammer fix.

----------

I have a proposed fix, branched from the master branch on Github.
    Diff here: https://github.com/zopefoundation/Zope/pull/4/files

Questions:
   1.  Is "Master" the correct place to fork from?

   2.  Is is safe - at least to start - to assume utf8 encoding when 
constructing query strings?

   3.  Dangerous idea:  If simpleMarshal is passed a unicode object that 
can be represented as ASCII, should we "magically" turn it into a 
string?    I don't like magic, but I also know it's common (and good) 
practice to use unicode in ASCII-based languages, making this exercise 
an overkill for those languages.

Any comments or criticisms (not to hard please!) would be appreciated!

-Flip

-- 
Mike McFadden
Radio Free Asia
Technical Operations Division
2025 M Street NW
Washington DC 20036 USA

This e-mail message is intended only for the use of the addressee and may contain information that is privileged and confidential.  Any unauthorized dissemination, distribution or copying is strictly prohibited.  If you receive this transmission in error, please contact network at rfa.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.zope.org/pipermail/zope-dev/attachments/20131029/b72452b9/attachment.html>


More information about the Zope-Dev mailing list