add possibility to https
This commit is contained in:
parent
abba49a635
commit
bd02b48507
2 changed files with 238 additions and 96 deletions
37
example-ssl.conf
Normal file
37
example-ssl.conf
Normal file
|
|
@ -0,0 +1,37 @@
|
|||
<IfModule mod_ssl.c>
|
||||
<VirtualHost *:443>
|
||||
ServerAdmin <your email>
|
||||
ServerName www.<your website>
|
||||
ServerAlias <your website>
|
||||
DocumentRoot /var/www/html/<your website>/web
|
||||
ErrorLog ${APACHE_LOG_DIR}/error.log
|
||||
CustomLog ${APACHE_LOG_DIR}/access.log combined
|
||||
|
||||
SSLEngine on
|
||||
SSLCertificateFile <path to SSLCertificateFile.pem>
|
||||
SSLCertificateKeyFile <path to SSLCertificateKeyFile.key>
|
||||
# Depending on your provider, you may not need a SSLCertificateChainFile
|
||||
# SSLCertificateChainFile <path to SSLCertificateChainFile.crt>
|
||||
|
||||
# Rewrite rule to redirect www.<your website> to <your website>
|
||||
# RewriteEngine on
|
||||
# RewriteCond %{SERVER_NAME} =<your website>
|
||||
# RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent]
|
||||
# OR
|
||||
# Rewrite rule to redirect <your website> to www.<your website>
|
||||
# RewriteEngine on
|
||||
# RewriteCond %{SERVER_NAME} =example.com
|
||||
# RewriteRule ^ https://www.%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent
|
||||
|
||||
<Directory /var/www/html/<your website>/web>
|
||||
Options FollowSymlinks
|
||||
AllowOverride All
|
||||
Require all granted
|
||||
RewriteEngine on
|
||||
RewriteBase /
|
||||
RewriteCond %{REQUEST_FILENAME} !-f
|
||||
RewriteCond %{REQUEST_FILENAME} !-d
|
||||
RewriteRule ^(.*)$ index.php?q= [L,QSA]
|
||||
</Directory>
|
||||
</VirtualHost>
|
||||
</IfModule>
|
||||
|
|
@ -7,38 +7,38 @@ RED='\033[0;31m'
|
|||
NC='\033[0m'
|
||||
|
||||
# Check if executer is root
|
||||
if [ "$EUID" -ne 0 ]
|
||||
then echo -e"${RED} Please run as root: \"sudo ./install_drupal-wisski.bash\"${NC}"
|
||||
if [ "$EUID" -ne 0 ]; then
|
||||
echo -e "${RED}Please run as root: \"sudo ./install_drupal-wisski.bash\""
|
||||
exit
|
||||
fi
|
||||
|
||||
echo -e "${GREEN}Hi, this script installs a LAMP-Stack with the latest Drupal-WissKI for you!${NC}"
|
||||
echo -e "${GREEN}Hi, this script installs a LAMP-Stack with the latest Drupal-WissKI for you!"
|
||||
echo
|
||||
sleep 3
|
||||
|
||||
# Check if installation is for local develepment or production
|
||||
# If yes: add website name to /etc/hosts/, see section "add website to /etc/hosts"
|
||||
echo -e "${YELLOW}Do you use this script to install WissKI on a local development system"
|
||||
echo -e "or on a server for production?${NC}"
|
||||
echo -e "${YELLOW}(Selecting \"for local development\" adds your domain to /etc/hosts) in a later step.${NC}"
|
||||
echo -e "${YELLOW}(Selecting \"for production\" opens the possibility to use ssl.)${NC}"
|
||||
echo -e "or on a server for production?"
|
||||
echo -e "(Selecting \"for local development\" adds your domain to /etc/hosts) in a later step."
|
||||
echo -e "(Selecting \"for production\" opens the possibility to use ssl.)${NC}"
|
||||
echo
|
||||
PS3="I am installing WissKI... "
|
||||
PS3="I am installing option... "
|
||||
options=("for local development." "for production." "I don't know, please quit.")
|
||||
select opt in "${options[@]}"
|
||||
do
|
||||
case $opt in
|
||||
"for local development.")
|
||||
LOCALHOST=true
|
||||
echo -e "${GREEN} Okay, will add website name to /etc/hosts later.${NC}"
|
||||
echo -e "${GREEN} Okay, will add website name to /etc/hosts later."
|
||||
break
|
||||
;;
|
||||
"for production.")
|
||||
echo "${GREEN}Okay fine.${NC}"
|
||||
echo -e "${GREEN}Okay fine."
|
||||
break
|
||||
;;
|
||||
"I don't know, please quit.")
|
||||
echo -e "${GREEN}Okay bye.${NC}"
|
||||
echo -e "${GREEN}Okay bye."
|
||||
exit 0
|
||||
;;
|
||||
*) echo "invalid option $REPLY";;
|
||||
|
|
@ -46,7 +46,7 @@ do
|
|||
done
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}I want to check if required LAMP-Stack is installed. You need:${NC}"
|
||||
echo -e "${GREEN}I want to check if required LAMP-Stack is installed. You need:"
|
||||
echo
|
||||
APTS=()
|
||||
|
||||
|
|
@ -58,7 +58,7 @@ else
|
|||
APACHE='not installed'
|
||||
APTS+=( "apache2" "libapache2-mod-php" )
|
||||
fi
|
||||
echo -e "${GREEN}Apache2: ${APACHE}${NC}"
|
||||
echo -e "${GREEN}Apache2: ${APACHE}"
|
||||
|
||||
# Mariadb
|
||||
if command -v mysql &> /dev/null
|
||||
|
|
@ -68,7 +68,7 @@ else
|
|||
MYSQL="not installed"
|
||||
APTS+=( "mariadb-server" )
|
||||
fi
|
||||
echo -e "${GREEN}MariaDB/MySQL: ${MYSQL}${NC}"
|
||||
echo -e "${GREEN}MariaDB/MySQL: ${MYSQL}"
|
||||
|
||||
# PHP
|
||||
if command -v php &> /dev/null
|
||||
|
|
@ -85,20 +85,20 @@ else
|
|||
PHP='not installed'
|
||||
fi
|
||||
|
||||
echo -e "${GREEN}PHP: ${PHP}${NC}"
|
||||
echo -e "${GREEN}PHP: ${PHP}"
|
||||
|
||||
if [[ $OLDPHPVERSION ]]
|
||||
then
|
||||
while true; do
|
||||
echo
|
||||
echo -e "${RED}Your php version is lower than 8.0, to you want to install php version 8.0 (this is optional)?${NC}"
|
||||
echo -e "${RED}Your php version is lower than 8.0, to you want to install php version 8.0 (this is optional)?"
|
||||
echo -e "${YELLOW}Please note that if you confirm the app-repo \"ppa:ondrej/php\" will be added to your sources.${NC}"
|
||||
read -p "(y/n): " CURRENTPHPVERSION
|
||||
case $CURRENTPHPVERSION in
|
||||
[Yy]* )
|
||||
sudo a2dismod php${PHPVERSION}
|
||||
PHPVERSION="8.0";
|
||||
APTS+=( "php8.0" );
|
||||
sudo a2dismod php${PHPVERSION}
|
||||
add-apt-repository ppa:ondrej/php -y; break;;
|
||||
[Nn]* ) break;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
|
|
@ -110,8 +110,9 @@ if [[ ${PHP} == "not installed" ]]
|
|||
then
|
||||
echo
|
||||
echo -e "${YELLOW}Since php is missing on your system, would you like to install version 8.0?"
|
||||
echo -e "${RED}The app-repo \"ppa:ondrej/php\" must be added to your sources."
|
||||
echo -e "${RED}The app-repo \"ppa:ondrej/php\" must be added to your sources for this."
|
||||
echo -e "If you do not like to add an external repo, you can stay with php 7.4.${NC}"
|
||||
echo
|
||||
PS3="I would like to use option... "
|
||||
options=("8.0 from ppa:ondrej/php" "7.4 from default sources" "I don't know, please quit.")
|
||||
select opt in "${options[@]}"
|
||||
|
|
@ -120,18 +121,18 @@ then
|
|||
"8.0 from ppa:ondrej/php")
|
||||
APTS+=( "php8.0" )
|
||||
PHPVERSION="8.0"
|
||||
echo -e "${GREEN}Add app-repo \"ppa:ondrej/php\" to your sources.${NC}"
|
||||
echo -e "${GREEN}Add app-repo \"ppa:ondrej/php\" to your sources."
|
||||
add-apt-repository ppa:ondrej/php -y;
|
||||
break
|
||||
;;
|
||||
"7.4 from default sources")
|
||||
APTS+=( "php7.4" )
|
||||
PHPVERSION="7.4"
|
||||
echo -e "${GREEN}Will take php7.4 from default sources. ${NC}"
|
||||
echo -e "${GREEN}Will take php7.4 from default sources. "
|
||||
break
|
||||
;;
|
||||
"I don't know, please quit.")
|
||||
echo -e "${GREEN}Okay bye.${NC}"
|
||||
echo -e "${GREEN}Okay bye."
|
||||
exit 0
|
||||
;;
|
||||
*) echo "invalid option $REPLY";;
|
||||
|
|
@ -147,33 +148,38 @@ then
|
|||
read -p "(y/n): " INSTALLPACKAGES
|
||||
case $INSTALLPACKAGES in
|
||||
[Yy]* ) apt update && apt install ${APTS[*]} -y; break;;
|
||||
[Nn]* ) echo -e "${RED}I need ${APTS[*]} to process, abort${NC}"; exit;;
|
||||
[Nn]* ) echo -e "${RED}I need ${APTS[*]} to process, abort"; exit;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
esac
|
||||
done
|
||||
else
|
||||
echo -e "${GREEN}Good, your LAMP-Stack is complete.${NC}"
|
||||
echo -e "${GREEN}Good, your LAMP-Stack is complete."
|
||||
fi
|
||||
|
||||
# check if dependencies are fulfilled
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Checking if dependencies are fulfilled...${NC}"
|
||||
echo -e "${GREEN}Checking if dependencies are fulfilled..."
|
||||
echo
|
||||
DEPENDENCIES=("libapache2-mod-php"\
|
||||
"php${PHPVERSION}-apcu"\
|
||||
"php${PHPVERSION}-curl"\
|
||||
"php${PHPVERSION}-gd"\
|
||||
"php${PHPVERSION}-json"\
|
||||
"php${PHPVERSION}-mbstring"\
|
||||
"php${PHPVERSION}-mysqli"\
|
||||
"php${PHPVERSION}-xml"\
|
||||
"php${PHPVERSION}-mysql"\
|
||||
"php${PHPVERSION}-xml"
|
||||
"php${PHPVERSION}-zip")
|
||||
|
||||
|
||||
if [[ ! $PHPVERSION == 8* ]]; then
|
||||
DEPENDENCIES+=("php${PHPVERSION}-json")
|
||||
fi
|
||||
|
||||
|
||||
for REQUIREDPKG in "${DEPENDENCIES[@]}"
|
||||
do
|
||||
if dpkg-query -W --showformat='${Status}\n' $REQUIREDPKG &> /dev/null
|
||||
then
|
||||
echo -e "${GREEN}${REQUIREDPKG} is installed.${NC}"
|
||||
if [[ "$(dpkg-query -W --showformat='${Status}\n' $REQUIREDPKG)" == "install ok installed" ]]; then
|
||||
echo -e "${GREEN}${REQUIREDPKG} is installed."
|
||||
delete=(${REQUIREDPKG})
|
||||
for target in "${delete[@]}"; do
|
||||
for i in "${!DEPENDENCIES[@]}"; do
|
||||
|
|
@ -183,7 +189,7 @@ do
|
|||
done
|
||||
done
|
||||
else
|
||||
echo -e "${RED}${REQUIREDPKG} is missing.${NC}"
|
||||
echo -e "${RED}${REQUIREDPKG} is missing."
|
||||
fi
|
||||
done
|
||||
|
||||
|
|
@ -195,13 +201,13 @@ then
|
|||
read -p "(y/n): " INSTALLDEPENDENCIES
|
||||
case $INSTALLDEPENDENCIES in
|
||||
[Yy]* ) apt update && apt install ${DEPENDENCIES[*]} -y; break;;
|
||||
[Nn]* ) echo -e "${RED}I need ${DEPENDENCIES[*]} to process, abort.${NC}"; exit;;
|
||||
[Nn]* ) echo -e "${RED}I need ${DEPENDENCIES[*]} to process, abort."; exit;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
esac
|
||||
done
|
||||
else
|
||||
echo
|
||||
echo -e "${GREEN}Good, all dependencies are fulfilled.${NC}"
|
||||
echo -e "${GREEN}Good, all dependencies are fulfilled."
|
||||
fi
|
||||
|
||||
unset REQUIREDPKG
|
||||
|
|
@ -214,11 +220,9 @@ HELPERS=(\
|
|||
"unzip" \
|
||||
)
|
||||
|
||||
for REQUIREDPKG in "${HELPERS[@]}"
|
||||
do
|
||||
if dpkg-query -W --showformat='${Status}\n' $REQUIREDPKG &> /dev/null
|
||||
then
|
||||
echo -e "${GREEN}${REQUIREDPKG} is installed.${NC}"
|
||||
for REQUIREDPKG in "${HELPERS[@]}"; do
|
||||
if [[ "$(dpkg-query -W --showformat='${Status}\n' $REQUIREDPKG)" == "install ok installed" ]]; then
|
||||
echo -e "${GREEN}${REQUIREDPKG} is installed."
|
||||
delete=(${REQUIREDPKG})
|
||||
for target in "${delete[@]}"; do
|
||||
for i in "${!HELPERS[@]}"; do
|
||||
|
|
@ -228,7 +232,7 @@ do
|
|||
done
|
||||
done
|
||||
else
|
||||
echo -e "${RED}${REQUIREDPKG} is missing.${NC}"
|
||||
echo -e "${RED}${REQUIREDPKG} is missing."
|
||||
fi
|
||||
done
|
||||
|
||||
|
|
@ -240,13 +244,13 @@ then
|
|||
read -p "(y/n): " INSTALLHELPERS
|
||||
case $INSTALLHELPERS in
|
||||
[Yy]* ) apt update && apt install ${HELPERS[*]} -y; break;;
|
||||
[Nn]* ) echo -e "${RED}I need ${HELPERS[*]} to process, abort${NC}"; exit;;
|
||||
[Nn]* ) echo -e "${RED}I need ${HELPERS[*]} to process, abort"; exit;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
esac
|
||||
done
|
||||
else
|
||||
echo
|
||||
echo -e "${GREEN}Good, all helpers are installed.${NC}"
|
||||
echo -e "${GREEN}Good, all helpers are installed."
|
||||
fi
|
||||
|
||||
# add php configuration via wisski.ini
|
||||
|
|
@ -261,17 +265,26 @@ date.timezone = Europe/Berlin
|
|||
max_input_nesting_level = 640'
|
||||
|
||||
echo
|
||||
echo -e "${YELLOW}Do you like to tweak your php?${NC}"
|
||||
echo -e "${YELLOW}(This will add${NC}"
|
||||
echo -e "${YELLOW}Do you like to tweak your php?"
|
||||
echo -e "${YELLOW}This will add"
|
||||
echo
|
||||
echo -e "${RED}${TWEAKPHP}${NC}"
|
||||
echo -e "${RED}${TWEAKPHP}"
|
||||
echo
|
||||
echo -e "${YELLOW}to"
|
||||
echo
|
||||
echo -e "${RED}/etc/php/${PHPVERSION}/mods-available/wisski.ini$"
|
||||
echo
|
||||
echo -e "${YELLOW}and activate it.${NC}"
|
||||
echo
|
||||
echo -e "${YELLOW}to ${RED}/etc/php/${PHPVERSION}/apache2/conf.d/wisski.ini${YELLOW})${NC}"
|
||||
|
||||
while true; do
|
||||
read -p "(y/n): " TWEAK
|
||||
case $TWEAK in
|
||||
[Yy]* ) echo "$TWEAKPHP" > /etc/php/${PHPVERSION}/apache2/conf.d/wisski.ini; break;;
|
||||
[Yy]* )
|
||||
echo "$TWEAKPHP" > /etc/php/${PHPVERSION}/mods-available/wisski.ini
|
||||
echo -e "${GREEN}Activate wisski.ini.${NC}"
|
||||
phpenmod -v ${PHPVERSION} wisski
|
||||
break;;
|
||||
[Nn]* ) break;;
|
||||
* ) echo "Please answer yes or no.";;
|
||||
esac
|
||||
|
|
@ -280,28 +293,27 @@ done
|
|||
# enable mod-rewrite
|
||||
echo
|
||||
echo -e "${GREEN}Enable mod_rewrite for apache2.${NC}"
|
||||
sleep 1
|
||||
echo
|
||||
a2enmod rewrite;
|
||||
|
||||
# restart apache
|
||||
echo
|
||||
echo -e "${GREEN}Restart apache server${NC}"
|
||||
sleep 1
|
||||
systemctl restart apache2
|
||||
echo
|
||||
# configure site
|
||||
|
||||
# configure site
|
||||
FINISHED=false
|
||||
while [ $FINISHED == false ]
|
||||
do
|
||||
echo -e "${YELLOW}What is the name of your Website (WITHOUT \"https://www.\" etc. like \"example.com\")?${NC}"
|
||||
echo -e "${YELLOW}What is the name of your Website (WITHOUT \"https://www.\" etc. like \"example.com\")?"
|
||||
echo -e "${YELLOW}It will be used as webroot dir at /var/www/html/ and as your servername.${NC}"
|
||||
while [[ -z $WEBSITENAME ]]
|
||||
do
|
||||
read WEBSITENAME
|
||||
if [[ -z $WEBSITENAME ]]
|
||||
then
|
||||
echo -e "${RED}Websitename can not be emtpy! Please enter a websitename!${NC}"
|
||||
echo -e "${RED}Websitename can not be emtpy! Please enter a websitename!"
|
||||
fi
|
||||
done
|
||||
echo -e "${YELLOW}Enter your server admin email adress:${NC}"
|
||||
|
|
@ -310,11 +322,11 @@ do
|
|||
read SERVERADMINEMAIL
|
||||
if [[ -z $SERVERADMINEMAIL ]]
|
||||
then
|
||||
echo -e "${RED}Server admin mail adress can not be emtpy! Please enter an amdin mail adress!${NC}"
|
||||
echo -e "${RED}Server admin mail adress can not be emtpy! Please enter an amdin mail adress!"
|
||||
fi
|
||||
done
|
||||
echo -e "${GREEN}Websitename: ${WEBSITENAME}${NC}"
|
||||
echo -e "${GREEN}Server admin mail: ${SERVERADMINEMAIL}${NC}"
|
||||
echo -e "${GREEN}Websitename: ${WEBSITENAME}"
|
||||
echo -e "${GREEN}Server admin mail: ${SERVERADMINEMAIL}"
|
||||
echo -e "${YELLOW}Is that correct?${NC}"
|
||||
|
||||
while true; do
|
||||
|
|
@ -326,7 +338,7 @@ do
|
|||
FINISHED=true;
|
||||
break;;
|
||||
[Nn]* )
|
||||
echo -e "${GREEN}Okay then...${NC}";
|
||||
echo -e "${GREEN}Okay then...";
|
||||
break;;
|
||||
* ) echo "Please answer yes or no.";;
|
||||
esac
|
||||
|
|
@ -338,29 +350,29 @@ done
|
|||
if [[ $LOCALHOST ]]
|
||||
then
|
||||
echo
|
||||
echo -e "${GREEN}Since, you are on localhost, I try to add \"127.0.0.1 ${WEBSITENAME}\" to /etc/hosts.${NC}"
|
||||
echo -e "${GREEN}Since, you are on localhost, I try to add \"127.0.0.1 ${WEBSITENAME}\" to /etc/hosts."
|
||||
if grep -q "${WEBSITENAME}" "/etc/hosts";
|
||||
then
|
||||
echo
|
||||
echo -e "${RED}Entry \"127.0.0.1 ${WEBSITENAME}\" already in /etc/hosts${NC}"
|
||||
echo -e "${RED}Entry \"127.0.0.1 ${WEBSITENAME}\" already in /etc/hosts"
|
||||
else
|
||||
echo
|
||||
echo -e "${YELLOW}ADD $WEBSITENAME to /etc/hosts, because you are on a localhost!${NC}"
|
||||
echo -e "${YELLOW}ADD $WEBSITENAME to /etc/hosts, because you are on a localhost!"
|
||||
echo "127.0.0.1 ${WEBSITENAME}" >> /etc/hosts
|
||||
fi
|
||||
fi
|
||||
|
||||
echo
|
||||
echo -e "${YELLOW}Do you like to add your site to your apache config?${NC}"
|
||||
echo -e "${YELLOW}This will create \"/etc/apache2/sites-available/${WEBSITENAME}.conf\".${NC}"
|
||||
echo -e "${YELLOW}Do you like to add your site to your apache config?"
|
||||
echo -e "This will create \"/etc/apache2/sites-available/${WEBSITENAME}.conf\".${NC}"
|
||||
|
||||
SITECONFIG=$'<VirtualHost *:80>
|
||||
ServerAdmin ${SERVERADMINEMAIL}
|
||||
DocumentRoot \"/var/www/html/${WEBSITENAME}/web\"
|
||||
ServerName www.${WEBSITENAME}
|
||||
ServerAlias ${WEBSITENAME}
|
||||
ErrorLog \"/var/log/apache2/drupal.local-error_log\"
|
||||
CustomLog \"/var/log/apache2/drupal.local-access_log\" common
|
||||
ErrorLog \"/var/log/apache2/${WEBSITENAME}-error_log\"
|
||||
CustomLog \"/var/log/apache2/${WEBSITENAME}-access_log\" common
|
||||
<Directory /var/www/html/$WEBSITENAME/web>
|
||||
Options FollowSymlinks
|
||||
AllowOverride All
|
||||
|
|
@ -401,7 +413,7 @@ then
|
|||
read -p "(y/n): " SECUREMARIADB
|
||||
case $SECUREMARIADB in
|
||||
[Yy]* )
|
||||
echo -e "${GREEN}Please note your credentials!${NC}";
|
||||
echo -e "${GREEN}Please note your credentials!";
|
||||
mysql_secure_installation;
|
||||
break;;
|
||||
[Nn]* )
|
||||
|
|
@ -411,10 +423,9 @@ then
|
|||
done
|
||||
fi
|
||||
|
||||
echo "hello"
|
||||
# create database user and database
|
||||
echo
|
||||
echo -e "${YELLOW}Create database and user for Drupal. Please note your inputs, they will be needed in a moment.${NC}"
|
||||
echo -e "${YELLOW}Create database and user for Drupal. Please note your inputs, they will be needed in a moment."
|
||||
CORRECTDATABASE=false
|
||||
CORRECTUSER=false
|
||||
FINISHED=false
|
||||
|
|
@ -424,33 +435,33 @@ while [[ $CORRECTDATABASE == false ]] && [[ $CORRECTUSER == false ]]; do
|
|||
read DB
|
||||
if [[ ! -z "`mysql -qfsBe "SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME='${DB}'" 2>&1`" ]]; then
|
||||
echo
|
||||
echo -e "${RED}Database already exists!${NC}"
|
||||
echo -e "${RED}Should I drop it and recreate? Attention: All data will be lost and can not be recovered!${NC}"
|
||||
echo -e "${RED}Database already exists!"
|
||||
echo -e "Should I drop it and recreate? Attention: All data will be lost and can not be recovered!${NC}"
|
||||
while true; do
|
||||
read -p "(y/n/rename/abort): " SURE
|
||||
read -p "(recreate/keep/rename/abort): " SURE
|
||||
case $SURE in
|
||||
[Yy]* )
|
||||
[recreate]* )
|
||||
mysql -e "DROP DATABASE ${DB};"
|
||||
mysql -e "CREATE DATABASE ${DB} ;"
|
||||
echo -e "${GREEN}Recreated database ${DB}.${NC}"
|
||||
echo -e "${GREEN}Recreated database ${DB}."
|
||||
FINISHED=true
|
||||
break;;
|
||||
[Nn]* )
|
||||
echo -e "${GREEN}Okay keep old database...${NC}"
|
||||
[keep]* )
|
||||
echo -e "${GREEN}Okay keep old database..."
|
||||
FINISHED=true
|
||||
break;;
|
||||
[retry]* )
|
||||
echo -e "${GREEN}Okay, then...${NC}"
|
||||
echo -e "${GREEN}Okay, then..."
|
||||
break;;
|
||||
[abort]* )
|
||||
echo -e "${GREEN}Okay, bye${NC}"
|
||||
echo -e "${GREEN}Okay, bye"
|
||||
exit;;
|
||||
* ) echo "Please answer y[es], n[o], rename or abort!";;
|
||||
esac
|
||||
done
|
||||
else
|
||||
mysql -e "CREATE DATABASE ${DB} ;"
|
||||
echo -e "${GREEN}Created database ${DB}.${NC}"
|
||||
echo -e "${GREEN}Created database ${DB}."
|
||||
FINISHED=true
|
||||
CORRECTDATABASE=true
|
||||
fi
|
||||
|
|
@ -463,8 +474,8 @@ while [[ $CORRECTDATABASE == false ]] && [[ $CORRECTUSER == false ]]; do
|
|||
echo -e "${YELLOW}Enter passwort of that user:${NC}"
|
||||
read USERPW
|
||||
echo
|
||||
echo -e "${GREEN}Database username: ${USER}${NC}"
|
||||
echo -e "${GREEN}Database user password: ${USERPW}${NC}"
|
||||
echo -e "${GREEN}Database username: ${USER}"
|
||||
echo -e "Database user password: ${USERPW}"
|
||||
echo -e "${YELLOW}Is that correct?${NC}"
|
||||
while true; do
|
||||
read -p "(y/n): " SURE
|
||||
|
|
@ -473,22 +484,48 @@ while [[ $CORRECTDATABASE == false ]] && [[ $CORRECTUSER == false ]]; do
|
|||
if [[ ! -z "`mysql -qfsBe "SELECT User FROM mysql.user WHERE User = '${USER}'" 2>&1`" ]];
|
||||
then
|
||||
echo
|
||||
echo -e "${RED}User already exists!${NC}"
|
||||
echo -e "${RED}Should I drop it and recreate or keep existing user?${NC}"
|
||||
echo -e "${RED}User already exists!"
|
||||
echo -e "Should I drop it and recreate or keep existing user?${NC}"
|
||||
while true; do
|
||||
read -p "(y/keep): " SURE
|
||||
read -p "(recreate/keep): " SURE
|
||||
case $SURE in
|
||||
[Yy]* )
|
||||
[recreate]* )
|
||||
mysql -e "DROP USER ${DB}@'localhost';"
|
||||
mysql -e "CREATE USER ${DB}@localhost IDENTIFIED BY '${USERPW}';"
|
||||
mysql -e "GRANT ALL PRIVILEGES ON ${DB}.* TO '${USER}'@'localhost';"
|
||||
mysql -e "FLUSH PRIVILEGES;"
|
||||
echo -e "${GREEN}Recreated User ${USER}.${NC}"
|
||||
echo -e "${GREEN}Recreated User ${USER}."
|
||||
FINISHED=true
|
||||
CORRECTUSER=true
|
||||
break;;
|
||||
[keep]* )
|
||||
echo -e "${GREEN}Okay keep user.${NC}"
|
||||
unset USERPW
|
||||
echo
|
||||
echo -e "${GREEN}Okay keep existing user."
|
||||
while [[ -z ${USERPW} ]]; do
|
||||
echo -e "${YELLOW}What is the password of this user?"
|
||||
echo -e "${RED}Be sure that the password is correct!${NC}"
|
||||
read USERPW
|
||||
while true; do
|
||||
echo
|
||||
echo -e "${GREEN}User password is: ${USERPW}"
|
||||
echo -e "${YELLOW}Is this correct?${NC}"
|
||||
read -p "(y/n): " SURE
|
||||
case $SURE in
|
||||
[Yy]* )
|
||||
CORRECTUSER=true
|
||||
break;;
|
||||
[Nn]* )
|
||||
unset USERPW
|
||||
break;;
|
||||
[abort]* )
|
||||
echo -e "${GREEN}Okay, bye"
|
||||
exit;;
|
||||
* ) echo "Please answer y[es], n[o] or abort!";;
|
||||
esac
|
||||
done
|
||||
done
|
||||
FINISHED=true
|
||||
break;;
|
||||
* ) echo "Please answer y[es] or keep.";;
|
||||
esac
|
||||
|
|
@ -498,27 +535,27 @@ while [[ $CORRECTDATABASE == false ]] && [[ $CORRECTUSER == false ]]; do
|
|||
mysql -e "GRANT ALL PRIVILEGES ON ${DB}.* TO '${USER}'@'localhost';"
|
||||
mysql -e "FLUSH PRIVILEGES;"
|
||||
echo
|
||||
echo -e "${GREEN}Created User ${USER}.${NC}"
|
||||
echo -e "${GREEN}Created User ${USER}."
|
||||
FINISHED=true
|
||||
CORRECTUSER=true
|
||||
fi
|
||||
break;;
|
||||
[Nn]* )
|
||||
echo -e "${GREEN}Okay then...${NC}"
|
||||
echo -e "${GREEN}Okay then..."
|
||||
break;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
* ) echo -e "${RED}Please answer y[es] or n[o].";;
|
||||
esac
|
||||
done
|
||||
done
|
||||
done
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Created ${DB} database with ${USER} identified by ${USERPW} ${NC}"
|
||||
echo -e "${GREEN}Created ${DB} database with ${USER}@localhost identified by ${USERPW}."
|
||||
sleep 1
|
||||
|
||||
# install drupal with drush
|
||||
echo
|
||||
echo -e "${GREEN}You are ready to install Drupal! It will be installed under /var/www/html/$WEBSITENAME.${NC}"
|
||||
echo -e "${GREEN}You are ready to install Drupal! It will be installed under /var/www/html/$WEBSITENAME."
|
||||
echo -e "${YELLOW}Should I start?${NC}"
|
||||
while true; do
|
||||
read -p "(y/n): " INSTALLDRUPAL
|
||||
|
|
@ -543,9 +580,9 @@ then
|
|||
echo -e "${RED}Seems that composer is not installed, do you like to install it?${NC}"
|
||||
while true; do
|
||||
read -p "(y/n): " INSTALLCOMPOSER
|
||||
case INSTALLCOMPOSER in
|
||||
case ${INSTALLCOMPOSER} in
|
||||
[Yy]* )
|
||||
echo -e "${YELLOW}I will install composer at \"/usr/local/bin/composer\n${NC}"
|
||||
echo -e "${RED}I will install composer at \"/usr/local/bin/composer\"${NC}"
|
||||
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
|
||||
php -r "if (hash_file('sha384', 'composer-setup.php') === '756890a4488ce9024fc62c56153228907f1545c228516cbf63f885e036d37e9a59d27d63f46af1d4d07ee0f76181c7d3') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
|
||||
php composer-setup.php --filename=composer --install-dir=/usr/local/bin
|
||||
|
|
@ -558,38 +595,106 @@ then
|
|||
fi
|
||||
|
||||
echo
|
||||
echo -e "${YELLOW}Composer will scold you for being root, do not worry, we take care of this later - answer always \"y\". "
|
||||
echo -e "${RED}Composer will scold you for being root, do not worry, we take care of this later - answer always \"y\".${NC}"
|
||||
echo
|
||||
composer create-project drupal/recommended-project $WEBSITENAME
|
||||
chown -R www-data:www-data $WEBSITENAME
|
||||
chmod 775 -R $WEBSITENAME
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Installing WissKI with some modules (you have to activate them later).${NC}"
|
||||
sleep 1
|
||||
echo
|
||||
cd /var/www/html/$WEBSITENAME
|
||||
composer require drupal/colorbox drupal/devel drush/drush drupal/imagemagick drupal/inline_entity_form:^1.0@RC drupal/wisski:^3.0@RC
|
||||
composer require drupal/colorbox drupal/devel drush/drush drupal/imagemagick 'drupal/inline_entity_form:1.x-dev@dev' 'drupal/wisski:^3.0@RC'
|
||||
cd web/modules/contrib/wisski
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Autoload WissKI dependencies.${NC}"
|
||||
echo
|
||||
composer update
|
||||
cd /var/www/html/$WEBSITENAME
|
||||
|
||||
## get mirador
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Get necessary libraries.${NC}"
|
||||
sleep 1
|
||||
echo
|
||||
mkdir -p web/libraries
|
||||
## get colorbox
|
||||
|
||||
wget https://github.com/jackmoore/colorbox/archive/refs/heads/master.zip -P web/libraries/
|
||||
unzip web/libraries/master.zip -d web/libraries/
|
||||
mv web/libraries/colorbox-master web/libraries/colorbox
|
||||
#wget http://wisskieu.nasarek.org/sites/default/files/assets/mirador.zip -P web/libraries/
|
||||
#unzip web/libraries/mirador.zip -d web/libraries/
|
||||
## get mirador
|
||||
|
||||
wget http://wisskieu.nasarek.org/sites/default/files/assets/mirador.zip -P web/libraries/
|
||||
unzip web/libraries/mirador.zip -d web/libraries/
|
||||
|
||||
#echo change permissions for webroot to www-data
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Change permissions to www-data at \"/var/www/html/$WEBSITENAME\".${NC}"
|
||||
echo
|
||||
chown -R www-data:www-data ../$WEBSITENAME
|
||||
chmod 775 -R ../$WEBSITENAME
|
||||
|
||||
if [[ ! ${LOCALHOST} ]]; then
|
||||
echo
|
||||
echo -e "${YELLOW}You are installing WissKI for production, do you like to add https support?"
|
||||
echo -e "You can use certbot and letsencrypt for an automaticaly installation and configuration"
|
||||
echo -e "of all certificates and Apache config files or"
|
||||
echo -e "use your own certificates and configure Apache manually.${NC}"
|
||||
echo
|
||||
|
||||
PS3="I would like to... "
|
||||
options=("use certbots automode." "configure Apache manually." "I don't know, please skip this.")
|
||||
select opt in "${options[@]}"
|
||||
do
|
||||
case $opt in
|
||||
"use certbots automode.")
|
||||
echo -e "${GREEN}Okay, installing certbot which obtaining letsencrypt certificates!"
|
||||
echo -e "Please note, that you need a correct DNS configuration with"
|
||||
echo -e "${WEBSITENAME} or www.${WEBSITENAME} pointing with a \"A\" record to your ServerIP"
|
||||
echo -e "${YELLOW}Can we start?${NC}"
|
||||
while true; do
|
||||
read -p "(y/n): " INSTALLCERTBOT
|
||||
case $INSTALLCERTBOT in
|
||||
[Yy]* )
|
||||
apt remove certbot -y
|
||||
snap install core
|
||||
snap refresh core
|
||||
snap install --classic certbot
|
||||
ln -s /snap/bin/certbot /usr/bin/certbot
|
||||
sudo certbot --apache
|
||||
break;;
|
||||
[Nn]* )
|
||||
echo -e "${GREEN}Okay skipping.";
|
||||
for (( i=0; i<${#options[@]}; i++)); do
|
||||
printf '%d) %s\n' $((i+1)) "${options[$i]}"
|
||||
done
|
||||
continue 2;;
|
||||
* ) echo "Please answer y[es] or n[o].";;
|
||||
esac
|
||||
done;
|
||||
break
|
||||
;;
|
||||
"configure Apache manually.")
|
||||
echo
|
||||
echo -e "${GREEN}You can use \"example-ssl.conf\" as a template. Please alter <your email>,"
|
||||
echo -e "<your website>, the paths to your certificate files and rewrite rules."
|
||||
echo -e "Copy it to /etc/apache2/sites-available/${WEBSITENAME}-ssl.conf"
|
||||
echo -e "and enable it with \"sudo a2ensite ${WEBSITENAME}-ssl\""
|
||||
break
|
||||
;;
|
||||
"I don't know, please skip this.")
|
||||
echo -e "${GREEN}Okay skipping.${NC}"
|
||||
break
|
||||
;;
|
||||
*) echo "invalid option $REPLY";;
|
||||
esac
|
||||
done
|
||||
fi
|
||||
|
||||
echo
|
||||
echo -e "${GREEN}Thats it! You can now visit http://${WEBSITENAME} and install Drupal!${NC}"
|
||||
|
||||
exit 0;
|
||||
Loading…
Add table
Add a link
Reference in a new issue