mirror of
https://codeberg.org/Amm0ni4/bypass-all-shortlinks-debloated.git
synced 2024-12-29 16:33:02 +05:00
fixed mega-enlace bypass
now it won't re-do the bypass when access is already granted re-expanded the code to be able to modify it
This commit is contained in:
parent
d3ea094651
commit
809c8bffb4
3 changed files with 98 additions and 6 deletions
|
@ -3,7 +3,7 @@
|
|||
// @namespace Violentmonkey Scripts
|
||||
// @run-at document-start
|
||||
// @author Amm0ni4
|
||||
// @version 91.5.7
|
||||
// @version 91.5.8
|
||||
// @grant GM_setValue
|
||||
// @grant GM_getValue
|
||||
// @grant GM_addStyle
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
// @namespace Violentmonkey Scripts
|
||||
// @run-at document-start
|
||||
// @author Amm0ni4
|
||||
// @version 91.5.7
|
||||
// @version 91.5.8
|
||||
// @grant GM_setValue
|
||||
// @grant GM_getValue
|
||||
// @grant GM_addStyle
|
||||
|
@ -2282,11 +2282,57 @@
|
|||
})();
|
||||
// ----- ----- -----
|
||||
|
||||
// ----- Bypass mega-enlace ( Taken from AdGuard https://github.com/AdguardTeam/AdguardFilters/blob/b1622e8b387148509ca355e8070ffa5cdcf87525/SpanishFilter/sections/general_extensions.txt#L108 ) -----
|
||||
// ----- Bypass mega-enlace ( Taken from AdGuard https://github.com/AdguardTeam/AdguardFilters/blob/b1622e8b387148509ca355e8070ffa5cdcf87525/SpanishFilter/sections/general_extensions.txt#L108 / https://github.com/AdguardTeam/AdguardFilters/issues/174863#issuecomment-1996735239) -----
|
||||
// used in: pelisenhd.org latinomegahd.net gatonplayseries.com peliculasgd.net tododvdfull.com cinemaniahdd.net
|
||||
(function() {
|
||||
if (/mega-enlace.com/.test(window.location.href)) {
|
||||
const window = unsafeWindow; //Added so it works in ViolentMonkey instead of AdGuard
|
||||
!function(){const e = e=>{const o=new XMLHttpRequest;o.open("POST","/check.php",!0),o.setRequestHeader("Content-type","application/x-www-form-urlencoded"),o.send("a");const t=atob(window.ext_site).replace(/[a-z]/gi,(e=>String.fromCharCode(e.charCodeAt(0)+(e.toLowerCase()<="m"?13:-13))));let n=e.replaceAll('\\"','"');n=n.replace("'+ api_key+ '",window.api_key),n=n.replace("'+ link_out+ \"",window.link_out),n=n.replace(/action="'\+ .*?\+ '"/,`action="${t}"`);var a;const i=(a=n,(new DOMParser).parseFromString(a,"text/html")).querySelector("form"),r=new FormData(i),c=new XMLHttpRequest;c.open("POST",t,!0),c.send(r),window.tab2=window,postMessage("_clicked_b",location.origin)},o={apply:(o,t,n)=>{if(n[1]&&n[1].includes("api_key")){const o=window.link_out,t=window.api_key,a=n[1].match(/window\.open\(.*?\(atob\(main_site\)\).*?("\/.*\.php\?.*=").*?("&.*?=").*?(api_key),"view"/),i=a[1].replaceAll('"',""),r=a[2].replaceAll('"',""),c=n[1].match(/<form target=[\s\S]*?<\/form>/)[0];if(n[1]=n[1].replace("window.location.href","var nulled"),n[1]=n[1].replace("window.open(f","location.assign(f"),n[1]=n[1].replace(/(parseInt\(c\.split\("-"\)\[0\]\)<= 0).*?(\)\{)/,"$1$2"),o&&t&&i&&r&&c)try{"loading"===document.readyState?window.addEventListener("load",(()=>{e(c)}),{once:!0}):e(c)}catch(e){console.debug(e)}}return Reflect.apply(o,t,n)}};window.Function.prototype.constructor=new Proxy(window.Function.prototype.constructor,o)}();
|
||||
|
||||
//Adguard snippet expanded and modified
|
||||
! function() {
|
||||
const e = e => { // The e function: It sends a POST request to the link shortener's server and performs some string replacements to modify the form data and action URL. Finally, it sends another POST request with the modified form data to the action URL.
|
||||
const o = new XMLHttpRequest;
|
||||
o.open("POST", "/check.php", !0), o.setRequestHeader("Content-type", "application/x-www-form-urlencoded"), o.send("a");
|
||||
const t = atob(window.ext_site).replace(/[a-z]/gi, (e => String.fromCharCode(e.charCodeAt(0) + (e.toLowerCase() <= "m" ? 13 : -13))));
|
||||
let n = e.replaceAll('\\"', '"');
|
||||
n = n.replace("'+ api_key+ '", window.api_key), n = n.replace("'+ link_out+ \"", window.link_out), n = n.replace(/action="'\+ .*?\+ '"/, `action="${t}"`);
|
||||
var a;
|
||||
const i = (a = n, (new DOMParser).parseFromString(a, "text/html")).querySelector("form"),
|
||||
r = new FormData(i),
|
||||
c = new XMLHttpRequest;
|
||||
c.open("POST", t, !0), c.send(r), window.tab2 = window, postMessage("_clicked_b", location.origin)
|
||||
},
|
||||
o = { // The o object: This object is a proxy that intercepts function calls. It checks if the function call includes the api_key parameter and performs additional modifications to the function's code. If the necessary conditions are met, it tries to bypass the link shortener by calling the e function.
|
||||
apply: (o, t, n) => {
|
||||
if (n[1] && n[1].includes("api_key")) {
|
||||
const o = window.link_out,
|
||||
t = window.api_key,
|
||||
a = n[1].match(/window\.open\(.*?\(atob\(main_site\)\).*?("\/.*\.php\?.*=").*?("&.*?=").*?(api_key),"view"/),
|
||||
i = a[1].replaceAll('"', ""),
|
||||
r = a[2].replaceAll('"', ""),
|
||||
c = n[1].match(/<form target=[\s\S]*?<\/form>/)[0];
|
||||
if (n[1] = n[1].replace("window.location.href", "var nulled"), n[1] = n[1].replace("window.open(f", "location.assign(f"), n[1] = n[1].replace(/(parseInt\(c\.split\("-"\)\[0\]\)<= 0).*?(\)\{)/, "$1$2"), o && t && i && r && c) try {
|
||||
"loading" === document.readyState ? window.addEventListener("load", (() => {
|
||||
//Check if there is already access permission before launching the POST requests for the bypass
|
||||
let accessGranted = document.getElementById('contador').value.trim() === "IR AL ENLACE";
|
||||
if (!accessGranted){
|
||||
e(c); //Launch the POST requests
|
||||
}
|
||||
}), {
|
||||
once: !0
|
||||
}) : e(c)
|
||||
} catch (e) {
|
||||
console.debug(e)
|
||||
}
|
||||
}
|
||||
return Reflect.apply(o, t, n)
|
||||
}
|
||||
};
|
||||
window.Function.prototype.constructor = new Proxy(window.Function.prototype.constructor, o)
|
||||
}();
|
||||
|
||||
|
||||
}
|
||||
})();
|
||||
// ----- ----- -----
|
||||
|
||||
|
|
|
@ -5,11 +5,57 @@
|
|||
// @run-at document-start
|
||||
// ==/UserScript==
|
||||
|
||||
// ----- Bypass mega-enlace ( Taken from AdGuard https://github.com/AdguardTeam/AdguardFilters/blob/b1622e8b387148509ca355e8070ffa5cdcf87525/SpanishFilter/sections/general_extensions.txt#L108 ) -----
|
||||
// ----- Bypass mega-enlace ( Taken from AdGuard https://github.com/AdguardTeam/AdguardFilters/blob/b1622e8b387148509ca355e8070ffa5cdcf87525/SpanishFilter/sections/general_extensions.txt#L108 / https://github.com/AdguardTeam/AdguardFilters/issues/174863#issuecomment-1996735239) -----
|
||||
// used in: pelisenhd.org latinomegahd.net gatonplayseries.com peliculasgd.net tododvdfull.com cinemaniahdd.net
|
||||
(function() {
|
||||
if (/mega-enlace.com/.test(window.location.href)) {
|
||||
const window = unsafeWindow; //Added so it works in ViolentMonkey instead of AdGuard
|
||||
!function(){const e = e=>{const o=new XMLHttpRequest;o.open("POST","/check.php",!0),o.setRequestHeader("Content-type","application/x-www-form-urlencoded"),o.send("a");const t=atob(window.ext_site).replace(/[a-z]/gi,(e=>String.fromCharCode(e.charCodeAt(0)+(e.toLowerCase()<="m"?13:-13))));let n=e.replaceAll('\\"','"');n=n.replace("'+ api_key+ '",window.api_key),n=n.replace("'+ link_out+ \"",window.link_out),n=n.replace(/action="'\+ .*?\+ '"/,`action="${t}"`);var a;const i=(a=n,(new DOMParser).parseFromString(a,"text/html")).querySelector("form"),r=new FormData(i),c=new XMLHttpRequest;c.open("POST",t,!0),c.send(r),window.tab2=window,postMessage("_clicked_b",location.origin)},o={apply:(o,t,n)=>{if(n[1]&&n[1].includes("api_key")){const o=window.link_out,t=window.api_key,a=n[1].match(/window\.open\(.*?\(atob\(main_site\)\).*?("\/.*\.php\?.*=").*?("&.*?=").*?(api_key),"view"/),i=a[1].replaceAll('"',""),r=a[2].replaceAll('"',""),c=n[1].match(/<form target=[\s\S]*?<\/form>/)[0];if(n[1]=n[1].replace("window.location.href","var nulled"),n[1]=n[1].replace("window.open(f","location.assign(f"),n[1]=n[1].replace(/(parseInt\(c\.split\("-"\)\[0\]\)<= 0).*?(\)\{)/,"$1$2"),o&&t&&i&&r&&c)try{"loading"===document.readyState?window.addEventListener("load",(()=>{e(c)}),{once:!0}):e(c)}catch(e){console.debug(e)}}return Reflect.apply(o,t,n)}};window.Function.prototype.constructor=new Proxy(window.Function.prototype.constructor,o)}();
|
||||
|
||||
//Adguard snippet expanded and modified
|
||||
! function() {
|
||||
const e = e => { // The e function: It sends a POST request to the link shortener's server and performs some string replacements to modify the form data and action URL. Finally, it sends another POST request with the modified form data to the action URL.
|
||||
const o = new XMLHttpRequest;
|
||||
o.open("POST", "/check.php", !0), o.setRequestHeader("Content-type", "application/x-www-form-urlencoded"), o.send("a");
|
||||
const t = atob(window.ext_site).replace(/[a-z]/gi, (e => String.fromCharCode(e.charCodeAt(0) + (e.toLowerCase() <= "m" ? 13 : -13))));
|
||||
let n = e.replaceAll('\\"', '"');
|
||||
n = n.replace("'+ api_key+ '", window.api_key), n = n.replace("'+ link_out+ \"", window.link_out), n = n.replace(/action="'\+ .*?\+ '"/, `action="${t}"`);
|
||||
var a;
|
||||
const i = (a = n, (new DOMParser).parseFromString(a, "text/html")).querySelector("form"),
|
||||
r = new FormData(i),
|
||||
c = new XMLHttpRequest;
|
||||
c.open("POST", t, !0), c.send(r), window.tab2 = window, postMessage("_clicked_b", location.origin)
|
||||
},
|
||||
o = { // The o object: This object is a proxy that intercepts function calls. It checks if the function call includes the api_key parameter and performs additional modifications to the function's code. If the necessary conditions are met, it tries to bypass the link shortener by calling the e function.
|
||||
apply: (o, t, n) => {
|
||||
if (n[1] && n[1].includes("api_key")) {
|
||||
const o = window.link_out,
|
||||
t = window.api_key,
|
||||
a = n[1].match(/window\.open\(.*?\(atob\(main_site\)\).*?("\/.*\.php\?.*=").*?("&.*?=").*?(api_key),"view"/),
|
||||
i = a[1].replaceAll('"', ""),
|
||||
r = a[2].replaceAll('"', ""),
|
||||
c = n[1].match(/<form target=[\s\S]*?<\/form>/)[0];
|
||||
if (n[1] = n[1].replace("window.location.href", "var nulled"), n[1] = n[1].replace("window.open(f", "location.assign(f"), n[1] = n[1].replace(/(parseInt\(c\.split\("-"\)\[0\]\)<= 0).*?(\)\{)/, "$1$2"), o && t && i && r && c) try {
|
||||
"loading" === document.readyState ? window.addEventListener("load", (() => {
|
||||
//Check if there is already access permission before launching the POST requests for the bypass
|
||||
let accessGranted = document.getElementById('contador').value.trim() === "IR AL ENLACE";
|
||||
if (!accessGranted){
|
||||
e(c); //Launch the POST requests
|
||||
}
|
||||
}), {
|
||||
once: !0
|
||||
}) : e(c)
|
||||
} catch (e) {
|
||||
console.debug(e)
|
||||
}
|
||||
}
|
||||
return Reflect.apply(o, t, n)
|
||||
}
|
||||
};
|
||||
window.Function.prototype.constructor = new Proxy(window.Function.prototype.constructor, o)
|
||||
}();
|
||||
|
||||
|
||||
}
|
||||
})();
|
||||
// ----- ----- -----
|
||||
|
||||
|
|
Loading…
Reference in a new issue