Home | History | Annotate | Download | only in scripts
      1 #!/bin/bash
      2 
      3 # (c) CopyRight EdelWeb for EdelKey and OpenEvidence, 2000-2004, 2009
      4 # Author: Peter Sylvester
      5 
      6 # "libre" for integration with curl
      7 
      8 OPENSSL=openssl
      9 if [ -f /usr/local/ssl/bin/openssl ] ; then
     10 OPENSSL=/usr/local/ssl/bin/openssl
     11 fi
     12 
     13 USAGE="echo Usage is genroot.sh \<name\>"
     14 
     15 HOME=`pwd`
     16 cd $HOME
     17 
     18 KEYSIZE=2048
     19 DURATION=6000
     20 
     21 PREFIX=$1
     22 if [ ".$PREFIX" = . ] ; then
     23 	echo No configuration prefix
     24 	NOTOK=1
     25 else
     26     if [ ! -f $PREFIX-ca.prm ] ; then
     27 	echo No configuration file $PREFIX-ca.prm
     28 	NOTOK=1
     29     fi
     30 fi
     31 
     32 if [ ".$NOTOK" != . ] ; then
     33     echo "Sorry, I can't do that for you."
     34     $USAGE
     35     exit
     36 fi
     37 
     38 GETSERIAL="\$t = time ;\$d =  \$t . substr(\$t+$$ ,-4,4)-1;print \$d"
     39 SERIAL=`/usr/bin/env perl -e "$GETSERIAL"`
     40 
     41 echo SERIAL=$SERIAL PREFIX=$PREFIX DURATION=$DURATION KEYSIZE=$KEYSIZE
     42 
     43 echo "openssl genrsa -out $PREFIX-ca.key $KEYSIZE -passout XXX"
     44 openssl genrsa -out $PREFIX-ca.key $KEYSIZE -passout pass:secret
     45 
     46 echo "openssl req -config $PREFIX-ca.prm -new -key $PREFIX-ca.key -out $PREFIX-ca.csr"
     47 $OPENSSL req -config $PREFIX-ca.prm -new -key $PREFIX-ca.key -out $PREFIX-ca.csr -passin pass:secret
     48 
     49 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 -sha1 "
     50 
     51 $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 -sha1
     52 
     53 echo "openssl x509 -text -in $PREFIX-$SERIAL-ca.cacert -nameopt multiline > $PREFIX-ca.cacert "
     54 $OPENSSL x509 -text -in $PREFIX-$SERIAL-ca.cacert -nameopt multiline > $PREFIX-ca.cacert
     55 
     56 echo "openssl x509 -in $PREFIX-ca.cacert -outform der -out $PREFIX-ca.der "
     57 $OPENSSL x509 -in $PREFIX-ca.cacert -outform der -out $PREFIX-ca.der
     58 
     59 echo "openssl x509 -in $PREFIX-ca.cacert -text -nameopt multiline > $PREFIX-ca.crt "
     60 
     61 $OPENSSL x509 -in $PREFIX-ca.cacert -text -nameopt multiline > $PREFIX-ca.crt
     62 
     63 echo "openssl x509 -noout -text -in $PREFIX-ca.cacert -nameopt multiline"
     64 $OPENSSL x509 -noout -text -in $PREFIX-ca.cacert -nameopt multiline
     65 
     66 #$OPENSSL rsa -in ../keys/$PREFIX-ca.key -text -noout -pubout
     67