/* $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
*/
/* slapcommon.c - common routine for the slap tools */
int truncatemode = 0;
int verbose = 0;
int continuemode = 0;
-int nosubs = 0;
+int nosubordinates = 0;
+int dryrun = 0;
char *ldiffile = NULL;
FILE *ldiffp = NULL;
int argc, char **argv )
{
char *options;
- char *base = NULL;
+ struct berval base = { 0, NULL };
int rc, i, dbnum;
int mode = SLAP_TOOL_MODE;
switch( tool ) {
case SLAPADD:
- options = "b:cd:f:l:n:tv";
+ options = "b:cd:f:l:n:tuv";
break;
case SLAPINDEX:
while ( (i = getopt( argc, argv, options )) != EOF ) {
switch ( i ) {
case 'b':
- base = strdup( optarg );
+ base.bv_val = strdup( optarg );
+ base.bv_len = strlen( base.bv_val );
case 'c': /* enable continue mode */
continuemode++;
mode |= SLAP_TRUNCATE_MODE;
break;
+ case 'u': /* dry run */
+ dryrun++;
+ break;
+
case 'v': /* turn on verbose */
verbose++;
break;
}
}
- if ( ( argc != optind ) || (dbnum >= 0 && base != NULL ) ) {
+ if ( ( argc != optind ) || (dbnum >= 0 && base.bv_val != NULL ) ) {
usage( tool );
}
exit( EXIT_FAILURE );
}
- rc = schema_init();
+ rc = slap_schema_init();
if (rc != 0 ) {
fprintf( stderr, "%s: slap_schema_init failed!\n", progname );
exit( EXIT_FAILURE );
}
- rc = schema_prep();
+ rc = slap_schema_check();
if (rc != 0 ) {
fprintf( stderr, "%s: slap_schema_prep failed!\n", progname );
exit( EXIT_FAILURE );
}
- if( base != NULL ) {
- char *tbase = ch_strdup( base );
+ if( base.bv_val != NULL ) {
+ struct berval *nbase = NULL;
- if( dn_normalize( tbase ) == NULL ) {
+ rc = dnNormalize( NULL, &base, &nbase );
+ if( rc != LDAP_SUCCESS ) {
fprintf( stderr, "%s: slap_init invalid suffix (\"%s\")\n",
- progname, base );
+ progname, base.bv_val );
exit( EXIT_FAILURE );
}
- be = select_backend( tbase, 0, 0 );
- free( tbase );
+ be = select_backend( nbase, 0, 0 );
+ ber_bvfree( nbase );
if( be == NULL ) {
fprintf( stderr, "%s: slap_init no backend for \"%s\"\n",
- progname, base );
+ progname, base.bv_val );
exit( EXIT_FAILURE );
}
/* If the named base is a glue master, operate on the
* entire context
*/
- if (be->be_glueflags & SLAP_GLUE_INSTANCE)
- nosubs = 1;
+ if (be->be_flags & SLAP_BFLAG_GLUE_INSTANCE)
+ nosubordinates = 1;
} else if ( dbnum == -1 ) {
be = &backends[dbnum=0];
/* If just doing the first by default and it is a
* glue subordinate, find the master.
*/
- while (be->be_glueflags & SLAP_GLUE_SUBORDINATE) {
- nosubs = 1;
+ while (be->be_flags & SLAP_BFLAG_GLUE_SUBORDINATE) {
+ nosubordinates = 1;
be++;
}
} else if ( dbnum < 0 || dbnum > (nbackends-1) ) {
fprintf( stderr,
"Database number selected via -n is out of range\n"
- "Must be in the range 1 to %d (number of databases in the config file)\n",
+ "Must be in the range 1 to %d"
+ " (number of databases in the config file)\n",
nbackends );
exit( EXIT_FAILURE );