summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 86bf451)
raw | patch | inline | side by side (parent: 86bf451)
author | Karl DeBisschop <kdebisschop@users.sourceforge.net> | |
Mon, 13 Jan 2003 04:50:03 +0000 (04:50 +0000) | ||
committer | Karl DeBisschop <kdebisschop@users.sourceforge.net> | |
Mon, 13 Jan 2003 04:50:03 +0000 (04:50 +0000) |
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@235 f882894a-f735-0410-b71e-b25c423dba1c
plugins/check_disk.c | patch | blob | history |
diff --git a/plugins/check_disk.c b/plugins/check_disk.c
index 26d9ac97b74021d51794c70e57bab29f158f1014..553430596656601b7fb2923638176ef04b79c970 100644 (file)
--- a/plugins/check_disk.c
+++ b/plugins/check_disk.c
#include "utils.h"
#include <stdarg.h>
-#define PROGNAME "check_disk"
#define REVISION "$Revision$"
#define COPYRIGHT "2000-2002"
void print_help (void);
void print_usage (void);
+const char *PROGNAME = "check_disk";
+
int w_df = -1;
int c_df = -1;
float w_dfp = -1.0;
float c_dfp = -1.0;
char *path = "";
-int verbose = FALSE;
+char *exclude_device = "";
+int verbose = 0;
int display_mntp = FALSE;
+
int
main (int argc, char **argv)
{
- int len;
int usp = -1;
int total_disk = -1;
int used_disk = -1;
int free_disk = -1;
int result = STATE_UNKNOWN;
- int temp_result = STATE_UNKNOWN;
- char *command_line = NULL;
- char input_buffer[MAX_INPUT_BUFFER] = "";
- char file_system[MAX_INPUT_BUFFER] = "";
- char mntp[MAX_INPUT_BUFFER] = "";
- char outbuf[MAX_INPUT_BUFFER] = "";
+ int disk_result = STATE_UNKNOWN;
+ char *command_line = "";
+ char input_buffer[MAX_INPUT_BUFFER];
+ char file_system[MAX_INPUT_BUFFER];
+ char mntp[MAX_INPUT_BUFFER];
char *output = "";
if (process_arguments (argc, argv) != OK)
asprintf (&command_line, "%s %s", DF_COMMAND, path);
- if (verbose)
+ if (verbose>0)
printf ("%s ==> ", command_line);
child_process = spopen (command_line);
if (!index (input_buffer, '/'))
continue;
- if (sscanf
- (input_buffer, "%s %d %d %d %d%% %s", file_system, &total_disk,
- &used_disk, &free_disk, &usp, &mntp) == 6
- || sscanf (input_buffer, "%s %*s %d %d %d %d%% %s", file_system,
- &total_disk, &used_disk, &free_disk, &usp, &mntp) == 6) {
- asprintf (&output, "%s [%d kB (%d%%) free on %s]", output, free_disk,
- 100 - usp, display_mntp ? mntp : file_system);
- result = max_state (result, check_disk (usp, free_disk));
+ if (sscanf (input_buffer, "%s %d %d %d %d%% %s", file_system,
+ &total_disk, &used_disk, &free_disk, &usp, mntp) == 6 ||
+ sscanf (input_buffer, "%s %*s %d %d %d %d%% %s", file_system,
+ &total_disk, &used_disk, &free_disk, &usp, mntp) == 6) {
+
+ if (strcmp(exclude_device,file_system) == 0 ||
+ strcmp(exclude_device,mntp) == 0) {
+ if (verbose>0)
+ printf ("ignoring %s.", file_system);
+ continue;
+ }
+
+ disk_result = check_disk (usp, free_disk);
+
+ if (strcmp (file_system, "none") == 0)
+ strncpy (file_system, mntp, MAX_INPUT_BUFFER-1);
+
+ if (disk_result!=STATE_OK || verbose>=0)
+ asprintf (&output, "%s [%d kB (%d%%) free on %s]", output,
+ free_disk, 100 - usp, display_mntp ? mntp : file_system);
+
+ result = max_state (result, disk_result);
}
+
else {
printf ("Unable to read output:\n%s\n%s\n", command_line, input_buffer);
return result;
}
/* If we get anything on stderr, at least set warning */
- while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_stderr))
- /*result = max (result, STATE_WARNING); */
- if( !( result == STATE_CRITICAL) ) {
+ while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_stderr)) {
+ if (result != STATE_CRITICAL) {
result = STATE_WARNING;
}
+ }
/* close stderr */
- (void) fclose (child_stderr);
+ if (child_stderr)
+ (void) fclose (child_stderr);
/* close the pipe */
- if (spclose (child_process))
- /*result = max (result, STATE_WARNING); */
- if( !( result == STATE_CRITICAL) ) {
+ if (spclose(child_process)!=0 && result!=STATE_CRITICAL)
result = STATE_WARNING;
- }
+
if (usp < 0)
printf ("Disk \"%s\" not mounted or nonexistant\n", path);
else if (result == STATE_UNKNOWN)
printf ("Unable to read output\n%s\n%s\n", command_line, input_buffer);
else
- printf ("DISK %s -%s\n", state_text (result), output);
+ printf ("DISK %s%s\n", state_text (result), output);
return result;
}
{"version", no_argument, 0, 'V'},
{"help", no_argument, 0, 'h'},
{"mountpoint", no_argument, 0, 'm'},
+ {"exclude_device", required_argument, 0, 'x'},
+ {"quiet", no_argument, 0, 'q'},
+
{0, 0, 0, 0}
};
#endif
while (1) {
#ifdef HAVE_GETOPT_H
c =
- getopt_long (argc, argv, "Vhvt:c:w:p:m", long_options, &option_index);
+ getopt_long (argc, argv, "+?Vqhvt:c:w:p:x:m", long_options, &option_index);
#else
- c = getopt (argc, argv, "Vhvt:c:w:p:m");
+ c = getopt (argc, argv, "+?Vqhvt:c:w:p:x:m");
#endif
if (c == -1 || c == EOF)
path = optarg;
break;
case 'v': /* verbose */
- verbose = TRUE;
+ verbose++;
+ break;
+ case 'q': /* verbose */
+ verbose--;
break;
case 'm': /* display mountpoint */
display_mntp = TRUE;
break;
+ case 'x': /* exclude path or partition */
+ exclude_device = optarg;
+ break;
case 'V': /* version */
print_revision (PROGNAME, REVISION);
exit (STATE_OK);
" -w, --warning=INTEGER\n"
" Exit with WARNING status if less than INTEGER kilobytes of disk are free\n"
" -w, --warning=PERCENT%%\n"
- " Exit with WARNING status if more than PERCENT of disk space is free\n"
+ " Exit with WARNING status if less than PERCENT of disk space is free\n"
" -c, --critical=INTEGER\n"
" Exit with CRITICAL status if less than INTEGER kilobytes of disk are free\n"
" -c, --critical=PERCENT%%\n"
- " Exit with CRITCAL status if more than PERCENT of disk space is free\n"
+ " Exit with CRITCAL status if less than PERCENT of disk space is free\n"
" -p, --path=PATH, --partition=PARTTION\n"
" Path or partition (checks all mounted partitions if unspecified)\n"
" -m, --mountpoint\n"
" Display the mountpoint instead of the partition\n"
+ " -x, --exclude_device=PATH\n"
+ " Ignore device (only works if -p unspecified)\n"
+ " -e, --errors-only\n"
+ " Display only devices/mountpoints with errors\n"
" -v, --verbose\n"
" Show details for command-line debugging (do not use with nagios server)\n"
" -h, --help\n"
print_usage (void)
{
printf
- ("Usage: %s -w limit -c limit [-p path] [-t timeout] [-m] [--verbose]\n"
+ ("Usage: %s -w limit -c limit [-p path | -x device] [-t timeout] [-m] [-e] [--verbose]\n"
" %s (-h|--help)\n"
" %s (-V|--version)\n", PROGNAME, PROGNAME, PROGNAME);
}