mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
SLAP_NVALUES mostly populated now
This commit is contained in:
parent
793dada79c
commit
2cdbd25a60
@ -696,10 +696,12 @@ int entry_decode(struct berval *bv, Entry **e)
|
|||||||
if( rc ) {
|
if( rc ) {
|
||||||
#ifdef NEW_LOGGING
|
#ifdef NEW_LOGGING
|
||||||
LDAP_LOG( OPERATION, DETAIL1,
|
LDAP_LOG( OPERATION, DETAIL1,
|
||||||
"str2entry: NULL (ssyn_normalize %d)\n" , rc, 0, 0 );
|
"entry_decode: NULL (ssyn_normalize %d)\n",
|
||||||
|
rc, 0, 0 );
|
||||||
#else
|
#else
|
||||||
Debug( LDAP_DEBUG_ANY,
|
Debug( LDAP_DEBUG_ANY,
|
||||||
"<= str2entry NULL (ssyn_normalize %d)\n", rc, 0, 0 );
|
"<= entry_decode NULL (ssyn_normalize %d)\n",
|
||||||
|
rc, 0, 0 );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -562,7 +562,7 @@ int slap_mods_check(
|
|||||||
/*
|
/*
|
||||||
* check values
|
* check values
|
||||||
*/
|
*/
|
||||||
if( ml->sml_bvalues != NULL ) {
|
if( ml->sml_nvalues != NULL ) {
|
||||||
ber_len_t nvals;
|
ber_len_t nvals;
|
||||||
slap_syntax_validate_func *validate =
|
slap_syntax_validate_func *validate =
|
||||||
ad->ad_type->sat_syntax->ssyn_validate;
|
ad->ad_type->sat_syntax->ssyn_validate;
|
||||||
@ -583,14 +583,14 @@ int slap_mods_check(
|
|||||||
* check that each value is valid per syntax
|
* check that each value is valid per syntax
|
||||||
* and pretty if appropriate
|
* and pretty if appropriate
|
||||||
*/
|
*/
|
||||||
for( nvals = 0; ml->sml_bvalues[nvals].bv_val; nvals++ ) {
|
for( nvals = 0; ml->sml_nvalues[nvals].bv_val; nvals++ ) {
|
||||||
struct berval pval;
|
struct berval pval;
|
||||||
if( pretty ) {
|
if( pretty ) {
|
||||||
rc = pretty( ad->ad_type->sat_syntax,
|
rc = pretty( ad->ad_type->sat_syntax,
|
||||||
&ml->sml_bvalues[nvals], &pval );
|
&ml->sml_nvalues[nvals], &pval );
|
||||||
} else {
|
} else {
|
||||||
rc = validate( ad->ad_type->sat_syntax,
|
rc = validate( ad->ad_type->sat_syntax,
|
||||||
&ml->sml_bvalues[nvals] );
|
&ml->sml_nvalues[nvals] );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( rc != 0 ) {
|
if( rc != 0 ) {
|
||||||
@ -602,16 +602,46 @@ int slap_mods_check(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if( pretty ) {
|
if( pretty ) {
|
||||||
ber_memfree( ml->sml_bvalues[nvals].bv_val );
|
ber_memfree( ml->sml_nvalues[nvals].bv_val );
|
||||||
ml->sml_bvalues[nvals] = pval;
|
ml->sml_nvalues[nvals] = pval;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef SLAP_NVALUES
|
||||||
|
if( nvals && ad->ad_type->sat_equality &&
|
||||||
|
ad->ad_type->sat_equality->smr_match &&
|
||||||
|
ad->ad_type->sat_syntax->ssyn_normalize )
|
||||||
|
{
|
||||||
|
ml->sml_nvalues = ch_malloc( (nvals+1)*sizeof(struct berval) );
|
||||||
|
for( nvals = 0; ml->sml_nvalues[nvals].bv_val; nvals++ ) {
|
||||||
|
rc = ad->ad_type->sat_syntax->ssyn_normalize(
|
||||||
|
ad->ad_type->sat_syntax,
|
||||||
|
&ml->sml_values[nvals], &ml->sml_nvalues[nvals] );
|
||||||
|
if( rc ) {
|
||||||
|
#ifdef NEW_LOGGING
|
||||||
|
LDAP_LOG( OPERATION, DETAIL1,
|
||||||
|
"str2entry: NULL (ssyn_normalize %d)\n",
|
||||||
|
rc, 0, 0 );
|
||||||
|
#else
|
||||||
|
Debug( LDAP_DEBUG_ANY,
|
||||||
|
"<= str2entry NULL (ssyn_normalize %d)\n",
|
||||||
|
rc, 0, 0 );
|
||||||
|
#endif
|
||||||
|
snprintf( textbuf, textlen,
|
||||||
|
"%s: value #%ld normalization failed",
|
||||||
|
ml->sml_type.bv_val, (long) nvals );
|
||||||
|
*text = textbuf;
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* a rough single value check... an additional check is needed
|
* a rough single value check... an additional check is needed
|
||||||
* to catch add of single value to existing single valued attribute
|
* to catch add of single value to existing single valued attribute
|
||||||
*/
|
*/
|
||||||
if( ( ml->sml_op == LDAP_MOD_ADD || ml->sml_op == LDAP_MOD_REPLACE )
|
if ((ml->sml_op == LDAP_MOD_ADD || ml->sml_op == LDAP_MOD_REPLACE)
|
||||||
&& nvals > 1 && is_at_single_value( ad->ad_type ))
|
&& nvals > 1 && is_at_single_value( ad->ad_type ))
|
||||||
{
|
{
|
||||||
snprintf( textbuf, textlen,
|
snprintf( textbuf, textlen,
|
||||||
|
Loading…
Reference in New Issue
Block a user