Spaces:
Running
Running
File size: 12,205 Bytes
0189974 83b0433 eef97a7 1b5719b d720c41 98ab4e9 1b5719b 3580517 1b5719b eef97a7 1cbc430 2fc8036 b002286 8e64093 fa04dc3 aa9e39d 4056428 aa9e39d 4056428 aa9e39d 795711a 4056428 795711a aa9e39d c31d06c 12f026d 09099c9 b002286 795711a 67daa79 1cbc430 a6269a8 1cbc430 b002286 2707517 67daa79 b002286 78d4936 67daa79 b002286 67daa79 1cbc430 d7e1221 d720c41 d7e1221 d720c41 3580517 1cbc430 d9f4368 c3b4392 1cbc430 d9f4368 1cbc430 4056428 8ee0322 9fb279b 7a70ed1 8ee0322 6e30a37 1543e1e c3b4392 1543e1e c3b4392 1543e1e 8ee0322 be92cb3 1543e1e 6e30a37 1543e1e 3c9449b 28fb891 c3b4392 d38ac2b 9cab3bd 4056428 d38ac2b 4056428 d38ac2b 4056428 d38ac2b 4056428 d38ac2b 4056428 d38ac2b 4056428 b002286 d9f4368 83b0433 d9f4368 83b0433 d9f4368 9fb279b 83b0433 9fb279b d9f4368 d7e1221 36b5e1c d9f4368 9fb279b d9f4368 9fb279b 28fb891 d9f4368 b002286 d9f4368 8e64093 67daa79 d720c41 1cbc430 78d4936 d720c41 22cb6ae d720c41 22cb6ae d720c41 4056428 d720c41 4056428 78d4936 d720c41 22cb6ae d720c41 4056428 d720c41 78d4936 1cbc430 4056428 f65dc76 1cbc430 9fb279b 1cbc430 c3b4392 1cbc430 c3b4392 711b749 5c5148b d9f4368 9fb279b d9f4368 3c9449b 62d9953 fa04dc3 62d9953 9fb279b aa9e39d d9f4368 bfbcae2 6daa732 d9f4368 8e64093 b002286 2fc8036 905276d 3580517 3c9449b 3580517 2fc8036 2707517 b002286 98ab4e9 3c9449b 98ab4e9 c6c04b2 b2b36e4 12f026d c6c04b2 83b0433 f65dc76 83b0433 c6c04b2 f65dc76 09099c9 3580517 4056428 3580517 3c9449b 09099c9 c6c04b2 09099c9 c6c04b2 12f026d b002286 67daa79 b002286 09099c9 b5992ae 905276d 4056428 905276d f26f9dc 09099c9 b002286 09099c9 3c9449b 4056428 09099c9 84d8f87 09099c9 1cbc430 4056428 09099c9 3c9449b 09099c9 3c9449b f7919c0 78d4936 f7919c0 04894f6 f7919c0 09099c9 83b0433 f65dc76 09099c9 8e64093 09099c9 84d8f87 09099c9 1cbc430 b7d0333 c3b4392 09099c9 b002286 1cbc430 fec5a2d 1cbc430 b002286 4ce98fd d76971a 809532c d76971a 2707517 ed63425 |
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 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 |
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.raw.functions.channels import GetFullChannel
from pyrogram.raw.functions.users import GetFullUser
from pyrogram.types import Message
from Powers import DEV_USERS, LOGGER, OWNER_ID, SUDO_USERS, 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
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
userrr = await c.resolve_peer(user_id)
about = "NA"
try:
ll = await c.invoke(
GetFullUser(
id=userrr
)
)
about = ll.full_user.about
except Exception:
pass
SUPPORT_STAFF = DEV_USERS.union(SUDO_USERS).union(WHITELIST_USERS)
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 = user_id in SUPPORT_STAFF
if user_id == c.me.id:
is_support = "A person is a great support to himself"
omp = "Hmmm.......Who is that again?"
if is_support or c.me.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 == c.me.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>βοΈ Bio</b>: `{about}`
<b>π§βπ» Support</b>: {is_support}\n"""
if is_support:
caption += f"<b>π₯· Support user type</b>: <code>{omp}</code>\n<b>π£ Gbanned</b>: {gban}\n"
else:
caption += f"<b>π£ Gbanned</b>: {gban}\n"
if gban:
caption += f"<b>β οΈ Gban reason</b>: <code>{reason}</code>\n"
caption += f"""
<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):
u_name = False
if not already:
try:
chat = await c.get_chat(chat)
try:
chat_r = (await c.resolve_peer(chat.id))
ll = await c.invoke(
GetFullChannel(
channel=chat_r
)
)
u_name = ll.chats[0].usernames
except Exception:
pass
except Exception:
try:
chat_r = await c.resolve_peer(chat)
chat = await c.get_chat(chat_r.channel_id)
try:
ll = await c.invoke(
GetFullChannel(
channel=chat_r
)
)
u_name = ll.chats[0].usernames
except Exception:
pass
except KeyError as e:
caption = f"Failed to find the chat due to\n{e}"
return caption, None
chat_id = chat.id
username = " ".join([f"@{i}" for i in u_name]) if u_name else 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>: {f"@{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):
if message.reply_to_message and message.reply_to_message.sender_chat:
await message.reply_text("This is not a user, but rather a channel. Use `/chinfo` to fetch its information.")
return
try:
user, _, user_name = await extract_user(c, message)
except Exception:
await message.reply_text("Got Some errors failed to fetch user info")
LOGGER.error(e)
LOGGER.error(format_exc)
if not user:
await message.reply_text("Can't find user to fetch info!")
m = await message.reply_text(
f"Fetching {f'@{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:
if e == "User not found ! Error: 'InputPeerChannel' object has no attribute 'user_id'":
await m.reply_text(
"Looks like you are trying to fetch info of a chat not an user. In that case please use /chinfo")
return
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:
if message.reply_to_message and message.reply_to_message.sender_chat:
chat = message.reply_to_message.sender_chat.id
else:
chat = message.chat.id
else:
chat = splited[1]
try:
chat = int(chat)
except Exception as ef:
if "invalid literal for int() with base 10:" not in str(ef):
return await message.reply_text(
f"Got and exception {ef}\n**Usage:**/chinfo [USERNAME|ID]"
)
chat = str(chat)
if chat.startswith("https://"):
chat = '@' + chat.split("/")[-1]
m = await message.reply_text(
"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
"""
|