6 sys.path.append("/opt/planetstack")
8 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "planetstack.settings")
9 from openstack.manager import OpenStackManager
10 from core.models import Slice, Sliver, ServiceClass, Reservation, Tag, Network, User, Node, Image, Deployment, Site, NetworkTemplate, NetworkSlice
12 def ps_id_to_pl_id(x):
13 # Since we don't want the PlanetStack object IDs to conflict with existing
14 # PlanetLab object IDs in the CMI, just add 100000 to the PlanetStack object
18 def pl_id_to_ps_id(x):
21 def filter_fields(src, fields):
23 for (key,value) in src.items():
24 if (not fields) or (key in fields):
28 def GetSlices(filter={}):
29 ps_slices = Slice.objects.filter(**filter)
31 for ps_slice in ps_slices:
33 for ps_sliver in ps_slice.slivers.all():
34 node_ids.append(ps_id_to_pl_id(ps_sliver.node.id))
36 slice = {"instantiation": "plc-instantiated",
37 "description": "planetstack slice",
38 "slice_id": ps_id_to_pl_id(ps_slice.id),
42 "peer_slice_id": None,
45 "site_id": ps_id_to_pl_id(ps_slice.site_id),
46 "name": ps_slice.name}
48 # creator_person_id, person_ids, expires, created
53 def GetNodes(node_ids, fields=None):
54 ps_nodes = Node.objects.filter(id__in=[pl_id_to_ps_id(nid) for nid in node_ids])
56 for ps_node in ps_nodes:
58 for ps_sliver in ps_node.slivers.all():
59 slice_ids.append(ps_id_to_pl_id(ps_sliver.slice.id))
61 node = {"node_id": ps_id_to_pl_id(ps_node.id),
62 "site_id": ps_id_to_pl_id(ps_node.site_id),
63 "node_type": "regular",
65 "hostname": ps_node.name,
67 "slice_ids": slice_ids,
68 "model": "planetstack",
72 # last_updated, key, boot_state, pcu_ids, node_type, session, last_boot,
73 # interface_ids, slice_ids_whitelist, run_level, ssh_rsa_key, last_pcu_reboot,
74 # nodegroup_ids, verified, last_contact, boot_nonce, version,
75 # last_pcu_configuration, last_download, date_created, ports
79 nodes = [filter_fields(node, fields) for node in nodes]
83 def GetTags(slicename,node_id):
87 ps_sites = Site.objects.all()
89 for ps_site in ps_sites:
91 for ps_slice in ps_site.slices.all():
92 slice_ids.append(ps_id_to_pl_id(ps_slice.id))
95 for ps_node in ps_site.nodes.all():
96 node_ids.append(ps_id_to_pl_id(ps_node.id))
99 site = {"site_id": ps_id_to_pl_id(ps_site.id),
100 "node_ids": node_ids,
105 "peer_site_id": None,
106 "abbrebiated_name": ps_site.abbreviated_name,
108 "name": ps_site.name,
112 "longitude": float(ps_site.location.longitude),
113 "latitude": float(ps_site.location.latitude),
114 "slice_ids": slice_ids,
115 "login_base": ps_site.login_base,
118 # last_updated, ext_consortium_id, person_ids, date_created
125 def GetConfiguration(name):
126 slicename = name["name"]
127 if "node_id" in name:
128 node_id = name["node_id"]
132 node_sliver_tags = GetTags(slicename, node_id)
134 slices = GetSlices({"name": slicename})
141 node_ids = slice['node_ids']
142 nodes = GetNodes(node_ids, ['hostname', 'node_id', 'site_id'])
145 nodemap[node['node_id']]=node['hostname']
150 sliver_tags = GetTags(slicename,nid)
151 perhost[nodemap[nid]] = sliver_tags
153 slivers = GetSlices()
155 slivers = [slice for slice in slivers if (node_id in slice.node_ids)]
159 site["site_tags"] = []
161 timestamp = int(time.time())
162 return {'version': 3,
163 'timestamp': timestamp,
164 'configuration': node_sliver_tags,
165 'allconfigurations':perhost,
166 'hostipmap':hostipmap,
168 'interfaces': allinterfaces,
172 if __name__ == '__main__':
173 print GetConfiguration({"name": "smbaker-coblitz"})