d83e8d38025e51826c7997fdcd0eefe3de5ee123
[monitor.git] / syncplcdb.py
1 #!/usr/bin/python
2
3 import plc
4 from config import config
5 import soltesz
6 import sys
7
8 config = config()
9
10 def dsites_from_lsites(l_sites):
11         d_sites = {}
12         id2lb = {}
13         for site in l_sites:
14                 if not site['login_base'] in d_sites:
15                         d_sites[site['login_base']] = site
16                         id2lb[site['site_id']] = site['login_base']
17                 else:
18                         #print "Two sites have the same login_base value %s!" % site['login_base']
19                         sys.exit(1)
20         return (d_sites, id2lb)
21
22 def dsn_from_dsln(d_sites, id2lb, l_nodes):
23         lb2hn = {}
24         dsn = {}
25         hn2lb = {}
26         for node in l_nodes:
27                 # this won't reach sites without nodes, which I guess isn't a problem.
28                 if node['site_id'] in id2lb.keys():
29                         login_base = id2lb[node['site_id']]
30                 else:
31                         for i in id2lb:
32                                 print i, " ", id2lb[i]
33                         raise Exception, "Node has missing site id!! %s %d" %(node['hostname'], node['site_id'])
34                 if not login_base in dsn:
35                         lb2hn[login_base] = []
36                         dsn[login_base] = {}
37                         dsn[login_base]['plc'] = d_sites[login_base]
38                         dsn[login_base]['monitor'] = {} # event log, or something
39
40                 hostname = node['hostname']
41                 lb2hn[login_base].append(node)
42                 dsn[login_base][hostname] = {}
43                 dsn[login_base][hostname]['plc'] = node
44                 dsn[login_base][hostname]['comon'] = {}
45                 dsn[login_base][hostname]['monitor'] = {}
46
47                 hn2lb[hostname] = login_base
48         return (dsn, hn2lb, lb2hn)
49
50 def create_netid2ip(l_nodes, l_nodenetworks):
51         netid2ip = {}
52         for node in l_nodes:
53                 for netid in node['nodenetwork_ids']:
54                         found = False
55                         for nn in l_nodenetworks:
56                                 if nn['nodenetwork_id'] == netid:
57                                         found = True
58                                         netid2ip[netid] = nn['ip']
59                         if not found:
60                                 print "ERROR! %s" % node
61
62         return netid2ip
63
64 def create_plcdb():
65
66         # get sites, and stats
67         l_sites = plc.getSites({'peer_id':None}, ['login_base', 'site_id', 'abbreviated_name', 'latitude', 'longitude', 
68                                                                                           'max_slices', 'slice_ids', 'node_ids' ])
69         if len(l_sites) == 0:
70                 sys.exit(1)
71         (d_sites,id2lb) = dsites_from_lsites(l_sites)
72
73         # get nodes at each site, and 
74         l_nodes = plc.getNodes({'peer_id':None}, ['hostname', 'node_id', 'ports', 'site_id', 'version', 
75                                                   'last_updated', 'date_created', 'last_contact', 'pcu_ids', 'nodenetwork_ids'])
76
77         l_nodenetworks = plc.getNodeNetworks()
78         (plcdb, hn2lb, lb2hn) = dsn_from_dsln(d_sites, id2lb, l_nodes)
79         netid2ip = create_netid2ip(l_nodes, l_nodenetworks)
80
81         # save information for future.
82         id2lb = id2lb
83         hn2lb = hn2lb
84         db = plcdb
85
86         if ('cachenodes' in dir(config) and config.cachenodes) or \
87                 'cachenodes' not in dir(config):
88                 soltesz.dbDump("plcdb_hn2lb", hn2lb)
89                 soltesz.dbDump("plcdb_lb2hn", lb2hn)
90                 soltesz.dbDump("plcdb_netid2ip", netid2ip)
91                 soltesz.dbDump("l_plcnodenetworks", l_nodenetworks)
92                 soltesz.dbDump("l_plcnodes", l_nodes)
93                 soltesz.dbDump("l_plcsites", l_sites)
94         
95         return l_nodes
96         
97
98 if __name__ == '__main__':
99         create_plcdb()