X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Ftools%2Fslapcat.c;h=c402dc40f7938d5533867cdee29acfbb86d73141;hb=113727ba53c91ab6f1b0880c5908eca43b89ec4e;hp=f2103878167937bed894a7d11c7e95dadb3ce025;hpb=403f4479bc9f9a864122d4aeecf7284408918302;p=openldap diff --git a/servers/slapd/tools/slapcat.c b/servers/slapd/tools/slapcat.c index f210387816..c402dc40f7 100644 --- a/servers/slapd/tools/slapcat.c +++ b/servers/slapd/tools/slapcat.c @@ -1,8 +1,25 @@ /* $OpenLDAP$ */ -/* - * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved. - * COPYING RESTRICTIONS APPLY, see COPYRIGHT file +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2003 The OpenLDAP Foundation. + * Portions Copyright 1998-2003 Kurt D. Zeilenga. + * Portions Copyright 2003 IBM Corporation. + * 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 file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ +/* ACKNOWLEDGEMENTS: + * This work was initially developed by Kurt Zeilenga for inclusion + * in OpenLDAP Software. Additional signficant contributors include + * Jong Hyuk Choi + */ + #include "portable.h" #include @@ -19,13 +36,14 @@ main( int argc, char **argv ) { ID id; int rc = EXIT_SUCCESS; + Operation op = {0}; slap_tool_init( "slapcat", SLAPCAT, argc, argv ); - if( !be->be_entry_open && - !be->be_entry_close && - !be->be_entry_first && - !be->be_entry_next && + if( !be->be_entry_open || + !be->be_entry_close || + !be->be_entry_first || + !be->be_entry_next || !be->be_entry_get ) { fprintf( stderr, "%s: database doesn't support necessary operations.\n", @@ -46,10 +64,7 @@ main( int argc, char **argv ) char *data; int len; Entry* e = be->be_entry_get( be, id ); - - if( verbose ) { - printf( "# id=%08lx\n", (long) id ); - } + op.o_bd = be; if ( e == NULL ) { printf("# no data for entry id=%08lx\n\n", (long) id ); @@ -58,8 +73,31 @@ main( int argc, char **argv ) break; } + if( sub_ndn.bv_len && !dnIsSuffix( &e->e_nname, &sub_ndn ) ) { + be_entry_release_r( &op, e ); + continue; + } + + if ( retrieve_ctxcsn == 0 ) { + if ( is_entry_syncProviderSubentry( e ) ) { + be_entry_release_r( &op, e ); + continue; + } + } + + if ( retrieve_synccookie == 0 ) { + if ( is_entry_syncConsumerSubentry( e ) ) { + be_entry_release_r( &op, e ); + continue; + } + } + + if( verbose ) { + printf( "# id=%08lx\n", (long) id ); + } + data = entry2str( e, &len ); - entry_free( e ); + be_entry_release_r( &op, e ); if ( data == NULL ) { printf("# bad data for entry id=%08lx\n\n", (long) id );