aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
author简律纯 <admin@jyunko.cn>2023-04-28 03:02:56 +0800
committerGitHub <noreply@github.com>2023-04-28 03:02:56 +0800
commit57a8f67b27aa617b7a993477231b3d6978f4f842 (patch)
treeab888fad782c517c9811ef0213a4ae3db394dbaf
parent19c6e564af050cb68420d1a2249d0570248952af (diff)
downloadHydroRoll-57a8f67b27aa617b7a993477231b3d6978f4f842.tar.gz
HydroRoll-57a8f67b27aa617b7a993477231b3d6978f4f842.zip
Delete HydroRoll directory
-rw-r--r--HydroRoll/bot.py64
-rw-r--r--HydroRoll/plugins/HydroRoll_plugin_base/__init__.py93
-rw-r--r--HydroRoll/plugins/HydroRoll_plugin_base/config.py30
-rw-r--r--HydroRoll/test.py0
4 files changed, 0 insertions, 187 deletions
diff --git a/HydroRoll/bot.py b/HydroRoll/bot.py
deleted file mode 100644
index c2b99e6..0000000
--- a/HydroRoll/bot.py
+++ /dev/null
@@ -1,64 +0,0 @@
-from iamai import Bot as _Bot
-from typing import Optional, Dict, List, Type, Any, Union
-from pathlib import Path
-import os
-# 获取当前目录路径
-current_dir = Path.cwd()
-
-# 获取当前脚本文件路径
-script_file = current_dir.resolve() / __file__
-
-# 获取当前脚本文件所在目录路径
-script_dir = script_file.parent
-
-__all__ = ["Bot"]
-
-class Bot:
- def __init__(
- self,
- *,
- config_file: Optional[str] = "config.toml",
- config_dict: Optional[Dict] = None,
- hot_reload: bool = False,
- ) -> None:
- self.bot = _Bot(hot_reload=hot_reload,
- config_file=config_file,
- config_dict=config_dict
- )
- self.bot.load_plugins_from_dirs(Path(f"{script_dir}/plugins"))
- self.create_folders()
- self.init_data()
- self.init_conf()
- self.init_webui()
-
- def run(self) -> None:
- self.bot.run()
-
- def restart(self) -> None:
- self.bot.restart()
-
- def create_folders(self):
- folder_path = os.path.dirname(os.path.abspath('__file__')) # 获取main.py所在文件夹路径
- if not os.path.isdir(os.path.join(folder_path, 'user')):
- os.mkdir(os.path.join(folder_path, 'user'))
- if not os.path.isdir(os.path.join(folder_path, 'data')):
- os.mkdir(os.path.join(folder_path, 'data'))
- if not os.path.isdir(os.path.join(folder_path, 'models')):
- os.mkdir(os.path.join(folder_path, 'models'))
- if not os.path.isdir(os.path.join(folder_path, 'web')):
- os.mkdir(os.path.join(folder_path, 'web'))
- if not os.path.isdir(os.path.join(folder_path, 'config')):
- os.mkdir(os.path.join(folder_path, 'config'))
- if not os.path.isdir(os.path.join(folder_path, 'logs')):
- os.mkdir(os.path.join(folder_path, 'logs'))
- if not os.path.isdir(os.path.join(folder_path, 'rules')):
- os.mkdir(os.path.join(folder_path, 'rules'))
-
- def init_data(self):
- ...
-
- def init_webui(self):
- ...
-
- def init_conf(self):
- ... \ No newline at end of file
diff --git a/HydroRoll/plugins/HydroRoll_plugin_base/__init__.py b/HydroRoll/plugins/HydroRoll_plugin_base/__init__.py
deleted file mode 100644
index a050ae1..0000000
--- a/HydroRoll/plugins/HydroRoll_plugin_base/__init__.py
+++ /dev/null
@@ -1,93 +0,0 @@
-import re
-from abc import ABC, abstractmethod
-from typing import Type, Union, Generic, TypeVar
-
-from iamai import Plugin
-from iamai.typing import T_State
-from iamai.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:
- is_bot_off = True
-
- if self.event.adapter.name != "cqhttp":
- return False
- if self.event.type != "message":
- return False
- match_str = self.event.message.get_plain_text()
- if is_bot_off:
- if self.event.message.startswith(f'[CQ:at,qq={self.event.self_id}]'):
- match_str = re.sub(fr'^\[CQ:at,qq={self.event.self_id}\]', '', match_str)
- else:
- return False
- if self.config.handle_all_message:
- return self.str_match(match_str)
- elif self.config.handle_friend_message:
- if self.event.message_type == "private":
- return self.str_match(match_str)
- 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(match_str)
- 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) \ No newline at end of file
diff --git a/HydroRoll/plugins/HydroRoll_plugin_base/config.py b/HydroRoll/plugins/HydroRoll_plugin_base/config.py
deleted file mode 100644
index 311874c..0000000
--- a/HydroRoll/plugins/HydroRoll_plugin_base/config.py
+++ /dev/null
@@ -1,30 +0,0 @@
-from typing import Set, Optional
-
-from iamai import ConfigModel
-
-
-class BasePluginConfig(ConfigModel):
- __config_name__ = ""
- handle_all_message: bool = True
- """是否处理所有类型的消息,此配置为 True 时会覆盖 handle_friend_message 和 handle_group_message。"""
- handle_friend_message: bool = True
- """是否处理好友消息。"""
- handle_group_message: bool = True
- """是否处理群消息。"""
- accept_group: Optional[Set[int]] = None
- """处理消息的群号,仅当 handle_group_message 为 True 时生效,留空表示处理所有群。"""
- message_str: str = "*{user_name} {message}"
- """最终发送消息的格式。"""
-
-
-class RegexPluginConfig(BasePluginConfig):
- pass
-
-
-class CommandPluginConfig(RegexPluginConfig):
- command_prefix: Set[str] = {".", "。","!",":"}
- """命令前缀。"""
- command: Set[str] = {}
- """命令文本。"""
- ignore_case: bool = True
- """忽略大小写。"""
diff --git a/HydroRoll/test.py b/HydroRoll/test.py
deleted file mode 100644
index e69de29..0000000
--- a/HydroRoll/test.py
+++ /dev/null