Fortnite Code Generator

Despite how sketchy the name is, this is an actual code generator. The odds of getting an actual code is low but not zero.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name         Fortnite Code Generator
// @namespace    https://spin.tk
// @license      GNU GPLv3
// @version      1.1
// @description  Despite how sketchy the name is, this is an actual code generator. The odds of getting an actual code is low but not zero.
// @author       Spinfal
// @match        https://www.epicgames.com/store/*
// @match        https://www.epicgames.com/id/login*
// @icon         https://www.google.com/s2/favicons?domain=epicgames.com
// @grant        none
// @run-at       document-start
// ==/UserScript==
 
(function() {
    'use strict';
 
    const controller = new AbortController();
    const signal = controller.signal;
    var running = false;
    if (sessionStorage['error'] !== undefined) {
        alert(sessionStorage['error']);
        sessionStorage.removeItem('error');
    }
    const Style = {
        base: [
            "color: #2ba9a9",
            "font-size: 30px",
            "background-color: #444",
            "padding: 2px 4px",
            "border-radius: 2px"
        ],
        secondary: [
            "font-size: 15px",
            "color: #eee",
            "background-color: #2b2b2b"
        ],
        success: [
            "font-size: 25px",
            "color: green",
            "background-color: #2b2b2b"
        ],
        error: [
            "font-size: 25px",
            "color: red",
            "background-color: #2b2b2b"
        ],
    }
    const log = (text, extra = []) => {
        let style = Style.base.join(';') + ';';
        style += extra.join(';'); // Add any additional styles
        console.log(`%c${text}`, style);
    }
 
    log("Please wait while Epic is done spamming the console with this shit");
    window.onload = () => {
        setImmediate(() => {
            const div = document.createElement('div');
            div.setAttribute('style', 'background-color: #0078F2; color: white; width: 16vh; border-radius: 4px; padding: 5px; cursor: default;');
            div.innerHTML = '<p>Open Developer Console for the code generator</p>';
            document.querySelector('[data-component=SiteNav]').appendChild(div);
            window.onkeydown = (event) => {
                console.clear();
                if (event.key === '/' && running === false) {
                    log("Starting generator...", Style.secondary);
                    setInterval(() => checkCodes(), 1000);
                } else if (running) {
                    log("Generator is already running!", Style.secondary);
                }
            }
            console.clear();
            log("Fortnite Code Generator");
            log("To run the generator, press the / key on your keyboard! (not in console)\nTo stop the generator, just reload your page.", Style.secondary);
        });
    }
 
    function makecode(length) {
        var result           = '';
        var characters       = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
        var charactersLength = characters.length;
        for ( var i = 0; i < length; i++ ) {
            result += characters.charAt(Math.floor(Math.random() *
                                                   charactersLength));
        }
        return result;
    }
 
    // res.json()).then(res => JSON.stringify(res)).then(res =>
    function checkCodes() {
        running = true;
        const giftCode = makecode(16);
 
        fetch(`https://www.epicgames.com/fortnite/en-US/api/posa/${giftCode}/status`, {
            signal: signal,
            "headers": {
                "accept": "application/json, text/plain, */*",
                "accept-language": "en-US,en;q=0.9",
                "sec-ch-ua": "\"Chromium\";v=\"96\", \"Google Chrome\";v=\"82\", \";Not A Brand\";v=\"99\"",
                "sec-ch-ua-mobile": "?0",
                "sec-ch-ua-platform": "\"Linux\"",
                "sec-fetch-dest": "empty",
                "sec-fetch-mode": "cors",
                "sec-fetch-site": "same-origin",
                "x-requested-with": "XMLHttpRequest"
            },
            "referrer": "https://www.epicgames.com/fortnite/en-US/vbuckscard?fromCta=true",
            "referrerPolicy": "strict-origin-when-cross-origin",
            "body": null,
            "method": "GET",
            "mode": "cors",
            "credentials": "include"
        }).then(res => {
            switch (res?.status) {
                case 200:
                    log(giftCode + " is a valid code", Style.success);
                    break;
                case 404:
                    log(giftCode + " is not a valid code", Style.error);
                    break;
                case 401:
                    controller.abort();
                    location.reload();
                    sessionStorage['error'] = 'you are not logged in to an epicgames account!';
                    //alert("you are not logged in to an epicgames account!");
                    window.open('https://www.epicgames.com/id/login', '_self');
                    break;
                case 429:
                    controller.abort();
                    location.reload();
                    sessionStorage['error'] = 'you are being rate limited, try again later';
                    //alert("you are being rate limited, try again later");
                    break;
                default:
                    running = false;
                    controller.abort();
                    log("an error has occurred with the status code: " + res?.status);
            }
        }).catch(console.error);
    }
})();