#!/bin/bash #*************************************************************************** # _ _ ____ _ # Project ___| | | | _ \| | # / __| | | | |_) | | # | (__| |_| | _ <| |___ # \___|\___/|_| \_\_____| # # Copyright (C) EdelWeb for EdelKey and OpenEvidence # # This software is licensed as described in the file COPYING, which # you should have received as part of this distribution. The terms # are also available at https://curl.se/docs/copyright.html. # # You may opt to use, copy, modify, merge, publish, distribute and/or sell # copies of the Software, and permit persons to whom the Software is # furnished to do so, under the terms of the COPYING file. # # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY # KIND, either express or implied. # # SPDX-License-Identifier: curl # ########################################################################### OPENSSL=openssl if [ -f /usr/local/ssl/bin/openssl ] ; then OPENSSL=/usr/local/ssl/bin/openssl fi USAGE="echo Usage is genroot.sh \" HOME=`pwd` cd $HOME KEYSIZE=2048 DURATION=6000 # The -sha256 option was introduced in OpenSSL 1.0.1 DIGESTALGO=-sha256 PREFIX=$1 if [ ".$PREFIX" = . ] ; then echo No configuration prefix NOTOK=1 else if [ ! -f $PREFIX-ca.prm ] ; then echo No configuration file $PREFIX-ca.prm NOTOK=1 fi fi if [ ".$NOTOK" != . ] ; then echo "Sorry, I can't do that for you." $USAGE exit fi GETSERIAL="\$t = time ;\$d = \$t . substr(\$t+$$ ,-4,4)-1;print \$d" SERIAL=`/usr/bin/env perl -e "$GETSERIAL"` # exit on first fail set -e echo SERIAL=$SERIAL PREFIX=$PREFIX DURATION=$DURATION KEYSIZE=$KEYSIZE echo "openssl genrsa -out $PREFIX-ca.key -passout XXX $KEYSIZE" openssl genrsa -out $PREFIX-ca.key -passout pass:secret $KEYSIZE echo "openssl req -config $PREFIX-ca.prm -new -key $PREFIX-ca.key -out $PREFIX-ca.csr" $OPENSSL req -config $PREFIX-ca.prm -new -key $PREFIX-ca.key -out $PREFIX-ca.csr -passin pass:secret echo "openssl x509 -set_serial $SERIAL -extfile $PREFIX-ca.prm -days $DURATION -req -signkey $PREFIX-ca.key -in $PREFIX-ca.csr -out $PREFIX-$SERIAL.ca-cacert $DIGESTALGO " $OPENSSL x509 -set_serial $SERIAL -extfile $PREFIX-ca.prm -days $DURATION -req -signkey $PREFIX-ca.key -in $PREFIX-ca.csr -out $PREFIX-$SERIAL-ca.cacert $DIGESTALGO echo "openssl x509 -text -in $PREFIX-$SERIAL-ca.cacert -nameopt multiline > $PREFIX-ca.cacert " $OPENSSL x509 -text -in $PREFIX-$SERIAL-ca.cacert -nameopt multiline > $PREFIX-ca.cacert echo "openssl x509 -in $PREFIX-ca.cacert -outform der -out $PREFIX-ca.der " $OPENSSL x509 -in $PREFIX-ca.cacert -outform der -out $PREFIX-ca.der echo "openssl x509 -in $PREFIX-ca.cacert -text -nameopt multiline > $PREFIX-ca.crt " $OPENSSL x509 -in $PREFIX-ca.cacert -text -nameopt multiline > $PREFIX-ca.crt echo "openssl x509 -noout -text -in $PREFIX-ca.cacert -nameopt multiline" $OPENSSL x509 -noout -text -in $PREFIX-ca.cacert -nameopt multiline #$OPENSSL rsa -in ../keys/$PREFIX-ca.key -text -noout -pubout