Can't you moderate the chat all the time? Automate this process and spend your time usefully✅
It is possible to customize for yourself📌
It's simple and convenient☁️
import openai from googletrans import Translator from aiogram import Bot, Dispatcher, executor, types """ Main easier way to automoderation """ class AutoModeration: translator = Translator() def __init__(self, openai_token: str, ban_words: list, ban: bool, language: str) -> None: self.openai_token = openai_token self.ban_words = ban_words self.ban = ban self.language = language def gen_context_msg_gpt(self, msg: str, ban_words: str) -> str: if self.ban_words: return f"""Hi, read this message\n{msg} and if it contains at least one word of their list - {ban_words}\nAlso, do you think this message is spam?, say yes or no""" else: return """Determine whether this message is spam or not, if yes, write yes in the answer""" def send_question_chatgpt(self, msg: str) -> bool: if self.language == "ru": content_to_chatgpt = self.translator.translate(self.gen_context_msg_gpt(msg, self.ban_words), src="ru", dest="en").text else: content_to_chatgpt = self.gen_context_msg_gpt(msg, self.ban_words) openai.api_key = self.openai_token messages = [{"role": "user", "content": content_to_chatgpt}] chatgpt_response = openai.ChatCompletion.create(model="gpt-3.5-turbo", messages=messages) response_from_chatgpt = chatgpt_response["choices"][0]["message"]["content"] # Offical api provider or gpt4free provider return "да" in response_from_chatgpt.lower() or "yes" in response_from_chatgpt.lower() or "contains" in response_from_chatgpt.lower() class TelegramBot: def __init__(self, telegram_token) -> None: self.telegram_token = telegram_token def start(self): bot = Bot(token=self.telegram_token) dp = Dispatcher(bot) @dp.message_handler(chat_type=types.ChatType.SUPERGROUP) async def spam_handler_supergroup(msg: types.Message): user_id = msg["from"]["id"] chat_id = msg["chat"]["id"] msg_id = msg["message_id"] moderation_class = AutoModeration("openai token", ["bruh"], True, "ru") is_spam = moderation_class.send_question_chatgpt(msg.text) if is_spam and moderation_class.ban: await bot.delete_message(chat_id, msg_id) await bot.ban_chat_member(chat_id, user_id) elif is_spam: await bot.delete_message(chat_id, msg_id) executor.start_polling(dp) if __name__ == "__main__": TelegramBot("telegram bot token").start()Our repository "AutoModeratorTelegramChatGPT" offers a simple and convenient solution for automatic moderation of Telegram chats using OpenAI GPT. Our moderator allows the user to configure the rules by which chats will be moderated, and provides automation of the routine task of moderation. In addition, our project is easily customized to the needs of each user. Thanks to these features, you can significantly improve the quality of your Telegram chat and save your time and effort. Join our project and simplify your life in Telegram💡