mirror of
https://github.com/EngineGPDev/Autoinstall.git
synced 2025-01-18 22:02:22 +03:00
Fix settings in MySQL
This commit is contained in:
parent
3e843af3f9
commit
a8e9432373
72
install.sh
72
install.sh
@ -159,8 +159,8 @@ while true; do
|
|||||||
# Проверяем, содержится ли текущая версия в массиве поддерживаемых версий
|
# Проверяем, содержится ли текущая версия в массиве поддерживаемых версий
|
||||||
if [[ " ${suppOS[@]} " =~ " ${currOS} " ]]; then
|
if [[ " ${suppOS[@]} " =~ " ${currOS} " ]]; then
|
||||||
# Список пакетов для установки
|
# Список пакетов для установки
|
||||||
pkgsLNAMP=(apache2 php php-fpm php-ctype php-json php-mbstring php-zip php-gd php-xml php-curl libapache2-mod-php libapache2-mod-fcgid nginx)
|
pkgsLNAMP=(apache2 php php-fpm php-ctype php-json php-mbstring php-zip php-gd php-xml php-curl libapache2-mod-fcgid nginx)
|
||||||
pkgsEGP=(ufw memcached cron php$verPHP php$verPHP-fpm php$verPHP-common php$verPHP-cli php$verPHP-memcache php$verPHP-memcached php$verPHP-mysql php$verPHP-xml php$verPHP-mbstring php$verPHP-gd php$verPHP-imagick php$verPHP-zip php$verPHP-curl php$verPHP-ssh2 php$verPHP-xml libapache2-mod-php$verPHP)
|
pkgsEGP=(ufw memcached cron php$verPHP php$verPHP-fpm php$verPHP-common php$verPHP-cli php$verPHP-memcache php$verPHP-memcached php$verPHP-mysql php$verPHP-xml php$verPHP-mbstring php$verPHP-gd php$verPHP-imagick php$verPHP-zip php$verPHP-curl php$verPHP-ssh2 php$verPHP-xml)
|
||||||
|
|
||||||
# Установка стека LNAMP + phpMyAdmin
|
# Установка стека LNAMP + phpMyAdmin
|
||||||
# Проверяем наличие репозитория php sury
|
# Проверяем наличие репозитория php sury
|
||||||
@ -197,16 +197,13 @@ while true; do
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Генерирование паролей и имён
|
# Генерирование паролей и имён
|
||||||
passSQL=$(pwgen -cnys -1 16)
|
passSQL=$(pwgen -cns -1 16)
|
||||||
safePassSQL=$(printf '%s\n' "$passSQL" | sed -e 's/[\&/]/\\&/g')
|
passPMA=$(pwgen -cns -1 16)
|
||||||
passPMA=$(pwgen -cnys -1 16)
|
usrEgpSQL="enginegp_$(pwgen -cns -1 8)"
|
||||||
safePassPMA=$(printf '%s\n' "$passPMA" | sed -e 's/[\&/]/\\&/g')
|
|
||||||
usrEgpSQL="enginegp_$(pwgen -1 8)"
|
|
||||||
dbEgpSQL="enginegp_$(pwgen -1 8)"
|
dbEgpSQL="enginegp_$(pwgen -1 8)"
|
||||||
passEgpSQL=$(pwgen -cnys -1 16)
|
passEgpSQL=$(pwgen -cns -1 16)
|
||||||
safePassEgpSQL=$(printf '%s\n' "$passEgpSQL" | sed -e 's/[\&/]/\\&/g')
|
|
||||||
usrEgpPASS=$(pwgen -cns -1 16)
|
usrEgpPASS=$(pwgen -cns -1 16)
|
||||||
usrEgpHASH=$(echo -n "$usrEgpPASS" | md5sum | sed 's/ -//')
|
usrEgpHASH=$(echo -n "$usrEgpPASS" | sed 's/-//' | tr -d '[:space:]')
|
||||||
|
|
||||||
# Конфигурация apache для EngineGP
|
# Конфигурация apache для EngineGP
|
||||||
apache_enginegp="<VirtualHost *:8080>
|
apache_enginegp="<VirtualHost *:8080>
|
||||||
@ -288,23 +285,23 @@ EOF
|
|||||||
sudo apt-get update >> $logsINST 2>&1
|
sudo apt-get update >> $logsINST 2>&1
|
||||||
sudo rm mysql-apt-config_0.8.26-1_all.deb >> $logsINST 2>&1
|
sudo rm mysql-apt-config_0.8.26-1_all.deb >> $logsINST 2>&1
|
||||||
sudo debconf-set-selections <<EOF
|
sudo debconf-set-selections <<EOF
|
||||||
mysql-community-server mysql-community-server/root-pass password $safePassSQL
|
mysql-community-server mysql-community-server/root-pass password $passSQL
|
||||||
mysql-community-server mysql-community-server/re-root-pass password $safePassSQL
|
mysql-community-server mysql-community-server/re-root-pass password $passSQL
|
||||||
mysql-community-server mysql-server/default-auth-override select Use Strong Password Encryption (RECOMMENDED)
|
mysql-community-server mysql-server/default-auth-override select Use Strong Password Encryption (RECOMMENDED)
|
||||||
EOF
|
EOF
|
||||||
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y mysql-server >> $logsINST 2>&1
|
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y mysql-server >> $logsINST 2>&1
|
||||||
|
|
||||||
# Создание пользователя
|
# Создание пользователя
|
||||||
mysql -h localhost -u root -p$safePassSQL -e "CREATE USER '$usrEgpSQL'@'localhost' IDENTIFIED BY '$safePassEgpSQL';" >> $logsINST 2>&1
|
mysql -u root -p$passSQL -e "CREATE USER '$usrEgpSQL'@'localhost' IDENTIFIED BY '$passEgpSQL';" >> $logsINST 2>&1
|
||||||
|
|
||||||
# Создание базы данных
|
# Создание базы данных
|
||||||
mysql -h localhost -u root -p$safePassSQL -e "CREATE DATABASE $dbEgpSQL;" >> $logsINST 2>&1
|
mysql -u root -p$passSQL -e "CREATE DATABASE $dbEgpSQL;" >> $logsINST 2>&1
|
||||||
|
|
||||||
# Предоставление привилегий пользователю на базу данных
|
# Предоставление привилегий пользователю на базу данных
|
||||||
mysql -h localhost -u root -p$safePassSQL -e "GRANT ALL PRIVILEGES ON $dbEgpSQL.* TO '$usrEgpSQL'@'localhost';" >> $logsINST 2>&1
|
mysql -u root -p$passSQL -e "GRANT ALL PRIVILEGES ON $dbEgpSQL.* TO '$usrEgpSQL'@'localhost';" >> $logsINST 2>&1
|
||||||
|
|
||||||
# Применение изменений привилегий
|
# Применение изменений привилегий
|
||||||
mysql -h localhost -u root -p$safePassSQL -e "FLUSH PRIVILEGES;" >> $logsINST 2>&1
|
mysql -u root -p$passSQL -e "FLUSH PRIVILEGES;" >> $logsINST 2>&1
|
||||||
else
|
else
|
||||||
echo "===================================" >> $logsINST 2>&1
|
echo "===================================" >> $logsINST 2>&1
|
||||||
echo "mysql-server уже установлен в системе. Продолжение установки невозможно." | tee -a $logsINST
|
echo "mysql-server уже установлен в системе. Продолжение установки невозможно." | tee -a $logsINST
|
||||||
@ -350,10 +347,10 @@ EOF
|
|||||||
echo "===================================" >> $logsINST 2>&1
|
echo "===================================" >> $logsINST 2>&1
|
||||||
sudo debconf-set-selections <<EOF
|
sudo debconf-set-selections <<EOF
|
||||||
phpmyadmin phpmyadmin/dbconfig-install boolean true
|
phpmyadmin phpmyadmin/dbconfig-install boolean true
|
||||||
phpmyadmin phpmyadmin/mysql/app-pass password $safePassPMA
|
phpmyadmin phpmyadmin/mysql/app-pass password $passPMA
|
||||||
phpmyadmin phpmyadmin/password-confirm password $safePassPMA
|
phpmyadmin phpmyadmin/password-confirm password $passPMA
|
||||||
phpmyadmin phpmyadmin/mysql/admin-pass password $safePassSQL
|
phpmyadmin phpmyadmin/mysql/admin-pass password $passSQL
|
||||||
phpmyadmin phpmyadmin/app-password-confirm password $safePassSQL
|
phpmyadmin phpmyadmin/app-password-confirm password $passSQL
|
||||||
phpmyadmin phpmyadmin/reconfigure-webserver multiselect
|
phpmyadmin phpmyadmin/reconfigure-webserver multiselect
|
||||||
EOF
|
EOF
|
||||||
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y phpmyadmin >> $logsINST 2>&1
|
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y phpmyadmin >> $logsINST 2>&1
|
||||||
@ -469,15 +466,10 @@ EOF
|
|||||||
sudo rm -r /tmp/enginegp/EngineGP-* >> $logsINST 2>&1
|
sudo rm -r /tmp/enginegp/EngineGP-* >> $logsINST 2>&1
|
||||||
sed -i "s/IPADDR/$sysIP/g" /var/www/enginegp/system/data/config.php >> $logsINST 2>&1
|
sed -i "s/IPADDR/$sysIP/g" /var/www/enginegp/system/data/config.php >> $logsINST 2>&1
|
||||||
sed -i "s/root/$usrEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
sed -i "s/root/$usrEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
||||||
sed -i "s/SQLPASS/$safePassEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
sed -i "s/SQLPASS/$passEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
||||||
sed -i "s/enginegp/$dbEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
sed -i "s/enginegp/$dbEgpSQL/g" /var/www/enginegp/system/data/mysql.php >> $logsINST 2>&1
|
||||||
sed -i "s/ENGINEGPHASH/$usrEgpHASH/g" /var/www/enginegp/enginegp.sql >> $logsINST 2>&1
|
sed -i "s/ENGINEGPHASH/$usrEgpHASH/g" /var/www/enginegp/enginegp.sql >> $logsINST 2>&1
|
||||||
mysql -h localhost -u $usrEgpSQL -p$safePassEgpSQL $dbEgpSQL < /var/www/enginegp/enginegp.sql >> $logsINST 2>&1
|
mysql -u $usrEgpSQL -p$passEgpSQL $dbEgpSQL < /var/www/enginegp/enginegp.sql >> $logsINST 2>&1
|
||||||
# Генерация и хэширование пароля
|
|
||||||
#saltEGP=$(pwgen -cnys -1 16) # Необходимо записывать в system.php и acpsystem.php
|
|
||||||
#passEGP=$(pwgen -cnys -1 16)
|
|
||||||
#hashedPassEGP=$(echo -n "$saltEGP$passEGP" | sha512sum)
|
|
||||||
#hashedPassEGP=${hashedPassEGP%% *}
|
|
||||||
else
|
else
|
||||||
echo "===================================" >> $logsINST 2>&1
|
echo "===================================" >> $logsINST 2>&1
|
||||||
echo "enginegp уже установлен в системе. Продолжение установки невозможно." | tee -a $logsINST
|
echo "enginegp уже установлен в системе. Продолжение установки невозможно." | tee -a $logsINST
|
||||||
@ -511,9 +503,10 @@ EOF
|
|||||||
echo "Ссылка на сайт: http://$sysIP/" | tee -a $saveDIR
|
echo "Ссылка на сайт: http://$sysIP/" | tee -a $saveDIR
|
||||||
echo "Пользователь: root" | tee -a $saveDIR
|
echo "Пользователь: root" | tee -a $saveDIR
|
||||||
echo "Пароль: $usrEgpPASS" | tee -a $saveDIR
|
echo "Пароль: $usrEgpPASS" | tee -a $saveDIR
|
||||||
echo "Пароль MySQL от $usrEgpSQL: $safePassEgpSQL" | tee -a $saveDIR
|
echo "Таблица EngineGP: $dbEgpSQL" | tee -a $saveDIR
|
||||||
echo "Пароль MySQL от root: $safePassSQL" | tee -a $saveDIR
|
echo "Пароль MySQL от $usrEgpSQL: $passEgpSQL" | tee -a $saveDIR
|
||||||
echo "Пароль MySQL от phpmyadmin: $safePassPMA" | tee -a $saveDIR
|
echo "Пароль MySQL от root: $passSQL" | tee -a $saveDIR
|
||||||
|
echo "Пароль MySQL от phpmyadmin: $passPMA" | tee -a $saveDIR
|
||||||
echo "===================================" >> $logsINST 2>&1
|
echo "===================================" >> $logsINST 2>&1
|
||||||
read -p "Нажмите Enter для завершения..."
|
read -p "Нажмите Enter для завершения..."
|
||||||
continue
|
continue
|
||||||
@ -529,9 +522,8 @@ EOF
|
|||||||
# Проверяем, содержится ли текущая версия в массиве поддерживаемых версий
|
# Проверяем, содержится ли текущая версия в массиве поддерживаемых версий
|
||||||
if [[ " ${suppOS[@]} " =~ " ${currOS} " ]]; then
|
if [[ " ${suppOS[@]} " =~ " ${currOS} " ]]; then
|
||||||
pkgsLOC=(lib32z1 libbabeltrace1 libc6-dbg libdw1 lib32stdc++6 libreadline5 lib32gcc1 screen tcpdump lsof qstat gdb-minimal ntpdate gcc-multilib iptables default-jdk nginx)
|
pkgsLOC=(lib32z1 libbabeltrace1 libc6-dbg libdw1 lib32stdc++6 libreadline5 lib32gcc1 screen tcpdump lsof qstat gdb-minimal ntpdate gcc-multilib iptables default-jdk nginx)
|
||||||
passMySQL=$(pwgen -cnys -1 16)
|
passMySQL=$(pwgen -cns -1 16)
|
||||||
safePassMySQL=$(printf '%s\n' "$passMySQL" | sed -e 's/[\&/]/\\&/g')
|
passProFTPD=$(pwgen -cns -1 16)
|
||||||
passProFTPD=$(pwgen -cnys -1 16)
|
|
||||||
|
|
||||||
if ! dpkg --print-foreign-architectures | grep -q "i386"; then
|
if ! dpkg --print-foreign-architectures | grep -q "i386"; then
|
||||||
echo "===================================" >> $logsINST 2>&1
|
echo "===================================" >> $logsINST 2>&1
|
||||||
@ -562,8 +554,8 @@ EOF
|
|||||||
sudo apt-get update >> $logsINST 2>&1
|
sudo apt-get update >> $logsINST 2>&1
|
||||||
sudo rm mysql-apt-config_0.8.26-1_all.deb >> $logsINST 2>&1
|
sudo rm mysql-apt-config_0.8.26-1_all.deb >> $logsINST 2>&1
|
||||||
sudo debconf-set-selections <<EOF
|
sudo debconf-set-selections <<EOF
|
||||||
mysql-community-server mysql-community-server/root-pass password $safePassMySQL
|
mysql-community-server mysql-community-server/root-pass password $passMySQL
|
||||||
mysql-community-server mysql-community-server/re-root-pass password $safePassMySQL
|
mysql-community-server mysql-community-server/re-root-pass password $passMySQL
|
||||||
mysql-community-server mysql-server/default-auth-override select Use Strong Password Encryption (RECOMMENDED)
|
mysql-community-server mysql-server/default-auth-override select Use Strong Password Encryption (RECOMMENDED)
|
||||||
EOF
|
EOF
|
||||||
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y mysql-server >> $logsINST 2>&1
|
sudo DEBIAN_FRONTEND="noninteractive" apt-get install -y mysql-server >> $logsINST 2>&1
|
||||||
@ -600,10 +592,10 @@ EOF
|
|||||||
curl -o /etc/proftpd/proftpd.conf $resURL/Components/ProFTPD/proftpd >> $logsINST 2>&1
|
curl -o /etc/proftpd/proftpd.conf $resURL/Components/ProFTPD/proftpd >> $logsINST 2>&1
|
||||||
curl -o /etc/proftpd/proftpd_modules.conf $resURL/Components/ProFTPD/proftpd_modules >> $logsINST 2>&1
|
curl -o /etc/proftpd/proftpd_modules.conf $resURL/Components/ProFTPD/proftpd_modules >> $logsINST 2>&1
|
||||||
curl -o /etc/proftpd/sql.conf $resURL/Components/ProFTPD/proftpd_sql >> $logsINST 2>&1
|
curl -o /etc/proftpd/sql.conf $resURL/Components/ProFTPD/proftpd_sql >> $logsINST 2>&1
|
||||||
mysql -uroot -p$safePassMySQL -e "CREATE DATABASE ftp;" >> $logsINST 2>&1
|
mysql -uroot -p$passMySQL -e "CREATE DATABASE ftp;" >> $logsINST 2>&1
|
||||||
mysql -uroot -p$safePassMySQL -e "CREATE USER 'ftp'@'localhost' IDENTIFIED BY '$passProFTPD';" >> $logsINST 2>&1
|
mysql -uroot -p$passMySQL -e "CREATE USER 'ftp'@'localhost' IDENTIFIED BY '$passProFTPD';" >> $logsINST 2>&1
|
||||||
mysql -uroot -p$safePassMySQL -e "GRANT ALL PRIVILEGES ON ftp . * TO 'ftp'@'localhost';" >> $logsINST 2>&1
|
mysql -uroot -p$passMySQL -e "GRANT ALL PRIVILEGES ON ftp . * TO 'ftp'@'localhost';" >> $logsINST 2>&1
|
||||||
mysql -uroot -p$safePassMySQL ftp < EngineGP-requirements/proftpd/sqldump.sql >> $logsINST 2>&1
|
mysql -uroot -p$passMySQL ftp < EngineGP-requirements/proftpd/sqldump.sql >> $logsINST 2>&1
|
||||||
sed -i 's/passwdfor/'$passProFTPD'/g' /etc/proftpd/sql.conf >> $logsINST 2>&1
|
sed -i 's/passwdfor/'$passProFTPD'/g' /etc/proftpd/sql.conf >> $logsINST 2>&1
|
||||||
chmod -R 750 /etc/proftpd >> $logsINST 2>&1
|
chmod -R 750 /etc/proftpd >> $logsINST 2>&1
|
||||||
systemctl restart proftpd >> $logsINST 2>&1
|
systemctl restart proftpd >> $logsINST 2>&1
|
||||||
@ -684,7 +676,7 @@ EOF
|
|||||||
echo "">>$SAVE
|
echo "">>$SAVE
|
||||||
echo "Location data:">>$saveDIR
|
echo "Location data:">>$saveDIR
|
||||||
echo "SQL_Username: root">>$saveDIR
|
echo "SQL_Username: root">>$saveDIR
|
||||||
echo "SQL_Password: $safePassMySQL">>$saveDIR
|
echo "SQL_Password: $passMySQL">>$saveDIR
|
||||||
echo "SQL_FileTP: ftp">>$saveDIR
|
echo "SQL_FileTP: ftp">>$saveDIR
|
||||||
echo "SQL_Port: 3306">>$saveDIR
|
echo "SQL_Port: 3306">>$saveDIR
|
||||||
echo "Password for FTP database: $passProFTPD">>$saveDIR
|
echo "Password for FTP database: $passProFTPD">>$saveDIR
|
||||||
|
Loading…
Reference in New Issue
Block a user