1 It seems that I can't use Polish characters in post title.
2 When I try to do it, then I can see error message: "Błąd: bad page name".
4 I hope it's a bug, not a feature and you fix it soon :) --[[Paweł|ptecza]]
6 > ikiwiki only allows a very limited set of characters raw in page names,
7 > this is done as a deny-by-default security thing. All other characters
8 > need to be encoded in `__code__` format, where "code" is the character
9 > number. This is normally done for you, but if you're adding a page
10 > manually, you need to handle it yourself. --[[Joey]]
12 >> Assume I have my own blog and I want to send a new post with Polish
13 >> characters in a title. I think it's totally normal and common thing
14 >> in our times. Do you want to tell me I shouldn't use my native
15 >> characters in the title? It can't be true ;)
17 >> In my opinion encoding of title is a job for the wiki engine,
18 >> not for me. Joey, please try to look at a problem from my point
19 >> of view. I'm only user and I don't have to understand
20 >> what the character number is. I only want to blog :)
22 >> BTW, why don't you use the modified-UTF7 coding for page names
23 >> as used in IMAP folder names with non-Latin letters? --[[Paweł|ptecza]]
25 >>> Joey, do you intend to fix that bug or it's a feature
26 >>> for you? ;) --[[Paweł|ptecza]]
28 >>>> Of course you can put Polish characters in the title. but the page
29 >>>> title and filename are not identical. Ikiwiki has to place some limits
30 >>>> on what filenames are legal to prevent abuse. Since
31 >>>> the safest thing to do in a security context is to deny by default and
32 >>>> only allow a few well-defined safe things, that's what it does, so
33 >>>> filenames are limited to basic alphanumeric characters.
35 >>>> It's not especially hard to transform your title into get a legal
36 >>>> ikiwiki filename:
38 joey@kodama:~>perl -MIkiWiki -le 'print IkiWiki::titlepage(shift).".mdwn"' "Błąd"
39 B__197____130____196____133__d.mdwn
41 >>>>> Thanks for the hint! It's good for me, but rather not for common users :)
43 >>>>>> Interesting... I have another result:
45 >>>>>> perl -MIkiWiki -le 'print IkiWiki::titlepage(shift).".mdwn"' "Błąd"
46 >>>>>> B__179____177__d.mdwn
48 >>>>>> What's your locale? I have both pl\_PL (ISO-8859-2) and pl\_PL.UTF-8,
49 >>>>>> but I use pl\_PL. Is it wrong? --[[Paweł|ptecza]]
51 >>>>>>> IkiWiki assumes UTF-8 throughout, so escaped filename characters
52 >>>>>>> should be `__x____y____z__` where x, y, z are the bytes of the
53 >>>>>>> UTF-8 encoding of the character. I don't know how to achieve that
54 >>>>>>> from a non-UTF-8 locale. --[[smcv]]
56 >>>> Now, as to UTF7, in retrospect, using a standard encoding might be a
57 >>>> better idea than coming up with my own encoding for filenames. Can
58 >>>> you provide a pointer to a description to modified-UTF7? --[[Joey]]
60 >>>>> The modified form of UTF7 is defined in [RFC 2060](http://www.ietf.org/rfc/rfc2060.txt)
61 >>>>> for IMAP4 protocol (please see section 5.1.3 for details).
63 >>>>> There is a Perl [Unicode::IMAPUtf7](http://search.cpan.org/~fabpot/Unicode-IMAPUtf7-2.01/lib/Unicode/IMAPUtf7.pm)
64 >>>>> module at the CPAN, but probably it hasn't been debianized yet :( --[[Paweł|ptecza]]
66 > Note: [libencode-imaputf7-perl][1] has made it into debian.
68 >> "IMAP UTF-7" uses & as an escape character, which seems like a recipe
69 >> for shell injection vulnerabilities... so I would not recommend it
70 >> for this particular use. --[[smcv]]
72 > I would value some clarification, in the ikiwiki setup file I have
74 > wiki_file_chars: -[:alnum:][\p{Arabic}()]+/.:_
76 > Ikiwiki doesn't seem to produce any errors on the commandline for this, but
77 > when I attempt to create a new post with Arabic characters from the web I get the following error :
79 > Error: Cannot decode string with wide characters at /usr/lib/x86_64-linux-gnu/perl/5.20/Encode.pm line 215.
81 > Should the modified regexp not be sufficient?
85 >> This seems like a bug: in principle non-ASCII in `wiki_file_chars` should work,
86 >> in practice it does not. I would suggest either using the default
87 >> `wiki_file_chars`, or digging into the code to find what is wrong.
88 >> Solving this sort of bug usually requires having a clear picture of
89 >> which "strings" are bytestrings, and which "strings" are Unicode. --[[smcv]]
91 >>> As mhameed noted on IRC, this might be the same issue as
92 >>> [[bugs/garbled_non-ascii_characters_in_body_in_web_interface]] and/or
93 >>> [[forum/__34__Error:_cannot_decode_string_with_wide_characters__34___on_Mageia_Linux_x86-64_Cauldron]].
94 >>> Please try [[anarcat]]'s patch which you can find at
95 >>> <http://git.pseudorandom.co.uk/smcv/ikiwiki.git/commitdiff/ready/anarcat/safe_unicode>.
99 [1]: https://packages.debian.org/search?suite=all§ion=all&arch=any&searchon=names&keywords=libencode-imaputf7-perl