Auto Click Cloudflare Ignore & Proceed

Автоматически нажимает кнопку "Ignore & Proceed" в предупреждении Cloudflare

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Auto Click Cloudflare Ignore & Proceed
// @namespace    http://tampermonkey.net/
// @version      0.3
// @description  Автоматически нажимает кнопку "Ignore & Proceed" в предупреждении Cloudflare
// @author       thebelg
// @match        *://*/*
// @grant        none
// @license      MIT
// @run-at       document-start
// ==/UserScript==

(function() {
    'use strict';

    function clickIgnoreButton() {
        // Ищем кнопку по разным возможным селекторам
        const ignoreButtonSelectors = [
            'button:contains("Ignore & Proceed")',
            'a:contains("Ignore & Proceed")',
            'button.ignore-button',
            'a.ignore-button',
            'button[class*="ignore"]',
            'a[class*="ignore"]',
            '[onclick*="ignore"]',
            '[id*="ignore"]',
            '[class*="proceed"]'
        ];

        // Перебираем селекторы и пытаемся найти и нажать на кнопку
        for (const selector of ignoreButtonSelectors) {
            try {
                // Поиск по тексту содержимого
                const buttonsByText = Array.from(document.querySelectorAll('button, a, input[type="button"], input[type="submit"]'))
                    .filter(el => el.textContent && el.textContent.includes('Ignore') && el.textContent.includes('Proceed'));

                if (buttonsByText.length > 0) {
                    buttonsByText[0].click();
                    console.log('Clicked ignore button by text content');
                    return true;
                }

                // Поиск по селектору
                const buttons = document.querySelectorAll(selector);
                if (buttons.length > 0) {
                    buttons[0].click();
                    console.log('Clicked ignore button by selector: ' + selector);
                    return true;
                }
            } catch (e) {
                // Игнорируем ошибки селекторов
            }
        }

        return false;
    }

    // Функция, которая будет вызываться несколько раз для попытки нажатия на кнопку
    function attemptToClick() {
        if (clickIgnoreButton()) {
            console.log('Successfully clicked the ignore button');
        } else {
            console.log('Button not found yet');
        }
    }

    // Запускаем попытки клика как можно раньше и часто
    // Начинаем с минимальной задержки и увеличиваем интервал
    for (let i = 0; i < 5; i++) {
        setTimeout(attemptToClick, 50 * i); // Первые попытки - очень быстро (50, 100, 150, 200, 250 мс)
    }

    for (let i = 0; i < 10; i++) {
        setTimeout(attemptToClick, 300 + 100 * i); // Следующие попытки с интервалом в 100 мс
    }

    // Запускаем при загрузке DOM для надежности
    document.addEventListener('DOMContentLoaded', function() {
        attemptToClick();
        // Еще несколько попыток после загрузки DOM
        setTimeout(attemptToClick, 50);
        setTimeout(attemptToClick, 100);
        setTimeout(attemptToClick, 200);
    });

    // Установим MutationObserver для отслеживания появления кнопки в динамически загружаемом контенте
    function setupObserver() {
        if (!document.body) return;

        const observer = new MutationObserver(function(mutations) {
            for (const mutation of mutations) {
                if (mutation.addedNodes && mutation.addedNodes.length > 0) {
                    // Если были добавлены новые узлы, пробуем нажать на кнопку
                    attemptToClick();
                }
            }
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true
        });
    }

    // Запускаем наблюдатель как можно раньше
    if (document.body) setupObserver();
    else document.addEventListener('DOMContentLoaded', setupObserver);
})();