优化开箱次数判断

This commit is contained in:
HibiKier 2022-07-23 14:09:17 +08:00
parent 62965fe1df
commit 1f01ba1d10
35 changed files with 511 additions and 507 deletions

View File

@ -247,6 +247,10 @@ PS: **ARM平台** 请使用全量版 同时 **如果你的机器 RAM < 1G 可能
## 更新
### 2022/7/23
* 优化开箱次数判断
### 2022/7/16
* cos提供连发命令
@ -262,7 +266,6 @@ PS: **ARM平台** 请使用全量版 同时 **如果你的机器 RAM < 1G 可能
* 微博热搜选择单条热搜时也会检测时效性 [@pull/891](https://github.com/HibiKier/zhenxun_bot/pull/891)
### 2022/7/4
* 修复商品未设置限购时无法购买

View File

@ -41,7 +41,7 @@ Config.add_plugin_config(
)
cx = on_message(priority=9, block=False)
cx = on_message(priority=9999, block=False, rule=lambda: False)
# 早上好

View File

@ -25,7 +25,7 @@ __plugin_configs__ = {
friend_req = on_request(priority=5, block=True)
group_req = on_request(priority=5, block=True)
x = on_message(priority=999, block=False)
x = on_message(priority=999, block=False, rule=lambda: False)
exists_data = {"private": {}, "group": {}}

View File

@ -22,9 +22,9 @@ class BagUser(db.Model):
@classmethod
async def get_user_total_gold(cls, user_qq: int, group_id: int) -> str:
"""
说明
说明:
获取金币概况
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
"""
@ -44,9 +44,9 @@ class BagUser(db.Model):
@classmethod
async def get_gold(cls, user_qq: int, group_id: int) -> int:
"""
说明
说明:
获取当前金币
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
"""
@ -64,9 +64,9 @@ class BagUser(db.Model):
@classmethod
async def get_property(cls, user_qq: int, group_id: int) -> Dict[str, int]:
"""
说明
说明:
获取当前道具
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
"""
@ -84,9 +84,9 @@ class BagUser(db.Model):
@classmethod
async def add_gold(cls, user_qq: int, group_id: int, num: int):
"""
说明
说明:
增加金币
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
:param num: 金币数量
@ -112,9 +112,9 @@ class BagUser(db.Model):
@classmethod
async def spend_gold(cls, user_qq: int, group_id: int, num: int):
"""
说明
说明:
花费金币
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
:param num: 金币数量
@ -140,9 +140,9 @@ class BagUser(db.Model):
@classmethod
async def add_property(cls, user_qq: int, group_id: int, name: str):
"""
说明
说明:
增加道具
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
:param name: 道具名称
@ -165,9 +165,9 @@ class BagUser(db.Model):
cls, user_qq: int, group_id: int, name: str, num: int = 1
) -> bool:
"""
说明
说明:
使用/删除 道具
参数
参数:
:param user_qq: qq号
:param group_id: 所在群号
:param name: 道具名称
@ -192,9 +192,9 @@ class BagUser(db.Model):
cls, user_qq: int, group_id: int, goods: "GoodsInfo", goods_num: int
) -> bool:
"""
说明
说明:
购买道具
参数
参数:
:param user_qq: 用户qq
:param group_id: 所在群聊
:param goods: 商品
@ -214,9 +214,9 @@ class BagUser(db.Model):
@classmethod
async def get_all_users(cls, group_id: Optional[int] = None) -> List["BagUser"]:
"""
说明
说明:
获取所有用户数据
参数
参数:
:param group_id: 群号
"""
if not group_id:

View File

@ -15,9 +15,9 @@ class BanUser(db.Model):
@classmethod
async def check_ban_level(cls, user_qq: int, level: int) -> bool:
"""
说明
说明:
检测ban掉目标的用户与unban用户的权限等级大小
参数
参数:
:param user_qq: unban用户的qq号
:param level: ban掉目标用户的权限等级
"""
@ -31,9 +31,9 @@ class BanUser(db.Model):
@classmethod
async def check_ban_time(cls, user_qq: int) -> str:
"""
说明
说明:
检测用户被ban时长
参数
参数:
:param user_qq: qq号
"""
query = cls.query.where((cls.user_qq == user_qq))
@ -49,9 +49,9 @@ class BanUser(db.Model):
@classmethod
async def is_ban(cls, user_qq: int) -> bool:
"""
说明
说明:
判断用户是否被ban
参数
参数:
:param user_qq: qq号
"""
if await cls.check_ban_time(user_qq):
@ -63,9 +63,9 @@ class BanUser(db.Model):
@classmethod
async def is_super_ban(cls, user_qq: int) -> bool:
"""
说明
说明:
判断用户是否被ban
参数
参数:
:param user_qq: qq号
"""
user = await cls.query.where((cls.user_qq == user_qq)).gino.first()
@ -77,9 +77,9 @@ class BanUser(db.Model):
@classmethod
async def ban(cls, user_qq: int, ban_level: int, duration: int) -> bool:
"""
说明
说明:
ban掉目标用户
参数
参数:
:param user_qq: 目标用户qq号
:param ban_level: 使用ban命令用户的权限
:param duration: ban时长
@ -104,9 +104,9 @@ class BanUser(db.Model):
@classmethod
async def unban(cls, user_qq: int) -> bool:
"""
说明
说明:
unban用户
参数
参数:
:param user_qq: qq号
"""
query = cls.query.where((cls.user_qq == user_qq))

View File

@ -28,9 +28,9 @@ class ChatHistory(db.Model):
days: Optional[int] = None,
) -> List["ChatHistory"]:
"""
说明
说明:
获取用户消息
参数
参数:
:param uid: 用户qq
:param msg_type: 消息类型私聊或群聊
:param days: 限制日期
@ -46,9 +46,9 @@ class ChatHistory(db.Model):
date_scope: Tuple[datetime, datetime] = None,
) -> List["ChatHistory"]:
"""
说明
说明:
获取群聊指定用户聊天记录
参数
参数:
:param uid: qq
:param gid: 群号
:param limit: 获取数量
@ -63,9 +63,9 @@ class ChatHistory(db.Model):
@classmethod
async def get_group_user_msg_count(cls, uid: int, gid: int) -> Optional[int]:
"""
说明
说明:
查询群聊指定用户的聊天记录数量
参数
参数:
:param uid: qq
:param gid: 群号
"""
@ -86,9 +86,9 @@ class ChatHistory(db.Model):
date_scope: Optional[Tuple[datetime, datetime]] = None,
) -> Optional[Tuple[int, int]]:
"""
说明
说明:
获取排行数据
参数
参数:
:param gid: 群号
:param limit: 获取数量
:param order: 排序类型descdes
@ -103,9 +103,9 @@ class ChatHistory(db.Model):
@classmethod
async def get_group_first_msg_datetime(cls, gid: int) -> Optional[datetime]:
"""
说明
说明:
获取群第一条记录消息时间
参数
参数:
:param gid:
"""
if (
@ -124,9 +124,9 @@ class ChatHistory(db.Model):
days: Optional[int] = None,
) -> int:
"""
说明
说明:
获取用户消息数量
参数
参数:
:param uid: 用户qq
:param msg_type: 消息类型私聊或群聊
:param days: 限制日期
@ -142,9 +142,9 @@ class ChatHistory(db.Model):
days: Optional[int] = None,
) -> List["ChatHistory"]:
"""
说明
说明:
获取群聊消息
参数
参数:
:param gid: 用户qq
:param days: 限制日期
"""
@ -157,9 +157,9 @@ class ChatHistory(db.Model):
days: Optional[int] = None,
) -> List["ChatHistory"]:
"""
说明
说明:
获取群聊消息数量
参数
参数:
:param gid: 用户qq
:param days: 限制日期
"""
@ -178,9 +178,9 @@ class ChatHistory(db.Model):
is_select_count: bool = False,
):
"""
说明
说明:
获取消息查询query
参数
参数:
:param uid: 用户qq
:param gid: 群号
:param type_: 类型私聊或群聊

View File

@ -15,9 +15,9 @@ class FriendUser(db.Model):
@classmethod
async def get_user_name(cls, user_id: int) -> str:
"""
说明
说明:
获取好友用户名称
参数
参数:
:param user_id: qq号
"""
query = cls.query.where(cls.user_id == user_id)
@ -30,9 +30,9 @@ class FriendUser(db.Model):
@classmethod
async def add_friend_info(cls, user_id: int, user_name: str) -> bool:
"""
说明
说明:
添加好友信息
参数
参数:
:param user_id: qq号
:param user_name: 用户名称
"""
@ -55,9 +55,9 @@ class FriendUser(db.Model):
@classmethod
async def delete_friend_info(cls, user_id: int) -> bool:
"""
说明
说明:
删除好友信息
参数
参数:
:param user_id: qq号
"""
try:
@ -72,9 +72,9 @@ class FriendUser(db.Model):
@classmethod
async def get_friend_nickname(cls, user_id: int) -> str:
"""
说明
说明:
获取用户昵称
参数
参数:
:param user_id: qq号
"""
query = cls.query.where(cls.user_id == user_id)
@ -92,9 +92,9 @@ class FriendUser(db.Model):
@classmethod
async def set_friend_nickname(cls, user_id: int, nickname: str) -> bool:
"""
说明
说明:
设置用户昵称
参数
参数:
:param user_id: qq号
:param nickname: 昵称
"""

View File

@ -30,9 +30,9 @@ class GoodsInfo(db.Model):
daily_limit: int = 0,
) -> bool:
"""
说明
说明:
添加商品
参数
参数:
:param goods_name: 商品名称
:param goods_price: 商品价格
:param goods_description: 商品简介
@ -58,9 +58,9 @@ class GoodsInfo(db.Model):
@classmethod
async def delete_goods(cls, goods_name: str) -> bool:
"""
说明
说明:
删除商品
参数
参数:
:param goods_name: 商品名称
"""
query = (
@ -84,9 +84,9 @@ class GoodsInfo(db.Model):
daily_limit: Optional[int] = None
) -> bool:
"""
说明
说明:
更新商品信息
参数
参数:
:param goods_name: 商品名称
:param goods_price: 商品价格
:param goods_description: 商品简介
@ -117,9 +117,9 @@ class GoodsInfo(db.Model):
@classmethod
async def get_goods_info(cls, goods_name: str) -> "GoodsInfo":
"""
说明
说明:
获取商品对象
参数
参数:
:param goods_name: 商品名称
"""
return await cls.query.where(cls.goods_name == goods_name).gino.first()
@ -127,7 +127,7 @@ class GoodsInfo(db.Model):
@classmethod
async def get_all_goods(cls) -> List["GoodsInfo"]:
"""
说明
说明:
获得全部有序商品对象
"""
query = await cls.query.gino.all()
@ -144,9 +144,9 @@ class GoodsInfo(db.Model):
cls, goods: "GoodsInfo", user_id: int, group_id: int, num: int = 1
):
"""
说明
说明:
添加用户明日购买限制
参数
参数:
:param goods: 商品
:param user_id: 用户id
:param group_id: 群号
@ -167,9 +167,9 @@ class GoodsInfo(db.Model):
cls, goods: "GoodsInfo", user_id: int, group_id: int, num: int = 1
) -> Tuple[bool, int]:
"""
说明
说明:
检测用户每日购买上限
参数
参数:
:param goods: 商品
:param user_id: 用户id
:param group_id: 群号

View File

@ -17,9 +17,9 @@ class GroupInfo(db.Model):
@classmethod
async def get_group_info(cls, group_id: int) -> "GroupInfo":
"""
说明
说明:
获取群信息
参数
参数:
:param group_id: 群号
"""
query = cls.query.where(cls.group_id == group_id)
@ -35,9 +35,9 @@ class GroupInfo(db.Model):
group_flag: Optional[int] = None,
) -> bool:
"""
说明
说明:
添加群信息
参数
参数:
:param group_id: 群号
:param group_name: 群名称
:param max_member_count: 群员最大数量
@ -74,9 +74,9 @@ class GroupInfo(db.Model):
@classmethod
async def delete_group_info(cls, group_id: int):
"""
说明
说明:
删除群信息
参数
参数:
:param group_id: 群号
"""
await cls.delete.where(cls.group_id == group_id).gino.status()
@ -84,7 +84,7 @@ class GroupInfo(db.Model):
@classmethod
async def get_all_group(cls) -> List["GroupInfo"]:
"""
说明
说明:
获取所有群对象
"""
query = await cls.query.gino.all()

View File

@ -27,9 +27,9 @@ class GroupInfoUser(db.Model):
uid: Optional[int] = None,
) -> bool:
"""
说明
说明:
添加群内用户信息
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param user_name: 用户名称
@ -57,9 +57,9 @@ class GroupInfoUser(db.Model):
cls, user_qq: int, group_id: int
) -> "GroupInfoUser":
"""
说明
说明:
查询群员信息
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -71,9 +71,9 @@ class GroupInfoUser(db.Model):
@classmethod
async def delete_member_info(cls, user_qq: int, group_id: int) -> bool:
"""
说明
说明:
删除群员信息
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -96,9 +96,9 @@ class GroupInfoUser(db.Model):
@classmethod
async def get_group_member_id_list(cls, group_id: int) -> List[int]:
"""
说明
说明:
获取该群所有用户qq
参数
参数:
:param group_id: 群号
"""
member_list = []
@ -112,9 +112,9 @@ class GroupInfoUser(db.Model):
cls, user_qq: int, group_id: int, nickname: str
) -> bool:
"""
说明
说明:
设置群员在该群内的昵称
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param nickname: 昵称
@ -131,9 +131,9 @@ class GroupInfoUser(db.Model):
@classmethod
async def get_user_all_group(cls, user_qq: int) -> List[int]:
"""
说明
说明:
获取该用户所在的所有群聊
参数
参数:
:param user_qq: 用户qq
"""
query = await cls.query.where(cls.user_qq == user_qq).gino.all()
@ -144,9 +144,9 @@ class GroupInfoUser(db.Model):
@classmethod
async def get_group_member_nickname(cls, user_qq: int, group_id: int) -> str:
"""
说明
说明:
获取用户在该群的昵称
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""

View File

@ -17,9 +17,9 @@ class LevelUser(db.Model):
@classmethod
async def get_user_level(cls, user_qq: int, group_id: int) -> int:
"""
说明
说明:
获取用户在群内的等级
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -35,9 +35,9 @@ class LevelUser(db.Model):
cls, user_qq: int, group_id: int, level: int, group_flag: int = 0
) -> bool:
"""
说明
说明:
设置用户在群内的权限
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param level: 权限等级
@ -64,9 +64,9 @@ class LevelUser(db.Model):
@classmethod
async def delete_level(cls, user_qq: int, group_id: int) -> bool:
"""
说明
说明:
删除用户权限
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -82,9 +82,9 @@ class LevelUser(db.Model):
@classmethod
async def check_level(cls, user_qq: int, group_id: int, level: int) -> bool:
"""
说明
说明:
检查用户权限等级是否大于 level
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param level: 权限等级
@ -112,9 +112,9 @@ class LevelUser(db.Model):
@classmethod
async def is_group_flag(cls, user_qq: int, group_id: int) -> bool:
"""
说明
说明:
检测是否会被自动更新刷新权限
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""

View File

@ -80,9 +80,9 @@ class SignGroupUser(db.Model):
@classmethod
async def get_all_impression(cls, group_id: int) -> "list, list, list":
"""
说明
说明:
获取该群所有用户 id 及对应 好感度
参数
参数:
:param group_id: 群号
"""
impression_list = []

View File

@ -25,9 +25,9 @@ class BlackWord(db.Model):
punish_level: int,
):
"""
说明
说明:
添加用户发送的敏感词
参数
参数:
:param user_qq: 用户id
:param group_id: 群号
:param black_word: 黑名单词汇
@ -52,9 +52,9 @@ class BlackWord(db.Model):
id_: Optional[int] = None,
) -> bool:
"""
说明
说明:
设置处罚
参数
参数:
:param user_qq: 用户id
:param punish: 处罚
:param black_word: 黑名单词汇
@ -81,9 +81,9 @@ class BlackWord(db.Model):
cls, user_qq: int, days: int = 7, punish_level: Optional[int] = None
) -> int:
"""
说明
说明:
获取用户规定周期内的犯事次数
参数
参数:
:param user_qq: 用户qq
:param days: 周期天数
:param punish_level: 惩罚等级
@ -101,9 +101,9 @@ class BlackWord(db.Model):
@classmethod
async def get_user_punish_level(cls, user_qq: int, days: int = 7) -> Optional[int]:
"""
说明
说明:
获取用户最近一次的惩罚记录等级
参数
参数:
:param user_qq: 用户qq
:param days: 周期天数
"""
@ -125,9 +125,9 @@ class BlackWord(db.Model):
date_type: str = "=",
) -> List["BlackWord"]:
"""
说明
说明:
通过指定条件查询数据
参数
参数:
:param user_qq: 用户qq
:param group_id: 群号
:param date: 日期

View File

@ -71,7 +71,6 @@ async def _(bot: Bot):
)
@restart.got("flag", prompt=f"确定是否重启{NICKNAME}?确定请回复[是|好|确定](重启失败咱们将失去联系,请谨慎!)")
async def _(flag: str = ArgStr("flag")):
if flag.lower() in ["true", "", "", "确定", "确定是"]:

View File

@ -30,7 +30,7 @@ class Map:
ratio: float = 1,
):
"""
参数
参数:
:param resource_name: 资源名称
:param center_point: 中心点
:param deviation: 坐标误差

View File

@ -25,9 +25,9 @@ class Genshin(db.Model):
@classmethod
async def add_uid(cls, user_qq: int, uid: int):
"""
说明
说明:
添加一个uid
参数
参数:
:param user_qq 用户qq
:param uid: 原神uid
"""
@ -44,9 +44,9 @@ class Genshin(db.Model):
@classmethod
async def set_mys_id(cls, uid: int, mys_id: int) -> bool:
"""
说明
说明:
设置米游社id
参数
参数:
:param uid: 原神uid
:param mys_id: 米游社id
"""
@ -60,9 +60,9 @@ class Genshin(db.Model):
@classmethod
async def set_bind_group(cls, uid: int, bind_group) -> bool:
"""
说明
说明:
绑定group_id除私聊外的提醒将在此群发送
参数
参数:
:param uid: uid
:param bind_group: 群号
"""
@ -76,9 +76,9 @@ class Genshin(db.Model):
@classmethod
async def get_bind_group(cls, uid: int) -> Optional[int]:
"""
说明
说明:
获取用户绑定的群聊
参数
参数:
:param uid: uid
"""
user = await cls.query.where(cls.uid == uid).gino.first()
@ -89,9 +89,9 @@ class Genshin(db.Model):
@classmethod
async def set_cookie(cls, uid: int, cookie: str) -> bool:
"""
说明
说明:
设置cookie
参数
参数:
:param uid: 原神uid
:param cookie: 米游社id
"""
@ -105,9 +105,9 @@ class Genshin(db.Model):
@classmethod
async def set_resin_remind(cls, uid: int, flag: bool) -> bool:
"""
说明
说明:
设置体力提醒
参数
参数:
:param uid: 原神uid
:param flag: 开关状态
"""
@ -121,9 +121,9 @@ class Genshin(db.Model):
@classmethod
async def set_user_resin_recovery_time(cls, uid: int, date: datetime):
"""
说明
说明:
设置体力完成时间
参数
参数:
:param uid: uid
:param date: 提醒日期
"""
@ -134,9 +134,9 @@ class Genshin(db.Model):
@classmethod
async def get_user_resin_recovery_time(cls, uid: int) -> Optional[datetime]:
"""
说明
说明:
获取体力完成时间
参数
参数:
:param uid: uid
"""
u = await cls.query.where(cls.uid == uid).gino.first()
@ -147,7 +147,7 @@ class Genshin(db.Model):
@classmethod
async def get_all_resin_remind_user(cls) -> List["Genshin"]:
"""
说明
说明:
获取所有开启体力提醒的用户
"""
return await cls.query.where(cls.resin_remind == True).gino.all()
@ -155,9 +155,9 @@ class Genshin(db.Model):
@classmethod
async def clear_resin_remind_time(cls, uid: int) -> bool:
"""
说明
说明:
清空提醒日期
参数
参数:
:param uid: uid
"""
user = await cls.query.where(cls.uid == uid).gino.first()
@ -169,9 +169,9 @@ class Genshin(db.Model):
@classmethod
async def set_auto_sign(cls, uid: int, flag: bool) -> bool:
"""
说明
说明:
设置米游社/原神自动签到
参数
参数:
:param uid: 原神uid
:param flag: 开关状态
"""
@ -185,7 +185,7 @@ class Genshin(db.Model):
@classmethod
async def get_all_auto_sign_user(cls) -> List["Genshin"]:
"""
说明
说明:
获取所有开启自动签到的用户
"""
return await cls.query.where(cls.auto_sign == True).gino.all()
@ -193,7 +193,7 @@ class Genshin(db.Model):
@classmethod
async def get_all_sign_user(cls) -> List["Genshin"]:
"""
说明
说明:
获取 原神 所有今日签到用户
"""
return await cls.query.where(cls.auto_sign_time != None).gino.all()
@ -201,9 +201,9 @@ class Genshin(db.Model):
@classmethod
async def clear_sign_time(cls, uid: int) -> bool:
"""
说明
说明:
清空签到日期
参数
参数:
:param uid: uid
"""
user = await cls.query.where(cls.uid == uid).gino.first()
@ -215,9 +215,9 @@ class Genshin(db.Model):
@classmethod
async def random_sign_time(cls, uid: int) -> Optional[datetime]:
"""
说明
说明:
随机签到时间
说明
说明:
:param uid: uid
"""
query = cls.query.where(cls.uid == uid).with_for_update()
@ -245,9 +245,9 @@ class Genshin(db.Model):
@classmethod
async def get_query_cookie(cls, uid: int) -> Optional[str]:
"""
说明
说明:
获取查询角色信息cookie
参数
参数:
:param uid: 原神uid
"""
# 查找用户今日是否已经查找过,防止重复
@ -265,9 +265,9 @@ class Genshin(db.Model):
@classmethod
async def get_user_cookie(cls, uid: int, flag: bool = False) -> Optional[str]:
"""
说明
说明:
获取用户cookie
参数
参数:
:param uid原神uid
:param flag必须使用自己的cookie
"""
@ -279,9 +279,9 @@ class Genshin(db.Model):
@classmethod
async def get_user_by_qq(cls, user_qq: int) -> Optional["Genshin"]:
"""
说明
说明:
通过qq获取用户对象
参数
参数:
:param user_qq: qq
"""
return await cls.query.where(cls.user_qq == user_qq).gino.first()
@ -289,9 +289,9 @@ class Genshin(db.Model):
@classmethod
async def get_user_by_uid(cls, uid: int) -> Optional["Genshin"]:
"""
说明
说明:
通过uid获取用户对象
参数
参数:
:param uid: qq
"""
return await cls.query.where(cls.uid == uid).gino.first()
@ -299,9 +299,9 @@ class Genshin(db.Model):
@classmethod
async def get_user_uid(cls, user_qq: int) -> Optional[int]:
"""
说明
说明:
获取用户uid
参数
参数:
:param user_qq用户qq
"""
return await cls._get_user_data(user_qq, None, "uid")
@ -311,7 +311,7 @@ class Genshin(db.Model):
"""
说嘛
获取用户米游社id
参数
参数:
:param uid原神id
"""
return await cls._get_user_data(None, uid, "mys_id")
@ -319,9 +319,9 @@ class Genshin(db.Model):
@classmethod
async def delete_user_cookie(cls, uid: int):
"""
说明
说明:
删除用户cookie
参数
参数:
:param uid: 原神uid
"""
query = cls.query.where(cls.uid == uid).with_for_update()
@ -332,9 +332,9 @@ class Genshin(db.Model):
@classmethod
async def delete_user(cls, user_qq: int):
"""
说明
说明:
删除用户数据
参数
参数:
:param user_qq 用户qq
"""
query = cls.query.where(cls.user_qq == user_qq).with_for_update()
@ -347,9 +347,9 @@ class Genshin(db.Model):
@classmethod
async def _add_query_uid(cls, uid: int, cookie_uid: int):
"""
说明
说明:
添加每日查询重复uid的cookie
参数
参数:
:param uid: 原神uid
:param cookie_uid: cookie的uid
"""
@ -362,9 +362,9 @@ class Genshin(db.Model):
cls, user_qq: Optional[int], uid: Optional[int], type_: str
) -> Optional[Union[int, str]]:
"""
说明
说明:
获取用户数据
参数
参数:
:param user_qq 用户qq
:param uid: uid
:param type_: 数据类型

View File

@ -18,9 +18,9 @@ class RedbagUser(db.Model):
@classmethod
async def add_redbag_data(cls, user_qq: int, group_id: int, itype: str, money: int):
"""
说明
说明:
添加收发红包数据
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param itype: 收或发
@ -45,9 +45,9 @@ class RedbagUser(db.Model):
@classmethod
async def ensure(cls, user_qq: int, group_id: int) -> bool:
"""
说明
说明:
获取用户对象
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -61,9 +61,9 @@ class RedbagUser(db.Model):
@classmethod
async def get_user_all(cls, group_id: int = None) -> List["RedbagUser"]:
"""
说明
说明:
获取所有用户对象
参数
参数:
:param group_id: 群号
"""
if not group_id:

View File

@ -31,7 +31,7 @@ async def open_case(user_qq: int, group: int, case_name: str = "狂牙大行动"
async with db.transaction():
user = await OpenCasesUser.ensure(user_qq, group, for_update=True)
# 一天次数上限
if user.today_open_total == int(
if user.today_open_total > int(
Config.get_config("open_cases", "INITIAL_OPEN_CASE_COUNT")
+ int(impression)
/ Config.get_config("open_cases", "EACH_IMPRESSION_ADD_COUNT")

View File

@ -38,9 +38,9 @@ class OmegaPixivIllusts(db.Model):
updated_at: datetime,
):
"""
说明
说明:
添加图片信息
参数
参数:
:param pid: pid
:param title: 标题
:param width: 宽度
@ -78,9 +78,9 @@ class OmegaPixivIllusts(db.Model):
num: int = 100
) -> List[Optional["OmegaPixivIllusts"]]:
"""
说明
说明:
查找符合条件的图片
参数
参数:
:param keywords: 关键词
:param uid: 画师uid
:param pid: 图片pid
@ -104,9 +104,9 @@ class OmegaPixivIllusts(db.Model):
@classmethod
async def check_exists(cls, pid: int) -> bool:
"""
说明
说明:
检测pid是否已存在
参数
参数:
:param pid: 图片PID
"""
query = await cls.query.where(cls.pid == pid).gino.all()
@ -115,9 +115,9 @@ class OmegaPixivIllusts(db.Model):
@classmethod
async def get_keyword_num(cls, tags: List[str] = None) -> "int, int, int":
"""
说明
说明:
获取相关关键词(keyword, tag)在图库中的数量
参数
参数:
:param tags: 关键词/Tag
"""
setattr(OmegaPixivIllusts, 'count', db.func.count(cls.pid).label('count'))
@ -133,7 +133,7 @@ class OmegaPixivIllusts(db.Model):
@classmethod
async def get_all_pid(cls) -> List[int]:
"""
说明
说明:
获取所有图片PID
"""
data = await cls.select('pid').gino.all()

View File

@ -38,9 +38,9 @@ class Pixiv(db.Model):
tags: str,
):
"""
说明
说明:
添加图片信息
参数
参数:
:param pid: pid
:param title: 标题
:param width: 宽度
@ -74,9 +74,9 @@ class Pixiv(db.Model):
@classmethod
async def remove_image_data(cls, pid: int, img_p: str) -> bool:
"""
说明
说明:
删除图片数据
参数
参数:
:param pid: 图片pid
:param img_p: 图片pid的张数p0p1
"""
@ -94,7 +94,7 @@ class Pixiv(db.Model):
@classmethod
async def get_all_pid(cls) -> List[int]:
"""
说明
说明:
获取所有PID
"""
query = await cls.query.select("pid").gino.first()
@ -112,9 +112,9 @@ class Pixiv(db.Model):
num: int = 100
) -> List[Optional["Pixiv"]]:
"""
说明
说明:
查找符合条件的图片
参数
参数:
:param keywords: 关键词
:param uid: 画师uid
:param pid: 图片pid
@ -140,9 +140,9 @@ class Pixiv(db.Model):
@classmethod
async def check_exists(cls, pid: int, img_p: str) -> bool:
"""
说明
说明:
检测pid是否已存在
参数
参数:
:param pid: 图片PID
:param img_p: 张数
"""
@ -154,9 +154,9 @@ class Pixiv(db.Model):
@classmethod
async def get_keyword_num(cls, tags: List[str] = None) -> "int, int":
"""
说明
说明:
获取相关关键词(keyword, tag)在图库中的数量
参数
参数:
:param tags: 关键词/Tag
"""
setattr(Pixiv, 'count', db.func.count(cls.pid).label('count'))

View File

@ -19,9 +19,9 @@ class PixivKeywordUser(db.Model):
cls, user_qq: int, group_id: int, keyword: str, superusers: Set[str]
) -> bool:
"""
说明
说明:
添加搜图的关键词
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param keyword: 关键词
@ -38,9 +38,9 @@ class PixivKeywordUser(db.Model):
@classmethod
async def delete_keyword(cls, keyword: str) -> bool:
"""
说明
说明:
删除关键词
参数
参数:
:param keyword: 关键词
"""
if await cls._check_keyword_exists(keyword):
@ -53,9 +53,9 @@ class PixivKeywordUser(db.Model):
@classmethod
async def set_keyword_pass(cls, keyword: str, is_pass: bool) -> "int, int":
"""
说明
说明:
通过或禁用关键词
参数
参数:
:param keyword: 关键词
:param is_pass: 通过状态
"""
@ -71,7 +71,7 @@ class PixivKeywordUser(db.Model):
@classmethod
async def get_all_user_dict(cls) -> dict:
"""
说明
说明:
获取关键词数据库各个用户贡献的关键词字典
"""
tmp = {}
@ -85,7 +85,7 @@ class PixivKeywordUser(db.Model):
@classmethod
async def get_current_keyword(cls) -> "List[str], List[str]":
"""
说明
说明:
获取当前通过与未通过的关键词
"""
pass_keyword = []
@ -101,7 +101,7 @@ class PixivKeywordUser(db.Model):
@classmethod
async def get_black_pid(cls) -> List[str]:
"""
说明
说明:
获取黑名单PID
"""
black_pid = []
@ -113,9 +113,9 @@ class PixivKeywordUser(db.Model):
@classmethod
async def _check_keyword_exists(cls, keyword: str) -> bool:
"""
说明
说明:
检测关键词是否已存在
参数
参数:
:param keyword: 关键词
"""
current_keyword = []

View File

@ -184,7 +184,7 @@ async def _():
logger.info(f"添加OmegaPixivIllusts图库数据已存在 ---> pid{pid}")
omega_pixiv_illusts = None
for file in os.listdir("."):
if "omega_pixiv_illusts" in file and ".sql" in file:
if "omega_pixiv_artwork" in file and ".sql" in file:
omega_pixiv_illusts = Path() / file
if omega_pixiv_illusts:
with open(omega_pixiv_illusts, "r", encoding="utf8") as f:

View File

@ -17,7 +17,7 @@ __zx_plugin_name__ = "P站排行/搜图"
__plugin_usage__ = """
usage
P站排行
可选参数
可选参数:
类型
1. 日排行
2. 周排行

View File

@ -23,9 +23,9 @@ class RussianUser(db.Model):
@classmethod
async def ensure(cls, user_qq: int, group_id: int) -> "RussianUser":
"""
说明
说明:
获取用户对象
参数
参数:
:param user_qq: qq号
:param group_id: 群号
"""
@ -39,9 +39,9 @@ class RussianUser(db.Model):
@classmethod
async def add_count(cls, user_qq: int, group_id: int, itype: str) -> bool:
"""
说明
说明:
添加用户输赢次数
说明
说明:
:param user_qq: qq号
:param group_id: 群号
:param itype: 输或赢 'win' or 'lose'
@ -87,9 +87,9 @@ class RussianUser(db.Model):
@classmethod
async def money(cls, user_qq: int, group_id: int, itype: str, count: int) -> bool:
"""
说明
说明:
添加用户输赢金钱
参数
参数:
:param user_qq: qq号
:param group_id: 群号
:param itype: 输或赢 'win' or 'lose'
@ -120,9 +120,9 @@ class RussianUser(db.Model):
@classmethod
async def get_all_user(cls, group_id: int) -> List["RussianUser"]:
"""
说明
说明:
获取该群所有用户对象
参数
参数:
:param group_id: 群号
"""
users = await cls.query.where((cls.group_id == group_id)).gino.all()

View File

@ -30,9 +30,9 @@ class Setu(db.Model):
tags: str,
):
"""
说明
说明:
添加一份色图数据
参数
参数:
:param local_id: 本地存储id
:param title: 标题
:param author: 作者
@ -62,9 +62,9 @@ class Setu(db.Model):
limit: int = 50,
):
"""
说明
说明:
通过tag查找色图
参数
参数:
:param local_id: 本地色图 id
:param tags: tags
:param r18: 是否 r180非r18 1r18 2混合
@ -90,7 +90,7 @@ class Setu(db.Model):
@classmethod
async def get_image_count(cls, r18: int = 0) -> int:
"""
说明
说明:
查询图片数量
"""
flag = False if r18 == 0 else True
@ -101,9 +101,9 @@ class Setu(db.Model):
@classmethod
async def get_image_in_hash(cls, img_hash: str) -> "Setu":
"""
说明
说明:
通过图像hash获取图像信息
参数
参数:
:param img_hash: = 图像hash值
"""
query = await cls.query.where(cls.img_hash == img_hash).gino.first()
@ -112,9 +112,9 @@ class Setu(db.Model):
@classmethod
async def _check_exists(cls, pid: int, img_url: str) -> bool:
"""
说明
说明:
检测图片是否存在
参数
参数:
:param pid: 图片pid
:param img_url: 图片链接
"""
@ -127,9 +127,9 @@ class Setu(db.Model):
@classmethod
async def delete_image(cls, pid: int) -> int:
"""
说明
说明:
删除图片并替换
参数
参数:
:param pid: 图片pid
"""
query = await cls.query.where(cls.pid == pid).gino.first()
@ -157,9 +157,9 @@ class Setu(db.Model):
tags: Optional[str] = None,
) -> bool:
"""
说明
说明:
根据PID修改图片数据
参数
参数:
:param local_id: 本地id
:param pid: 图片pid
:param title: 标题
@ -190,7 +190,7 @@ class Setu(db.Model):
@classmethod
async def get_all_setu(cls) -> List["Setu"]:
"""
说明
说明:
获取所有图片对象
"""
return await cls.query.gino.all()

View File

@ -76,7 +76,7 @@ async def _(user: User = Depends(token_to_user)) -> Result:
async def get_system_data(user: User = Depends(token_to_user)):
"""
说明
说明:
获取系统信息资源文件大小网络状态等
"""
baidu = 200
@ -107,7 +107,7 @@ async def get_system_data(user: User = Depends(token_to_user)):
def _get_system_status(user: User = Depends(token_to_user)) -> SystemStatus:
"""
说明
说明:
获取系统信息等
"""
cpu = psutil.cpu_percent()
@ -126,7 +126,7 @@ def _get_system_disk(
type_: Optional[str], user: User = Depends(token_to_user)
) -> Union[SystemFolderSize, Dict[str, Union[float, datetime]]]:
"""
说明
说明:
获取资源文件大小等
"""
if not type_:
@ -171,9 +171,9 @@ def _get_system_disk(
def _get_dir_size(dir_path: Path) -> float:
"""
说明
说明:
获取文件夹大小
参数
参数:
:param dir_path: 文件夹路径
"""
size = 0
@ -184,9 +184,9 @@ def _get_dir_size(dir_path: Path) -> float:
def save_system_data(cpu: float, memory: float, disk: float):
"""
说明
说明:
保存一些系统信息
参数
参数:
:param cpu: cpu
:param memory: memory
:param disk: disk

View File

@ -1,34 +1,34 @@
from configs.config import Config
import nonebot
Config.add_plugin_config(
"word_bank",
"WORD_BANK_LEVEL [LEVEL]",
5,
name="词库问答",
help_="设置增删词库的权限等级",
default_value=5
)
Config.add_plugin_config(
"word_bank",
"WORD_BANK_FUZZY",
False,
help_="模糊匹配",
default_value=False
)
Config.add_plugin_config(
"word_bank",
"WORD_BANK_KEY",
True,
help_="关键字匹配",
default_value=True
)
Config.add_plugin_config(
"word_bank",
"WORD_BANK_MIX",
25,
help_="查看词条时图片内最多显示条数",
default_value=25
)
nonebot.load_plugins("plugins/word_bank")
# from configs.config import Config
# import nonebot
#
# Config.add_plugin_config(
# "word_bank",
# "WORD_BANK_LEVEL [LEVEL]",
# 5,
# name="词库问答",
# help_="设置增删词库的权限等级",
# default_value=5
# )
#
# Config.add_plugin_config(
# "word_bank",
# "WORD_BANK_FUZZY",
# False,
# help_="模糊匹配",
# default_value=False
# )
# Config.add_plugin_config(
# "word_bank",
# "WORD_BANK_KEY",
# True,
# help_="关键字匹配",
# default_value=True
# )
# Config.add_plugin_config(
# "word_bank",
# "WORD_BANK_MIX",
# 25,
# help_="查看词条时图片内最多显示条数",
# default_value=25
# )
# nonebot.load_plugins("plugins/word_bank")

View File

@ -10,9 +10,9 @@ async def init_rank(
title: str, all_user_id: List[int], all_user_data: List[int], group_id: int, total_count: int = 10
) -> BuildMat:
"""
说明
说明:
初始化通用的数据排行榜
参数
参数:
:param title: 排行榜标题
:param all_user_id: 所有用户的qq号
:param all_user_data: 所有用户需要排行的对应数据

View File

@ -37,9 +37,9 @@ class AsyncHttpx:
**kwargs,
) -> Response:
"""
说明
说明:
Get
参数
参数:
:param url: url
:param params: params
:param headers: 请求头
@ -80,9 +80,9 @@ class AsyncHttpx:
**kwargs,
) -> Response:
"""
说明
说明:
Post
参数
参数:
:param url: url
:param data: data
:param content: content
@ -129,9 +129,9 @@ class AsyncHttpx:
**kwargs,
) -> bool:
"""
说明
说明:
下载文件
参数
参数:
:param url: url
:param path: 存储路径
:param params: params
@ -224,9 +224,9 @@ class AsyncHttpx:
**kwargs,
) -> List[bool]:
"""
说明
说明:
分组同时下载文件
参数
参数:
:param url_list: url列表
:param path_list: 存储路径列表
:param limit_async_number: 限制同时请求数量
@ -288,9 +288,9 @@ class AsyncPlaywright:
@classmethod
async def _new_page(cls, user_agent: Optional[str] = None, **kwargs) -> Page:
"""
说明
说明:
获取一个新页面
参数
参数:
:param user_agent: 请求头
"""
browser = await get_browser()
@ -301,9 +301,9 @@ class AsyncPlaywright:
@classmethod
async def new_context(cls, user_agent: Optional[str] = None, **kwargs) -> BrowserContext:
"""
说明
说明:
获取一个新上下文
参数
参数:
:param user_agent: 请求头
"""
browser = await get_browser()
@ -324,9 +324,9 @@ class AsyncPlaywright:
**kwargs
) -> Optional[Page]:
"""
说明
说明:
goto
参数
参数:
:param url: 网址
:param timeout: 超时限制
:param wait_until: 等待类型
@ -360,9 +360,9 @@ class AsyncPlaywright:
**kwargs
) -> Optional[MessageSegment]:
"""
说明
说明:
截图该方法仅用于简单快捷截图复杂截图请操作 page
参数
参数:
:param url: 网址
:param path: 存储路径
:param element: 元素选择

View File

@ -24,9 +24,9 @@ def compare_image_with_hash(
image_file1: str, image_file2: str, max_dif: int = 1.5
) -> bool:
"""
说明
说明:
比较两张图片的hash值是否相同
参数
参数:
:param image_file1: 图片文件路径
:param image_file2: 图片文件路径
:param max_dif: 允许最大hash差值, 越小越精确,最小为0
@ -45,9 +45,9 @@ def compare_image_with_hash(
def get_img_hash(image_file: Union[str, Path]) -> ImageHash:
"""
说明
说明:
获取图片的hash值
参数
参数:
:param image_file: 图片文件路径
"""
with open(image_file, "rb") as fp:
@ -59,9 +59,9 @@ def compressed_image(
in_file: Union[str, Path], out_file: Union[str, Path] = None, ratio: float = 0.9
):
"""
说明
说明:
压缩图片
参数
参数:
:param in_file: 被压缩的文件路径
:param out_file: 压缩后输出的文件路径
:param ratio: 压缩率宽高 * 压缩率
@ -80,9 +80,9 @@ def compressed_image(
def alpha2white_pil(pic: Image) -> Image:
"""
说明
说明:
将图片透明背景转化为白色
参数
参数:
:param pic: 通过PIL打开的图片文件
"""
img = pic.convert("RGBA")
@ -99,9 +99,9 @@ def alpha2white_pil(pic: Image) -> Image:
def pic2b64(pic: Image) -> str:
"""
说明
说明:
PIL图片转base64
参数
参数:
:param pic: 通过PIL打开的图片文件
"""
buf = BytesIO()
@ -112,9 +112,9 @@ def pic2b64(pic: Image) -> str:
def fig2b64(plt_: plt) -> str:
"""
说明
说明:
matplotlib图片转base64
参数
参数:
:param plt_: matplotlib生成的图片
"""
buf = BytesIO()
@ -125,9 +125,9 @@ def fig2b64(plt_: plt) -> str:
def is_valid(file: Union[str, Path]) -> bool:
"""
说明
说明:
判断图片是否损坏
参数
参数:
:param file: 图片文件路径
"""
valid = True
@ -160,7 +160,7 @@ class BuildImage:
font_color: Optional[Union[str, Tuple[int, int, int]]] = None,
):
"""
参数
参数:
:param w: 自定义图片的宽度w=0时为图片原本宽度
:param h: 自定义图片的高度h=0时为图片原本高度
:param paste_image_width: 当图片做为背景图时设置贴图的宽度用于贴图自动换行
@ -241,9 +241,9 @@ class BuildImage:
center_type: Optional[Literal["center", "by_height", "by_width"]] = None,
):
"""
说明
说明:
异步 贴图
参数
参数:
:param img: 已打开的图片文件可以为 BuildImage Image
:param pos: 贴图位置左上角
:param alpha: 图片背景是否为透明
@ -259,9 +259,9 @@ class BuildImage:
center_type: Optional[Literal["center", "by_height", "by_width"]] = None,
):
"""
说明
说明:
贴图
参数
参数:
:param img: 已打开的图片文件可以为 BuildImage Image
:param pos: 贴图位置左上角
:param alpha: 图片背景是否为透明
@ -304,9 +304,9 @@ class BuildImage:
def getsize(self, msg: str) -> Tuple[int, int]:
"""
说明
说明:
获取文字在该图片 font_size 下所需要的空间
参数
参数:
:param msg: 文字内容
"""
return self.font.getsize(msg)
@ -315,9 +315,9 @@ class BuildImage:
self, pos: Tuple[int, int], fill: Optional[Tuple[int, int, int]] = None
):
"""
说明
说明:
异步 绘制多个或单独的像素
参数
参数:
:param pos: 坐标
:param fill: 填错颜色
"""
@ -325,9 +325,9 @@ class BuildImage:
def point(self, pos: Tuple[int, int], fill: Optional[Tuple[int, int, int]] = None):
"""
说明
说明:
绘制多个或单独的像素
参数
参数:
:param pos: 坐标
:param fill: 填错颜色
"""
@ -341,9 +341,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
异步 绘制圆
参数
参数:
:param pos: 坐标范围
:param fill: 填充颜色
:param outline: 描线颜色
@ -359,9 +359,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
绘制圆
参数
参数:
:param pos: 坐标范围
:param fill: 填充颜色
:param outline: 描线颜色
@ -377,9 +377,9 @@ class BuildImage:
center_type: Optional[Literal["center", "by_height", "by_width"]] = None,
):
"""
说明
说明:
异步 在图片上添加文字
参数
参数:
:param pos: 文字位置
:param text: 文字内容
:param fill: 文字颜色
@ -395,9 +395,9 @@ class BuildImage:
center_type: Optional[Literal["center", "by_height", "by_width"]] = None,
):
"""
说明
说明:
在图片上添加文字
参数
参数:
:param pos: 文字位置
:param text: 文字内容
:param fill: 文字颜色
@ -424,18 +424,18 @@ class BuildImage:
async def asave(self, path: Optional[Union[str, Path]] = None):
"""
说明
说明:
异步 保存图片
参数
参数:
:param path: 图片路径
"""
await self.loop.run_in_executor(None, self.save, path)
def save(self, path: Optional[Union[str, Path]] = None):
"""
说明
说明:
保存图片
参数
参数:
:param path: 图片路径
"""
if not path:
@ -444,16 +444,16 @@ class BuildImage:
def show(self):
"""
说明
说明:
显示图片
"""
self.markImg.show(self.markImg)
async def aresize(self, ratio: float = 0, w: int = 0, h: int = 0):
"""
说明
说明:
异步 压缩图片
参数
参数:
:param ratio: 压缩倍率
:param w: 压缩图片宽度至 w
:param h: 压缩图片高度至 h
@ -462,9 +462,9 @@ class BuildImage:
def resize(self, ratio: float = 0, w: int = 0, h: int = 0):
"""
说明
说明:
压缩图片
参数
参数:
:param ratio: 压缩倍率
:param w: 压缩图片宽度至 w
:param h: 压缩图片高度至 h
@ -481,18 +481,18 @@ class BuildImage:
async def acrop(self, box: Tuple[int, int, int, int]):
"""
说明
说明:
异步 裁剪图片
参数
参数:
:param box: 左上角坐标右下角坐标 (left, upper, right, lower)
"""
await self.loop.run_in_executor(None, self.crop, box)
def crop(self, box: Tuple[int, int, int, int]):
"""
说明
说明:
裁剪图片
参数
参数:
:param box: 左上角坐标右下角坐标 (left, upper, right, lower)
"""
self.markImg = self.markImg.crop(box)
@ -502,18 +502,18 @@ class BuildImage:
def check_font_size(self, word: str) -> bool:
"""
说明
说明:
检查文本所需宽度是否大于图片宽度
参数
参数:
:param word: 文本内容
"""
return self.font.getsize(word)[0] > self.w
async def atransparent(self, alpha_ratio: float = 1, n: int = 0):
"""
说明
说明:
异步 图片透明化
参数
参数:
:param alpha_ratio: 透明化程度
:param n: 透明化大小内边距
"""
@ -521,9 +521,9 @@ class BuildImage:
def transparent(self, alpha_ratio: float = 1, n: int = 0):
"""
说明
说明:
图片透明化
参数
参数:
:param alpha_ratio: 透明化程度
:param n: 透明化大小内边距
"""
@ -538,7 +538,7 @@ class BuildImage:
def pic2bs4(self) -> str:
"""
说明
说明:
BuildImage base64
"""
buf = BytesIO()
@ -548,9 +548,9 @@ class BuildImage:
def convert(self, type_: str):
"""
说明
说明:
修改图片类型
参数
参数:
:param type_: 类型
"""
self.markImg = self.markImg.convert(type_)
@ -563,9 +563,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
异步 画框
参数
参数:
:param xy: 坐标
:param fill: 填充颜色
:param outline: 轮廓颜色
@ -581,9 +581,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
画框
参数
参数:
:param xy: 坐标
:param fill: 填充颜色
:param outline: 轮廓颜色
@ -600,7 +600,7 @@ class BuildImage:
"""
说明:
异步 画多边形
参数
参数:
:param xy: 坐标
:param fill: 颜色
:param outline: 线宽
@ -616,7 +616,7 @@ class BuildImage:
"""
说明:
画多边形
参数
参数:
:param xy: 坐标
:param fill: 颜色
:param outline: 线宽
@ -630,9 +630,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
异步 画线
参数
参数:
:param xy: 坐标
:param fill: 填充
:param width: 线宽
@ -646,9 +646,9 @@ class BuildImage:
width: int = 1,
):
"""
说明
说明:
画线
参数
参数:
:param xy: 坐标
:param fill: 填充
:param width: 线宽
@ -657,14 +657,14 @@ class BuildImage:
async def acircle(self):
"""
说明
说明:
异步 BuildImage 图片变为圆形
"""
await self.loop.run_in_executor(None, self.circle)
def circle(self):
"""
说明
说明:
使图像变圆
"""
self.markImg.convert("RGBA")
@ -693,18 +693,18 @@ class BuildImage:
async def acircle_corner(self, radii: int = 30):
"""
说明
说明:
异步 矩形四角变圆
参数
参数:
:param radii: 半径
"""
await self.loop.run_in_executor(None, self.circle_corner, radii)
def circle_corner(self, radii: int = 30):
"""
说明
说明:
矩形四角变圆
参数
参数:
:param radii: 半径
"""
# 画圆用于分离4个角
@ -724,9 +724,9 @@ class BuildImage:
async def arotate(self, angle: int, expand: bool = False):
"""
说明
说明:
异步 旋转图片
参数
参数:
:param angle: 角度
:param expand: 放大图片适应角度
"""
@ -734,9 +734,9 @@ class BuildImage:
def rotate(self, angle: int, expand: bool = False):
"""
说明
说明:
旋转图片
参数
参数:
:param angle: 角度
:param expand: 放大图片适应角度
"""
@ -744,27 +744,27 @@ class BuildImage:
async def atranspose(self, angle: int):
"""
说明
说明:
异步 旋转图片(包括边框)
参数
参数:
:param angle: 角度
"""
await self.loop.run_in_executor(None, self.transpose, angle)
def transpose(self, angle: int):
"""
说明
说明:
旋转图片(包括边框)
参数
参数:
:param angle: 角度
"""
self.markImg.transpose(angle)
async def afilter(self, filter_: str, aud: int = None):
"""
说明
说明:
异步 图片变化
参数
参数:
:param filter_: 变化效果
:param aud: 利率
"""
@ -772,9 +772,9 @@ class BuildImage:
def filter(self, filter_: str, aud: int = None):
"""
说明
说明:
图片变化
参数
参数:
:param filter_: 变化效果
:param aud: 利率
"""
@ -804,9 +804,9 @@ class BuildImage:
replace_color: Tuple[int, int, int],
):
"""
说明
说明:
异步 颜色替换
参数
参数:
:param src_color: 目标颜色或者使用列表设置阈值
:param replace_color: 替换颜色
"""
@ -822,9 +822,9 @@ class BuildImage:
replace_color: Tuple[int, int, int],
):
"""
说明
说明:
颜色替换
参数
参数:
:param src_color: 目标颜色或者使用元祖设置阈值
:param replace_color: 替换颜色
"""
@ -880,9 +880,9 @@ class BuildMat:
bar_color: Optional[List[Union[str, Tuple[int, int, int]]]] = None,
):
"""
说明
说明:
初始化 BuildMat
参数
参数:
:param y: 坐标值
:param mat_type: 图像类型 可能的值[line]: 折线图[bar]: 柱状图[barh]: 横向柱状图
:param x_name: 横坐标名称
@ -981,7 +981,7 @@ class BuildMat:
"""
说明:
给坐标点设置新值
参数
参数:
:param y: 坐标点
"""
self._check_value(y, self.y_index)
@ -991,7 +991,7 @@ class BuildMat:
"""
说明:
设置y轴坐标值
参数
参数:
:param y_index: y轴坐标值
"""
self._check_value(self.y, y_index)
@ -999,9 +999,9 @@ class BuildMat:
def set_title(self, title: str, color: Optional[Union[str, Tuple[int, int, int]]]):
"""
说明
说明:
设置标题
参数
参数:
:param title: 标题
:param color: 字体颜色
"""
@ -1013,9 +1013,9 @@ class BuildMat:
self, background: Optional[List[str]], type_: Optional[str] = None
):
"""
说明
说明:
设置背景图片
参数
参数:
:param background: 图片路径列表
:param type_: 填充类型
"""
@ -1024,32 +1024,32 @@ class BuildMat:
def show(self):
"""
说明
说明:
展示图像
"""
self.markImg.show()
def pic2bs4(self) -> str:
"""
说明
说明:
转base64
"""
return self.markImg.pic2bs4()
def resize(self, ratio: float = 0.9):
"""
说明
说明:
调整图像大小
参数
参数:
:param ratio: 比例
"""
self.markImg.resize(ratio)
def save(self, path: Union[str, Path]):
"""
说明
说明:
保存图片
参数
参数:
:param path: 路径
"""
self.markImg.save(path)
@ -1063,7 +1063,7 @@ class BuildMat:
"""
说明:
检查值合法性
参数
参数:
:param y: 坐标值
:param y_index: y轴坐标值
:param x_index: x轴坐标值
@ -1087,7 +1087,7 @@ class BuildMat:
"""
说明:
生成折线图
参数
参数:
:param y: 坐标点
:param display_num: 显示该点的值
"""
@ -1134,9 +1134,9 @@ class BuildMat:
is_barh: bool = False,
):
"""
说明
说明:
生成柱状图
参数
参数:
:param y: 坐标值
:param display_num: 是否显示数值
:param is_barh: 横柱状图
@ -1216,9 +1216,9 @@ class BuildMat:
is_grid: bool = False,
) -> BuildImage:
"""
说明
说明:
初始化图像生成xy轴
参数
参数:
:param x_name: x轴名称
:param y_name: y轴名称
:param x_index: x轴坐标值
@ -1347,7 +1347,7 @@ async def text2image(
_add_height: float = 0,
) -> BuildImage:
"""
说明
说明:
解析文本并转为图片
使用标签
<f> </f>
@ -1359,7 +1359,7 @@ async def text2image(
在不在<f font=YSHaoShenTi-2.ttf font_size=30 font_color=red>HibiKi小姐</f>
你最近还好吗<f font_size=15 font_color=black>我非常想你</f>这段时间我非常不好过
<f font_size=25>抽卡抽不到金色</f>这让我很痛苦
参数
参数:
:param text: 文本
:param auto_parse: 是否自动解析否则原样发送
:param font_size: 普通字体大小

View File

@ -31,9 +31,9 @@ class GroupManager(StaticData):
def block_plugin(self, module: str, group_id: int):
"""
说明
说明:
锁定插件
参数
参数:
:param module: 功能模块名
:param group_id: 群组None时为超级用户禁用
"""
@ -41,9 +41,9 @@ class GroupManager(StaticData):
def unblock_plugin(self, module: str, group_id: int):
"""
说明
说明:
解锁插件
参数
参数:
:param module: 功能模块名
:param group_id: 群组
"""
@ -51,27 +51,27 @@ class GroupManager(StaticData):
def turn_on_group_bot_status(self, group_id: int):
"""
说明
说明:
开启群bot开关
参数
参数:
:param group_id: 群号
"""
self._set_group_bot_status(group_id, True)
def shutdown_group_bot_status(self, group_id: int):
"""
说明
说明:
关闭群bot开关
参数
参数:
:param group_id: 群号
"""
self._set_group_bot_status(group_id, False)
def check_group_bot_status(self, group_id: int) -> bool:
"""
说明
说明:
检查群聊bot总开关状态
参数
参数:
:param group_id: 说明
"""
group_id = str(group_id)
@ -86,9 +86,9 @@ class GroupManager(StaticData):
def set_group_level(self, group_id: int, level: int):
"""
说明
说明:
设置群权限
参数
参数:
:param group_id: 群组
:param level: 权限等级
"""
@ -100,9 +100,9 @@ class GroupManager(StaticData):
def get_plugin_status(self, module: str, group_id: int) -> bool:
"""
说明
说明:
获取插件状态
参数
参数:
:param module: 功能模块名
:param group_id: 群组
"""
@ -116,9 +116,9 @@ class GroupManager(StaticData):
def get_group_level(self, group_id: int) -> int:
"""
说明
说明:
获取群等级
参数
参数:
:param group_id: 群号
"""
group_id = str(group_id)
@ -128,18 +128,18 @@ class GroupManager(StaticData):
def check_group_is_white(self, group_id: int) -> bool:
"""
说明
说明:
检测群聊是否在白名单
参数
参数:
:param group_id: 群号
"""
return group_id in self._data["super"]["white_group_list"]
def add_group_white_list(self, group_id: int):
"""
说明
说明:
将群聊加入白名单
参数
参数:
:param group_id: 群号
"""
if group_id not in self._data["super"]["white_group_list"]:
@ -147,9 +147,9 @@ class GroupManager(StaticData):
def delete_group_white_list(self, group_id: int):
"""
说明
说明:
将群聊从白名单中删除
参数
参数:
:param group_id: 群号
"""
if group_id in self._data["super"]["white_group_list"]:
@ -157,16 +157,16 @@ class GroupManager(StaticData):
def get_group_white_list(self) -> List[str]:
"""
说明
说明:
获取所有群白名单
"""
return self._data["super"]["white_group_list"]
def delete_group(self, group_id: int):
"""
说明
说明:
删除群配置
参数
参数:
:param group_id: 群号
"""
if group_id in self._data["group_manager"]:
@ -177,9 +177,9 @@ class GroupManager(StaticData):
async def open_group_task(self, group_id: int, task: str):
"""
说明
说明:
开启群被动技能
参数
参数:
:param group_id: 群号
:param task: 被动技能名称
"""
@ -187,9 +187,9 @@ class GroupManager(StaticData):
async def close_group_task(self, group_id: int, task: str):
"""
说明
说明:
关闭群被动技能
参数
参数:
:param group_id: 群号
:param task: 被动技能名称
"""
@ -197,9 +197,9 @@ class GroupManager(StaticData):
async def check_group_task_status(self, group_id: int, task: str) -> bool:
"""
说明
说明:
查看群被动技能状态
参数
参数:
:param group_id: 群号
:param task: 被动技能名称
"""
@ -214,16 +214,16 @@ class GroupManager(StaticData):
def get_task_data(self) -> Dict[str, str]:
"""
说明
说明:
获取所有被动任务
"""
return self._task
async def group_task_status(self, group_id: int) -> str:
"""
说明
说明:
查看群被全部动技能状态
参数
参数:
:param group_id: 群号
"""
x = "[群被动技能]:\n"
@ -236,9 +236,9 @@ class GroupManager(StaticData):
async def _set_group_task_status(self, group_id: int, task: str, status: bool):
"""
说明
说明:
管理群被动技能状态
参数
参数:
:param group_id: 群号
:param task: 被动技能
:param status: 状态
@ -257,7 +257,7 @@ class GroupManager(StaticData):
async def init_group_task(self, group_id: Optional[Union[int, str]] = None):
"""
说明
说明:
初始化群聊 被动技能 状态
"""
if not self._task:
@ -313,9 +313,9 @@ class GroupManager(StaticData):
group_id: int,
):
"""
说明
说明:
设置功能开关状态
参数
参数:
:param module: 功能模块名
:param status: 功能状态
:param group_id: 群组
@ -333,9 +333,9 @@ class GroupManager(StaticData):
def _init_group(self, group_id: str):
"""
说明
说明:
初始化群数据
参数
参数:
:param group_id: 群号
"""
default_group_level = Config.get_config("group_manager", "DEFAULT_GROUP_LEVEL")
@ -354,9 +354,9 @@ class GroupManager(StaticData):
def _set_group_bot_status(self, group_id: Union[int, str], status: bool):
"""
说明
说明:
设置群聊bot总开关
参数
参数:
:param group_id: 群号
:param status: 开关状态
"""
@ -368,7 +368,7 @@ class GroupManager(StaticData):
def get_super_old_data(self) -> Optional[dict]:
"""
说明
说明:
获取旧数据平时使用请不要调用
"""
if self._data["super"].get("close_plugins"):

View File

@ -48,9 +48,9 @@ class PluginsManager(StaticData):
self, module: str, group_id: Optional[int] = None, block_type: str = "all"
):
"""
说明
说明:
锁定插件
参数
参数:
:param module: 功能模块名
:param group_id: 群组None时为超级用户禁用
:param block_type: 限制类型
@ -59,9 +59,9 @@ class PluginsManager(StaticData):
def unblock_plugin(self, module: str, group_id: Optional[int] = None):
"""
说明
说明:
解锁插件
参数
参数:
:param module: 功能模块名
:param group_id: 群组
"""
@ -71,9 +71,9 @@ class PluginsManager(StaticData):
self, module: str, block_type: str = "all"
) -> bool:
"""
说明
说明:
获取插件状态
参数
参数:
:param module: 功能模块名
:param block_type: 限制类型
"""
@ -86,9 +86,9 @@ class PluginsManager(StaticData):
def get_plugin_block_type(self, module: str) -> str:
"""
说明
说明:
获取功能限制类型
参数
参数:
:param module: 模块名称
"""
if module in self._data.keys():
@ -112,9 +112,9 @@ class PluginsManager(StaticData):
block_type: str = "all",
):
"""
说明
说明:
设置功能开关状态
参数
参数:
:param module: 功能模块名
:param status: 功能状态
:param group_id: 群组

View File

@ -8,9 +8,9 @@ class WithdrawMessageManager:
def append(self, message_data: Tuple[Union[int, Dict[str, int]], int]):
"""
说明
说明:
添加一个撤回消息id和时间
参数
参数:
:param message_data: 撤回消息id和时间
"""
if isinstance(message_data[0], dict):
@ -19,9 +19,9 @@ class WithdrawMessageManager:
def remove(self, message_data: Tuple[int, int]):
"""
说明
说明:
删除一个数据
参数
参数:
:param message_data: 消息id和时间
"""
self.data.remove(message_data)

View File

@ -13,10 +13,10 @@ def image(
b64: str = None,
) -> Union[MessageSegment, str]:
"""
说明
说明:
生成一个 MessageSegment.image 消息
生成顺序绝对路径(abspath) > base64(b64) > img_name
参数
参数:
:param file: 图片文件名称默认在 resource/img 目录下
:param path: 图片所在路径默认在 resource/img 目录下
:param b64: 图片base64
@ -42,11 +42,11 @@ def image(
return ""
def at(qq: int) -> MessageSegment:
def at(qq: Union[int, str]) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.at 消息
参数
参数:
:param qq: qq号
"""
return MessageSegment.at(qq)
@ -54,9 +54,9 @@ def at(qq: int) -> MessageSegment:
def record(voice_name: str, path: str = None) -> MessageSegment or str:
"""
说明
说明:
生成一个 MessageSegment.record 消息
参数
参数:
:param voice_name: 音频文件名称默认在 resource/voice 目录下
:param path: 音频文件路径默认在 resource/voice 目录下
"""
@ -79,9 +79,9 @@ def record(voice_name: str, path: str = None) -> MessageSegment or str:
def text(msg: str) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.text 消息
参数
参数:
:param msg: 消息文本
"""
return MessageSegment.text(msg)
@ -89,9 +89,9 @@ def text(msg: str) -> MessageSegment:
def contact_user(qq: int) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.contact_user 消息
参数
参数:
:param qq: qq号
"""
return MessageSegment.contact_user(qq)
@ -101,9 +101,9 @@ def share(
url: str, title: str, content: str = None, image_url: str = None
) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.share 消息
参数
参数:
:param url: 自定义分享的链接
:param title: 自定义分享的包体
:param content: 自定义分享的内容
@ -114,9 +114,9 @@ def share(
def xml(data: str) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.xml 消息
参数
参数:
:param data: 数据文本
"""
return MessageSegment.xml(data)
@ -124,9 +124,9 @@ def xml(data: str) -> MessageSegment:
def json(data: str) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.json 消息
参数
参数:
:param data: 消息数据
"""
return MessageSegment.json(data)
@ -134,9 +134,9 @@ def json(data: str) -> MessageSegment:
def face(id_: int) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.face 消息
参数
参数:
:param id_: 表情id
"""
return MessageSegment.face(id_)
@ -144,9 +144,9 @@ def face(id_: int) -> MessageSegment:
def poke(qq: int) -> MessageSegment:
"""
说明
说明:
生成一个 MessageSegment.poke 消息
参数
参数:
:param qq: qq号
"""
return MessageSegment("poke", {"qq": qq})
@ -160,10 +160,12 @@ def custom_forward_msg(
msg_list: List[Union[str, Message]], uin: Union[int, str], name: str = f"这里是{NICKNAME}"
) -> List[dict]:
"""
生成自定义合并消息
:param msg_list: 消息列表
:param uin: 发送者 QQ
:param name: 自定义名称
说明:
生成自定义合并消息
参数:
:param msg_list: 消息列表
:param uin: 发送者 QQ
:param name: 自定义名称
"""
uin = int(uin)
mes_list = []

View File

@ -150,9 +150,9 @@ class DailyNumberLimiter:
def is_number(s: str) -> bool:
"""
说明
说明:
检测 s 是否为数字
参数
参数:
:param s: 文本
"""
try:
@ -172,7 +172,7 @@ def is_number(s: str) -> bool:
def get_bot() -> Optional[Bot]:
"""
说明
说明:
获取 bot 对象
"""
try:
@ -194,9 +194,9 @@ def get_matchers() -> List[Type[Matcher]]:
def get_message_at(data: Union[str, Message]) -> List[int]:
"""
说明
说明:
获取消息中所有的 at 对象的 qq
参数
参数:
:param data: event.json()
"""
qq_list = []
@ -214,9 +214,9 @@ def get_message_at(data: Union[str, Message]) -> List[int]:
def get_message_img(data: Union[str, Message]) -> List[str]:
"""
说明
说明:
获取消息中所有的 图片 的链接
参数
参数:
:param data: event.json()
"""
img_list = []
@ -233,9 +233,9 @@ def get_message_img(data: Union[str, Message]) -> List[str]:
def get_message_img_file(data: Union[str, Message]) -> List[str]:
"""
说明
说明:
获取消息中所有的 图片file
参数
参数:
:param data: event.json()
"""
file_list = []
@ -252,9 +252,9 @@ def get_message_img_file(data: Union[str, Message]) -> List[str]:
def get_message_text(data: Union[str, Message]) -> str:
"""
说明
说明:
获取消息中 纯文本 的信息
参数
参数:
:param data: event.json()
"""
result = ""
@ -267,14 +267,14 @@ def get_message_text(data: Union[str, Message]) -> str:
else:
for seg in data["text"]:
result += seg.data["text"] + " "
return result
return result.strip()
def get_message_record(data: Union[str, Message]) -> List[str]:
"""
说明
说明:
获取消息中所有 语音 的链接
参数
参数:
:param data: event.json()
"""
record_list = []
@ -291,9 +291,9 @@ def get_message_record(data: Union[str, Message]) -> List[str]:
def get_message_json(data: str) -> List[dict]:
"""
说明
说明:
获取消息中所有 json
参数
参数:
:param data: event.json()
"""
try:
@ -309,7 +309,7 @@ def get_message_json(data: str) -> List[dict]:
def get_local_proxy():
"""
说明
说明:
获取 config.py 中设置的代理
"""
return SYSTEM_PROXY if SYSTEM_PROXY else None
@ -317,9 +317,9 @@ def get_local_proxy():
def is_chinese(word: str) -> bool:
"""
说明
说明:
判断字符串是否为纯中文
参数
参数:
:param word: 文本
"""
for ch in word:
@ -330,9 +330,9 @@ def is_chinese(word: str) -> bool:
async def get_user_avatar(qq: int) -> Optional[bytes]:
"""
说明
说明:
快捷获取用户头像
参数
参数:
:param qq: qq号
"""
url = f"http://q1.qlogo.cn/g?b=qq&nk={qq}&s=160"
@ -347,9 +347,9 @@ async def get_user_avatar(qq: int) -> Optional[bytes]:
async def get_group_avatar(group_id: int) -> Optional[bytes]:
"""
说明
说明:
快捷获取用群头像
参数
参数:
:param group_id: 群号
"""
url = f"http://p.qlogo.cn/gh/{group_id}/{group_id}/640/"
@ -364,9 +364,9 @@ async def get_group_avatar(group_id: int) -> Optional[bytes]:
def cn2py(word: str) -> str:
"""
说明
说明:
将字符串转化为拼音
参数
参数:
:param word: 文本
"""
temp = ""
@ -379,9 +379,9 @@ def change_pixiv_image_links(
url: str, size: Optional[str] = None, nginx_url: Optional[str] = None
):
"""
说明
说明:
根据配置改变图片大小和反代链接
参数
参数:
:param url: 图片原图链接
:param size: 模式
:param nginx_url: 反代
@ -404,9 +404,9 @@ def change_pixiv_image_links(
def change_img_md5(path_file: Union[str, Path]) -> bool:
"""
说明
说明:
改变图片MD5
参数
参数:
:param path_file: 图片路径
"""
try: