Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 1 | #!/usr/bin/env python3 |
| 2 | |
| 3 | """ |
| 4 | Generate `tests/src/test_certs.h` which includes certficaties/keys/certificate list for testing. |
| 5 | """ |
| 6 | |
| 7 | # |
| 8 | # Copyright The Mbed TLS Contributors |
Dave Rodgman | 16799db | 2023-11-02 19:47:20 +0000 | [diff] [blame] | 9 | # SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 10 | |
| 11 | |
| 12 | import os |
| 13 | import sys |
| 14 | import argparse |
| 15 | import jinja2 |
Valerio Setti | 5f37b25 | 2024-05-03 15:34:06 +0200 | [diff] [blame] | 16 | import scripts_path # pylint: disable=unused-import |
| 17 | from mbedtls_dev.build_tree import guess_project_root |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 18 | |
Valerio Setti | 5f37b25 | 2024-05-03 15:34:06 +0200 | [diff] [blame] | 19 | TEST_DIR = os.path.join(guess_project_root(), 'tests') |
| 20 | DATA_FILES_PATH = os.path.join(TEST_DIR, 'data_files') |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 21 | |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 22 | INPUT_ARGS = [ |
Valerio Setti | f27d407 | 2024-04-16 16:17:45 +0200 | [diff] [blame] | 23 | ("string", "TEST_CA_CRT_EC_PEM", DATA_FILES_PATH + "/test-ca2.crt"), |
| 24 | ("binary", "TEST_CA_CRT_EC_DER", DATA_FILES_PATH + "/test-ca2.crt.der"), |
| 25 | ("string", "TEST_CA_KEY_EC_PEM", DATA_FILES_PATH + "/test-ca2.key.enc"), |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 26 | ("password", "TEST_CA_PWD_EC_PEM", "PolarSSLTest"), |
Valerio Setti | f27d407 | 2024-04-16 16:17:45 +0200 | [diff] [blame] | 27 | ("binary", "TEST_CA_KEY_EC_DER", DATA_FILES_PATH + "/test-ca2.key.der"), |
| 28 | ("string", "TEST_CA_CRT_RSA_SHA256_PEM", DATA_FILES_PATH + "/test-ca-sha256.crt"), |
| 29 | ("binary", "TEST_CA_CRT_RSA_SHA256_DER", DATA_FILES_PATH + "/test-ca-sha256.crt.der"), |
| 30 | ("string", "TEST_CA_CRT_RSA_SHA1_PEM", DATA_FILES_PATH + "/test-ca-sha1.crt"), |
| 31 | ("binary", "TEST_CA_CRT_RSA_SHA1_DER", DATA_FILES_PATH + "/test-ca-sha1.crt.der"), |
| 32 | ("string", "TEST_CA_KEY_RSA_PEM", DATA_FILES_PATH + "/test-ca.key"), |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 33 | ("password", "TEST_CA_PWD_RSA_PEM", "PolarSSLTest"), |
Valerio Setti | f27d407 | 2024-04-16 16:17:45 +0200 | [diff] [blame] | 34 | ("binary", "TEST_CA_KEY_RSA_DER", DATA_FILES_PATH + "/test-ca.key.der"), |
| 35 | ("string", "TEST_SRV_CRT_EC_PEM", DATA_FILES_PATH + "/server5.crt"), |
| 36 | ("binary", "TEST_SRV_CRT_EC_DER", DATA_FILES_PATH + "/server5.crt.der"), |
| 37 | ("string", "TEST_SRV_KEY_EC_PEM", DATA_FILES_PATH + "/server5.key"), |
| 38 | ("binary", "TEST_SRV_KEY_EC_DER", DATA_FILES_PATH + "/server5.key.der"), |
| 39 | ("string", "TEST_SRV_CRT_RSA_SHA256_PEM", DATA_FILES_PATH + "/server2-sha256.crt"), |
| 40 | ("binary", "TEST_SRV_CRT_RSA_SHA256_DER", DATA_FILES_PATH + "/server2-sha256.crt.der"), |
| 41 | ("string", "TEST_SRV_CRT_RSA_SHA1_PEM", DATA_FILES_PATH + "/server2.crt"), |
| 42 | ("binary", "TEST_SRV_CRT_RSA_SHA1_DER", DATA_FILES_PATH + "/server2.crt.der"), |
| 43 | ("string", "TEST_SRV_KEY_RSA_PEM", DATA_FILES_PATH + "/server2.key"), |
| 44 | ("binary", "TEST_SRV_KEY_RSA_DER", DATA_FILES_PATH + "/server2.key.der"), |
| 45 | ("string", "TEST_CLI_CRT_EC_PEM", DATA_FILES_PATH + "/cli2.crt"), |
| 46 | ("binary", "TEST_CLI_CRT_EC_DER", DATA_FILES_PATH + "/cli2.crt.der"), |
| 47 | ("string", "TEST_CLI_KEY_EC_PEM", DATA_FILES_PATH + "/cli2.key"), |
| 48 | ("binary", "TEST_CLI_KEY_EC_DER", DATA_FILES_PATH + "/cli2.key.der"), |
| 49 | ("string", "TEST_CLI_CRT_RSA_PEM", DATA_FILES_PATH + "/cli-rsa-sha256.crt"), |
| 50 | ("binary", "TEST_CLI_CRT_RSA_DER", DATA_FILES_PATH + "/cli-rsa-sha256.crt.der"), |
| 51 | ("string", "TEST_CLI_KEY_RSA_PEM", DATA_FILES_PATH + "/cli-rsa.key"), |
| 52 | ("binary", "TEST_CLI_KEY_RSA_DER", DATA_FILES_PATH + "/cli-rsa.key.der"), |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 53 | ] |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 54 | |
| 55 | def main(): |
| 56 | parser = argparse.ArgumentParser() |
Valerio Setti | 5f37b25 | 2024-05-03 15:34:06 +0200 | [diff] [blame] | 57 | default_output_path = os.path.join(TEST_DIR, 'src', 'test_certs.h') |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 58 | parser.add_argument('--output', type=str, default=default_output_path) |
| 59 | parser.add_argument('--list-dependencies', action='store_true') |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 60 | args = parser.parse_args() |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 61 | |
Valerio Setti | 5f37b25 | 2024-05-03 15:34:06 +0200 | [diff] [blame] | 62 | if args.list_dependencies: |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 63 | files_list = [arg[2] for arg in INPUT_ARGS] |
| 64 | print(" ".join(files_list)) |
| 65 | return |
| 66 | |
Valerio Setti | f27d407 | 2024-04-16 16:17:45 +0200 | [diff] [blame] | 67 | generate(INPUT_ARGS, output=args.output) |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 68 | |
Jerry Yu | 99a82dd | 2023-05-24 15:02:11 +0800 | [diff] [blame] | 69 | #pylint: disable=dangerous-default-value, unused-argument |
Valerio Setti | 455fb4e | 2024-04-15 06:30:18 +0200 | [diff] [blame] | 70 | def generate(values=[], output=None): |
Jerry Yu | 99a82dd | 2023-05-24 15:02:11 +0800 | [diff] [blame] | 71 | """Generate C header file. |
| 72 | """ |
Valerio Setti | f27d407 | 2024-04-16 16:17:45 +0200 | [diff] [blame] | 73 | template_loader = jinja2.FileSystemLoader(DATA_FILES_PATH) |
Jerry Yu | 5811869 | 2023-05-23 16:14:47 +0800 | [diff] [blame] | 74 | template_env = jinja2.Environment( |
| 75 | loader=template_loader, lstrip_blocks=True, trim_blocks=True) |
| 76 | |
| 77 | def read_as_c_array(filename): |
| 78 | with open(filename, 'rb') as f: |
| 79 | data = f.read(12) |
| 80 | while data: |
| 81 | yield ', '.join(['{:#04x}'.format(b) for b in data]) |
| 82 | data = f.read(12) |
| 83 | |
| 84 | def read_lines(filename): |
| 85 | with open(filename) as f: |
| 86 | try: |
| 87 | for line in f: |
| 88 | yield line.strip() |
| 89 | except: |
| 90 | print(filename) |
| 91 | raise |
| 92 | |
| 93 | def put_to_column(value, position=0): |
| 94 | return ' '*position + value |
| 95 | |
| 96 | template_env.filters['read_as_c_array'] = read_as_c_array |
| 97 | template_env.filters['read_lines'] = read_lines |
| 98 | template_env.filters['put_to_column'] = put_to_column |
| 99 | |
| 100 | template = template_env.get_template('test_certs.h.jinja2') |
| 101 | |
| 102 | with open(output, 'w') as f: |
| 103 | f.write(template.render(macros=values)) |
| 104 | |
| 105 | |
| 106 | if __name__ == '__main__': |
| 107 | sys.exit(main()) |