|
import os |
|
import time |
|
import string |
|
import random |
|
import asyncio |
|
import aiofiles |
|
import datetime |
|
|
|
from FileStream.utils.broadcast_helper import send_msg |
|
from FileStream.utils.database import Database |
|
from FileStream.bot import FileStream |
|
from FileStream.server.exceptions import FIleNotFound |
|
from FileStream.config import Telegram, Server |
|
from pyrogram import filters, Client |
|
from pyrogram.types import Message |
|
from pyrogram.enums.parse_mode import ParseMode |
|
|
|
db = Database(Telegram.DATABASE_URL, Telegram.SESSION_NAME) |
|
broadcast_ids = {} |
|
|
|
|
|
@FileStream.on_message(filters.command("status") & filters.private & filters.user(Telegram.OWNER_ID)) |
|
async def sts(c: Client, m: Message): |
|
await m.reply_text(text=f"""**Total Users in DB:** `{await db.total_users_count()}` |
|
**Banned Users in DB:** `{await db.total_banned_users_count()}` |
|
**Total Links Generated: ** `{await db.total_files()}`""" |
|
, parse_mode=ParseMode.MARKDOWN, quote=True) |
|
|
|
|
|
@FileStream.on_message(filters.command("ban") & filters.private & filters.user(Telegram.OWNER_ID)) |
|
async def sts(b, m: Message): |
|
id = m.text.split("/ban ")[-1] |
|
if not await db.is_user_banned(int(id)): |
|
try: |
|
await db.ban_user(int(id)) |
|
await db.delete_user(int(id)) |
|
await m.reply_text(text=f"`{id}`** is Banned** ", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
if not str(id).startswith('-100'): |
|
await b.send_message( |
|
chat_id=id, |
|
text="**Your Banned to Use The Bot**", |
|
parse_mode=ParseMode.MARKDOWN, |
|
disable_web_page_preview=True |
|
) |
|
except Exception as e: |
|
await m.reply_text(text=f"**something went wrong: {e}** ", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
else: |
|
await m.reply_text(text=f"`{id}`** is Already Banned** ", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
|
|
|
|
@FileStream.on_message(filters.command("unban") & filters.private & filters.user(Telegram.OWNER_ID)) |
|
async def sts(b, m: Message): |
|
id = m.text.split("/unban ")[-1] |
|
if await db.is_user_banned(int(id)): |
|
try: |
|
await db.unban_user(int(id)) |
|
await m.reply_text(text=f"`{id}`** is Unbanned** ", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
if not str(id).startswith('-100'): |
|
await b.send_message( |
|
chat_id=id, |
|
text="**Your Unbanned now Use can use The Bot**", |
|
parse_mode=ParseMode.MARKDOWN, |
|
disable_web_page_preview=True |
|
) |
|
except Exception as e: |
|
await m.reply_text(text=f"** something went wrong: {e}**", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
else: |
|
await m.reply_text(text=f"`{id}`** is not Banned** ", parse_mode=ParseMode.MARKDOWN, quote=True) |
|
|
|
|
|
@FileStream.on_message(filters.command("broadcast") & filters.private & filters.user(Telegram.OWNER_ID) & filters.reply) |
|
async def broadcast_(c, m): |
|
all_users = await db.get_all_users() |
|
broadcast_msg = m.reply_to_message |
|
while True: |
|
broadcast_id = ''.join([random.choice(string.ascii_letters) for i in range(3)]) |
|
if not broadcast_ids.get(broadcast_id): |
|
break |
|
out = await m.reply_text( |
|
text=f"Broadcast initiated! You will be notified with log file when all the users are notified." |
|
) |
|
start_time = time.time() |
|
total_users = await db.total_users_count() |
|
done = 0 |
|
failed = 0 |
|
success = 0 |
|
broadcast_ids[broadcast_id] = dict( |
|
total=total_users, |
|
current=done, |
|
failed=failed, |
|
success=success |
|
) |
|
async with aiofiles.open('broadcast.txt', 'w') as broadcast_log_file: |
|
async for user in all_users: |
|
sts, msg = await send_msg( |
|
user_id=int(user['id']), |
|
message=broadcast_msg |
|
) |
|
if msg is not None: |
|
await broadcast_log_file.write(msg) |
|
if sts == 200: |
|
success += 1 |
|
else: |
|
failed += 1 |
|
if sts == 400: |
|
await db.delete_user(user['id']) |
|
done += 1 |
|
if broadcast_ids.get(broadcast_id) is None: |
|
break |
|
else: |
|
broadcast_ids[broadcast_id].update( |
|
dict( |
|
current=done, |
|
failed=failed, |
|
success=success |
|
) |
|
) |
|
try: |
|
await out.edit_text(f"Broadcast Status\n\ncurrent: {done}\nfailed:{failed}\nsuccess: {success}") |
|
except: |
|
pass |
|
if broadcast_ids.get(broadcast_id): |
|
broadcast_ids.pop(broadcast_id) |
|
completed_in = datetime.timedelta(seconds=int(time.time() - start_time)) |
|
await asyncio.sleep(3) |
|
await out.delete() |
|
if failed == 0: |
|
await m.reply_text( |
|
text=f"broadcast completed in `{completed_in}`\n\nTotal users {total_users}.\nTotal done {done}, {success} success and {failed} failed.", |
|
quote=True |
|
) |
|
else: |
|
await m.reply_document( |
|
document='broadcast.txt', |
|
caption=f"broadcast completed in `{completed_in}`\n\nTotal users {total_users}.\nTotal done {done}, {success} success and {failed} failed.", |
|
quote=True |
|
) |
|
os.remove('broadcast.txt') |
|
|
|
|
|
@FileStream.on_message(filters.command("del") & filters.private & filters.user(Telegram.OWNER_ID)) |
|
async def sts(c: Client, m: Message): |
|
file_id = m.text.split(" ")[-1] |
|
try: |
|
file_info = await db.get_file(file_id) |
|
except FIleNotFound: |
|
await m.reply_text( |
|
text=f"**File Already Deleted**", |
|
quote=True |
|
) |
|
return |
|
await db.delete_one_file(file_info['_id']) |
|
await db.count_links(file_info['user_id'], "-") |
|
await m.reply_text( |
|
text=f"**Fɪʟᴇ Dᴇʟᴇᴛᴇᴅ Sᴜᴄᴄᴇssғᴜʟʟʏ !** ", |
|
quote=True |
|
) |
|
|
|
|
|
|
|
|