Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 1 | import threading |
| 2 | import requests, json |
Sapan Bhatia | 66f4e61 | 2013-07-02 12:12:38 -0400 | [diff] [blame] | 3 | |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 4 | from xos.config import Config, XOS_DIR |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 5 | |
Scott Baker | c1c45f8 | 2014-01-21 16:23:51 -0800 | [diff] [blame] | 6 | import uuid |
Sapan Bhatia | 9182b32 | 2013-06-25 16:22:14 -0400 | [diff] [blame] | 7 | import os |
Scott Baker | 6ecd426 | 2014-01-21 23:15:21 -0800 | [diff] [blame] | 8 | import imp |
| 9 | import inspect |
Sapan Bhatia | 9182b32 | 2013-06-25 16:22:14 -0400 | [diff] [blame] | 10 | import base64 |
Sapan Bhatia | dbaf193 | 2013-09-03 11:28:52 -0400 | [diff] [blame] | 11 | import json |
Scott Baker | 6ecd426 | 2014-01-21 23:15:21 -0800 | [diff] [blame] | 12 | import traceback |
Sapan Bhatia | 9182b32 | 2013-06-25 16:22:14 -0400 | [diff] [blame] | 13 | |
Scott Baker | 7648c58 | 2015-03-10 12:52:29 -0700 | [diff] [blame] | 14 | if getattr(Config(),"observer_fofum_disabled", False) != True: |
| 15 | from fofum import Fofum |
| 16 | fofum_enabled = True |
| 17 | else: |
| 18 | fofum_enabled = False |
| 19 | |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 20 | random_client_id=None |
| 21 | def get_random_client_id(): |
| 22 | global random_client_id |
| 23 | |
Scott Baker | 3bd7c86 | 2015-02-04 16:54:10 -0800 | [diff] [blame] | 24 | if (random_client_id is None) and os.path.exists(XOS_DIR + "/random_client_id"): |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 25 | # try to use the last one we used, if we saved it |
| 26 | try: |
Scott Baker | 3bd7c86 | 2015-02-04 16:54:10 -0800 | [diff] [blame] | 27 | random_client_id = open(XOS_DIR+"/random_client_id","r").readline().strip() |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 28 | print "get_random_client_id: loaded %s" % random_client_id |
| 29 | except: |
Scott Baker | 3bd7c86 | 2015-02-04 16:54:10 -0800 | [diff] [blame] | 30 | print "get_random_client_id: failed to read " + XOS_DIR + "/random_client_id" |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 31 | |
| 32 | if random_client_id is None: |
| 33 | random_client_id = base64.urlsafe_b64encode(os.urandom(12)) |
| 34 | print "get_random_client_id: generated new id %s" % random_client_id |
| 35 | |
| 36 | # try to save it for later (XXX: could race with another client here) |
| 37 | try: |
Scott Baker | 3bd7c86 | 2015-02-04 16:54:10 -0800 | [diff] [blame] | 38 | open(XOS_DIR + "/random_client_id","w").write("%s\n" % random_client_id) |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 39 | except: |
Scott Baker | 3bd7c86 | 2015-02-04 16:54:10 -0800 | [diff] [blame] | 40 | print "get_random_client_id: failed to write " + XOS_DIR + "/random_client_id" |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 41 | |
| 42 | return random_client_id |
| 43 | |
| 44 | # decorator that marks dispatachable event methods |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 45 | def event(func): |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 46 | setattr(func, 'event', func.__name__) |
| 47 | return func |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 48 | |
| 49 | class EventHandler: |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 50 | # This code is currently not in use. |
| 51 | def __init__(self): |
| 52 | pass |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 53 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 54 | @staticmethod |
| 55 | def get_events(): |
| 56 | events = [] |
| 57 | for name in dir(EventHandler): |
| 58 | attribute = getattr(EventHandler, name) |
| 59 | if hasattr(attribute, 'event'): |
| 60 | events.append(getattr(attribute, 'event')) |
| 61 | return events |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 62 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 63 | def dispatch(self, event, *args, **kwds): |
| 64 | if hasattr(self, event): |
| 65 | return getattr(self, event)(*args, **kwds) |
| 66 | |
Scott Baker | 3d5a278 | 2014-05-13 09:58:02 -0700 | [diff] [blame] | 67 | |
Sapan Bhatia | 66f4e61 | 2013-07-02 12:12:38 -0400 | [diff] [blame] | 68 | class EventSender: |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 69 | def __init__(self,user=None,clientid=None): |
| 70 | try: |
| 71 | user = Config().feefie_client_user |
| 72 | except: |
| 73 | user = 'pl' |
Sapan Bhatia | 66f4e61 | 2013-07-02 12:12:38 -0400 | [diff] [blame] | 74 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 75 | try: |
| 76 | clid = Config().feefie_client_id |
| 77 | except: |
| 78 | clid = get_random_client_id() |
Sapan Bhatia | fc69f3d | 2014-07-21 20:09:06 -0400 | [diff] [blame] | 79 | print "EventSender: no feefie_client_id configured. Using random id %s" % clid |
Sapan Bhatia | 66f4e61 | 2013-07-02 12:12:38 -0400 | [diff] [blame] | 80 | |
Scott Baker | 7648c58 | 2015-03-10 12:52:29 -0700 | [diff] [blame] | 81 | if fofum_enabled: |
| 82 | self.fofum = Fofum(user=user) |
| 83 | self.fofum.make(clid) |
Sapan Bhatia | 9faf7b0 | 2013-10-09 10:27:14 -0400 | [diff] [blame] | 84 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 85 | def fire(self,**kwargs): |
| 86 | kwargs["uuid"] = str(uuid.uuid1()) |
Scott Baker | 7648c58 | 2015-03-10 12:52:29 -0700 | [diff] [blame] | 87 | if fofum_enabled: |
| 88 | self.fofum.fire(json.dumps(kwargs)) |
Tony Mack | 79a49c8 | 2013-06-15 23:51:57 -0400 | [diff] [blame] | 89 | |
| 90 | class EventListener: |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 91 | def __init__(self,wake_up=None): |
| 92 | self.handler = EventHandler() |
| 93 | self.wake_up = wake_up |
Scott Baker | 6ecd426 | 2014-01-21 23:15:21 -0800 | [diff] [blame] | 94 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 95 | def handle_event(self, payload): |
| 96 | payload_dict = json.loads(payload) |
Sapan Bhatia | 43c3a77 | 2013-07-03 11:19:07 -0400 | [diff] [blame] | 97 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 98 | if (self.wake_up): |
| 99 | self.wake_up() |
Sapan Bhatia | dbaf193 | 2013-09-03 11:28:52 -0400 | [diff] [blame] | 100 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 101 | def run(self): |
| 102 | # This is our unique client id, to be used when firing and receiving events |
| 103 | # It needs to be generated once and placed in the config file |
Scott Baker | c1c45f8 | 2014-01-21 16:23:51 -0800 | [diff] [blame] | 104 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 105 | try: |
| 106 | user = Config().feefie_client_user |
| 107 | except: |
| 108 | user = 'pl' |
Sapan Bhatia | 66f4e61 | 2013-07-02 12:12:38 -0400 | [diff] [blame] | 109 | |
Sapan Bhatia | 1b84d66 | 2014-04-29 23:45:48 -0400 | [diff] [blame] | 110 | try: |
| 111 | clid = Config().feefie_client_id |
| 112 | except: |
| 113 | clid = get_random_client_id() |
| 114 | print "EventListener: no feefie_client_id configured. Using random id %s" % clid |
Scott Baker | c1c45f8 | 2014-01-21 16:23:51 -0800 | [diff] [blame] | 115 | |
Scott Baker | 7648c58 | 2015-03-10 12:52:29 -0700 | [diff] [blame] | 116 | if fofum_enabled: |
| 117 | f = Fofum(user=user) |
| 118 | |
| 119 | listener_thread = threading.Thread(target=f.listen_for_event,args=(clid,self.handle_event)) |
| 120 | listener_thread.start() |