X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fopenstack%2Fobserver.py;h=fbacb67c831129ecfff409fa6c304c3167f0276f;hb=43c3a775661098220309c758a0c689e2c6d576d3;hp=b59530e4bec79a9b997f664b83887e8cffc992bf;hpb=e3f8d8609e0b6ce9d788604aadbc4d4dd94bf031;p=plstackapi.git diff --git a/planetstack/openstack/observer.py b/planetstack/openstack/observer.py index b59530e..fbacb67 100644 --- a/planetstack/openstack/observer.py +++ b/planetstack/openstack/observer.py @@ -1,12 +1,15 @@ import time import traceback import commands +import threading + from datetime import datetime from collections import defaultdict from core.models import * from django.db.models import F, Q from openstack.manager import OpenStackManager -from util.logger import Logger, logging +from util.logger import Logger, logging, logger +#from timeout import timeout logger = Logger(logfile='observer.log', level=logging.INFO) @@ -15,20 +18,37 @@ class OpenStackObserver: def __init__(self): self.manager = OpenStackManager() + # The Condition object that gets signalled by Feefie events + self.event_cond = threading.Condition() + + def wait_for_event(self, timeout): + self.event_cond.acquire() + self.event_cond.wait(timeout) + self.event_cond.release() + + def wake_up(self): + logger.info('Wake up routine called. Event cond %r'%self.event_cond) + self.event_cond.acquire() + self.event_cond.notify() + self.event_cond.release() def run(self): if not self.manager.enabled or not self.manager.has_openstack: return while True: try: + logger.info('Observer run loop') #self.sync_roles() + logger.info('Calling sync tenants') self.sync_tenants() self.sync_users() self.sync_user_tenant_roles() self.sync_slivers() self.sync_sliver_ips() + logger.info('Calling sync external routes') self.sync_external_routes() - time.sleep(10) + self.wait_for_event(timeout=300) + logger.info('Observer woken up') except: traceback.print_exc()