Onionr/src/httpapi/daemoneventsapi/__init__.py

54 lines
1.8 KiB
Python
Raw Normal View History

2019-12-31 00:57:14 +00:00
"""Onionr - Private P2P Communication.
Event driven interface to trigger events in communicator
"""
import json
from flask import Blueprint, request, Response
import config
"""
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
"""
2020-01-02 02:07:34 +00:00
class DaemonEventsBP:
2019-12-31 00:57:14 +00:00
def __init__(self):
"""Create DaemonEvents instance, intended to be a singleton.
Attributes:
events: dict of current/finished events
listeners: callables that are called when a new event is added.
The callables name should match the event name
_too_many: TooManyObjects instance set by external code
"""
2020-01-02 02:07:34 +00:00
event_BP = Blueprint('event_BP', __name__)
2019-12-31 00:57:14 +00:00
self.events = {}
2020-01-02 02:07:34 +00:00
self.listeners = {}
2019-12-31 00:57:14 +00:00
self.flask_bp = event_BP
event_BP = self.flask_bp
2020-01-02 02:07:34 +00:00
@event_BP.route('/daemon-event/<name>', methods=['POST'])
def daemon_event_handler(name):
if name in self.listeners:
@event_BP.route('/daemon-event/bp-enabled')
def bp_enabled() -> Response:
return Response('true')
2019-12-31 00:57:14 +00:00
def clean_old(self):
"""Deletes old daemon events based on their completion date."""
pass