From be50680a8cdd4d972278015a4be86750f4a4af8b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Manuel=20P=C3=A9gouri=C3=A9-Gonnard?= Date: Thu, 11 Jul 2013 13:17:21 +0200 Subject: [PATCH] Fix use of x509_cert.rsa in programs --- programs/test/ssl_cert_test.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/programs/test/ssl_cert_test.c b/programs/test/ssl_cert_test.c index bf4684b2f2..ec824c9eb1 100644 --- a/programs/test/ssl_cert_test.c +++ b/programs/test/ssl_cert_test.c @@ -206,19 +206,28 @@ int main( int argc, char *argv[] ) printf( " ok\n" ); /* - * 1.5. Verify certificate validity with private key + * 1.6. Verify certificate validity with private key */ printf( " . Verify the client certificate with private key..." ); fflush( stdout ); - ret = mpi_cmp_mpi(&rsa.N, &clicert.rsa.N); + + /* EC NOT IMPLEMENTED YET */ + if( clicert.pk.type != POLARSSL_PK_RSA ) + { + printf( " failed\n ! certificate's key is not RSA\n\n" ); + ret = POLARSSL_ERR_X509_FEATURE_UNAVAILABLE; + goto exit; + } + + ret = mpi_cmp_mpi(&rsa.N, &pk_rsa( clicert.pk )->N); if( ret != 0 ) { printf( " failed\n ! mpi_cmp_mpi for N returned %d\n\n", ret ); goto exit; } - ret = mpi_cmp_mpi(&rsa.E, &clicert.rsa.E); + ret = mpi_cmp_mpi(&rsa.E, &pk_rsa( clicert.pk )->E); if( ret != 0 ) { printf( " failed\n ! mpi_cmp_mpi for E returned %d\n\n", ret );