-
Notifications
You must be signed in to change notification settings - Fork 128
/
Copy pathwormholes_install.sh
120 lines (112 loc) · 4.75 KB
/
wormholes_install.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
#!/bin/bash
#check docker cmd
echo "Script version Number: v0.13.2"
which docker >/dev/null 2>&1
if [ $? -ne 0 ] ; then
echo "docker not found, please install first!"
echo "ubuntu:sudo apt install docker.io -y"
echo "centos:yum install -y docker-ce "
echo "fedora:sudo dnf install -y docker-ce"
exit
fi
#check docker service
docker ps > /dev/null 2>&1
if [ $? -ne 0 ] ; then
echo "docker service is not running! you can use command start it:"
echo "sudo service docker start"
exit
fi
vt5=1670383155
vl=$(wget https://docker.wormholes.com/version>/dev/null 2>&1 && cat version|awk '{print $1}')
vr=$(cat version|awk '{print $2}' && rm version)
worm=$(docker images|grep "wormholestech/wormholes"|grep "v1")
if [ -n "$worm" ];then
ct=$(docker inspect wormholestech/wormholes:v1 -f {{.Created}})
cts=$(date -d "$ct" +%s)
if [ $cts -eq $vl ];then
container=$(docker ps -a|awk '{if($NF == "wormholes")print $0}')
if [[ $container =~ "Up" ]];then
while true
do
key=$(docker exec -it wormholes /usr/bin/ls -l /wm/.wormholes/wormholes/nodekey)
if [ -n "$key" ];then
echo -e "It is the latest version: $vr \nYour private key:"
docker exec -it wormholes /usr/bin/cat .wormholes/wormholes/nodekey
echo -e "\n"
exit 0
else
sleep 5s
fi
done
elif [[ $container =~ "Exited" ]];then
echo -e "Your peer isn't running\nYou can use 'docker start wormholes' to start the node"
exit 0
else
docker rm wormholes
read -p "Enter your private key:" ky
fi
elif [ $cts -lt $vl ];then
docker stop wormholes > /dev/null 2>&1
docker rm wormholes > /dev/null 2>&1
docker rmi wormholestech/wormholes:v1 > /dev/null 2>&1
if [ $cts -lt $vt5 ];then
if [ -f /wm/.wormholes/wormholes/nodekey ];then
echo "Clearing historical data ............"
cp /wm/.wormholes/wormholes/nodekey /wm/nodekey
rm -rf /wm/.wormholes
mkdir -p /wm/.wormholes/wormholes
mv /wm/nodekey /wm/.wormholes/wormholes/
else
read -p "Enter your private key:" ky
fi
elif [ $cts -ge $vt5 ];then
if [ ! -f /wm/.wormholes/wormholes/nodekey ];then
read -p "Enter your private key:" ky
fi
fi
fi
else
read -p "Enter your private key:" ky
fi
if [ -n "$ky" ]; then
mkdir -p /wm/.wormholes/wormholes
if [ ${#ky} -eq 64 ];then
echo $ky > /wm/.wormholes/wormholes/nodekey
elif [ ${#ky} -eq 66 ] && ([ ${ky:0:2} == "0x" ] || [ ${ky:0:2} == "0X" ]);then
echo ${ky:2:64} > /wm/.wormholes/wormholes/nodekey
else
echo "the nodekey format is not correct"
exit 1
fi
fi
docker pull wormholestech/wormholes:v1
docker images|awk '{print $1,$2}'|while read img ver
do
if [[ $img == "wormholestech/wormholes" ]] && [[ $ver == "v1" ]];then
echo "true">temp
break
fi
done
if [[ -f temp ]];then
rm temp
echo -e "\n\033[32mdocker pull images complete. Start running the container, please wait\033[0m\n"
else
echo -e "\033[31mdocker pull err, please check your network\033[0m"
exit 1
fi
docker run -id -p 30303:30303 -p 8545:8545 -v /wm/.wormholes:/wm/.wormholes --name wormholes wormholestech/wormholes:v1
while true
do
echo -e "running the container...\n"
s=$(docker ps -a|grep "Up"|awk '{if($NF == "wormholes") print $NF}'|wc -l)
key=$(docker exec -it wormholes /usr/bin/ls -l /wm/.wormholes/wormholes/nodekey 2>/dev/null)
if [[ $s -gt 0 ]] && [[ "$key" =~ "nodekey" ]];then
echo "Your private key is:"
docker exec -it wormholes /usr/bin/cat /wm/.wormholes/wormholes/nodekey
echo -ne "\n"
docker exec -it wormholes ./wormholes version|grep "Version"|grep -v go
break
else
sleep 5s
fi
done