-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.sh
executable file
·60 lines (45 loc) · 1.71 KB
/
main.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
#!/bin/bash
CRT="/etc/perdition/perdition.crt.pem"
KEY="/etc/perdition/perdition.key.pem"
DB=$MYSQL_DATABASE
USER=$MYSQL_USER
PASS=$MYSQL_PASSWORD
HOST=${MYSQL_HOST:-"db"}
while ! mysqladmin ping -h"$HOST" --silent; do
echo "waiting for mariadb service port....";
sleep 1
done
#DB initialization
TBL=$(echo "show tables;" | mysql -h$HOST -u$USER -p$PASS $DB|wc -l)
if [ "$TBL" -gt "0" ]
then
echo "truncate exist data...";
echo "truncate tblPerdition;" | mysql -h$HOST -u$USER -p$PASS $DB;
else
echo "table not exist, initializing...";
SQL="CREATE TABLE tblPerdition (user varchar(128) NOT NULL, servername varchar(255) NOT NULL, port varchar(8) DEFAULT NULL, PRIMARY KEY (user), KEY idxtblPerdition_user (user) ) ENGINE=MyISAM DEFAULT CHARSET=latin1;"
echo $SQL | mysql -h$HOST -u$USER -p$PASS $DB;
fi
#import server list from popmap file to table in DB
if [ -f /config/popmap ]
then
cp -f /config/popmap /etc/perdition/popmap
fi
for i in $(cat /etc/perdition/popmap);
do
DOMAIN=$(echo $i|cut -d: -f1);
SERVER=$(echo $i|cut -d: -f2);
PORT=$(echo $i|cut -d: -f3);
INSERT="INSERT INTO tblPerdition (user, servername, port) VALUES ('$DOMAIN', '$SERVER', '$PORT');"
echo $INSERT | mysql -h$HOST -u$USER -p$PASS $DB;
done
if [ ! -f "$CRT" ] || [ ! -f "$KEY" ]; then
echo "certificado y key no definido, generando nuevo"
# Generar certificado autofirmado y key
openssl req -new -x509 -days 365 -nodes -out $CRT -keyout $KEY -subj "/C=CL/ST=MT/L=Santiago/O=My Organization/OU=TI/CN=perdition-proxy.org"
fi
/usr/sbin/rsyslogd -n -iNONE &
touch /var/log/syslog
chown syslog.adm /var/log/syslog
/etc/init.d/perdition start &
tail -f /var/log/syslog