-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathonekey_run_vpnserver.sh
118 lines (103 loc) · 3.47 KB
/
onekey_run_vpnserver.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
#!/bin/bash
# File desc: onekey install ikev2 vpn server on docker
# Requirements: ubuntu 16.04+ / Centos7+
# Time: 2018-05-06
install_docker(){
if python -mplatform | grep -qi ubuntu ; then
export os_type=ubuntu
elif python -mplatform | grep -qi centos-6 ; then
echo "Error: Linux System is Centos6.x,Please update to Centos7.x"
echo "Exit install process..."
exit
elif python -mplatform | grep -qi centos-7 ; then
export os_type=centos
else
echo -e 'Unknow system platform\n'
fi
case $os_type in
ubuntu)
echo -e "*************** Install Docker... *******************\n"
sudo apt-get update
sudo apt-get install apt-transport-https ca-certificates ca-certificates software-properties-common dnsutils
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get update
sudo apt-get install -y docker-ce
sudo systemctl enable docker -q
sudo systemctl start docker
echo -e "\n*************** Install docker on ubuntu. "
;;
centos)
echo -e "\n*************** Install Docker... *******************"
sudo yum install -y yum-utils device-mapper-persistent-data lvm2 bind-utils
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install -y docker-ce-17.12.1.ce-1.el7.centos
sudo systemctl enable docker -q
sudo systemctl start docker
echo -e "\n*************** install docker on centos ***************"
;;
*)
echo -e "\n*************** please check os platform"
;;
esac
}
# ensure docker is running
running_docker(){
sudo systemctl start docker
}
# pull image command
pull_image(){
echo -e "\n*************** Pull ikev2 vpn image from docker hub... ***************"
sudo docker pull hanyifeng/alpine-ikev2-vpn
}
# run command
run_docker(){
sudo docker run --restart=always -itd --privileged -v /lib/modules:/lib/modules \
-e HOST_IP=$PUBLIC_IP -e VPNUSER=$VPNUSER -e VPNPASS="$VPNPASS" \
-p 500:500/udp -p 4500:4500/udp --name=ikev2-vpn hanyifeng/alpine-ikev2-vpn
}
# Run ikev2 server
run_vpnserver(){
export PUBLIC_IP=`dig +short myip.opendns.com @resolver1.opendns.com`
export VPNUSER=$1
export VPNPASS=$2
CONTAINER_NAME=`sudo docker ps -f name=ikev2-vpn --format '{{.Names}}'`
echo -e "\n*************** Start vpn server...***************"
if [ "$CONTAINER_NAME" = 'ikev2-vpn' ]; then
echo -e "\n*************** Delete old vpn server. "
sudo docker rm -f $CONTAINER_NAME
run_docker
else
run_docker
fi
echo -e "\n*************** Vpn Server is up, just a moment... ***************"
sleep 3
}
# Generate certificate
generate_cert(){
echo -e "\n*************** Generate certificate ***************"
sudo docker exec -it ikev2-vpn sh /usr/bin/vpn
echo -e "\n*************** Congratulations. 42. *************** "
echo "Note: Don't forget to set the cloud host's firewall to allow udp port 500 and port 4500 traffic ! ^_^"
}
install_dep_tools(){
echo "Install Dependent soft tools"
yum install bind-utils -y
}
# ensure installed docker engine
command -v docker >/dev/null 2>&1
if [ $? -eq 0 ] ; then
echo "Docker already exists !"
install_dep_tools
running_docker
pull_image
run_vpnserver $@
generate_cert
else
install_docker
install_dep_tools
running_docker
pull_image
run_vpnserver $@
generate_cert
fi