Spaces:
Sleeping
Sleeping
File size: 22,820 Bytes
87abec5 11ae35a f0f9ad9 11ae35a 6b5947b 11ae35a 83fe5dc ca4eb6d 83fe5dc 30b876d 6dcea66 f0f9ad9 11ae35a af45fef ca4eb6d 6cef7ec ca4eb6d 11170eb ca4eb6d 11170eb ca4eb6d 11170eb af1662b ca4eb6d 87abec5 ca4eb6d 89ad488 ca4eb6d 11170eb ca4eb6d 89ad488 ca4eb6d 56e6de1 ca4eb6d af45fef 56e6de1 ca4eb6d c62ca93 1d0457e ca4eb6d 2a73bdb ca4eb6d c62ca93 ca4eb6d 6dcea66 89ad488 6dcea66 ca4eb6d c62ca93 6cef7ec c62ca93 af45fef 6cef7ec ca4eb6d 6cef7ec ca4eb6d 83fe5dc ca4eb6d 6cef7ec ca4eb6d 11170eb ca4eb6d 56e6de1 ca4eb6d af45fef ca4eb6d af45fef 26c93b1 ca4eb6d af1662b ca4eb6d c62ca93 ca4eb6d 5ed29cb ca4eb6d 5bc27d3 ca4eb6d 26c93b1 78c0c28 9015bc5 af45fef 350cc3c 6cef7ec 89a7a7a 6cef7ec ca4eb6d 350cc3c ea3cfbe 89a7a7a ca4eb6d af45fef ca4eb6d 78c0c28 ca4eb6d af1662b ca4eb6d 11170eb ca4eb6d af1662b ca4eb6d af1662b ca4eb6d 56e6de1 ca4eb6d af45fef ca4eb6d af1662b ca4eb6d c62ca93 ca4eb6d 5ed29cb ca4eb6d 225c97e c62ca93 e36fb5a ca4eb6d 78c0c28 9015bc5 26c93b1 89a7a7a 6cef7ec 89a7a7a 6cef7ec 350cc3c 89a7a7a 6cef7ec ca4eb6d 11170eb ca4eb6d 78c0c28 ca4eb6d af1662b ca4eb6d 11170eb ca4eb6d 11170eb ca4eb6d af1662b ca4eb6d 56e6de1 ca4eb6d af45fef 225c97e c62ca93 225c97e e36fb5a 6b5947b 6cef7ec 225c97e e36fb5a 56e6de1 e36fb5a 225c97e af45fef ca4eb6d 6cef7ec 83fe5dc ca4eb6d 5ed29cb 11170eb ca4eb6d 11170eb ca4eb6d 11170eb ca4eb6d 11170eb ca4eb6d 11170eb ca4eb6d 56e6de1 ca4eb6d af45fef ca4eb6d 5ed29cb ca4eb6d af45fef 6cef7ec ca4eb6d 5ed29cb ca4eb6d af45fef ca4eb6d 5ed29cb ca4eb6d 89ad488 ca4eb6d c62ca93 ca4eb6d af45fef ca4eb6d 5ed29cb ca4eb6d 89ad488 ca4eb6d 6cef7ec ca4eb6d af45fef ca4eb6d 709df35 096ee5f 0006686 9da6fea d5348c6 0006686 9da6fea d5348c6 7eeba00 d5348c6 ea508b7 9da6fea af1662b |
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 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 |
from asyncio import sleep
from html import escape
from os import remove
from traceback import format_exc
from pyrogram import filters
from pyrogram.enums import ChatMemberStatus as CMS
from pyrogram.enums import ChatType
from pyrogram.errors import (BotChannelsNa, ChatAdminInviteRequired,
ChatAdminRequired, FloodWait, RightForbidden,
RPCError, UserAdminInvalid)
from pyrogram.types import ChatPrivileges, Message
from Powers import LOGGER, OWNER_ID
from Powers.bot_class import Gojo
from Powers.database.approve_db import Approve
from Powers.database.reporting_db import Reporting
from Powers.supports import get_support_staff
from Powers.utils.caching import ADMIN_CACHE, admin_cache_reload
from Powers.utils.custom_filters import admin_filter, command, promote_filter
from Powers.utils.extract_user import extract_user
from Powers.utils.parser import mention_html
@Gojo.on_message(command("adminlist"))
async def adminlist_show(_, m: Message):
global ADMIN_CACHE
if m.chat.type not in [ChatType.SUPERGROUP, ChatType.GROUP]:
return await m.reply_text(
text="This command is made to be used in groups only!",
)
try:
try:
admin_list = ADMIN_CACHE[m.chat.id]
note = "<i>Note:</i> These are cached values!"
except KeyError:
admin_list = await admin_cache_reload(m, "adminlist")
note = "<i>Note:</i> These are up-to-date values!"
adminstr = f"Admins in <b>{m.chat.title}</b>:" + "\n\n"
bot_admins = [i for i in admin_list if (i[1].lower()).endswith("bot")]
user_admins = [i for i in admin_list if not (i[1].lower()).endswith("bot")]
# format is like: (user_id, username/name,anonyamous or not)
mention_users = [
(
admin[1]
if admin[1].startswith("@")
else (await mention_html(admin[1], admin[0]))
)
for admin in user_admins
if not admin[2] # if non-anonyamous admin
]
mention_users.sort(key=lambda x: x[1])
mention_bots = [
(
admin[1]
if admin[1].startswith("@")
else (await mention_html(admin[1], admin[0]))
)
for admin in bot_admins
]
mention_bots.sort(key=lambda x: x[1])
adminstr += "<b>User Admins:</b>\n"
adminstr += "\n".join(f"- {i}" for i in mention_users)
adminstr += "\n\n<b>Bots:</b>\n"
adminstr += "\n".join(f"- {i}" for i in mention_bots)
await m.reply_text(adminstr + "\n\n" + note)
except Exception as ef:
if str(ef) == str(m.chat.id):
await m.reply_text(text="Use /admincache to reload admins!")
else:
ef = f"{str(ef)}{admin_list}\n"
await m.reply_text(
text=f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{ef}</code>"
)
LOGGER.error(ef)
LOGGER.error(format_exc())
return
@Gojo.on_message(command("zombies") & admin_filter)
async def zombie_clean(c: Gojo, m: Message):
zombie = 0
wait = await m.reply_text("Searching ... and banning ...")
failed = 0
async for member in c.get_chat_members(m.chat.id):
if member.user.is_deleted:
zombie += 1
try:
await c.ban_chat_member(m.chat.id, member.user.id)
except UserAdminInvalid:
failed += 1
except FloodWait as e:
await sleep(e.value)
try:
await c.ban_chat_member(m.chat.id, member.user.id)
except Exception:
pass
if zombie == 0:
return await wait.edit_text("Group is clean!")
await wait.delete()
txt = f"<b>{zombie}</b> Zombies found and {zombie - failed} has been banned!\n{failed} zombies' are immune to me",
await m.reply_animation("https://graph.org/file/02a1dcf7788186ffb36cb.mp4", caption=txt)
return
@Gojo.on_message(command("admincache"))
async def reload_admins(_, m: Message):
global TEMP_ADMIN_CACHE_BLOCK
if m.chat.type not in [ChatType.SUPERGROUP, ChatType.GROUP]:
return await m.reply_text(
"This command is made to be used in groups only!",
)
SUPPORT_STAFF = get_support_staff()
if (
(m.chat.id in set(TEMP_ADMIN_CACHE_BLOCK.keys()))
and (m.from_user.id not in SUPPORT_STAFF)
and TEMP_ADMIN_CACHE_BLOCK[m.chat.id] == "manualblock"
):
await m.reply_text("Can only reload admin cache once per 10 mins!")
return
try:
await admin_cache_reload(m, "admincache")
TEMP_ADMIN_CACHE_BLOCK[m.chat.id] = "manualblock"
await m.reply_text(text="Reloaded all admins in this chat!")
except RPCError as ef:
await m.reply_text(
text=f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{ef}</code>"
)
LOGGER.error(ef)
LOGGER.error(format_exc())
return
@Gojo.on_message(filters.regex(r"^(?i)@admin(s)?") & filters.group)
async def tag_admins(_, m: Message):
db = Reporting(m.chat.id)
if not db.get_settings():
return
try:
admin_list = ADMIN_CACHE[m.chat.id]
except KeyError:
admin_list = await admin_cache_reload(m, "adminlist")
user_admins = [i for i in admin_list if not (i[1].lower()).endswith("bot")]
mention_users = [(await mention_html("\u2063", admin[0])) for admin in user_admins]
mention_users.sort(key=lambda x: x[1])
mention_str = "".join(mention_users)
await m.reply_text(
(
f"{(await mention_html(m.from_user.first_name, m.from_user.id))}"
f" reported the message to admins!{mention_str}"
),
)
@Gojo.on_message(command("fullpromote") & promote_filter)
async def fullpromote_usr(c: Gojo, m: Message):
global ADMIN_CACHE
if len(m.text.split()) == 1 and not m.reply_to_message:
await m.reply_text(
text="I can't promote nothing! Give me an username or user id or atleast reply to that user"
)
return
try:
user_id, user_first_name, user_name = await extract_user(c, m)
except Exception:
return
bot = await c.get_chat_member(m.chat.id, c.me.id)
if user_id == c.me.id:
await m.reply_text("Huh, how can I even promote myself?")
return
if not bot.privileges.can_promote_members:
return await m.reply_text(
"I don't have enough permissions!",
) # This should be here
user = await c.get_chat_member(m.chat.id, m.from_user.id)
if m.from_user.id != OWNER_ID and user.status != CMS.OWNER:
return await m.reply_text("This command can only be used by chat owner.")
# If user is alreay admin
try:
admin_list = {i[0] for i in ADMIN_CACHE[m.chat.id]}
except KeyError:
admin_list = {
i[0] for i in (await admin_cache_reload(m, "promote_cache_update"))
}
if user_id in admin_list:
await m.reply_text(
"This user is already an admin, how am I supposed to re-promote them?",
)
return
try:
await m.chat.promote_member(user_id=user_id, privileges=bot.privileges)
title = ""
if m.chat.type in [ChatType.SUPERGROUP, ChatType.GROUP]:
title = "Gojo" # Default fullpromote title
if len(m.text.split()) == 3 and not m.reply_to_message:
title = " ".join(m.text.split()[2:16]) # trim title to 16 characters
elif len(m.text.split()) >= 2 and m.reply_to_message:
title = " ".join(m.text.split()[1:16]) # trim title to 16 characters
try:
await c.set_administrator_title(m.chat.id, user_id, title)
except RPCError as e:
LOGGER.error(e)
LOGGER.error(format_exc())
except Exception as e:
LOGGER.error(e)
LOGGER.error(format_exc())
await m.reply_text(
(
"{promoter} promoted {promoted} in chat <b>{chat_title}</b> with full rights!"
).format(
promoter=(await mention_html(m.from_user.first_name, m.from_user.id)),
promoted=(await mention_html(user_first_name, user_id)),
chat_title=f"{escape(m.chat.title)} title set to {title}"
if title
else f"{escape(m.chat.title)} title set to Default",
),
)
# If user is approved, disapprove them as they willbe promoted and get
# even more rights
if Approve(m.chat.id).check_approve(user_id):
Approve(m.chat.id).remove_approve(user_id)
# ----- Add admin to temp cache -----
try:
inp1 = user_name or user_first_name
admins_group = ADMIN_CACHE[m.chat.id]
admins_group.append((user_id, inp1))
ADMIN_CACHE[m.chat.id] = admins_group
except KeyError:
await admin_cache_reload(m, "promote_key_error")
except ChatAdminRequired:
await m.reply_text(text="I'm not admin or I don't have rights......")
except RightForbidden:
await m.reply_text(text="I don't have enough rights to promote this user.")
except UserAdminInvalid:
await m.reply_text(
text="Cannot act on this user, maybe I wasn't the one who changed their permissions."
)
except RPCError as e:
await m.reply_text(
text=f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{e}</code>"
)
LOGGER.error(e)
LOGGER.error(format_exc())
return
@Gojo.on_message(command("promote") & promote_filter)
async def promote_usr(c: Gojo, m: Message):
global ADMIN_CACHE
if len(m.text.split()) == 1 and not m.reply_to_message:
await m.reply_text(
text="I can't promote nothing!......reply to user to promote him/her...."
)
return
try:
user_id, user_first_name, user_name = await extract_user(c, m)
except Exception:
return
bot = await c.get_chat_member(m.chat.id, c.me.id)
if user_id == c.me.id:
await m.reply_text("Huh, how can I even promote myself?")
return
if not bot.privileges.can_promote_members:
return await m.reply_text(
"I don't have enough permissions",
) # This should be here
# If user is alreay admin
try:
admin_list = {i[0] for i in ADMIN_CACHE[m.chat.id]}
except KeyError:
admin_list = {
i[0] for i in (await admin_cache_reload(m, "promote_cache_update"))
}
if user_id in admin_list:
await m.reply_text(
"This user is already an admin, how am I supposed to re-promote them?",
)
return
try:
await m.chat.promote_member(
user_id=user_id,
privileges=ChatPrivileges(
can_change_info=bot.privileges.can_change_info,
can_invite_users=bot.privileges.can_invite_users,
can_delete_messages=bot.privileges.can_delete_messages,
can_restrict_members=bot.privileges.can_restrict_members,
can_pin_messages=bot.privileges.can_pin_messages,
can_manage_chat=bot.privileges.can_manage_chat,
can_manage_video_chats=bot.privileges.can_manage_video_chats,
can_post_messages=bot.privileges.can_post_messages,
can_edit_messages=bot.privileges.can_edit_messages
),
)
title = ""
if m.chat.type in [ChatType.SUPERGROUP, ChatType.GROUP]:
title = "Itadori" # Deafult title
if len(m.text.split()) >= 3 and not m.reply_to_message:
title = " ".join(m.text.split()[2:16]) # trim title to 16 characters
elif len(m.text.split()) >= 2 and m.reply_to_message:
title = " ".join(m.text.split()[1:16]) # trim title to 16 characters
try:
await c.set_administrator_title(m.chat.id, user_id, title)
except RPCError as e:
LOGGER.error(e)
LOGGER.error(format_exc())
except Exception as e:
LOGGER.error(e)
LOGGER.error(format_exc())
await m.reply_text(
("{promoter} promoted {promoted} in chat <b>{chat_title}</b>!").format(
promoter=(await mention_html(m.from_user.first_name, m.from_user.id)),
promoted=(await mention_html(user_first_name, user_id)),
chat_title=f"{escape(m.chat.title)} title set to {title}"
if title
else f"{escape(m.chat.title)} title set to default",
),
)
# If user is approved, disapprove them as they willbe promoted and get
# even more rights
if Approve(m.chat.id).check_approve(user_id):
Approve(m.chat.id).remove_approve(user_id)
# ----- Add admin to temp cache -----
try:
inp1 = user_name or user_first_name
admins_group = ADMIN_CACHE[m.chat.id]
admins_group.append((user_id, inp1))
ADMIN_CACHE[m.chat.id] = admins_group
except KeyError:
await admin_cache_reload(m, "promote_key_error")
except ChatAdminRequired:
await m.reply_text(text="I'm not admin or I don't have rights.")
except RightForbidden:
await m.reply_text(text="I don't have enough rights to promote this user.")
except UserAdminInvalid:
await m.reply_text(
text="Cannot act on this user, maybe I wasn't the one who changed their permissions."
)
except RPCError as e:
await m.reply_text(
text=f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{e}</code>"
)
LOGGER.error(e)
LOGGER.error(format_exc())
return
@Gojo.on_message(command("demote") & promote_filter)
async def demote_usr(c: Gojo, m: Message):
global ADMIN_CACHE
if len(m.text.split()) == 1 and not m.reply_to_message:
await m.reply_text("I can't demote nothing.")
return
try:
user_id, user_first_name, _ = await extract_user(c, m)
except Exception:
return
if user_id == c.me.id:
await m.reply_text("Get an admin to demote me!")
return
# If user not already admin
try:
admin_list = {i[0] for i in ADMIN_CACHE[m.chat.id]}
except KeyError:
admin_list = {
i[0] for i in (await admin_cache_reload(m, "demote_cache_update"))
}
if user_id not in admin_list:
await m.reply_text(
"This user is not an admin, how am I supposed to re-demote them?",
)
return
try:
await m.chat.promote_member(
user_id=user_id,
privileges=ChatPrivileges(can_manage_chat=False),
)
# ----- Remove admin from cache -----
try:
admin_list = ADMIN_CACHE[m.chat.id]
user = next(user for user in admin_list if user[0] == user_id)
admin_list.remove(user)
ADMIN_CACHE[m.chat.id] = admin_list
except (KeyError, StopIteration):
await admin_cache_reload(m, "demote_key_stopiter_error")
await m.reply_text(
("{demoter} demoted {demoted} in <b>{chat_title}</b>!").format(
demoter=(
await mention_html(
m.from_user.first_name,
m.from_user.id,
)
),
demoted=(await mention_html(user_first_name, user_id)),
chat_title=m.chat.title,
),
)
except ChatAdminRequired:
await m.reply_text("I am not admin aroung here.")
except RightForbidden:
await m.reply_text("I can't demote users here.")
except UserAdminInvalid:
await m.reply_text(
"Cannot act on this user, maybe I wasn't the one who changed their permissions."
)
except BotChannelsNa:
await m.reply_text(
"May be the user is bot and due to telegram restrictions I can't demote them. Please do it manually")
except RPCError as ef:
await m.reply_text(
f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{ef}</code>"
)
LOGGER.error(ef)
LOGGER.error(format_exc())
return
@Gojo.on_message(command("invitelink"))
async def get_invitelink(c: Gojo, m: Message):
# Bypass the bot devs, sudos and owner
DEV_LEVEL = get_support_staff("dev_level")
if m.from_user.id not in DEV_LEVEL:
user = await m.chat.get_member(m.from_user.id)
if not user.privileges.can_invite_users and user.status != CMS.OWNER:
await m.reply_text(text="You don't have rights to invite users....")
return False
try:
link = await c.export_chat_invite_link(m.chat.id)
await m.reply_text(
text=f"Invite Link for Chat <b>{m.chat.id}</b>: {link}",
disable_web_page_preview=True,
)
except ChatAdminRequired:
await m.reply_text(text="I'm not admin or I don't have rights.")
except ChatAdminInviteRequired:
await m.reply_text(text="I don't have permission for invite link!")
except RightForbidden:
await m.reply_text(text="You don't have permissions to invite users.")
except RPCError as ef:
await m.reply_text(
text=f"Some error occured, report it using `/bug` \n <b>Error:</b> <code>{ef}</code>"
)
LOGGER.error(ef)
LOGGER.error(format_exc())
return
@Gojo.on_message(command("setgtitle") & admin_filter)
async def setgtitle(_, m: Message):
user = await m.chat.get_member(m.from_user.id)
if not user.privileges.can_change_info and user.status != CMS.OWNER:
await m.reply_text(
"You don't have enough permission to use this command!",
)
return False
if len(m.command) < 1:
return await m.reply_text("Please read /help for using it!")
gtit = m.text.split(None, 1)[1]
try:
await m.chat.set_title(gtit)
except Exception as e:
return await m.reply_text(f"Error: {e}")
return await m.reply_text(
f"Successfully Changed Group Title From {m.chat.title} To {gtit}",
)
@Gojo.on_message(command("setgdes") & admin_filter)
async def setgdes(_, m: Message):
user = await m.chat.get_member(m.from_user.id)
if not user.privileges.can_change_info and user.status != CMS.OWNER:
await m.reply_text(
"You don't have enough permission to use this command!",
)
return False
if len(m.command) < 1:
return await m.reply_text("Please read /help for using it!")
desp = m.text.split(None, 1)[1]
try:
await m.chat.set_description(desp)
except Exception as e:
return await m.reply_text(f"Error: {e}")
return await m.reply_text(
f"Successfully Changed Group description From {m.chat.description} To {desp}",
)
@Gojo.on_message(command("title") & admin_filter)
async def set_user_title(c: Gojo, m: Message):
user = await m.chat.get_member(m.from_user.id)
if not user.privileges.can_promote_members and user.status != CMS.OWNER:
await m.reply_text(
"You don't have enough permission to use this command!",
)
return False
if len(m.text.split()) == 1 and not m.reply_to_message:
return await m.reply_text("To whom??")
if m.reply_to_message:
if len(m.text.split()) >= 2:
reason = m.text.split(None, 1)[1]
elif len(m.text.split()) >= 3:
reason = m.text.split(None, 2)[2]
try:
user_id, _, _ = await extract_user(c, m)
except Exception:
return
if not user_id:
return await m.reply_text("Cannot find user!")
if user_id == c.me.id:
return await m.reply_text("Huh, why ?")
if not reason:
return await m.reply_text("Read /help please!")
from_user = await c.get_users(user_id)
title = reason
try:
await c.set_administrator_title(m.chat.id, from_user.id, title)
except Exception as e:
return await m.reply_text(f"Error: {e}")
return await m.reply_text(
f"Successfully Changed {from_user.mention}'s Admin Title To {title}",
)
@Gojo.on_message(command("setgpic") & admin_filter)
async def setgpic(c: Gojo, m: Message):
user = await m.chat.get_member(m.from_user.id)
if not user.privileges.can_change_info and user.status != CMS.OWNER:
await m.reply_text(
"You don't have enough permission to use this command!",
)
return False
if not m.reply_to_message:
return await m.reply_text("Reply to a photo to set it as chat photo")
if not m.reply_to_message.photo and not m.reply_to_message.document:
return await m.reply_text("Reply to a photo to set it as chat photo")
photo = await m.reply_to_message.download()
is_vid = bool(m.reply_to_message.video)
try:
await m.chat.set_photo(photo, video=is_vid)
except Exception as e:
remove(photo)
return await m.reply_text(f"Error: {e}")
await m.reply_text("Successfully Changed Group Photo!")
remove(photo)
__PLUGIN__ = "admin"
__alt_name__ = [
"admins",
"promote",
"demote",
"adminlist",
"setgpic",
"title",
"setgtitle",
"fullpromote",
"invitelink",
"setgdes",
"zombies",
]
__HELP__ = """
**Admin**
**User Commands:**
• /adminlist: List all the admins in the Group.
**Admin only:**
• /invitelink: Gets chat invitelink.
• /promote: Promotes the user replied to or tagged (supports with title).
• /fullpromote: Fully Promotes the user replied to or tagged (supports with title).
• /demote: Demotes the user replied to or tagged.
• /setgpic: Set group picture.
• /admincache: Reloads the List of all the admins in the Group.
• /zombies: Bans all the deleted accounts. (owner only)
• /title: sets a custom title for an admin that the bot promoted.
• /disable <commandname>: Stop users from using "commandname" in this group.
• /enable <item name>: Allow users from using "commandname" in this group.
• /disableable: List all disableable commands.
• /disabledel <yes/off>: Delete disabled commands when used by non-admins.
• /disabled: List the disabled commands in this chat.
• /enableall: enable all disabled commands.
**Example:**
`/promote @username`: this promotes a user to admin."""
|