|  | 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" | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  | 
					
						
						|  |  |