mirror of
https://github.com/cytopia/devilbox.git
synced 2025-02-07 11:30:16 +00:00
Remove pre-login from phpMyAdmin CI test
This commit is contained in:
parent
4324f13714
commit
a47a497597
@ -80,202 +80,202 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
###
|
####
|
||||||
### Ensure given phpMyAdmin version works
|
#### Ensure given phpMyAdmin version works
|
||||||
###
|
####
|
||||||
|
#
|
||||||
printf "[TEST] Fetch ${URL}"
|
#printf "[TEST] Fetch ${URL}"
|
||||||
# 1st Try
|
## 1st Try
|
||||||
if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
#if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
||||||
# 2nd Try
|
# # 2nd Try
|
||||||
sleep 1
|
# sleep 1
|
||||||
if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
# if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
||||||
# 3rd Try
|
# # 3rd Try
|
||||||
sleep 1
|
# sleep 1
|
||||||
if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
# if ! curl -sS localhost${URL} | tac | tac | grep -Eiq "welcome to.+phpMyAdmin"; then
|
||||||
printf "\r[FAIL] Fetch ${URL}\n"
|
# printf "\r[FAIL] Fetch ${URL}\n"
|
||||||
curl -sS localhost/${URL} || true
|
# curl -sS localhost/${URL} || true
|
||||||
curl -sSI localhost/${URL} || true
|
# curl -sSI localhost/${URL} || true
|
||||||
exit 1
|
# exit 1
|
||||||
else
|
# else
|
||||||
printf "\r[OK] Fetch ${URL} (3 rounds)\n"
|
# printf "\r[OK] Fetch ${URL} (3 rounds)\n"
|
||||||
fi
|
# fi
|
||||||
else
|
# else
|
||||||
printf "\r[OK] Fetch ${URL} (2 rounds)\n"
|
# printf "\r[OK] Fetch ${URL} (2 rounds)\n"
|
||||||
fi
|
# fi
|
||||||
else
|
#else
|
||||||
printf "\r[OK] Fetch ${URL} (1 round)\n"
|
# printf "\r[OK] Fetch ${URL} (1 round)\n"
|
||||||
fi
|
#fi
|
||||||
|
#
|
||||||
|
#
|
||||||
###
|
####
|
||||||
### Login
|
#### Login
|
||||||
###
|
####
|
||||||
|
#
|
||||||
TOKEN=
|
#TOKEN=
|
||||||
printf "[TEST] Retrieve phpMyAdmin login page"
|
#printf "[TEST] Retrieve phpMyAdmin login page"
|
||||||
while true; do
|
#while true; do
|
||||||
# Try again until it succeeds
|
# # Try again until it succeeds
|
||||||
if ! CONTENT="$( curl -sS -c cookie.txt localhost${URL} )"; then
|
# if ! CONTENT="$( curl -sS -c cookie.txt localhost${URL} )"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "e"
|
# printf "e"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Extract the token
|
# # Extract the token
|
||||||
if ! TOKEN="$( echo "${CONTENT}" \
|
# if ! TOKEN="$( echo "${CONTENT}" \
|
||||||
| grep -Eo "name=\"token\" value=\".+\"" \
|
# | grep -Eo "name=\"token\" value=\".+\"" \
|
||||||
| head -1 \
|
# | head -1 \
|
||||||
| grep -Eo "value=\".+\"" \
|
# | grep -Eo "value=\".+\"" \
|
||||||
| sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
# | sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "w"
|
# printf "w"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '!'
|
# # Ensure Token does not contain '!'
|
||||||
if echo "${TOKEN}" | grep -q "!"; then
|
# if echo "${TOKEN}" | grep -q "!"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "!"
|
# printf "!"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '&'
|
# # Ensure Token does not contain '&'
|
||||||
if echo "${TOKEN}" | grep -q "&"; then
|
# if echo "${TOKEN}" | grep -q "&"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "&"
|
# printf "&"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '?'
|
# # Ensure Token does not contain '?'
|
||||||
if echo "${TOKEN}" | grep -q "?"; then
|
# if echo "${TOKEN}" | grep -q "?"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "?"
|
# printf "?"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '"'
|
# # Ensure Token does not contain '"'
|
||||||
if echo "${TOKEN}" | grep -q "\""; then
|
# if echo "${TOKEN}" | grep -q "\""; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "\""
|
# printf "\""
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '
|
# # Ensure Token does not contain '
|
||||||
if echo "${TOKEN}" | grep -q "'"; then
|
# if echo "${TOKEN}" | grep -q "'"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "'"
|
# printf "'"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '@'
|
# # Ensure Token does not contain '@'
|
||||||
if echo "${TOKEN}" | grep -q "@"; then
|
# if echo "${TOKEN}" | grep -q "@"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "@"
|
# printf "@"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '\'
|
# # Ensure Token does not contain '\'
|
||||||
if echo "${TOKEN}" | grep -q "\\\\"; then
|
# if echo "${TOKEN}" | grep -q "\\\\"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "\\"
|
# printf "\\"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '='
|
# # Ensure Token does not contain '='
|
||||||
if echo "${TOKEN}" | grep -q "="; then
|
# if echo "${TOKEN}" | grep -q "="; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "="
|
# printf "="
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '`'
|
# # Ensure Token does not contain '`'
|
||||||
if echo "${TOKEN}" | grep -q "\`"; then
|
# if echo "${TOKEN}" | grep -q "\`"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "\`"
|
# printf "\`"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '+'
|
# # Ensure Token does not contain '+'
|
||||||
if echo "${TOKEN}" | grep -q "+"; then
|
# if echo "${TOKEN}" | grep -q "+"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "+"
|
# printf "+"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain ';'
|
# # Ensure Token does not contain ';'
|
||||||
if echo "${TOKEN}" | grep -q ";"; then
|
# if echo "${TOKEN}" | grep -q ";"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf ";"
|
# printf ";"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '%'
|
# # Ensure Token does not contain '%'
|
||||||
if echo "${TOKEN}" | grep -q "%"; then
|
# if echo "${TOKEN}" | grep -q "%"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "%%"
|
# printf "%%"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain ']'
|
# # Ensure Token does not contain ']'
|
||||||
if echo "${TOKEN}" | grep -q "\]"; then
|
# if echo "${TOKEN}" | grep -q "\]"; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "\]"
|
# printf "\]"
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '['
|
# # Ensure Token does not contain '['
|
||||||
if echo "${TOKEN}" | grep -q "\["; then
|
# if echo "${TOKEN}" | grep -q "\["; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf "\["
|
# printf "\["
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
# Ensure Token does not contain '$'
|
# # Ensure Token does not contain '$'
|
||||||
if echo "${TOKEN}" | grep -q '\$'; then
|
# if echo "${TOKEN}" | grep -q '\$'; then
|
||||||
rm -f cookie.txt
|
# rm -f cookie.txt
|
||||||
printf '\$'
|
# printf '\$'
|
||||||
continue;
|
# continue;
|
||||||
fi
|
# fi
|
||||||
|
#
|
||||||
# All set
|
# # All set
|
||||||
break
|
# break
|
||||||
done
|
#done
|
||||||
printf "\r[OK] Retrieve phpMyAdmin login page\r\n"
|
#printf "\r[OK] Retrieve phpMyAdmin login page\r\n"
|
||||||
|
#
|
||||||
|
#
|
||||||
printf "[TEST] Exract phpMyAdmin login token"
|
#printf "[TEST] Exract phpMyAdmin login token"
|
||||||
if ! TOKEN="$( echo "${CONTENT}" \
|
#if ! TOKEN="$( echo "${CONTENT}" \
|
||||||
| grep -Eo "name=\"token\" value=\".+\"" \
|
# | grep -Eo "name=\"token\" value=\".+\"" \
|
||||||
| head -1 \
|
# | head -1 \
|
||||||
| grep -Eo "value=\".+\"" \
|
# | grep -Eo "value=\".+\"" \
|
||||||
| sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
# | sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
||||||
printf "\r[FAIL] Exract phpMyAdmin login token\n"
|
# printf "\r[FAIL] Exract phpMyAdmin login token\n"
|
||||||
rm -f cookie.txt || true
|
# rm -f cookie.txt || true
|
||||||
echo "${CONTENT}"
|
# echo "${CONTENT}"
|
||||||
exit 1
|
# exit 1
|
||||||
fi
|
#fi
|
||||||
printf "\r[OK] Exract phpMyAdmin login token: \"%s\"\n" "${TOKEN}"
|
#printf "\r[OK] Exract phpMyAdmin login token: \"%s\"\n" "${TOKEN}"
|
||||||
|
#
|
||||||
printf "[TEST] Extract phpMyAdmin login session"
|
#printf "[TEST] Extract phpMyAdmin login session"
|
||||||
if ! SESSION="$( echo "${CONTENT}" \
|
#if ! SESSION="$( echo "${CONTENT}" \
|
||||||
| grep -Eo "name=\"set_session\" value=\"[A-Fa-f0-9]+\"" \
|
# | grep -Eo "name=\"set_session\" value=\"[A-Fa-f0-9]+\"" \
|
||||||
| grep -Eo "value=\"[A-Fa-f0-9]+\"" \
|
# | grep -Eo "value=\"[A-Fa-f0-9]+\"" \
|
||||||
| sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
# | sed -e 's/^value="//g' -e 's/"$//g' )"; then
|
||||||
printf "\r[OK] Extract phpMyAdmin login session (not available)\n"
|
# printf "\r[OK] Extract phpMyAdmin login session (not available)\n"
|
||||||
SESSION=""
|
# SESSION=""
|
||||||
else
|
#else
|
||||||
printf "\r[OK] Extract phpMyAdmin login session: \"%s\"\n" "${SESSION}"
|
# printf "\r[OK] Extract phpMyAdmin login session: \"%s\"\n" "${SESSION}"
|
||||||
fi
|
#fi
|
||||||
|
#
|
||||||
|
#
|
||||||
printf "[TEST] Submit phpMyAdmin POST login"
|
#printf "[TEST] Submit phpMyAdmin POST login"
|
||||||
# 1st Try
|
## 1st Try
|
||||||
if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
#if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
||||||
# 2nd Try
|
# # 2nd Try
|
||||||
sleep 1
|
# sleep 1
|
||||||
if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
# if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
||||||
# 3rd Try
|
# # 3rd Try
|
||||||
sleep 1
|
# sleep 1
|
||||||
if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
# if ! curl -sS -c cookie.txt -b cookie.txt -d "pma_username=root&pma_password=&server=1&target=index.php&token=${TOKEN}&set_session=${SESSION}" localhost${URL}; then
|
||||||
printf "\r[FAIL] Submit phpMyAdmin POST login\n"
|
# printf "\r[FAIL] Submit phpMyAdmin POST login\n"
|
||||||
curl -sS -c cookie.txt -b cookie.txt localhost/${URL} || true
|
# curl -sS -c cookie.txt -b cookie.txt localhost/${URL} || true
|
||||||
curl -sSI -c cookie.txt -b cookie.txt localhost/${URL} || true
|
# curl -sSI -c cookie.txt -b cookie.txt localhost/${URL} || true
|
||||||
rm -f cookie.txt || true
|
# rm -f cookie.txt || true
|
||||||
exit 1
|
# exit 1
|
||||||
else
|
# else
|
||||||
printf "\r[OK] Submit phpMyAdmin POST login (3 rounds)\n"
|
# printf "\r[OK] Submit phpMyAdmin POST login (3 rounds)\n"
|
||||||
fi
|
# fi
|
||||||
else
|
# else
|
||||||
printf "\r[OK] Submit phpMyAdmin POST login (2 rounds)\n"
|
# printf "\r[OK] Submit phpMyAdmin POST login (2 rounds)\n"
|
||||||
fi
|
# fi
|
||||||
else
|
#else
|
||||||
printf "\r[OK] Submit phpMyAdmin POST login (1 round)\n"
|
# printf "\r[OK] Submit phpMyAdmin POST login (1 round)\n"
|
||||||
fi
|
#fi
|
||||||
|
|
||||||
|
|
||||||
printf "[TEST] Evaluate successful phpMyAdmin login"
|
printf "[TEST] Evaluate successful phpMyAdmin login"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user