forked from oneinstack/oneinstack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaddons.sh
executable file
·185 lines (173 loc) · 4.83 KB
/
addons.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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
#!/bin/bash
# Author: yeho <lj2007331 AT gmail.com>
# BLOG: https://linuxeye.com
#
# Notes: OneinStack for CentOS/RedHat 7+ Debian 9+ and Ubuntu 16+
#
# Project home page:
# https://oneinstack.com
# https://github.com/oneinstack/oneinstack
export PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin
clear
printf "
#######################################################################
# OneinStack for CentOS/RedHat 7+ Debian 9+ and Ubuntu 16+ #
# Install/Uninstall Extensions #
# For more information please visit https://oneinstack.com #
#######################################################################
"
# Check if user is root
# shellcheck disable=SC2046
[ $(id -u) != '0' ] && { echo "${CFAILURE}Error: You must be root to run this script${CEND}"; exit 1; }
oneinstack_dir=$(dirname "`readlink -f $0`")
# shellcheck disable=SC2164
pushd ${oneinstack_dir} > /dev/null
. ./versions.txt
. ./options.conf
. ./include/color.sh
. ./include/check_os.sh
. ./include/download.sh
. ./include/get_char.sh
. ./include/composer.sh
. ./include/fail2ban.sh
. ./include/ngx_lua_waf.sh
# get the out ip country
OUTIP_STATE=$(./include/ois.${ARCH} ip_state)
# shellcheck disable=SC2154
Show_Help() {
echo
echo "Usage: $0 command ...
--help, -h Show this help message
--install, -i Install
--uninstall, -u Uninstall
--composer Composer
--fail2ban Fail2ban
--ngx_lua_waf Ngx_lua_waf
"
}
ARG_NUM=$#
TEMP=`getopt -o hiu --long help,install,uninstall,composer,fail2ban,ngx_lua_waf -- "$@" 2>/dev/null`
[ $? != 0 ] && echo "${CWARNING}ERROR: unknown argument! ${CEND}" && Show_Help && exit 1
eval set -- "${TEMP}"
while :; do
[ -z "$1" ] && break;
case "$1" in
-h|--help)
Show_Help; exit 0
;;
-i|--install)
install_flag=y; shift 1
;;
-u|--uninstall)
uninstall_flag=y; shift 1
;;
--composer)
composer_flag=y; shift 1
;;
--fail2ban)
fail2ban_flag=y; shift 1
;;
--ngx_lua_waf)
ngx_lua_waf_flag=y; shift 1
;;
--)
shift
;;
*)
echo "${CWARNING}ERROR: unknown argument! ${CEND}" && Show_Help && exit 1
;;
esac
done
ACTION_FUN() {
while :; do
echo
echo "Please select an action:"
echo -e "\t${CMSG}1${CEND}. install"
echo -e "\t${CMSG}2${CEND}. uninstall"
read -e -p "Please input a number:(Default 1 press Enter) " ACTION
ACTION=${ACTION:-1}
if [[ ! "${ACTION}" =~ ^[1,2]$ ]]; then
echo "${CWARNING}input error! Please only input number 1~2${CEND}"
else
[ "${ACTION}" == '1' ] && install_flag=y
[ "${ACTION}" == '2' ] && uninstall_flag=y
break
fi
done
}
Menu() {
while :;do
printf "
What Are You Doing?
\t${CMSG}1${CEND}. Install/Uninstall PHP Composer
\t${CMSG}2${CEND}. Install/Uninstall fail2ban
\t${CMSG}3${CEND}. Install/Uninstall ngx_lua_waf
\t${CMSG}q${CEND}. Exit
"
read -e -p "Please input the correct option: " Number
if [[ ! "${Number}" =~ ^[1-3,q]$ ]]; then
echo "${CFAILURE}input error! Please only input 1~3 and q${CEND}"
else
case "${Number}" in
1)
ACTION_FUN
if [ "${install_flag}" = 'y' ]; then
Install_composer
elif [ "${uninstall_flag}" = 'y' ]; then
Uninstall_composer
fi
;;
2)
ACTION_FUN
if [ "${install_flag}" = 'y' ]; then
Install_fail2ban
elif [ "${uninstall_flag}" = 'y' ]; then
Uninstall_fail2ban
fi
;;
3)
ACTION_FUN
if [ "${install_flag}" = 'y' ]; then
# shellcheck disable=SC2154
[ -e "${nginx_install_dir}/sbin/nginx" ] && Nginx_lua_waf
# shellcheck disable=SC2154
[ -e "${tengine_install_dir}/sbin/nginx" ] && Tengine_lua_waf
enable_lua_waf
elif [ "${uninstall_flag}" = 'y' ]; then
disable_lua_waf
fi
;;
q)
exit
;;
esac
fi
done
}
if [ ${ARG_NUM} == 0 ]; then
Menu
else
if [ "${composer_flag}" == 'y' ]; then
if [ "${install_flag}" = 'y' ]; then
Install_composer
elif [ "${uninstall_flag}" = 'y' ]; then
Uninstall_composer
fi
fi
if [ "${fail2ban_flag}" == 'y' ]; then
if [ "${install_flag}" = 'y' ]; then
Install_fail2ban
elif [ "${uninstall_flag}" = 'y' ]; then
Uninstall_fail2ban
fi
fi
if [ "${ngx_lua_waf_flag}" == 'y' ]; then
if [ "${install_flag}" = 'y' ]; then
[ -e "${nginx_install_dir}/sbin/nginx" ] && Nginx_lua_waf
[ -e "${tengine_install_dir}/sbin/nginx" ] && Tengine_lua_waf
enable_lua_waf
elif [ "${uninstall_flag}" = 'y' ]; then
disable_lua_waf
fi
fi
fi