mirror of
https://github.com/munin-monitoring/contrib.git
synced 2025-07-22 02:51:03 +00:00
[nextcloud_] Add scheme configuration and cleanup autoconf
Signed-off-by: Olivier Mehani <shtrom@ssji.net>
This commit is contained in:
parent
12cb113403
commit
f47fddf326
1 changed files with 15 additions and 18 deletions
|
@ -30,6 +30,7 @@ Set username and password in your munin-node configuration
|
||||||
env.username <nexcloud_user>
|
env.username <nexcloud_user>
|
||||||
env.password <nextcloud_password>
|
env.password <nextcloud_password>
|
||||||
env.api_path <default: /ocs/v2.php/apps/serverinfo/api/v1/info>
|
env.api_path <default: /ocs/v2.php/apps/serverinfo/api/v1/info>
|
||||||
|
env.scheme <default: https>
|
||||||
env.timeout <default: 2s>
|
env.timeout <default: 2s>
|
||||||
env.updates_warning <default: 1>
|
env.updates_warning <default: 1>
|
||||||
|
|
||||||
|
@ -60,6 +61,7 @@ fi
|
||||||
|
|
||||||
API_PATH="${api_path:-/ocs/v2.php/apps/serverinfo/api/v1/info}?format=json"
|
API_PATH="${api_path:-/ocs/v2.php/apps/serverinfo/api/v1/info}?format=json"
|
||||||
DOMAIN="${0##*nextcloud_}"
|
DOMAIN="${0##*nextcloud_}"
|
||||||
|
SCHEME="${scheme:-https}://"
|
||||||
TIMEOUT="${timeout:-2}"
|
TIMEOUT="${timeout:-2}"
|
||||||
UPDATES_WARNING="${updates_warning:-1}"
|
UPDATES_WARNING="${updates_warning:-1}"
|
||||||
CLEANDOMAIN="$(clean_fieldname "$DOMAIN")"
|
CLEANDOMAIN="$(clean_fieldname "$DOMAIN")"
|
||||||
|
@ -68,7 +70,7 @@ PASSWORD="${password:-}"
|
||||||
|
|
||||||
print_json_data() {
|
print_json_data() {
|
||||||
local FIRST="$1"
|
local FIRST="$1"
|
||||||
[ -z "$FIRST" ] && exit 0
|
[ -z "$FIRST" ] && (echo "incorrect call to print_json_data $*">&2; exit 1)
|
||||||
shift 1
|
shift 1
|
||||||
for KEY in "$@"; do
|
for KEY in "$@"; do
|
||||||
VALUE=$(echo "$FIRST" | jq -cr ".$KEY")
|
VALUE=$(echo "$FIRST" | jq -cr ".$KEY")
|
||||||
|
@ -83,22 +85,18 @@ fetch_url () {
|
||||||
case $1 in
|
case $1 in
|
||||||
|
|
||||||
autoconf)
|
autoconf)
|
||||||
if [ -x "$(command -v curl)" ]; then
|
if [ ! -x "$(command -v curl)" ]; then
|
||||||
if [ -x "$(command -v jq)" ]; then
|
echo "no (curl not found)"
|
||||||
(fetch_url -I -u "$USERNAME:$PASSWORD" -I "https://${DOMAIN}${API_PATH}" \
|
elif [ ! -x "$(command -v jq)" ]; then
|
||||||
|
echo "no (jq not found)"exit 0
|
||||||
|
else
|
||||||
|
fetch_url -I -u "$USERNAME:$PASSWORD" -I "${SCHEME}${DOMAIN}${API_PATH}" \
|
||||||
| grep -iq "Content-Type: application/json" \
|
| grep -iq "Content-Type: application/json" \
|
||||||
|| fetch_url -I -u "$USERNAME:$PASSWORD" -I "http://${DOMAIN}${API_PATH}" \
|
&& echo "yes" \
|
||||||
| grep -iq "Content-Type: application/json") \
|
|| echo "no (invalid or empty response from nextlcoud serverinfo api)"
|
||||||
&& echo "yes" && exit 0 \
|
fi
|
||||||
|| echo "no (invalid or empty response from nextlcoud serverinfo api)" && exit 0
|
exit 0
|
||||||
else
|
;;
|
||||||
echo "no (jq not found)" && exit 0
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "no (curl not found)" && exit 0
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
config)
|
config)
|
||||||
|
|
||||||
cat << EOM
|
cat << EOM
|
||||||
|
@ -216,8 +214,7 @@ esac
|
||||||
|
|
||||||
# Get JSON data
|
# Get JSON data
|
||||||
JSONSTATS=$(
|
JSONSTATS=$(
|
||||||
fetch_url -u "$USERNAME:$PASSWORD" "https://${DOMAIN}${API_PATH}" | sed 's/\\/\\\\/g' | jq -cr ".ocs.data" 2>&1 \
|
fetch_url -u "$USERNAME:$PASSWORD" "${SCHEME}${DOMAIN}${API_PATH}" | sed 's/\\/\\\\/g' | jq -cr ".ocs.data" 2>&1
|
||||||
|| fetch_url -u "$USERNAME:$PASSWORD" "http://${DOMAIN}${API_PATH}" | sed 's/\\/\\\\/g' | jq -cr ".ocs.data"
|
|
||||||
)
|
)
|
||||||
USERS=$(echo "$JSONSTATS" | jq -cr ".activeUsers")
|
USERS=$(echo "$JSONSTATS" | jq -cr ".activeUsers")
|
||||||
STORAGE=$(echo "$JSONSTATS" | jq -cr ".nextcloud.storage")
|
STORAGE=$(echo "$JSONSTATS" | jq -cr ".nextcloud.storage")
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue