// ==UserScript==
// @name Linkvertise Bypass [+krnl]
// @namespace http://tampermonkey.net/
// @version 3.5
// @description Bypasses Linkvertise links locally on computer or with external api [working]
// @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 paper.ostrichesica.com
// @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 = true; //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) {
let serialToken = JSON.parse(resp.responseText);
// Stage 3 - Generate cheq token
GM_xmlhttpRequest({
method: 'GET',
url: "https://paper.ostrichesica.com/ct?id=14473&url=" + encodeURIComponent(loc.href),
onload: function(resp) {
let cheqToken = resp.responseText.split("\"jsonp\":\"")[1].split("\"")[0];
// Stage 4 - Traffic validation
GM_xmlhttpRequest({
method: 'POST',
url: "https://publisher.linkvertise.com/api/v1/redirect/link/" + pathId + "/" + pathName + "/traffic-validation",
data: JSON.stringify({"type": "cq","token": cheqToken}),
headers: {
"Content-Type": 'application/json',
},
onload: function(resp) {
response = JSON.parse(resp.responseText);
let requestToken = response["data"]["tokens"]["TARGET"];
// Stage 5 - Get download target
serialToken["token"] = requestToken;
GM_xmlhttpRequest({
method: 'POST',
url: "https://publisher.linkvertise.com/api/v1/redirect/link/" + pathId + "/" + pathName + ((target_type == "PASTE") ? "/paste" : "/target"),
data: JSON.stringify(serialToken),
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 6 - (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 7 - 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 8 - 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 8 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, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'");
}
/*
* 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()"}
}
});