Don't use deprecated router parameter

This commit is contained in:
Tulir Asokan 2021-11-20 01:02:57 +02:00
parent d4a5de1d4f
commit c8ae7cd9f5

View file

@ -26,7 +26,7 @@ import sys
from ruamel.yaml import YAML from ruamel.yaml import YAML
from ruamel.yaml.comments import CommentedMap from ruamel.yaml.comments import CommentedMap
import sqlalchemy as sql import sqlalchemy as sql
from aiohttp import web, ClientSession from aiohttp import web, hdrs, ClientSession
from yarl import URL from yarl import URL
from mautrix.util.config import RecursiveDict, BaseMissingError from mautrix.util.config import RecursiveDict, BaseMissingError
@ -36,7 +36,7 @@ from mautrix.types import (Filter, RoomFilter, RoomEventFilter, StrippedStateEve
EventType, Membership, FilterID, SyncToken) EventType, Membership, FilterID, SyncToken)
from ..plugin_base import Plugin from ..plugin_base import Plugin
from ..plugin_server import PluginWebApp from ..plugin_server import PluginWebApp, PrefixResource
from ..loader import PluginMeta from ..loader import PluginMeta
from ..server import AccessLogger from ..server import AccessLogger
from ..matrix import MaubotMatrixClient from ..matrix import MaubotMatrixClient
@ -149,11 +149,23 @@ if meta.config:
sys.exit(1) sys.exit(1)
if meta.webapp: if meta.webapp:
plugin_webapp = PluginWebApp() web_app = web.Application()
web_app = web.Application(router=plugin_webapp)
web_runner = web.AppRunner(web_app, access_log_class=AccessLogger) web_runner = web.AppRunner(web_app, access_log_class=AccessLogger)
web_base_path = config["server.base_path"].rstrip("/") web_base_path = config["server.base_path"].rstrip("/")
public_url = str(URL(config["server.public_url"]) / web_base_path).rstrip("/") public_url = str(URL(config["server.public_url"]) / web_base_path.lstrip("/")).rstrip("/")
plugin_webapp = PluginWebApp()
async def _handle_plugin_request(req: web.Request) -> web.StreamResponse:
if req.path.startswith(web_base_path):
req = req.clone(rel_url=req.rel_url
.with_path(req.rel_url.path[len(web_base_path):])
.with_query(req.query_string))
return await plugin_webapp.handle(req)
return web.Response(status=404)
resource = PrefixResource(web_base_path)
resource.add_route(hdrs.METH_ANY, _handle_plugin_request)
web_app.router.register_resource(resource)
else: else:
web_app = web_runner = public_url = plugin_webapp = None web_app = web_runner = public_url = plugin_webapp = None
@ -191,6 +203,12 @@ async def main():
await crypto_store.put_device_id(device_id) await crypto_store.put_device_id(device_id)
log.debug("Enabled encryption support") log.debug("Enabled encryption support")
if web_runner:
await web_runner.setup()
site = web.TCPSite(web_runner, config["server.hostname"], config["server.port"])
await site.start()
log.info(f"Web server listening on {site.name}")
while True: while True:
try: try:
whoami = await client.whoami() whoami = await client.whoami()
@ -236,12 +254,6 @@ async def main():
await bot.internal_start() await bot.internal_start()
if web_runner:
await web_runner.setup()
site = web.TCPSite(web_runner, config["server.hostname"], config["server.port"])
await site.start()
log.info(f"Web server listening on {site.name}")
async def stop() -> None: async def stop() -> None:
client.stop() client.stop()