blob: 656ae6844d5dd26a0cd179158242b680a988e91a [file] [log] [blame]
Sapan Bhatia24836f12013-08-27 10:16:05 -04001import os
2import base64
3from planetstack.config import Config
Sapan Bhatia04c94ad2013-09-02 18:00:28 -04004from observer.openstacksyncstep import OpenStackSyncStep
5from core.models.network import *
Sapan Bhatia24836f12013-08-27 10:16:05 -04006
7class SyncNetworks(OpenStackSyncStep):
Tony Mackce79de02013-09-24 10:12:33 -04008 provides=[Network]
9 requested_interval = 0
Sapan Bhatia24836f12013-08-27 10:16:05 -040010
Tony Mackce79de02013-09-24 10:12:33 -040011 def save_network(self, network):
12 if not network.network_id:
13 if network.template.sharedNetworkName:
14 network.network_id = network.template.sharedNetworkId
15 (network.subnet_id, network.subnet) = self.driver.get_network_subnet(network.network_id)
16 else:
17 network_name = network.name
Sapan Bhatia24836f12013-08-27 10:16:05 -040018
Tony Mackce79de02013-09-24 10:12:33 -040019 # create network
20 os_network = self.driver.create_network(network_name, shared=True)
21 network.network_id = os_network['id']
Sapan Bhatia24836f12013-08-27 10:16:05 -040022
Tony Mackce79de02013-09-24 10:12:33 -040023 # create router
24 router = self.driver.create_router(network_name)
25 network.router_id = router['id']
Sapan Bhatia24836f12013-08-27 10:16:05 -040026
Tony Mackce79de02013-09-24 10:12:33 -040027 # create subnet
28 next_subnet = self.get_next_subnet()
29 cidr = str(next_subnet.cidr)
30 ip_version = next_subnet.version
31 start = str(next_subnet[2])
32 end = str(next_subnet[-2])
33 subnet = self.driver.create_subnet(name=network_name,
34 network_id = network.network_id,
35 cidr_ip = cidr,
36 ip_version = ip_version,
37 start = start,
38 end = end)
39 network.subnet = cidr
40 network.subnet_id = subnet['id']
Tony Mack387a73f2013-09-18 07:59:14 -040041 # add subnet as interface to slice's router
42 self.driver.add_router_interface(router['id'], subnet['id'])
43 # add external route
44 self.driver.add_external_route(subnet)
Sapan Bhatia24836f12013-08-27 10:16:05 -040045
Tony Mackce79de02013-09-24 10:12:33 -040046 def sync_record(self, site):
47 if network.owner and network.owner.creator:
48 try:
49 # update manager context
Tony Mack387a73f2013-09-18 07:59:14 -040050 real_driver = self.driver
51 self.driver = self.driver.client_driver(network.owner.creator, network.owner.name)
Tony Mackce79de02013-09-24 10:12:33 -040052 self.save_network(network)
Tony Mack387a73f2013-09-18 07:59:14 -040053 self.driver = real_driver
Tony Mackce79de02013-09-24 10:12:33 -040054 logger.info("saved network: %s" % (network))
55 except Exception,e:
56 logger.log_exc("save network failed: %s" % network)
57 raise e
Sapan Bhatia24836f12013-08-27 10:16:05 -040058