X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Foperational.c;h=fd12d0aff6e38f89c691edfe763b8b015e05aedb;hb=3cdba151ad18dba10786fde4464442ddaf67b5fe;hp=bc842049ed0844b09664bbc242eda1f67bae072d;hpb=c75be97ae946dab41f002a31d8347cc38cda7658;p=openldap diff --git a/servers/slapd/operational.c b/servers/slapd/operational.c index bc842049ed..fd12d0aff6 100644 --- a/servers/slapd/operational.c +++ b/servers/slapd/operational.c @@ -1,7 +1,16 @@ /* operational.c - routines to deal with on-the-fly operational attrs */ -/* - * Copyright 2001-2003 The OpenLDAP Foundation, All Rights Reserved. - * COPYING RESTRICTIONS APPLY, see COPYRIGHT file +/* This work is part of OpenLDAP Software . + * + * Copyright 2001-2007 The OpenLDAP Foundation. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted only as authorized by the OpenLDAP + * Public License. + * + * A copy of this license is available in the file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ #include "portable.h" @@ -18,56 +27,61 @@ slap_operational_subschemaSubentry( Backend *be ) Attribute *a; /* The backend wants to take care of it */ - if ( be && be->be_schemadn.bv_val ) return NULL; + if ( be && !SLAP_FRONTEND(be) && be->be_schemadn.bv_val ) return NULL; - a = ch_malloc( sizeof( Attribute ) ); - a->a_desc = slap_schema.si_ad_subschemaSubentry; + a = attr_alloc( slap_schema.si_ad_subschemaSubentry ); a->a_vals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_dupbv( a->a_vals, &global_schemadn ); + ber_dupbv( a->a_vals, &frontendDB->be_schemadn ); a->a_vals[1].bv_len = 0; a->a_vals[1].bv_val = NULL; a->a_nvals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_dupbv( a->a_nvals, &global_schemandn ); + ber_dupbv( a->a_nvals, &frontendDB->be_schemandn ); a->a_nvals[1].bv_len = 0; a->a_nvals[1].bv_val = NULL; - a->a_next = NULL; - a->a_flags = 0; - return a; } Attribute * -slap_operational_hasSubordinate( int hs ) +slap_operational_entryDN( Entry *e ) { Attribute *a; - char *val; - ber_len_t len; - if ( hs ) { - val = "TRUE"; - len = sizeof( "TRUE" ) - 1; + assert( e != NULL ); + assert( !BER_BVISNULL( &e->e_name ) ); + assert( !BER_BVISNULL( &e->e_nname ) ); + + a = attr_alloc( slap_schema.si_ad_entryDN ); + + a->a_vals = ch_malloc( 2 * sizeof( struct berval ) ); + ber_dupbv( &a->a_vals[ 0 ], &e->e_name ); + BER_BVZERO( &a->a_vals[ 1 ] ); + + a->a_nvals = ch_malloc( 2 * sizeof( struct berval ) ); + ber_dupbv( &a->a_nvals[ 0 ], &e->e_nname ); + BER_BVZERO( &a->a_nvals[ 1 ] ); + + return a; +} - } else { - val = "FALSE"; - len = sizeof( "FALSE" ) - 1; +Attribute * +slap_operational_hasSubordinate( int hs ) +{ + Attribute *a; + struct berval val; - } + val = hs ? slap_true_bv : slap_false_bv; - a = ch_malloc( sizeof( Attribute ) ); - a->a_desc = slap_schema.si_ad_hasSubordinates; + a = attr_alloc( slap_schema.si_ad_hasSubordinates ); a->a_vals = ch_malloc( 2 * sizeof( struct berval ) ); - ber_str2bv( val, len, 1, a->a_vals ); + ber_dupbv( &a->a_vals[0], &val ); a->a_vals[1].bv_val = NULL; a->a_nvals = a->a_vals; - a->a_next = NULL; - a->a_flags = 0; - return a; }