1 | #!/bin/sh
|
---|
2 | #
|
---|
3 | # Initialize the OpenVPN Easy-RSA 2.0 scripts
|
---|
4 | #
|
---|
5 | # Rick van der Zwet <rick@wirelessleiden.nl>
|
---|
6 | #
|
---|
7 |
|
---|
8 | # This variable should point to
|
---|
9 | # the top level of the easy-rsa
|
---|
10 | # tree.
|
---|
11 | export EASY_RSA=${EASY_RSA:-"/usr/local/share/easy-rsa"}
|
---|
12 |
|
---|
13 | if [ ! -d "$EASY_RSA" ]; then
|
---|
14 | echo "# Installing easy-rsa at $EASY_RSA"
|
---|
15 | trap "mount -ur /; exit 1" 1 2 15
|
---|
16 | mount -uwo noatime / || exit 1
|
---|
17 | make -C /usr/local/share/doc/openvpn/easy-rsa/2.0 install DESTDIR=$EASY_RSA || exit 1
|
---|
18 | # Avoid disasters and move the vars template holder
|
---|
19 | mv $EASY_RSA/vars $EASY_RSA/vars.old || exit 1
|
---|
20 | mount -ur /
|
---|
21 | trap - 1 2 15
|
---|
22 | fi
|
---|
23 |
|
---|
24 | #
|
---|
25 | # This variable should point to
|
---|
26 | # the requested executables
|
---|
27 | #
|
---|
28 | export OPENSSL="openssl"
|
---|
29 | export PKCS11TOOL="pkcs11-tool"
|
---|
30 | export GREP="grep"
|
---|
31 |
|
---|
32 |
|
---|
33 | # This variable should point to
|
---|
34 | # the openssl.cnf file included
|
---|
35 | # with easy-rsa.
|
---|
36 | export KEY_CONFIG=`$EASY_RSA/whichopensslcnf $EASY_RSA`
|
---|
37 |
|
---|
38 | # Edit this variable to point to
|
---|
39 | # your soon-to-be-created key
|
---|
40 | # directory.
|
---|
41 | #
|
---|
42 | # WARNING: clean-all will do
|
---|
43 | # a rm -rf on this directory
|
---|
44 | # so make sure you define
|
---|
45 | # it correctly!
|
---|
46 | export KEY_DIR="${KEY_DIR:-/etc/easy-rsa-keys}"
|
---|
47 |
|
---|
48 | # Issue rm -rf warning
|
---|
49 | echo NOTE: If you run ./clean-all, I will be doing a rm -rf on $KEY_DIR
|
---|
50 |
|
---|
51 | # PKCS11 fixes
|
---|
52 | export PKCS11_MODULE_PATH="dummy"
|
---|
53 | export PKCS11_PIN="dummy"
|
---|
54 |
|
---|
55 | # Increase this to 2048 if you
|
---|
56 | # are paranoid. This will slow
|
---|
57 | # down TLS negotiation performance
|
---|
58 | # as well as the one-time DH parms
|
---|
59 | # generation process.
|
---|
60 | export KEY_SIZE=1024
|
---|
61 |
|
---|
62 | # In how many days should the root CA key expire?
|
---|
63 | export CA_EXPIRE=3650
|
---|
64 |
|
---|
65 | # In how many days should certificates expire?
|
---|
66 | export KEY_EXPIRE=3650
|
---|
67 |
|
---|
68 | # These are the default values for fields
|
---|
69 | # which will be placed in the certificate.
|
---|
70 | # Don't leave any of these fields blank.
|
---|
71 | export KEY_COUNTRY="US"
|
---|
72 | export KEY_PROVINCE="CA"
|
---|
73 | export KEY_CITY="SanFrancisco"
|
---|
74 | export KEY_ORG="Fort-Funston"
|
---|
75 | export KEY_EMAIL="me@myhost.mydomain"
|
---|
76 | export KEY_EMAIL=mail@host.domain
|
---|
77 | export KEY_CN=changeme
|
---|
78 | export KEY_NAME=changeme
|
---|
79 | export KEY_OU=changeme
|
---|
80 | export PKCS11_MODULE_PATH=changeme
|
---|
81 | export PKCS11_PIN=1234
|
---|
82 |
|
---|
83 | # Start the local shell
|
---|
84 | cd $EASY_RSA
|
---|
85 | echo "#"
|
---|
86 | echo "# Type exit when done to write changes to persistent disk"
|
---|
87 | echo "#"
|
---|
88 | # Primer to remember what we are doing
|
---|
89 | sed -n -e '/Typical/,$p' README | sed -e 's/^/## /g' | grep -v '. ./vars'
|
---|
90 | echo "#"
|
---|
91 | bash || sh
|
---|
92 |
|
---|
93 | echo "# Writing changes to persistent storage (/cfg)"
|
---|
94 | trap "umount /cfg; exit 1" 1 2 15 EXIT
|
---|
95 |
|
---|
96 | mount -ro noatime /cfg || exit 1
|
---|
97 | CFG_KEY_DIR=/cfg/`basename $KEY_DIR`
|
---|
98 | diff -b -B -q -r $KEY_DIR $CFG_KEY_DIR || {
|
---|
99 | mount -uwo noatime /cfg || exit 1
|
---|
100 | rm -fR $CFG_KEY_DIR || exit 1
|
---|
101 | cp -R $KEY_DIR $CFG_KEY_DIR || exit 1
|
---|
102 | }
|
---|