Spaces:
Sleeping
Sleeping
File size: 10,235 Bytes
9db4ada 0e31799 f0f9ad9 11ae35a 87abec5 11ae35a acd17b7 11ae35a f0f9ad9 0d887f0 3925c05 11ae35a af1662b 42a7e92 b51521e ef4e395 0364f1a ef4e395 0364f1a 9015bc5 14c8b0e 6e5ac37 af1662b 0364f1a fa6f4d3 0d887f0 87696ba 0d887f0 af1662b d5348c6 fa6f4d3 af1662b 9015bc5 fa6f4d3 af1662b fa6f4d3 0d887f0 18c86d3 fac74eb 0d887f0 18c86d3 0d887f0 0249134 26ed39a 92b81e1 de34607 acd17b7 63ad048 fac74eb 63ad048 fac74eb 63ad048 de34607 63ad048 acd17b7 63ad048 92b81e1 89ef22e fac74eb f87a0c5 3fb2204 f87a0c5 78c3748 f87a0c5 af1662b 18c86d3 0e31799 18c86d3 0e31799 18c86d3 26ed39a 0e31799 26ed39a 18c86d3 26ed39a 18c86d3 26ed39a 18c86d3 26ed39a 18c86d3 26ed39a 89ef22e 18c86d3 af1662b 18c86d3 42a7e92 fa6f4d3 0d887f0 9015bc5 0d887f0 7eb17b1 0d887f0 26ed39a 0d887f0 fac74eb 0d887f0 fac74eb c1d601a 3a7618b 18c86d3 26ed39a 18c86d3 2cf0846 aa46d17 b51521e aa46d17 26ed39a ef4e395 18c86d3 b2229d5 5ea462e 18c86d3 42a7e92 af1662b 3925c05 c0ed2cf af1662b 3925c05 d5348c6 af1662b 87abec5 6fefa14 e44597a 14c8b0e 6fefa14 0e31799 7eb17b1 0e31799 6fefa14 7eb17b1 6e5ac37 6fefa14 6e5ac37 6fefa14 14c8b0e af1662b fa6f4d3 af1662b 6e5ac37 725787c 6e5ac37 af1662b 6e5ac37 9015bc5 6e5ac37 1ee14ac 6e5ac37 0d887f0 6e5ac37 d8d7492 6e5ac37 9015bc5 5942ba9 9015bc5 5942ba9 6c4dae8 5942ba9 6e5ac37 0e31799 7eb17b1 6e5ac37 42a7e92 6e5ac37 1ee14ac 6e5ac37 0d887f0 c224902 fac74eb 6e5ac37 af1662b 0d887f0 a06c0e6 0d887f0 af1662b 8a5a595 709df35 096ee5f 709df35 d5348c6 423e59b |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 |
import os
from asyncio import sleep
from datetime import datetime
from traceback import format_exc
from pyrogram import enums
from pyrogram.errors import EntityBoundsInvalid, MediaCaptionTooLong, RPCError
from pyrogram.types import Message
from Powers import (DEV_USERS, LOGGER, OWNER_ID, SUDO_USERS, SUPPORT_STAFF,
WHITELIST_USERS)
from Powers.bot_class import Gojo
from Powers.database.antispam_db import GBan
from Powers.utils.custom_filters import command
from Powers.utils.extract_user import extract_user
from Powers.vars import Config
gban_db = GBan()
async def count(c: Gojo, chat):
try:
administrator = []
async for admin in c.get_chat_members(
chat_id=chat, filter=enums.ChatMembersFilter.ADMINISTRATORS
):
administrator.append(admin)
total_admin = administrator
bot = []
async for tbot in c.get_chat_members(
chat_id=chat, filter=enums.ChatMembersFilter.BOTS
):
bot.append(tbot)
total_bot = bot
bot_admin = 0
ban = []
async for banned in c.get_chat_members(
chat, filter=enums.ChatMembersFilter.BANNED
):
ban.append(banned)
total_banned = ban
for x in total_admin:
for y in total_bot:
if x == y:
bot_admin += 1
total_admin = len(total_admin)
total_bot = len(total_bot)
total_banned = len(total_banned)
return total_bot, total_admin, bot_admin, total_banned
except Exception as e:
total_bot = (
total_admin
) = bot_admin = total_banned = "Can't fetch because I am not part of the chat."
return total_bot, total_admin, bot_admin, total_banned
async def user_info(c: Gojo, user, already=False):
if not already:
user = await c.get_users(user_ids=user)
if not user.first_name:
return ["Deleted account", None]
gbanned, reason_gban = gban_db.get_gban(user.id)
if gbanned:
gban = True
reason = reason_gban
else:
gban = False
reason = "User is not gbanned"
user_id = user.id
username = user.username
first_name = user.first_name
last_name = user.last_name
mention = user.mention(f"{first_name}")
dc_id = user.dc_id
is_verified = user.is_verified
is_restricted = user.is_restricted
photo_id = user.photo.big_file_id if user.photo else None
is_support = True if user_id in SUPPORT_STAFF else False
if user_id == Config.BOT_ID:
is_support = "A person is a great support to himself"
omp = "Hmmm.......Who is that again?"
if is_support or Config.BOT_ID:
if user_id in DEV_USERS:
omp = "Dev"
elif user_id in SUDO_USERS:
omp = "Sudoer"
elif user_id in WHITELIST_USERS:
omp = "Whitelist"
elif user_id == Config.BOT_ID:
omp = "I am the targeted user"
elif user_id == OWNER_ID:
omp = "Owner of the bot"
if user_id in DEV_USERS and user_id == OWNER_ID:
omp = "Dev and Owner"
is_scam = user.is_scam
is_bot = user.is_bot
is_fake = user.is_fake
status = user.status
last_date = "Unable to fetch"
if is_bot is True:
last_date = "Targeted user is a bot"
if status == enums.UserStatus.RECENTLY:
last_date = "User was seen recently"
if status == enums.UserStatus.LAST_WEEK:
last_date = "User was seen last week"
if status == enums.UserStatus.LAST_MONTH:
last_date = "User was seen last month"
if status == enums.UserStatus.LONG_AGO:
last_date = "User was seen long ago or may be I am blocked by the user :("
if status == enums.UserStatus.ONLINE:
last_date = "User is online"
if status == enums.UserStatus.OFFLINE:
try:
last_date = datetime.fromtimestamp(user.status.date).strftime("%Y-%m-%d %H:%M:%S")
except Exception:
last_date = "User is offline"
caption = f"""
<b><i><u>β‘οΈ Extracted User info From Telegram β‘οΈ</b></i></u>
<b>π User ID</b>: <code>{user_id}</code>
<b>π Link To Profile</b>: <a href='tg://user?id={user_id}'>Click Hereπͺ</a>
<b>π«΅ Mention</b>: {mention}
<b>π£ First Name</b>: <code>{first_name}</code>
<b>π
Second Name</b>: <code>{last_name}</code>
<b>π Username</b>: {("@" + username) if username else "NA"}
<b>π§βπ» Support</b>: {is_support}
<b>π₯· Support user type</b>: <code>{omp}</code>
<b>π£ Gbanned</b>: {gban}
<b>β οΈ Gban reason</b>: <code>{reason}</code>
<b>π DC ID</b>: {dc_id}
<b>β RESTRICTED</b>: {is_restricted}
<b>β
VERIFIED</b>: {is_verified}
<b>β FAKE</b> : {is_fake}
<b>β οΈ SCAM</b> : {is_scam}
<b>π€ BOT</b>: {is_bot}
<b>π Last seen</b>: <code>{last_date}</code>
"""
return caption, photo_id
async def chat_info(c: Gojo, chat, already=False):
if not already:
try:
chat = await c.get_chat(chat)
except Exception:
try:
chat_r = await c.resolve_peer(chat)
chat = await c.get_chat(chat_r.channel_id)
except KeyError as e:
caption = f"Failed to find the chat due to\n{e}"
return caption, None
chat_id = chat.id
username = chat.username
total_bot, total_admin, total_bot_admin, total_banned = await count(c, chat.id)
title = chat.title
type_ = str(chat.type).split(".")[1]
is_scam = chat.is_scam
is_fake = chat.is_fake
description = chat.description
members = chat.members_count
is_restricted = chat.is_restricted
dc_id = chat.dc_id
photo_id = chat.photo.big_file_id if chat.photo else None
can_save = chat.has_protected_content
linked_chat = chat.linked_chat
caption = f"""
π° <b>CHAT INFO</b> π°
<b>π ID</b>: <code>{chat_id}</code>
<b>π Chat Title</b>: {title}
<b>β¨ Chat Type</b>: {type_}
<b>π DataCentre ID</b>: {dc_id}
<b>π Username</b>: {("@" + username) if username else "NA"}
<b>βοΈ Administrators</b>: {total_admin}
<b>π€ Bots</b>: {total_bot}
<b>π« Banned</b>: {total_banned}
<b>βοΈ Admin π€ Bots</b>: {total_bot_admin}
<b>βοΈ Scam</b>: {is_scam}
<b>β Fake</b>: {is_fake}
<b>β Restricted</b>: {is_restricted}
<b>π¨πΏβπ» Description</b>: <code>{description}</code>
<b>πͺ Total members</b>: {members}
<b>π« Has Protected Content</b>: {can_save}
<b>π Linked Chat</b>: <code>{linked_chat.id if linked_chat else "Not Linked"}</code>
"""
return caption, photo_id
@Gojo.on_message(command(["info", "whois"]))
async def info_func(c: Gojo, message: Message):
user, _, user_name = await extract_user(c, message)
if not user:
await message.reply_text("Can't find user to fetch info!")
m = await message.reply_text(
f"Fetching {('@' + user_name) if user_name else 'user'} info from telegram's database..."
)
try:
info_caption, photo_id = await user_info(c, user)
except Exception as e:
LOGGER.error(e)
LOGGER.error(format_exc())
return await m.edit(str(e))
if not photo_id:
await m.delete()
await sleep(2)
return await message.reply_text(info_caption, disable_web_page_preview=True)
photo = await c.download_media(photo_id)
await m.delete()
await sleep(2)
try:
await message.reply_photo(photo, caption=info_caption, quote=False)
except MediaCaptionTooLong:
x = await message.reply_photo(photo)
try:
await x.reply_text(info_caption)
except EntityBoundsInvalid:
await x.delete()
await message.reply_text(info_caption)
except RPCError as rpc:
await message.reply_text(rpc)
LOGGER.error(rpc)
LOGGER.error(format_exc())
except Exception as e:
await message.reply_text(text=e)
LOGGER.error(e)
LOGGER.error(format_exc())
os.remove(photo)
return
@Gojo.on_message(command(["chinfo", "chatinfo", "chat_info"]))
async def chat_info_func(c: Gojo, message: Message):
splited = message.text.split()
if len(splited) == 1:
chat = message.chat.id
else:
chat = splited[1]
try:
chat = int(chat)
except (ValueError, Exception) as ef:
if "invalid literal for int() with base 10:" in str(ef):
chat = str(chat)
if chat.startswith("https://"):
chat = '@'+chat.split("/")[-1]
else:
return await message.reply_text(
f"Got and exception {ef}\n**Usage:**/chinfo [USERNAME|ID]"
)
m = await message.reply_text(
f"Fetching chat info of chat from telegram's database....."
)
try:
info_caption, photo_id = await chat_info(c, chat=chat)
if info_caption.startswith("Failed to find the chat due"):
await message.reply_text(info_caption)
return
except Exception as e:
await m.delete()
await sleep(0.5)
return await message.reply_text(f"**GOT AN ERROR:**\n {e}")
if not photo_id:
await m.delete()
await sleep(2)
return await message.reply_text(info_caption, disable_web_page_preview=True)
photo = await c.download_media(photo_id)
await m.delete()
await sleep(2)
try:
await message.reply_photo(photo, caption=info_caption, quote=False)
except MediaCaptionTooLong:
x = await message.reply_photo(photo)
try:
await x.reply_text(info_caption)
except EntityBoundsInvalid:
await x.delete()
await message.reply_text(info_caption)
except RPCError as rpc:
await message.reply_text(rpc)
LOGGER.error(rpc)
LOGGER.error(format_exc())
except Exception as e:
await message.reply_text(text=e)
LOGGER.error(e)
LOGGER.error(format_exc())
os.remove(photo)
return
__PLUGIN__ = "info"
__alt_name__ = [
"info",
"chinfo",
]
__HELP__ = """
**Information**
β’ /info - To get info about the user
β’ /chinfo - To get info about the chat
"""
|