File: active_monitoring_pools.lua

package info (click to toggle)
ntopng 5.2.1%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 121,832 kB
  • sloc: javascript: 143,431; cpp: 71,175; ansic: 11,108; sh: 4,687; makefile: 911; python: 587; sql: 512; pascal: 234; perl: 118; ruby: 52; exp: 4
file content (62 lines) | stat: -rw-r--r-- 1,821 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
--
-- (C) 2017-22 - ntop.org
--

local dirs = ntop.getDirs()
package.path = dirs.installdir .. "/scripts/lua/modules/pools/?.lua;" .. package.path

require "lua_utils" -- needed by am_utils
local plugins_utils = require "plugins_utils"
local am_utils = require "am_utils"
local pools = require "pools"

local active_monitoring_pools = {}

-- ##############################################

function active_monitoring_pools:create()
   -- Instance of the base class
   local _active_monitoring_pools = pools:create()

   -- Subclass using the base class instance
   self.key = "active_monitoring"
   -- self is passed as argument so it will be set as base class metatable
   -- and this will actually make it possible to override functions
   local _active_monitoring_pools_instance = _active_monitoring_pools:create(self)

   -- Return the instance
   return _active_monitoring_pools_instance
end

-- ##############################################

-- @brief Given a member key, returns a table of member details such as member name.
function active_monitoring_pools:get_member_details(member)
   local name = member
   local am_host = am_utils.key2host(member)

   if am_host and am_host["label"] then
      name = am_host["label"]
   end

   return {name = name}
end

-- ##############################################

-- @brief Returns a table of all possible active_monitoring ids, both assigned and unassigned to pool members
function active_monitoring_pools:get_all_members()
   local res = {}

   local am_hosts = am_utils.getHosts()
   for key, _ in pairs(am_hosts) do
      -- The key is the member id itself, which in this case is the active_monitoring id
      res[key] = self:get_member_details(key)
   end

   return res
end

-- ##############################################

return active_monitoring_pools