File: createRA.sh

package info (click to toggle)
libest 3.2.0%2Bds-1.1
  • links: PTS
  • area: main
  • in suites: forky, sid, trixie
  • size: 11,792 kB
  • sloc: ansic: 60,980; java: 12,082; sh: 4,956; python: 4,474; xml: 385; makefile: 290
file content (42 lines) | stat: -rwxr-xr-x 1,435 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
#!/bin/bash

# default variables and config options
EST_SCRIPTNAME=$0
EST_OPENSSL_CACNF=./estExampleCA.cnf
EST_SERVER_SUBJ="/CN=127.0.0.1"
EST_SERVER_CERTREQ=tmp/proxy-csr.pem
EST_SERVER_CERT=proxy-cert.pem
EST_SERVER_KEY=proxy-key.pem
EST_ECPARMS=tmp/ec.pem
OPENSSLCMD=openssl

function iferrorlogandexit ()
{
    if [ $? -ne 0 ] ; then
        echo "###########..EXIT..##########"
        echo "SCRIPT $EST_SCRIPTNAME EXIT: $1 ($2)"
        echo "###########^^EXIT^^##########"
        echo ""
        exit $2
    fi
}

if [ -e tmp ] ; then 
    rm -r tmp 
fi
mkdir tmp

eval $OPENSSLCMD ecparam -out $EST_ECPARMS -name prime256v1 -genkey
eval $OPENSSLCMD ecparam -in $EST_ECPARMS -check

# Create a certificate for our est server
# TODO: add extension for est server
echo "#################################################################"
echo "####(Re)creating a certificate for our RA to use"
echo "#################################################################"
# re-using the same NEWKEY_PARAM as is used for our CA
eval $OPENSSLCMD req -new -nodes -out $EST_SERVER_CERTREQ -newkey ec:$EST_ECPARMS -keyout $EST_SERVER_KEY -subj $EST_SERVER_SUBJ -config $EST_OPENSSL_CACNF
iferrorlogandexit "Unable to create est server CSR" 1
$OPENSSLCMD ca -out $EST_SERVER_CERT -batch -config $EST_OPENSSL_CACNF -infiles $EST_SERVER_CERTREQ
iferrorlogandexit "Unable to create RA certificate" 1
$OPENSSLCMD x509 -in $EST_SERVER_CERT -text