X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fopenstack%2Fobserver.py;h=8da099989b4f4e3765bf03d898834073a70bd77a;hb=70780e90a156018e8e1a9d13124375418fa9362b;hp=6fcb3b4b21b9612a307820327931b6c3e2c356c7;hpb=9b7a8bd1e763f5217b3e5627c55c025681492086;p=plstackapi.git diff --git a/planetstack/openstack/observer.py b/planetstack/openstack/observer.py index 6fcb3b4..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 * @@ -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) +