DDoS-Guard Captcha Autoclick

Automatically clicks the DDoS-Guard captcha checkbox when detected it and doesn't solve the captcha for you!

// ==UserScript==
// @name         DDoS-Guard Captcha Autoclick
// @namespace    https://violentmonkey.github.io/
// @version      1.0
// @description  Automatically clicks the DDoS-Guard captcha checkbox when detected it and doesn't solve the captcha for you!
// @author       Streampunk
// @icon         
// @match        *://*/*
// @grant        none
// @license      MIT
// @run-at       document-start
// ==/UserScript==

(function() {
    'use strict';

    // Check if there is a DDoS-Guard captcha on the site page
    function isDDOSGuardPage() {
        const scripts = document.getElementsByTagName('script');
        for (const script of scripts) {
            if (script.src.includes('ddos-guard.net') || script.src.includes('/.well-known/ddos-guard')) {
                return true;
            }
        }
        return !!document.querySelector('#ddg-captcha');
    }

    // Exit if there is no DDoS-Guard captcha on the site page
    if (!isDDOSGuardPage()) return;

    let hasClicked = false;

    // Simulate a click on an element
    function simulateClick(element) {
        if (!element || hasClicked) return false;
        const rect = element.getBoundingClientRect();
        const event = new MouseEvent('click', {
            bubbles: true,
            cancelable: true,
            clientX: rect.left + rect.width / 2,
            clientY: rect.top + rect.height / 2
        });
        element.dispatchEvent(event);
        hasClicked = true;
        return true;
    }

    // Find and click the CAPTCHA checkbox in iframe
    function clickCaptcha() {
        if (hasClicked) return true;
        const iframe = document.querySelector('#ddg-iframe');
        if (!iframe) return false;

        try {
            const iframeDoc = iframe.contentDocument || iframe.contentWindow.document;
            const checkbox = iframeDoc?.querySelector('.ddg-captcha__checkbox');
            if (checkbox) {
                simulateClick(checkbox);
                setTimeout(() => {
                    if (!checkbox.classList.contains('ddg-captcha__checkbox--checked')) {
                        checkbox.click();
                    }
                }, 500);
                return true;
            }
        } catch (error) {
            console.log('Error accessing iframe:', error.message);
        }
        return false;
    }

    // Start polling to check for CAPTCHA
    function startPolling() {
        const interval = setInterval(() => {
            if (clickCaptcha()) {
                setTimeout(() => clearInterval(interval), 3000);
            }
        }, 250);
    }

    // Observe DOM for iframe addition
    const observer = new MutationObserver((mutations) => {
        if (mutations.some(m => m.addedNodes.length && document.querySelector('#ddg-iframe'))) {
            setTimeout(clickCaptcha, 1000);
            startPolling();
            observer.disconnect();
        }
    });

    // Initialize the script
    function init() {
        if (document.readyState === 'loading') {
            document.addEventListener('DOMContentLoaded', () => {
                if (isDDOSGuardPage()) {
                    observer.observe(document.body || document.documentElement, { childList: true, subtree: true });
                    setTimeout(clickCaptcha, 1000);
                    startPolling();
                }
            });
        } else if (isDDOSGuardPage()) {
            observer.observe(document.body || document.documentElement, { childList: true, subtree: true });
            setTimeout(clickCaptcha, 1000);
            startPolling();
        }
    }

    init();
})();