aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/plugins/alicebot_plugin_base/__init__.py
diff options
context:
space:
mode:
author简律纯 <hsiangnianian@outlook.com>2023-04-18 18:03:02 +0800
committer简律纯 <hsiangnianian@outlook.com>2023-04-18 18:03:02 +0800
commit025020c503ef5b8dc0270197c5b1e6d4e0f8807d (patch)
tree25f8c8d8882647e22ea0acebadafef99306f4c98 /plugins/alicebot_plugin_base/__init__.py
parent074ad0c914ae0b53ace46ed5d4c24205eacbabaa (diff)
downloadHydroRoll-025020c503ef5b8dc0270197c5b1e6d4e0f8807d.tar.gz
HydroRoll-025020c503ef5b8dc0270197c5b1e6d4e0f8807d.zip
✨本体文件
Diffstat (limited to 'plugins/alicebot_plugin_base/__init__.py')
-rw-r--r--plugins/alicebot_plugin_base/__init__.py85
1 files changed, 85 insertions, 0 deletions
diff --git a/plugins/alicebot_plugin_base/__init__.py b/plugins/alicebot_plugin_base/__init__.py
new file mode 100644
index 0000000..a36fb78
--- /dev/null
+++ b/plugins/alicebot_plugin_base/__init__.py
@@ -0,0 +1,85 @@
+import re
+from abc import ABC, abstractmethod
+from typing import Type, Union, Generic, TypeVar
+
+from alicebot import Plugin
+from alicebot.typing import T_State
+from alicebot.adapter.cqhttp.event import GroupMessageEvent, PrivateMessageEvent
+
+from .config import BasePluginConfig, RegexPluginConfig, CommandPluginConfig
+
+T_Config = TypeVar("T_Config", bound=BasePluginConfig)
+T_RegexPluginConfig = TypeVar("T_RegexPluginConfig", bound=RegexPluginConfig)
+T_CommandPluginConfig = TypeVar("T_CommandPluginConfig", bound=CommandPluginConfig)
+
+
+class BasePlugin(
+ Plugin[Union[PrivateMessageEvent, GroupMessageEvent], T_State, T_Config],
+ ABC,
+ Generic[T_State, T_Config],
+):
+ Config: Type[T_Config] = BasePluginConfig
+
+ def format_str(self, format_str: str, message_str: str = "") -> str:
+ return format_str.format(
+ message=message_str,
+ user_name=self.event.sender.nickname,
+ user_id=self.event.sender.user_id,
+ )
+
+ async def rule(self) -> bool:
+ if self.event.adapter.name != "cqhttp":
+ return False
+ if self.event.type != "message":
+ return False
+ if self.config.handle_all_message:
+ return self.str_match(self.event.message.get_plain_text())
+ elif self.config.handle_friend_message:
+ if self.event.message_type == "private":
+ return self.str_match(self.event.message.get_plain_text())
+ elif self.config.handle_group_message:
+ if self.event.message_type == "group":
+ if (
+ self.config.accept_group is None
+ or self.event.group_id in self.config.accept_group
+ ):
+ return self.str_match(self.event.message.get_plain_text())
+ return False
+
+ @abstractmethod
+ def str_match(self, msg_str: str) -> bool:
+ raise NotImplemented
+
+
+class RegexPluginBase(BasePlugin[T_State, T_RegexPluginConfig], ABC):
+ msg_match: re.Match
+ re_pattern: re.Pattern
+ Config: Type[T_RegexPluginConfig] = RegexPluginConfig
+
+ def str_match(self, msg_str: str) -> bool:
+ msg_str = msg_str.strip()
+ self.msg_match = self.re_pattern.fullmatch(msg_str)
+ return bool(self.msg_match)
+
+
+class CommandPluginBase(RegexPluginBase[T_State, T_CommandPluginConfig], ABC):
+ command_match: re.Match
+ command_re_pattern: re.Pattern
+ Config: Type[T_CommandPluginConfig] = CommandPluginConfig
+
+ def str_match(self, msg_str: str) -> bool:
+ if not hasattr(self, "command_re_pattern"):
+ self.command_re_pattern = re.compile(
+ f'({"|".join(self.config.command_prefix)})'
+ f'({"|".join(self.config.command)})'
+ r"\s*(?P<command_args>.*)",
+ flags=re.I if self.config.ignore_case else 0,
+ )
+ msg_str = msg_str.strip()
+ self.command_match = self.command_re_pattern.fullmatch(msg_str)
+ if not self.command_match:
+ return False
+ self.msg_match = self.re_pattern.fullmatch(
+ self.command_match.group("command_args")
+ )
+ return bool(self.msg_match)