forked from hetzneronline/installimage
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcpanel.functions.sh
149 lines (122 loc) · 4.47 KB
/
cpanel.functions.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
#!/usr/bin/env bash
#
# cpanel functions
#
# (c) 2008-2018, Hetzner Online GmbH
#
# is_cpanel_install()
# is this a cpanel install?
is_cpanel_install() {
[[ "${OPT_INSTALL,,}" == cpanel ]] || [[ "${IMAGENAME,,}" == *cpanel ]]
}
# cpanel_setup_mainip()
cpanel_setup_mainip() {
local mainip_file=/var/cpanel/mainip
local v4_main_ip
v4_main_ip="$(v4_main_ip)"
if [[ -n "$v4_main_ip" ]]; then
debug "# setting up ${mainip_file}"
echo -n "$(ip_addr_without_suffix "$v4_main_ip")" > "${FOLD}/hdd/${mainip_file}"
return
fi
debug "fatal: no IPv4 main IP: not setting up $mainip_file"
return 1
}
# cpanel_setup_wwwacct_conf()
cpanel_setup_wwwacct_conf() {
local wwwacct_conf; wwwacct_conf=/etc/wwwacct.conf
local v4_main_ip
v4_main_ip="$(v4_main_ip)"
if [[ -z "$v4_main_ip" ]]; then
debug "fatal: no IPv4 main IP: can not set up $wwwacct_conf"
return 1
fi
debug "# setting up ${wwwacct_conf}"
sed --expression='/^ADDR\s/d' \
--expression='/^HOST\s/d' \
--expression='/^NS[[:digit:]]*\s/d' \
--in-place "${FOLD}/hdd/${wwwacct_conf}"
{
echo
echo "### ${COMPANY} installimage"
echo "ADDR $(ip_addr_without_suffix "$v4_main_ip")"
echo "HOST ${NEWHOSTNAME}"
echo "NS ${AUTH_DNS1}"
echo "NS2 ${AUTH_DNS2}"
echo "NS3 ${AUTH_DNS3}"
echo 'NS4'
} >> "${FOLD}/hdd/${wwwacct_conf}"
}
# randomize_cpanel_passwords()
randomize_cpanel_passwords() {
debug '# randomizing cpanel passwords'
# passwords of the following database users must be randomized
# * root
# * cphulkd
# * eximstats
# * leechprotect
# * modsec
# * roundcube
local root_password; root_password=$(generate_password)
local cphulkd_password; cphulkd_password=$(generate_password)
local eximstats_password; eximstats_password=$(generate_password)
local leechprotect_password; leechprotect_password=$(generate_password)
local roundcube_password; roundcube_password=$(generate_password)
reset_mysql_root_password "$root_password" || return 1
set_mysql_password cphulkd "${cphulkd_password}" || return 1
set_mysql_password eximstats "${eximstats_password}" || return 1
set_mysql_password leechprotect "${leechprotect_password}" || return 1
set_mysql_password roundcube "${roundcube_password}" || return 1
echo "${cphulkd_password}" > "${FOLD}/hdd/var/cpanel/hulkd/password"
echo "${eximstats_password}" > "${FOLD}/hdd/var/cpanel/eximstatspass"
echo "${leechprotect_password}" > "${FOLD}/hdd/var/cpanel/leechprotectpass"
echo "${roundcube_password}" > "${FOLD}/hdd/var/cpanel/roundcubepass"
systemd_nspawn /usr/local/cpanel/bin/updateeximstats || return 1
systemd_nspawn /usr/local/cpanel/bin/updateleechprotect || return 1
systemd_nspawn /usr/local/cpanel/bin/modsecpass || return 1
systemd_nspawn /usr/local/cpanel/bin/update-roundcube --force || return 1
poweroff_systemd_nspawn
debug 'randomized cpanel passwords'
}
# setup_cpanel()
setup_cpanel() {
debug '# setting up cpanel'
cpanel_setup_mainip
cpanel_setup_wwwacct_conf || return 1
randomize_cpanel_passwords || return 1
debug 'set up cpanel'
}
# install_cpanel()
install_cpanel() {
local temp_file="/cpanel-installer"
debug "# downloading cpanel installer ${CPANEL_INSTALLER_SRC}/${IMAGENAME}"
curl --location --output "${FOLD}/hdd/${temp_file}" --silent --write-out '%{response_code}' "${CPANEL_INSTALLER_SRC}/${IMAGENAME}" \
| grep --quiet 200 || return 1
chmod a+x "${FOLD}/hdd/${temp_file}"
debug 'downloaded cpanel installer'
execute_chroot_command 'yum check-update' # || return 1
execute_chroot_command 'yum -y install yum-utils' || return 1
if [[ -e "$FOLD/hdd/usr/bin/needs-restarting" ]]; then
mv "$FOLD/hdd/usr/bin/needs-restarting" "$FOLD/hdd/usr/bin/needs-restarting.bak"
{
echo '#!/usr/bin/env bash'
echo '/usr/bin/needs-restarting.bak | grep -v systemd_nspawn-runner'
} > "$FOLD/hdd/usr/bin/needs-restarting"
chmod 755 "$FOLD/hdd/usr/bin/needs-restarting"
fi
debug '# installing cpanel'
local command="${temp_file} --force"
if installed_os_uses_systemd && ! systemd_nspawn_booted; then
boot_systemd_nspawn || return 1
fi
execute_command "${command}" || return 1
systemd_nspawn_booted && poweroff_systemd_nspawn
if [[ -e "$FOLD/hdd/usr/bin/needs-restarting.bak" ]]; then
mv "$FOLD/hdd/usr/bin/needs-restarting.bak" "$FOLD/hdd/usr/bin/needs-restarting"
fi
debug '# setting up cpanel'
cpanel_setup_wwwacct_conf || return 1
debug 'set up cpanel'
debug 'installed cpanel'
}
# vim: ai:ts=2:sw=2:et