pluto/handler/app.py

114 lines
2.9 KiB
Python
Raw Normal View History

2021-12-28 12:52:19 +00:00
#!/usr/bin/env python3
2021-12-23 16:59:35 +00:00
# Twisted/Klein imports
2021-12-23 14:46:51 +00:00
from twisted.logger import Logger
from twisted.internet import reactor
from twisted.internet.task import LoopingCall, deferLater
from klein import Klein
2021-12-23 16:59:35 +00:00
# Other library imports
2021-12-23 14:46:51 +00:00
from json import dumps, loads
from json.decoder import JSONDecodeError
2021-12-23 16:59:35 +00:00
# Project imports
2021-12-24 17:27:36 +00:00
from settings import settings
2021-12-23 16:59:35 +00:00
from revolut import Revolut
2021-12-24 02:23:38 +00:00
from agora import Agora
from transactions import Transactions
2021-12-24 17:27:36 +00:00
from irc import bot
2022-01-27 19:12:15 +00:00
from notify import Notify
2021-12-23 14:46:51 +00:00
2021-12-23 19:09:16 +00:00
def convert(data):
if isinstance(data, bytes):
return data.decode("ascii")
if isinstance(data, dict):
return dict(map(convert, data.items()))
if isinstance(data, tuple):
return map(convert, data)
return data
2021-12-23 16:59:35 +00:00
class WebApp(object):
"""
Our Klein webapp.
"""
2021-12-23 14:46:51 +00:00
2021-12-23 16:59:35 +00:00
app = Klein()
2021-12-23 14:46:51 +00:00
def __init__(self):
2021-12-23 16:59:35 +00:00
self.log = Logger("webapp")
2021-12-23 14:46:51 +00:00
2021-12-28 13:42:31 +00:00
def set_tx(self, tx):
self.tx = tx
2021-12-23 16:59:35 +00:00
@app.route("/callback", methods=["POST"])
def callback(self, request):
content = request.content.read()
try:
parsed = loads(content)
except JSONDecodeError:
self.log.error("Failed to parse JSON callback: {content}", content=content)
2021-12-24 17:27:36 +00:00
return dumps(False)
2021-12-23 19:09:16 +00:00
self.log.info("Callback received: {parsed}", parsed=parsed["data"]["id"])
self.tx.transaction(parsed)
2021-12-24 17:27:36 +00:00
return dumps(True)
2021-12-23 14:46:51 +00:00
2021-12-23 16:59:35 +00:00
if __name__ == "__main__":
2022-01-27 19:12:15 +00:00
# Define Notify
notify = Notify()
# Define IRC and Agora
irc = bot()
agora = Agora()
2022-01-27 19:12:15 +00:00
# Pass Notify to IRC and Agora
irc.set_notify(notify)
agora.set_notify(notify)
# Pass Agora to Notify
notify.set_agora(agora)
# Pass IRC to Agora and Agora to IRC
# This is to prevent recursive dependencies
agora.set_irc(irc)
2021-12-27 13:50:32 +00:00
irc.set_agora(agora)
# Define Revolut
revolut = Revolut()
# Pass IRC to Revolut and Revolut to IRC
revolut.set_irc(irc)
irc.set_revolut(revolut)
revolut.set_agora(agora)
# Define Transactions
tx = Transactions()
2022-01-27 19:12:15 +00:00
# Pass Notify to Transactions
tx.set_notify(notify)
2021-12-28 12:50:19 +00:00
# Pass Agora and IRC to Transactions and Transactions to IRC
tx.set_agora(agora)
tx.set_irc(irc)
2022-01-25 17:54:42 +00:00
tx.set_revolut(revolut)
2021-12-28 12:50:19 +00:00
irc.set_tx(tx)
2021-12-28 15:28:45 +00:00
agora.set_tx(tx)
# Define WebApp
webapp = WebApp()
2021-12-28 13:42:31 +00:00
webapp.set_tx(tx)
# Handle setting up JWT and request_token from an auth code
if settings.Revolut.SetupToken == "1":
deferLater(reactor, 1, revolut.setup_auth)
else:
# Schedule refreshing the access token using the refresh token
deferLater(reactor, 1, revolut.get_new_token, True)
# Check if the webhook is set up and set up if not
deferLater(reactor, 4, revolut.setup_webhook)
# Schedule repeatedly refreshing the access token
lc = LoopingCall(revolut.get_new_token)
lc.start(int(settings.Revolut.RefreshSec))
# Run the WebApp
2021-12-23 16:59:35 +00:00
webapp.app.run("127.0.0.1", 8080)