xref: /openbsd-src/regress/usr.sbin/rpki-client/test-spl.c (revision 5af821209fa3336ed87da6b82b004b70a12d2594)
1*5af82120Sclaudio /*	$Id: test-spl.c,v 1.3 2024/04/22 05:54:01 claudio Exp $ */
2a6584db8Sjob /*
3a6584db8Sjob  * Copyright (c) 2024 Job Snijders <job@fastly.com>
4a6584db8Sjob  * Copyright (c) 2019 Kristaps Dzonsons <kristaps@bsd.lv>
5a6584db8Sjob  *
6a6584db8Sjob  * Permission to use, copy, modify, and distribute this software for any
7a6584db8Sjob  * purpose with or without fee is hereby granted, provided that the above
8a6584db8Sjob  * copyright notice and this permission notice appear in all copies.
9a6584db8Sjob  *
10a6584db8Sjob  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11a6584db8Sjob  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12a6584db8Sjob  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13a6584db8Sjob  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14a6584db8Sjob  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15a6584db8Sjob  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16a6584db8Sjob  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17a6584db8Sjob  */
18a6584db8Sjob 
19a6584db8Sjob #include <assert.h>
20a6584db8Sjob #include <err.h>
21a6584db8Sjob #include <inttypes.h>
22a6584db8Sjob #include <stdio.h>
23a6584db8Sjob #include <stdlib.h>
24a6584db8Sjob #include <string.h>
25a6584db8Sjob #include <unistd.h>
26a6584db8Sjob 
27a6584db8Sjob #include <openssl/err.h>
28a6584db8Sjob #include <openssl/evp.h>
29a6584db8Sjob #include <openssl/pem.h>
30a6584db8Sjob #include <openssl/x509v3.h>
31a6584db8Sjob 
32a6584db8Sjob #include "extern.h"
33a6584db8Sjob 
34a6584db8Sjob int outformats;
35a6584db8Sjob int verbose;
36229518c6Sjob int filemode = 1;
37*5af82120Sclaudio int experimental;
38a6584db8Sjob 
39a6584db8Sjob int
main(int argc,char * argv[])40a6584db8Sjob main(int argc, char *argv[])
41a6584db8Sjob {
42a6584db8Sjob 	int		 c, i, ppem = 0, verb = 0;
43a6584db8Sjob 	X509		*xp = NULL;
44a6584db8Sjob 	struct spl	*p;
45a6584db8Sjob 	unsigned char	*buf;
46a6584db8Sjob 	size_t		 len;
47a6584db8Sjob 
48a6584db8Sjob 	ERR_load_crypto_strings();
49a6584db8Sjob 	OpenSSL_add_all_ciphers();
50a6584db8Sjob 	OpenSSL_add_all_digests();
51a6584db8Sjob 	x509_init_oid();
52a6584db8Sjob 
53a6584db8Sjob 	while ((c = getopt(argc, argv, "pv")) != -1)
54a6584db8Sjob 		switch (c) {
55a6584db8Sjob 		case 'p':
56a6584db8Sjob 			if (ppem)
57a6584db8Sjob 				break;
58a6584db8Sjob 			ppem = 1;
59a6584db8Sjob 			break;
60a6584db8Sjob 		case 'v':
61a6584db8Sjob 			verb++;
62a6584db8Sjob 			break;
63a6584db8Sjob 		default:
64a6584db8Sjob 			errx(1, "bad argument %c", c);
65a6584db8Sjob 		}
66a6584db8Sjob 
67a6584db8Sjob 	argv += optind;
68a6584db8Sjob 	argc -= optind;
69a6584db8Sjob 
70a6584db8Sjob 	if (argc == 0)
71a6584db8Sjob 		errx(1, "argument missing");
72a6584db8Sjob 
73a6584db8Sjob 	for (i = 0; i < argc; i++) {
74a6584db8Sjob 		buf = load_file(argv[i], &len);
75a6584db8Sjob 		if ((p = spl_parse(&xp, argv[i], -1, buf, len)) == NULL) {
76a6584db8Sjob 			free(buf);
77a6584db8Sjob 			break;
78a6584db8Sjob 		}
79a6584db8Sjob 		if (verb)
80a6584db8Sjob 			spl_print(xp, p);
81a6584db8Sjob 		if (ppem) {
82a6584db8Sjob 			if (!PEM_write_X509(stdout, xp))
83a6584db8Sjob 				errx(1, "PEM_write_X509: unable to write cert");
84a6584db8Sjob 		}
85a6584db8Sjob 		free(buf);
86a6584db8Sjob 		spl_free(p);
87a6584db8Sjob 		X509_free(xp);
88a6584db8Sjob 	}
89a6584db8Sjob 
90a6584db8Sjob 	EVP_cleanup();
91a6584db8Sjob 	CRYPTO_cleanup_all_ex_data();
92a6584db8Sjob 	ERR_free_strings();
93a6584db8Sjob 
94a6584db8Sjob 	if (i < argc)
95a6584db8Sjob 		errx(1, "test failed for %s", argv[i]);
96a6584db8Sjob 
97a6584db8Sjob 	printf("OK\n");
98a6584db8Sjob 	return 0;
99a6584db8Sjob }
100a6584db8Sjob 
101a6584db8Sjob time_t
get_current_time(void)102a6584db8Sjob get_current_time(void)
103a6584db8Sjob {
104a6584db8Sjob 	return time(NULL);
105a6584db8Sjob }
106