X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fopenstack%2Fobserver.py;h=b59530e4bec79a9b997f664b83887e8cffc992bf;hb=e3f8d8609e0b6ce9d788604aadbc4d4dd94bf031;hp=44908ab6ee3ce1d7b70a00269c68226a003fb2a2;hpb=aa8ad5ffd286f959f11c602815887912cc208739;p=plstackapi.git diff --git a/planetstack/openstack/observer.py b/planetstack/openstack/observer.py index 44908ab..b59530e 100644 --- a/planetstack/openstack/observer.py +++ b/planetstack/openstack/observer.py @@ -1,5 +1,6 @@ import time import traceback +import commands from datetime import datetime from collections import defaultdict from core.models import * @@ -26,7 +27,8 @@ class OpenStackObserver: self.sync_user_tenant_roles() self.sync_slivers() self.sync_sliver_ips() - time.sleep(7) + self.sync_external_routes() + time.sleep(10) except: traceback.print_exc() @@ -226,12 +228,12 @@ class OpenStackObserver: # get all users that need to be synced (enacted < updated or enacted is None) pending_slivers = Sliver.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None)) for sliver in pending_slivers: - if not sliver.instance_id and sliver.creator: + if sliver.creator: try: # update manager context self.manager.init_caller(sliver.creator, sliver.slice.name) self.manager.save_sliver(sliver) - logger.info("saved sliver: %s %s" % (sliver)) + logger.info("saved sliver: %s" % (sliver)) except: logger.log_exc("save sliver failed: %s" % sliver) @@ -263,7 +265,7 @@ class OpenStackObserver: for sliver in slivers: # update connection self.manager.init_admin(tenant=sliver.slice.name) - servers = self.manager.client.nova.servers.findall(id=sliver.instance_id) + servers = self.manager.driver.shell.nova.servers.findall(id=sliver.instance_id) if not servers: continue server = servers[0] @@ -273,3 +275,13 @@ class OpenStackObserver: sliver.ip = ips[0]['addr'] sliver.save() logger.info("saved sliver ip: %s %s" % (sliver, ips[0])) + + def sync_external_routes(self): + routes = self.manager.driver.get_external_routes() + subnets = self.manager.driver.shell.quantum.list_subnets()['subnets'] + for subnet in subnets: + try: + self.manager.driver.add_external_route(subnet, routes) + except: + logger.log_exc("failed to add external route for subnet %s" % subnet) +