Skip CurseForge Countdown

Instantly downloads from CurseForge with NO countdown, NO redirect, to use press the download button under the install app dropdown.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         Skip CurseForge Countdown
// @namespace    https://curseforge.com/
// @version      3.0.0
// @description  Instantly downloads from CurseForge with NO countdown, NO redirect, to use press the download button under the install app dropdown.
// @author       Filip (https://github.com/f1amee-dev)
// @match        https://www.curseforge.com/*
// @grant        none
// @run-at       document-end
// @license MIT
// ==/UserScript==

(function() {
    'use strict';

    document.addEventListener('click', async function(e) {
        const link = e.target.closest('a[href*="/download"]');
        if (!link) return;

        const href = link.getAttribute('href');
        if (!href || !href.includes('/download') || href.includes('/api/v1/mods/')) return;

        const fileMatch = href.match(/\/download\/(\d+)/);
        const fileId = fileMatch ? fileMatch[1] : null;

        let slug = null;
        const slugMatch = href.match(/curseforge\.com\/(.+?)\/download/) || href.match(/^\/(.+?)\/download/);
        if (slugMatch) {
            slug = slugMatch[1];
        } else {
            const pageMatch = window.location.pathname.match(/^\/([^/]+\/[^/]+\/[^/]+)/);
            if (pageMatch) slug = pageMatch[1];
        }

        if (!fileId || !slug) return;

        e.preventDefault();
        e.stopPropagation();

        try {
            const resp = await fetch(`https://api.cfwidget.com/${slug}`);
            if (!resp.ok) throw new Error();
            const data = await resp.json();
            if (!data.id) throw new Error();

            const iframe = document.createElement('iframe');
            iframe.style.display = 'none';
            iframe.src = `https://www.curseforge.com/api/v1/mods/${data.id}/files/${fileId}/download`;
            document.body.appendChild(iframe);
            setTimeout(() => iframe.remove(), 5000);
        } catch {
            window.location.href = link.href;
        }
    }, true);
})();