mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
update gold_redbag
This commit is contained in:
parent
4d133ed2df
commit
a053c120c4
@ -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
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user