zabbix_log(LOG_LEVEL_DEBUG, "End of %s():%s %s", __func__, zbx_result_string(ret), ZBX_NULL2EMPTY_STR(*error));
#include "zbxembed.h"
#include "embed_xml.h"
#include "embed.h"
#include "log.h"
#include "httprequest.h"
#include "zabbix.h"
#include "global.h"
#include "console.h"
#include "zbxstr.h"
#define ZBX_ES_MEMORY_LIMIT (1024 * 1024 * 64)
#define ZBX_ES_STACK_LIMIT 1000
#define ZBX_ES_MAX_CONSEQUENT_RT_ERROR 3
#define ZBX_ES_SCRIPT_HEADER "function(value){"
#define ZBX_ES_SCRIPT_FOOTER "\n}"
static void es_handle_error(void *udata, const char *msg)
{
zbx_es_env_t *env = (zbx_es_env_t *)udata;
zabbix_log(LOG_LEVEL_WARNING, "Cannot process javascript, fatal error: %s", msg);
env->fatal_error = 1;
env->error = zbx_strdup(env->error, msg);
longjmp(env->loc, 1);
}
static void *es_malloc(void *udata, duk_size_t size)
{
zbx_es_env_t *env = (zbx_es_env_t *)udata;
uint64_t *uptr;
if (env->total_alloc + size + 8 > ZBX_ES_MEMORY_LIMIT)
{
if (NULL == env->ctx)
env->error = zbx_strdup(env->error, "cannot allocate memory");
return NULL;
}
env->total_alloc += (size + 8);
uptr = zbx_malloc(NULL, size + 8);
*uptr++ = size;
return uptr;
}
static void *es_realloc(void *udata, void *ptr, duk_size_t size)
{
zbx_es_env_t *env = (zbx_es_env_t *)udata;
uint64_t *uptr = ptr;
size_t old_size;
if (NULL != uptr)
{
--uptr;
old_size = *uptr + 8;
}
else