/* $OpenLDAP$ */
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
*
- * Copyright 1998-2005 The OpenLDAP Foundation.
+ * Copyright 1998-2006 The OpenLDAP Foundation.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
}
acl_destroy( bd->be_acl, frontendDB->be_acl );
- assert( bd->be_replogfile == NULL );
+ if ( bd->be_replogfile != NULL ) {
+ free( bd->be_replogfile );
+ }
assert( bd->be_replica == NULL );
}
BackendDB *
backend_db_init(
- const char *type )
+ const char *type,
+ BackendDB *be )
{
- Backend *be;
BackendInfo *bi = backend_info(type);
int rc = 0;
return NULL;
}
- be = ch_calloc( 1, sizeof(Backend) );
- nbackends++;
- LDAP_STAILQ_INSERT_TAIL(&backendDB, be, be_next);
+ /* If be is provided, treat it as private. Otherwise allocate
+ * one and add it to the global list.
+ */
+ if ( !be ) {
+ be = ch_calloc( 1, sizeof(Backend) );
+ nbackends++;
+ LDAP_STAILQ_INSERT_TAIL(&backendDB, be, be_next);
+ }
be->bd_info = bi;
continue;
}
} else {
- b2 = be;
+ /* If any parts of the tree are glued, use the first
+ * match regardless of manageDSAit. Otherwise use the
+ * last match.
+ */
+ if( !( SLAP_DBFLAGS( be ) & ( SLAP_DBFLAG_GLUE_INSTANCE |
+ SLAP_DBFLAG_GLUE_SUBORDINATE )))
+ b2 = be;
}
return b2;
}
}
}
+ /* temporarily removed */
+#if 0
/* check should be generalized */
if( get_manageDIT(op) && !be_isroot(op)) {
rs->sr_text = "requires manager authorization";
rs->sr_err = LDAP_UNWILLING_TO_PERFORM;
}
+#endif
done:;
return rs->sr_err;
int rw,
Entry **e )
{
- int rc;
-
*e = NULL;
- if (op->o_bd == NULL) {
- rc = LDAP_NO_SUCH_OBJECT;
- } else if ( op->o_bd->be_fetch ) {
- rc = ( op->o_bd->be_fetch )( op, ndn,
- oc, at, rw, e );
- } else {
- rc = LDAP_UNWILLING_TO_PERFORM;
+ if ( op->o_bd == NULL ) {
+ return LDAP_NO_SUCH_OBJECT;
}
- return rc;
+
+ if ( op->o_bd->be_fetch ) {
+ return op->o_bd->be_fetch( op, ndn, oc, at, rw, e );
+ }
+
+ return LDAP_UNWILLING_TO_PERFORM;
}
int
AttributeDescription *group_at )
{
Entry *e;
+ void *o_priv = op->o_private, *e_priv = NULL;
Attribute *a;
int rc;
GroupAssertion *g;
e = target;
rc = 0;
} else {
+ op->o_private = NULL;
rc = be_entry_get_rw( op, gr_ndn, group_oc, group_at, 0, &e );
+ e_priv = op->o_private;
+ op->o_private = o_priv;
}
if ( e ) {
a = attr_find( e->e_attrs, group_at );
struct berval bv, nbase;
Filter *filter;
Entry *user;
+ void *user_priv = NULL;
Backend *b2 = op->o_bd;
if ( target && dn_match( &target->e_nname, op_ndn ) ) {
user = target;
} else {
op->o_bd = select_backend( op_ndn, 0, 0 );
+ op->o_private = NULL;
rc = be_entry_get_rw(op, op_ndn, NULL, NULL, 0, &user );
+ user_priv = op->o_private;
+ op->o_private = o_priv;
}
if ( rc == 0 ) {
goto loopit;
}
break;
-#ifdef LDAP_SCOPE_SUBORDINATE
case LDAP_SCOPE_SUBORDINATE:
if ( dn_match( &nbase, op_ndn ) ||
!dnIsSuffix( op_ndn, &nbase ) )
{
goto loopit;
}
-#endif
}
filter = str2filter_x( op, ludp->lud_filter );
if ( filter ) {
if ( rc == 0 ) break;
}
if ( user != target ) {
+ op->o_private = user_priv;
be_entry_release_r( op, user );
+ op->o_private = o_priv;
}
}
op->o_bd = b2;
} else {
rc = LDAP_NO_SUCH_ATTRIBUTE;
}
- if (e != target ) {
+ if ( e != target ) {
+ op->o_private = e_priv;
be_entry_release_r( op, e );
+ op->o_private = o_priv;
}
} else {
rc = LDAP_NO_SUCH_OBJECT;
slap_access_t access )
{
Entry *e = NULL;
+ void *o_priv = op->o_private, *e_priv = NULL;
Attribute *a = NULL;
int freeattr = 0, i, j, rc = LDAP_SUCCESS;
AccessControlState acl_state = ACL_STATE_INIT;
e = target;
} else {
+ op->o_private = NULL;
rc = be_entry_get_rw( op, edn, NULL, entry_at, 0, &e );
+ e_priv = op->o_private;
+ op->o_private = o_priv;
}
if ( e ) {
}
}
freeit: if ( e != target ) {
+ op->o_private = e_priv;
be_entry_release_r( op, e );
+ op->o_private = o_priv;
}
if ( freeattr ) {
attr_free( a );
slap_mask_t *mask )
{
Entry *e = NULL;
+ void *o_priv = op->o_private, *e_priv = NULL;
int rc = LDAP_INSUFFICIENT_ACCESS;
Backend *be = op->o_bd;
e = target;
} else {
+ op->o_private = NULL;
rc = be_entry_get_rw( op, edn, NULL, entry_at, 0, &e );
+ e_priv = op->o_private;
+ op->o_private = o_priv;
}
if ( e ) {
}
}
freeit: if ( e != target ) {
+ op->o_private = e_priv;
be_entry_release_r( op, e );
+ op->o_private = o_priv;
}
if ( freeattr ) {
attr_free( a );
/* Let the overlays have a chance at this */
be_orig = op->o_bd;
op->o_bd = select_backend( &op->o_req_ndn, 0, 0 );
- if ( op->o_bd != frontendDB &&
+ if ( !be_match( op->o_bd, frontendDB ) &&
( SLAP_OPATTRS( rs->sr_attr_flags ) || rs->sr_attrs ) &&
op->o_bd != NULL && op->o_bd->be_operational != NULL )
{