genroot.sh 2.2 KB

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