Don't use deprecated router parameter
This commit is contained in:
parent
d4a5de1d4f
commit
c8ae7cd9f5
1 changed files with 23 additions and 11 deletions
|
@ -26,7 +26,7 @@ import sys
|
|||
from ruamel.yaml import YAML
|
||||
from ruamel.yaml.comments import CommentedMap
|
||||
import sqlalchemy as sql
|
||||
from aiohttp import web, ClientSession
|
||||
from aiohttp import web, hdrs, ClientSession
|
||||
from yarl import URL
|
||||
|
||||
from mautrix.util.config import RecursiveDict, BaseMissingError
|
||||
|
@ -36,7 +36,7 @@ from mautrix.types import (Filter, RoomFilter, RoomEventFilter, StrippedStateEve
|
|||
EventType, Membership, FilterID, SyncToken)
|
||||
|
||||
from ..plugin_base import Plugin
|
||||
from ..plugin_server import PluginWebApp
|
||||
from ..plugin_server import PluginWebApp, PrefixResource
|
||||
from ..loader import PluginMeta
|
||||
from ..server import AccessLogger
|
||||
from ..matrix import MaubotMatrixClient
|
||||
|
@ -149,11 +149,23 @@ if meta.config:
|
|||
sys.exit(1)
|
||||
|
||||
if meta.webapp:
|
||||
plugin_webapp = PluginWebApp()
|
||||
web_app = web.Application(router=plugin_webapp)
|
||||
web_app = web.Application()
|
||||
web_runner = web.AppRunner(web_app, access_log_class=AccessLogger)
|
||||
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:
|
||||
web_app = web_runner = public_url = plugin_webapp = None
|
||||
|
||||
|
@ -191,6 +203,12 @@ async def main():
|
|||
await crypto_store.put_device_id(device_id)
|
||||
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:
|
||||
try:
|
||||
whoami = await client.whoami()
|
||||
|
@ -236,12 +254,6 @@ async def main():
|
|||
|
||||
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:
|
||||
client.stop()
|
||||
|
|
Loading…
Reference in a new issue