/* ** Zabbix ** Copyright (C) 2001-2023 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. **/ #include "evalfunc_common.h" #include "log.h" #include "zbxtrends.h" #include "zbxnum.h" #include "zbxexpr.h" const char *zbx_type_string(zbx_value_type_t type) { switch (type) { case ZBX_VALUE_NONE: return "none"; case ZBX_VALUE_SECONDS: return "sec"; case ZBX_VALUE_NVALUES: return "num"; default: THIS_SHOULD_NEVER_HAPPEN; return "unknown"; } } int get_function_parameter_uint64(const char *parameters, int Nparam, zbx_uint64_t *value) { char *parameter; int ret = FAIL; zabbix_log(LOG_LEVEL_DEBUG, "In %s() parameters:'%s' Nparam:%d", __func__, parameters, Nparam); if (NULL == (parameter = zbx_function_get_param_dyn(parameters, Nparam))) goto out; if (SUCCEED == (ret = zbx_is_uint64(parameter, value))) zabbix_log(LOG_LEVEL_DEBUG, "%s() value:" ZBX_FS_UI64, __func__, *value); zbx_free(parameter); out: zabbix_log(LOG_LEVEL_DEBUG, "End of %s():%s", __func__, zbx_result_string(ret)); return ret; } int get_function_parameter_float(const char *parameters, int Nparam, unsigned char flags, double *value) { char *parameter; int ret = FAIL; zabbix_log(LOG_LEVEL_DEBUG, "In %s() parameters:'%s' Nparam:%d", __func__, parameters, Nparam); if (NULL == (parameter = zbx_function_get_param_dyn(parameters, Nparam))) goto out; if (SUCCEED == (ret = zbx_is_double_suffix(parameter, flags))) { *value = zbx_str2double(parameter); zabbix_log(LOG_LEVEL_DEBUG, "%s() value:" ZBX_FS_DBL, __func__, *value); } zbx_free(parameter); out: zabbix_log(LOG_LEVEL_DEBUG, "End of %s():%s", __func__, zbx_result_string(ret)); return ret; } int get_function_parameter_str(const char *parameters, int Nparam, char **value) { int ret = FAIL; zabbix_log(LOG_LEVEL_DEBUG, "In %s() parameters:'%s' Nparam:%d", __func__, parameters, Nparam); if (NULL == (*value = zbx_function_get_param_dyn(parameters, Nparam))) goto out; zabbix_log(LOG_LEVEL_DEBUG, "%s() value:'%s'", __func__, *value); ret = SUCCEED; out: zabbix_log(LOG_LEVEL_DEBUG, "End of %s():%s", __func__, zbx_result_string(ret)); return ret; } /****************************************************************************** * * * Purpose: get the value of sec|num + timeshift trigger function parameter * * * * Parameters: from - [IN] the function calculation time * * parameters - [IN] trigger function parameters * * Nparam - [IN] specifies which parameter to extract * * value - [OUT] parameter value (preserved as is if the * * parameter is optional and empty) * * type - [OUT] parameter value type (number of seconds * * or number of values) * * timeshift - [OUT] the timeshift value (0 if absent) * * * * Return value: SUCCEED - parameter is valid * * FAIL - otherwise * * * ******************************************************************************/ int get_function_parameter_hist_range(int from, const char *parameters, int Nparam, int *value, zbx_value_type_t *type, int *timeshift) { char *parameter = NULL, *shift; int ret = FAIL; zabbix_log(LOG_LEVEL_DEBUG, "In %s() parameters:'%s' Nparam:%d", __func__, parameters, Nparam); if (NULL == (parameter = zbx_function_get_param_dyn(parameters, Nparam))) goto out; if (NULL != (shift = strchr(parameter, ':'))) *shift++ = '\0'; if ('\0' == *parameter) { *value = 0; *type = ZBX_VALUE_NONE; } else if ('#' != *parameter) { if (SUCCEED != zbx_is_time_suffix(parameter, value, ZBX_LENGTH_UNLIMITED) || 0 > *value) goto out; *type = ZBX_VALUE_SECONDS; } else { if (SUCCEED != zbx_is_uint31(parameter + 1, value) || 0 >= *value) goto out; *type = ZBX_VALUE_NVALUES; } if (NULL != shift) { struct tm tm; char *error = NULL; int end; if (SUCCEED != zbx_trends_parse_timeshift(from, shift, &tm, &error)) { zabbix_log(LOG_LEVEL_DEBUG, "%s() timeshift error:%s", __func__, error); zbx_free(error); goto out; } if (-1 == (end = (int)mktime(&tm))) { zabbix_log(LOG_LEVEL_DEBUG, "%s() invalid timeshift value:%s", __func__, zbx_strerror(errno)); goto out; } *timeshift = from - end; } else *timeshift = 0; ret = SUCCEED; zabbix_log(LOG_LEVEL_DEBUG, "%s() type:%s value:%d timeshift:%d", __func__, zbx_type_string(*type), *value, *timeshift); out: zbx_free(parameter); zabbix_log(LOG_LEVEL_DEBUG, "End of %s():%s", __func__, zbx_result_string(ret)); return ret; }