| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 1 | /* BEGIN_HEADER */ | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 2 | #include <polarssl/x509write.h> | 
|  | 3 | #include <polarssl/x509.h> | 
|  | 4 | #include <polarssl/pem.h> | 
| Paul Bakker | c70b982 | 2013-04-07 22:00:46 +0200 | [diff] [blame] | 5 | #include <polarssl/oid.h> | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 6 | /* END_HEADER */ | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 7 |  | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 8 | /* BEGIN_DEPENDENCIES | 
|  | 9 | * depends_on:POLARSSL_X509_WRITE_C:POLARSSL_BIGNUM_C | 
|  | 10 | * END_DEPENDENCIES | 
|  | 11 | */ | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 12 |  | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 13 | /* BEGIN_CASE */ | 
|  | 14 | void x509_cert_req_check( char *key_file, int md_type, | 
|  | 15 | char *cert_req_check_file ) | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 16 | { | 
|  | 17 | rsa_context rsa; | 
|  | 18 | pem_context pem; | 
|  | 19 | x509_req_name req_name, *cur; | 
|  | 20 | unsigned char *c; | 
|  | 21 | unsigned char buf[4000]; | 
|  | 22 | unsigned char check_buf[4000]; | 
|  | 23 | int ret; | 
|  | 24 | size_t olen = 2000; | 
|  | 25 | FILE *f; | 
|  | 26 |  | 
|  | 27 | cur = &req_name; | 
|  | 28 |  | 
|  | 29 | memset( cur, 0, sizeof(x509_req_name) ); | 
| Paul Bakker | c70b982 | 2013-04-07 22:00:46 +0200 | [diff] [blame] | 30 | strcpy( cur->oid, OID_AT_CN ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 31 | strcpy( cur->name, "PolarSSL Server 1" ); | 
|  | 32 | cur->next = malloc( sizeof(x509_req_name) ); | 
|  | 33 | cur = cur->next; | 
|  | 34 |  | 
|  | 35 | memset( cur, 0, sizeof(x509_req_name) ); | 
| Paul Bakker | c70b982 | 2013-04-07 22:00:46 +0200 | [diff] [blame] | 36 | strcpy( cur->oid, OID_AT_ORGANIZATION ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 37 | strcpy( cur->name, "PolarSSL" ); | 
|  | 38 | cur->next = malloc( sizeof(x509_req_name) ); | 
|  | 39 | cur = cur->next; | 
|  | 40 |  | 
|  | 41 | memset( cur, 0, sizeof(x509_req_name) ); | 
| Paul Bakker | c70b982 | 2013-04-07 22:00:46 +0200 | [diff] [blame] | 42 | strcpy( cur->oid, OID_AT_COUNTRY ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 43 | strcpy( cur->name, "NL" ); | 
|  | 44 |  | 
|  | 45 | memset( &rsa, 0, sizeof(rsa_context) ); | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 46 | ret = x509parse_keyfile_rsa( &rsa, key_file, NULL ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 47 | TEST_ASSERT( ret == 0 ); | 
|  | 48 | if( ret != 0 ) | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 49 | return; | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 50 |  | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 51 | ret = x509_write_cert_req( buf, 4000, &rsa, &req_name, md_type ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 52 | TEST_ASSERT( ret >= 0 ); | 
|  | 53 |  | 
|  | 54 | c = buf + 3999 - ret; | 
|  | 55 |  | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 56 | f = fopen( cert_req_check_file, "r" ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 57 | TEST_ASSERT( f != NULL ); | 
|  | 58 | fread( check_buf, 1, 4000, f ); | 
|  | 59 | fclose( f ); | 
|  | 60 |  | 
|  | 61 | pem_init( &pem ); | 
|  | 62 | pem_read_buffer( &pem, "-----BEGIN CERTIFICATE REQUEST-----", "-----END CERTIFICATE REQUEST-----", check_buf, NULL, 0, &olen ); | 
|  | 63 |  | 
|  | 64 | TEST_ASSERT( memcmp( c, pem.buf, pem.buflen ) == 0 ); | 
|  | 65 | TEST_ASSERT( pem.buflen == (size_t) ret ); | 
| Paul Bakker | 58ef6ec | 2013-01-03 11:33:48 +0100 | [diff] [blame] | 66 |  | 
|  | 67 | while( ( cur = req_name.next ) != NULL ) | 
|  | 68 | { | 
|  | 69 | req_name.next = cur->next; | 
|  | 70 | free( cur ); | 
|  | 71 | } | 
|  | 72 |  | 
|  | 73 | rsa_free( &rsa ); | 
|  | 74 | pem_free( &pem ); | 
| Paul Bakker | 6d62050 | 2012-02-16 14:09:13 +0000 | [diff] [blame] | 75 | } | 
| Paul Bakker | 33b43f1 | 2013-08-20 11:48:36 +0200 | [diff] [blame] | 76 | /* END_CASE */ |