xref: /plan9/sys/src/cmd/auth/rsa2x509.c (revision 92f5376fc8452ee77cfb206cc1e9943fc8566122)
1fb7f0c93SDavid du Colombier #include <u.h>
2fb7f0c93SDavid du Colombier #include <libc.h>
3fb7f0c93SDavid du Colombier #include <bio.h>
4fb7f0c93SDavid du Colombier #include <auth.h>
5fb7f0c93SDavid du Colombier #include <mp.h>
6fb7f0c93SDavid du Colombier #include <libsec.h>
7fb7f0c93SDavid du Colombier #include "rsa2any.h"
8fb7f0c93SDavid du Colombier 
9fb7f0c93SDavid du Colombier void
usage(void)10fb7f0c93SDavid du Colombier usage(void)
11fb7f0c93SDavid du Colombier {
12*92f5376fSDavid du Colombier 	fprint(2, "usage: auth/rsa2x509 [-e expireseconds] 'C=US ...CN=xxx' [key]");
13fb7f0c93SDavid du Colombier 	exits("usage");
14fb7f0c93SDavid du Colombier }
15fb7f0c93SDavid du Colombier 
16fb7f0c93SDavid du Colombier void
main(int argc,char ** argv)17fb7f0c93SDavid du Colombier main(int argc, char **argv)
18fb7f0c93SDavid du Colombier {
19fb7f0c93SDavid du Colombier 	int len;
20fb7f0c93SDavid du Colombier 	uchar *cert;
21fb7f0c93SDavid du Colombier 	ulong valid[2];
22fb7f0c93SDavid du Colombier 	RSApriv *key;
23fb7f0c93SDavid du Colombier 
24fb7f0c93SDavid du Colombier 	fmtinstall('B', mpfmt);
25fb7f0c93SDavid du Colombier 	fmtinstall('H', encodefmt);
26fb7f0c93SDavid du Colombier 
27fb7f0c93SDavid du Colombier 	valid[0] = time(0);
28fb7f0c93SDavid du Colombier 	valid[1] = valid[0] + 3*366*24*60*60;
29fb7f0c93SDavid du Colombier 
30fb7f0c93SDavid du Colombier 	ARGBEGIN{
31fb7f0c93SDavid du Colombier 	default:
32fb7f0c93SDavid du Colombier 		usage();
33fb7f0c93SDavid du Colombier 	case 'e':
34fb7f0c93SDavid du Colombier 		valid[1] = valid[0] + strtoul(ARGF(), 0, 10);
35fb7f0c93SDavid du Colombier 		break;
36fb7f0c93SDavid du Colombier 	}ARGEND
37fb7f0c93SDavid du Colombier 
38fb7f0c93SDavid du Colombier 	if(argc != 1 && argc != 2)
39fb7f0c93SDavid du Colombier 		usage();
40fb7f0c93SDavid du Colombier 
41fb7f0c93SDavid du Colombier 	if((key = getkey(argc-1, argv+1, 1, nil)) == nil)
42fb7f0c93SDavid du Colombier 		sysfatal("%r");
43fb7f0c93SDavid du Colombier 
44fb7f0c93SDavid du Colombier 	cert = X509gen(key, argv[0], valid, &len);
45fb7f0c93SDavid du Colombier 	if(cert == nil)
46fb7f0c93SDavid du Colombier 		sysfatal("X509gen: %r");
47fb7f0c93SDavid du Colombier 
48fb7f0c93SDavid du Colombier 	write(1, cert, len);
49fb7f0c93SDavid du Colombier 	exits(0);
50fb7f0c93SDavid du Colombier }
51