-
-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathbackend.py
80 lines (66 loc) · 2.68 KB
/
backend.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
from __future__ import annotations
import sys
from contextlib import suppress
from typing import TYPE_CHECKING
from loguru import logger
from nonechat import Backend, Frontend
from nonechat.info import Event
from avilla.standard.core.account import (
AccountAvailable,
AccountRegistered,
AccountUnavailable,
)
from ..core.account import AccountInfo
from .account import PLATFORM, ConsoleAccount
from .capability import ConsoleCapability
if TYPE_CHECKING:
from .service import ConsoleService
class AvillaConsoleBackend(Backend):
account: ConsoleAccount
_service: ConsoleService
def __init__(self, app: Frontend):
super().__init__(app)
self._stderr = sys.stdout
self._logger_id: int | None = None
self._should_restore_logger: bool = False
def set_service(self, service: ConsoleService):
self._service = service
def on_console_load(self):
logger.remove()
self._should_restore_logger = True
self.account = ConsoleAccount(self._service.protocol)
self._logger_id = logger.add(self.frontend._fake_output, level=0, diagnose=False)
self._service.protocol.avilla.accounts[self.account.route] = AccountInfo(
self.account.route, self.account, self._service.protocol, PLATFORM
)
self._service.protocol.avilla.broadcast.postEvent(
AccountRegistered(self._service.protocol.avilla, self.account)
)
def on_console_mount(self):
self.account.status.enabled = True
self._service.protocol.avilla.broadcast.postEvent(AccountAvailable(self._service.protocol.avilla, self.account))
def on_console_unmount(self):
if self._logger_id is not None:
logger.remove(self._logger_id)
self._logger_id = None
if self._should_restore_logger:
logger.add(
self._stderr,
backtrace=True,
diagnose=True,
colorize=True,
)
self._should_restore_logger = False
self.account.status.enabled = False
self._service.protocol.avilla.accounts.pop(self.account.route, None)
self._service.protocol.avilla.broadcast.postEvent(
AccountUnavailable(self._service.protocol.avilla, self.account)
)
logger.success("Console exit.")
logger.warning("Press Ctrl-C for Application exit")
async def post_event(self, event: Event):
with suppress(NotImplementedError):
res = await ConsoleCapability(self.account.staff).event_callback(event)
self._service.protocol.post_event(res)
return
logger.warning(f"received unsupported event {event.type}: {event}")