/* * This file is part of the UCB release of Plan 9. It is subject to the license * terms in the LICENSE file found in the top-level directory of this * distribution and at http://akaros.cs.berkeley.edu/files/Plan9License. No * part of the UCB release of Plan 9, including this file, may be copied, * modified, propagated, or distributed except according to the terms contained * in the LICENSE file. */ /* Portions of this file are Copyright (C) 9front's team. * See /doc/license/9front-mit for details about the licensing. * See http://git.9front.org/plan9front/plan9front/HEAD/info.html for a list of authors. */ #include #include #include #include #include #include #include "rsa2any.h" void usage(void) { fprint(2, "usage: auth/rsa2x509 [-e expireseconds] 'C=US ...CN=xxx' [key]\n"); exits("usage"); } void main(int argc, char **argv) { int len; uint8_t *cert; uint32_t valid[2]; RSApriv *key; fmtinstall('B', mpfmt); fmtinstall('H', encodefmt); valid[0] = time(0); valid[1] = valid[0] + 3*366*24*60*60; ARGBEGIN{ default: usage(); case 'e': valid[1] = valid[0] + strtoul(ARGF(), 0, 10); break; }ARGEND if(argc != 1 && argc != 2) usage(); if((key = getrsakey(argc-1, argv+1, 1, nil)) == nil) sysfatal("%r"); cert = X509rsagen(key, argv[0], valid, &len); if(cert == nil) sysfatal("X509rsagen: %r"); jehanne_write(1, cert, len); exits(0); }