Linkvertise Bypass [+krnl]

[Working 🟢] Bypasses Linkvertise links locally on computer or with external api

Устаревшая версия на 26.03.2022. Перейти к последней версии.

// ==UserScript==
// @name         Linkvertise Bypass [+krnl]
// @namespace    http://tampermonkey.net/
// @version      3.3
// @description  [Working 🟢] Bypasses Linkvertise links locally on computer or with external api
// @author       HussNuss
// @license      GNU GPL v3.0. http://www.gnu.org/copyleft/gpl.html
// @noframes
// @compatible   chrome
// @compatible   firefox
// @compatible   edge
// @compatible   brave
// @compatible   dolphin
// @compatible   uc
// @compatible   safari
// @compatible   chromium
// @compatible   opera
// @compatible   opera next
// @compatible   opera gx
// @require      https://code.jquery.com/jquery-3.5.1.min.js
// @require      https://cdn.jsdelivr.net/gh/jpillora/notifyjs@d27d96fc2454c2e7ec21dc9fd7609944831fdedd/dist/notify.js
// @match        *://*.linkvertise.com/*
// @match        *://*.linkvertise.net/*
// @match        *://*.linkvertise.download/*
// @match        *://*.link-to.net/*
// @connect      publisher.linkvertise.com
// @connect      code.jquery.com
// @connect      cdn.jsdelivr.net
// @connect      balatin.de
// @connect      api.bypass.vip
// @connect      d17kz3i6hbr7d3.cloudfront.net
// @run-at       document-body
// @icon         https://www.google.com/s2/favicons?sz=64&domain=https://linkvertise.com
// @grant        GM_xmlhttpRequest
// @grant        GM_openInTab
// @grant        window.onurlchange
// ==/UserScript==


/*
 * SETTINGS
 * feel free to edit if you know what you're doing :)
*/

const cooldownAfterLoad = 10; //In milliseconds
const openInNewTab = false; //If set to true, make sure to allow popups for the page
let local = false; //Whether to use local bypassing or external fetching of linkvertise links

/*
 * MAIN SCRIPT
*/

const excludedDomains = ["link-mutation.linkvertise.com", "cdn.linkvertise.com", "publisher.linkvertise.com", "blog.linkvertise.com"];
const excludedPaths = ["/search", "/assets", "/profile"];
const useStage6 = true;
let bypassActive = false;

if (window.onurlchange === null) {
    window.addEventListener('urlchange', (info) => {
        startBypass();
    });
} else {
    startBypass();
}

function startBypass() {
    let loc = window.location;
    if(bypassActive || excludedDomains.includes(loc.hostname.toLowerCase()) || loc.pathname == "/") {
        return;
    }
    for(let index = 0; index < excludedPaths.length; index++) {
        if(loc.pathname.toLowerCase().startsWith(excludedPaths[index])) {
            return;
        }
    }
    (async () => {
        if(document.contentType == "text/html") {
            bypass(loc);
        }
    })();
}

async function bypass(loc) {
    if(loc.hostname == "linkvertise.com" && loc.pathname.startsWith("/") && loc.pathname.split("/").length >= 3) {
        bypassActive = true;
        if(local) {
            $.notify("Bypassing link... Please wait...", {className: "info", autoHideDelay: 10000});
            let pathId = loc.pathname.split("/")[1];
            let pathName = loc.pathname.split("/")[2];
            let dynamic = loc.pathname.includes("/dynamic");
            let rId = dynamic && window.location.search.includes("&r=") ? window.location.search.split("&r=")[1].split("&")[0] : dynamic && window.location.search.includes("?r=") ? window.location.search.split("?r=")[1].split("&")[0] : "";
            // Stage 1 - Fetch link id
            GM_xmlhttpRequest({
                method: 'GET',
                url: "https://publisher.linkvertise.com/api/v1/redirect/link/" + (dynamic ? "dynamic/" + pathId + "/" + rId : "static/" + pathId + "/" + pathName),
                onload: function(resp) {
                    let response = JSON.parse(resp.responseText);
                    pathName = response["data"]["link"]["url"];
                    let target_type = response["data"]["link"]["target_type"];
                    // Stage 2 - Generate serial
                    GM_xmlhttpRequest({
                        method: 'GET',
                        url: "https://balatin.de/api/serial?p=" + pathName + "&pid=" + pathId + "&id=" + response["data"]["link"]["id"],
                        onload: function(resp) {
                            // Stage 3 - Get download target
                            GM_xmlhttpRequest({
                                method: 'POST',
                                url: "https://publisher.linkvertise.com/api/v1/redirect/link/" + pathId + "/" + pathName + ((target_type == "PASTE") ? "/paste" : "/target"),
                                data: resp.responseText,
                                headers: {
                                    "Content-Type": 'application/json',
                                },
                                onload: function(resp) {
                                    response = JSON.parse(resp.responseText);
                                    if(target_type != "PASTE") {
                                        let dest = new URL(response["data"]["target"]);
                                        if(dest.hostname == "linkvertise.download") {
                                            bypassDownload(dest);
                                        } else {
                                            handleResult(dest.href);
                                        }
                                    } else {
                                        handleResult("https://balatin.de/api/txt/" + btoa(unescape(encodeURIComponent(response["data"]["paste"]))));
                                    }
                                }
                            });
                        }
                    });
                }
            });
        } else {
            $.notify("Bypassing link via external api...", {className: "info", autoHideDelay: 8000});
            GM_xmlhttpRequest({
                method: 'POST',
                url: "https://api.bypass.vip/",
                headers: {
                    "Content-Type": 'application/x-www-form-urlencoded;charset=UTF-8',
                },
                data: 'url=' + encodeURIComponent(loc.href),
                onload: function(resp) {
                    let jsonResponse = JSON.parse(resp.responseText);
                    if(jsonResponse != null && jsonResponse.destination != null) {
                        handleResult(jsonResponse.destination);
                    } else if(jsonResponse != null && jsonResponse.response != null) {
                        // Text proxy used to redirect
                        handleResult("https://balatin.de/api/txt/" + btoa(unescape(encodeURIComponent(jsonResponse.response))));
                    } else {
                        $.notify("Could not bypass link", {className: "error", autoHideDelay: 10000});
                    }
                }
            });
        }
    } else if (loc.hostname == "linkvertise.download") {
        bypassDownload(loc);
        return;
    } else {
        $.notify("Unknown error occurred (domain or path)", {className: "error", autoHideDelay: 10000});
        return;
    }
}

async function bypassDownload(dest) {
    if(dest.pathname.startsWith("/download/")) {
        let pathId = dest.pathname.split("/")[2];
        let pathName = dest.pathname.split("/")[3];
        $.notify("Bypassing executable..", {className: "base", autoHideDelay: 3000});
        let key = JSON.stringify({key: dest.pathname.split("/")[4]});
        // Stage 4 - (if link is download) get installer
        GM_xmlhttpRequest({
            method: 'POST',
            url: "https://publisher.linkvertise.com/api/v1/redirect/link/" + pathId + "/" + pathName + "/download-info",
            data: key,
            headers: {
                "Content-Type": 'application/json',
            },
            onload: function(resp) {
                let response = JSON.parse(resp.responseText);
                let downloadUrl = new URL(response["data"]["downloadUrl"]);
                if(downloadUrl.hostname.endsWith("cloudfront.net")) {
                    // Stage 5 - Extract filename of executable
                    if(useStage6) {
                        let downloadReq = GM_xmlhttpRequest({
                            method: 'GET',
                            url: "https://balatin.de/api/stage6?url=" + downloadUrl.href,
                            onload: function(resp) {
                                response = resp.responseText;
                                let filename = JSON.stringify({"a":"Linkvertise","s":"Linkvertise","u":response});
                                // Stage 6 - Retrieve final download based on filename key
                                GM_xmlhttpRequest({
                                    method: 'POST',
                                    url: "https://d17kz3i6hbr7d3.cloudfront.net/o",
                                    data: filename,
                                    headers: {
                                        "Content-Type": 'application/json',
                                    },
                                    onload: function(resp) {
                                        handleResult(JSON.parse(resp.responseText)["i"]["cu"]);
                                    }
                                });
                            }
                        });
                    } else {// Stage 6 skipped
                        let downloadReq = GM_xmlhttpRequest({
                            method: 'GET',
                            url: "https://balatin.de/api/installer?url=" + downloadUrl.href,
                            onload: function(resp) {
                                handleResult(resp.responseText);
                            }
                        });
                    }
                } else {
                    handleResult(downloadUrl.href);
                }
            }
        });
    }
}

async function handleResult(dest) {
    try {
        new URL(dest);
    } catch(e) {
        if(local) {
            local = false;
            bypass(window.location);
        } else {
            local = true;
            $.notify("Could not bypass link :c", {className: "error", autoHideDelay: 15000});
        }
        return;
    }
    let krnlId = "/48193/"; //Path ID for krnl links
    if(window.location.pathname.startsWith(krnlId)) {
        $.notify("Detected krnl! Redirecting in 15 seconds...", {className: "warn", autoHideDelay: 15000});
        setTimeout(() => {
            $.notify("Redirecting...", {className: "success", autoHideDelay: 8000});
            window.location.replace(dest);
        }, 15100);
    } else {
        if(cooldownAfterLoad > 0) {
            let seconds = (cooldownAfterLoad / 1000);
            $.notify((openInNewTab ? "Opening link" : "Redirecting") + " in " + seconds + " second" + (seconds === 1 ? "" : "s"), {className: "base", autoHideDelay: cooldownAfterLoad + 200});
        }
        setTimeout(() => {
            if(openInNewTab) {
                GM_openInTab(dest, false);
                $.notify("Opened link in new tab", {className: "success", autoHideDelay: 8000});
            } else {
                $.notify("Redirecting...", {className: "success", autoHideDelay: 8000});
                window.location.replace(dest);
            }
        }, cooldownAfterLoad);
    }
}

function escapeHtml(str) {
    return str.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#039;");
}

/*
 * DESIGN
*/

$.notify.addStyle("bootstrap", {
    html: "<div>\n<span data-notify-text></span>\n</div>",
    classes: {
        base: {"z-index":"99999","font-size":"20px","font-family":"Segoe UI, Frutiger, Dejavu Sans, Helvetica Neue, Arial, sans-serif","padding":"10px 17px 10px 16px","text-shadow":"0 1px 0 rgba(18, 18, 18, 0.5)","color":"#EAEAEA","background-color":"#101010","border":"2px solid #161616","border-radius":"10px","white-space":"nowrap","padding-left":"46px","background-repeat":"no-repeat","background-position":"8px 8px"},
        error: {"color":"#E84A48","background-color":"#260D0D","border-color":"#331111","background-image":"url()"},
        success: {"color":"#1EC77D","background-color":"#08331F","border-color":"#062818","background-image":"url()"},
        info: {"color":"#3AA7AD","background-color":"#0C1C23","border-color":"#112833","background-image":"url()"},
        warn: {"color":"#D99853","background-color":"#332B0B","border-color":"#262008","background-image":"url()"}
    }
});