mirror of
https://github.com/PaiGramTeam/PaiGram.git
synced 2024-12-26 19:35:37 +00:00
4034c5d30c
Co-authored-by: deepsource-autofix[bot] <62050782+deepsource-autofix[bot]@users.noreply.github.com> Co-authored-by: xtaodada <xtao@xtaolink.cn>
102 lines
4.7 KiB
Python
102 lines
4.7 KiB
Python
from telegram import Chat, Update, User
|
|
from telegram.error import NetworkError, Forbidden
|
|
from telegram.ext import CallbackContext, ChatMemberHandler
|
|
|
|
from core.config import JoinGroups, config
|
|
from core.plugin import Plugin, handler
|
|
from core.services.cookies import CookiesService
|
|
from core.services.players import PlayersService
|
|
from core.services.users.services import UserAdminService
|
|
from core.services.groups.services import GroupService
|
|
from utils.chatmember import extract_status_change
|
|
from utils.log import logger
|
|
|
|
|
|
class ChatMember(Plugin):
|
|
def __init__(
|
|
self,
|
|
user_admin_service: UserAdminService = None,
|
|
players_service: PlayersService = None,
|
|
cookies_service: CookiesService = None,
|
|
group_service: GroupService = None,
|
|
):
|
|
self.cookies_service = cookies_service
|
|
self.players_service = players_service
|
|
self.user_admin_service = user_admin_service
|
|
self.group_service = group_service
|
|
|
|
@handler.chat_member(chat_member_types=ChatMemberHandler.MY_CHAT_MEMBER, block=False)
|
|
async def track_chats(self, update: Update, context: CallbackContext) -> None:
|
|
result = extract_status_change(update.my_chat_member)
|
|
if result is None:
|
|
return
|
|
was_member, is_member = result
|
|
user = update.effective_user
|
|
chat = update.effective_chat
|
|
if chat.type == Chat.PRIVATE:
|
|
if not was_member and is_member:
|
|
logger.info("用户 %s[%s] 启用了机器人", user.full_name, user.id)
|
|
elif was_member and not is_member:
|
|
logger.info("用户 %s[%s] 屏蔽了机器人", user.full_name, user.id)
|
|
elif chat.type in [Chat.GROUP, Chat.SUPERGROUP]:
|
|
if not was_member and is_member:
|
|
logger.info("用户 %s[%s] 邀请BOT进入群 %s[%s]", user.full_name, user.id, chat.title, chat.id)
|
|
await self.greet(user, chat, context)
|
|
elif was_member and not is_member:
|
|
logger.info("用户 %s[%s] 从 %s[%s] 群移除Bot", user.full_name, user.id, chat.title, chat.id)
|
|
else:
|
|
if not was_member and is_member:
|
|
logger.info("用户 %s[%s] 邀请BOT进入频道 %s[%s]", user.full_name, user.id, chat.title, chat.id)
|
|
elif was_member and not is_member:
|
|
logger.info("用户 %s[%s] 从 %s[%s] 频道移除Bot", user.full_name, user.id, chat.title, chat.id)
|
|
|
|
async def greet(self, user: User, chat: Chat, context: CallbackContext) -> None:
|
|
if await self.group_service.is_banned(chat.id):
|
|
return
|
|
quit_status = True
|
|
if config.join_groups == JoinGroups.NO_ALLOW:
|
|
try:
|
|
if await self.user_admin_service.is_admin(user.id):
|
|
quit_status = False
|
|
else:
|
|
logger.warning("不是管理员邀请!退出群聊")
|
|
except Exception as exc: # pylint: disable=W0703
|
|
logger.error("获取信息出现错误", exc_info=exc)
|
|
elif config.join_groups == JoinGroups.ALLOW_AUTH_USER:
|
|
try:
|
|
if await self.cookies_service.get(user.id) is not None:
|
|
quit_status = False
|
|
except Exception as exc: # pylint: disable=W0703
|
|
logger.error("获取信息出现错误", exc_info=exc)
|
|
elif config.join_groups == JoinGroups.ALLOW_USER:
|
|
try:
|
|
if await self.players_service.get(user.id) is not None:
|
|
quit_status = False
|
|
except Exception as exc: # pylint: disable=W0703
|
|
logger.error("获取信息出现错误", exc_info=exc)
|
|
elif config.join_groups == JoinGroups.ALLOW_ALL:
|
|
quit_status = False
|
|
else:
|
|
quit_status = True
|
|
if quit_status:
|
|
try:
|
|
await context.bot.send_message(chat.id, config.notice.quit_status)
|
|
except Forbidden as exc:
|
|
logger.info("发送消息失败 %s", exc.message)
|
|
except NetworkError as exc:
|
|
logger.info("发送消息失败 %s", exc.message)
|
|
except Exception as exc:
|
|
logger.info("发送消息失败", exc_info=exc)
|
|
await context.bot.leave_chat(chat.id)
|
|
else:
|
|
try:
|
|
await context.bot.send_message(
|
|
chat.id, f"感谢邀请小{config.notice.bot_name}到本群!请使用 /help 查看咱已经学会的功能。"
|
|
)
|
|
except Forbidden as exc:
|
|
logger.info("发送消息失败 %s", exc.message)
|
|
except NetworkError as exc:
|
|
logger.info("发送消息失败 %s", exc.message)
|
|
except Exception as exc:
|
|
logger.info("发送消息失败", exc_info=exc)
|