X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=libraries%2Flibldap%2Fcompare.c;h=4af59d01b8d15842a6a5f44db0244028d1a04c66;hb=70092b38fb23b9141a2b8414fb5a9c5200f3c12d;hp=489905b9703270097c505c523351b369563b5069;hpb=dc07e765f263ef459dcd2afd1ece01cfc85a0edd;p=openldap diff --git a/libraries/libldap/compare.c b/libraries/libldap/compare.c index 489905b970..4af59d01b8 100644 --- a/libraries/libldap/compare.c +++ b/libraries/libldap/compare.c @@ -1,5 +1,6 @@ +/* $OpenLDAP$ */ /* - * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved. + * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* Portions @@ -9,6 +10,16 @@ * compare.c */ +/* The compare request looks like this: + * CompareRequest ::= SEQUENCE { + * entry DistinguishedName, + * ava SEQUENCE { + * type AttributeType, + * value AttributeValue + * } + * } + */ + #include "portable.h" #include @@ -25,7 +36,7 @@ * attr and value) are supplied. The msgid of the response is returned. * * Example: - * struct berval bvalue = { "secret", strlen("secret") }; + * struct berval bvalue = { "secret", sizeof("secret")-1 }; * rc = ldap_compare( ld, "c=us@cn=bob", * "userPassword", &bvalue, * sctrl, cctrl, &msgid ) @@ -40,29 +51,33 @@ ldap_compare_ext( LDAPControl **cctrls, int *msgidp ) { + int rc; BerElement *ber; - /* The compare request looks like this: - * CompareRequest ::= SEQUENCE { - * entry DistinguishedName, - * ava SEQUENCE { - * type AttributeType, - * value AttributeValue - * } - * } - * and must be wrapped in an LDAPMessage. - */ - +#ifdef NEW_LOGGING + LDAP_LOG (( "compare", LDAP_LEVEL_ENTRY, "ldap_compare\n" )); +#else Debug( LDAP_DEBUG_TRACE, "ldap_compare\n", 0, 0, 0 ); +#endif + + assert( ld != NULL ); + assert( LDAP_VALID( ld ) ); + assert( dn != NULL ); + assert( attr != NULL ); + assert( msgidp != NULL ); + + /* check client controls */ + rc = ldap_int_client_controls( ld, cctrls ); + if( rc != LDAP_SUCCESS ) return rc; /* create a message to send */ - if ( (ber = ldap_alloc_ber_with_options( ld )) == NULLBER ) { + if ( (ber = ldap_alloc_ber_with_options( ld )) == NULL ) { return( LDAP_NO_MEMORY ); } - if ( ber_printf( ber, "{it{s{sO}}", /* leave open '}' */ + if ( ber_printf( ber, "{it{s{sON}N}", /* '}' */ ++ld->ld_msgid, - LDAP_REQ_COMPARE, dn, attr, &bvalue ) == -1 ) + LDAP_REQ_COMPARE, dn, attr, bvalue ) == -1 ) { ld->ld_errno = LDAP_ENCODING_ERROR; ber_free( ber, 1 ); @@ -75,7 +90,7 @@ ldap_compare_ext( return ld->ld_errno; } - if( ber_printf( ber, "}" ) == -1 ) { + if( ber_printf( ber, /*{*/ "N}" ) == -1 ) { ld->ld_errno = LDAP_ENCODING_ERROR; ber_free( ber, 1 ); return( ld->ld_errno ); @@ -116,6 +131,8 @@ ldap_compare( int msgid; struct berval bvalue; + assert( value != NULL ); + bvalue.bv_val = (char *) value; bvalue.bv_len = (value == NULL) ? 0 : strlen( value ); @@ -156,8 +173,10 @@ ldap_compare_s( { struct berval bvalue; + assert( value != NULL ); + bvalue.bv_val = (char *) value; bvalue.bv_len = (value == NULL) ? 0 : strlen( value ); return ldap_compare_ext_s( ld, dn, attr, &bvalue, NULL, NULL ); -} \ No newline at end of file +}