Support Group Admin Change Event and Member Restrict Event
This commit is contained in:
parent
0ae4cb80f8
commit
2a52da8c61
@ -50,6 +50,7 @@ from .Utils import (
|
|||||||
download_user_avatar,
|
download_user_avatar,
|
||||||
process_quote_text,
|
process_quote_text,
|
||||||
qq_emoji_list,
|
qq_emoji_list,
|
||||||
|
strf_time,
|
||||||
)
|
)
|
||||||
|
|
||||||
all_group_list = []
|
all_group_list = []
|
||||||
@ -322,6 +323,64 @@ class GoCQHttp(BaseClient):
|
|||||||
context["message"] = text
|
context["message"] = text
|
||||||
self.send_efb_group_notice(context)
|
self.send_efb_group_notice(context)
|
||||||
|
|
||||||
|
@self.coolq_bot.on_notice("group_admin")
|
||||||
|
def handle_group_admin_msg(context):
|
||||||
|
if len(all_group_list) > 0 and context["group_id"] not in all_group_list:
|
||||||
|
print(f"Filter 1 group_admin from {context['group_id']}.")
|
||||||
|
return
|
||||||
|
context["event_description"] = self._("\u2139 Group Admin Change Event")
|
||||||
|
if (context["sub_type"]) == "set":
|
||||||
|
text = self._("{nickname}({context[user_id]}) "
|
||||||
|
"has been appointed as the group({group_name}) administrator")
|
||||||
|
else:
|
||||||
|
text = self._("{nickname}({context[user_id]}) "
|
||||||
|
"has been de-appointed as the group({group_name}) administrator")
|
||||||
|
|
||||||
|
original_group = self.get_group_info(context["group_id"], False)
|
||||||
|
group_name = context["group_id"]
|
||||||
|
if original_group is not None and "group_name" in original_group:
|
||||||
|
group_name = original_group["group_name"]
|
||||||
|
text = text.format(
|
||||||
|
nickname=self.get_stranger_info(context["user_id"])["nickname"],
|
||||||
|
context=context,
|
||||||
|
group_name=group_name,
|
||||||
|
)
|
||||||
|
|
||||||
|
context["message"] = text
|
||||||
|
self.send_efb_group_notice(context)
|
||||||
|
|
||||||
|
@self.coolq_bot.on_notice("group_ban")
|
||||||
|
def handle_group_ban_msg(context):
|
||||||
|
if len(all_group_list) > 0 and context["group_id"] not in all_group_list:
|
||||||
|
print(f"Filter 1 group_ban from {context['group_id']}.")
|
||||||
|
return
|
||||||
|
context["event_description"] = self._("\u2139 Group Member Restrict Event")
|
||||||
|
if (context["sub_type"]) == "ban":
|
||||||
|
text = self._("{nickname}({context[user_id]}) "
|
||||||
|
"is restricted for speaking for `{time}` at the group({group_name}) by "
|
||||||
|
"{nickname_}({context[operator_id]})")
|
||||||
|
time_text = strf_time(context["duration"])
|
||||||
|
else:
|
||||||
|
text = self._("{nickname}({context[user_id]}) "
|
||||||
|
"is lifted from restrictions at the group({group_name}) by "
|
||||||
|
"{nickname_}({context[operator_id]}){time}")
|
||||||
|
time_text = ""
|
||||||
|
|
||||||
|
original_group = self.get_group_info(context["group_id"], False)
|
||||||
|
group_name = context["group_id"]
|
||||||
|
if original_group is not None and "group_name" in original_group:
|
||||||
|
group_name = original_group["group_name"]
|
||||||
|
text = text.format(
|
||||||
|
nickname=self.get_stranger_info(context["user_id"])["nickname"],
|
||||||
|
context=context,
|
||||||
|
time=time_text,
|
||||||
|
group_name=group_name,
|
||||||
|
nickname_=self.get_stranger_info(context["operator_id"])["nickname"],
|
||||||
|
)
|
||||||
|
|
||||||
|
context["message"] = text
|
||||||
|
self.send_efb_group_notice(context)
|
||||||
|
|
||||||
@self.coolq_bot.on_notice("offline_file")
|
@self.coolq_bot.on_notice("offline_file")
|
||||||
def handle_offline_file_upload_msg(context):
|
def handle_offline_file_upload_msg(context):
|
||||||
context["event_description"] = self._("\u2139 Offline File Upload Event")
|
context["event_description"] = self._("\u2139 Offline File Upload Event")
|
||||||
@ -949,12 +1008,13 @@ class GoCQHttp(BaseClient):
|
|||||||
author = chat.get_member(SystemChatMember.SYSTEM_ID)
|
author = chat.get_member(SystemChatMember.SYSTEM_ID)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
author = chat.add_system_member()
|
author = chat.add_system_member()
|
||||||
|
event_description = context.get("event_description", "")
|
||||||
msg = Message(
|
msg = Message(
|
||||||
uid="__group_notice__.%s" % int(time.time()),
|
uid="__group_notice__.%s" % int(time.time()),
|
||||||
type=MsgType.Text,
|
type=MsgType.Text,
|
||||||
chat=chat,
|
chat=chat,
|
||||||
author=author,
|
author=author,
|
||||||
text=context["message"],
|
text=event_description + "\n\n" + context["message"] if event_description else context["message"],
|
||||||
deliver_to=coordinator.master,
|
deliver_to=coordinator.master,
|
||||||
)
|
)
|
||||||
coordinator.send_message(msg)
|
coordinator.send_message(msg)
|
||||||
|
@ -783,3 +783,15 @@ def download_voice(voice_url: str):
|
|||||||
else:
|
else:
|
||||||
audio_file = origin_file
|
audio_file = origin_file
|
||||||
return audio_file
|
return audio_file
|
||||||
|
|
||||||
|
|
||||||
|
def strf_time(seconds: int) -> str:
|
||||||
|
minutes, seconds = divmod(seconds, 60)
|
||||||
|
hours, minutes = divmod(minutes, 60)
|
||||||
|
days, hours = divmod(hours, 24)
|
||||||
|
text = ""
|
||||||
|
text += f"{days}d" if days else ""
|
||||||
|
text += f"{hours}h" if hours else ""
|
||||||
|
text += f"{minutes}m" if minutes else ""
|
||||||
|
text += f"{seconds}s" if seconds else ""
|
||||||
|
return text
|
||||||
|
Loading…
Reference in New Issue
Block a user