zhenxun_bot/basic_plugins/scripts.py

219 lines
7.6 KiB
Python
Raw Normal View History

import random
2022-01-16 14:52:50 +08:00
from asyncpg.exceptions import (
DuplicateColumnError,
UndefinedColumnError,
PostgresSyntaxError,
)
2021-11-23 21:44:59 +08:00
from nonebot import Driver
from services.db_context import db
from models.group_info import GroupInfo
2022-01-16 14:52:50 +08:00
from models.bag_user import BagUser
2022-02-19 18:20:19 +08:00
from nonebot.adapters.onebot.v11 import Bot
2021-11-23 21:44:59 +08:00
from services.log import logger
from configs.path_config import TEXT_PATH
from asyncio.exceptions import TimeoutError
2022-01-16 14:52:50 +08:00
from typing import List
2021-11-23 21:44:59 +08:00
from utils.http_utils import AsyncHttpx
2022-10-15 19:49:53 +08:00
from utils.utils import GDict
2022-01-05 22:32:59 +08:00
from utils.utils import scheduler
2021-11-23 21:44:59 +08:00
import nonebot
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:
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("自动更新城市列表完成.....")
except TimeoutError:
logger.warning("自动更新城市列表超时.....")
except ValueError:
logger.warning("自动城市列表失败.....")
except Exception as e:
logger.error(f"自动城市列表未知错误 {type(e)}{e}")
2021-11-23 21:44:59 +08:00
@driver.on_startup
async def _():
"""
数据库表结构变换
"""
2022-01-16 14:52:50 +08:00
_flag = []
2021-11-23 21:44:59 +08:00
sql_str = [
2022-01-16 14:52:50 +08:00
(
"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
2022-02-09 20:05:49 +08:00
(
"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"
), # 新增原神自动签到字段
2022-02-19 18:20:19 +08:00
(
"ALTER TABLE genshin ADD bind_group Integer;",
"genshin"
), # 新增原神群号绑定字段
2022-08-21 13:37:03 +08:00
(
"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绑定字段
2022-05-23 22:01:56 +08:00
(
"ALTER TABLE chat_history ADD plain_text Text;",
"chat_history"
), # 新增纯文本
2022-06-26 03:08:23 +08:00
(
"ALTER TABLE goods_info ADD daily_limit Integer DEFAULT 0;",
"goods_info"
), # 新增纯文本
(
"ALTER TABLE goods_info ADD daily_purchase_limit Json DEFAULT '{}';",
"goods_info"
), # 新增纯文本
2021-11-23 21:44:59 +08:00
]
for sql in sql_str + GDict.get('run_sql', []):
2021-11-23 21:44:59 +08:00
try:
if isinstance(sql, str):
flag = f'{random.randint(1, 10000)}'
else:
flag = sql[1]
sql = sql[0]
2021-11-23 21:44:59 +08:00
query = db.text(sql)
await db.first(query)
2022-01-16 14:52:50 +08:00
logger.info(f"完成sql操作{sql}")
_flag.append(flag)
except (DuplicateColumnError, UndefinedColumnError):
2021-11-23 21:44:59 +08:00
pass
2022-01-16 14:52:50 +08:00
except PostgresSyntaxError:
logger.error(f"语法错误执行sql失败{sql}")
# bag_user 将文本转为字典格式
await __database_script(_flag)
2021-11-23 21:44:59 +08:00
@driver.on_bot_connect
async def _(bot: Bot):
"""
版本某些需要的变换
"""
# 清空不存在的群聊信息并将已所有已存在的群聊group_flag设置为1认证所有已存在的群
if not await GroupInfo.get_group_info(114514):
# 标识符,该功能只需执行一次
await GroupInfo.add_group_info(114514, "114514", 114514, 114514, 1)
group_list = await bot.get_group_list()
group_list = [g["group_id"] for g in group_list]
_gl = [x.group_id for x in await GroupInfo.get_all_group()]
if 114514 in _gl:
_gl.remove(114514)
for group_id in _gl:
if group_id in group_list:
if await GroupInfo.get_group_info(group_id):
await GroupInfo.set_group_flag(group_id, 1)
else:
group_info = await bot.get_group_info(group_id=group_id)
await GroupInfo.add_group_info(
group_info["group_id"],
group_info["group_name"],
group_info["max_member_count"],
group_info["member_count"],
1,
)
logger.info(f"已将群聊 {group_id} 添加认证...")
else:
await GroupInfo.delete_group_info(group_id)
logger.info(f"移除不存在的群聊信息:{group_id}")
2022-01-05 22:32:59 +08:00
2022-01-16 14:52:50 +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-05 22:32:59 +08:00
# 自动更新城市列表
@scheduler.scheduled_job(
"cron",
hour=6,
minute=1,
)
async def _():
await update_city()