4 from monitor.wrapper import plc
5 from monitor import database
6 from monitor import config
8 def dsites_from_lsites(l_sites):
12 if not site['login_base'] in d_sites:
13 d_sites[site['login_base']] = site
14 id2lb[site['site_id']] = site['login_base']
16 #print "Two sites have the same login_base value %s!" % site['login_base']
18 return (d_sites, id2lb)
20 def dsn_from_dsln(d_sites, id2lb, l_nodes):
25 # this won't reach sites without nodes, which I guess isn't a problem.
26 if node['site_id'] in id2lb.keys():
27 login_base = id2lb[node['site_id']]
29 print "%s has a foreign site_id %s" % (node['hostname'],
33 print i, " ", id2lb[i]
34 raise Exception, "Node has missing site id!! %s %d" %(node['hostname'], node['site_id'])
35 if not login_base in dsn:
36 lb2hn[login_base] = []
38 dsn[login_base]['plc'] = d_sites[login_base]
39 dsn[login_base]['monitor'] = {} # event log, or something
41 hostname = node['hostname']
42 lb2hn[login_base].append(node)
43 dsn[login_base][hostname] = {}
44 dsn[login_base][hostname]['plc'] = node
45 dsn[login_base][hostname]['comon'] = {}
46 dsn[login_base][hostname]['monitor'] = {}
48 hn2lb[hostname] = login_base
49 return (dsn, hn2lb, lb2hn)
51 def create_netid2ip(l_nodes, l_nodenetworks):
54 for netid in node['nodenetwork_ids']:
56 for nn in l_nodenetworks:
57 if nn['nodenetwork_id'] == netid:
59 netid2ip[netid] = nn['ip']
61 print "ERROR! %s" % node
83 api = plc.getCachedAuthAPI()
84 l_sites = api.GetSites({'peer_id':None},
85 ['login_base', 'site_id', 'abbreviated_name', 'latitude',
86 'longitude', 'max_slices', 'slice_ids', 'node_ids' ])
87 l_nodes = api.GetNodes({'peer_id':None},
88 ['hostname', 'node_id', 'ports', 'site_id', 'version', 'last_updated',
89 'date_created', 'last_contact', 'pcu_ids', 'nodenetwork_ids'])
90 l_pcus = api.GetPCUs()
91 l_nodenetworks = api.GetNodeNetworks()
93 (d_sites,id2lb) = dsites_from_lsites(l_sites)
94 (plcdb, hn2lb, lb2hn) = dsn_from_dsln(d_sites, id2lb, l_nodes)
95 netid2ip = create_netid2ip(l_nodes, l_nodenetworks)
99 plcdb_netid2ip = netid2ip
106 # get sites, and stats
107 l_sites = plc.getSites({'peer_id':None}, ['login_base', 'site_id', 'abbreviated_name', 'latitude', 'longitude',
108 'max_slices', 'slice_ids', 'node_ids' ])
109 if len(l_sites) == 0:
111 (d_sites,id2lb) = dsites_from_lsites(l_sites)
113 # get nodes at each site, and
114 l_nodes = plc.getNodes({'peer_id':None}, ['hostname', 'node_id', 'ports', 'site_id', 'version',
115 'last_updated', 'date_created', 'last_contact', 'pcu_ids', 'nodenetwork_ids'])
117 l_nodenetworks = plc.getNodeNetworks()
118 (plcdb, hn2lb, lb2hn) = dsn_from_dsln(d_sites, id2lb, l_nodes)
119 netid2ip = create_netid2ip(l_nodes, l_nodenetworks)
121 # save information for future.
126 if ('cachenodes' in dir(config) and config.cachenodes) or \
127 'cachenodes' not in dir(config):
128 database.dbDump("plcdb_hn2lb", hn2lb)
129 database.dbDump("plcdb_lb2hn", lb2hn)
130 database.dbDump("plcdb_netid2ip", netid2ip)
131 database.dbDump("l_plcnodenetworks", l_nodenetworks)
132 database.dbDump("l_plcnodes", l_nodes)
133 database.dbDump("l_plcsites", l_sites)
137 if __name__ == '__main__':
140 print "calling plccache init()"