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