UPDATE Install Nginx 1 [MASTER]

This commit is contained in:
Mitchell Krog 2019-06-28 14:45:00 +02:00
parent 4c75649c77
commit c2ca4b1421
No known key found for this signature in database
GPG key ID: C243C388553EDE5D

View file

@ -16,21 +16,22 @@
# # # #
############################################################################## ##############################################################################
# ------------------------------------------------------------------------------
# MIT License # MIT License
# ------------------------------------------------------------------------------
# Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com # Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com
# https://github.com/mitchellkrogza # https://github.com/mitchellkrogza
# ------------------------------------------------------------------------------
# Permission is hereby granted, free of charge, to any person obtaining a copy # Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal # of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights # in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is # copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions: # furnished to do so, subject to the following conditions:
# ------------------------------------------------------------------------------
# The above copyright notice and this permission notice shall be included in all # The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software. # copies or substantial portions of the Software.
# ------------------------------------------------------------------------------
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
@ -38,10 +39,11 @@
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE. # SOFTWARE.
# ------------------------------------------------------------------------------
# ************************ # ------------------------
# Set Terminal Font Colors # Set Terminal Font Colors
# ************************ # ------------------------
bold=$(tput bold) bold=$(tput bold)
red=$(tput setaf 1) red=$(tput setaf 1)
@ -53,32 +55,36 @@ cyan=$(tput setaf 6)
white=$(tput setaf 7) white=$(tput setaf 7)
defaultcolor=$(tput setaf default) defaultcolor=$(tput setaf default)
# *************************************************************** # ---------
# Start Getting Nginx Ready for Testing the Nginx Bad Bot Blocker # FUNCTIONS
# *************************************************************** # ---------
printf "\n" reloadNginX () {
echo "${bold}${green}------------------" echo "${bold}${green}---------------"
echo "${bold}${green}Start Nginx Test 1" echo "${bold}${green}Reloading Nginx"
echo "${bold}${green}------------------" echo "${bold}${green}---------------"
printf "\n" printf "\n\n"
sudo nginx -t && sudo nginx -s reload
}
# ****************************************************** waitforReload () {
# Make a backup of the clean and default nginx.conf file echo "${bold}${yellow}-----------------------------------------------------------------------"
# Needed to run Nginx test 3 echo "${bold}${yellow}Sleeping for 10 seconds to allow Nginx to Properly Reload inside Travis"
# ****************************************************** echo "${bold}${yellow}-----------------------------------------------------------------------"
printf "\n\n"
sleep 10s
}
backupNginxConf () {
printf "\n" printf "\n"
echo "${bold}${yellow}---------------------------" echo "${bold}${yellow}---------------------------"
echo "${bold}${yellow}Making backup of nginx.conf" echo "${bold}${yellow}Making backup of nginx.conf"
echo "${bold}${yellow}---------------------------" echo "${bold}${yellow}---------------------------"
printf "\n" printf "\n"
sudo cp /etc/nginx/nginx.conf ${TRAVIS_BUILD_DIR}/.dev-tools/_nginx_conf_backup/nginx.conf sudo cp /etc/nginx/nginx.conf ${TRAVIS_BUILD_DIR}/.dev-tools/_nginx_conf_backup/nginx.conf
}
# ************************************************* prepareVhost () {
# Delete default site created by Nginx Installation
# *************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}-------------------------------------------" echo "${bold}${yellow}-------------------------------------------"
echo "${bold}${yellow}Delete any default files installed by Nginx" echo "${bold}${yellow}Delete any default files installed by Nginx"
@ -87,47 +93,33 @@ printf "\n"
sudo rm /etc/nginx/sites-available/default sudo rm /etc/nginx/sites-available/default
sudo rm /etc/nginx/sites-enabled/default sudo rm /etc/nginx/sites-enabled/default
sudo rm /var/www/html/* sudo rm /var/www/html/*
# ********************************************************
# Copy our default.vhost file into Nginx /sites-available/
# ********************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}---------------------" echo "${bold}${yellow}---------------------"
echo "${bold}${yellow}Setup Vhost for Nginx" echo "${bold}${yellow}Setup Vhost for Nginx"
echo "${bold}${yellow}---------------------" echo "${bold}${yellow}---------------------"
printf "\n" printf "\n"
sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/default.vhost /etc/nginx/sites-available/default.vhost sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/default.vhost /etc/nginx/sites-available/default.vhost
# **********************************************
# Link the vhost file into Nginx /sites-enabled/
# **********************************************
sudo ln -s /etc/nginx/sites-available/default.vhost /etc/nginx/sites-enabled/default.vhost sudo ln -s /etc/nginx/sites-available/default.vhost /etc/nginx/sites-enabled/default.vhost
# ***********************************************************
# Copy our index.php file into the default site's root folder
# ***********************************************************
sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/index.html /var/www/html/index.html sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/index.html /var/www/html/index.html
}
# *********************************************** makeScriptsExecutable () {
# Fetch our install-ngxblocker file from the repo sudo chmod +x /usr/sbin/install-ngxblocker
# *********************************************** sudo chmod +x /usr/sbin/setup-ngxblocker
sudo chmod +x /usr/sbin/update-ngxblocker
}
getinstallngxblocker () {
printf "\n" printf "\n"
echo "${bold}${magenta}--------------------------------------" echo "${bold}${magenta}--------------------------------------"
echo "${bold}${magenta}Fetch install-ngxblocker from the repo" echo "${bold}${magenta}Fetch install-ngxblocker from the repo"
echo "${bold}${magenta}--------------------------------------" echo "${bold}${magenta}--------------------------------------"
printf "\n" printf "\n"
sudo wget https://raw.githubusercontent.com/mitchellkrogza/nginx-ultimate-bad-bot-blocker/master/install-ngxblocker -O /usr/sbin/install-ngxblocker sudo wget https://raw.githubusercontent.com/mitchellkrogza/nginx-ultimate-bad-bot-blocker/master/install-ngxblocker -O /usr/sbin/install-ngxblocker
sudo chmod +x /usr/sbin/install-ngxblocker sudo chmod +x /usr/sbin/install-ngxblocker
}
# ********************** runinstallngxblocker () {
# Run Install-NgxBlocker
# **********************
printf "\n" printf "\n"
echo "${bold}${magenta}--------------------------" echo "${bold}${magenta}--------------------------"
echo "${bold}${magenta}Execute install-ngxblocker" echo "${bold}${magenta}Execute install-ngxblocker"
@ -135,19 +127,9 @@ echo "${bold}${magenta}--------------------------"
printf "\n" printf "\n"
cd /usr/sbin cd /usr/sbin
sudo bash ./install-ngxblocker -s /usr/sbin/ -x sudo bash ./install-ngxblocker -s /usr/sbin/ -x
}
# ************************************************** runsetupngxblocker1 () {
# Set our install and setup scripts to be executable
# **************************************************
sudo chmod +x /usr/sbin/install-ngxblocker
sudo chmod +x /usr/sbin/setup-ngxblocker
sudo chmod +x /usr/sbin/update-ngxblocker
# ********************
# Run setup-ngxblocker
# ********************
printf "\n" printf "\n"
echo "${bold}${magenta}------------------------" echo "${bold}${magenta}------------------------"
echo "${bold}${magenta}Execute setup-ngxblocker" echo "${bold}${magenta}Execute setup-ngxblocker"
@ -155,51 +137,32 @@ echo "${bold}${magenta}------------------------"
printf "\n" printf "\n"
cd /usr/sbin cd /usr/sbin
sudo bash ./setup-ngxblocker -i /usr/sbin/install-ngxblocker -x sudo bash ./setup-ngxblocker -i /usr/sbin/install-ngxblocker -x
}
# ************************ runsetupngxblocker2 () {
# Load our Nginx.conf file printf "\n"
# ************************ echo "${bold}${magenta}------------------------"
echo "${bold}${magenta}Execute setup-ngxblocker"
echo "${bold}${magenta}------------------------"
printf "\n"
cd /usr/sbin
sudo bash ./setup-ngxblocker -x
}
loadNginxConf () {
sudo nginx -c /etc/nginx/nginx.conf sudo nginx -c /etc/nginx/nginx.conf
}
# **************************************************************************************** forceUpdateTest1 () {
# Copy a dummy version of globalblacklist.conf with an older version number to test update
# ****************************************************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}----------------------------------------------------" echo "${bold}${yellow}----------------------------------------------------"
echo "${bold}${yellow}Copy older globalblacklist.conf file to force update" echo "${bold}${yellow}Copy older globalblacklist.conf file to force update"
echo "${bold}${yellow}----------------------------------------------------" echo "${bold}${yellow}----------------------------------------------------"
printf "\n" printf "\n"
sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf
}
# **************************************************************************************** forceUpdateTest2 () {
# Run update-ngxblocker test which downloads latest globalblacklist.conf and reloads Nginx
# ****************************************************************************************
printf "\n"
echo "${bold}${magenta}-------------------------"
echo "${bold}${magenta}Execute update-ngxblocker"
echo "${bold}${magenta}-------------------------"
printf "\n"
cd /usr/sbin
sudo bash ./update-ngxblocker -n
# *********************
# Force reload of Nginx
# *********************
printf "\n"
echo "${bold}${green}------------"
echo "${bold}${green}Reload Nginx"
echo "${bold}${green}------------"
printf "\n"
sudo nginx -t && sudo nginx -s reload
# *******************************************************************************************
# Test that update-ngxblocker can install all missing required files by deleting some of them
# *******************************************************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}--------------------------------------" echo "${bold}${yellow}--------------------------------------"
echo "${bold}${yellow}Delete Files to test update-ngxblocker" echo "${bold}${yellow}Delete Files to test update-ngxblocker"
@ -209,34 +172,18 @@ sudo rm /etc/nginx/conf.d/*.conf
sudo rm /etc/nginx/bots.d/*.conf sudo rm /etc/nginx/bots.d/*.conf
ls -la /etc/nginx/conf.d/ ls -la /etc/nginx/conf.d/
ls -la /etc/nginx/bots.d/ ls -la /etc/nginx/bots.d/
}
# ********************************************************************************************************* forceUpdateTest3 () {
# Run update-ngxblocker to test for missing files and download latest globalblacklist.conf and reload Nginx
# *********************************************************************************************************
printf "\n"
echo "${bold}${magenta}-------------------------"
echo "${bold}${magenta}Execute update-ngxblocker"
echo "${bold}${magenta}-------------------------"
printf "\n"
cd /usr/sbin
sudo bash ./update-ngxblocker -n
# ****************************************************************************************
# Copy a dummy version of globalblacklist.conf with an older version number to test update
# ****************************************************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}----------------------------------------------------" echo "${bold}${yellow}----------------------------------------------------"
echo "${bold}${yellow}Copy older globalblacklist.conf file to force update" echo "${bold}${yellow}Copy older globalblacklist.conf file to force update"
echo "${bold}${yellow}----------------------------------------------------" echo "${bold}${yellow}----------------------------------------------------"
printf "\n" printf "\n"
sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf
}
# ********************************************************************************************************* runupdatengxblocker () {
# Run update-ngxblocker to test for missing files and download latest globalblacklist.conf and reload Nginx
# *********************************************************************************************************
printf "\n" printf "\n"
echo "${bold}${magenta}-------------------------" echo "${bold}${magenta}-------------------------"
echo "${bold}${magenta}Execute update-ngxblocker" echo "${bold}${magenta}Execute update-ngxblocker"
@ -244,56 +191,18 @@ echo "${bold}${magenta}-------------------------"
printf "\n" printf "\n"
cd /usr/sbin cd /usr/sbin
sudo bash ./update-ngxblocker -n sudo bash ./update-ngxblocker -n
}
# ************************** activateLatestBlacklist () {
# Run setup-ngxblocker again
# **************************
printf "\n"
echo "${bold}${magenta}------------------------"
echo "${bold}${magenta}Execute setup-ngxblocker"
echo "${bold}${magenta}------------------------"
printf "\n"
cd /usr/sbin
sudo bash ./setup-ngxblocker -x
# *********************
# Force reload of Nginx
# *********************
printf "\n"
echo "${bold}${green}------------"
echo "${bold}${green}Reload Nginx"
echo "${bold}${green}------------"
printf "\n"
sudo nginx -t && sudo nginx -s reload
# *******************************************************
# Make sure we test latest generated globalblacklist.conf
# *******************************************************
printf "\n" printf "\n"
echo "${bold}${yellow}------------------------------------------------------------" echo "${bold}${yellow}------------------------------------------------------------"
echo "${bold}${yellow}Make sure we test with latest generated globalblacklist.conf" echo "${bold}${yellow}Make sure we test with latest generated globalblacklist.conf"
echo "${bold}${yellow}------------------------------------------------------------" echo "${bold}${yellow}------------------------------------------------------------"
printf "\n" printf "\n"
sudo cp ${TRAVIS_BUILD_DIR}/conf.d/globalblacklist.conf /etc/nginx/conf.d/globalblacklist.conf sudo cp ${TRAVIS_BUILD_DIR}/conf.d/globalblacklist.conf /etc/nginx/conf.d/globalblacklist.conf
}
# ********************* backupConfFiles () {
# Force reload of Nginx
# *********************
printf "\n"
echo "${bold}${green}------------"
echo "${bold}${green}Reload Nginx"
echo "${bold}${green}------------"
printf "\n"
sudo nginx -t && sudo nginx -s reload
# ************************************************************
# Copy all .conf files used in Test 1 to a folder for checking
# ************************************************************
printf "\n" printf "\n"
echo "${bold}${green}------------------------------------------------------------" echo "${bold}${green}------------------------------------------------------------"
echo "${bold}${green}Make Backup all conf files and folders used during this test" echo "${bold}${green}Make Backup all conf files and folders used during this test"
@ -303,33 +212,66 @@ sudo cp /etc/nginx/bots.d/* ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/bot
sudo cp /etc/nginx/conf.d/* ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/conf.d/ sudo cp /etc/nginx/conf.d/* ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/conf.d/
sudo cp /etc/nginx/sites-available/default.vhost ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/default.vhost sudo cp /etc/nginx/sites-available/default.vhost ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/default.vhost
sudo cp /etc/nginx/nginx.conf ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/nginx.conf sudo cp /etc/nginx/nginx.conf ${TRAVIS_BUILD_DIR}/.dev-tools/_conf_files_test1/nginx.conf
}
# ********************** # ------------------
# Start Installation
# ------------------
printf "\n"
echo "${bold}${green}------------------"
echo "${bold}${green}Start Nginx Test 1"
echo "${bold}${green}------------------"
printf "\n"
backupNginxConf
prepareVhost
getinstallngxblocker
runinstallngxblocker
makeScriptsExecutable
runsetupngxblocker1
loadNginxConf
forceUpdateTest1
runupdatengxblocker
reloadNginX
waitforReload
forceUpdateTest2
runupdatengxblocker
forceUpdateTest3
runsetupngxblocker2
reloadNginX
waitforReload
activateLatestBlacklist
reloadNginX
# ----------------------
# Exit With Error Number # Exit With Error Number
# ********************** # ----------------------
exit ${?} exit ${?}
# ------------------------------------------------------------------------------
# MIT License # MIT License
# ------------------------------------------------------------------------------
# Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com # Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com
# https://github.com/mitchellkrogza # https://github.com/mitchellkrogza
# ------------------------------------------------------------------------------
# Permission is hereby granted, free of charge, to any person obtaining a copy # Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal # of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights # in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is # copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions: # furnished to do so, subject to the following conditions:
# ------------------------------------------------------------------------------
# The above copyright notice and this permission notice shall be included in all # The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software. # copies or substantial portions of the Software.
# ------------------------------------------------------------------------------
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE. # SOFTWARE.
# ------------------------------------------------------------------------------