blob: 5a2cc1bd32a5155510abfa4dddbc1c6e6fa97b93 (
plain)
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
|
#!/bin/bash
# Usage
# ...
# exit if any commands returns non-zero status
set -e
# XXX DEBUG
set -x
# Check if scipt is run in debug mode so we can hide secrets
if [[ "$-" =~ 'x' ]]
then
echo 'Running with xtrace enabled!'
xtrace=true
else
echo 'Running with xtrace disabled!'
xtrace=false
fi
PROVIDER='demo.bitmask.net'
INVITE_CODE=${BITMASK_INVITE_CODE:?"Need to set BITMASK_INVITE_CODE non-empty"}
BCTL='bitmaskctl'
LEAP_HOME="$HOME/.config/leap"
username="tmp_user_$(date +%Y%m%d%H%M%S)"
user="${username}@${PROVIDER}"
pw="$(head -c 10 < /dev/urandom | base64)"
# Stop any previously started bitmaskd
# and start a new instance
"$BCTL" stop
[ -d "$LEAP_HOME" ] && rm -rf "$LEAP_HOME"
"$BCTL" start
# Register a new user
# Disable xtrace
set +x
"$BCTL" user create "$user" --pass "$pw" --invite "$INVITE_CODE"
# Enable xtrace again only if it was set at beginning of script
[[ $xtrace == true ]] && set -x
# Authenticate
"$BCTL" user auth "$user" --pass "$pw" > /dev/null
# Enable VPN
"$BCTL" vpn enable
# Get VPN cert
"$BCTL" vpn get_cert "$user"
"$BCTL" vpn start --json
# XXX DEBUG ---
tail -n 200 ~/.config/leap/bitmaskd.log
which pkexec
ls -la /usr/sbin/openvpn
ls -la /usr/local/sbin/bitmask-root
# XXX DEBUG ---
sleep 5
"$BCTL" vpn status --json
tests/e2e/check_ip vpn_on
"$BCTL" vpn stop
sleep 5
tests/e2e/check_ip vpn_off
echo "Succeeded - the vpn routed you through the expected address"
|