mirror of
https://github.com/MuRuLOSE/limoka.git
synced 2026-06-16 06:24:18 +02:00
169 lines
6.1 KiB
Python
Executable File
169 lines
6.1 KiB
Python
Executable File
# █ █ ▀ █▄▀ ▄▀█ █▀█ ▀
|
|
# █▀█ █ █ █ █▀█ █▀▄ █
|
|
# © 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": (
|
|
"<emoji document_id=5188311512791393083>🔎</emoji> <b>Looking for the most"
|
|
" active users in chat...\nThis might take a while.</b>"
|
|
),
|
|
"user": (
|
|
'<emoji document_id=5314541718312328811>👤</emoji> {}. <a href="{}">{}</a>:'
|
|
" {} messages"
|
|
),
|
|
"active": (
|
|
"<emoji document_id=5312361425409156767>⬆️</emoji> <b>The most active users"
|
|
" in this chat:</b>\n\n{}\n<i>Request took: {}s</i>"
|
|
),
|
|
}
|
|
|
|
strings_ru = {
|
|
"searching": (
|
|
"<emoji document_id=5188311512791393083>🔎</emoji> <b>Поиск самых активных"
|
|
" участников чата...\nЭто может занять некоторое время.</b>"
|
|
),
|
|
"active": (
|
|
"<emoji document_id=5312361425409156767>⬆️</emoji> <b>Самые активные"
|
|
" пользователи в чате:</b>\n\n{}\n<i>Подсчет занял: {}s</i>"
|
|
),
|
|
"_cmd_doc_activists": (
|
|
"[количество] [-m <int>] - Найти наиболее активных пользователей чата"
|
|
),
|
|
"_cls_doc": "Ищет наиболее активных пользователей чата",
|
|
}
|
|
|
|
strings_de = {
|
|
"searching": (
|
|
"<emoji document_id=5188311512791393083>🔎</emoji> <b>Suche nach den"
|
|
" aktivsten Benutzern im Chat...\nDies kann eine Weile dauern.</b>"
|
|
),
|
|
"active": (
|
|
"<emoji document_id=5312361425409156767>⬆️</emoji> <b>Die aktivsten"
|
|
" Benutzer in diesem Chat:</b>\n\n{}\n<i>Anfrage dauerte: {}s</i>"
|
|
),
|
|
"_cmd_doc_activists": (
|
|
"[Anzahl] [-m <int>] - Finde die aktivsten Benutzer im Chat"
|
|
),
|
|
"_cls_doc": "Sucht nach den aktivsten Benutzern im Chat",
|
|
}
|
|
|
|
strings_hi = {
|
|
"searching": (
|
|
"<emoji document_id=5188311512791393083>🔎</emoji> <b>चैट में सबसे सक्रिय"
|
|
" उपयोगकर्ताओं की तलाश कर रहा हूं...\nयह थोड़ा समय लेने सकता है।</b>"
|
|
),
|
|
"active": (
|
|
"<emoji document_id=5312361425409156767>⬆️</emoji> <b>इस चैट में सबसे"
|
|
" सक्रिय उपयोगकर्ता:</b>\n\n{}\n<i>अनुरोध लिया: {}s</i>"
|
|
),
|
|
"_cmd_doc_activists": (
|
|
"[संख्या] [-m <int>] - चैट में सबसे सक्रिय उपयोगकर्ताओं की तलाश करें"
|
|
),
|
|
"_cls_doc": "चैट में सबसे सक्रिय उपयोगकर्ताओं की तलाश करता है",
|
|
}
|
|
|
|
strings_uz = {
|
|
"searching": (
|
|
"<emoji document_id=5188311512791393083>🔎</emoji> <b>Chatdagi eng faol"
|
|
" foydalanuvchilarni qidirish...\nBu bir necha vaqt olishi mumkin.</b>"
|
|
),
|
|
"active": (
|
|
"<emoji document_id=5312361425409156767>⬆️</emoji> <b>Ushbu chatdagi eng"
|
|
" faol foydalanuvchilar:</b>\n\n{}\n<i>Talab: {}s</i>"
|
|
),
|
|
"_cmd_doc_activists": (
|
|
"[soni] [-m <int>] - 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 <int>] - 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)
|
|
),
|
|
)
|