]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/back-bdb/key.c
Added bdb_attribute and bdb_group ACL support routines
[openldap] / servers / slapd / back-bdb / key.c
index f5b877e5a21ee6d9ca5a85d2bbf03e30bcf6de54..7ca382532ebabcea82af6df0e14306395dfb8045 100644 (file)
@@ -14,8 +14,8 @@
 
 #include "slap.h"
 #include "back-bdb.h"
+#include "idl.h"
 
-#ifdef BDB_FILTER_INDICES
 /* read a key */
 int
 bdb_key_read(
@@ -26,7 +26,8 @@ bdb_key_read(
        ID *ids
 )
 {
-       DBT             key;
+       int rc;
+       DBT key;
 
 #ifdef NEW_LOGGING
        LDAP_LOG(( "index", LDAP_LEVEL_ENTRY,
@@ -35,11 +36,10 @@ bdb_key_read(
        Debug( LDAP_DEBUG_TRACE, "=> key_read\n", 0, 0, 0 );
 #endif
 
-       DBzero( &key );
-       key.data = k->bv_val;
-       key.size = k->bv_len;
+       DBTzero( &key );
+       bv2DBT(k,&key);
 
-       rc = bdb_idl_fetch_key( be, db, txn, key, ids );
+       rc = bdb_idl_fetch_key( be, db, txn, &key, ids );
 
        if( rc != LDAP_SUCCESS ) {
 #ifdef NEW_LOGGING
@@ -53,19 +53,16 @@ bdb_key_read(
        } else {
 #ifdef NEW_LOGGING
                LDAP_LOG(( "index", LDAP_LEVEL_ENTRY,
-                       "bdb_key_read: %ld candidates\n",
-                       idl ? ID_BLOCK_NIDS(idl) : 0 ));
+                       "bdb_key_read: %ld candidates\n", (long) BDB_IDL_N(ids) ));
 #else
                Debug( LDAP_DEBUG_TRACE, "<= bdb_index_read %ld candidates\n",
-               idl ? ID_BLOCK_NIDS(idl) : 0, 0, 0 );
+               (long) BDB_IDL_N(ids), 0, 0 );
 #endif
        }
 
        return rc;
 }
-#endif
 
-#ifdef BDB_INDEX
 /* Add or remove stuff from index files */
 int
 bdb_key_change(
@@ -83,15 +80,14 @@ bdb_key_change(
 #ifdef NEW_LOGGING
        LDAP_LOG(( "index", LDAP_LEVEL_ENTRY,
                "key_change: %s ID %lx\n",
-               op == SLAP_INDEX_ADD_OP ? "Add" : "Delete", (long)id ));
+               op == SLAP_INDEX_ADD_OP ? "Add" : "Delete", (long) id ));
 #else
        Debug( LDAP_DEBUG_TRACE, "=> key_change(%s,%lx)\n",
                op == SLAP_INDEX_ADD_OP ? "ADD":"DELETE", (long) id, 0 );
 #endif
 
        DBTzero( &key );
-       key.data = k->bv_val;
-       key.size = k->bv_len;
+       bv2DBT(k,&key);
 
        if (op == SLAP_INDEX_ADD_OP) {
            /* Add values */
@@ -111,4 +107,3 @@ bdb_key_change(
 
        return rc;
 }
-#endif