mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-02-26 03:40:26 +00:00
tls13: server: Fix state update in CLIENT_CERTIFICATE
The state should be updated only if the handler returns in success. Signed-off-by: Ronald Cron <ronald.cron@arm.com>
This commit is contained in:
parent
6994e3e0c2
commit
209cae9c42
@ -1628,14 +1628,17 @@ int mbedtls_ssl_tls13_handshake_server_step( mbedtls_ssl_context *ssl )
|
|||||||
|
|
||||||
case MBEDTLS_SSL_CLIENT_CERTIFICATE:
|
case MBEDTLS_SSL_CLIENT_CERTIFICATE:
|
||||||
ret = mbedtls_ssl_tls13_process_certificate( ssl );
|
ret = mbedtls_ssl_tls13_process_certificate( ssl );
|
||||||
if( ret == 0 && ssl->session_negotiate->peer_cert != NULL )
|
if( ret == 0 )
|
||||||
{
|
{
|
||||||
mbedtls_ssl_handshake_set_state(
|
if( ssl->session_negotiate->peer_cert != NULL )
|
||||||
ssl, MBEDTLS_SSL_CLIENT_CERTIFICATE_VERIFY );
|
{
|
||||||
|
mbedtls_ssl_handshake_set_state(
|
||||||
|
ssl, MBEDTLS_SSL_CLIENT_CERTIFICATE_VERIFY );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
mbedtls_ssl_handshake_set_state(
|
||||||
|
ssl, MBEDTLS_SSL_CLIENT_FINISHED );
|
||||||
}
|
}
|
||||||
else
|
|
||||||
mbedtls_ssl_handshake_set_state(
|
|
||||||
ssl, MBEDTLS_SSL_CLIENT_FINISHED );
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MBEDTLS_SSL_CLIENT_CERTIFICATE_VERIFY:
|
case MBEDTLS_SSL_CLIENT_CERTIFICATE_VERIFY:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user