forked from petems/vagrant-vault-softhsm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.sh
186 lines (148 loc) · 4.69 KB
/
run.sh
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
#!/bin/bash
: ${CONFIG_BASE:=$HOME/.config}
#Default values
: ${NODES:=3}
: ${API_PORT:=8200}
: ${CLUSTER_PORT:=$(( $API_PORT+1 ))}
: ${CLUSTER_IDENTIFIER:=cluster_${API_PORT}}
: ${SOFTHSM2_CONF:=$CONFIG_BASE/softhsm2/$CLUSTER_IDENTIFIER/softhsm2.conf}
export SOFTHSM2_CONF
herefile() {
expand | awk 'NR == 1 {match($0, /^ */); l = RLENGTH + 1} {print substr($0, l)}'
}
function clean {
echo Deleting previous tokens and vault data...
rm -Rf \
$CONFIG_BASE/softhsm2/$CLUSTER_IDENTIFIER \
$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER \
;
}
function config {
mkdir -vp \
$CONFIG_BASE/softhsm2/$CLUSTER_IDENTIFIER/tokens/ \
$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/1 \
$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/2 \
$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/3 \
;
herefile << EOF > $CONFIG_BASE/softhsm2/$CLUSTER_IDENTIFIER/softhsm2.conf
# SoftHSM v2 configuration file
directories.tokendir = $CONFIG_BASE/softhsm2/$CLUSTER_IDENTIFIER/tokens/
objectstore.backend = file
# ERROR, WARNING, INFO, DEBUG
log.level = DEBUG
EOF
#Generate an HSM key per Vault instance
softhsm2-util --init-token --free --label "vault-hsm-key" --pin 1234 --so-pin asdf
VAULT_HSM_SLOT=$(softhsm2-util --show-slots | grep ^Slot | sed "q;d" | cut -d\ -f2)
#Create Vault configuration files, each with its own HSM slot
for (( N=1; N<=$NODES; N++ ))
do
herefile << EOF > $CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/${N}/config.hcl
listener "tcp" {
address = "127.0.0.${N}:$API_PORT"
tls_disable = "true"
}
storage "raft" {
path = "$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/${N}"
node_id = "data-vault-$API_PORT-${N}"
}
#I am testing on WSL which does not support mlock
disable_mlock = true
ui = true
api_addr = "http://127.0.0.${N}:$API_PORT"
cluster_addr = "https://127.0.0.${N}:$CLUSTER_PORT"
pid_file = "$CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/pid${N}"
seal "pkcs11" {
lib = "/usr/lib/softhsm/libsofthsm2.so"
slot = "$VAULT_HSM_SLOT"
pin = "1234"
key_label = "vault-hsm-key"
hmac_key_label = "vault-hsm-hmac-key"
generate_key = "true"
}
EOF
done
}
function install {
echo Installing the required packages...
sudo apt-get update
sudo apt-get install libltdl7 libsofthsm2 softhsm2 libltdl-dev opensc
}
function start_vault {
for (( N=1; N<=$NODES; N++ ))
do
echo -n $N
nohup vault server --config $CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/${N}/config.hcl --log-level=trace >> vault${N}.log 2>&1 &
until curl --fail --silent --max-time 5 http://127.0.0.${N}:${API_PORT}/v1/sys/health?standbycode=200\&sealedcode=200\&uninitcode=200\&drsecondarycode=200 --header "X-Vault-No-Request-Forwardilg: 1" -o /dev/null; do echo -n $N ; sleep 0.5; done
done
echo
ps -ef | grep -v grep | grep "vault server"
}
function raft_join {
echo "Building the Vault Raft cluster"
# Start with node 2, node 1 is already Raft
for (( N=2; N<=$NODES; N++ ))
do
VAULT_ADDR=http://127.0.0.${N}:$API_PORT vault operator raft join http://127.0.0.1:$API_PORT
done
}
function stop_vault {
echo "Stopping Vault(s)"
for (( N=1; N<=$NODES; N++ ))
do
PID=$(cat $CONFIG_BASE/vault/$CLUSTER_IDENTIFIER/pid${N})
echo "Waiting for vault pid $PID to end"
kill $PID
tail --pid=$PID -f /dev/null
done
}
POSITIONAL=()
while [[ $# -gt 0 ]]
do
key="$1"
case $key in
-h|--hsm)
USE_HSM=1
shift # past value
;;
-n|--nodes)
shift # past argument
NODES=$2
shift # past value
echo Will use $NODES
;;
*) # unknown option
POSITIONAL+=("$1") # save it in an array for later
shift # past argument
;;
esac
done
# Restore positional parameters
set -- "${POSITIONAL[@]}"
# Call each task, in order
for task in $*
do
case $task in
install)
install
;;
clean)
clean
;;
config | configure)
config
;;
start)
start_vault
;;
join)
raft_join
;;
stop)
stop_vault
;;
*)
echo $"Ignoring $task not in {install|clean|config[ure]|start}"
exit 1
esac
done