# █ █ ▀ █▄▀ ▄▀█ █▀█ ▀
# █▀█ █ █ █ █▀█ █▀▄ █
# © Copyright 2022
# https://t.me/hikariatama
#
# 🔒 Licensed under the GNU AGPLv3
# 🌐 https://www.gnu.org/licenses/agpl-3.0.html
# meta pic: https://static.dan.tatar/activists_icon.png
# meta banner: https://mods.hikariatama.ru/badges/activists.jpg
# meta developer: @hikarimods
# scope: hikka_only
# scope: hikka_min 1.4.0
import time
import typing
from telethon.tl.types import Chat, Message, User
from telethon.utils import get_display_name
from .. import loader, utils
@loader.tds
class ActivistsMod(loader.Module):
"""Looks for the most active users in chat"""
strings = {
"name": "Activists",
"searching": (
"🔎 Looking for the most"
" active users in chat...\nThis might take a while."
),
"user": (
'👤 {}. {}:'
" {} messages"
),
"active": (
"⬆️ The most active users"
" in this chat:\n\n{}\nRequest took: {}s"
),
}
strings_ru = {
"searching": (
"🔎 Поиск самых активных"
" участников чата...\nЭто может занять некоторое время."
),
"active": (
"⬆️ Самые активные"
" пользователи в чате:\n\n{}\nПодсчет занял: {}s"
),
"_cmd_doc_activists": (
"[количество] [-m ] - Найти наиболее активных пользователей чата"
),
"_cls_doc": "Ищет наиболее активных пользователей чата",
}
strings_de = {
"searching": (
"🔎 Suche nach den"
" aktivsten Benutzern im Chat...\nDies kann eine Weile dauern."
),
"active": (
"⬆️ Die aktivsten"
" Benutzer in diesem Chat:\n\n{}\nAnfrage dauerte: {}s"
),
"_cmd_doc_activists": (
"[Anzahl] [-m ] - Finde die aktivsten Benutzer im Chat"
),
"_cls_doc": "Sucht nach den aktivsten Benutzern im Chat",
}
strings_hi = {
"searching": (
"🔎 चैट में सबसे सक्रिय"
" उपयोगकर्ताओं की तलाश कर रहा हूं...\nयह थोड़ा समय लेने सकता है।"
),
"active": (
"⬆️ इस चैट में सबसे"
" सक्रिय उपयोगकर्ता:\n\n{}\nअनुरोध लिया: {}s"
),
"_cmd_doc_activists": (
"[संख्या] [-m ] - चैट में सबसे सक्रिय उपयोगकर्ताओं की तलाश करें"
),
"_cls_doc": "चैट में सबसे सक्रिय उपयोगकर्ताओं की तलाश करता है",
}
strings_uz = {
"searching": (
"🔎 Chatdagi eng faol"
" foydalanuvchilarni qidirish...\nBu bir necha vaqt olishi mumkin."
),
"active": (
"⬆️ Ushbu chatdagi eng"
" faol foydalanuvchilar:\n\n{}\nTalab: {}s"
),
"_cmd_doc_activists": (
"[soni] [-m ] - Chatdagi eng faol foydalanuvchilarni qidirish"
),
"_cls_doc": "Chatdagi eng faol foydalanuvchilarni qidiradi",
}
async def check_admin(
self,
chat: typing.Union[int, Chat],
user_id: typing.Union[int, User],
) -> bool:
try:
return (await self._client.get_perms_cached(chat, user_id)).is_admin
except Exception:
return False
async def activistscmd(self, message: Message):
"""[quantity] [-m ] - Find top active users in chat"""
args = utils.get_args_raw(message)
limit = None
if "-m" in args:
limit = int(
"".join([lim for lim in args[args.find("-m") + 2 :] if lim.isdigit()])
)
args = args[: args.find("-m")].strip()
quantity = int(args) if args.isdigit() else 15
message = await utils.answer(message, self.strings("searching"))
st = time.perf_counter()
temp = {}
async for msg in self._client.iter_messages(message.peer_id, limit=limit):
user = getattr(msg, "sender_id", False)
if not user:
continue
if user not in temp:
temp[user] = 0
temp[user] += 1
stats = [
user[0]
for user in list(
sorted(list(temp.items()), key=lambda x: x[1], reverse=True)
)
]
top_users = []
for u in stats:
if len(top_users) >= quantity:
break
if not await self.check_admin(message.peer_id, u):
top_users += [(await self._client.get_entity(u), u)]
top_users_formatted = [
self.strings("user").format(
i + 1, utils.get_link(user[0]), get_display_name(user[0]), temp[user[1]]
)
for i, user in enumerate(top_users)
]
await utils.answer(
message,
self.strings("active").format(
"\n".join(top_users_formatted), round(time.perf_counter() - st, 2)
),
)