Beispiel #1
0
def enforce_gban(bot: Bot, update: Update):

    # Not using @restrict handler to avoid spamming - just ignore if cant gban.

    if sql.does_chat_gban(
            update.effective_chat.id) and update.effective_chat.get_member(
                bot.id).can_restrict_members:

        user = update.effective_user  # type: Optional[User]

        chat = update.effective_chat  # type: Optional[Chat]

        msg = update.effective_message  # type: Optional[Message]

        if user and not is_user_admin(chat, user.id):

            check_and_ban(update, user.id)

        if msg.new_chat_members:

            new_members = update.effective_message.new_chat_members

            for mem in new_members:

                check_and_ban(update, mem.id)

        if msg.reply_to_message:

            user = msg.reply_to_message.from_user  # type: Optional[User]

            if user and not is_user_admin(chat, user.id):

                check_and_ban(update, user.id, should_message=False)
Beispiel #2
0
def antispam(bot: Bot, update: Update, args: List[str]):

    chat = update.effective_chat  # type: Optional[Chat]

    if len(args) > 0:

        if args[0].lower() in ["on", "yes"]:

            sql.enable_antispam(chat.id)

            update.effective_message.reply_text(
                tld(
                    chat.id,
                    "I've enabled antispam security in this group. This will help protect you "
                    "from spammers, unsavoury characters, and the biggest trolls."
                ))

        elif args[0].lower() in ["off", "no"]:

            sql.disable_antispam(chat.id)

            update.effective_message.reply_text(
                tld(
                    chat.id,
                    "I've disabled antispam security in this group. GBans wont affect your users "
                    "anymore. You'll be less protected from any trolls and spammers "
                    "though! And i am little disappointed too. 😶"))

    else:

        update.effective_message.reply_text(
            tld(
                chat.id,
                "Give me some arguments to choose a setting! on/off, yes/no!\n\n"
                "Your current setting is: {}\n"
                "When True, any gbans that happen will also happen in your group. "
                "When False, they won't, leaving you at the possible mercy of "
                "spammers.").format(sql.does_chat_gban(chat.id)))
Beispiel #3
0
def __chat_settings__(bot, update, chat, chatP, user):

    chat_id = chat.id

    return "This chat is enforcing *gbans*: `{}`.".format(
        sql.does_chat_gban(chat_id))
Beispiel #4
0
def ungmute(bot: Bot, update: Update, args: List[str]):

    message = update.effective_message  # type: Optional[Message]

    user_id = extract_user(message, args)

    if not user_id:

        message.reply_text("You don't seem to be referring to a user.")

        return

    user_chat = bot.get_chat(user_id)

    if user_chat.type != 'private':

        message.reply_text("That's not a user!")

        return

    if not sql.is_user_gmuted(user_id):

        message.reply_text("This user is not gmuted!")

        return

    muter = update.effective_user  # type: Optional[User]

    message.reply_text("I'll let {} speak again, globally.".format(
        user_chat.first_name))

    send_to_list(bot,
                 SUDO_USERS + SUPPORT_USERS,
                 "{} has ungmuted user {}".format(
                     mention_html(muter.id, muter.first_name),
                     mention_html(user_chat.id, user_chat.first_name)),
                 html=True)

    chats = get_all_chats()

    for chat in chats:

        chat_id = chat.chat_id

        # Check if this group has disabled gmutes

        if not sql.does_chat_gban(chat_id):

            continue

        try:

            member = bot.get_chat_member(chat_id, user_id)

            if member.status == 'restricted':

                bot.restrict_chat_member(chat_id,
                                         int(user_id),
                                         can_send_messages=True,
                                         can_send_media_messages=True,
                                         can_send_other_messages=True,
                                         can_add_web_page_previews=True)

        except BadRequest as excp:

            if excp.message == "User is an administrator of the chat":

                pass

            elif excp.message == "Chat not found":

                pass

            elif excp.message == "Not enough rights to restrict/unrestrict chat member":

                pass

            elif excp.message == "User_not_participant":

                pass

            elif excp.message == "Method is available for supergroup and channel chats only":

                pass

            elif excp.message == "Not in the chat":

                pass

            elif excp.message == "Channel_private":

                pass

            elif excp.message == "Chat_admin_required":

                pass

            else:

                message.reply_text("Could not un-gmute due to: {}".format(
                    excp.message))

                bot.send_message(
                    OWNER_ID,
                    "Could not un-gmute due to: {}".format(excp.message))

                return

        except TelegramError:

            pass

    sql.ungmute_user(user_id)

    send_to_list(bot, SUDO_USERS + SUPPORT_USERS, "un-gmute complete!")

    message.reply_text("Person has been un-gmuted.")
Beispiel #5
0
def gban(bot: Bot, update: Update, args: List[str]):

    message = update.effective_message  # type: Optional[Message]

    user_id, reason = extract_user_and_text(message, args)

    if not user_id:

        message.reply_text("You don't seem to be referring to a person.")

        return

    if int(user_id) in SUDO_USERS:

        message.reply_text(
            "I spy, with my little eye... a sudo user war! Why are you guys turning on each other?"
        )

        return

    if int(user_id) in SUPPORT_USERS:

        message.reply_text(
            "OOOH someone's trying to gban a support user! *grabs popcorn*")

        return

    if user_id == bot.id:

        message.reply_text(
            "-_- So funny, lets gban myself why don't I? Nice try. Earth That is my price!"
        )

        return

    try:

        user_chat = bot.get_chat(user_id)

    except BadRequest as excp:

        message.reply_text(excp.message)

        return

    if user_chat.type != 'private':

        message.reply_text("That's not a user!")

        return

    if sql.is_user_gbanned(user_id):

        if not reason:

            message.reply_text(
                "This person is already gbanned; I'd change the reason, but you haven't given me one..."
            )

            return

        old_reason = sql.update_gban_reason(
            user_id, user_chat.username or user_chat.first_name, reason)

        if old_reason:

            message.reply_text(
                "This person is already gbanned, for the following reason:\n"
                "<code>{}</code>\n"
                "I've gone and updated it with your new reason!".format(
                    html.escape(old_reason)),
                parse_mode=ParseMode.HTML)

        else:

            message.reply_text(
                "This person is already gbanned, but had no reason set; I've gone and updated it!"
            )

        return

    ok123 = mention_html(user_chat.id, user_chat.first_name)

    text12 = f"*Summoning all infinity stones* The end is near. ☠️ {ok123}."

    update.effective_message.reply_text(text12, parse_mode=ParseMode.HTML)

    banner = update.effective_user  # type: Optional[User]

    send_to_list(bot, SUDO_USERS + SUPPORT_USERS,

                 "<b>Global Ban</b>" \

                 "\n#GBAN" \

                 "\n<b>Status:</b> <code>Enforcing</code>" \

                 "\n<b>Sudo Admin:</b> {}" \

                 "\n<b>User:</b> {}" \

                 "\n<b>ID:</b> <code>{}</code>" \

                 "\n<b>Reason:</b> {}".format(mention_html(banner.id, banner.first_name),

                                              mention_html(user_chat.id, user_chat.first_name),

                                                           user_chat.id, reason or "No reason given"),

                html=True)

    sql.gban_user(user_id, user_chat.username or user_chat.first_name, reason)

    chats = get_all_chats()

    for chat in chats:

        chat_id = chat.chat_id

        # Check if this group has disabled gbans

        if not sql.does_chat_gban(chat_id):

            continue

        try:

            bot.kick_chat_member(chat_id, user_id)

        except BadRequest as excp:

            if excp.message in GBAN_ERRORS:

                pass

            else:

                message.reply_text("Could not gban due to: {}".format(
                    excp.message))

                send_to_list(bot, SUDO_USERS + SUPPORT_USERS,
                             "Could not gban due to: {}".format(excp.message))

                sql.ungban_user(user_id)

                return

        except TelegramError:

            pass

    send_to_list(bot,
                 SUDO_USERS + SUPPORT_USERS,
                 "{} has been successfully gbanned!".format(
                     mention_html(user_chat.id, user_chat.first_name)),
                 html=True)

    text13 = f"Justice has been done with {ok123} 😉 'Peace'."

    update.effective_message.reply_text(text13, parse_mode=ParseMode.HTML)
Beispiel #6
0
def gmute(bot: Bot, update: Update, args: List[str]):

    message = update.effective_message  # type: Optional[Message]

    user_id, reason = extract_user_and_text(message, args)

    if not user_id:

        message.reply_text("You don't seem to be referring to a person.")

        return

    if int(user_id) in SUDO_USERS:

        message.reply_text(
            "I spy, with my little eye... a sudo user war! Why are you guys turning on each other?"
        )

        return

    if int(user_id) in SUPPORT_USERS:

        message.reply_text(
            "OOOH someone's trying to gmute a support user! *grabs popcorn*")

        return

    if user_id == bot.id:

        message.reply_text(
            "-_- So funny, lets gmute myself why don't I? Nice try.")

        return

    try:

        user_chat = bot.get_chat(user_id)

    except BadRequest as excp:

        message.reply_text(excp.message)

        return

    if user_chat.type != 'private':

        message.reply_text("That's not a user!")

        return

    if sql.is_user_gmuted(user_id):

        if not reason:

            message.reply_text(
                "This user is already gmuted; I'd change the reason, but you haven't given me one..."
            )

            return

        success = sql.update_gmute_reason(
            user_id, user_chat.username or user_chat.first_name, reason)

        if success:

            message.reply_text(
                "This user is already gmuted; I've gone and updated the gmute reason though!"
            )

        else:

            message.reply_text(
                "Do you mind trying again? I thought this person was gmuted, but then they weren't? "
                "Am very confused")

        return

    message.reply_text("*Gets duct tape ready* 😉")

    muter = update.effective_user  # type: Optional[User]

    send_to_list(bot,
                 SUDO_USERS + SUPPORT_USERS,
                 "{} is gmuting user {} "
                 "because:\n{}".format(
                     mention_html(muter.id, muter.first_name),
                     mention_html(user_chat.id, user_chat.first_name), reason
                     or "No reason given"),
                 html=True)

    sql.gmute_user(user_id, user_chat.username or user_chat.first_name, reason)

    chats = get_all_chats()

    for chat in chats:

        chat_id = chat.chat_id

        # Check if this group has disabled gmutes

        if not sql.does_chat_gban(chat_id):

            continue

        try:

            bot.restrict_chat_member(chat_id, user_id, can_send_messages=False)

        except BadRequest as excp:

            if excp.message == "User is an administrator of the chat":

                pass

            elif excp.message == "Chat not found":

                pass

            elif excp.message == "Not enough rights to restrict/unrestrict chat member":

                pass

            elif excp.message == "User_not_participant":

                pass

            elif excp.message == "Peer_id_invalid":  # Suspect this happens when a group is suspended by telegram.

                pass

            elif excp.message == "Group chat was deactivated":

                pass

            elif excp.message == "Need to be inviter of a user to kick it from a basic group":

                pass

            elif excp.message == "Chat_admin_required":

                pass

            elif excp.message == "Only the creator of a basic group can kick group administrators":

                pass

            elif excp.message == "Method is available only for supergroups":

                pass

            elif excp.message == "Can't demote chat creator":

                pass

            else:

                message.reply_text("Could not gmute due to: {}".format(
                    excp.message))

                send_to_list(bot, SUDO_USERS + SUPPORT_USERS,
                             "Could not gmute due to: {}".format(excp.message))

                sql.ungmute_user(user_id)

                return

        except TelegramError:

            pass

    send_to_list(bot, SUDO_USERS + SUPPORT_USERS, "gmute complete!")

    message.reply_text("Person has been gmuted.")
Beispiel #7
0
def ungban(bot: Bot, update: Update, args: List[str]):

    message = update.effective_message  # type: Optional[Message]

    user_id = extract_user(message, args)

    if not user_id:

        message.reply_text("You don't seem to be referring to a person.")

        return

    user_chat = bot.get_chat(user_id)

    if user_chat.type != 'private':

        message.reply_text("That's not a person!")

        return

    if not sql.is_user_gbanned(user_id):

        message.reply_text("This person is not gbanned!")

        return

    banner = update.effective_user  # type: Optional[User]

    message.reply_text(
        "I'll give {} a second chance, globally.I do not ask for your trust.I demand only your obedience."
        .format(user_chat.first_name))



    send_to_list(bot, SUDO_USERS + SUPPORT_USERS,

                 "<b>Regression of Global Ban</b>" \

                 "\n#UNGBAN" \

                 "\n<b>Status:</b> <code>Ceased</code>" \

                 "\n<b>Sudo Admin:</b> {}" \

                 "\n<b>User:</b> {}" \

                 "\n<b>ID:</b> <code>{}</code>".format(mention_html(banner.id, banner.first_name),

                                                       mention_html(user_chat.id, user_chat.first_name),

                                                                    user_chat.id),

                html=True)

    chats = get_all_chats()

    for chat in chats:

        chat_id = chat.chat_id

        # Check if this group has disabled gbans

        if not sql.does_chat_gban(chat_id):

            continue

        try:

            member = bot.get_chat_member(chat_id, user_id)

            if member.status == 'kicked':

                bot.unban_chat_member(chat_id, user_id)

        except BadRequest as excp:

            if excp.message in UNGBAN_ERRORS:

                pass

            else:

                message.reply_text("Could not un-gban due to: {}".format(
                    excp.message))

                bot.send_message(
                    OWNER_ID,
                    "Could not un-gban due to: {}".format(excp.message))

                return

        except TelegramError:

            pass

    sql.ungban_user(user_id)

    send_to_list(bot,
                 SUDO_USERS + SUPPORT_USERS,
                 "{} has been successfully un-gbanned!".format(
                     mention_html(user_chat.id, user_chat.first_name)),
                 html=True)

    message.reply_text(
        "Person has been un-gbanned.The hardest choices require the strongest wills.😐"
    )