diff options
author | Alex Griffin <griffin.aj@gmail.com> | 2012-04-18 11:43:13 -0500 |
---|---|---|
committer | Holger Weiss <holger@zedat.fu-berlin.de> | 2012-05-29 14:07:37 +0200 |
commit | aab6b8a16c9ec1dfe9d27f70cfbe19281153e306 (patch) | |
tree | 559fa79d29775211b43113fb85874d4fad97550f /plugins-scripts | |
parent | 252ae618fc6a02ca68872a1262d054a0b7b98fdb (diff) | |
download | monitoring-plugins-aab6b8a16c9ec1dfe9d27f70cfbe19281153e306.tar.gz |
Added check_range shell function to utils.sh.in
Diffstat (limited to 'plugins-scripts')
-rw-r--r-- | plugins-scripts/utils.sh.in | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/plugins-scripts/utils.sh.in b/plugins-scripts/utils.sh.in index b30b9083..d5013a60 100644 --- a/plugins-scripts/utils.sh.in +++ b/plugins-scripts/utils.sh.in | |||
@@ -21,3 +21,88 @@ support() { | |||
21 | $ECHO "@SUPPORT@" | sed -e 's/\n/ /g' | 21 | $ECHO "@SUPPORT@" | sed -e 's/\n/ /g' |
22 | } | 22 | } |
23 | 23 | ||
24 | |||
25 | # check_range takes a value and a range string, returning successfully if an | ||
26 | # alert should be raised based on the range | ||
27 | check_range() { | ||
28 | local v range yes no err decimal start end cmp match | ||
29 | v="$1" | ||
30 | range="$2" | ||
31 | |||
32 | # whether to raise an alert or not | ||
33 | yes=0 | ||
34 | no=1 | ||
35 | err=2 | ||
36 | |||
37 | # regex to match a decimal number | ||
38 | decimal="-?([0-9]+\.?[0-9]*|[0-9]*\.[0-9]+)" | ||
39 | |||
40 | # compare numbers (including decimals), returning true/false | ||
41 | cmp() { awk "BEGIN{ if ($1) exit(0); exit(1)}"; } | ||
42 | |||
43 | # returns successfully if the string in the first argument matches the | ||
44 | # regex in the second | ||
45 | match() { echo "$1" | grep -E -q -- "$2"; } | ||
46 | |||
47 | # make sure value is valid | ||
48 | if ! match "$v" "^$decimal$"; then | ||
49 | echo "${0##*/}: check_range: invalid value" >&2 | ||
50 | unset -f cmp match | ||
51 | return "$err" | ||
52 | fi | ||
53 | |||
54 | # make sure range is valid | ||
55 | if ! match "$range" "^@?(~|$decimal)(:($decimal)?)?$"; then | ||
56 | echo "${0##*/}: check_range: invalid range" >&2 | ||
57 | unset -f cmp match | ||
58 | return "$err" | ||
59 | fi | ||
60 | |||
61 | # check for leading @ char, which negates the range | ||
62 | if match $range '^@'; then | ||
63 | range=${range#@} | ||
64 | yes=1 | ||
65 | no=0 | ||
66 | fi | ||
67 | |||
68 | # parse the range string | ||
69 | if ! match "$range" ':'; then | ||
70 | start=0 | ||
71 | end="$range" | ||
72 | else | ||
73 | start="${range%%:*}" | ||
74 | end="${range#*:}" | ||
75 | fi | ||
76 | |||
77 | # do the comparison, taking positive ("") and negative infinity ("~") | ||
78 | # into account | ||
79 | if [ "$start" != "~" ] && [ "$end" != "" ]; then | ||
80 | if cmp "$start <= $v" && cmp "$v <= $end"; then | ||
81 | unset -f cmp match | ||
82 | return "$no" | ||
83 | else | ||
84 | unset -f cmp match | ||
85 | return "$yes" | ||
86 | fi | ||
87 | elif [ "$start" != "~" ] && [ "$end" = "" ]; then | ||
88 | if cmp "$start <= $v"; then | ||
89 | unset -f cmp match | ||
90 | return "$no" | ||
91 | else | ||
92 | unset -f cmp match | ||
93 | return "$yes" | ||
94 | fi | ||
95 | elif [ "$start" = "~" ] && [ "$end" != "" ]; then | ||
96 | if cmp "$v <= $end"; then | ||
97 | unset -f cmp match | ||
98 | return "$no" | ||
99 | else | ||
100 | unset -f cmp match | ||
101 | return "$yes" | ||
102 | fi | ||
103 | else | ||
104 | unset -f cmp match | ||
105 | return "$no" | ||
106 | fi | ||
107 | } | ||
108 | |||