1 /* compare.c - bdb2 backend compare routine */
11 #include "back-bdb2.h"
12 #include "proto-back-bdb2.h"
15 bdb2i_back_compare_internal(
23 struct ldbminfo *li = (struct ldbminfo *) be->be_private;
29 /* get entry with reader lock */
30 if ( (e = bdb2i_dn2entry_r( be, dn, &matched )) == NULL ) {
31 send_ldap_result( conn, op, LDAP_NO_SUCH_OBJECT, matched, "" );
33 if(matched == NULL) free(matched);
37 /* check for deleted */
38 if ( ! access_allowed( be, conn, op, e,
39 ava->ava_type, &ava->ava_value, ACL_COMPARE ) )
41 send_ldap_result( conn, op, LDAP_INSUFFICIENT_ACCESS, "", "" );
46 if ( (a = attr_find( e->e_attrs, ava->ava_type )) == NULL ) {
47 send_ldap_result( conn, op, LDAP_NO_SUCH_ATTRIBUTE, "", "" );
52 if ( value_find( a->a_vals, &ava->ava_value, a->a_syntax, 1 ) == 0 )
53 send_ldap_result( conn, op, LDAP_COMPARE_TRUE, "", "" );
55 send_ldap_result( conn, op, LDAP_COMPARE_FALSE, "", "" );
60 bdb2i_cache_return_entry_r( &li->li_cache, e );
75 struct ldbminfo *li = (struct ldbminfo *) be->be_private;
77 struct timeval time1, time2;
81 gettimeofday( &time1, NULL );
83 if ( bdb2i_enter_backend_r( get_dbenv( be ), &lock ) != 0 ) {
85 send_ldap_result( conn, op, LDAP_OPERATIONS_ERROR, "", "" );
90 ret = bdb2i_back_compare_internal( be, conn, op, dn, ava );
92 (void) bdb2i_leave_backend( get_dbenv( be ), lock );
94 if ( bdb2i_do_timing ) {
96 gettimeofday( &time2, NULL);
97 elapsed_time = bdb2i_elapsed( time1, time2 );
98 Debug( LDAP_DEBUG_ANY, "conn=%d op=%d CMP elapsed=%s\n",
99 conn->c_connid, op->o_opid, elapsed_time );
100 free( elapsed_time );