11 #include "ldapconfig.h"
13 #include "../back-bdb2/back-bdb2.h"
17 static char *tailorfile;
18 static char *inputfile;
23 fprintf( stderr, "usage: %s -i inputfile [-d debuglevel] [-f configfile] [-n databasenumber]\n", name );
28 main( int argc, char **argv )
30 int i, cargc, indb, stop, status;
32 char *defargv[MAXARGS];
34 char line[BUFSIZ], idbuf[BUFSIZ];
42 struct berval *vals[2];
43 Avlnode *avltypes = NULL;
46 tailorfile = SLAPD_DEFAULT_CONFIGFILE;
48 while ( (i = getopt( argc, argv, "d:f:i:n:" )) != EOF ) {
50 case 'd': /* turn on debugging */
51 ldap_debug = atoi( optarg );
54 case 'f': /* specify a tailor file */
55 tailorfile = strdup( optarg );
58 case 'i': /* input file */
59 inputfile = strdup( optarg );
62 case 'n': /* which config file db to index */
63 dbnum = atoi( optarg ) - 1;
71 if ( inputfile == NULL ) {
74 if ( freopen( inputfile, "r", stdin ) == NULL ) {
81 * initialize stuff and figure out which backend we're dealing with
84 slap_init(SLAP_TOOL_MODE, "ldif2id2entry");
85 read_config( tailorfile );
88 for ( dbnum = 0; dbnum < nbackends; dbnum++ ) {
89 if ( strcasecmp( backends[dbnum].be_type, "bdb2" )
94 if ( dbnum == nbackends ) {
95 fprintf( stderr, "No bdb2 database found in config file\n" );
98 } else if ( dbnum < 0 || dbnum > (nbackends-1) ) {
99 fprintf( stderr, "Database number selected via -n is out of range\n" );
100 fprintf( stderr, "Must be in the range 1 to %d (number of databases in the config file)\n", nbackends );
102 } else if ( strcasecmp( backends[dbnum].be_type, "bdb2" ) != 0 ) {
103 fprintf( stderr, "Database number %d selected via -n is not an bdb2 database\n", dbnum );
109 be = &backends[dbnum];
111 /* disable write sync'ing */
112 li = (struct ldbminfo *) be->be_private;
113 li->li_dbcachewsync = 0;
115 if ( (db = bdb2i_cache_open( be, "id2entry", BDB2_SUFFIX, LDBM_NEWDB ))
117 perror( "id2entry file" );
128 char *type, *val, *s;
132 ldbm_datum_init( key );
133 ldbm_datum_init( data );
135 if ( fgets( line, sizeof(line), stdin ) != NULL ) {
138 len = strlen( line );
139 if ( buf == NULL || *buf == '\0' ) {
140 if (!isdigit(line[0])) {
141 sprintf( idbuf, "%d\n", id + 1 );
142 idlen = strlen( idbuf );
151 while ( lcur + len + idlen + 1 > lmax ) {
153 buf = (char *) ch_realloc( buf, lmax );
157 strcpy( buf + lcur, idbuf );
160 strcpy( buf + lcur, line );
165 if ( line[0] == '\n' || stop && buf && *buf ) {
166 if ( *buf != '\n' ) {
170 key.dptr = (char *) &id;
171 key.dsize = sizeof(ID);
174 if (buf[len - 1] == '\n')
176 data.dsize = len + 1;
177 if ( ldbm_store( db->dbc_db, key, data,
178 LDBM_INSERT ) != 0 ) {
179 fputs("id2entry ldbm_store failed\n",
190 slap_shutdown(dbnum);
193 sprintf( line, "%s/NEXTID",
194 ((struct ldbminfo *) be->be_private)->li_directory );
195 if ( (fp = fopen( line, "w" )) == NULL ) {
197 fprintf( stderr, "Could not write next id %ld\n", id );
199 fprintf( fp, "%ld\n", id );