forked from platypush/platypush
Removed old processor module
This commit is contained in:
parent
7f3a94dcaf
commit
96f2d9f496
1 changed files with 0 additions and 43 deletions
|
@ -1,43 +0,0 @@
|
|||
import logging
|
||||
|
||||
from .rule import EventRule
|
||||
|
||||
from platypush.config import Config
|
||||
from platypush.message import Message
|
||||
from platypush.message.request import Request
|
||||
|
||||
class EventProcessor(object):
|
||||
""" Event processor class. Checks an event against the configured
|
||||
rules and executes any matching event hooks """
|
||||
|
||||
def __init__(self, hooks=Config.get_event_hooks(), **kwargs):
|
||||
"""
|
||||
Params:
|
||||
hooks -- List of event hooks (default: any entry in the config
|
||||
named as event.hook.<hook_name> """
|
||||
|
||||
self.hooks = {}
|
||||
for (name, hook) in hooks.items():
|
||||
self.hooks[name] = {
|
||||
'if': EventRule.build(hook['if'] if 'if' in hook else {}),
|
||||
'then': hook['then'],
|
||||
}
|
||||
|
||||
def process_event(self, event):
|
||||
""" Processes an event and runs any matched hooks """
|
||||
|
||||
matching_hooks = { name: hook['then'] for (name, hook) in self.hooks.items()
|
||||
if event.matches_rule(hook['if']) }
|
||||
|
||||
for (name, hook) in matching_hooks.items():
|
||||
logging.info('Running command {} triggered by matching event'
|
||||
.format(name))
|
||||
|
||||
# TODO Extend the request with the parameters coming from the event.
|
||||
# A hook should support a syntax like "playlist_id: $EVENT[playlist_id]"
|
||||
request = Request.build(hook)
|
||||
request.execute()
|
||||
|
||||
|
||||
# vim:sw=4:ts=4:et:
|
||||
|
Loading…
Add table
Reference in a new issue