[Pidgin] #6620: Jabber client doesn't support spaces in user names

Pidgin trac at pidgin.im
Mon Aug 18 18:48:49 EDT 2008


#6620: Jabber client doesn't support spaces in user names
------------------------------------+---------------------------------------
 Reporter:  not_a_commie            |        Owner:  seanegan   
     Type:  defect                  |       Status:  new        
Milestone:                          |    Component:  Google Talk
  Version:  2.4.3                   |   Resolution:             
 Keywords:  jabber username spaces  |  
------------------------------------+---------------------------------------
Changes (by not_a_commie):

  * owner:  lschiere => seanegan
  * component:  unclassified => Google Talk


Old description:

> Pidgin fails to authenticate with a Jabber server when entering a
> username with spaces in it.  I’ve looked up the code where this happens
> and found the following in jutil.c:
>
> gboolean jabber_nodeprep_validate(const char *str)
> {
>                 const char *c;
>
>                 if(!str)
>                                 return TRUE;
>

>
>                if(strlen(str) > 1023)
>                                 return FALSE;
>
>                 c = str;
>                 while(c && *c) {
>                                gunichar ch = g_utf8_get_char(c);
>                                 if(ch == '\"' || ch == '&' || ch == '\''
> || ch == '/' || ch == ':' ||
>                                                                 ch == '<'
> || ch == '>' || ch == '@' || !g_unichar_isgraph(ch)) {
>                                                 return FALSE;
>                                 }
>                                 c = g_utf8_next_char(c);
>                 }
>                 return TRUE;
> }
>
> The part that fails is the call to g_unichar_isgraph which returns false
> if the character is not printable *or* a space.  There is a related
> function called g_unichar_isprint which is the same with the exception
> that it allows spaces.  I propose that Pidgin uses g_unichar_isprint
> instead.
>
> http://www.gtk.org/api/2.6/glib/glib-Unicode-Manipulation.html#g-unichar-
> isgraph
>
> http://www.gtk.org/api/2.6/glib/glib-Unicode-Manipulation.html#g-unichar-
> isprint

New description:

 Pidgin fails to authenticate with a Jabber server when entering a username
 with spaces in it.  I’ve looked up the code where this happens and found
 the following in jutil.c:

 gboolean jabber_nodeprep_validate(const char *str)
 {
                 const char *c;

                 if(!str)
                                 return TRUE;



                if(strlen(str) > 1023)
                                 return FALSE;

                 c = str;
                 while(c && *c) {
                                gunichar ch = g_utf8_get_char(c);
                                 if(ch == '\"' || ch == '&' || ch == '\''
 || ch == '/' || ch == ':' ||
                                                                 ch == '<'
 || ch == '>' || ch == '@' || !g_unichar_isgraph(ch)) {
                                                 return FALSE;
                                 }
                                 c = g_utf8_next_char(c);
                 }
                 return TRUE;
 }

 The part that fails is the call to g_unichar_isgraph which returns false
 if the character is not printable *or* a space.  There is a related
 function called g_unichar_isprint which is the same with the exception
 that it allows spaces.  I propose that Pidgin uses g_unichar_isprint
 instead.

 http://www.gtk.org/api/2.6/glib/glib-Unicode-Manipulation.html#g-unichar-
 isgraph

 http://www.gtk.org/api/2.6/glib/glib-Unicode-Manipulation.html#g-unichar-
 isprint


 I should add that Skype doesn't have this problem with spaces and
 usernames with spaces are quite common on NT domains, which usernames are
 often used for authentication with Skype.

--

-- 
Ticket URL: <http://developer.pidgin.im/ticket/6620#comment:1>
Pidgin <http://pidgin.im>
Pidgin


More information about the Tracker mailing list