#include #include #include #include #include #include <9p.h> #include #include #include #include "sshtun.h" Cipher *cryptos[1]; int debug; void usage(void) { fprint(2, "usage: ssh2key [file]\n"); exits("usage"); } void main(int argc, char *argv[]) { Packet *p; char *ep, *np, *user; mpint *e, *n; int fd, m; char key[8192], encpub[8192]; ARGBEGIN { default: usage(); } ARGEND if (argc > 1) usage(); user = getenv("user"); if (argc == 0) fd = 0; else { fd = open(argv[0], OREAD); if (fd < 0) usage(); } m = read(fd, key, 8191); close(fd); key[m] = 0; ep = strstr(key, " ek="); np = strstr(key, " n="); if (ep == nil || np == nil) { fprint(2, "Invalid key file\n"); exits("invalid"); } e = strtomp(ep+4, nil, 16, nil); n = strtomp(np+3, nil, 16, nil); p = new_packet(nil); add_string(p, "ssh-rsa"); add_mp(p, e); add_mp(p, n); if ((m = enc64(encpub, 8192, p->payload, p->rlength-1)) < 0) { fprint(2, "Base 64 encoding failed\n"); exits("fail"); } print("ssh-rsa "); write(1, encpub, m); if (user) print(" %s\n", user); }