/* * 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. */ /* Portions of this file are Copyright (C) 2015-2018 Giacomo Tesio * See /doc/license/gpl-2.0.txt for details about the licensing. */ #include #include #include #include #include #include #include "rsa2any.h" void usage(void) { fprint(2, "usage: aux/rsa2csr 'C=US ...CN=xxx' [key]\n"); exits("usage"); } void main(int argc, char **argv) { int len; uint8_t *cert; RSApriv *key; fmtinstall('B', mpfmt); fmtinstall('H', encodefmt); ARGBEGIN{ default: usage(); }ARGEND if(argc != 1 && argc != 2) usage(); if((key = getrsakey(argc-1, argv+1, 1, nil)) == nil) sysfatal("%r"); cert = X509rsareq(key, argv[0], &len); if(cert == nil) sysfatal("X509rsareq: %r"); jehanne_write(1, cert, len); exits(0); }