mirror of
https://github.com/mitchellkrogza/nginx-ultimate-bad-bot-blocker.git
synced 2025-09-01 01:59:47 +00:00
252 lines
No EOL
13 KiB
Bash
Executable file
252 lines
No EOL
13 KiB
Bash
Executable file
#!/bin/bash
|
|
# Travis CI Generating and Building for the Nginx Ultimate Bad Bot Blocker
|
|
# Created by: Mitchell Krog (mitchellkrog@gmail.com)
|
|
# Copyright: Mitchell Krog - https://github.com/mitchellkrogza
|
|
# Repo Url: https://github.com/mitchellkrogza/nginx-ultimate-bad-bot-blocker
|
|
|
|
#########################################################################
|
|
# _ __ _ #
|
|
# / |/ /__ _(_)__ __ __ #
|
|
# / / _ `/ / _ \\ \ / #
|
|
# /_/|_/\_, /_/_//_/_\_\ #
|
|
# __/___/ __ ___ __ ___ __ __ #
|
|
# / _ )___ ____/ / / _ )___ / /_ / _ )/ /__ ____/ /_____ ____ #
|
|
# / _ / _ `/ _ / / _ / _ \/ __/ / _ / / _ \/ __/ '_/ -_) __/ #
|
|
# /____/\_,_/\_,_/ /____/\___/\__/ /____/_/\___/\__/_/\_\\__/_/ #
|
|
#########################################################################
|
|
|
|
# MIT License
|
|
|
|
# Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com
|
|
# https://github.com/mitchellkrogza
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
# The above copyright notice and this permission notice shall be included in all
|
|
# copies or substantial portions of the Software.
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# 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
|
|
# SOFTWARE.
|
|
|
|
# ***************************************************************
|
|
# Start Getting Nginx Ready for Testing the Nginx Bad Bot Blocker
|
|
# ***************************************************************
|
|
|
|
# *************************************************
|
|
# Delete default site created by Nginx Installation
|
|
# *************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "###########################################" "Delete any default files installed by Nginx" "###########################################"
|
|
sudo rm /etc/nginx/sites-available/default
|
|
sudo rm /etc/nginx/sites-enabled/default
|
|
sudo rm /var/www/html/*
|
|
printf '\n%s\n%s\n%s\n\n' "#######################################" "Nginx prepared for our Testing Sequence" "#######################################"
|
|
|
|
# ********************************************************
|
|
# Copy our default.vhost file into Nginx /sites-available/
|
|
# ********************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "################################" "Get Nginx Setup for Nginx Test 1" "################################"
|
|
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
|
|
|
|
# ***********************************************************
|
|
# Copy our index.php file into the default site's root folder
|
|
# ***********************************************************
|
|
|
|
sudo cp $TRAVIS_BUILD_DIR/.dev-tools/index.php /var/www/html/index.php
|
|
printf '\n%s\n%s\n%s\n\n' "#####################################" "Finished Nginx Setup for Nginx Test 1" "#####################################"
|
|
|
|
# ***********************************************
|
|
# Fetch our install-ngxblocker file from the repo
|
|
# ***********************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################################" "Fetch install-ngxblocker from the repo" "######################################"
|
|
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
|
|
|
|
# **********************
|
|
# Run Install-NgxBlocker
|
|
# **********************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################" "Run install-ngxblocker" "######################"
|
|
cd /usr/sbin
|
|
sudo bash ./install-ngxblocker -x
|
|
|
|
# **************************************************
|
|
# Set our install and setup scripts to be executable
|
|
# **************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "##########################################################" "Set our install, setup and update 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%s\n%s\n%s\n\n' "####################" "Run setup-ngxblocker" "####################"
|
|
cd /usr/sbin
|
|
sudo bash ./setup-ngxblocker -x
|
|
|
|
# ************************
|
|
# Load our Nginx.conf file
|
|
# ************************
|
|
|
|
sudo nginx -c /etc/nginx/nginx.conf
|
|
|
|
# ****************************************************************************************
|
|
# Copy a dummy version of globalblacklist.conf with an older version number to test update
|
|
# ****************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "####################################################" "Copy older globalblacklist.conf file to force update" "####################################################"
|
|
sudo cp $TRAVIS_BUILD_DIR/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf
|
|
|
|
# ****************************************************************************************
|
|
# Run update-ngxblocker test which downloads latest globalblacklist.conf and reloads Nginx
|
|
# ****************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################" "Run update-ngxblocker" "######################"
|
|
cd /usr/sbin
|
|
sudo bash ./update-ngxblocker -n
|
|
|
|
# *********************
|
|
# Force reload of Nginx
|
|
# *********************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "########################" "Force Reloading of Nginx" "########################"
|
|
sudo service nginx reload
|
|
|
|
# *******************************************************************************************
|
|
# Test that update-ngxblocker can install all missing required files by deleting some of them
|
|
# *******************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "####################################################################" "Delete existing files to force update-ngxblocker to re-download them" "####################################################################"
|
|
sudo rm /etc/nginx/conf.d/*.conf
|
|
sudo rm /etc/nginx/bots.d/*.conf
|
|
|
|
# *************************************
|
|
# List Directories to Confirm Deletions
|
|
# *************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "################################################" "Confirming /etc/nginx/conf.d/ directory is EMPTY" "################################################"
|
|
ls -la /etc/nginx/conf.d/
|
|
printf '\n%s\n%s\n%s\n\n' "################################################" "Confirming /etc/nginx/bots.d/ directory is EMPTY" "################################################"
|
|
ls -la /etc/nginx/bots.d/
|
|
|
|
# *********************************************************************************************************
|
|
# Run update-ngxblocker to test for missing files and download latest globalblacklist.conf and reload Nginx
|
|
# *********************************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################" "Run update-ngxblocker" "######################"
|
|
cd /usr/sbin
|
|
sudo bash ./update-ngxblocker -n
|
|
|
|
# ****************************************************
|
|
# List Directories to Confirm Downloaded Missing Files
|
|
# ****************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "#######################################################################################" "Confirming /etc/nginx/conf.d/ directory has missing files replaced by update-ngxblocker" "#######################################################################################"
|
|
ls -la /etc/nginx/conf.d/
|
|
printf '\n%s\n%s\n%s\n\n' "#######################################################################################" "Confirming /etc/nginx/bots.d/ directory has missing files replaced by update-ngxblocker" "#######################################################################################"
|
|
ls -la /etc/nginx/bots.d/
|
|
|
|
# ****************************************************************************************
|
|
# Copy a dummy version of globalblacklist.conf with an older version number to test update
|
|
# ****************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "####################################################" "Copy older globalblacklist.conf file to force update" "####################################################"
|
|
sudo cp $TRAVIS_BUILD_DIR/.dev-tools/globalblacklist-dummy.conf /etc/nginx/conf.d/globalblacklist.conf
|
|
|
|
# *********************************************************************************************************
|
|
# Run update-ngxblocker to test for missing files and download latest globalblacklist.conf and reload Nginx
|
|
# *********************************************************************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################" "Run update-ngxblocker" "######################"
|
|
cd /usr/sbin
|
|
sudo bash ./update-ngxblocker -n
|
|
|
|
# **************************
|
|
# Run setup-ngxblocker again
|
|
# **************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "####################" "Run setup-ngxblocker" "####################"
|
|
cd /usr/sbin
|
|
sudo bash ./setup-ngxblocker -x
|
|
|
|
# *********************
|
|
# Force reload of Nginx
|
|
# *********************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "########################" "Force Reloading of Nginx" "########################"
|
|
sudo service nginx reload
|
|
|
|
# *******************************************************
|
|
# Make sure we test latest generated globalblacklist.conf
|
|
# *******************************************************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "##############################################################################" "Copy latest generated globalblacklist.conf file to test for any compile errors" "##############################################################################"
|
|
sudo cp $TRAVIS_BUILD_DIR/conf.d/globalblacklist.conf /etc/nginx/conf.d/globalblacklist.conf
|
|
|
|
# *********************
|
|
# Force reload of Nginx
|
|
# *********************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "########################" "Force Reloading of Nginx" "########################"
|
|
sudo service nginx reload
|
|
|
|
# **********************
|
|
# Now Run our Curl Tests
|
|
# **********************
|
|
|
|
printf '\n%s\n%s\n%s\n\n' "######################" "Now Run our Curl Tests" "######################"
|
|
|
|
# ************************************************************
|
|
# Copy all .conf files used in Test 1 to a folder for checking
|
|
# ************************************************************
|
|
|
|
cp /etc/nginx/bots.d/* $TRAVIS_BUILD_DIR/.dev-tools/_conf_files_test1/bots.d/
|
|
cp /etc/nginx/conf.d/* $TRAVIS_BUILD_DIR/.dev-tools/_conf_files_test1/conf.d/
|
|
|
|
# *****************************************************************************************
|
|
# Travis now moves into running the rest of the tests in the script: section of .travis.yml
|
|
# *****************************************************************************************
|
|
|
|
# MIT License
|
|
|
|
# Copyright (c) 2017 Mitchell Krog - mitchellkrog@gmail.com
|
|
# https://github.com/mitchellkrogza
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
# in the Software without restriction, including without limitation the rights
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
# The above copyright notice and this permission notice shall be included in all
|
|
# copies or substantial portions of the Software.
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
# 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
|
|
# SOFTWARE. |