123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143 |
- #!/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 genserv.sh <prefix> <caprefix>"
- # exit on first fail
- set -e
- HOME=`pwd`
- cd $HOME
- KEYSIZE=2048
- DURATION=3000
- # The -sha256 option was introduced in OpenSSL 1.0.1
- DIGESTALGO=-sha256
- REQ=YES
- P12=NO
- DHP=NO
- PREFIX=$1
- if [ ".$PREFIX" = . ] ; then
- echo No configuration prefix
- NOTOK=1
- else
- if [ ! -f $PREFIX-sv.prm ] ; then
- echo No configuration file $PREFIX-sv.prm
- NOTOK=1
- fi
- fi
- CAPREFIX=$2
- if [ ".$CAPREFIX" = . ] ; then
- echo No CA prefix
- NOTOK=1
- else
- if [ ! -f $CAPREFIX-ca.cacert ] ; then
- echo No CA certificate file $CAPREFIX-ca.caert
- NOTOK=1
- fi
- if [ ! -f $CAPREFIX-ca.key ] ; then
- echo No $CAPREFIX key
- NOTOK=1
- fi
- fi
- if [ ".$NOTOK" != . ] ; then
- echo "Sorry, I can't do that for you."
- $USAGE
- exit
- fi
- if [ ".$SERIAL" = . ] ; then
- GETSERIAL="\$t = time ;\$d = \$t . substr(\$t+$$ ,-4,4)-1;print \$d"
- SERIAL=`/usr/bin/env perl -e "$GETSERIAL"`
- fi
- echo SERIAL=$SERIAL PREFIX=$PREFIX CAPREFIX=$CAPREFIX DURATION=$DURATION KEYSIZE=$KEYSIZE
- if [ "$DHP." = YES. ] ; then
- echo "openssl dhparam -2 -out $PREFIX-sv.dhp $KEYSIZE"
- $OPENSSL dhparam -2 -out $PREFIX-sv.dhp $KEYSIZE
- fi
- if [ "$REQ." = YES. ] ; then
- echo "openssl req -config $PREFIX-sv.prm -newkey rsa:$KEYSIZE -keyout $PREFIX-sv.key -out $PREFIX-sv.csr -passout XXX"
- $OPENSSL req -config $PREFIX-sv.prm -newkey rsa:$KEYSIZE -keyout $PREFIX-sv.key -out $PREFIX-sv.csr -passout pass:secret
- fi
- echo "openssl rsa -in $PREFIX-sv.key -out $PREFIX-sv.key"
- $OPENSSL rsa -in $PREFIX-sv.key -out $PREFIX-sv.key -passin pass:secret
- echo pseudo secrets generated
- echo "openssl rsa -in $PREFIX-sv.key -pubout -outform DER -out $PREFIX-sv.pub.der"
- $OPENSSL rsa -in $PREFIX-sv.key -pubout -outform DER -out $PREFIX-sv.pub.der
- echo "openssl rsa -in $PREFIX-sv.key -pubout -outform PEM -out $PREFIX-sv.pub.pem"
- $OPENSSL rsa -in $PREFIX-sv.key -pubout -outform PEM -out $PREFIX-sv.pub.pem
- echo "openssl x509 -set_serial $SERIAL -extfile $PREFIX-sv.prm -days $DURATION -CA $CAPREFIX-ca.cacert -CAkey $CAPREFIX-ca.key -in $PREFIX-sv.csr -req -text -nameopt multiline $DIGESTALGO > $PREFIX-sv.crt "
- $OPENSSL x509 -set_serial $SERIAL -extfile $PREFIX-sv.prm -days $DURATION -CA $CAPREFIX-ca.cacert -CAkey $CAPREFIX-ca.key -in $PREFIX-sv.csr -req -text -nameopt multiline $DIGESTALGO > $PREFIX-sv.crt
- if [ "$P12." = YES. ] ; then
- echo "$OPENSSL pkcs12 -export -des3 -out $PREFIX-sv.p12 -caname $CAPREFIX -name $PREFIX -inkey $PREFIX-sv.key -in $PREFIX-sv.crt -certfile $CAPREFIX-ca.crt "
- $OPENSSL pkcs12 -export -des3 -out $PREFIX-sv.p12 -caname $CAPREFIX -name $PREFIX -inkey $PREFIX-sv.key -in $PREFIX-sv.crt -certfile $CAPREFIX-ca.crt
- fi
- echo "openssl x509 -noout -text -hash -in $PREFIX-sv.selfcert -nameopt multiline"
- $OPENSSL x509 -noout -text -hash -in $PREFIX-sv.crt -nameopt multiline
- # revoke server cert
- touch $CAPREFIX-ca.db
- echo 01 > $CAPREFIX-ca.cnt
- echo "openssl ca -config $CAPREFIX-ca.cnf -revoke $PREFIX-sv.crt"
- $OPENSSL ca -config $CAPREFIX-ca.cnf -revoke $PREFIX-sv.crt
- # issue CRL
- echo "openssl ca -config $CAPREFIX-ca.cnf -gencrl -out $PREFIX-sv.crl"
- $OPENSSL ca -config $CAPREFIX-ca.cnf -gencrl -out $PREFIX-sv.crl
- echo "openssl x509 -in $PREFIX-sv.crt -outform der -out $PREFIX-sv.der "
- $OPENSSL x509 -in $PREFIX-sv.crt -outform der -out $PREFIX-sv.der
- # all together now
- touch $PREFIX-sv.dhp
- cat $PREFIX-sv.prm $PREFIX-sv.key $PREFIX-sv.crt $PREFIX-sv.dhp >$PREFIX-sv.pem
- chmod o-r $PREFIX-sv.prm
- $OPENSSL x509 -in $PREFIX-sv.pem -pubkey -noout | \
- $OPENSSL pkey -pubin -outform der | $OPENSSL dgst -sha256 -binary | \
- $OPENSSL enc -base64 >$PREFIX-sv.pubkey-pinned
- echo "$PREFIX-sv.pem done"
|