LiteyukiBot/liteyuki/plugin/model.py

85 lines
1.8 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
@Time : 2024/7/24 上午12:02
@Author : snowykami
@Email : snowykami@outlook.com
@File : model.py
@Software: PyCharm
"""
2024-08-18 00:06:06 +00:00
from enum import Enum
from types import ModuleType
2024-08-18 00:06:06 +00:00
from typing import Any, Optional
from pydantic import BaseModel
2024-08-18 00:06:06 +00:00
class PluginType(Enum):
"""
插件类型枚举值
"""
APPLICATION = "application"
"""应用端例如NoneBot"""
SERVICE = "service"
"""服务端例如AI绘画后端"""
IMPLEMENTATION = "implementation"
"""实现端:例如与聊天平台的协议实现"""
MODULE = "module"
"""模块:导出对象给其他插件使用"""
UNCLASSIFIED = "unclassified"
"""未分类:默认值"""
class PluginMetadata(BaseModel):
"""
轻雪插件元数据由插件编写者提供name为必填项
2024-08-18 00:06:06 +00:00
Attributes:
----------
name: str
插件名称
description: str
插件描述
usage: str
插件使用方法
type: str
插件类型
author: str
插件作者
homepage: str
插件主页
extra: dict[str, Any]
额外信息
"""
name: str
description: str = ""
usage: str = ""
2024-08-18 15:39:19 +00:00
type: PluginType = PluginType.UNCLASSIFIED
2024-08-18 00:06:06 +00:00
author: str = ""
2024-08-18 15:39:19 +00:00
homepage: str = ""
2024-08-18 00:06:06 +00:00
extra: dict[str, Any] = {}
class Plugin(BaseModel):
"""
存储插件信息
"""
model_config = {
'arbitrary_types_allowed': True
}
name: str
"""插件名称 例如plugin_loader"""
module: ModuleType
"""插件模块对象"""
module_name: str
"""点分割模块路径 例如a.b.c"""
metadata: Optional[PluginMetadata] = None
def __hash__(self):
return hash(self.module_name)