xref: /plan9/sys/src/cmd/auth/asn12dsa.c (revision 2d8b52e80aea4fb9116c3dab5690599d2d0cf529)
1*2d8b52e8SDavid du Colombier #include <u.h>
2*2d8b52e8SDavid du Colombier #include <libc.h>
3*2d8b52e8SDavid du Colombier #include <bio.h>
4*2d8b52e8SDavid du Colombier #include <mp.h>
5*2d8b52e8SDavid du Colombier #include <libsec.h>
6*2d8b52e8SDavid du Colombier 
7*2d8b52e8SDavid du Colombier void
usage(void)8*2d8b52e8SDavid du Colombier usage(void)
9*2d8b52e8SDavid du Colombier {
10*2d8b52e8SDavid du Colombier 	fprint(2, "auth/asn12dsa [-t tag] [file]\n");
11*2d8b52e8SDavid du Colombier 	exits("usage");
12*2d8b52e8SDavid du Colombier }
13*2d8b52e8SDavid du Colombier 
14*2d8b52e8SDavid du Colombier void
main(int argc,char ** argv)15*2d8b52e8SDavid du Colombier main(int argc, char **argv)
16*2d8b52e8SDavid du Colombier {
17*2d8b52e8SDavid du Colombier 	char *s;
18*2d8b52e8SDavid du Colombier 	uchar *buf;
19*2d8b52e8SDavid du Colombier 	int fd;
20*2d8b52e8SDavid du Colombier 	long n, tot;
21*2d8b52e8SDavid du Colombier 	char *tag, *file;
22*2d8b52e8SDavid du Colombier 	DSApriv *key;
23*2d8b52e8SDavid du Colombier 
24*2d8b52e8SDavid du Colombier 	fmtinstall('B', mpfmt);
25*2d8b52e8SDavid du Colombier 
26*2d8b52e8SDavid du Colombier 	tag = nil;
27*2d8b52e8SDavid du Colombier 	ARGBEGIN{
28*2d8b52e8SDavid du Colombier 	case 't':
29*2d8b52e8SDavid du Colombier 		tag = EARGF(usage());
30*2d8b52e8SDavid du Colombier 		break;
31*2d8b52e8SDavid du Colombier 	default:
32*2d8b52e8SDavid du Colombier 		usage();
33*2d8b52e8SDavid du Colombier 	}ARGEND
34*2d8b52e8SDavid du Colombier 
35*2d8b52e8SDavid du Colombier 	if(argc != 0 && argc != 1)
36*2d8b52e8SDavid du Colombier 		usage();
37*2d8b52e8SDavid du Colombier 
38*2d8b52e8SDavid du Colombier 	if(argc == 1)
39*2d8b52e8SDavid du Colombier 		file = argv[0];
40*2d8b52e8SDavid du Colombier 	else
41*2d8b52e8SDavid du Colombier 		file = "/dev/stdin";
42*2d8b52e8SDavid du Colombier 
43*2d8b52e8SDavid du Colombier 	if((fd = open(file, OREAD)) < 0)
44*2d8b52e8SDavid du Colombier 		sysfatal("open %s: %r", file);
45*2d8b52e8SDavid du Colombier 	buf = nil;
46*2d8b52e8SDavid du Colombier 	tot = 0;
47*2d8b52e8SDavid du Colombier 	for(;;){
48*2d8b52e8SDavid du Colombier 		buf = realloc(buf, tot+8192);
49*2d8b52e8SDavid du Colombier 		if(buf == nil)
50*2d8b52e8SDavid du Colombier 			sysfatal("realloc: %r");
51*2d8b52e8SDavid du Colombier 		if((n = read(fd, buf+tot, 8192)) < 0)
52*2d8b52e8SDavid du Colombier 			sysfatal("read: %r");
53*2d8b52e8SDavid du Colombier 		if(n == 0)
54*2d8b52e8SDavid du Colombier 			break;
55*2d8b52e8SDavid du Colombier 		tot += n;
56*2d8b52e8SDavid du Colombier 	}
57*2d8b52e8SDavid du Colombier 
58*2d8b52e8SDavid du Colombier 	key = asn1toDSApriv(buf, tot);
59*2d8b52e8SDavid du Colombier 	if(key == nil)
60*2d8b52e8SDavid du Colombier 		sysfatal("couldn't parse asn1 key");
61*2d8b52e8SDavid du Colombier 
62*2d8b52e8SDavid du Colombier 	s = smprint("key proto=dsa %s%sp=%B q=%B alpha=%B key=%B !secret=%B\n",
63*2d8b52e8SDavid du Colombier 		tag ? tag : "", tag ? " " : "",
64*2d8b52e8SDavid du Colombier 		key->pub.p, key->pub.q, key->pub.alpha, key->pub.key,
65*2d8b52e8SDavid du Colombier 		key->secret);
66*2d8b52e8SDavid du Colombier 	if(s == nil)
67*2d8b52e8SDavid du Colombier 		sysfatal("smprint: %r");
68*2d8b52e8SDavid du Colombier 	write(1, s, strlen(s));
69*2d8b52e8SDavid du Colombier 	exits(0);
70*2d8b52e8SDavid du Colombier }
71