|
1 | 1 | import asyncio |
2 | 2 | import logging |
3 | 3 | import os |
| 4 | +from collections import defaultdict |
4 | 5 |
|
5 | 6 | from pybot.plugins.airtable import endpoints |
6 | 7 | from pybot.plugins.airtable.api import AirtableAPI |
7 | | -from pybot.plugins.airtable.requests import RequestRouter |
8 | 8 |
|
9 | 9 | logger = logging.getLogger(__name__) |
10 | 10 |
|
@@ -33,8 +33,25 @@ def load(self, sirbot, api_key=None, base_key=None, verify=None): |
33 | 33 |
|
34 | 34 | sirbot.router.add_route('POST', '/airtable/request', endpoints.incoming_request) |
35 | 35 |
|
36 | | - def on_request(self, request, handler, wait=True): |
| 36 | + def on_request(self, request, handler, **kwargs): |
37 | 37 | if not asyncio.iscoroutinefunction(handler): |
38 | 38 | handler = asyncio.coroutine(handler) |
39 | | - configuration = {'wait': wait} |
40 | | - self.routers['request'].register(request, (handler, configuration)) |
| 39 | + options = {**kwargs, 'wait': False} |
| 40 | + self.routers['request'].register(request, (handler, options)) |
| 41 | + |
| 42 | + |
| 43 | +class RequestRouter: |
| 44 | + def __init__(self): |
| 45 | + self._routes = defaultdict(list) |
| 46 | + |
| 47 | + def register(self, request_type, handler, **detail): |
| 48 | + logger.info("Registering %s, %s to %s", request_type, detail, handler) |
| 49 | + self._routes[request_type].append(handler) |
| 50 | + |
| 51 | + def dispatch(self, request): |
| 52 | + logger.debug('Dispatching request "%s"', request.get("type")) |
| 53 | + if request["type"] in self._routes: |
| 54 | + for handler in self._routes.get(request['type']): |
| 55 | + yield handler |
| 56 | + else: |
| 57 | + return |
0 commit comments