-
Notifications
You must be signed in to change notification settings - Fork 151
/
start_ztncui.sh
executable file
·76 lines (62 loc) · 2.51 KB
/
start_ztncui.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
#!/bin/bash
cd /opt/key-networks/ztncui
if [ -z $MYADDR ]; then
echo "Set Your IP Address to continue."
echo "If you don't do that, I will automatically detect."
MYEXTADDR=$(curl --connect-timeout 5 ip.sb)
if [ -z $MYEXTADDR ]; then
MYINTADDR=$(ifconfig eth0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
MYADDR=${MYINTADDR}
else
MYADDR=${MYEXTADDR}
fi
echo "YOUR IP: ${MYADDR}"
fi
MYDOMAIN=${MYDOMAIN:-ztncui.docker.test} # Used for minica
ZTNCUI_PASSWD=${ZTNCUI_PASSWD:-password} # Used for argon2g
MYADDR=${MYADDR}
HTTP_ALL_INTERFACES=${HTTP_ALL_INTERFACES}
HTTP_PORT=${HTTP_PORT:-3000}
PLANET_RETR_PUBLIC=${PLANET_RETR_PUBLIC}
# HTTPS Disabled
# HTTPS_PORT=${HTTPS_PORT:-3443}
echo "YOUR DOMAIN: ${MYDOMAIN}"
while [ ! -f /var/lib/zerotier-one/authtoken.secret ]; do
echo "ZT1 AuthToken is not found... Wait for ZT1 to start..."
sleep 2
done
chown zerotier-one:zerotier-one /var/lib/zerotier-one/authtoken.secret
chmod 640 /var/lib/zerotier-one/authtoken.secret
cd /opt/key-networks/ztncui
echo "NODE_ENV=production" > /opt/key-networks/ztncui/.env
echo "MYADDR=$MYADDR" >> /opt/key-networks/ztncui/.env
echo "HTTP_PORT=$HTTP_PORT" >> /opt/key-networks/ztncui/.env
if [ ! -z $HTTP_ALL_INTERFACES ]; then
echo "HTTP_ALL_INTERFACES=$HTTP_ALL_INTERFACES" >> /opt/key-networks/ztncui/.env
else
[ ! -z $HTTPS_PORT ] && echo "HTTPS_PORT=$HTTPS_PORT" >> /opt/key-networks/ztncui/.env
fi
echo "ZTNCUI ENV CONFIGURATION: "
cat /opt/key-networks/ztncui/.env
mkdir -p /opt/key-networks/ztncui/etc/storage
mkdir -p /opt/key-networks/ztncui/etc/tls
mkdir -p /opt/key-networks/ztncui/etc/httpfs # for planet files
if [ ! -f /opt/key-networks/ztncui/etc/passwd ]; then
echo "Default Password File Not Exists... Generating..."
cd /opt/key-networks/ztncui/etc
/usr/local/bin/argon2g
cd ../
fi
if [ ! -f /opt/key-networks/ztncui/etc/tls/fullchain.pem ] || [ ! -f /opt/key-networks/ztncui/etc/tls/privkey.pem ]; then
echo "Cannot detect TLS Certs, Generating..."
cd /opt/key-networks/ztncui/etc/tls
/usr/local/bin/minica -domains "$MYDOMAIN"
cat "$MYDOMAIN/cert.pem" minica.pem > fullchain.pem
cp -f "$MYDOMAIN/key.pem" privkey.pem
cp -f minica.pem /opt/key-networks/ztncui/etc/httpfs/ca.pem
cd ../../
fi
chown -R zerotier-one:zerotier-one /opt/key-networks/ztncui
chmod 0755 /opt/key-networks/ztncui/ztncui
unset ZTNCUI_PASSWD
/usr/local/bin/gosu zerotier-one:zerotier-one /opt/key-networks/ztncui/ztncui