Diff for /libraries/libldap/result.c between versions 1.124.2.13 and 1.146

version 1.124.2.13, 2008/09/26 22:23:05 version 1.146, 2007/01/04 14:01:22
Line 1 Line 1
 /* result.c - wait for an ldap result */  /* result.c - wait for an ldap result */
 /* $OpenLDAP: pkg/ldap/libraries/libldap/result.c,v 1.124.2.12 2008/07/09 23:16:48 quanah Exp $ */  /* $OpenLDAP: pkg/ldap/libraries/libldap/result.c,v 1.145 2007/01/02 19:00:58 kurt Exp $ */
 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.  /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
  *   *
  * Copyright 1998-2008 The OpenLDAP Foundation.   * Copyright 1998-2007 The OpenLDAP Foundation.
  * All rights reserved.   * All rights reserved.
  *   *
  * Redistribution and use in source and binary forms, with or without   * Redistribution and use in source and binary forms, with or without
Line 244  chkResponseList( Line 244  chkResponseList(
                         "ldap_chkResponseList returns ld %p NULL\n", (void *)ld, 0, 0);                          "ldap_chkResponseList returns ld %p NULL\n", (void *)ld, 0, 0);
         } else {          } else {
                 Debug( LDAP_DEBUG_TRACE,                  Debug( LDAP_DEBUG_TRACE,
                         "ldap_chkResponseList returns ld %p msgid %d, type 0x%02lx\n",                          "ldap_chkResponseList returns ld %p msgid %d, type 0x%02lu\n",
                         (void *)ld, lm->lm_msgid, (unsigned long)lm->lm_msgtype );                          (void *)ld, lm->lm_msgid, (unsigned long)lm->lm_msgtype );
         }          }
 #endif  #endif
Line 263  wait4msg( Line 263  wait4msg(
         int             rc;          int             rc;
         struct timeval  tv = { 0 },          struct timeval  tv = { 0 },
                         tv0 = { 0 },                          tv0 = { 0 },
                         start_time_tv = { 0 },                          *tvp;
                         *tvp = NULL;          time_t          start_time = 0;
           time_t          tmp_time;
         LDAPConn        *lc;          LDAPConn        *lc;
   
         assert( ld != NULL );          assert( ld != NULL );
Line 274  wait4msg( Line 275  wait4msg(
         LDAP_PVT_THREAD_ASSERT_MUTEX_OWNER( &ld->ld_res_mutex );          LDAP_PVT_THREAD_ASSERT_MUTEX_OWNER( &ld->ld_res_mutex );
 #endif  #endif
   
         if ( timeout == NULL && ld->ld_options.ldo_tm_api.tv_sec >= 0 ) {  
                 tv = ld->ld_options.ldo_tm_api;  
                 timeout = &tv;  
         }  
   
 #ifdef LDAP_DEBUG  #ifdef LDAP_DEBUG
         if ( timeout == NULL ) {          if ( timeout == NULL ) {
                 Debug( LDAP_DEBUG_TRACE, "wait4msg ld %p msgid %d (infinite timeout)\n",                  Debug( LDAP_DEBUG_TRACE, "wait4msg ld %p msgid %d (infinite timeout)\n",
Line 289  wait4msg( Line 285  wait4msg(
         }          }
 #endif /* LDAP_DEBUG */  #endif /* LDAP_DEBUG */
   
         if ( timeout != NULL ) {          if ( timeout == NULL ) {
                   tvp = NULL;
           } else {
                 tv0 = *timeout;                  tv0 = *timeout;
                 tv = *timeout;                  tv = *timeout;
                 tvp = &tv;                  tvp = &tv;
 #ifdef HAVE_GETTIMEOFDAY                  start_time = time( NULL );
                 gettimeofday( &start_time_tv, NULL );  
 #else /* ! HAVE_GETTIMEOFDAY */  
                 time( &start_time_tv.tv_sec );  
                 start_time_tv.tv_usec = 0;  
 #endif /* ! HAVE_GETTIMEOFDAY */  
         }          }
                                           
         rc = LDAP_MSG_X_KEEP_LOOKING;          rc = LDAP_MSG_X_KEEP_LOOKING;
Line 322  wait4msg( Line 315  wait4msg(
                 }                  }
 #endif /* LDAP_DEBUG */  #endif /* LDAP_DEBUG */
   
                 if ( ( *result = chkResponseList( ld, msgid, all ) ) != NULL ) {                  if ( ( *result = chkResponseList( ld, msgid, all ) ) != NULL ) {
                         rc = (*result)->lm_msgtype;                          rc = (*result)->lm_msgtype;
   
                 } else {                  } else {
Line 350  wait4msg( Line 343  wait4msg(
                         ldap_pvt_thread_mutex_unlock( &ld->ld_conn_mutex );                          ldap_pvt_thread_mutex_unlock( &ld->ld_conn_mutex );
 #endif  #endif
   
                         if ( !lc_ready ) {                          if ( !lc_ready ) {
                                 int err;  
                                 rc = ldap_int_select( ld, tvp );                                  rc = ldap_int_select( ld, tvp );
                                 if ( rc == -1 ) {  
                                         err = sock_errno();  
 #ifdef LDAP_DEBUG  #ifdef LDAP_DEBUG
                                   if ( rc == -1 ) {
                                         Debug( LDAP_DEBUG_TRACE,                                          Debug( LDAP_DEBUG_TRACE,
                                                 "ldap_int_select returned -1: errno %d\n",                                                  "ldap_int_select returned -1: errno %d\n",
                                                 err, 0, 0 );                                                  sock_errno(), 0, 0 );
 #endif  
                                 }                                  }
   #endif
   
                                 if ( rc == 0 || ( rc == -1 && (                                  if ( rc == 0 || ( rc == -1 && (
                                         !LDAP_BOOL_GET(&ld->ld_options, LDAP_BOOL_RESTART)                                          !LDAP_BOOL_GET(&ld->ld_options, LDAP_BOOL_RESTART)
                                                 || err != EINTR ) ) )                                                  || sock_errno() != EINTR ) ) )
                                 {                                  {
                                         ld->ld_errno = (rc == -1 ? LDAP_SERVER_DOWN :                                          ld->ld_errno = (rc == -1 ? LDAP_SERVER_DOWN :
                                                 LDAP_TIMEOUT);                                                  LDAP_TIMEOUT);
Line 427  wait4msg( Line 418  wait4msg(
                 }                  }
   
                 if ( rc == LDAP_MSG_X_KEEP_LOOKING && tvp != NULL ) {                  if ( rc == LDAP_MSG_X_KEEP_LOOKING && tvp != NULL ) {
                         struct timeval  curr_time_tv = { 0 },                          tmp_time = time( NULL );
                                         delta_time_tv = { 0 };                          tv0.tv_sec -= ( tmp_time - start_time );
                           if ( tv0.tv_sec <= 0 ) {
 #ifdef HAVE_GETTIMEOFDAY                                  rc = 0; /* timed out */
                         gettimeofday( &curr_time_tv, NULL );  
 #else /* ! HAVE_GETTIMEOFDAY */  
                         time( &curr_time_tv.tv_sec );  
                         curr_time_tv.tv_usec = 0;  
 #endif /* ! HAVE_GETTIMEOFDAY */  
   
                         /* delta_time = tmp_time - start_time */  
                         delta_time_tv.tv_sec = curr_time_tv.tv_sec - start_time_tv.tv_sec;  
                         delta_time_tv.tv_usec = curr_time_tv.tv_usec - start_time_tv.tv_usec;  
                         if ( delta_time_tv.tv_usec < 0 ) {  
                                 delta_time_tv.tv_sec--;  
                                 delta_time_tv.tv_usec += 1000000;  
                         }  
   
                         /* tv0 < delta_time ? */  
                         if ( ( tv0.tv_sec < delta_time_tv.tv_sec ) ||  
                              ( ( tv0.tv_sec == delta_time_tv.tv_sec ) && ( tv0.tv_usec < delta_time_tv.tv_usec ) ) )  
                         {  
                                 rc = 0; /* timed out */  
                                 ld->ld_errno = LDAP_TIMEOUT;                                  ld->ld_errno = LDAP_TIMEOUT;
                                 break;                                  break;
                         }                          }
   
                         /* tv0 -= delta_time */  
                         tv0.tv_sec -= delta_time_tv.tv_sec;  
                         tv0.tv_usec -= delta_time_tv.tv_usec;  
                         if ( tv0.tv_usec < 0 ) {  
                                 tv0.tv_sec--;  
                                 tv0.tv_usec += 1000000;  
                         }  
   
                         tv.tv_sec = tv0.tv_sec;                          tv.tv_sec = tv0.tv_sec;
                         tv.tv_usec = tv0.tv_usec;  
   
                         Debug( LDAP_DEBUG_TRACE, "wait4msg ld %p %ld s %ld us to go\n",  
                                 (void *)ld, (long) tv.tv_sec, (long) tv.tv_usec );  
   
                         start_time_tv.tv_sec = curr_time_tv.tv_sec;                          Debug( LDAP_DEBUG_TRACE, "wait4msg ld %p %ld secs to go\n",
                         start_time_tv.tv_usec = curr_time_tv.tv_usec;                                  (void *)ld, (long) tv.tv_sec, 0 );
                           start_time = tmp_time;
                 }                  }
         }          }
   
Line 495  try_read1msg( Line 455  try_read1msg(
         LDAPRequest     *lr, *tmplr, dummy_lr = { 0 };          LDAPRequest     *lr, *tmplr, dummy_lr = { 0 };
         LDAPConn        *lc;          LDAPConn        *lc;
         BerElement      tmpber;          BerElement      tmpber;
         int             rc, refer_cnt, hadref, simple_request, err;          int             rc, refer_cnt, hadref, simple_request;
         ber_int_t       lderr;          ber_int_t       lderr;
   
 #ifdef LDAP_CONNECTIONLESS  #ifdef LDAP_CONNECTIONLESS
Line 549  nextresp3: Line 509  nextresp3:
                 break;                  break;
   
         case LBER_DEFAULT:          case LBER_DEFAULT:
                 err = sock_errno();  
 #ifdef LDAP_DEBUG                    #ifdef LDAP_DEBUG                  
                 Debug( LDAP_DEBUG_CONNS,                  Debug( LDAP_DEBUG_CONNS,
                         "ber_get_next failed.\n", 0, 0, 0 );                          "ber_get_next failed.\n", 0, 0, 0 );
 #endif               #endif             
 #ifdef EWOULDBLOCK                        #ifdef EWOULDBLOCK                      
                 if ( err == EWOULDBLOCK ) return LDAP_MSG_X_KEEP_LOOKING;                  if ( sock_errno() == EWOULDBLOCK ) return LDAP_MSG_X_KEEP_LOOKING;
 #endif  #endif
 #ifdef EAGAIN  #ifdef EAGAIN
                 if ( err == EAGAIN ) return LDAP_MSG_X_KEEP_LOOKING;                  if ( sock_errno() == EAGAIN ) return LDAP_MSG_X_KEEP_LOOKING;
 #endif  #endif
                 ld->ld_errno = LDAP_SERVER_DOWN;                  ld->ld_errno = LDAP_SERVER_DOWN;
 #ifdef LDAP_R_COMPILE  
                 ldap_pvt_thread_mutex_lock( &ld->ld_req_mutex );  
 #endif  
                 ldap_free_connection( ld, lc, 1, 0 );  
 #ifdef LDAP_R_COMPILE  
                 ldap_pvt_thread_mutex_unlock( &ld->ld_req_mutex );  
 #endif  
                 lc = *lcp = NULL;  
                 return -1;                  return -1;
   
         default:          default:
Line 585  nextresp3: Line 536  nextresp3:
   
         /* id == 0 iff unsolicited notification message (RFC 4511) */          /* id == 0 iff unsolicited notification message (RFC 4511) */
   
         /* id < 0 is invalid, just toss it. FIXME: should we disconnect? */  
         if ( id < 0 ) {  
                 goto retry_ber;  
         }  
           
         /* if it's been abandoned, toss it */          /* if it's been abandoned, toss it */
         if ( id > 0 ) {          if ( id > 0 ) {
                 if ( ldap_abandoned( ld, id, &idx ) ) {                  if ( ldap_abandoned( ld, id, &idx ) ) {
Line 610  nextresp3: Line 556  nextresp3:
                         }                          }
   
                         Debug( LDAP_DEBUG_ANY,                          Debug( LDAP_DEBUG_ANY,
                                 "abandoned/discarded ld %p msgid %d message type %s\n",                                  "abandoned/discarded ld %p msgid %ld message type %s\n",
                                 (void *)ld, id, ldap_int_msgtype2str( tag ) );                                  (void *)ld, (long)id, ldap_int_msgtype2str( tag ) );
   
 retry_ber:  retry_ber:
                         ber_free( ber, 1 );                          ber_free( ber, 1 );
Line 637  retry_ber: Line 583  retry_ber:
                         }                          }
   
                         Debug( LDAP_DEBUG_ANY,                          Debug( LDAP_DEBUG_ANY,
                                 "no request for response on ld %p msgid %d message type %s (tossing)\n",                                  "no request for response on ld %p msgid %ld message type %s (tossing)\n",
                                 (void *)ld, id, msg );                                  (void *)ld, (long)id, msg );
   
                         goto retry_ber;                          goto retry_ber;
                 }                  }
Line 648  retry_ber: Line 594  retry_ber:
                         ber_scanf(ber, "x{");                          ber_scanf(ber, "x{");
                 }                  }
 nextresp2:  nextresp2:
                 ;  
 #endif  #endif
         }          }
   
Line 661  nextresp2: Line 606  nextresp2:
         }          }
   
         Debug( LDAP_DEBUG_TRACE,          Debug( LDAP_DEBUG_TRACE,
                 "read1msg: ld %p msgid %d message type %s\n",                  "read1msg: ld %p msgid %ld message type %s\n",
                 (void *)ld, id, ldap_int_msgtype2str( tag ) );                  (void *)ld, (long)lr->lr_msgid, ldap_int_msgtype2str( tag ) );
   
         if ( id == 0 ) {          if ( id == 0 ) {
                 /* unsolicited notification message (RFC 4511) */                  /* unsolicited notification message (RFC 4511) */
Line 909  nextresp2: Line 854  nextresp2:
                         {                          {
                                 id = lr->lr_msgid;                                  id = lr->lr_msgid;
                                 tag = lr->lr_res_msgtype;                                  tag = lr->lr_res_msgtype;
                                 Debug( LDAP_DEBUG_TRACE, "request done: ld %p msgid %d\n",                                  Debug( LDAP_DEBUG_ANY, "request done: ld %p msgid %ld\n",
                                         (void *)ld, id, 0 );                                          (void *)ld, (long) id, 0 );
                                 Debug( LDAP_DEBUG_TRACE,                                  Debug( LDAP_DEBUG_TRACE,
                                         "res_errno: %d, res_error: <%s>, "                                          "res_errno: %d, res_error: <%s>, "
                                         "res_matched: <%s>\n",                                          "res_matched: <%s>\n",
Line 933  nextresp2: Line 878  nextresp2:
                                 lr = NULL;                                  lr = NULL;
                         }                          }
   
                         /*                          if ( lc != NULL ) {
                          * RF 4511 unsolicited (id == 0) responses  
                          * shouldn't necessarily end the connection  
                          */  
                         if ( lc != NULL && id != 0 ) {  
 #ifdef LDAP_R_COMPILE  #ifdef LDAP_R_COMPILE
                                 ldap_pvt_thread_mutex_lock( &ld->ld_req_mutex );                                  ldap_pvt_thread_mutex_lock( &ld->ld_req_mutex );
 #endif  #endif
Line 962  nextresp2: Line 903  nextresp2:
         }          }
   
         /* try to handle unsolicited responses as appropriate */          /* try to handle unsolicited responses as appropriate */
         if ( id == 0 && msgid > LDAP_RES_UNSOLICITED ) {          if ( id == 0 && msgid != LDAP_RES_UNSOLICITED ) {
                 int     is_nod = 0;                  int     is_nod = 0;
   
                 tag = ber_peek_tag( &tmpber, &len );                  tag = ber_peek_tag( ber, &len );
   
                 /* we have a res oid */                  /* we have a res oid */
                 if ( tag == LDAP_TAG_EXOP_RES_OID ) {                  if ( tag == LDAP_TAG_EXOP_RES_OID ) {
                         static struct berval    bv_nod = BER_BVC( LDAP_NOTICE_OF_DISCONNECTION );                          char    *resoid = NULL;
                         struct berval           resoid = BER_BVNULL;  
   
                         if ( ber_scanf( &tmpber, "m", &resoid ) == LBER_ERROR ) {                          if ( ber_scanf( ber, "a", &resoid ) == LBER_ERROR ) {
                                 ld->ld_errno = LDAP_DECODING_ERROR;                                  ld->ld_errno = LDAP_DECODING_ERROR;
                                 ber_free( ber, 1 );                                  ber_free( ber, 1 );
                                 return -1;                                  return -1;
                         }                          }
   
                         assert( !BER_BVISEMPTY( &resoid ) );                          assert( resoid[ 0 ] != '\0' );
   
                         is_nod = ber_bvcmp( &resoid, &bv_nod ) == 0;                          is_nod = strcmp( resoid, LDAP_NOTICE_OF_DISCONNECTION ) == 0;
                           LDAP_FREE( resoid );
   
                         tag = ber_peek_tag( &tmpber, &len );                          tag = ber_peek_tag( ber, &len );
                 }                  }
   
 #if 0 /* don't need right now */                  /* we have a res value */
                 /* we have res data */  
                 if ( tag == LDAP_TAG_EXOP_RES_VALUE ) {                  if ( tag == LDAP_TAG_EXOP_RES_VALUE ) {
                         struct berval resdata;                          /* don't need right now */
   
                         if ( ber_scanf( &tmpber, "m", &resdata ) == LBER_ERROR ) {  
                                 ld->ld_errno = LDAP_DECODING_ERROR;  
                                 ber_free( ber, 0 );  
                                 return ld->ld_errno;  
                         }  
   
                         /* use it... */  
                 }                  }
 #endif  
   
                 /* handle RFC 4511 "Notice of Disconnection" locally */                  /* handle RFC 4511 "Notice of Disconnection" locally */
   
Line 1018  nextresp2: Line 949  nextresp2:
 #ifdef LDAP_R_COMPILE  #ifdef LDAP_R_COMPILE
                                 ldap_pvt_thread_mutex_unlock( &ld->ld_req_mutex );                                  ldap_pvt_thread_mutex_unlock( &ld->ld_req_mutex );
 #endif  #endif
                                 lc = *lcp = NULL;                                  *lcp = NULL;
                         }                          }
   
                         /* need to return -1, because otherwise                          return LDAP_RES_EXTENDED;
                          * a valid result is expected */  
                         return -1;  
                 }                  }
         }          }
   
Line 1165  nextresp2: Line 1094  nextresp2:
                 goto exit;                  goto exit;
         }          }
   
         Debug( LDAP_DEBUG_TRACE, "adding response ld %p msgid %d type %ld:\n",          Debug( LDAP_DEBUG_TRACE, "adding response ld %p msgid %ld type %ld:\n",
                 (void *)ld, newmsg->lm_msgid, (long) newmsg->lm_msgtype );                  (void *)ld, (long) newmsg->lm_msgid, (long) newmsg->lm_msgtype );
   
         /* part of a search response - add to end of list of entries */          /* part of a search response - add to end of list of entries */
         l->lm_chain_tail->lm_chain = newmsg;          l->lm_chain_tail->lm_chain = newmsg;

Removed from v.1.124.2.13  
changed lines
  Added in v.1.146


______________
© Copyright 1998-2020, OpenLDAP Foundation, info@OpenLDAP.org