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.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, Greasemonkey alebo Violentmonkey.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie, ako napríklad Tampermonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey, % alebo Violentmonkey.

Na nainštalovanie skriptu si budete musieť nainštalovať rozšírenie, ako napríklad Tampermonkey alebo Userscripts.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie, ako napríklad Tampermonkey.

Na inštaláciu tohto skriptu je potrebné nainštalovať rozšírenie správcu používateľských skriptov.

(Už mám správcu používateľských skriptov, nechajte ma ho nainštalovať!)

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie, ako napríklad Stylus.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

Na inštaláciu tohto štýlu je potrebné nainštalovať rozšírenie správcu používateľských štýlov.

(Už mám správcu používateľských štýlov, nechajte ma ho nainštalovať!)

// ==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);
    }
})();