import os import json from config import pconf, plugin_config, conf from common.log import logger class Plugin: def __init__(self): self.handlers = {} def load_config(self) -> dict: """ 加载当前插件配置 :return: 插件配置字典 """ # 优先获取 plugins/config.json 中的全局配置 plugin_conf = pconf(self.name) if not plugin_conf or not conf().get("use_global_plugin_config"): # 全局配置不存在 或者 未开启全局配置开关,则获取插件目录下的配置 plugin_config_path = os.path.join(self.path, "config.json") if os.path.exists(plugin_config_path): with open(plugin_config_path, "r", encoding="utf-8") as f: plugin_conf = json.load(f) logger.debug(f"loading plugin config, plugin_name={self.name}, conf={plugin_conf}") return plugin_conf def save_config(self, config: dict): try: plugin_config[self.name] = config # 写入全局配置 global_config_path = "./plugins/config.json" if os.path.exists(global_config_path): with open(global_config_path, "w", encoding='utf-8') as f: json.dump(plugin_config, f, indent=4, ensure_ascii=False) # 写入插件配置 plugin_config_path = os.path.join(self.path, "config.json") if os.path.exists(plugin_config_path): with open(plugin_config_path, "w", encoding='utf-8') as f: json.dump(config, f, indent=4, ensure_ascii=False) except Exception as e: logger.warn("save plugin config failed: {}".format(e)) def get_help_text(self, **kwargs): return "暂无帮助信息"