Core procedures
The following procedures are exported by core.
-  add_stat(type: string statname, type: integer value);
- 
Add value to the statistical counter using the current time. 
-  add_stat(type: string statname, type: integer value, type: datetime time);
- 
Add value to the statistical counter using the time specified in the argument named time. 
-  add_to_route(type: string routename);
- 
Copy the currently processed event data to the route specified. This procedure makes a copy of the data. The original will be processed normally. Note that flow control is explicitly disabled when moving data with add_to_route() and the data will not be added if the queue of the target module(s) is full. 
-  array_append(type: array dst_array, type: array src_array, type: integer src_index, type: integer src_num_elements);
- 
This procedure copies elements from src_array to the end of dst_array. The src_index specifies the first src_array element index and src_num_elements specifies the number of elements to copy. The size of dst_array will increase by src_num_elements at most. dst_array and src_array must both be arraytypes. The operation is not executed if src_index exceeds the src_array size or src_num_elements is 0.
-  array_push(type: array array_value, type: varargs value);
- 
Pushing the value(s) into the array_value after the highest index value. The size of the array_value will increase by the number of value arguments. If array_value is not an arraytype then no operation(s) will be carried out.
-  array_trim(type: array array_value);
- 
Removing the undefvalues from the end of the array_value container. The size of the array will decrease if such element(s) was(were) found at the end of the container. If array_value is not anarraytype then no operation(s) will be carried out.
-  create_stat(type: string statname, type: string type);
- 
Create a module statistical counter with the specified name using the current time. The statistical counter will be created with an infinite lifetime. The type argument must be one of the following to select the required algorithm for calculating the value of the statistical counter: COUNT,COUNTMIN,COUNTMAX,AVG,AVGMIN,AVGMAX,RATE,RATEMIN,RATEMAX,GRAD,GRADMIN, orGRADMAX(see Statistical counters).The interval parameter is optional for COUNTtype statistical counters. It is mandatory for all other types.This procedure will do nothing if a counter with the specified name already exists. 
-  create_stat(type: string statname, type: string type, type: integer interval);
- 
Create a module statistical counter with the specified name to be calculated over interval seconds and using the current time. The statistical counter will be created with an infinite lifetime. 
-  create_stat(type: string statname, type: string type, type: integer interval, type: datetime time);
- 
Create a module statistical counter with the specified name to be calculated over interval seconds and the time value specified in the time argument. The statistical counter will be created with an infinite lifetime. 
-  create_stat(type: string statname, type: string type, type: integer interval, type: datetime time, type: integer lifetime);
- 
Create a module statistical counter with the specified name to be calculated over interval seconds and the time value specified in the time argument. The statistical counter will expire after lifetime seconds. 
-  create_stat(type: string statname, type: string type, type: integer interval, type: datetime time, type: datetime expiry);
- 
Create a module statistical counter with the specified name to be calculated over interval seconds and the time value specified in the time argument. The statistical counter will expire at expiry. 
-  create_var(type: string varname);
- 
Create a module variable with the specified name. The variable will be created with an infinite lifetime. 
-  create_var(type: string varname, type: integer lifetime);
- 
Create a module variable with the specified name and the lifetime given in seconds. When the lifetime expires, the variable will be deleted automatically and get_var(name)will return undef.
-  create_var(type: string varname, type: datetime expiry);
- 
Create a module variable with the specified name. The expiry specifies when the variable should be deleted automatically. 
-  debug(type: unknown arg, type: varargs args);
- 
Print the argument(s) with DEBUGlog level. This procedure is the same as log_debug().
-  delete(type: unknown arg);
- 
Delete a field or a module variable from the event. For example, delete($field)ordelete(variable)`. Note that `$field = undef` or `variable = undefis not the same, though after both operations the field or the module variable will be undefined. If the argument is an expression which is not purely a field ($field) or a module variable ($$variable) then the expression will be evaluated and that value will be treated as a name of the field to be deleted. If the expression yields a non-string type value then an error message will be issued.
- delete(type: string arg);
- 
Delete the field from the event. For example, delete("field").
-  delete_all();
- 
Delete all of the fields from the event except raw_eventfield.
-  delete_stat(type: string statname);
- 
Delete a module statistical counter with the specified name. This procedure will do nothing if a counter with the specified name does not exist (e.g. was already deleted). 
-  delete_var(type: string varname);
- 
Delete the module variable with the specified name if it exists. 
-  drop();
- 
Drop the event record that is currently being processed. Any further action on the event record will result in a "missing record" error. 
-  duplicate_guard();
- 
Guard against event duplication. 
-  hash_remove(type: hash hash_value, type: varargs key);
- 
Removing the keys(s) from the hash_value. The size of the hash_value will increase by the number of key arguments. To perform this operation, the key argument(s) must be of string type. If hash_value is not a hashtype then no operation(s) will be carried out.
-  log_debug(type: unknown arg, type: varargs args);
- 
Print the argument(s) with DEBUGlog level. This procedure is the same as debug(). Messages longer than LogSizeLimit will be truncated.
 Any combination of new-line characters is replaced with a semicolon (;) by default. This behavior can be changed with the LogExpandNonPrintable global setting.
-  log_error(type: unknown arg, type: varargs args);
- 
Print the argument(s) with ERRORlog level. Messages longer than LogSizeLimit will be truncated.
 Any combination of new-line characters is replaced with a semicolon (;) by default. This behavior can be changed with the LogExpandNonPrintable global setting.
-  log_info(type: unknown arg, type: varargs args);
- 
Print the argument(s) with INFOlog level. Messages longer than LogSizeLimit will be truncated.
 Any combination of new-line characters is replaced with a semicolon (;) by default. This behavior can be changed with the LogExpandNonPrintable global setting.
-  log_warning(type: unknown arg, type: varargs args);
- 
Print the argument(s) with WARNINGlog level. Messages longer than LogSizeLimit will be truncated.
 Any combination of new-line characters is replaced with a semicolon (;) by default. This behavior can be changed with the LogExpandNonPrintable global setting.
-  module_restart();
- 
Issue module_stopand then amodule_startevents for the calling module. Cross-module calls are supported:other_module→module_restart().
-  module_start();
- 
Issue a module_startevent for the calling module. Cross-module calls are supported:other_module→module_start().
-  module_stop();
- 
Issue a module_stopevent for the calling module. Cross-module calls are supported:other_module→module_stop().
-  rename_field(type: unknown old, type: unknown new);
- 
Rename a field. For example, rename_field($old, $new).
-  rename_field(type: string old, type: string new);
- 
Rename a field. For example, rename_field("old", "new").
-  reroute(type: string routename);
- 
Move the currently processed event data to the route specified. The event data will enter the route as if it was received by an input module there. Note that flow control is explicitly disabled when moving data with reroute() and the data will be dropped if the queue of the target module(s) is full. 
-  set_var(type: string varname, type: unknown value);
- 
Set the value of a module variable. If the variable does not exist, it will be created with an infinite lifetime. 
-  sleep(type: integer interval);
- 
Sleep the specified number of microseconds. This procedure is provided for testing purposes primarily. It can be used as a poor man’s rate limiting tool, though this use is not recommended. 
