diff --git a/README.md b/README.md index ae14ed9d..df861aec 100644 --- a/README.md +++ b/README.md @@ -48,6 +48,14 @@ $ pip3 install -r requirements.txt #### 2021-10-24 +修复:Cookies池中存在失效Cookies时可能导致自动签到不正常运作 + +新增:每月统计的命令(该功能需要Cookies),具体使用可以前往[指令](#指令)处查阅。 + +优化:添加了部分代码的注释 + +#### 2021-10-24 + **重要:目前Cookies池又采用了新的方式(去除冗余),如果你是上个版本的使用者,请在更新后使用群聊命令:优化Cookies,无损迁移旧版本全部Cookies;(如果你是上上个版本的使用者,更新后使用命令:迁移Cookies)** 修复:可能会导致的添加cookies问题 @@ -156,33 +164,34 @@ $ pip3 install -r requirements.txt (**括号内为可选词缀**,以下所有可以输出图片的,**命令后跟图可自定义背景图片**): -| 触发前缀 | 触发后缀/备注 | 效果 | 举例 | 备注 | -| :--------------------- | ---------------------- | ----------------------------------- | ------------------ | ---------------------------------------- | -| uid | | 获取角色信息一览(带武器信息) | uid123456789 | | -| uid | (上期)深渊 | 获取角色深渊总览(层数为最后一层) | uid123456789深渊 | | -| uid | (上期)深渊9/10/11/12 | 获取角色深渊某一层数据 | uid123456789深渊12 | | -| mys | | 角色信息(带武器信息,冒险等级) | mys123456 | 米游社通行证 | -| mys | (上期)深渊 | 获取角色深渊总览(层数为最后一层) | mys123456深渊 | 米游社通行证 | -| mys | (上期)深渊9/10/11/12 | 获取角色深渊某一层数据 | mys123456深渊12 | 米游社通行证 | -| UID | | 获取角色信息一览(不带武器信息) | UID123456789 | 旧版本,比例更和谐 | -| 绑定uid | | 当前qq号关联绑定uid | 绑定uid123456789 | 查询前缀前置条件 | -| 绑定mys | | 当前qq号关联绑定米游社通行证 | 绑定mys12345678 | 查询前缀前置条件 | -| 查询 | | 查询当前绑定角色信息一览 | 查询 | **必须**绑定过mys/uid | -| 查询(上期)深渊 | | 查询当前绑定角色深渊总览 | 查询深渊 | **必须**绑定过mys/uid | -| 查询(上期)深渊\d | | 查询当前绑定角色深渊某一层数据 | 查询深渊10 | **必须**绑定过mys/uid | -| 添加 | | 向cookies池添加cookies | 添加 _ga=balabala | **私聊**bot,注意空格 | -| 查询 @人 | | 获取@的群友的角色信息一览 | 查询 @Wuyi | | -| 查询(上期)深渊 @人 | | 获取@的群友的深渊信息一览 | 查询深渊 @Wuyi | | -| 查询(上期)深渊\d @人 | | 获取@的群友的深渊某一层数据 | 查询深渊10 @Wuyi | | -| 当前状态 | | 获取树脂、每日委托、派遣等信息 | 当前状态 | **必须**绑定过CK和uid | -| 开启推送 | | 开启推送,超过140树脂提醒旅行者 | 开启推送 | 群聊/私聊都可
**必须**绑定过CK和uid | -| 关闭推送 | | 关闭树脂快满的提醒 | 关闭推送 | 都可以 | -| 校验全部Cookies | | 校验当前池内全部Cookies状态 | 校验全部Cookies | **群聊** | -| 迁移Cookies | | 迁移旧版本(上上个版本)全部Cookies | 迁移Cookies | **群聊** | -| 优化Cookies | | 优化上个版本全部Cookies | 优化Cookies | **群聊** | -| 签到 | | 米游社签到 | 签到 | **必须**绑定过CK和uid | -| 开启自动签到 | | 开启每日米游社签到 | 开启自动签到 | 群聊/私聊都可
**必须**绑定过CK和uid | -| 关闭自动签到 | | 关闭每日米游社签到 | 关闭自动签到 | 群聊/私聊都可
**必须**绑定过CK和uid | +| 触发前缀 | 触发后缀/备注 | 效果 | 举例 | 备注 | +| :--------------------- | ---------------------- | -------------------------------------- | ------------------ | ---------------------------------------- | +| uid | | 获取角色信息一览(带武器信息) | uid123456789 | | +| uid | (上期)深渊 | 获取角色深渊总览(层数为最后一层) | uid123456789深渊 | | +| uid | (上期)深渊9/10/11/12 | 获取角色深渊某一层数据 | uid123456789深渊12 | | +| mys | | 角色信息(带武器信息,冒险等级) | mys123456 | 米游社通行证 | +| mys | (上期)深渊 | 获取角色深渊总览(层数为最后一层) | mys123456深渊 | 米游社通行证 | +| mys | (上期)深渊9/10/11/12 | 获取角色深渊某一层数据 | mys123456深渊12 | 米游社通行证 | +| UID | | 获取角色信息一览(不带武器信息) | UID123456789 | 旧版本,比例更和谐 | +| 绑定uid | | 当前qq号关联绑定uid | 绑定uid123456789 | 查询前缀前置条件 | +| 绑定mys | | 当前qq号关联绑定米游社通行证 | 绑定mys12345678 | 查询前缀前置条件 | +| 查询 | | 查询当前绑定角色信息一览 | 查询 | **必须**绑定过mys/uid | +| 查询(上期)深渊 | | 查询当前绑定角色深渊总览 | 查询深渊 | **必须**绑定过mys/uid | +| 查询(上期)深渊\d | | 查询当前绑定角色深渊某一层数据 | 查询深渊10 | **必须**绑定过mys/uid | +| 添加 | | 向cookies池添加cookies | 添加 _ga=balabala | **私聊**bot,注意空格 | +| 查询 @人 | | 获取@的群友的角色信息一览 | 查询 @Wuyi | | +| 查询(上期)深渊 @人 | | 获取@的群友的深渊信息一览 | 查询深渊 @Wuyi | | +| 查询(上期)深渊\d @人 | | 获取@的群友的深渊某一层数据 | 查询深渊10 @Wuyi | | +| 当前状态 | | 获取树脂、每日委托、派遣等信息 | 当前状态 | **必须**绑定过CK和uid | +| 开启推送 | | 开启推送,超过140树脂提醒旅行者 | 开启推送 | 群聊/私聊都可
**必须**绑定过CK和uid | +| 关闭推送 | | 关闭树脂快满的提醒 | 关闭推送 | 都可以 | +| 校验全部Cookies | | 校验当前池内全部Cookies状态 | 校验全部Cookies | **群聊** | +| 迁移Cookies | | 迁移旧版本(上上个版本)全部Cookies | 迁移Cookies | **群聊** | +| 优化Cookies | | 优化上个版本全部Cookies | 优化Cookies | **群聊** | +| 签到 | | 米游社签到 | 签到 | **必须**绑定过CK和uid | +| 开启自动签到 | | 开启每日米游社签到 | 开启自动签到 | 群聊/私聊都可
**必须**绑定过CK和uid | +| 关闭自动签到 | | 关闭每日米游社签到 | 关闭自动签到 | 群聊/私聊都可
**必须**绑定过CK和uid | +| 每月统计 | | 查询当前绑定账号的每月/每日的原石/莫拉 | | 仅限群聊,**必须**绑定Cookies和uid | ### 深渊查询: diff --git a/__init__.py b/__init__.py index 02ee87bd..b88cb20d 100644 --- a/__init__.py +++ b/__init__.py @@ -1,5 +1,5 @@ from .getImg import draw_pic,draw_abyss_pic,draw_abyss0_pic -from .getDB import connectDB,selectDB,cookiesDB,cacheDB,deletecache,CheckDB,TransDB,OpenPush,GetMysInfo,GetDaily,GetSignList,MysSign,GetSignInfo,OpCookies +from .getDB import connectDB,selectDB,cookiesDB,cacheDB,deletecache,CheckDB,TransDB,OpenPush,GetMysInfo,GetDaily,GetSignList,MysSign,GetSignInfo,OpCookies,GetAward from nonebot import * from hoshino import Service,R,priv,util @@ -31,10 +31,29 @@ daily_im = ''' ======== {}''' +month_im = ''' +============== +本日获取原石:{} +本日获取摩拉:{} +============== +昨日获取原石:{} +昨日获取摩拉:{} +============== +本月获取原石:{} +本月获取摩拉:{} +============== +上月获取原石:{} +上月获取摩拉:{} +============== +{}======== +''' + +#每日零点清空cookies使用缓存 @sv.scheduled_job('cron', hour='0') async def delete(): deletecache() - + +#每日零点半进行米游社签到 @sv.scheduled_job('cron', hour='0',minute="30") async def dailysign(): conn = sqlite3.connect('ID_DATA.db') @@ -42,14 +61,13 @@ async def dailysign(): cursor = c.execute("SELECT * FROM NewCookiesTable WHERE StatusB != ?",("off",)) c_data = cursor.fetchall() for row in c_data: - im = await sign(str(row[0])) - if row[4] == "on": await bot.send_private_msg(user_id = row[2],message = im) else: await bot.send_group_msg(group_id = row[4],message = f"[CQ:at,qq={row[2]}]" + "\n" + im) - + +#每隔半小时检测树脂是否超过设定值 @sv.scheduled_job('interval', minutes=30) async def push(): daily_data = await daily() @@ -62,8 +80,7 @@ async def push(): else: pass - - +#私聊事件 @bot.on_message('private') async def setting(ctx): message = ctx['raw_message'] @@ -83,7 +100,6 @@ async def setting(ctx): if i['data'][0]['name'] != '活跃天数': mys_data['data']['list'].remove(i) uid = mys_data['data']['list'][0]['game_role_id'] - await cookiesDB(uid,cookie,userid) await bot.send_msg(self_id=sid, user_id=userid, group_id=gid, message=f'添加Cookies成功!Cookies属于个人重要信息,如果你是在不知情的情况下添加,请马上修改米游社账户密码,保护个人隐私!') except: @@ -116,7 +132,8 @@ async def setting(ctx): await bot.send_msg(self_id=sid, user_id=userid, group_id=gid, message=im) except: await bot.send_msg(self_id=sid, user_id=userid, group_id=gid, message="未找到uid绑定记录。") - + +#群聊开启 自动签到 和 推送树脂提醒 功能 @sv.on_prefix('开启') async def _(bot:HoshinoBot, ev: CQEvent): message = ev.message.extract_plain_text() @@ -139,7 +156,8 @@ async def _(bot:HoshinoBot, ev: CQEvent): await bot.send(ev,im,at_sender=True) except: await bot.send(ev,"未绑定uid信息!",at_sender=True) - + +#群聊关闭 自动签到 和 推送树脂提醒 功能 @sv.on_prefix('关闭') async def _(bot:HoshinoBot, ev: CQEvent): message = ev.message.extract_plain_text() @@ -162,7 +180,34 @@ async def _(bot:HoshinoBot, ev: CQEvent): await bot.send(ev,im,at_sender=True) except: await bot.send(ev,"未绑定uid信息!",at_sender=True) + +#群聊内 每月统计 功能 +@sv.on_fullmatch('每月统计') +async def _(bot:HoshinoBot, ev: CQEvent): + try: + qid = ev.sender["user_id"] + uid = await selectDB(ev.sender['user_id'],mode = "uid") + uid = uid[0] + data = await GetAward(uid) + nickname = data['data']['nickname'] + day_stone = data['data']['day_data']['current_primogems'] + day_mora = data['data']['day_data']['current_mora'] + lastday_stone = data['data']['day_data']['last_primogems'] + lastday_mora = data['data']['day_data']['last_mora'] + month_stone = data['data']['month_data']['current_primogems'] + month_mora = data['data']['month_data']['current_mora'] + lastmonth_stone = data['data']['month_data']['last_primogems'] + lastmonth_mora = data['data']['month_data']['last_mora'] + group_str = '' + for i in data['data']['month_data']['group_by']: + group_str = group_str + i['action'] + ":" + str(i['num']) + "| " + "百分比:" + str(i['percent']) + "%" + '\n' + im = month_im.format(day_stone,day_mora,lastday_stone,lastday_mora,month_stone,month_mora,lastmonth_stone,lastmonth_mora,group_str) + await bot.send(ev,im,at_sender=True) + except: + pass + +#群聊内 签到 功能 @sv.on_fullmatch('签到') async def _(bot:HoshinoBot, ev: CQEvent): try: @@ -174,6 +219,7 @@ async def _(bot:HoshinoBot, ev: CQEvent): except: pass +#群聊内 数据库v2 迁移至 数据库v3 的命令,一般只需要更新时执行一次 @sv.on_fullmatch('优化Cookies') async def _(bot:HoshinoBot, ev: CQEvent): try: @@ -181,17 +227,20 @@ async def _(bot:HoshinoBot, ev: CQEvent): await bot.send(ev,im,at_sender=True) except: pass - + +#群聊内 校验Cookies 是否正常的功能,不正常自动删掉 @sv.on_fullmatch('校验全部Cookies') async def _(bot:HoshinoBot, ev: CQEvent): im = await CheckDB() await bot.send(ev,im) +#群聊内 数据库v1 迁移至 数据库v2 的命令,一般只需要更新时执行一次 @sv.on_fullmatch('迁移Cookies') async def _(bot:HoshinoBot, ev: CQEvent): im = await TransDB() await bot.send(ev,im) - + +#群聊内 查询当前树脂状态以及派遣状态 的命令 @sv.on_fullmatch('当前状态') async def _(bot:HoshinoBot, ev: CQEvent): try: @@ -204,7 +253,7 @@ async def _(bot:HoshinoBot, ev: CQEvent): await bot.send(ev,im, at_sender=True) - +#群聊内 查询uid 的命令 @sv.on_prefix('uid') async def _(bot:HoshinoBot, ev: CQEvent): image = re.search(r"\[CQ:image,file=(.*),url=(.*)\]", str(ev.message)) @@ -239,14 +288,16 @@ async def _(bot:HoshinoBot, ev: CQEvent): await bot.send(ev, im, at_sender=True) except: await bot.send(ev,'输入错误!') - + +#群聊内 绑定uid 的命令,会绑定至当前qq号上 @sv.on_prefix('绑定uid') async def _(bot:HoshinoBot, ev: CQEvent): message = ev.message.extract_plain_text() uid = re.findall(r"\d+", message)[0] # str await connectDB(ev.sender['user_id'],uid) await bot.send(ev,'绑定uid成功!', at_sender=True) - + +#群聊内 绑定米游社通行证 的命令,会绑定至当前qq号上,和绑定uid不冲突,两者可以同时绑定 @sv.on_prefix('绑定mys') async def _(bot:HoshinoBot, ev: CQEvent): message = ev.message.extract_plain_text() @@ -254,6 +305,7 @@ async def _(bot:HoshinoBot, ev: CQEvent): await connectDB(ev.sender['user_id'],None,mys) await bot.send(ev,'绑定米游社id成功!', at_sender=True) +#群聊内 绑定过uid/mysid的情况下,可以查询,默认优先调用米游社通行证,多出世界等级一个参数 @sv.on_prefix('查询') async def _(bot, ev): image = re.search(r"\[CQ:image,file=(.*),url=(.*)\]", str(ev.message)) @@ -303,7 +355,7 @@ async def _(bot, ev): else: await bot.send(ev,'未找到绑定记录!') - +#群聊内 查询米游社通行证 的命令 @sv.on_prefix('mys') async def _(bot:HoshinoBot, ev: CQEvent): image = re.search(r"\[CQ:image,file=(.*),url=(.*)\]", str(ev.message)) @@ -339,6 +391,7 @@ async def _(bot:HoshinoBot, ev: CQEvent): except: await bot.send(ev,'输入错误!') +#群聊内 查询uid 的命令(旧版),不输出武器信息 @sv.on_prefix('UID') async def _(bot:HoshinoBot, ev: CQEvent): image = re.search(r"\[CQ:image,file=(.*),url=(.*)\]", str(ev.message)) @@ -352,24 +405,28 @@ async def _(bot:HoshinoBot, ev: CQEvent): - +#签到函数 async def sign(uid): - sign_data = await MysSign(uid) - sign_info = await GetSignInfo(uid) - sign_info = sign_info['data'] - sign_list = await GetSignList() - status = sign_data['message'] - getitem = sign_list['data']['awards'][int(sign_info['total_sign_day'])-1]['name'] - getnum = sign_list['data']['awards'][int(sign_info['total_sign_day'])-1]['cnt'] - get_im = f"本次签到获得{getitem}x{getnum}" - if status == "OK" and sign_info['is_sign'] == True: - mes_im = "签到成功" - else: - mes_im = status - sign_missed = sign_info['sign_cnt_missed'] - im = "\n" + mes_im +"!" + "\n" + get_im + "\n" + f"本月漏签次数:{sign_missed}" + try: + sign_data = await MysSign(uid) + sign_info = await GetSignInfo(uid) + sign_info = sign_info['data'] + sign_list = await GetSignList() + status = sign_data['message'] + getitem = sign_list['data']['awards'][int(sign_info['total_sign_day'])-1]['name'] + getnum = sign_list['data']['awards'][int(sign_info['total_sign_day'])-1]['cnt'] + get_im = f"本次签到获得{getitem}x{getnum}" + if status == "OK" and sign_info['is_sign'] == True: + mes_im = "签到成功" + else: + mes_im = status + sign_missed = sign_info['sign_cnt_missed'] + im = "\n" + mes_im +"!" + "\n" + get_im + "\n" + f"本月漏签次数:{sign_missed}" + except: + im = "\n签到失败,请检查Cookies是否失效。" return im +#统计状态函数 async def daily(mode = "push",uid = None): temp_list = [] conn = sqlite3.connect('ID_DATA.db')