genserv.sh 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  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 genserv.sh <prefix> <caprefix>"
  10. HOME=`pwd`
  11. cd $HOME
  12. KEYSIZE=2048
  13. DURATION=3000
  14. # The -sha256 option was introduced in OpenSSL 1.0.1
  15. DIGESTALGO=-sha256
  16. REQ=YES
  17. P12=NO
  18. DHP=NO
  19. PREFIX=$1
  20. if [ ".$PREFIX" = . ] ; then
  21. echo No configuration prefix
  22. NOTOK=1
  23. else
  24. if [ ! -f $PREFIX-sv.prm ] ; then
  25. echo No configuration file $PREFIX-sv.prm
  26. NOTOK=1
  27. fi
  28. fi
  29. CAPREFIX=$2
  30. if [ ".$CAPREFIX" = . ] ; then
  31. echo No CA prefix
  32. NOTOK=1
  33. else
  34. if [ ! -f $CAPREFIX-ca.cacert ] ; then
  35. echo No CA certificate file $CAPREFIX-ca.caert
  36. NOTOK=1
  37. fi
  38. if [ ! -f $CAPREFIX-ca.key ] ; then
  39. echo No $CAPREFIX key
  40. NOTOK=1
  41. fi
  42. fi
  43. if [ ".$NOTOK" != . ] ; then
  44. echo "Sorry, I can't do that for you."
  45. $USAGE
  46. exit
  47. fi
  48. if [ ".$SERIAL" = . ] ; then
  49. GETSERIAL="\$t = time ;\$d = \$t . substr(\$t+$$ ,-4,4)-1;print \$d"
  50. SERIAL=`/usr/bin/env perl -e "$GETSERIAL"`
  51. fi
  52. echo SERIAL=$SERIAL PREFIX=$PREFIX CAPREFIX=$CAPREFIX DURATION=$DURATION KEYSIZE=$KEYSIZE
  53. if [ "$DHP." = YES. ] ; then
  54. echo "openssl dhparam -2 -out $PREFIX-sv.dhp $KEYSIZE"
  55. $OPENSSL dhparam -2 -out $PREFIX-sv.dhp $KEYSIZE
  56. fi
  57. if [ "$REQ." = YES. ] ; then
  58. echo "openssl req -config $PREFIX-sv.prm -newkey rsa:$KEYSIZE -keyout $PREFIX-sv.key -out $PREFIX-sv.csr -passout XXX"
  59. $OPENSSL req -config $PREFIX-sv.prm -newkey rsa:$KEYSIZE -keyout $PREFIX-sv.key -out $PREFIX-sv.csr -passout pass:secret
  60. fi
  61. echo "openssl rsa -in $PREFIX-sv.key -out $PREFIX-sv.key"
  62. $OPENSSL rsa -in $PREFIX-sv.key -out $PREFIX-sv.key -passin pass:secret
  63. echo pseudo secrets generated
  64. echo "openssl rsa -in $PREFIX-sv.key -pubout -outform DER -out $PREFIX-sv.pub.der"
  65. $OPENSSL rsa -in $PREFIX-sv.key -pubout -outform DER -out $PREFIX-sv.pub.der
  66. echo "openssl rsa -in $PREFIX-sv.key -pubout -outform PEM -out $PREFIX-sv.pub.pem"
  67. $OPENSSL rsa -in $PREFIX-sv.key -pubout -outform PEM -out $PREFIX-sv.pub.pem
  68. 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 "
  69. $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
  70. if [ "$P12." = YES. ] ; then
  71. 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 "
  72. $OPENSSL pkcs12 -export -des3 -out $PREFIX-sv.p12 -caname $CAPREFIX -name $PREFIX -inkey $PREFIX-sv.key -in $PREFIX-sv.crt -certfile $CAPREFIX-ca.crt
  73. fi
  74. echo "openssl x509 -noout -text -hash -in $PREFIX-sv.selfcert -nameopt multiline"
  75. $OPENSSL x509 -noout -text -hash -in $PREFIX-sv.crt -nameopt multiline
  76. # revoke server cert
  77. touch $CAPREFIX-ca.db
  78. echo 01 > $CAPREFIX-ca.cnt
  79. echo "openssl ca -config $CAPREFIX-ca.cnf -revoke $PREFIX-sv.crt"
  80. $OPENSSL ca -config $CAPREFIX-ca.cnf -revoke $PREFIX-sv.crt
  81. # issue CRL
  82. echo "openssl ca -config $CAPREFIX-ca.cnf -gencrl -out $PREFIX-sv.crl"
  83. $OPENSSL ca -config $CAPREFIX-ca.cnf -gencrl -out $PREFIX-sv.crl
  84. echo "openssl x509 -in $PREFIX-sv.crt -outform der -out $PREFIX-sv.der "
  85. $OPENSSL x509 -in $PREFIX-sv.crt -outform der -out $PREFIX-sv.der
  86. # all together now
  87. touch $PREFIX-sv.dhp
  88. cat $PREFIX-sv.prm $PREFIX-sv.key $PREFIX-sv.crt $PREFIX-sv.dhp >$PREFIX-sv.pem
  89. chmod o-r $PREFIX-sv.prm
  90. echo "$PREFIX-sv.pem done"