1
0
mirror of https://github.com/irssi/irssi.git synced 2025-01-03 14:56:47 -05:00

Merge pull request #1036 from berkerpeksag/fix-bio-read

Check return value of BIO_read() in set_pubkey_info()
This commit is contained in:
ailin-nemui 2019-04-24 13:51:06 +02:00 committed by GitHub
commit 2db6e99038
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -601,18 +601,19 @@ static void set_cipher_info(TLS_REC *tls, SSL *ssl)
tls_rec_set_cipher_size(tls, SSL_get_cipher_bits(ssl, NULL)); tls_rec_set_cipher_size(tls, SSL_get_cipher_bits(ssl, NULL));
} }
static void set_pubkey_info(TLS_REC *tls, X509 *cert, unsigned char *cert_fingerprint, size_t cert_fingerprint_size, unsigned char *public_key_fingerprint, size_t public_key_fingerprint_size) static gboolean set_pubkey_info(TLS_REC *tls, X509 *cert, unsigned char *cert_fingerprint, size_t cert_fingerprint_size, unsigned char *public_key_fingerprint, size_t public_key_fingerprint_size)
{ {
gboolean ret = TRUE;
EVP_PKEY *pubkey = NULL; EVP_PKEY *pubkey = NULL;
char *cert_fingerprint_hex = NULL; char *cert_fingerprint_hex = NULL;
char *public_key_fingerprint_hex = NULL; char *public_key_fingerprint_hex = NULL;
BIO *bio = NULL; BIO *bio = NULL;
char buffer[128]; char buffer[128];
size_t length; ssize_t length;
g_return_if_fail(tls != NULL); g_return_val_if_fail(tls != NULL, FALSE);
g_return_if_fail(cert != NULL); g_return_val_if_fail(cert != NULL, FALSE);
pubkey = X509_get_pubkey(cert); pubkey = X509_get_pubkey(cert);
@ -648,6 +649,11 @@ static void set_pubkey_info(TLS_REC *tls, X509 *cert, unsigned char *cert_finger
bio = BIO_new(BIO_s_mem()); bio = BIO_new(BIO_s_mem());
ASN1_TIME_print(bio, X509_get_notBefore(cert)); ASN1_TIME_print(bio, X509_get_notBefore(cert));
length = BIO_read(bio, buffer, sizeof(buffer)); length = BIO_read(bio, buffer, sizeof(buffer));
if (length < 0) {
ret = FALSE;
BIO_free(bio);
goto done;
}
buffer[length] = '\0'; buffer[length] = '\0';
BIO_free(bio); BIO_free(bio);
tls_rec_set_not_before(tls, buffer); tls_rec_set_not_before(tls, buffer);
@ -656,13 +662,21 @@ static void set_pubkey_info(TLS_REC *tls, X509 *cert, unsigned char *cert_finger
bio = BIO_new(BIO_s_mem()); bio = BIO_new(BIO_s_mem());
ASN1_TIME_print(bio, X509_get_notAfter(cert)); ASN1_TIME_print(bio, X509_get_notAfter(cert));
length = BIO_read(bio, buffer, sizeof(buffer)); length = BIO_read(bio, buffer, sizeof(buffer));
if (length < 0) {
ret = FALSE;
BIO_free(bio);
goto done;
}
buffer[length] = '\0'; buffer[length] = '\0';
BIO_free(bio); BIO_free(bio);
tls_rec_set_not_after(tls, buffer); tls_rec_set_not_after(tls, buffer);
done:
g_free(cert_fingerprint_hex); g_free(cert_fingerprint_hex);
g_free(public_key_fingerprint_hex); g_free(public_key_fingerprint_hex);
EVP_PKEY_free(pubkey); EVP_PKEY_free(pubkey);
return ret;
} }
static void set_peer_cert_chain_info(TLS_REC *tls, SSL *ssl) static void set_peer_cert_chain_info(TLS_REC *tls, SSL *ssl)
@ -881,7 +895,11 @@ int irssi_ssl_handshake(GIOChannel *handle)
tls = tls_create_rec(); tls = tls_create_rec();
set_cipher_info(tls, chan->ssl); set_cipher_info(tls, chan->ssl);
set_pubkey_info(tls, cert, cert_fingerprint, cert_fingerprint_size, pubkey_fingerprint, pubkey_fingerprint_size); if (! set_pubkey_info(tls, cert, cert_fingerprint, cert_fingerprint_size, pubkey_fingerprint, pubkey_fingerprint_size)) {
g_warning("Couldn't set pubkey information");
ret = 0;
goto done;
}
set_peer_cert_chain_info(tls, chan->ssl); set_peer_cert_chain_info(tls, chan->ssl);
set_server_temporary_key_info(tls, chan->ssl); set_server_temporary_key_info(tls, chan->ssl);