mirror of
https://github.com/mitchellkrogza/nginx-ultimate-bad-bot-blocker.git
synced 2025-09-01 18:19:55 +00:00
419 lines
16 KiB
Bash
Executable file
419 lines
16 KiB
Bash
Executable file
#!/bin/bash
|
|
# Curl Testing Script for 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.
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# ------------------------
|
|
# Set Terminal Font Colors
|
|
# ------------------------
|
|
|
|
bold=$(tput bold)
|
|
red=$(tput setaf 1)
|
|
green=$(tput setaf 2)
|
|
yellow=$(tput setaf 3)
|
|
blue=$(tput setaf 4)
|
|
magenta=$(tput setaf 5)
|
|
cyan=$(tput setaf 6)
|
|
white=$(tput setaf 7)
|
|
defaultcolor=$(tput setaf default)
|
|
|
|
# ---------
|
|
# FUNCTIONS
|
|
# ---------
|
|
|
|
|
|
resetNginx () {
|
|
echo "${bold}${green}------------------------------------------------"
|
|
echo "${bold}${green}Disable any User Whitelisting and set to Default"
|
|
echo "${bold}${green}------------------------------------------------"
|
|
printf "\n\n"
|
|
sudo cp ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/blacklist-user-agents-none.conf /etc/nginx/bots.d/blacklist-user-agents.conf
|
|
}
|
|
|
|
reloadNginX () {
|
|
echo "${bold}${green}---------------"
|
|
echo "${bold}${green}Reloading Nginx"
|
|
echo "${bold}${green}---------------"
|
|
printf "\n\n"
|
|
sudo nginx -t && sudo nginx -s reload
|
|
}
|
|
|
|
waitforReload () {
|
|
echo "${bold}${yellow}-----------------------------------------------------------------------"
|
|
echo "${bold}${yellow}Sleeping for 10 seconds to allow Nginx to Properly Reload inside Travis"
|
|
echo "${bold}${yellow}-----------------------------------------------------------------------"
|
|
printf "\n\n"
|
|
sleep 10s
|
|
}
|
|
|
|
run_curltest1 () {
|
|
if curl -v -A "80legs" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}80legs BAD BOT DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}80legs BAD BOT NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest2 () {
|
|
if curl -v -A "Nutch" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}Nutch BAD BOT DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}Nutch BAD BOT NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest3 () {
|
|
if curl -I http://localhost:9000 -e http://100dollars-seo.com 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}100dollars-seo.com BAD REFERRER DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}100dollars-seo.com BAD REFERRER NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest4 () {
|
|
if curl -I http://localhost:9000 -e http://zx6.ru 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}zx6.ru BAD REFERRER DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}zx6.ru BAD REFERRER NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest5 () {
|
|
if curl -v -A "GoogleBot" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}GoogleBot GOOD BOT ALLOWED THROUGH"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}GoogleBot GOOD BOT NOT ALLOWED THROUGH"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest6 () {
|
|
if curl -v -A "BingBot" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}BingBot GOOD BOT ALLOWED THROUGH"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}BingBot GOOD BOT NOT ALLOWED THROUGH"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest7 () {
|
|
if curl http://localhost:9000 -e http://google.com 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}google.com GOOD REFERRER DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}google.com GOOD REFERRER NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest8 () {
|
|
if curl http://localhost:9000 -e http://bing.com 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${red}bing.com GOOD REFERRER DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}bing.com GOOD REFERRER NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest9 () {
|
|
if curl -A "Googlebot/Nutch-1.7" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}Googlebot/Nutch-1.7 BAD BOT DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}Googlebot/Nutch-1.7 BAD BOT NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest10 () {
|
|
if curl -A "Mozilla/5.0 (compatible; Googlebot/Nutch2.1; +http://www.google.com/bot.html)" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}Googlebot/Nutch2.1 BAD BOT DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}Googlebot/Nutch2.1 BAD BOT NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest11 () {
|
|
if curl -A "Mozilla/5.0 (compatible; Googlebot/nutch/-2.1; +http://www.google.com/bot.html)" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}Googlebot/nutch/-2.1 BAD BOT DETECTED"
|
|
else
|
|
echo "${bold}${red}FAILED - Googlebot/nutch/-2.1 BAD BOT NOT DETECTED"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest12 () {
|
|
if curl -v -A "Mozilla/5.0 (compatible; Googlebot-Image/Snutch\-/-2.1; +http://www.google.com/bot.html)" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - NO FALSE POSITIVE on Googlebot-Image/Snutch\-/-2.1"
|
|
else
|
|
echo "${bold}${red}FAILED - FALSE POSITIVE FOUND on Googlebot-Image/Snutch\-/-2.1"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest13 () {
|
|
if curl -v -A "SnutchMozilla/5.0 (compatible; Googlebot-Image/SMutch\-/-2.1; +http://www.google.com/bot.html)" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - NO FALSE POSITIVE on SnutchMozilla/5.0"
|
|
else
|
|
echo "${bold}${red}FAILED - FALSE POSITIVE FOUND on SnutchMozilla/5.0"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest14 () {
|
|
if curl -v -A "Mozilla/5.0 (X11; Linux x86_64; rv:67.0) Gecko/20100101 Firefox/67.0" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - NO FALSE POSITIVE on Mozilla/5.0"
|
|
else
|
|
echo "${bold}${red}FAILED - FALSE POSITIVE FOUND on Mozilla/5.0"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
run_curltest15 () {
|
|
if curl -v -A "Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.1 Mobile/15E148 Safari/604.1" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - NO FALSE POSITIVE on Safari"
|
|
else
|
|
echo "${bold}${red}FAILED - FALSE POSITIVE FOUND on Safari"
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
testBadUserAgents () {
|
|
shuf -n 10 ${TRAVIS_BUILD_DIR}/_generator_lists/bad-user-agents.list > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.tmp
|
|
sed 's/\\//g' ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.tmp > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.list
|
|
sudo rm ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.tmp
|
|
sort -u ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.list -o ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.list
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}---------------------------"
|
|
echo "${bold}${magenta}Testing 10 Random Bad Bots"
|
|
echo "${bold}${magenta}---------------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-bots-for-test-quick.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -v -A "${line}" http://localhost:9000 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}${line} was ${bold}${red}NOT BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
testGoodUserAgents () {
|
|
sed 's/\\//g' ${TRAVIS_BUILD_DIR}/_generator_lists/good-user-agents.list > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/good-bots-for-test.list
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}---------------------"
|
|
echo "${bold}${magenta}Testing All Good Bots"
|
|
echo "${bold}${magenta}---------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/good-bots-for-test.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -v -A "${line}" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}${line} was ${bold}${green}ALLOWED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
testAllowedUserAgents () {
|
|
sed 's/\\//g' ${TRAVIS_BUILD_DIR}/_generator_lists/allowed-user-agents.list > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/allowed-bots-for-test.list
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}------------------------"
|
|
echo "${bold}${magenta}Testing All Allowed Bots"
|
|
echo "${bold}${magenta}------------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/allowed-bots-for-test.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -v -A "${line}" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}${line} was ${bold}${green}ALLOWED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
testLimitedUserAgents () {
|
|
sed 's/\\//g' ${TRAVIS_BUILD_DIR}/_generator_lists/limited-user-agents.list > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/limited-bots-for-test.list
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}------------------------"
|
|
echo "${bold}${magenta}Testing All Limited Bots"
|
|
echo "${bold}${magenta}------------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/limited-bots-for-test.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -v -A "${line}" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}${line} was ${bold}${green}ALLOWED"
|
|
else
|
|
echo "${bold}${green}FAILED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
testRandomReferrers () {
|
|
shuf -n 10 ${TRAVIS_BUILD_DIR}/_generator_lists/bad-referrers.list > ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-referrers-for-test-quick.list
|
|
sort -u ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-referrers-for-test-quick.list -o ${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-referrers-for-test-quick.list
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}---------------------------------"
|
|
echo "${bold}${magenta}Testing 10 Random Bad Referrers"
|
|
echo "${bold}${magenta}---------------------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/random-referrers-for-test-quick.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -I http://localhost:9000 -e "http://${line}" 2>&1 | grep -i '(52)'; then
|
|
echo "${bold}${green}PASSED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
else
|
|
echo "${bold}${red}FAILED - ${red}${line} was ${bold}${red}NOT BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
testGoodReferrers () {
|
|
printf "\n\n"
|
|
echo "${bold}${magenta}----------------------"
|
|
echo "${bold}${magenta}Testing Good Referrers"
|
|
echo "${bold}${magenta}----------------------"
|
|
printf "\n\n"
|
|
IFS=$'\n'
|
|
file=${TRAVIS_BUILD_DIR}/.dev-tools/test_units/good-referrers-for-test.list
|
|
lines=$(cat ${file})
|
|
for line in ${lines}; do
|
|
if
|
|
curl -v -A "${line}" http://localhost:9000 2>&1 | grep -i 'Welcome'; then
|
|
echo "${bold}${green}PASSED - ${green}${line} was ${bold}${green}ALLOWED"
|
|
else
|
|
echo "${bold}${green}FAILED - ${red}${line} was ${bold}${red}BLOCKED"
|
|
fi
|
|
done
|
|
IFS=""
|
|
}
|
|
|
|
# -----------------
|
|
# Trigger Functions
|
|
# -----------------
|
|
|
|
echo "${bold}${green}--------------"
|
|
echo "${bold}${green}Tests Starting"
|
|
echo "${bold}${green}--------------"
|
|
printf "\n\n"
|
|
|
|
resetNginx
|
|
reloadNginX
|
|
waitforReload
|
|
run_curltest1
|
|
run_curltest2
|
|
run_curltest3
|
|
run_curltest4
|
|
run_curltest5
|
|
run_curltest6
|
|
run_curltest7
|
|
run_curltest8
|
|
run_curltest9
|
|
run_curltest10
|
|
run_curltest11
|
|
run_curltest12
|
|
run_curltest13
|
|
run_curltest14
|
|
run_curltest15
|
|
testBadUserAgents
|
|
testGoodUserAgents
|
|
testAllowedUserAgents
|
|
testLimitedUserAgents
|
|
testRandomReferrers
|
|
testGoodReferrers
|
|
|
|
printf "\n"
|
|
echo "${bold}${cyan}Tests Completed"
|
|
echo "${bold}${green}All Tests Passed"
|
|
|
|
# ----------------------
|
|
# Exit With Error Number
|
|
# ----------------------
|
|
|
|
exit ${?}
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# 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.
|
|
# ------------------------------------------------------------------------------
|
|
|