2022-08-21 16:47:50 +08:00
|
|
|
|
import random
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from asyncio.exceptions import TimeoutError
|
2022-08-21 16:47:50 +08:00
|
|
|
|
|
2023-02-18 18:46:54 +08:00
|
|
|
|
import nonebot
|
2022-02-19 18:20:19 +08:00
|
|
|
|
from nonebot.adapters.onebot.v11 import Bot
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from nonebot.drivers import Driver
|
|
|
|
|
|
|
2021-11-23 21:44:59 +08:00
|
|
|
|
from configs.path_config import TEXT_PATH
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from models.bag_user import BagUser
|
|
|
|
|
|
from models.group_info import GroupInfo
|
|
|
|
|
|
from services.log import logger
|
2021-11-23 21:44:59 +08:00
|
|
|
|
from utils.http_utils import AsyncHttpx
|
2023-02-18 18:46:54 +08:00
|
|
|
|
from utils.utils import GDict, scheduler
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
|
import ujson as json
|
|
|
|
|
|
except ModuleNotFoundError:
|
|
|
|
|
|
import json
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
driver: Driver = nonebot.get_driver()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@driver.on_startup
|
|
|
|
|
|
async def update_city():
|
|
|
|
|
|
"""
|
|
|
|
|
|
部分插件需要中国省份城市
|
|
|
|
|
|
这里直接更新,避免插件内代码重复
|
|
|
|
|
|
"""
|
2022-02-19 18:20:19 +08:00
|
|
|
|
china_city = TEXT_PATH / "china_city.json"
|
2021-11-23 21:44:59 +08:00
|
|
|
|
data = {}
|
2022-01-05 22:32:59 +08:00
|
|
|
|
if not china_city.exists():
|
|
|
|
|
|
try:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
logger.debug("开始更新城市列表...")
|
2021-11-23 21:44:59 +08:00
|
|
|
|
res = await AsyncHttpx.get(
|
2022-01-05 22:32:59 +08:00
|
|
|
|
"http://www.weather.com.cn/data/city3jdata/china.html", timeout=5
|
2021-11-23 21:44:59 +08:00
|
|
|
|
)
|
|
|
|
|
|
res.encoding = "utf8"
|
2022-01-05 22:32:59 +08:00
|
|
|
|
provinces_data = json.loads(res.text)
|
|
|
|
|
|
for province in provinces_data.keys():
|
|
|
|
|
|
data[provinces_data[province]] = []
|
|
|
|
|
|
res = await AsyncHttpx.get(
|
|
|
|
|
|
f"http://www.weather.com.cn/data/city3jdata/provshi/{province}.html",
|
|
|
|
|
|
timeout=5,
|
|
|
|
|
|
)
|
|
|
|
|
|
res.encoding = "utf8"
|
|
|
|
|
|
city_data = json.loads(res.text)
|
|
|
|
|
|
for city in city_data.keys():
|
|
|
|
|
|
data[provinces_data[province]].append(city_data[city])
|
|
|
|
|
|
with open(china_city, "w", encoding="utf8") as f:
|
|
|
|
|
|
json.dump(data, f, indent=4, ensure_ascii=False)
|
|
|
|
|
|
logger.info("自动更新城市列表完成.....")
|
2023-02-18 18:46:54 +08:00
|
|
|
|
except TimeoutError as e:
|
|
|
|
|
|
logger.warning("自动更新城市列表超时...", e=e)
|
|
|
|
|
|
except ValueError as e:
|
|
|
|
|
|
logger.warning("自动城市列表失败.....", e=e)
|
2022-01-05 22:32:59 +08:00
|
|
|
|
except Exception as e:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
logger.error(f"自动城市列表未知错误", e=e)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
2023-02-18 18:46:54 +08:00
|
|
|
|
# @driver.on_startup
|
|
|
|
|
|
# async def _():
|
|
|
|
|
|
# """
|
|
|
|
|
|
# 数据库表结构变换
|
|
|
|
|
|
# """
|
|
|
|
|
|
# _flag = []
|
|
|
|
|
|
# sql_str = [
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE group_info ADD group_flag Integer NOT NULL DEFAULT 0;",
|
|
|
|
|
|
# "group_info",
|
|
|
|
|
|
# ), # group_info表添加一个group_flag
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE bag_users rename belonging_group To group_id;",
|
|
|
|
|
|
# "bag_users",
|
|
|
|
|
|
# ), # 将 bag_users 的 belonging_group 改为 group_id
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE group_info_users rename belonging_group To group_id;",
|
|
|
|
|
|
# "group_info_users",
|
|
|
|
|
|
# ),
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE sign_group_users rename belonging_group To group_id;",
|
|
|
|
|
|
# "sign_group_users",
|
|
|
|
|
|
# ),
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE open_cases_users rename belonging_group To group_id;",
|
|
|
|
|
|
# "open_cases_users",
|
|
|
|
|
|
# ),
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE bag_users ADD property json NOT NULL DEFAULT '{}';",
|
|
|
|
|
|
# "bag_users",
|
|
|
|
|
|
# ), # bag_users 新增字段 property 替代 props
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD auto_sign_time timestamp with time zone;",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增原神自动签到字段
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD resin_remind boolean DEFAULT False;",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增原神自动签到字段
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD resin_recovery_time timestamp with time zone;",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增原神自动签到字段
|
|
|
|
|
|
# ("ALTER TABLE genshin ADD bind_group Integer;", "genshin"), # 新增原神群号绑定字段
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD login_ticket VARCHAR(255) DEFAULT '';",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增米游社login_ticket绑定字段
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD stuid VARCHAR(255) DEFAULT '';",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增米游社stuid绑定字段
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE genshin ADD stoken VARCHAR(255) DEFAULT '';",
|
|
|
|
|
|
# "genshin",
|
|
|
|
|
|
# ), # 新增米游社stoken绑定字段
|
|
|
|
|
|
# ("ALTER TABLE chat_history ADD plain_text Text;", "chat_history"), # 新增纯文本
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE goods_info ADD daily_limit Integer DEFAULT 0;",
|
|
|
|
|
|
# "goods_info",
|
|
|
|
|
|
# ), # 新增纯文本
|
|
|
|
|
|
# (
|
|
|
|
|
|
# "ALTER TABLE goods_info ADD daily_purchase_limit Json DEFAULT '{}';",
|
|
|
|
|
|
# "goods_info",
|
|
|
|
|
|
# ), # 新增纯文本
|
|
|
|
|
|
# ]
|
|
|
|
|
|
# for sql in sql_str + GDict.get("run_sql", []):
|
|
|
|
|
|
# try:
|
|
|
|
|
|
# if isinstance(sql, str):
|
|
|
|
|
|
# flag = f"{random.randint(1, 10000)}"
|
|
|
|
|
|
# else:
|
|
|
|
|
|
# flag = sql[1]
|
|
|
|
|
|
# sql = sql[0]
|
|
|
|
|
|
# query = db.text(sql)
|
|
|
|
|
|
# await db.first(query)
|
|
|
|
|
|
# logger.info(f"完成sql操作:{sql}")
|
|
|
|
|
|
# _flag.append(flag)
|
|
|
|
|
|
# except (DuplicateColumnError, UndefinedColumnError):
|
|
|
|
|
|
# pass
|
|
|
|
|
|
# except PostgresSyntaxError:
|
|
|
|
|
|
# logger.error(f"语法错误:执行sql失败:{sql}")
|
|
|
|
|
|
# bag_user 将文本转为字典格式
|
|
|
|
|
|
# await __database_script(_flag)
|
2022-01-16 14:52:50 +08:00
|
|
|
|
|
2021-11-23 21:44:59 +08:00
|
|
|
|
|
|
|
|
|
|
@driver.on_bot_connect
|
|
|
|
|
|
async def _(bot: Bot):
|
|
|
|
|
|
"""
|
|
|
|
|
|
版本某些需要的变换
|
|
|
|
|
|
"""
|
|
|
|
|
|
# 清空不存在的群聊信息,并将已所有已存在的群聊group_flag设置为1(认证所有已存在的群)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
if not await GroupInfo.get_or_none(group_id=114514):
|
2021-11-23 21:44:59 +08:00
|
|
|
|
# 标识符,该功能只需执行一次
|
2023-02-18 18:46:54 +08:00
|
|
|
|
await GroupInfo.create(
|
|
|
|
|
|
group_id=114514,
|
|
|
|
|
|
group_name="114514",
|
|
|
|
|
|
max_member_count=114514,
|
|
|
|
|
|
member_count=114514,
|
|
|
|
|
|
group_flag=1,
|
|
|
|
|
|
)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
group_list = await bot.get_group_list()
|
|
|
|
|
|
group_list = [g["group_id"] for g in group_list]
|
2023-02-18 18:46:54 +08:00
|
|
|
|
_gl = [x.group_id for x in await GroupInfo.all()]
|
2021-11-23 21:44:59 +08:00
|
|
|
|
if 114514 in _gl:
|
|
|
|
|
|
_gl.remove(114514)
|
|
|
|
|
|
for group_id in _gl:
|
|
|
|
|
|
if group_id in group_list:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
if group := await GroupInfo.get_or_none(group_id=group_id):
|
2023-02-26 20:42:50 +08:00
|
|
|
|
group.group_flag = 1
|
|
|
|
|
|
await group.save(update_fields=["group_flag"])
|
2021-11-23 21:44:59 +08:00
|
|
|
|
else:
|
|
|
|
|
|
group_info = await bot.get_group_info(group_id=group_id)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
await GroupInfo.create(
|
|
|
|
|
|
group_id=group_info["group_id"],
|
|
|
|
|
|
group_name=group_info["group_name"],
|
|
|
|
|
|
max_member_count=group_info["max_member_count"],
|
|
|
|
|
|
member_count=group_info["member_count"],
|
|
|
|
|
|
group_flag=1,
|
2021-11-23 21:44:59 +08:00
|
|
|
|
)
|
2023-02-18 18:46:54 +08:00
|
|
|
|
logger.info(f"已添加群认证...", group_id=group_id)
|
2021-11-23 21:44:59 +08:00
|
|
|
|
else:
|
2023-02-18 18:46:54 +08:00
|
|
|
|
await GroupInfo.filter(group_id=group_id).delete()
|
|
|
|
|
|
logger.info(f"移除不存在的群聊信息", group_id=group_id)
|
2022-01-05 22:32:59 +08:00
|
|
|
|
|
|
|
|
|
|
|
2023-02-18 18:46:54 +08:00
|
|
|
|
# async def __database_script(_flag: List[str]):
|
|
|
|
|
|
# # bag_user 将文本转为字典格式
|
|
|
|
|
|
# if "bag_users" in _flag:
|
|
|
|
|
|
# for x in await BagUser.get_all_users():
|
|
|
|
|
|
# props = {}
|
|
|
|
|
|
# if x.props:
|
|
|
|
|
|
# for prop in [p for p in x.props.split(",") if p]:
|
|
|
|
|
|
# if props.get(prop):
|
|
|
|
|
|
# props[prop] += 1
|
|
|
|
|
|
# else:
|
|
|
|
|
|
# props[prop] = 1
|
|
|
|
|
|
# logger.info(
|
|
|
|
|
|
# f"__database_script USER {x.user_qq} GROUP {x.group_id} 更新数据 {props}"
|
|
|
|
|
|
# )
|
|
|
|
|
|
# await x.update(
|
|
|
|
|
|
# property=props,
|
|
|
|
|
|
# props="",
|
|
|
|
|
|
# ).apply()
|
2022-01-16 14:52:50 +08:00
|
|
|
|
|
|
|
|
|
|
|
2022-01-05 22:32:59 +08:00
|
|
|
|
# 自动更新城市列表
|
|
|
|
|
|
@scheduler.scheduled_job(
|
|
|
|
|
|
"cron",
|
|
|
|
|
|
hour=6,
|
|
|
|
|
|
minute=1,
|
|
|
|
|
|
)
|
|
|
|
|
|
async def _():
|
|
|
|
|
|
await update_city()
|