Fix uninitialized access (random error message) in certificate verification

This commit is contained in:
Florian Zeitz 2012-09-17 16:48:49 +02:00
parent 1aa89e25dd
commit 1ef41f4eb6

View file

@ -389,13 +389,17 @@ ssl_locking_callback(int mode, int n, const char *file, int line)
{
unsigned long ret;
if ((SSL_get_peer_certificate(ssl) == NULL) ||
((ret = SSL_get_verify_result(ssl)) != X509_V_OK)) {
const char *reason = X509_verify_cert_error_string(ret);
if (SSL_get_peer_certificate(ssl) != NULL) {
if ((ret = SSL_get_verify_result(ssl)) != X509_V_OK) {
const char *tmp = X509_verify_cert_error_string(ret);
OFString *reason = [OFString stringWithUTF8String: tmp];
@throw [SSLInvalidCertificateException
exceptionWithClass: [self class]
reason: [OFString
stringWithUTF8String: reason]];
reason: reason];
}
} else
@throw [SSLInvalidCertificateException
exceptionWithClass: [self class]
reason: @"No certificate"];
}
@end