2022-12-04 16:46:33 +08:00
|
|
|
|
import copy
|
2021-11-04 16:11:50 +08:00
|
|
|
|
from pathlib import Path
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from typing import Any, Optional, Union
|
|
|
|
|
|
|
2021-11-04 16:11:50 +08:00
|
|
|
|
from ruamel import yaml
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from ruamel.yaml import YAML
|
2022-05-26 22:49:48 +08:00
|
|
|
|
from ruamel.yaml.scanner import ScannerError
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ConfigsManager:
|
|
|
|
|
|
"""
|
|
|
|
|
|
插件配置 与 资源 管理器
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
def __init__(self, file: Path):
|
|
|
|
|
|
self._data: dict = {}
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self._simple_data: dict = {}
|
2021-11-04 16:11:50 +08:00
|
|
|
|
self._admin_level_data = []
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self._simple_file = Path() / "configs" / "config.yaml"
|
2021-11-04 16:11:50 +08:00
|
|
|
|
if file:
|
|
|
|
|
|
file.parent.mkdir(exist_ok=True, parents=True)
|
|
|
|
|
|
self.file = file
|
2022-04-10 22:19:50 +08:00
|
|
|
|
_yaml = YAML()
|
2021-11-04 16:11:50 +08:00
|
|
|
|
if file.exists():
|
|
|
|
|
|
with open(file, "r", encoding="utf8") as f:
|
|
|
|
|
|
self._data = _yaml.load(f)
|
2022-05-26 22:49:48 +08:00
|
|
|
|
if not self._data:
|
|
|
|
|
|
self.file.unlink()
|
|
|
|
|
|
raise ValueError(
|
|
|
|
|
|
"配置文件为空!\n"
|
|
|
|
|
|
"***********************************************************\n"
|
|
|
|
|
|
"****** 配置文件 plugins2config.yaml 为空,已删除,请重启 ******\n"
|
|
|
|
|
|
"***********************************************************"
|
|
|
|
|
|
)
|
2022-04-10 22:19:50 +08:00
|
|
|
|
if self._simple_file.exists():
|
2022-05-26 22:49:48 +08:00
|
|
|
|
try:
|
|
|
|
|
|
with open(self._simple_file, "r", encoding="utf8") as f:
|
|
|
|
|
|
self._simple_data = _yaml.load(f)
|
|
|
|
|
|
except ScannerError as e:
|
|
|
|
|
|
raise ScannerError(
|
|
|
|
|
|
f"{e}\n**********************************************\n"
|
|
|
|
|
|
f"****** 可能为config.yaml配置文件填写不规范 ******\n"
|
|
|
|
|
|
f"**********************************************"
|
|
|
|
|
|
)
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
|
|
|
|
|
def add_plugin_config(
|
|
|
|
|
|
self,
|
|
|
|
|
|
module: str,
|
|
|
|
|
|
key: str,
|
|
|
|
|
|
value: Optional[Any],
|
|
|
|
|
|
*,
|
|
|
|
|
|
name: Optional[str] = None,
|
|
|
|
|
|
help_: Optional[str] = None,
|
2023-02-18 18:46:54 +08:00
|
|
|
|
default_value: Optional[Any] = None,
|
2021-11-29 13:09:47 +08:00
|
|
|
|
_override: bool = False,
|
2021-11-04 16:11:50 +08:00
|
|
|
|
):
|
|
|
|
|
|
"""
|
|
|
|
|
|
为插件添加一个配置,不会被覆盖,只有第一个生效
|
|
|
|
|
|
:param module: 模块
|
|
|
|
|
|
:param key: 键
|
|
|
|
|
|
:param value: 值
|
|
|
|
|
|
:param name: 插件名称
|
|
|
|
|
|
:param help_: 配置注解
|
|
|
|
|
|
:param default_value: 默认值
|
|
|
|
|
|
:param _override: 覆盖前值
|
|
|
|
|
|
"""
|
|
|
|
|
|
if (
|
|
|
|
|
|
not (module in self._data.keys() and self._data[module].get(key))
|
|
|
|
|
|
or _override
|
|
|
|
|
|
):
|
|
|
|
|
|
_module = None
|
|
|
|
|
|
if ":" in module:
|
|
|
|
|
|
module = module.split(":")
|
|
|
|
|
|
_module = module[-1]
|
|
|
|
|
|
module = module[0]
|
|
|
|
|
|
if "[LEVEL]" in key and _module:
|
|
|
|
|
|
key = key.replace("[LEVEL]", "").strip()
|
|
|
|
|
|
self._admin_level_data.append((_module, value))
|
|
|
|
|
|
if self._data.get(module) is None:
|
|
|
|
|
|
self._data[module] = {}
|
|
|
|
|
|
key = key.upper()
|
|
|
|
|
|
self._data[module][key] = {
|
|
|
|
|
|
"value": value,
|
|
|
|
|
|
"name": name.strip() if isinstance(name, str) else name,
|
|
|
|
|
|
"help": help_.strip() if isinstance(help_, str) else help_,
|
|
|
|
|
|
"default_value": default_value,
|
2021-11-29 13:09:47 +08:00
|
|
|
|
"level_module": _module,
|
2021-11-04 16:11:50 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
def remove_plugin_config(self, module: str):
|
|
|
|
|
|
"""
|
|
|
|
|
|
为插件删除一个配置
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
"""
|
|
|
|
|
|
if module in self._data.keys():
|
|
|
|
|
|
del self._data[module]
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self.save()
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
2022-08-22 22:49:35 +08:00
|
|
|
|
def set_config(self, module: str, key: str, value: Any, auto_save: bool = False, save_simple_data: bool = True):
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
设置配置值
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
:param key: 配置名称
|
|
|
|
|
|
:param value: 值
|
2022-08-22 22:49:35 +08:00
|
|
|
|
:param auto_save: 自动保存
|
|
|
|
|
|
:param save_simple_data: 保存至config.yaml
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
if module in self._data.keys():
|
2022-05-26 22:49:48 +08:00
|
|
|
|
if (
|
|
|
|
|
|
self._data[module].get(key) is not None
|
|
|
|
|
|
and self._data[module][key] != value
|
|
|
|
|
|
):
|
2021-11-04 16:11:50 +08:00
|
|
|
|
self._data[module][key]["value"] = value
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self._simple_data[module][key] = value
|
2022-08-22 22:49:35 +08:00
|
|
|
|
if auto_save:
|
2022-08-21 18:09:31 +08:00
|
|
|
|
self.save(save_simple_data=save_simple_data)
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
|
|
|
|
|
def set_help(self, module: str, key: str, help_: str):
|
|
|
|
|
|
"""
|
|
|
|
|
|
设置配置注释
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
:param key: 配置名称
|
|
|
|
|
|
:param help_: 注释文本
|
|
|
|
|
|
"""
|
|
|
|
|
|
if module in self._data.keys():
|
|
|
|
|
|
if self._data[module].get(key) is not None:
|
|
|
|
|
|
self._data[module][key]["help"] = help_
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self.save()
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
2022-06-16 14:25:22 +08:00
|
|
|
|
def set_default_value(self, module: str, key: str, value: Any):
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
设置配置默认值
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
:param key: 配置名称
|
|
|
|
|
|
:param value: 值
|
|
|
|
|
|
"""
|
|
|
|
|
|
if module in self._data.keys():
|
|
|
|
|
|
if self._data[module].get(key) is not None:
|
|
|
|
|
|
self._data[module][key]["default_value"] = value
|
2022-04-10 22:19:50 +08:00
|
|
|
|
self.save()
|
2021-11-04 16:11:50 +08:00
|
|
|
|
|
2022-05-26 22:49:48 +08:00
|
|
|
|
def get_config(
|
|
|
|
|
|
self, module: str, key: str, default: Optional[Any] = None
|
|
|
|
|
|
) -> Optional[Any]:
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
获取指定配置值
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
:param key: 配置名称
|
2021-12-16 11:16:28 +08:00
|
|
|
|
:param default: 没有key值内容的默认返回值
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
key = key.upper()
|
2022-08-22 22:49:35 +08:00
|
|
|
|
if module in self._data.keys():
|
2021-11-09 18:04:33 +08:00
|
|
|
|
for key in [key, f"{key} [LEVEL]"]:
|
2022-08-22 22:49:35 +08:00
|
|
|
|
if self._data[module].get(key) is not None:
|
|
|
|
|
|
if self._data[module][key]["value"] is None:
|
|
|
|
|
|
return self._data[module][key]["default_value"]
|
|
|
|
|
|
return self._data[module][key]["value"]
|
2021-12-16 11:16:28 +08:00
|
|
|
|
if default is not None:
|
|
|
|
|
|
return default
|
2021-11-04 16:11:50 +08:00
|
|
|
|
return None
|
|
|
|
|
|
|
2021-11-29 13:09:47 +08:00
|
|
|
|
def get_level2module(self, module: str, key: str) -> Optional[str]:
|
|
|
|
|
|
"""
|
|
|
|
|
|
获取指定key所绑定的module,一般为权限等级
|
|
|
|
|
|
:param module: 模块名
|
|
|
|
|
|
:param key: 配置名称
|
|
|
|
|
|
:return:
|
|
|
|
|
|
"""
|
|
|
|
|
|
if self._data.get(module) is not None:
|
|
|
|
|
|
if self._data[module].get(key) is not None:
|
|
|
|
|
|
return self._data[module][key].get("level_module")
|
|
|
|
|
|
|
2021-11-04 16:11:50 +08:00
|
|
|
|
def get(self, key: str):
|
|
|
|
|
|
"""
|
|
|
|
|
|
获取插件配置数据
|
|
|
|
|
|
:param key: 名称
|
|
|
|
|
|
"""
|
|
|
|
|
|
if key in self._data.keys():
|
|
|
|
|
|
return self._data[key]
|
|
|
|
|
|
|
2022-04-10 22:19:50 +08:00
|
|
|
|
def save(self, path: Union[str, Path] = None, save_simple_data: bool = False):
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
|
|
|
|
|
保存数据
|
|
|
|
|
|
:param path: 路径
|
2022-04-10 22:19:50 +08:00
|
|
|
|
:param save_simple_data: 同时保存至config.yaml
|
2021-11-04 16:11:50 +08:00
|
|
|
|
"""
|
2022-04-10 22:19:50 +08:00
|
|
|
|
if save_simple_data:
|
|
|
|
|
|
with open(self._simple_file, "w", encoding="utf8") as f:
|
|
|
|
|
|
yaml.dump(
|
2022-05-26 22:49:48 +08:00
|
|
|
|
self._simple_data,
|
|
|
|
|
|
f,
|
|
|
|
|
|
indent=2,
|
|
|
|
|
|
Dumper=yaml.RoundTripDumper,
|
|
|
|
|
|
allow_unicode=True,
|
2022-04-10 22:19:50 +08:00
|
|
|
|
)
|
2021-11-04 16:11:50 +08:00
|
|
|
|
path = path if path else self.file
|
|
|
|
|
|
with open(path, "w", encoding="utf8") as f:
|
|
|
|
|
|
yaml.dump(
|
|
|
|
|
|
self._data, f, indent=2, Dumper=yaml.RoundTripDumper, allow_unicode=True
|
|
|
|
|
|
)
|
|
|
|
|
|
|
2022-02-19 18:20:19 +08:00
|
|
|
|
def reload(self):
|
|
|
|
|
|
"""
|
|
|
|
|
|
重新加载配置文件
|
|
|
|
|
|
"""
|
|
|
|
|
|
_yaml = YAML()
|
2022-08-21 18:09:31 +08:00
|
|
|
|
if self._simple_file.exists():
|
|
|
|
|
|
with open(self._simple_file, "r", encoding="utf8") as f:
|
|
|
|
|
|
self._simple_data = _yaml.load(f)
|
|
|
|
|
|
for key in self._simple_data.keys():
|
|
|
|
|
|
for k in self._simple_data[key].keys():
|
|
|
|
|
|
self._data[key][k]["value"] = self._simple_data[key][k]
|
2022-02-19 18:20:19 +08:00
|
|
|
|
self.save()
|
|
|
|
|
|
|
2021-11-04 16:11:50 +08:00
|
|
|
|
def get_admin_level_data(self):
|
|
|
|
|
|
"""
|
|
|
|
|
|
获取管理插件等级
|
|
|
|
|
|
"""
|
|
|
|
|
|
return self._admin_level_data
|
|
|
|
|
|
|
2022-12-04 16:46:33 +08:00
|
|
|
|
def get_data(self):
|
|
|
|
|
|
return copy.deepcopy(self._data)
|
|
|
|
|
|
|
2021-11-04 16:11:50 +08:00
|
|
|
|
def is_empty(self) -> bool:
|
|
|
|
|
|
return not bool(self._data)
|
|
|
|
|
|
|
|
|
|
|
|
def keys(self):
|
|
|
|
|
|
return self._data.keys()
|
|
|
|
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
|
|
return str(self._data)
|
|
|
|
|
|
|
|
|
|
|
|
def __setitem__(self, key, value):
|
|
|
|
|
|
self._data[key] = value
|
|
|
|
|
|
|
|
|
|
|
|
def __getitem__(self, key):
|
|
|
|
|
|
return self._data[key]
|