Source
if (1 == invalid_user) /* handle 0 for non-existent user after all parameters have been parsed and validated */
/*
** Zabbix
** Copyright (C) 2001-2022 Zabbix SIA
**
** 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 2 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, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
static int check_procstate(struct procentry64 *procentry, int zbx_proc_stat)
{
if (ZBX_PROC_STAT_ALL == zbx_proc_stat)
return SUCCEED;
switch (zbx_proc_stat)
{
case ZBX_PROC_STAT_RUN:
return SACTIVE == procentry->pi_state && 0 != procentry->pi_cpu ? SUCCEED : FAIL;
case ZBX_PROC_STAT_SLEEP:
return SACTIVE == procentry->pi_state && 0 == procentry->pi_cpu ? SUCCEED : FAIL;
case ZBX_PROC_STAT_ZOMB:
return SZOMB == procentry->pi_state ? SUCCEED : FAIL;
}
return FAIL;
}
static int check_procargs(struct procentry64 *procentry, const char *proccomm)
{
int i;
char procargs[MAX_BUFFER_LEN];
if (0 != getargs(procentry, (int)sizeof(*procentry), procargs, (int)sizeof(procargs)))
return FAIL;
for (i = 0; i < sizeof(procargs) - 1; i++)
{
if ('\0' == procargs[i])
{
if ('\0' == procargs[i + 1])
break;
procargs[i] = ' ';
}
}
if (i == sizeof(procargs) - 1)
procargs[i] = '\0';