mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-24 13:24:56 +08:00
don't chase referrals (essentially, because it may cause an endless loop in libldap/request.c:ldap_chase_v3referrals)
This commit is contained in:
parent
1418b2c5b1
commit
82d50f40ed
@ -320,6 +320,7 @@ retry:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Add/Delete(%d): entry=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Add/Delete(%d): entry=\"%s\".\n",
|
||||||
|
@ -197,6 +197,8 @@ do_bind( char *uri, char *dn, struct berval *pass, int maxloop, int force, int n
|
|||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION,
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION,
|
||||||
&version );
|
&version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS,
|
||||||
|
LDAP_OPT_OFF );
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = ldap_sasl_bind_s( ld, dn, LDAP_SASL_SIMPLE, pass, NULL, NULL, NULL );
|
rc = ldap_sasl_bind_s( ld, dn, LDAP_SASL_SIMPLE, pass, NULL, NULL, NULL );
|
||||||
|
@ -194,6 +194,7 @@ do_modify( char *uri, char *manager,
|
|||||||
struct ldapmod mod;
|
struct ldapmod mod;
|
||||||
struct ldapmod *mods[2];
|
struct ldapmod *mods[2];
|
||||||
char *values[2];
|
char *values[2];
|
||||||
|
int version = LDAP_VERSION3;
|
||||||
|
|
||||||
pid = getpid();
|
pid = getpid();
|
||||||
|
|
||||||
@ -212,11 +213,8 @@ retry:;
|
|||||||
exit( EXIT_FAILURE );
|
exit( EXIT_FAILURE );
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
int version = LDAP_VERSION3;
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION,
|
|
||||||
&version );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Modify(%d): entry=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Modify(%d): entry=\"%s\".\n",
|
||||||
|
@ -205,6 +205,7 @@ retry:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Modrdn(%d): entry=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Modrdn(%d): entry=\"%s\".\n",
|
||||||
|
@ -168,6 +168,7 @@ retry:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Read(%d): entry=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Read(%d): entry=\"%s\".\n",
|
||||||
|
@ -212,6 +212,7 @@ do_random( char *uri, char *manager, struct berval *passwd,
|
|||||||
}
|
}
|
||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Search(%d): base=\"%s\", filter=\"%s\" attr=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Search(%d): base=\"%s\", filter=\"%s\" attr=\"%s\".\n",
|
||||||
@ -258,6 +259,10 @@ do_random( char *uri, char *manager, struct berval *passwd,
|
|||||||
|
|
||||||
ldap_msgfree( res );
|
ldap_msgfree( res );
|
||||||
|
|
||||||
|
if ( do_retry == maxretries ) {
|
||||||
|
fprintf( stderr, "PID=%ld - got %d values.\n", (long) pid, nvalues );
|
||||||
|
}
|
||||||
|
|
||||||
for ( i = 0; i < innerloop; i++ ) {
|
for ( i = 0; i < innerloop; i++ ) {
|
||||||
char buf[ BUFSIZ ];
|
char buf[ BUFSIZ ];
|
||||||
|
|
||||||
@ -297,6 +302,7 @@ retry:;
|
|||||||
}
|
}
|
||||||
|
|
||||||
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
(void) ldap_set_option( ld, LDAP_OPT_PROTOCOL_VERSION, &version );
|
||||||
|
(void) ldap_set_option( ld, LDAP_OPT_REFERRALS, LDAP_OPT_OFF );
|
||||||
|
|
||||||
if ( do_retry == maxretries ) {
|
if ( do_retry == maxretries ) {
|
||||||
fprintf( stderr, "PID=%ld - Search(%d): base=\"%s\", filter=\"%s\".\n",
|
fprintf( stderr, "PID=%ld - Search(%d): base=\"%s\", filter=\"%s\".\n",
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
#define TBINDFILE "do_bind.0"
|
#define TBINDFILE "do_bind.0"
|
||||||
|
|
||||||
static char *get_file_name( char *dirname, char *filename );
|
static char *get_file_name( char *dirname, char *filename );
|
||||||
static int get_search_filters( char *filename, char *filters[], char *bases[] );
|
static int get_search_filters( char *filename, char *filters[], char *attrs[], char *bases[] );
|
||||||
static int get_read_entries( char *filename, char *entries[] );
|
static int get_read_entries( char *filename, char *entries[] );
|
||||||
static void fork_child( char *prog, char **args );
|
static void fork_child( char *prog, char **args );
|
||||||
static void wait4kids( int nkidval );
|
static void wait4kids( int nkidval );
|
||||||
@ -115,6 +115,7 @@ main( int argc, char **argv )
|
|||||||
/* search */
|
/* search */
|
||||||
char *sfile = NULL;
|
char *sfile = NULL;
|
||||||
char *sreqs[MAXREQS];
|
char *sreqs[MAXREQS];
|
||||||
|
char *sattrs[MAXREQS];
|
||||||
char *sbase[MAXREQS];
|
char *sbase[MAXREQS];
|
||||||
int snum = 0;
|
int snum = 0;
|
||||||
char *sargs[MAXARGS];
|
char *sargs[MAXARGS];
|
||||||
@ -276,7 +277,7 @@ main( int argc, char **argv )
|
|||||||
|
|
||||||
/* look for search requests */
|
/* look for search requests */
|
||||||
if ( sfile ) {
|
if ( sfile ) {
|
||||||
snum = get_search_filters( sfile, sreqs, sbase );
|
snum = get_search_filters( sfile, sreqs, sattrs, sbase );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* look for read requests */
|
/* look for read requests */
|
||||||
@ -291,12 +292,12 @@ main( int argc, char **argv )
|
|||||||
|
|
||||||
/* look for modify requests */
|
/* look for modify requests */
|
||||||
if ( modfile ) {
|
if ( modfile ) {
|
||||||
modnum = get_search_filters( modfile, modreqs, moddn );
|
modnum = get_search_filters( modfile, modreqs, NULL, moddn );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* look for bind requests */
|
/* look for bind requests */
|
||||||
if ( bfile ) {
|
if ( bfile ) {
|
||||||
bnum = get_search_filters( bfile, bcreds, breqs );
|
bnum = get_search_filters( bfile, bcreds, NULL, breqs );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* setup friendly option */
|
/* setup friendly option */
|
||||||
@ -359,7 +360,11 @@ main( int argc, char **argv )
|
|||||||
sargs[sanum++] = NULL; /* will hold the search base */
|
sargs[sanum++] = NULL; /* will hold the search base */
|
||||||
sargs[sanum++] = "-f";
|
sargs[sanum++] = "-f";
|
||||||
sargs[sanum++] = NULL; /* will hold the search request */
|
sargs[sanum++] = NULL; /* will hold the search request */
|
||||||
|
|
||||||
sargs[sanum++] = NULL;
|
sargs[sanum++] = NULL;
|
||||||
|
sargs[sanum] = NULL; /* might hold the "attr" request */
|
||||||
|
|
||||||
|
sargs[sanum + 1] = NULL;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* generate the read clients
|
* generate the read clients
|
||||||
@ -544,6 +549,13 @@ main( int argc, char **argv )
|
|||||||
|
|
||||||
sargs[sanum - 2] = sreqs[j];
|
sargs[sanum - 2] = sreqs[j];
|
||||||
sargs[sanum - 4] = sbase[j];
|
sargs[sanum - 4] = sbase[j];
|
||||||
|
if ( sattrs[j] != NULL ) {
|
||||||
|
sargs[sanum - 1] = "-a";
|
||||||
|
sargs[sanum] = sattrs[j];
|
||||||
|
|
||||||
|
} else {
|
||||||
|
sargs[sanum - 1] = NULL;
|
||||||
|
}
|
||||||
fork_child( scmd, sargs );
|
fork_child( scmd, sargs );
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -603,7 +615,7 @@ get_file_name( char *dirname, char *filename )
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
get_search_filters( char *filename, char *filters[], char *bases[] )
|
get_search_filters( char *filename, char *filters[], char *attrs[], char *bases[] )
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
int filter = 0;
|
int filter = 0;
|
||||||
@ -621,7 +633,23 @@ get_search_filters( char *filename, char *filters[], char *bases[] )
|
|||||||
if (( nl = strchr( line, '\r' )) || ( nl = strchr( line, '\n' )))
|
if (( nl = strchr( line, '\r' )) || ( nl = strchr( line, '\n' )))
|
||||||
*nl = '\0';
|
*nl = '\0';
|
||||||
|
|
||||||
filters[filter++] = ArgDup( line );
|
filters[filter] = ArgDup( line );
|
||||||
|
if ( attrs ) {
|
||||||
|
if ( filters[filter][0] == '+') {
|
||||||
|
char *sep = strchr( filters[filter], ':' );
|
||||||
|
|
||||||
|
if ( sep != NULL ) {
|
||||||
|
attrs[ filter ] = &filters[ filter ][ 1 ];
|
||||||
|
sep[ 0 ] = '\0';
|
||||||
|
/* NOTE: don't free this! */
|
||||||
|
filters[ filter ] = &sep[ 1 ];
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
attrs[ filter] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
filter++;
|
||||||
|
|
||||||
}
|
}
|
||||||
fclose( fp );
|
fclose( fp );
|
||||||
|
Loading…
Reference in New Issue
Block a user