Erome auto-pass age gate

Automatically clears the Erome 18+ disclaimer when it appears

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

Advertisement:

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

Advertisement:

// ==UserScript==
// @name         Erome auto-pass age gate
// @namespace    https://github.com/danmaclann/
// @license      MIT
// @author       danmaclann
// @version      1.0
// @description  Automatically clears the Erome 18+ disclaimer when it appears
// @match        https://www.erome.com/*
// @run-at       document-idle
// @grant        none
// @icon         https://www.erome.com/android-chrome-512x512.png
// ==/UserScript==

(function () {
    'use strict';

    function clearDisclaimer() {
        const disclaimer = document.getElementById('disclaimer');
        const enterBtn = document.querySelector('.enter');

        if (!disclaimer || !enterBtn) return;

        // Prevent repeated firing
        if (window.__eromeDisclaimerBypassed) return;
        window.__eromeDisclaimerBypassed = true;

        const csrf =
            document.querySelector('meta[name="csrf-token"]')?.content ||
            document.querySelector('input[name="_token"]')?.value ||
            getCookie('XSRF-TOKEN');

        fetch('/user/disclaimer', {
            method: 'POST',
            credentials: 'same-origin',
            headers: {
                'X-Requested-With': 'XMLHttpRequest',
                ...(csrf ? { 'X-CSRF-TOKEN': decodeURIComponent(csrf) } : {})
            }
        })
        .then(() => {
            disclaimer.remove();
            document.body.style.overflow = 'visible';
            location.reload();
        })
        .catch(() => {
            // Fallback: trigger the site's own click handler
            enterBtn.click();
        });
    }

    function getCookie(name) {
        const match = document.cookie.match(
            new RegExp('(?:^|; )' + name.replace(/[.*+?^${}()|[\]\\]/g, '\\$&') + '=([^;]*)')
        );
        return match ? match[1] : null;
    }

    clearDisclaimer();

    const observer = new MutationObserver(() => clearDisclaimer());
    observer.observe(document.documentElement, {
        childList: true,
        subtree: true
    });
})();