.. _Checks: Checks ============ Checks are the core of scripts. They actually allow certain actions to be performed periodically, or when a certain event occurs. The logic of a script is contained in its users scripts. A script contains zero to many checks. Structure --------- The structure of a check is the following: .. code:: lua local checks = require("checks") -- ################################################################# local script = { hooks = {}, -- other script attributes ... } -- ################################################################# function script.setup() -- return false to disable the script return true end -- ################################################################# return(script) Every check must return a Lua table with the following keys: - :code:`hooks`: a Lua table with hook names as key and checks as values. :ref:`Check Hooks` are events or points in time. ntopng uses hooks to know when to call a check. A check defining a hook will get the hook callaback called by ntopng. Checks must register to at least one hook. See :ref:`Check Hooks`. - :code:`gui`: a Lua table specifying check name, description and configuration. Data is used by ntopng to show the check configurable from the :ref:`Web GUI`. - :code:`packet_interface_only` (optional): only execute the script on packet interfaces, excluding ZMQ interfaces. - :code:`nedge_only` (optional): if true, the script is only executed in nEdge. - :code:`nedge_exclude` (optional): if true, the script is not executed in nEdge. - :code:`default_value` (optional): the default value for the script configuration, in the form :code:`;;` (e.g. :code:`syn_flood_victim;gt;50`). See :ref:`Web GUI`. - :code:`default_enabled` (optional): if false, the script is disabled by default. Furthermore, a script may define the following extra functions, which are only called once per script: - :code:`setup()`: called once per check. If it returns :code:`false` then the script is considered disabled and its hooks are not be called. - :code:`teardown()`: called after the script operation is complete (e.g. after all the hosts have been iterated and hooks called). .. _Flow Checks: Flow and Host Checks -------------------- Flow and Host checks are currently executed in the core engine by means of C++ checks. Flow checks have access to flow information such as L4 and L7 protocols, peers involved in the communication, and other things. Similarly Host checks have access to all the host information available in the engine. Please read the `Developing Alerts`_ section for instructions about the implementation of C++ checks. .. _`Developing Alerts`: ../developing_alerts/developing_alerts.html ntopng supports users scripts (Lua) for the following traffic elements: - :code:`interface`: a network interface of ntopng. Check out the `Interface Checks API`_. - :code:`network`: a local network of ntopng. Check out the `Network Checks API`_. - :code:`system`: the system on top of which is running ntopng - :code:`SNMP interfaces`: interfaces of monitored SNMP devices Refer to :ref:`Check Hooks` for available hooks. .. _`Interface Checks API`: ../api/lua_c/interface_checks/index.html .. _`Network Checks API`: ../api/lua_c/network_checks/index.html Syslog Checks ------------------- Syslog scripts are used to handle syslog events and ingest data, including flows and alerts, from external sources (e.g. alerts from Intrusion Detection Systems). Scripts Location ~~~~~~~~~~~~~~~~ Syslog scripts are located under :code:`/usr/share/ntopng/scripts/callbacks/system/syslog` and should use the source name (e.g. application name) with the :code:`.lua` extension as file name. In fact messages demultiplexing is implemented by using the source name for matching the script name. For example, log messages coming from :code:`suricata` will be delivered to the :code:`/usr/share/ntopng/scripts/checks/syslog/suricata.lua` script. Script API ~~~~~~~~~~ A syslog module shoule implement the below functions: - :code:`setup` (optional) which is called once to initialize the module. - :code:`teardown` (optional) which is called once to terminate the module. - :code:`hooks.handleEvent` which is called for each log message matching the module. Script Example ~~~~~~~~~~~~~~ Here is a sample script :code:`suricata.lua` processing log messages from Suricata, exported to syslog in Eve JSON format. .. code:: lua local dirs = ntop.getDirs() package.path = dirs.installdir .. "/scripts/lua/modules/?.lua;" .. package.path require "lua_utils" local json = require ("dkjson") local syslog_module = { hooks = {}, } -- The function below is called once to initialize the script function syslog_module.setup() return true end -- The function below is called for each log message received from Suricata function syslog_module.hooks.handleEvent(message) local alert = json.decode(message) tprint(alert) end -- The function below is called once to terminate the script function syslog_module.teardown() return true end return syslog_module