mirror of
https://github.com/natelandau/shell-scripting-templates.git
synced 2025-11-08 05:03:46 -05:00
commit 61bf734812cb62ba6e0ec224bc15f7928705a8a2 Author: Nathaniel Landau <nate@natelandau.com> Date: Thu Oct 21 15:44:21 2021 -0400 Major overhaul continued - rename templates - add checks utilities - add new array utilities - rename files - add assorted utilities - improve documentation commit 546178fff3b526f492eb0eeffc63f79537e75de3 Author: Nathaniel Landau <nate@natelandau.com> Date: Wed Oct 20 16:31:14 2021 -0400 Update conventions commit f6d0642f85518efda9c5d8472b99d1c14163e381 Author: Nathaniel Landau <nate@natelandau.com> Date: Wed Oct 20 09:47:09 2021 -0400 minor formatting changes commit 2217612b55e3f9faf803a2d0c937ea2261206505 Author: Nathaniel Landau <nate@natelandau.com> Date: Tue Oct 19 17:59:09 2021 -0400 add new functions commit 347ba7aa738dcd6a5ad9d70886b38da3a17dc89e Author: Nathaniel Landau <nate@natelandau.com> Date: Tue Oct 19 12:06:44 2021 -0400 major overhaul - Add standaloneTemplate.sh - Rework README - Refactor inline documentation - Enforce coding standards - Remove CSV utilities - Add new array utilities - add _useGNUutils_ - more ... commit cd8e0d49aef25eeaf6b3e71a3c9e1f29ab9b06f5 Author: Nathaniel Landau <nate@natelandau.com> Date: Sun Oct 17 09:56:08 2021 -0400 Add debug functions commit f7c5c0a3d19815dcc6ba80b5f5a2ebb77ef88b07 Author: Nathaniel Landau <nate@natelandau.com> Date: Sat Oct 16 21:10:01 2021 -0400 add new array functions _joinArray_, _isEmptyArray_, _sortArray_, _reverseSortArray_, and _mergearrays_ commit d8bc3d8cabdbcee3c479f97b43a45bdfe3bdafe0 Author: Nathaniel Landau <nate@natelandau.com> Date: Fri Oct 15 17:27:12 2021 -0400 add _columnize_ commit 2fd2ae9435f476bc3968c3eb0d793db4bf1d9eaf Author: Nathaniel Landau <nate@natelandau.com> Date: Mon Oct 11 22:17:45 2021 -0400 _progressBar_: Fix unbound variable commit e8933d15fc955a1acc665e9a081f131e681855d5 Author: Nathaniel Landau <nate@natelandau.com> Date: Sun Oct 10 11:50:42 2021 -0400 _alert_: header now underlined commit c9ce894361dec7d3513c038794a155519baf26bc Author: Nathaniel Landau <nate@natelandau.com> Date: Tue Oct 5 09:49:42 2021 -0400 _alert_: line numbers to gray commit 4aaddd336ce613f629a7e6a62ef3b27ffc24d22d Author: Nathaniel Landau <nate@natelandau.com> Date: Fri Oct 8 15:05:20 2021 -0400 _usage_ to stdout commit e2372fc3122ec1f20acc27f04d29b3785f014e25 Author: Nathaniel Landau <nate@natelandau.com> Date: Tue Oct 5 09:38:26 2021 -0400 _setPATH_: remove unneeded logic commit e60c75b6c954ac4bd146e2758252168027b9a43d Author: Nathaniel Landau <nate@natelandau.com> Date: Tue Oct 5 09:25:38 2021 -0400 _findSource_: bugfix commit 0e84912e1ccd7203e5beff9f8737f8374f4aa5d8 Author: Nathaniel Landau <nate@natelandau.com> Date: Thu Sep 30 16:29:25 2021 -0400 add requirements to documentation commit 2c24843e3ada591e1868a94416e40b5ac0aa4994 Author: Nathaniel Landau <nate@natelandau.com> Date: Thu Sep 30 15:34:10 2021 -0400 _uniqueFilename_: improve extension handling commit 08bc2dfdcc8632efee9179e9c960a574fc17cf0c Author: Nathaniel Landau <nate@natelandau.com> Date: Mon Sep 27 15:13:53 2021 -0400 improve hooks script commit 641918f1559d3b3aa38a9bbdf418938b2b81c176 Author: Nathaniel Landau <nate@natelandau.com> Date: Fri Sep 24 08:16:52 2021 -0400 _inArry_: case insensitivity commit eae10f170680540fdb4a1222add7e54f8785ea63 Author: Nathaniel Landau <nate@natelandau.com> Date: Mon Sep 20 18:31:44 2021 -0400 clean up alerting commit 700acd56f57fd57db84ef0e232ef41cdd7aee43c Author: Nathaniel Landau <nate@natelandau.com> Date: Mon Sep 20 18:22:11 2021 -0400 refactor _execute_ commit d893f86900a9fed9d91a0c9cc06c13b6b34d9926 Author: Nathaniel Landau <nate@natelandau.com> Date: Mon Sep 20 18:19:18 2021 -0400 'fatal' replaces 'die' commit 3326857bf127bef36cd9982246aa5b826d796d0a Author: Nathaniel Landau <nate@natelandau.com> Date: Fri Sep 17 08:29:50 2021 -0400 _execute_: ensure quiet and verbose work together
137 lines
5.3 KiB
Bash
137 lines
5.3 KiB
Bash
# Functions for working with network services
|
|
|
|
_httpStatus_() {
|
|
# DESC:
|
|
# Report the HTTP status of a specified URL
|
|
# ARGS:
|
|
# $1 (Required) - URL (will work fine without https:// prefix)
|
|
# $2 (Optional) - Seconds to wait until timeout (Default is 3)
|
|
# $3 (Optional) - either '--code' or '--status' (default)
|
|
# $4 (optional) - CURL opts separated by spaces (Use -L to follow redirects)
|
|
# OUTS:
|
|
# stdout: Prints the HTTP status code or status message
|
|
# USAGE:
|
|
# _httpStatus_ URL [timeout] [--code or --status] [curl opts]
|
|
# NOTE:
|
|
# https://gist.github.com/rsvp/1171304
|
|
# EXAMPLES
|
|
# $ _httpStatus_ bit.ly
|
|
# 301 Redirection: Moved Permanently
|
|
#
|
|
# $ _httpStatus_ www.google.com 100 --code
|
|
|
|
[[ $# == 0 ]] && fatal "Missing required argument to ${FUNCNAME[0]}"
|
|
|
|
local _saveIFS=${IFS}
|
|
IFS=$' \n\t'
|
|
|
|
local _url=${1}
|
|
local _timeout=${2:-3}
|
|
local _flag=${3:---status}
|
|
local _arg4=${4:-}
|
|
local _arg5=${5:-}
|
|
local _arg6=${6:-}
|
|
local _arg7=${7:-}
|
|
local _curlops="${_arg4} ${_arg5} ${_arg6} ${_arg7}"
|
|
local _code
|
|
local _status
|
|
|
|
# __________ get the CODE which is numeric:
|
|
_code=$(curl --write-out %{http_code} --silent --connect-timeout "${_timeout}" \
|
|
--no-keepalive ${_curlops} --output /dev/null ${_url})
|
|
|
|
# __________ get the STATUS (from code) which is human interpretable:
|
|
case $_code in
|
|
000) _status="Not responding within ${_timeout} seconds" ;;
|
|
100) _status="Informational: Continue" ;;
|
|
101) _status="Informational: Switching Protocols" ;;
|
|
200) _status="Successful: OK within ${_timeout} seconds" ;;
|
|
201) _status="Successful: Created" ;;
|
|
202) _status="Successful: Accepted" ;;
|
|
203) _status="Successful: Non-Authoritative Information" ;;
|
|
204) _status="Successful: No Content" ;;
|
|
205) _status="Successful: Reset Content" ;;
|
|
206) _status="Successful: Partial Content" ;;
|
|
300) _status="Redirection: Multiple Choices" ;;
|
|
301) _status="Redirection: Moved Permanently" ;;
|
|
302) _status="Redirection: Found residing temporarily under different URI" ;;
|
|
303) _status="Redirection: See Other" ;;
|
|
304) _status="Redirection: Not Modified" ;;
|
|
305) _status="Redirection: Use Proxy" ;;
|
|
306) _status="Redirection: status not defined" ;;
|
|
307) _status="Redirection: Temporary Redirect" ;;
|
|
400) _status="Client Error: Bad Request" ;;
|
|
401) _status="Client Error: Unauthorized" ;;
|
|
402) _status="Client Error: Payment Required" ;;
|
|
403) _status="Client Error: Forbidden" ;;
|
|
404) _status="Client Error: Not Found" ;;
|
|
405) _status="Client Error: Method Not Allowed" ;;
|
|
406) _status="Client Error: Not Acceptable" ;;
|
|
407) _status="Client Error: Proxy Authentication Required" ;;
|
|
408) _status="Client Error: Request Timeout within ${_timeout} seconds" ;;
|
|
409) _status="Client Error: Conflict" ;;
|
|
410) _status="Client Error: Gone" ;;
|
|
411) _status="Client Error: Length Required" ;;
|
|
412) _status="Client Error: Precondition Failed" ;;
|
|
413) _status="Client Error: Request Entity Too Large" ;;
|
|
414) _status="Client Error: Request-URI Too Long" ;;
|
|
415) _status="Client Error: Unsupported Media Type" ;;
|
|
416) _status="Client Error: Requested Range Not Satisfiable" ;;
|
|
417) _status="Client Error: Expectation Failed" ;;
|
|
500) _status="Server Error: Internal Server Error" ;;
|
|
501) _status="Server Error: Not Implemented" ;;
|
|
502) _status="Server Error: Bad Gateway" ;;
|
|
503) _status="Server Error: Service Unavailable" ;;
|
|
504) _status="Server Error: Gateway Timeout within ${_timeout} seconds" ;;
|
|
505) _status="Server Error: HTTP Version Not Supported" ;;
|
|
*) fatal "httpstatus: status not defined." ;;
|
|
esac
|
|
|
|
case ${_flag} in
|
|
--status) echo "${_code} ${_status}" ;;
|
|
-s) echo "${_code} ${_status}" ;;
|
|
--code) echo "${_code}" ;;
|
|
-c) echo "${_code}" ;;
|
|
*) echo " _httpStatus_: bad flag" && _safeExit_ ;;
|
|
esac
|
|
|
|
IFS="${_saveIFS}"
|
|
}
|
|
|
|
_pushover_() {
|
|
# DESC:
|
|
# Sends a notification via Pushover
|
|
# ARGS:
|
|
# $1 (Required) - Title of notification
|
|
# $2 (Required) - Body of notification
|
|
# $3 (Required) - User Token
|
|
# $4 (Required) - API Key
|
|
# $5 (Optional) - Device
|
|
# OUTS:
|
|
# 0 if success
|
|
# 1 if failure
|
|
# USAGE: _pushover_ "Title Goes Here" "Message Goes Here"
|
|
# NOTE: The variables for the two API Keys must have valid values
|
|
# Credit: http://ryonsherman.blogspot.com/2012/10/shell-script-to-send-pushover.html
|
|
|
|
[[ $# -lt 4 ]] && fatal "Missing required argument to ${FUNCNAME[0]}"
|
|
|
|
local _pushoverURL="https://api.pushover.net/1/messages.json"
|
|
local _message="${2}"
|
|
local _apiKey="${3}"
|
|
local _userKey="${4}"
|
|
local _device="${5:-}"
|
|
|
|
if curl \
|
|
-F "token=${_apiKey}" \
|
|
-F "user=${_userKey}" \
|
|
-F "device=${_device}" \
|
|
-F "title=${_messageTitle}" \
|
|
-F "message=${_message}" \
|
|
"${_pushoverURL}" >/dev/null 2>&1; then
|
|
return 0
|
|
else
|
|
return 1
|
|
fi
|
|
}
|