| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- /*****************************************************************************
- *
- * Nagios check_users plugin
- *
- * License: GPL
- * Copyright (c) 2000-2014 Nagios Plugins Development Team
- *
- * Description:
- *
- * This file contains the check_users plugin
- *
- * This plugin checks the number of users currently logged in on the local
- * system and generates an error if the number exceeds the thresholds
- * specified.
- *
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- *
- *
- *****************************************************************************/
- const char *progname = "check_users";
- const char *copyright = "2000-2014";
- const char *email = "devel@nagios-plugins.org";
- #include "common.h"
- #include "utils.h"
- #if HAVE_WTSAPI32_H
- # include <windows.h>
- # include <wtsapi32.h>
- # undef ERROR
- # define ERROR -1
- #elif HAVE_UTMPX_H
- # include <utmpx.h>
- #else
- # include "popen.h"
- #endif
- #define possibly_set(a,b) ((a) == 0 ? (b) : 0)
- int process_arguments (int, char **);
- void print_help (void);
- void print_usage (void);
- char *warning_range = NULL;
- char *critical_range = NULL;
- thresholds *thlds = NULL;
- int
- main (int argc, char **argv)
- {
- int users = -1;
- int result = STATE_UNKNOWN;
- #if HAVE_WTSAPI32_H
- WTS_SESSION_INFO *wtsinfo;
- DWORD wtscount;
- DWORD index;
- #elif HAVE_UTMPX_H
- struct utmpx *putmpx;
- #else
- char input_buffer[MAX_INPUT_BUFFER];
- #endif
- setlocale (LC_ALL, "");
- bindtextdomain (PACKAGE, LOCALEDIR);
- textdomain (PACKAGE);
- /* Parse extra opts if any */
- argv = np_extra_opts (&argc, argv, progname);
- if (process_arguments (argc, argv) == ERROR)
- usage4 (_("Could not parse arguments"));
- users = 0;
- #if HAVE_WTSAPI32_H
- if (!WTSEnumerateSessions(WTS_CURRENT_SERVER_HANDLE,
- 0, 1, &wtsinfo, &wtscount)) {
- printf(_("Could not enumerate RD sessions: %d\n"), GetLastError());
- return STATE_UNKNOWN;
- }
- for (index = 0; index < wtscount; index++) {
- LPTSTR username;
- DWORD size;
- int len;
- if (!WTSQuerySessionInformation(WTS_CURRENT_SERVER_HANDLE,
- wtsinfo[index].SessionId, WTSUserName, &username, &size))
- continue;
- len = lstrlen(username);
- WTSFreeMemory(username);
- if (len == 0)
- continue;
- if (wtsinfo[index].State == WTSActive ||
- wtsinfo[index].State == WTSDisconnected)
- users++;
- }
- WTSFreeMemory(wtsinfo);
- #elif HAVE_UTMPX_H
- /* get currently logged users from utmpx */
- setutxent ();
- while ((putmpx = getutxent ()) != NULL)
- if (putmpx->ut_type == USER_PROCESS)
- users++;
- endutxent ();
- #else
- /* run the command */
- child_process = spopen (WHO_COMMAND);
- if (child_process == NULL) {
- printf (_("Could not open pipe: %s\n"), WHO_COMMAND);
- return STATE_UNKNOWN;
- }
- child_stderr = fdopen (child_stderr_array[fileno (child_process)], "r");
- if (child_stderr == NULL)
- printf (_("Could not open stderr for %s\n"), WHO_COMMAND);
- while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_process)) {
- /* increment 'users' on all lines except total user count */
- if (input_buffer[0] != '#') {
- users++;
- continue;
- }
- /* get total logged in users */
- if (sscanf (input_buffer, _("# users=%d"), &users) == 1)
- break;
- }
- /* check STDERR */
- if (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_stderr))
- result = possibly_set (result, STATE_UNKNOWN);
- (void) fclose (child_stderr);
- /* close the pipe */
- if (spclose (child_process))
- result = possibly_set (result, STATE_UNKNOWN);
- #endif
- /* check the user count against warning and critical thresholds */
- result = get_status((double)users, thlds);
- if (result == STATE_UNKNOWN)
- printf ("%s\n", _("Unable to read output"));
- else {
- printf (_("USERS %s - %d users currently logged in |%s\n"),
- state_text(result), users,
- sperfdata_int("users", users, "", warning_range,
- critical_range, TRUE, 0, FALSE, 0));
- }
- return result;
- }
- /* process command-line arguments */
- int
- process_arguments (int argc, char **argv)
- {
- int c;
- int option = 0;
- static struct option longopts[] = {
- {"critical", required_argument, 0, 'c'},
- {"warning", required_argument, 0, 'w'},
- {"version", no_argument, 0, 'V'},
- {"help", no_argument, 0, 'h'},
- {0, 0, 0, 0}
- };
- if (argc < 2)
- usage ("\n");
- while (1) {
- c = getopt_long (argc, argv, "+hVvc:w:", longopts, &option);
- if (c == -1 || c == EOF || c == 1)
- break;
- switch (c) {
- case '?': /* print short usage statement if args not parsable */
- usage5 ();
- case 'h': /* help */
- print_help ();
- exit (STATE_OK);
- case 'V': /* version */
- print_revision (progname, NP_VERSION);
- exit (STATE_OK);
- case 'c': /* critical */
- critical_range = optarg;
- break;
- case 'w': /* warning */
- warning_range = optarg;
- break;
- }
- }
- c = optind;
- if (warning_range == NULL && argc > c)
- warning_range = argv[c++];
- if (critical_range == NULL && argc > c)
- critical_range = argv[c++];
- /* this will abort in case of invalid ranges */
- set_thresholds (&thlds, warning_range, critical_range);
- if (!thlds->warning || thlds->warning->end < 0)
- usage4 (_("Warning threshold must be zero or greater"));
- if (!thlds->critical || thlds->critical->end < 0)
- usage4 (_("Critical threshold must be zero or greater"));
- return OK;
- }
- void
- print_help (void)
- {
- print_revision (progname, NP_VERSION);
- printf ("Copyright (c) 1999 Ethan Galstad\n");
- printf (COPYRIGHT, copyright, email);
- printf ("%s\n", _("This plugin checks the number of users currently logged in on the local"));
- printf ("%s\n", _("system and generates an error if the number exceeds the thresholds specified."));
- printf ("\n\n");
- print_usage ();
- printf (UT_HELP_VRSN);
- printf (UT_EXTRA_OPTS);
- printf (" %s\n", "-w, --warning=INTEGER");
- printf (" %s\n", _("Set WARNING status if more than INTEGER users are logged in"));
- printf (" %s\n", "-c, --critical=INTEGER");
- printf (" %s\n", _("Set CRITICAL status if more than INTEGER users are logged in"));
- printf (UT_SUPPORT);
- }
- void
- print_usage (void)
- {
- printf ("%s\n", _("Usage:"));
- printf ("%s -w <users> -c <users>\n", progname);
- }
|