/* tools.c - tools for slap tools */
/* $OpenLDAP$ */
/*
- * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.
+ * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
*/
int bdb_tool_entry_open(
BackendDB *be, int mode )
{
- int rc;
- struct bdb_info *bdb = (struct bdb_info *) be->be_private;
-
- assert( be != NULL );
- assert( bdb != NULL );
-
- rc = bdb->bi_id2entry->bdi_db->cursor(
- bdb->bi_id2entry->bdi_db, NULL, &cursor, 0 );
- if( rc != 0 ) {
- return NOID;
- }
-
/* initialize key and data thangs */
DBTzero( &key );
DBTzero( &data );
int bdb_tool_entry_close(
BackendDB *be )
{
- struct bdb_info *bdb = (struct bdb_info *) be->be_private;
-
assert( be != NULL );
if( key.data ) {
{
int rc;
ID id;
+ struct bdb_info *bdb = (struct bdb_info *) be->be_private;
assert( be != NULL );
assert( slapMode & SLAP_TOOL_MODE );
- assert( cursor != NULL );
+ assert( bdb != NULL );
+
+ if (cursor == NULL) {
+ rc = bdb->bi_id2entry->bdi_db->cursor(
+ bdb->bi_id2entry->bdi_db, NULL, &cursor,
+ bdb->bi_db_opflags );
+ if( rc != 0 ) {
+ return NOID;
+ }
+ }
rc = cursor->c_get( cursor, &key, &data, DB_NEXT );
e->e_id = id;
}
+#ifdef BDB_HIER
+ bdb_fix_dn(be, id, e);
+#endif
+
return e;
}
ID bdb_tool_entry_put(
BackendDB *be,
- Entry *e )
+ Entry *e,
+ struct berval *text )
{
int rc;
struct bdb_info *bdb = (struct bdb_info *) be->be_private;
- DB_TXN *tid;
+ DB_TXN *tid = NULL;
+ struct berval pdn;
assert( be != NULL );
assert( slapMode & SLAP_TOOL_MODE );
+ assert( text );
+ assert( text->bv_val );
+ assert( text->bv_val[0] == '\0' ); /* overconservative? */
+
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ARGS, "=> bdb_tool_entry_put( %ld, \"%s\" )\n",
+ (long) e->e_id, e->e_dn, 0 );
+#else
Debug( LDAP_DEBUG_TRACE, "=> bdb_tool_entry_put( %ld, \"%s\" )\n",
- e->e_id, e->e_dn, 0 );
+ (long) e->e_id, e->e_dn, 0 );
+#endif
- rc = txn_begin( bdb->bi_dbenv, NULL, &tid, 0 );
+ rc = TXN_BEGIN( bdb->bi_dbenv, NULL, &tid,
+ bdb->bi_db_opflags );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "txn_begin failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR, "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: txn_begin failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n",
+ text->bv_val, 0, 0 );
+#endif
return NOID;
}
rc = bdb_next_id( be, tid, &e->e_id );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "next_id failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: next_id failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#endif
goto done;
}
/* add dn2id indices */
- rc = bdb_dn2id_add( be, tid, e->e_ndn, e->e_id );
+ if ( be_issuffix( be, &e->e_nname ) ) {
+ pdn = slap_empty_bv;
+ } else {
+ dnParent( &e->e_nname, &pdn );
+ }
+ rc = bdb_dn2id_add( be, tid, &pdn, e );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "dn2id_add failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: dn2id_add failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#endif
goto done;
}
/* id2entry index */
rc = bdb_id2entry_add( be, tid, e );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "id2entry_add failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: id2entry_add failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#endif
goto done;
}
-#if BDB_INDEX
rc = bdb_index_entry_add( be, tid, e, e->e_attrs );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "index_entry_add failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: index_entry_add failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#endif
goto done;
}
-#endif
done:
if( rc == 0 ) {
- rc = txn_commit( tid, 0 );
+ rc = TXN_COMMIT( tid, 0 );
if( rc != 0 ) {
+ snprintf( text->bv_val, text->bv_len,
+ "txn_commit failed: %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: txn_commit failed: %s (%d)\n",
- db_strerror(rc), rc, 0 );
+ "=> bdb_tool_entry_put: %s\n",
+ text->bv_val, 0, 0 );
+#endif
e->e_id = NOID;
}
} else {
+ TXN_ABORT( tid );
+ snprintf( text->bv_val, text->bv_len,
+ "txn_aborted! %s (%d)",
+ db_strerror(rc), rc );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_put: %s\n", text->bv_val, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
- "=> bdb_tool_entry_put: txn_aborted!\n",
- 0, 0, 0 );
- txn_abort( tid );
+ "=> bdb_tool_entry_put: %s\n",
+ text->bv_val, 0, 0 );
+#endif
e->e_id = NOID;
}
return e->e_id;
}
-#if BDB_REINDEX
int bdb_tool_entry_reindex(
BackendDB *be,
ID id )
int rc;
Entry *e;
DB_TXN *tid = NULL;
+ struct berval pdn;
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ARGS,
+ "=> bdb_tool_entry_reindex( %ld )\n", (long) id, 0, 0 );
+#else
Debug( LDAP_DEBUG_ARGS, "=> bdb_tool_entry_reindex( %ld )\n",
(long) id, 0, 0 );
-
-#if 0
- rc = txn_begin( bi->bi_dbenv, NULL, &tid, 0 );
#endif
-
+
e = bdb_tool_entry_get( be, id );
if( e == NULL ) {
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, DETAIL1,
+ "bdb_tool_entry_reindex:: could not locate id=%ld\n",
+ (long) id, 0, 0 );
+#else
Debug( LDAP_DEBUG_ANY,
"bdb_tool_entry_reindex:: could not locate id=%ld\n",
(long) id, 0, 0 );
-#if 0
- txn_abort( tid );
#endif
return -1;
}
+ rc = TXN_BEGIN( bi->bi_dbenv, NULL, &tid, bi->bi_db_opflags );
+ if( rc != 0 ) {
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_reindex: txn_begin failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#else
+ Debug( LDAP_DEBUG_ANY,
+ "=> bdb_tool_entry_reindex: txn_begin failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#endif
+ goto done;
+ }
+
/*
* just (re)add them for now
* assume that some other routine (not yet implemented)
*
*/
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_reindex( %ld, \"%s\" )\n", (long) id, e->e_dn, 0 );
+#else
Debug( LDAP_DEBUG_TRACE, "=> bdb_tool_entry_reindex( %ld, \"%s\" )\n",
- id, e->e_dn, 0 );
+ (long) id, e->e_dn, 0 );
+#endif
+
+ /* add dn2id indices */
+ if ( be_issuffix( be, &e->e_nname ) ) {
+ pdn = slap_empty_bv;
+ } else {
+ dnParent( &e->e_nname, &pdn );
+ }
+ rc = bdb_dn2id_add( be, tid, &pdn, e );
+ if( rc != 0 && rc != DB_KEYEXIST ) {
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_reindex: dn2id_add failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#else
+ Debug( LDAP_DEBUG_ANY,
+ "=> bdb_tool_entry_reindex: dn2id_add failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#endif
+ goto done;
+ }
rc = bdb_index_entry_add( be, tid, e, e->e_attrs );
- entry_free( e );
+done:
+ if( rc == 0 ) {
+ rc = TXN_COMMIT( tid, 0 );
+ if( rc != 0 ) {
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, ERR,
+ "=> bdb_tool_entry_reindex: txn_commit failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#else
+ Debug( LDAP_DEBUG_ANY,
+ "=> bdb_tool_entry_reindex: txn_commit failed: %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#endif
+ e->e_id = NOID;
+ }
+
+ } else {
+ TXN_ABORT( tid );
+#ifdef NEW_LOGGING
+ LDAP_LOG ( TOOLS, DETAIL1,
+ "=> bdb_tool_entry_reindex: txn_aborted! %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#else
+ Debug( LDAP_DEBUG_ANY,
+ "=> bdb_tool_entry_reindex: txn_aborted! %s (%d)\n",
+ db_strerror(rc), rc, 0 );
+#endif
+ e->e_id = NOID;
+ }
return rc;
}
-#endif