Makes base64Decode generally more tolerant of whitespace
q = data;
p = str;
- while (*p && *p && (*p == '=' || strchr(base64_chars, *p))) {
- unsigned int val = token_decode(p);
- unsigned int marker = (val >> 24) & 0xff;
+ while (*p && (*p == '=' || strchr(base64_chars, *p) || isspace(*p))) {
+ unsigned int val;
+ unsigned int marker;
+ if (isspace(*p)) {
+ p++;
+ continue;
+ }
+ val = token_decode(p);
+ marker = (val >> 24) & 0xff;
if (val == DECODE_ERROR)
return -1;
*q++ = (val >> 16) & 0xff;
if (marker < 1)
*q++ = val & 0xff;
p += 4;
- if (*p == '\n')
- p++;
}
return q - (unsigned char *) data;
}
blobLength = base64Decode(caCertificate, blobData);
- if ((blobLength <= 0) ||
- (blobLength < maxLength - 2)) {
+ if (blobLength <= 0) {
major = GSS_S_DEFECTIVE_CREDENTIAL;
*minor = GSSEAP_BAD_CACERTIFICATE;
GSSEAP_FREE(blobData);