Merge pull request #1257 from yajiwa/main

解决开红包经常误触的问题
This commit is contained in:
HibiKier 2023-02-18 22:53:13 +08:00 committed by GitHub
commit eea1be0fc1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -29,7 +29,6 @@ from nonebot.params import CommandArg
import random import random
import time import time
__zx_plugin_name__ = "金币红包" __zx_plugin_name__ = "金币红包"
__plugin_usage__ = """ __plugin_usage__ = """
usage usage
@ -64,11 +63,16 @@ __plugin_settings__ = {
} }
__plugin_resources__ = {"prts": IMAGE_PATH} __plugin_resources__ = {"prts": IMAGE_PATH}
async def rule(event: GroupMessageEvent) -> bool:
return check_on_gold_red(event)
gold_redbag = on_command( gold_redbag = on_command(
"塞红包", aliases={"金币红包"}, priority=5, block=True, permission=GROUP "塞红包", aliases={"金币红包"}, priority=5, block=True, permission=GROUP
) )
open_ = on_command("", aliases={""}, priority=5, block=True, permission=GROUP) open_ = on_command("", aliases={""}, priority=5, block=True, permission=GROUP, rule=rule)
poke_ = on_notice(priority=6, block=False) poke_ = on_notice(priority=6, block=False)
@ -85,27 +89,11 @@ festive_redbag_data = {}
# 阻断其他poke # 阻断其他poke
@run_preprocessor @run_preprocessor
async def _(matcher: Matcher, event: PokeNotifyEvent): async def _(matcher: Matcher, event: PokeNotifyEvent, ):
try: try:
if matcher.type == "notice" and event.self_id == event.target_id: if matcher.type == "notice" and event.self_id == event.target_id:
flag1 = True flag = check_on_gold_red(event)
flag2 = True if flag:
try:
if festive_redbag_data[event.group_id]["user_id"]:
if (
event.user_id
in festive_redbag_data[event.group_id]["open_user"]
):
flag1 = False
except KeyError:
flag1 = False
try:
if redbag_data[event.group_id]["user_id"]:
if event.user_id in redbag_data[event.group_id]["open_user"]:
flag2 = False
except KeyError:
flag2 = False
if flag1 or flag2:
if matcher.plugin_name == "poke": if matcher.plugin_name == "poke":
raise IgnoredException("目前正在抢红包...") raise IgnoredException("目前正在抢红包...")
else: else:
@ -194,26 +182,6 @@ async def _(event: GroupMessageEvent, arg: Message = CommandArg()):
if msg: if msg:
if "红包" not in msg: if "红包" not in msg:
return return
flag1 = True
flag2 = True
open_flag1 = True
open_flag2 = True
try:
if festive_redbag_data[event.group_id]["user_id"]:
if event.user_id in festive_redbag_data[event.group_id]["open_user"]:
open_flag1 = False
except KeyError:
open_flag1 = False
flag1 = False
try:
if redbag_data[event.group_id]["user_id"]:
if event.user_id in redbag_data[event.group_id]["open_user"]:
open_flag2 = False
except KeyError:
flag2 = False
if not flag1 and not flag2:
await open_.finish("目前没有红包可以开...", at_sender=True)
if open_flag1 or open_flag2:
try: try:
await open_.send( await open_.send(
image(b64=await get_redbag_img(event.user_id, event.group_id)), image(b64=await get_redbag_img(event.user_id, event.group_id)),
@ -221,27 +189,14 @@ async def _(event: GroupMessageEvent, arg: Message = CommandArg()):
) )
except KeyError: except KeyError:
await open_.finish("真贪心,明明已经开过这个红包了的说...", at_sender=True) await open_.finish("真贪心,明明已经开过这个红包了的说...", at_sender=True)
else:
await open_.finish("真贪心,明明已经开过这个红包了的说...", at_sender=True)
@poke_.handle() @poke_.handle()
async def _poke_(event: PokeNotifyEvent): async def _poke_(event: PokeNotifyEvent):
global redbag_data, festive_redbag_data global redbag_data, festive_redbag_data
if event.self_id == event.target_id: if event.self_id == event.target_id:
flag1 = True flag = check_on_gold_red(event)
flag2 = True if not flag:
try:
if event.user_id in festive_redbag_data[event.group_id]["open_user"]:
flag1 = False
except KeyError:
flag1 = False
try:
if event.user_id in redbag_data[event.group_id]["open_user"]:
flag2 = False
except KeyError:
flag2 = False
if not flag1 and not flag2:
return return
await poke_.send( await poke_.send(
image(b64=await get_redbag_img(event.user_id, event.group_id)), image(b64=await get_redbag_img(event.user_id, event.group_id)),
@ -428,3 +383,27 @@ async def end_festive_redbag(bot: Bot, group_id: int):
) )
await bot.send_group_msg(group_id=group_id, message=message) await bot.send_group_msg(group_id=group_id, message=message)
festive_redbag_data[group_id] = {} festive_redbag_data[group_id] = {}
def check_on_gold_red(event) -> bool:
flag1 = True
flag2 = True
try:
if festive_redbag_data[event.group_id]["user_id"]:
if (
event.user_id
in festive_redbag_data[event.group_id]["open_user"]
):
flag1 = False
except KeyError:
flag1 = False
try:
if redbag_data[event.group_id]["user_id"]:
if event.user_id in redbag_data[event.group_id]["open_user"]:
flag2 = False
except KeyError:
flag2 = False
if flag1 or flag2:
return True
else:
return False