pass pk to deleter, support model as a class or instance, give each event a uuid...
[plstackapi.git] / planetstack / observer / event_manager.py
index c4215ac..8ec3fc2 100644 (file)
@@ -1,25 +1,24 @@
 import threading
 import requests, json
 
-from core.models import *
-#from openstack.manager import OpenStackManager
 from planetstack.config import Config
 from observer.deleters import deleters
 
+import uuid
 import os
 import base64
 from fofum import Fofum
 import json
 
-# decorator that marks dispatachable event methods     
+# decorator that marks dispatachable event methods       
 def event(func):
        setattr(func, 'event', func.__name__)
-       return func              
+       return func                     
 
 class EventHandler:
        # This code is currently not in use.
        def __init__(self):
-               pass #self.manager = OpenStackManager()
+               pass 
 
        @staticmethod
        def get_events():
@@ -38,17 +37,23 @@ class EventHandler:
 class EventSender:
        def __init__(self,user=None,clientid=None):
                try:
-                       clid = Config().feefie_client_id
                        user = Config().feefie_client_user
                except:
-                       clid = 'planetstack_core_team'
                        user = 'pl'
 
+               try:
+                       clid = Config().feefie_client_id
+               except:
+                       clid = self.random_client_id()
+                       
+
                self.fofum = Fofum(user=user)
                self.fofum.make(clid)
 
-       def fire(self,**args):
-               self.fofum.fire(json.dumps(args))
+       def fire(self,**kwargs):
+                kwargs["uuid"] = str(uuid.uuid1())
+                print "YYY fire", kwargs
+               self.fofum.fire(json.dumps(kwargs))
 
 class EventListener:
        def __init__(self,wake_up=None):
@@ -59,31 +64,44 @@ class EventListener:
                payload_dict = json.loads(payload)
 
                try:
-                       deletion = payload_dict['deletion_flag']
+                       deletion = payload_dict.get('delete_flag', False)
+                        print "XXX", payload_dict, deletion
                        if (deletion):
                                model = payload_dict['model']
                                pk = payload_dict['pk']
 
+                                print "XXX", model, pk, deleters
+
                                for deleter in deleters[model]:
+                                        print "ZZZ executing deleter"
                                        deleter(pk)
                except:
                        deletion = False
 
                if (not deletion and self.wake_up):
                        self.wake_up()
-               
+
+       def random_client_id(self):
+               try:
+                       return self.client_id
+               except AttributeError:
+                       self.client_id = base64.urlsafe_b64encode(os.urandom(12))
+                       return self.client_id
 
        def run(self):
                # This is our unique client id, to be used when firing and receiving events
                # It needs to be generated once and placed in the config file
 
                try:
-                       clid = Config().feefie_client_id
                        user = Config().feefie_client_user
                except:
-                       clid = 'planetstack_core_team'
                        user = 'pl'
 
+               try:
+                       clid = Config().feefie_client_id
+               except:
+                       clid = self.random_client_id()
+
                f = Fofum(user=user)
                
                listener_thread = threading.Thread(target=f.listen_for_event,args=(clid,self.handle_event))