Diff for /libraries/liblber/decode.c between versions 1.105.2.5 and 1.106

version 1.105.2.5, 2008/09/02 23:54:37 version 1.106, 2007/01/02 19:00:57
Line 1 Line 1
 /* decode.c - ber input decoding routines */  /* decode.c - ber input decoding routines */
 /* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.105.2.4 2008/02/11 23:26:41 kurt Exp $ */  /* $OpenLDAP: pkg/ldap/libraries/liblber/decode.c,v 1.105 2006/02/14 22:18:12 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 45  static ber_len_t ber_getnint LDAP_P(( Line 45  static ber_len_t ber_getnint LDAP_P((
         ber_int_t *num,          ber_int_t *num,
         ber_len_t len ));          ber_len_t len ));
   
 /* out->bv_len should be the buffer size on input */  
 int  
 ber_decode_oid( BerValue *in, BerValue *out )  
 {  
         const unsigned char *der;  
         unsigned long val;  
         unsigned val1;  
         ber_len_t i;  
         char *ptr;  
   
         assert( in != NULL );  
         assert( out != NULL );  
   
         /* need 4 chars/inbyte + \0 for input={7f 7f 7f...} */  
         if ( !out->bv_val || (out->bv_len+3)/4 <= in->bv_len )  
                 return -1;  
   
         ptr = NULL;  
         der = (unsigned char *) in->bv_val;  
         val = 0;  
         for ( i=0; i < in->bv_len; i++ ) {  
                 val |= der[i] & 0x7f;  
                 if ( !( der[i] & 0x80 )) {  
                         if ( ptr == NULL ) {  
                                 /* Initial "x.y": val=x*40+y, x<=2, y<40 if x<2 */  
                                 ptr = out->bv_val;  
                                 val1 = (val < 80 ? val/40 : 2);  
                                 val -= val1*40;  
                                 ptr += sprintf( ptr, "%u", val1 );  
                         }  
                         ptr += sprintf( ptr, ".%lu", val );  
                         val = 0;  
                 } else if ( val - 1UL < LBER_OID_COMPONENT_MAX >> 7 ) {  
                         val <<= 7;  
                 } else {  
                         /* val would overflow, or is 0 from invalid initial 0x80 octet */  
                         return -1;  
                 }  
         }  
         if ( ptr == NULL || val != 0 )  
                 return -1;  
   
         out->bv_len = ptr - out->bv_val;  
         return 0;  
 }  
   
 /* return the tag - LBER_DEFAULT returned means trouble */  /* return the tag - LBER_DEFAULT returned means trouble */
 ber_tag_t  ber_tag_t
 ber_get_tag( BerElement *ber )  ber_get_tag( BerElement *ber )
Line 419  ber_get_stringbvl( bgbvr *b, ber_len_t * Line 373  ber_get_stringbvl( bgbvr *b, ber_len_t *
         case BvOff:          case BvOff:
                 *b->res.ba = ber_memalloc_x( (n+1) * b->siz, b->ber->ber_memctx );                  *b->res.ba = ber_memalloc_x( (n+1) * b->siz, b->ber->ber_memctx );
                 if ( *b->res.ba == NULL ) return LBER_DEFAULT;                  if ( *b->res.ba == NULL ) return LBER_DEFAULT;
                 ((struct berval *)((char *)(*b->res.ba) + n*b->siz +                  ((struct berval *)((long)(*b->res.ba) + n*b->siz +
                         b->off))->bv_val = NULL;                          b->off))->bv_val = NULL;
                 break;                  break;
         }          }
Line 452  ber_get_stringbvl( bgbvr *b, ber_len_t * Line 406  ber_get_stringbvl( bgbvr *b, ber_len_t *
                         *bvp = bv;                          *bvp = bv;
                         break;                          break;
                 case BvOff:                  case BvOff:
                         *(BerVarray)((char *)(*b->res.ba)+n*b->siz+b->off) = bv;                          *(BerVarray)((long)(*b->res.ba)+n*b->siz+b->off) = bv;
                         break;                          break;
                 }                  }
         }          }
Line 483  nomem: Line 437  nomem:
 }  }
   
 ber_tag_t  ber_tag_t
 ber_get_stringbv( BerElement *ber, struct berval *bv, int option )  ber_get_stringbv( BerElement *ber, struct berval *bv, int alloc )
 {  {
         ber_tag_t       tag;          ber_tag_t       tag;
   
Line 501  ber_get_stringbv( BerElement *ber, struc Line 455  ber_get_stringbv( BerElement *ber, struc
                 return LBER_DEFAULT;                  return LBER_DEFAULT;
         }          }
   
         if ( option & LBER_BV_ALLOC ) {          if ( alloc ) {
                 bv->bv_val = (char *) ber_memalloc_x( bv->bv_len + 1,                  bv->bv_val = (char *) ber_memalloc_x( bv->bv_len + 1,
                         ber->ber_memctx );                          ber->ber_memctx );
                 if ( bv->bv_val == NULL ) {                  if ( bv->bv_val == NULL ) {
Line 520  ber_get_stringbv( BerElement *ber, struc Line 474  ber_get_stringbv( BerElement *ber, struc
                 ber->ber_ptr += bv->bv_len;                  ber->ber_ptr += bv->bv_len;
         }          }
         ber->ber_tag = *(unsigned char *)ber->ber_ptr;          ber->ber_tag = *(unsigned char *)ber->ber_ptr;
         if ( !( option & LBER_BV_NOTERM ))          bv->bv_val[bv->bv_len] = '\0';
                 bv->bv_val[bv->bv_len] = '\0';  
   
         return tag;          return tag;
 }  }
   
 ber_tag_t  ber_tag_t
 ber_get_stringbv_null( BerElement *ber, struct berval *bv, int option )  ber_get_stringbv_null( BerElement *ber, struct berval *bv, int alloc )
 {  {
         ber_tag_t       tag;          ber_tag_t       tag;
   
Line 551  ber_get_stringbv_null( BerElement *ber, Line 504  ber_get_stringbv_null( BerElement *ber,
                 return tag;                  return tag;
         }          }
   
         if ( option & LBER_BV_ALLOC ) {          if ( alloc ) {
                 bv->bv_val = (char *) ber_memalloc_x( bv->bv_len + 1,                  bv->bv_val = (char *) ber_memalloc_x( bv->bv_len + 1,
                         ber->ber_memctx );                          ber->ber_memctx );
                 if ( bv->bv_val == NULL ) {                  if ( bv->bv_val == NULL ) {
Line 570  ber_get_stringbv_null( BerElement *ber, Line 523  ber_get_stringbv_null( BerElement *ber,
                 ber->ber_ptr += bv->bv_len;                  ber->ber_ptr += bv->bv_len;
         }          }
         ber->ber_tag = *(unsigned char *)ber->ber_ptr;          ber->ber_tag = *(unsigned char *)ber->ber_ptr;
         if ( !( option & LBER_BV_NOTERM ))          bv->bv_val[bv->bv_len] = '\0';
                 bv->bv_val[bv->bv_len] = '\0';  
   
         return tag;          return tag;
 }  }
Line 584  ber_get_stringa( BerElement *ber, char * Line 536  ber_get_stringa( BerElement *ber, char *
   
         assert( buf != NULL );          assert( buf != NULL );
   
         tag = ber_get_stringbv( ber, &bv, LBER_BV_ALLOC );          tag = ber_get_stringbv( ber, &bv, 1 );
         *buf = bv.bv_val;          *buf = bv.bv_val;
   
         return tag;          return tag;
Line 598  ber_get_stringa_null( BerElement *ber, c Line 550  ber_get_stringa_null( BerElement *ber, c
   
         assert( buf != NULL );          assert( buf != NULL );
   
         tag = ber_get_stringbv_null( ber, &bv, LBER_BV_ALLOC );          tag = ber_get_stringbv_null( ber, &bv, 1 );
         *buf = bv.bv_val;          *buf = bv.bv_val;
   
         return tag;          return tag;
Line 618  ber_get_stringal( BerElement *ber, struc Line 570  ber_get_stringal( BerElement *ber, struc
                 return LBER_DEFAULT;                  return LBER_DEFAULT;
         }          }
   
         tag = ber_get_stringbv( ber, *bv, LBER_BV_ALLOC );          tag = ber_get_stringbv( ber, *bv, 1 );
         if ( tag == LBER_DEFAULT ) {          if ( tag == LBER_DEFAULT ) {
                 LBER_FREE( *bv );                  LBER_FREE( *bv );
                 *bv = NULL;                  *bv = NULL;
Line 780  ber_scanf ( BerElement *ber, Line 732  ber_scanf ( BerElement *ber,
   
         fmt_reset = fmt;          fmt_reset = fmt;
   
         if ( ber->ber_debug & (LDAP_DEBUG_TRACE|LDAP_DEBUG_BER)) {          ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug,
                 ber_log_printf( LDAP_DEBUG_TRACE, ber->ber_debug,                  "ber_scanf fmt (%s) ber:\n", fmt );
                         "ber_scanf fmt (%s) ber:\n", fmt );          ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 );
                 ber_log_dump( LDAP_DEBUG_BER, ber->ber_debug, ber, 1 );  
         }  
   
         for ( rc = 0; *fmt && rc != LBER_DEFAULT; fmt++ ) {          for ( rc = 0; *fmt && rc != LBER_DEFAULT; fmt++ ) {
                 /* When this is modified, remember to update                  /* When this is modified, remember to update
Line 861  ber_scanf ( BerElement *ber, Line 811  ber_scanf ( BerElement *ber,
   
                 case 'o':       /* octet string in a supplied berval */                  case 'o':       /* octet string in a supplied berval */
                         bval = va_arg( ap, struct berval * );                          bval = va_arg( ap, struct berval * );
                         rc = ber_get_stringbv( ber, bval, LBER_BV_ALLOC );                          rc = ber_get_stringbv( ber, bval, 1 );
                         break;                          break;
   
                 case 'O':       /* octet string - allocate & include length */                  case 'O':       /* octet string - allocate & include length */
Line 890  ber_scanf ( BerElement *ber, Line 840  ber_scanf ( BerElement *ber,
                         bgbvr cookie = { ChArray };                          bgbvr cookie = { ChArray };
                         cookie.ber = ber;                          cookie.ber = ber;
                         cookie.res.c = va_arg( ap, char *** );                          cookie.res.c = va_arg( ap, char *** );
                         cookie.alloc = LBER_BV_ALLOC;                          cookie.alloc = 1;
                         rc = ber_get_stringbvl( &cookie, NULL );                          rc = ber_get_stringbvl( &cookie, NULL );
                         break;                          break;
                 }                  }
Line 900  ber_scanf ( BerElement *ber, Line 850  ber_scanf ( BerElement *ber,
                         bgbvr cookie = { BvVec };                          bgbvr cookie = { BvVec };
                         cookie.ber = ber;                          cookie.ber = ber;
                         cookie.res.bv = va_arg( ap, struct berval *** );                          cookie.res.bv = va_arg( ap, struct berval *** );
                         cookie.alloc = LBER_BV_ALLOC;                          cookie.alloc = 1;
                         rc = ber_get_stringbvl( &cookie, NULL );                          rc = ber_get_stringbvl( &cookie, NULL );
                         break;                          break;
                 }                  }
Line 910  ber_scanf ( BerElement *ber, Line 860  ber_scanf ( BerElement *ber,
                         bgbvr cookie = { BvArray };                          bgbvr cookie = { BvArray };
                         cookie.ber = ber;                          cookie.ber = ber;
                         cookie.res.ba = va_arg( ap, struct berval ** );                          cookie.res.ba = va_arg( ap, struct berval ** );
                         cookie.alloc = LBER_BV_ALLOC;                          cookie.alloc = 1;
                         rc = ber_get_stringbvl( &cookie, NULL );                          rc = ber_get_stringbvl( &cookie, NULL );
                         break;                          break;
                 }                  }

Removed from v.1.105.2.5  
changed lines
  Added in v.1.106


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