mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-24 13:24:56 +08:00
Allow utf-8 in AD-Canonical Names
This commit is contained in:
parent
88cbe052e0
commit
6ab46208bc
@ -2368,12 +2368,12 @@ strval2DCEstr( struct berval *val, char *str, unsigned flags, ber_len_t *len )
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Length of the (supposedly) AD canonical string representation,
|
* Length of the (supposedly) AD canonical string representation,
|
||||||
* accounting for escaped hex of UTF-8 chars
|
* accounting for chars that need to be escaped
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
strval2ADstrlen( struct berval *val, unsigned flags, ber_len_t *len )
|
strval2ADstrlen( struct berval *val, unsigned flags, ber_len_t *len )
|
||||||
{
|
{
|
||||||
ber_len_t l;
|
ber_len_t l, cl;
|
||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
assert( val != NULL );
|
assert( val != NULL );
|
||||||
@ -2384,20 +2384,15 @@ strval2ADstrlen( struct berval *val, unsigned flags, ber_len_t *len )
|
|||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( flags & LDAP_AVA_NONPRINTABLE ) {
|
for ( l = 0, p = val->bv_val; p[ 0 ]; p += cl ) {
|
||||||
/*
|
cl = LDAP_UTF8_CHARLEN2( p, cl );
|
||||||
* FIXME: Turn the value into a binary encoded BER?
|
if ( cl == 0 ) {
|
||||||
*/
|
/* illegal utf-8 char */
|
||||||
return( -1 );
|
return -1;
|
||||||
|
} else if ( (cl == 1) && LDAP_DN_NEEDESCAPE_AD( p[ 0 ] ) ) {
|
||||||
} else {
|
|
||||||
for ( l = 0, p = val->bv_val; p[ 0 ]; p++ ) {
|
|
||||||
if ( LDAP_DN_NEEDESCAPE_AD( p[ 0 ] ) ) {
|
|
||||||
l += 2;
|
l += 2;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
l++;
|
l += cl;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2408,13 +2403,12 @@ strval2ADstrlen( struct berval *val, unsigned flags, ber_len_t *len )
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* convert to (supposedly) AD string representation,
|
* convert to (supposedly) AD string representation,
|
||||||
* escaping with hex the UTF-8 stuff;
|
|
||||||
* assume the destination has enough room for escaping
|
* assume the destination has enough room for escaping
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
strval2ADstr( struct berval *val, char *str, unsigned flags, ber_len_t *len )
|
strval2ADstr( struct berval *val, char *str, unsigned flags, ber_len_t *len )
|
||||||
{
|
{
|
||||||
ber_len_t s, d;
|
ber_len_t s, d, cl;
|
||||||
|
|
||||||
assert( val != NULL );
|
assert( val != NULL );
|
||||||
assert( str != NULL );
|
assert( str != NULL );
|
||||||
@ -2425,24 +2419,20 @@ strval2ADstr( struct berval *val, char *str, unsigned flags, ber_len_t *len )
|
|||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( flags & LDAP_AVA_NONPRINTABLE ) {
|
|
||||||
/*
|
/*
|
||||||
* FIXME: Turn the value into a binary encoded BER?
|
* we assume the string has enough room for the escaping
|
||||||
*/
|
|
||||||
*len = 0;
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
} else {
|
|
||||||
|
|
||||||
/*
|
|
||||||
* we assume the string has enough room for the hex encoding
|
|
||||||
* of the value
|
* of the value
|
||||||
*/
|
*/
|
||||||
|
|
||||||
for ( s = 0, d = 0; s < val->bv_len; ) {
|
for ( s = 0, d = 0; s < val->bv_len; ) {
|
||||||
if ( LDAP_DN_NEEDESCAPE_AD( val->bv_val[ s ] ) ) {
|
cl = LDAP_UTF8_CHARLEN2( val->bv_val+s, cl );
|
||||||
|
if ( cl == 0 ) {
|
||||||
|
/* illegal utf-8 char */
|
||||||
|
return -1;
|
||||||
|
} else if ( (cl == 1) && LDAP_DN_NEEDESCAPE_AD(val->bv_val[ s ]) ) {
|
||||||
str[ d++ ] = '\\';
|
str[ d++ ] = '\\';
|
||||||
}
|
}
|
||||||
|
for (; cl--;) {
|
||||||
str[ d++ ] = val->bv_val[ s++ ];
|
str[ d++ ] = val->bv_val[ s++ ];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user