X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fopenstack%2Fobserver.py;h=8da099989b4f4e3765bf03d898834073a70bd77a;hb=70780e90a156018e8e1a9d13124375418fa9362b;hp=c14b2cb836bccd2ad1e68fbcbb85c02cfbd7eded;hpb=79a49c87e1ef80e7ea6d2052e681066bb67820d9;p=plstackapi.git diff --git a/planetstack/openstack/observer.py b/planetstack/openstack/observer.py index c14b2cb..8da0999 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 * @@ -105,7 +106,7 @@ class OpenStackObserver: tenants = self.manager.driver.shell.keystone.tenants.findall() system_tenants = ['admin','service'] for tenant in tenants: - if tenant.name == 'admin': + if tenant.name in system_tenants: continue if tenant.name not in site_dict and tenant.name not in slice_dict: try: @@ -226,7 +227,7 @@ 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) @@ -235,7 +236,7 @@ class OpenStackObserver: except: logger.log_exc("save sliver failed: %s" % sliver) - # get all slivers that where enacted != null. We can assume these users + # get all slivers where enacted != null. We can assume these users # have previously been synced and need to be checed for deletion. slivers = Sliver.objects.filter(enacted__isnull=False) sliver_dict = {} @@ -246,12 +247,12 @@ class OpenStackObserver: ctx = self.manager.driver.shell.nova_db.ctx instances = self.manager.driver.shell.nova_db.instance_get_all(ctx) for instance in instances: - if instance.id not in sliver_dict: + if instance.uuid not in sliver_dict: try: # lookup tenant and update context tenant = self.manager.driver.shell.keystone.tenants.find(id=instance.project_id) self.manager.init_admin(tenant=tenant.name) - self.manager.driver.destroy_instance(instance.id) + self.manager.driver.destroy_instance(instance.uuid) logger.info("destroyed sliver: %s" % (instance)) except: logger.log_exc("destroy sliver failed: %s" % instance) @@ -263,7 +264,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 +274,10 @@ 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() + for subnet in subnets: + self.manager.driver.add_external_route(subnet, routes) +