xref: /plan9/sys/src/cmd/auth/dsa2ssh.c (revision 2d8b52e80aea4fb9116c3dab5690599d2d0cf529)
1*2d8b52e8SDavid du Colombier #include <u.h>
2*2d8b52e8SDavid du Colombier #include <libc.h>
3*2d8b52e8SDavid du Colombier #include <auth.h>
4*2d8b52e8SDavid du Colombier #include <mp.h>
5*2d8b52e8SDavid du Colombier #include <libsec.h>
6*2d8b52e8SDavid du Colombier #include "rsa2any.h"
7*2d8b52e8SDavid du Colombier 
8*2d8b52e8SDavid du Colombier void
usage(void)9*2d8b52e8SDavid du Colombier usage(void)
10*2d8b52e8SDavid du Colombier {
11*2d8b52e8SDavid du Colombier 	fprint(2, "usage: auth/dsa2ssh [-c comment] [file]\n");
12*2d8b52e8SDavid du Colombier 	exits("usage");
13*2d8b52e8SDavid du Colombier }
14*2d8b52e8SDavid du Colombier 
15*2d8b52e8SDavid du Colombier void
main(int argc,char ** argv)16*2d8b52e8SDavid du Colombier main(int argc, char **argv)
17*2d8b52e8SDavid du Colombier {
18*2d8b52e8SDavid du Colombier 	DSApriv *k;
19*2d8b52e8SDavid du Colombier 	char *comment;
20*2d8b52e8SDavid du Colombier 	uchar buf[8192], *p;
21*2d8b52e8SDavid du Colombier 
22*2d8b52e8SDavid du Colombier 	fmtinstall('B', mpfmt);
23*2d8b52e8SDavid du Colombier 	fmtinstall('[', encodefmt);
24*2d8b52e8SDavid du Colombier 	comment = "";
25*2d8b52e8SDavid du Colombier 	ARGBEGIN{
26*2d8b52e8SDavid du Colombier 	case 'c':
27*2d8b52e8SDavid du Colombier 		comment = EARGF(usage());
28*2d8b52e8SDavid du Colombier 		break;
29*2d8b52e8SDavid du Colombier 	default:
30*2d8b52e8SDavid du Colombier 		usage();
31*2d8b52e8SDavid du Colombier 	}ARGEND
32*2d8b52e8SDavid du Colombier 
33*2d8b52e8SDavid du Colombier 	if(argc > 1)
34*2d8b52e8SDavid du Colombier 		usage();
35*2d8b52e8SDavid du Colombier 
36*2d8b52e8SDavid du Colombier 	if((k = getdsakey(argc, argv, 0, nil)) == nil)
37*2d8b52e8SDavid du Colombier 		sysfatal("%r");
38*2d8b52e8SDavid du Colombier 
39*2d8b52e8SDavid du Colombier 	p = buf;
40*2d8b52e8SDavid du Colombier 	p = put4(p, 7);
41*2d8b52e8SDavid du Colombier 	p = putn(p, "ssh-dss", 7);
42*2d8b52e8SDavid du Colombier 	p = putmp2(p, k->pub.p);
43*2d8b52e8SDavid du Colombier 	p = putmp2(p, k->pub.q);
44*2d8b52e8SDavid du Colombier 	p = putmp2(p, k->pub.alpha);
45*2d8b52e8SDavid du Colombier 	p = putmp2(p, k->pub.key);
46*2d8b52e8SDavid du Colombier 	print("ssh-dss %.*[ %s\n", (int)(p - buf), buf, comment);
47*2d8b52e8SDavid du Colombier 	exits(nil);
48*2d8b52e8SDavid du Colombier }
49