|
import datetime, time, os, asyncio,logging |
|
from pyrogram.errors import InputUserDeactivated, UserNotParticipant, FloodWait, UserIsBlocked, PeerIdInvalid |
|
from pyrogram.errors.exceptions.bad_request_400 import MessageTooLong, PeerIdInvalid |
|
from pyrogram.types import Message, InlineKeyboardButton |
|
from pyrogram import Client, filters, enums |
|
from database.users_chats_db import db |
|
from info import ADMINS |
|
|
|
|
|
@Client.on_message(filters.command("broadcast") & filters.user(ADMINS) & filters.reply) |
|
async def broadcast(bot, message): |
|
users = await db.get_all_users() |
|
b_msg = message.reply_to_message |
|
sts = await message.reply_text('Bʀᴏᴀᴅᴄᴀsᴛɪɴɢ Yᴏᴜʀ Mᴇssᴀɢᴇs...') |
|
start_time = time.time() |
|
total_users = await db.total_users_count() |
|
done = 0 |
|
blocked = 0 |
|
deleted = 0 |
|
failed =0 |
|
success = 0 |
|
async for user in users: |
|
pti, sh = await broadcast_messages(int(user['id']), b_msg) |
|
if pti: |
|
success += 1 |
|
elif pti == False: |
|
if sh == "Blocked": |
|
blocked+=1 |
|
elif sh == "Deleted": |
|
deleted += 1 |
|
elif sh == "Error": |
|
failed += 1 |
|
done += 1 |
|
if not done % 20: |
|
await sts.edit(f"Bʀᴏᴀᴅᴄᴀsᴛ Iɴ Pʀᴏɢʀᴇss:\n\nTᴏᴛᴀʟ Uꜱᴇʀꜱ {total_users}\nCᴏᴍᴩʟᴇᴛᴇᴅ: {done} / {total_users}\nSᴜᴄᴄᴇꜱꜱ: {success}\nBʟᴏᴄᴋᴇᴅ: {blocked}\nDᴇʟᴇᴛᴇᴅ: {deleted}") |
|
time_taken = datetime.timedelta(seconds=int(time.time()-start_time)) |
|
await sts.delete() |
|
await bot.send_message(message.chat.id, f"Bʀᴏᴀᴅᴄᴀsᴛ Coᴍᴩʟᴇᴛᴇᴅ:\nTɪᴍᴇ Tᴀᴋᴇᴅ{time_taken} Sᴇᴄ\n\nTᴏᴛᴀʟ Uꜱᴇʀꜱ: {total_users}\nCᴏᴍᴩʟᴇᴛᴇᴅ: {done} / {total_users}\nSucᴄᴇꜱꜱ: {success}\nBʟᴏᴄᴋᴇᴅ: {blocked}\nDᴇʟᴇᴛᴇᴅ: {deleted}") |
|
|
|
|
|
@Client.on_message(filters.command("clear_junk") & filters.user(ADMINS)) |
|
async def remove_junkuser__db(bot, message): |
|
users = await db.get_all_users() |
|
b_msg = message |
|
sts = await message.reply_text('IN PROGRESS.......') |
|
start_time = time.time() |
|
total_users = await db.total_users_count() |
|
blocked = 0 |
|
deleted = 0 |
|
failed = 0 |
|
done = 0 |
|
async for user in users: |
|
pti, sh = await clear_junk(int(user['id']), b_msg) |
|
if pti == False: |
|
if sh == "Blocked": |
|
blocked+=1 |
|
elif sh == "Deleted": |
|
deleted += 1 |
|
elif sh == "Error": |
|
failed += 1 |
|
done += 1 |
|
if not done % 20: |
|
await sts.edit(f"In Progress:\n\nTotal Users {total_users}\nCompleted: {done} / {total_users}\nBlocked: {blocked}\nDeleted: {deleted}") |
|
time_taken = datetime.timedelta(seconds=int(time.time()-start_time)) |
|
await sts.delete() |
|
await bot.send_message(message.chat.id, f"Completed:\nCompleted in {time_taken} seconds.\n\nTotal Users {total_users}\nCompleted: {done} / {total_users}\nBlocked: {blocked}\nDeleted: {deleted}") |
|
|
|
|
|
@Client.on_message(filters.command("group_broadcast") & filters.user(ADMINS) & filters.reply) |
|
async def broadcast_group(bot, message): |
|
groups = await db.get_all_chats() |
|
b_msg = message.reply_to_message |
|
sts = await message.reply_text(text='Broadcasting your messages To Groups...') |
|
start_time = time.time() |
|
total_groups = await db.total_chat_count() |
|
done = 0 |
|
failed = "" |
|
success = 0 |
|
deleted = 0 |
|
async for group in groups: |
|
pti, sh, ex = await broadcast_messages_group(int(group['id']), b_msg) |
|
if pti == True: |
|
if sh == "Succes": |
|
success += 1 |
|
elif pti == False: |
|
if sh == "deleted": |
|
deleted+=1 |
|
failed += ex |
|
try: |
|
await bot.leave_chat(int(group['id'])) |
|
except Exception as e: |
|
print(f"{e} > {group['id']}") |
|
done += 1 |
|
if not done % 20: |
|
await sts.edit(f"Broadcast in progress:\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nSuccess: {success}\nDeleted: {deleted}") |
|
time_taken = datetime.timedelta(seconds=int(time.time()-start_time)) |
|
await sts.delete() |
|
try: |
|
await message.reply_text(f"Broadcast Completed:\nCompleted in {time_taken} seconds.\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nSuccess: {success}\nDeleted: {deleted}\n\nFiled Reson:- {failed}") |
|
except MessageTooLong: |
|
with open('reason.txt', 'w+') as outfile: |
|
outfile.write(failed) |
|
await message.reply_document('reason.txt', caption=f"Completed:\nCompleted in {time_taken} seconds.\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nSuccess: {success}\nDeleted: {deleted}") |
|
os.remove("reason.txt") |
|
|
|
|
|
@Client.on_message(filters.command(["junk_group", "clear_junk_group"]) & filters.user(ADMINS)) |
|
async def junk_clear_group(bot, message): |
|
groups = await db.get_all_chats() |
|
b_msg = message |
|
sts = await message.reply_text(text='..............') |
|
start_time = time.time() |
|
total_groups = await db.total_chat_count() |
|
done = 0 |
|
failed = "" |
|
deleted = 0 |
|
async for group in groups: |
|
pti, sh, ex = await junk_group(int(group['id']), b_msg) |
|
if pti == False: |
|
if sh == "deleted": |
|
deleted+=1 |
|
failed += ex |
|
try: |
|
await bot.leave_chat(int(group['id'])) |
|
except Exception as e: |
|
print(f"{e} > {group['id']}") |
|
done += 1 |
|
if not done % 20: |
|
await sts.edit(f"in progress:\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nDeleted: {deleted}") |
|
time_taken = datetime.timedelta(seconds=int(time.time()-start_time)) |
|
await sts.delete() |
|
try: |
|
await bot.send_message(message.chat.id, f"Completed:\nCompleted in {time_taken} seconds.\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nDeleted: {deleted}\n\nFiled Reson:- {failed}") |
|
except MessageTooLong: |
|
with open('junk.txt', 'w+') as outfile: |
|
outfile.write(failed) |
|
await message.reply_document('junk.txt', caption=f"Completed:\nCompleted in {time_taken} seconds.\n\nTotal Groups {total_groups}\nCompleted: {done} / {total_groups}\nDeleted: {deleted}") |
|
os.remove("junk.txt") |
|
|
|
async def broadcast_messages_group(chat_id, message): |
|
try: |
|
await message.copy(chat_id=chat_id) |
|
return True, "Succes", 'mm' |
|
except FloodWait as e: |
|
await asyncio.sleep(e.value) |
|
return await broadcast_messages_group(chat_id, message) |
|
except Exception as e: |
|
await db.delete_chat(int(chat_id)) |
|
logging.info(f"{chat_id} - PeerIdInvalid") |
|
return False, "deleted", f'{e}\n\n' |
|
|
|
async def junk_group(chat_id, message): |
|
try: |
|
kk = await message.copy(chat_id=chat_id) |
|
await kk.delete(True) |
|
return True, "Succes", 'mm' |
|
except FloodWait as e: |
|
await asyncio.sleep(e.value) |
|
return await junk_group(chat_id, message) |
|
except Exception as e: |
|
await db.delete_chat(int(chat_id)) |
|
logging.info(f"{chat_id} - PeerIdInvalid") |
|
return False, "deleted", f'{e}\n\n' |
|
|
|
|
|
async def clear_junk(user_id, message): |
|
try: |
|
key = await message.copy(chat_id=user_id) |
|
await key.delete(True) |
|
return True, "Success" |
|
except FloodWait as e: |
|
await asyncio.sleep(e.value) |
|
return await clear_junk(user_id, message) |
|
except InputUserDeactivated: |
|
await db.delete_user(int(user_id)) |
|
logging.info(f"{user_id}-Removed from Database, since deleted account.") |
|
return False, "Deleted" |
|
except UserIsBlocked: |
|
logging.info(f"{user_id} -Blocked the bot.") |
|
return False, "Blocked" |
|
except PeerIdInvalid: |
|
await db.delete_user(int(user_id)) |
|
logging.info(f"{user_id} - PeerIdInvalid") |
|
return False, "Error" |
|
except Exception as e: |
|
return False, "Error" |
|
|
|
|
|
|
|
async def broadcast_messages(user_id, message): |
|
try: |
|
await message.copy(chat_id=user_id) |
|
return True, "Success" |
|
except FloodWait as e: |
|
await asyncio.sleep(e.value) |
|
return await broadcast_messages(user_id, message) |
|
except InputUserDeactivated: |
|
await db.delete_user(int(user_id)) |
|
logging.info(f"{user_id}-Removed from Database, since deleted account.") |
|
return False, "Deleted" |
|
except UserIsBlocked: |
|
logging.info(f"{user_id} -Blocked the bot.") |
|
return False, "Blocked" |
|
except PeerIdInvalid: |
|
await db.delete_user(int(user_id)) |
|
logging.info(f"{user_id} - PeerIdInvalid") |
|
return False, "Error" |
|
except Exception as e: |
|
return False, "Error" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|