#!/bin/bash # Define the usage message usage() { echo "Usage: $0 -u [-w ] [-c ] [-C ] [-L] [-I] [-H ] [-p] [-R] [-s]" echo "[Arguments]: -u Specify the URL to check (required). -w Set the warn level for response time (default: 1 second). -c Set the critical level for response time (default: 2 seconds). -C If the body does not contain this string, return CRITICAL. -L Follow redirects. -I Insecure mode (--insecure). -H Specify headers. Formatted like \"Header1: value,Header2: value\" -p Print the curl command and exit -R Set curl --resolve option. -s Ignore the response status code." exit 3 } # Parse the command-line arguments while getopts "u:w:c:C:H:R:LhIps" opt; do case $opt in u) URL=$OPTARG ;; w) WARNING_LEVEL=$OPTARG ;; c) CRITICAL_LEVEL=$OPTARG ;; L) FOLLOW_REDIRECTS="-L" ;; C) CONTAINS=$OPTARG ;; I) INSECURE="--insecure" ;; H) HEADERS=$OPTARG ;; p) PRINT_ONLY=true ;; R) RESOLVE="--resolve $OPTARG" ;; s) IGNORE_STATUS_CODE=true ;; h) usage ;; *) usage ;; esac done WARNING_LEVEL=${WARNING_LEVEL:-1} CRITICAL_LEVEL=${CRITICAL_LEVEL:-2} #FOLLOW_REDIRECTS=${FOLLOW_REDIRECTS:-""} PRINT_ONLY=${PRINT_ONLY:-false} IGNORE_STATUS_CODE=${IGNORE_STATUS_CODE:-false} if [ -z "$URL" ]; then usage fi HEADER_ARGS="" IFS=',' read -ra values <<<"$HEADERS" for value in "${values[@]}"; do HEADER_ARGS+=' -H "'$value'" ' done if $PRINT_ONLY; then echo "curl --output \"$TMP_RESPONSE\" -s -w \"%{http_code}\n%{time_total}"\ $(echo "${HEADER_ARGS[@]}" | tr -s ' ') $FOLLOW_REDIRECTS $INSECURE $RESOLVE $URL" exit 3 fi TMP_ERROR_LOG=$(mktemp) TMP_RESPONSE=$(mktemp) RESPONSE=$(curl --output "$TMP_RESPONSE" -s -w "%{http_code}\n%{time_total}" $(echo "${HEADER_ARGS[@]}" | tr -s ' ') $FOLLOW_REDIRECTS $INSECURE $RESOLVE $URL 2>"$TMP_ERROR_LOG") # shellcheck disable=SC2181 if [ $? -ne 0 ]; then echo "CRITICAL: curl failed!" echo "Error log:" cat "$TMP_ERROR_LOG" rm -rf "$TMP_ERROR_LOG" exit 2 fi rm -rf "$TMP_ERROR_LOG" RESPONSE_CODE=$(echo "$RESPONSE" | head -n 1) RESPONSE_TIME=$(printf "%.3f" $(echo "$RESPONSE" | tail -n 1)) OUTPUT_MSG="" OUTPUT_CODE=0 if ([ $RESPONSE_CODE -eq 200 ] || $IGNORE_STATUS_CODE) && [ "$(echo "$RESPONSE_TIME < $CRITICAL_LEVEL" | bc -l)" -eq 1 ]; then OUTPUT_MSG="OK: ${RESPONSE_TIME}s - $URL" OUTPUT_CODE=0 elif ([ $RESPONSE_CODE -eq 200 ] || $IGNORE_STATUS_CODE) && [ "$(echo "$RESPONSE_TIME < $WARNING_LEVEL" | bc -l)" -eq 1 ]; then OUTPUT_MSG="WARNING: response time is slow ($RESPONSE_TIME seconds)." OUTPUT_CODE=1 elif ([ $RESPONSE_CODE -eq 200 ] || $IGNORE_STATUS_CODE); then OUTPUT_MSG"CRITICAL: response time is very slow ($RESPONSE_TIME seconds)." OUTPUT_CODE=2 else OUTPUT_MSG="CRITICAL: website did not return 200, response was $RESPONSE_CODE code." OUTPUT_CODE=2 fi if [[ -n ${CONTAINS+x} ]]; then if ! grep -q "$CONTAINS" "$TMP_RESPONSE"; then OUTPUT_MSG+="\nCRITICAL: response did not contain required string!\nFound: $(cat "$TMP_RESPONSE")" OUTPUT_CODE=2 # else # OUTPUT_MSG+="\nOK: response contained required string." fi fi rm -rf "$TMP_RESPONSE" if $IGNORE_STATUS_CODE && [[ $RESPONSE_CODE -ne 200 ]]; then OUTPUT_MSG+="\nResponse code was $RESPONSE_CODE." fi OUTPUT_MSG+=" | response_time=${RESPONSE_TIME}s;$WARNING_LEVEL;$CRITICAL_LEVEL;0" case $OUTPUT_CODE in #0) # echo "OK: $URL" # ;; 1) echo "WARNING: $URL" ;; 2) echo "CRITICAL: $URL" ;; 3) echo "UNKNOWN: $URL" ;; esac echo -e "$OUTPUT_MSG" exit $OUTPUT_CODE