mirror of
https://github.com/myvesta/vesta.git
synced 2024-11-21 13:00:11 -08:00
168 lines
6.8 KiB
Bash
168 lines
6.8 KiB
Bash
#!/bin/bash
|
|
#
|
|
# phpmyadmin-fixer
|
|
#
|
|
# Fixes for phpmyadmin (configuration storage and some extended features)
|
|
#
|
|
# Original Version by Pavel Galkin (https://skurudo.ru)
|
|
# https://github.com/skurudo/phpmyadmin-fixer
|
|
#
|
|
# Changed some lines to fit to Hestia Configuration.
|
|
#
|
|
|
|
# Defining password-gen function
|
|
gen_pass() {
|
|
MATRIX='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
|
|
LENGTH=10
|
|
while [ ${n:=1} -le $LENGTH ]; do
|
|
PASS="$PASS${MATRIX:$(($RANDOM%${#MATRIX})):1}"
|
|
let n+=1
|
|
done
|
|
echo "$PASS"
|
|
}
|
|
|
|
PASS=$(gen_pass)
|
|
|
|
#ubuntu phpmyadmin path
|
|
pmapath1="/etc/phpmyadmin/config.inc.php"
|
|
pmapath2="/usr/share/phpmyadmin/config.sample.inc.php"
|
|
|
|
#delete old and paste new value
|
|
sed -i '/pmadb/d' $pmapath1
|
|
sed -i '/controluser/d' $pmapath1
|
|
sed -i '/bookmarktable/d' $pmapath1
|
|
sed -i '/relation/d' $pmapath1
|
|
sed -i '/userconfig/d' $pmapath1
|
|
sed -i '/table_info/d' $pmapath1
|
|
sed -i '/column_info/d' $pmapath1
|
|
sed -i '/history/d' $pmapath1
|
|
sed -i '/recent/d' $pmapath1
|
|
sed -i '/table_uiprefs/d' $pmapath1
|
|
sed -i '/tracking/d' $pmapath1
|
|
sed -i '/table_coords/d' $pmapath1
|
|
sed -i '/pdf_pages/d' $pmapath1
|
|
sed -i '/designer_coords/d' $pmapath1
|
|
sed -i '/controlpass/d' $pmapath1
|
|
sed -i '/\$i = 1; /d' $pmapath1
|
|
echo "\$i = 1;" >> $pmapath1
|
|
sed -i '/savedsearches/d' $pmapath1
|
|
sed -i '/navigationhiding/d' $pmapath1
|
|
sed -i '/users/d' $pmapath1
|
|
sed -i '/controlpass/d' $pmapath1
|
|
sed -i '/favorite/d' $pmapath1
|
|
sed -i '/usergroups/d' $pmapath1
|
|
sed -i '/central_columns/d' $pmapath1
|
|
sed -i '/designer_settings/d' $pmapath1
|
|
sed -i '/export_templates/d' $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['favorite'] = 'pma__favorite';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['usergroups'] = 'pma__usergroups';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['central_columns'] = 'pma__central_columns';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['designer_settings'] = 'pma__designer_settings';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['export_templates'] = 'pma__export_templates';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['savedsearches'] = 'pma__savedsearches';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['navigationhiding'] = 'pma__navigationhiding';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['users'] = 'pma__users';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['usergroups'] = 'pma__usergroups';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['pmadb'] = 'phpmyadmin';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['controluser'] = 'pma';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['controlpass'] = '$PASS';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['bookmarktable'] = 'pma__bookmark';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['relation'] = 'pma__relation';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['userconfig'] = 'pma__userconfig';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['table_info'] = 'pma__table_info';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['column_info'] = 'pma__column_info';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['history'] = 'pma__history';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['recent'] = 'pma__recent';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['table_uiprefs'] = 'pma__table_uiprefs';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['tracking'] = 'pma__tracking';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['table_coords'] = 'pma__table_coords';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['pdf_pages'] = 'pma__pdf_pages';" >> $pmapath1
|
|
echo "\$cfg['Servers'][\$i]['designer_coords'] = 'pma__designer_coords';" >> $pmapath1
|
|
|
|
sed -i '/pmadb/d' $pmapath2
|
|
sed -i '/controluser/d' $pmapath2
|
|
sed -i '/bookmarktable/d' $pmapath2
|
|
sed -i '/relation/d' $pmapath2
|
|
sed -i '/userconfig/d' $pmapath2
|
|
sed -i '/table_info/d' $pmapath2
|
|
sed -i '/column_info/d' $pmapath2
|
|
sed -i '/history/d' $pmapath2
|
|
sed -i '/recent/d' $pmapath2
|
|
sed -i '/table_uiprefs/d' $pmapath2
|
|
sed -i '/tracking/d' $pmapath2
|
|
sed -i '/table_coords/d' $pmapath2
|
|
sed -i '/pdf_pages/d' $pmapath2
|
|
sed -i '/designer_coords/d' $pmapath2
|
|
sed -i '/controlpass/d' $pmapath2
|
|
sed -i '/savedsearches/d' $pmapath2
|
|
sed -i '/navigationhiding/d' $pmapath2
|
|
sed -i '/users/d' $pmapath2
|
|
sed -i '/controlpass/d' $pmapath2
|
|
sed -i '/favorite/d' $pmapath2
|
|
sed -i '/usergroups/d' $pmapath2
|
|
sed -i '/central_columns/d' $pmapath2
|
|
sed -i '/designer_settings/d' $pmapath2
|
|
sed -i '/export_templates/d' $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['favorite'] = 'pma__favorite';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['usergroups'] = 'pma__usergroups';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['central_columns'] = 'pma__central_columns';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['designer_settings'] = 'pma__designer_settings';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['export_templates'] = 'pma__export_templates';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['savedsearches'] = 'pma__savedsearches';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['navigationhiding'] = 'pma__navigationhiding';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['users'] = 'pma__users';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['usergroups'] = 'pma__usergroups';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['pmadb'] = 'phpmyadmin';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['controluser'] = 'pma';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['controlpass'] = '$PASS';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['bookmarktable'] = 'pma__bookmark';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['relation'] = 'pma__relation';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['userconfig'] = 'pma__userconfig';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['table_info'] = 'pma__table_info';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['column_info'] = 'pma__column_info';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['history'] = 'pma__history';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['recent'] = 'pma__recent';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['table_uiprefs'] = 'pma__table_uiprefs';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['tracking'] = 'pma__tracking';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['table_coords'] = 'pma__table_coords';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['pdf_pages'] = 'pma__pdf_pages';" >> $pmapath2
|
|
echo "\$cfg['Servers'][\$i]['designer_coords'] = 'pma__designer_coords';" >> $pmapath2
|
|
|
|
#SOME WORK with DATABASE (table / user)
|
|
PMADB=phpmyadmin
|
|
PMAUSER=pma
|
|
|
|
#DROP USER and TABLE
|
|
mysql -uroot <<MYSQL_PMA1
|
|
DROP USER IF EXISTS '$PMAUSER'@'localhost';
|
|
DROP DATABASE IF EXISTS $PMADB;
|
|
FLUSH PRIVILEGES;
|
|
MYSQL_PMA1
|
|
|
|
#CREATE PMA USER
|
|
mysql -uroot <<MYSQL_PMA2
|
|
CREATE USER '$PMAUSER'@'localhost' IDENTIFIED BY '$PASS';
|
|
CREATE DATABASE $PMADB;
|
|
MYSQL_PMA2
|
|
|
|
#GRANT PMA USE SOME RIGHTS
|
|
if [ ! -f "/etc/apt/sources.list.d/mysql.list" ]; then
|
|
# MariaDB
|
|
mysql -uroot <<MYSQL_PMA3
|
|
USE $PMADB;
|
|
GRANT USAGE ON $PMADB.* TO '$PMAUSER'@'localhost' IDENTIFIED BY '$PASS';
|
|
GRANT ALL PRIVILEGES ON $PMADB.* TO '$PMAUSER'@'localhost';
|
|
FLUSH PRIVILEGES;
|
|
MYSQL_PMA3
|
|
else
|
|
# MySQL8
|
|
mysql -uroot <<MYSQL_PMA3
|
|
USE $PMADB;
|
|
GRANT ALL ON $PMADB.* TO '$PMAUSER'@'localhost';
|
|
FLUSH PRIVILEGES;
|
|
MYSQL_PMA3
|
|
fi
|
|
|
|
#MYSQL DB and TABLES ADDITION
|
|
mysql -uroot < /root/phpmyadmin/create_tables.sql
|