mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
modified: basic_plugins/admin_bot_manage/admin_config.py modified: basic_plugins/admin_bot_manage/custom_welcome_message.py modified: basic_plugins/admin_bot_manage/timing_task.py modified: basic_plugins/apscheduler/__init__.py modified: basic_plugins/ban/__init__.py modified: basic_plugins/ban/data_source.py modified: basic_plugins/chat_history/chat_message.py modified: basic_plugins/chat_history/chat_message_handle.py modified: basic_plugins/group_handle/__init__.py modified: basic_plugins/hooks/_utils.py modified: basic_plugins/hooks/ban_hook.py modified: basic_plugins/hooks/chkdsk_hook.py modified: basic_plugins/init_plugin_config/__init__.py deleted: basic_plugins/init_plugin_config/init_group_manager.py modified: basic_plugins/invite_manager/__init__.py new file: basic_plugins/invite_manager/utils.py modified: basic_plugins/nickname.py modified: basic_plugins/plugin_shop/__init__.py modified: basic_plugins/plugin_shop/data_source.py modified: basic_plugins/scripts.py modified: basic_plugins/shop/__init__.py modified: basic_plugins/shop/buy.py modified: basic_plugins/shop/gold.py modified: basic_plugins/shop/my_props/__init__.py deleted: basic_plugins/shop/reset_today_gold.py modified: basic_plugins/shop/shop_handle/__init__.py modified: basic_plugins/shop/shop_handle/data_source.py modified: basic_plugins/shop/use/__init__.py modified: basic_plugins/shop/use/data_source.py modified: basic_plugins/super_cmd/__init__.py modified: basic_plugins/super_cmd/bot_friend_group.py modified: basic_plugins/super_cmd/clear_data.py modified: basic_plugins/super_cmd/exec_sql.py modified: basic_plugins/super_cmd/manager_group.py modified: basic_plugins/super_cmd/reload_setting.py modified: basic_plugins/super_cmd/set_admin_permissions.py deleted: basic_plugins/super_cmd/super_task_switch.py modified: basic_plugins/super_cmd/update_friend_group_info.py modified: basic_plugins/super_help/__init__.py modified: basic_plugins/update_info.py modified: configs/config.py modified: configs/utils/__init__.py modified: models/bag_user.py modified: models/ban_user.py modified: models/chat_history.py modified: models/friend_user.py modified: models/goods_info.py modified: models/group_info.py modified: models/group_member_info.py modified: models/level_user.py modified: models/sign_group_user.py modified: models/user_shop_gold_log.py modified: plugins/aconfig/__init__.py modified: plugins/ai/__init__.py modified: plugins/ai/data_source.py modified: plugins/bilibili_sub/__init__.py modified: plugins/bilibili_sub/data_source.py modified: plugins/bilibili_sub/model.py modified: plugins/black_word/__init__.py modified: plugins/black_word/model.py modified: plugins/black_word/utils.py modified: plugins/bt/data_source.py modified: plugins/genshin/almanac/__init__.py modified: plugins/genshin/material_remind/__init__.py modified: plugins/genshin/query_user/_models/__init__.py modified: plugins/genshin/query_user/_utils/__init__.py modified: plugins/genshin/query_user/bind/__init__.py modified: plugins/genshin/query_user/genshin_sign/__init__.py modified: plugins/genshin/query_user/genshin_sign/data_source.py modified: plugins/genshin/query_user/genshin_sign/init_task.py modified: plugins/genshin/query_user/mihoyobbs_sign/__init__.py modified: plugins/genshin/query_user/query_memo/__init__.py modified: plugins/genshin/query_user/query_memo/data_source.py modified: plugins/genshin/query_user/query_role/__init__.py modified: plugins/genshin/query_user/query_role/data_source.py modified: plugins/genshin/query_user/reset_today_query_user_data/__init__.py modified: plugins/genshin/query_user/resin_remind/__init__.py modified: plugins/genshin/query_user/resin_remind/init_task.py modified: plugins/gold_redbag/model.py modified: plugins/image_management/send_image/__init__.py modified: plugins/my_info/__init__.py modified: plugins/open_cases/models/buff_prices.py modified: plugins/open_cases/models/open_cases_user.py modified: plugins/open_cases/open_cases_c.py modified: plugins/open_cases/utils.py modified: plugins/parse_bilibili_json.py modified: plugins/pid_search.py modified: plugins/pix_gallery/__init__.py modified: plugins/pix_gallery/_data_source.py modified: plugins/pix_gallery/_model/omega_pixiv_illusts.py modified: plugins/pix_gallery/_model/pixiv.py modified: plugins/pix_gallery/_model/pixiv_keyword_user.py modified: plugins/pix_gallery/pix_add_keyword.py modified: plugins/pix_gallery/pix_pass_del_keyword.py modified: plugins/pix_gallery/pix_show_info.py modified: plugins/pix_gallery/pix_update.py modified: plugins/pixiv_rank_search/data_source.py modified: plugins/poke/__init__.py modified: plugins/russian/__init__.py modified: plugins/russian/data_source.py modified: plugins/russian/model.py modified: plugins/send_dinggong_voice/__init__.py modified: plugins/send_setu_/_model.py modified: plugins/send_setu_/send_setu/__init__.py modified: plugins/send_setu_/send_setu/data_source.py modified: plugins/send_setu_/update_setu/data_source.py modified: plugins/sign_in/goods_register.py modified: plugins/sign_in/group_user_checkin.py modified: plugins/sign_in/random_event.py modified: plugins/sign_in/utils.py modified: plugins/statistics/_model.py modified: plugins/statistics/statistics_handle.py modified: plugins/statistics/statistics_hook.py modified: plugins/update_picture.py modified: plugins/web_ui/api/request.py modified: plugins/word_bank/_model.py deleted: plugins/word_bank/_old_model.py modified: plugins/word_bank/_rule.py modified: plugins/word_bank/word_handle.py modified: plugins/word_clouds/data_source.py modified: resources/image/sign/sign_res/bar.png modified: resources/image/sign/sign_res/bar_white.png modified: services/db_context.py modified: services/log.py modified: utils/browser.py modified: utils/data_utils.py modified: utils/depends/__init__.py modified: utils/http_utils.py modified: utils/image_utils.py modified: utils/manager/admin_manager.py modified: utils/message_builder.py modified: utils/utils.py
107 lines
3.2 KiB
Python
107 lines
3.2 KiB
Python
from datetime import datetime, timedelta
|
||
from typing import Any, List, Literal, Optional, Tuple, Union
|
||
|
||
from tortoise import fields
|
||
from tortoise.functions import Count
|
||
|
||
from services.db_context import Model
|
||
|
||
|
||
class ChatHistory(Model):
|
||
|
||
id = fields.IntField(pk=True, generated=True, auto_increment=True)
|
||
"""自增id"""
|
||
user_qq = fields.BigIntField()
|
||
"""用户id"""
|
||
group_id = fields.BigIntField()
|
||
"""群聊id"""
|
||
text = fields.TextField()
|
||
"""文本内容"""
|
||
plain_text = fields.TextField()
|
||
"""纯文本"""
|
||
create_time = fields.DatetimeField(auto_now_add=True)
|
||
"""创建时间"""
|
||
|
||
class Meta:
|
||
table = "chat_history"
|
||
table_description = "聊天记录数据表"
|
||
|
||
@classmethod
|
||
async def get_group_msg_rank(
|
||
cls,
|
||
gid: int,
|
||
limit: int = 10,
|
||
order: str = "DESC",
|
||
date_scope: Optional[Tuple[datetime, datetime]] = None,
|
||
) -> List["ChatHistory"]:
|
||
"""
|
||
说明:
|
||
获取排行数据
|
||
参数:
|
||
:param gid: 群号
|
||
:param limit: 获取数量
|
||
:param order: 排序类型,desc,des
|
||
:param date_scope: 日期范围
|
||
"""
|
||
return list(
|
||
await cls.filter(group_id=gid, create_time__range=date_scope)
|
||
.annotate(count=Count("user_qq"))
|
||
.order_by(order)
|
||
.group_by("user_qq")
|
||
.limit(limit)
|
||
.values_list("user_qq", "count")
|
||
)
|
||
|
||
@classmethod
|
||
async def get_group_first_msg_datetime(cls, group_id: int) -> Optional[datetime]:
|
||
"""
|
||
说明:
|
||
获取群第一条记录消息时间
|
||
参数:
|
||
:param group_id: 群聊id
|
||
"""
|
||
if (
|
||
message := await cls.filter(group_id=group_id)
|
||
.order_by("create_time")
|
||
.first()
|
||
):
|
||
return message.create_time
|
||
|
||
@classmethod
|
||
async def get_message(
|
||
cls,
|
||
uid: Optional[int],
|
||
gid: Optional[int],
|
||
type_: Literal["user", "group"],
|
||
msg_type: Optional[Literal["private", "group"]] = None,
|
||
days: Optional[Union[int, Tuple[datetime, datetime]]] = None,
|
||
) -> List["ChatHistory"]:
|
||
"""
|
||
说明:
|
||
获取消息查询query
|
||
参数:
|
||
:param uid: 用户qq
|
||
:param gid: 群号
|
||
:param type_: 类型,私聊或群聊
|
||
:param msg_type: 消息类型,用户或群聊
|
||
:param days: 限制日期
|
||
"""
|
||
if type_ == "user":
|
||
query = cls.filter(user_qq=uid)
|
||
if msg_type == "private":
|
||
query = query.filter(group_id__isnull=True)
|
||
elif msg_type == "group":
|
||
query = query.filter(group_id__not_isnull=True)
|
||
else:
|
||
query = cls.filter(group_id=gid)
|
||
if uid:
|
||
query = query.filter(user_qq=uid)
|
||
if days:
|
||
if isinstance(days, int):
|
||
query = query.filter(
|
||
create_time__gte=datetime.now() - timedelta(days=days)
|
||
)
|
||
elif isinstance(days, tuple):
|
||
query = query.filter(create_at__range=days)
|
||
return await query.all()
|