mirror of
https://github.com/ntop/ntopng.git
synced 2026-05-05 19:15:03 +00:00
Add v1/get/alert/ts.lua REST API (implement #3943
This commit is contained in:
parent
09ea665c9b
commit
21fe9aa490
2 changed files with 123 additions and 0 deletions
106
scripts/lua/rest/v1/get/alert/ts.lua
Normal file
106
scripts/lua/rest/v1/get/alert/ts.lua
Normal file
|
|
@ -0,0 +1,106 @@
|
|||
--
|
||||
-- (C) 2013-20 - ntop.org
|
||||
--
|
||||
|
||||
dirs = ntop.getDirs()
|
||||
package.path = dirs.installdir .. "/scripts/lua/modules/?.lua;" .. package.path
|
||||
|
||||
require "lua_utils"
|
||||
local alert_utils = require "alert_utils"
|
||||
require "flow_utils"
|
||||
local alert_consts = require "alert_consts"
|
||||
local format_utils = require "format_utils"
|
||||
local json = require "dkjson"
|
||||
local rest_utils = require("rest_utils")
|
||||
|
||||
--
|
||||
-- Read alerts data as timeseries (number of alerts per hour)
|
||||
-- Example: curl -u admin:admin -d '{"ifid": "6", "status": "historical-flows", "epoch_begin": 1590226522, "epoch_end": 1590485722}' http://localhost:3000/lua/rest/v1/get/alert/ts.lua
|
||||
--
|
||||
-- NOTE: in case of invalid login, no error is returned but redirected to login
|
||||
--
|
||||
|
||||
sendHTTPHeader('application/json')
|
||||
|
||||
local rc = rest_utils.consts_ok
|
||||
local res = {}
|
||||
|
||||
local ifid = _GET["ifid"]
|
||||
local what = _GET["status"] -- historical, historical-flows
|
||||
local epoch_begin = _GET["epoch_begin"]
|
||||
local epoch_end = _GET["epoch_end"]
|
||||
local alert_type = _GET["alert_type"]
|
||||
local alert_severity = _GET["alert_severity"]
|
||||
|
||||
if isEmptyString(ifid) then
|
||||
rc = rest_utils.consts_invalid_interface
|
||||
print(rest_utils.rc(rc))
|
||||
return
|
||||
end
|
||||
|
||||
interface.select(ifid)
|
||||
|
||||
if isEmptyString(what) then
|
||||
rc = rest_utils.consts_invalid_args
|
||||
print(rest_utils.rc(rc))
|
||||
return
|
||||
end
|
||||
|
||||
if isEmptyString(epoch_begin) or isEmptyString(epoch_end) then
|
||||
rc = rest_utils.consts_invalid_args
|
||||
print(rest_utils.rc(rc))
|
||||
return
|
||||
end
|
||||
|
||||
epoch_begin = tonumber(epoch_begin);
|
||||
epoch_end = tonumber(epoch_end);
|
||||
|
||||
if epoch_end <= epoch_begin then
|
||||
rc = rest_utils.consts_invalid_args
|
||||
print(rest_utils.rc(rc))
|
||||
return
|
||||
end
|
||||
|
||||
local hour_secs = 60*60
|
||||
local day_secs = 60*60*24
|
||||
|
||||
-- Round begin to start of day
|
||||
epoch_begin = epoch_begin - (epoch_begin % day_secs)
|
||||
|
||||
-- Round end to end of day
|
||||
epoch_end = epoch_end - (epoch_end % day_secs) + day_secs
|
||||
|
||||
local days = (epoch_end - epoch_begin) / day_secs
|
||||
|
||||
local engaged = false
|
||||
if what == "engaged" then
|
||||
engaged = true
|
||||
end
|
||||
|
||||
local counters = alert_utils.getNumAlertsPerHour(what, epoch_begin, epoch_end, alert_type, alert_severity)
|
||||
|
||||
if counters == nil then
|
||||
rc = rest_utils.consts_internal_error
|
||||
print(rest_utils.rc(rc))
|
||||
return
|
||||
end
|
||||
|
||||
res.data = {}
|
||||
for day=1,days do
|
||||
local day_epoch = epoch_begin + (day * day_secs)
|
||||
res.data[day_epoch] = {}
|
||||
for hour=1,24 do
|
||||
res.data[day_epoch][hour] = 0
|
||||
end
|
||||
end
|
||||
|
||||
local curr_epoch = epoch_begin
|
||||
|
||||
for k,v in ipairs(counters) do
|
||||
local day_epoch = v.hour - (v.hour % day_secs)
|
||||
local hour = (v.hour - day_epoch) / hour_secs
|
||||
res.data[day_epoch][hour] = v.count
|
||||
end -- for
|
||||
|
||||
print(rest_utils.rc(rc, res))
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue