ntopng/scripts/lua/modules/alert_definitions/flow/alert_host_policy.lua
2024-12-23 21:01:01 +01:00

63 lines
1.9 KiB
Lua

--
-- (C) 2019-24 - ntop.org
--
-- ##############################################
local flow_alert_keys = require "flow_alert_keys"
-- Import the classes library.
local classes = require "classes"
-- Make sure to import the Superclass!
local alert = require "alert"
local json = require "dkjson"
-- Import Mitre Att&ck utils
local mitre = require "mitre_utils"
-- ##############################################
local flow_alert_host_policy = classes.class(alert)
-- ##############################################
flow_alert_host_policy.meta = {
alert_key = flow_alert_keys.flow_alert_host_policy,
icon = "fas fa-fw fa-exclamation",
i18n_title = "alerts_dashboard.host_policy",
}
-- ##############################################
-- @brief Prepare an alert table used to generate the alert
-- @return A table with the alert built
function flow_alert_host_policy:init()
-- Call the parent constructor
self.super:init()
end
-- #######################################################
-- @brief Format an alert into a human-readable string
-- @param ifid The integer interface id of the generated alert
-- @param alert The alert description table, including alert data such as the generating entity, timestamp, granularity, type
-- @param alert_type_params Table `alert_type_params` as built in the `:init` method
-- @return A human-readable string
function flow_alert_host_policy.format(ifid, alert, alert_type_params)
-- Extracting info field
local href = ntop.getHttpPrefix() .. '/lua/admin/network_configuration.lua?page=policy'
local key
local reason = alert_type_params.reason
if(reason == nil) then
key = tostring(flow_alert_keys.flow_alert_host_policy)
reason = alert_type_params.alerts[key].reason
end
key = "alerts_dashboard.alert_host_policy_descr_"..reason
return(i18n(key, { href = href }))
end
-- #######################################################
return flow_alert_host_policy