3 from django.db.models import F, Q
4 from planetstack.config import Config
5 from observer.openstacksyncstep import OpenStackSyncStep
6 from core.models.network import *
7 from util.logger import Logger, logging
9 logger = Logger(level=logging.INFO)
11 class SyncNetworks(OpenStackSyncStep):
13 requested_interval = 0
15 def fetch_pending(self):
16 return Network.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
18 def save_network(self, network):
19 if not network.network_id:
20 if network.template.sharedNetworkName:
21 network.network_id = network.template.sharedNetworkId
22 (network.subnet_id, network.subnet) = self.driver.get_network_subnet(network.network_id)
24 network_name = network.name
27 os_network = self.driver.create_network(network_name, shared=True)
28 network.network_id = os_network['id']
31 router = self.driver.create_router(network_name)
32 network.router_id = router['id']
35 next_subnet = self.get_next_subnet()
36 cidr = str(next_subnet.cidr)
37 ip_version = next_subnet.version
38 start = str(next_subnet[2])
39 end = str(next_subnet[-2])
40 subnet = self.driver.create_subnet(name=network_name,
41 network_id = network.network_id,
43 ip_version = ip_version,
47 network.subnet_id = subnet['id']
48 # add subnet as interface to slice's router
49 self.driver.add_router_interface(router['id'], subnet['id'])
51 self.driver.add_external_route(subnet)
53 def sync_record(self, network):
54 if network.owner and network.owner.creator:
56 # update manager context
57 real_driver = self.driver
58 self.driver = self.driver.client_driver(network.owner.creator, network.owner.name)
59 self.save_network(network)
60 self.driver = real_driver
61 logger.info("saved network: %s" % (network))
63 logger.log_exc("save network failed: %s" % network)