Hi All,
I'm new to Radius, now encountered problems with ldap_escape_func in rlm_ldap. please help me since it's really a bit urgent.
 
 
the comments regarding to this function is 'Add an ldap_escape_func. Escape the * character from the filter so that we can avoid the trivial DoS of username=*'. if i was not wrong, this function intends to filter out the * which follows the username, i.e, if username is 'userid*' in access-request packet, ldapsearch is only based on 'userid'. but what's the purpose for doing this and is it secure? or did i misunderstand the comments?
 
the lastest version freeradius-1.0.5 has a slightly different version for this piece of code,
*****************************************************************
freeradius-1.0.5
             if (strchr("*=\\,()", *in)) {
                        static const char *hex = "0123456789abcdef";
                        if (outlen <= 3) break;
 
                        *(out++) = '\\';
                        *(out++) = hex[((*in) >> 4) & 0x0f];
                        *(out++) = hex[(*in) & 0x0f];
                        outlen -= 3;
                        continue;
                }
**************************************************************
freeradius-1.0.4 and previous
 
                if (strchr("*", *in)) {
                        in++;
                        outlen--;
                        continue;
                }
 
i couldn't figure out what does the change intend to do, is it to filter out '*', '\\', '()' and '=' from username? and why should it be in that way? please help me. thanks a lot in advance.

- 
List info/subscribe/unsubscribe? See http://www.freeradius.org/list/users.html

Reply via email to