2 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 * Copyright 1998-2004 The OpenLDAP Foundation.
5 * Portions Copyright 1998-2003 Kurt D. Zeilenga.
6 * Portions Copyright 2003 IBM Corporation.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted only as authorized by the OpenLDAP
13 * A copy of this license is available in file LICENSE in the
14 * top-level directory of the distribution or, alternatively, at
15 * <http://www.OpenLDAP.org/license.html>.
18 * This work was initially developed by Kurt Zeilenga for inclusion
19 * in OpenLDAP Software. Additional signficant contributors include
27 #include <ac/stdlib.h>
29 #include <ac/socket.h>
30 #include <ac/string.h>
32 #include "slapcommon.h"
35 slapcat( int argc, char **argv )
38 int rc = EXIT_SUCCESS;
40 const char *progname = "slapcat";
42 slap_tool_init( progname, SLAPCAT, argc, argv );
44 if( !be->be_entry_open ||
45 !be->be_entry_close ||
46 !be->be_entry_first ||
50 fprintf( stderr, "%s: database doesn't support necessary operations.\n",
55 if( be->be_entry_open( be, 0 ) != 0 ) {
56 fprintf( stderr, "%s: could not open database.\n",
61 for ( id = be->be_entry_first( be );
63 id = be->be_entry_next( be ) )
67 Entry* e = be->be_entry_get( be, id );
71 printf("# no data for entry id=%08lx\n\n", (long) id );
73 if( continuemode ) continue;
77 if( sub_ndn.bv_len && !dnIsSuffix( &e->e_nname, &sub_ndn ) ) {
78 be_entry_release_r( &op, e );
82 if( filter != NULL ) {
83 int rc = test_filter( NULL, e, filter );
84 if( rc != LDAP_COMPARE_TRUE ) {
85 be_entry_release_r( &op, e );
90 if ( retrieve_ctxcsn == 0 ) {
91 if ( is_entry_syncProviderSubentry( e ) ) {
92 be_entry_release_r( &op, e );
97 if ( retrieve_synccookie == 0 ) {
98 if ( is_entry_syncConsumerSubentry( e ) ) {
99 be_entry_release_r( &op, e );
105 printf( "# id=%08lx\n", (long) id );
108 data = entry2str( e, &len );
109 be_entry_release_r( &op, e );
111 if ( data == NULL ) {
112 printf("# bad data for entry id=%08lx\n\n", (long) id );
114 if( continuemode ) continue;
118 fputs( data, ldiffp );
119 fputs( "\n", ldiffp );
122 be->be_entry_close( be );