// ==UserScript== // @name Bypass It // @namespace http://tampermonkey.net/ // @version 2025-04-28 (4) // @description Automatically Bypass Restrictions and Get Straight to Your Destination! // @supportURL https://greasyfork.org/scripts/527564/feedback // @author You // @match *://vn88.id/* // @match *://vn88.fan/* // @match *://vn88.ing/* // @match *://vn88.wtf/* // @match *://aylink.co/* // @match *://vn8eu.com/* // @match *://vn88n.com/* // @match *://gplinks.co/* // @match *://v2links.me/* // @match *://upfion.com/* // @match *://fb88dv.com/* // @match *://m88usb.com/* // @match *://vn88.group/* // @match *://vn88wo.com/* // @match *://vn88zx.com/* // @match *://vn88ko.com/* // @match *://vn88es.com/* // @match *://vn88tu.com/* // @match *://www.m88.com/* // @match *://bet88li.com/* // @match *://cutyion.com/* // @match *://vn88tk1.com/* // @match *://vn88vc.wiki/* // @match *://fb88vao.com/* // @match *://coinclix.co/* // @match *://vn88.hiphop/* // @match *://gwaher.com/ptc // @match *://www.fb88.com/* // @match *://*.devnote.in/* // @match *://naamlist.com/* // @match *://modsfire.com/* // @match *://yeumoney.com/* // @match *://165.22.63.250/* // @match *://*.gmsrweb.org/* // @match *://modijiurl.com/* // @match *://geekgrove.net/* // @match *://www.m88sut.com/* // @match *://*.techyuth.xyz/* // @match *://vn88.solutions/* // @match *://financewada.com/* // @match *://188.166.185.213/* // @match *://gemini.google.com/* // @match *://cryptowidgets.net/* // @match *://*.wikijankari.com/* // @match *://cricketlegacy.com/* // @match *://ourcoincash.xyz/ptc* // @match *://*.idblogmarket.com/* // @match *://*.phonesparrow.com/* // @match *://financenova.online/* // @match *://bitcotasks.com//lead* // @match *://rajasthantopnews.com/* // @match *://www.google.com/url?q=* // @match *://freepayz.com/framed-ads // @match *://utkarshonlinetest.com/* // @match *://www.youtube.com/redirect* // @match *://www.facebook.com/flx/warn/* // @match *://gemini.google.com/app?msg=* // @match *://www.instagram.com/linkshim/* // @match https://www.google.com/recaptcha/api2/bframe* // @match https://www.google.com/recaptcha/api2/anchor* // @icon  // @grant GM_getValue // @grant GM_setValue // @grant GM_addStyle // @grant unsafeWindow // @grant GM_openInTab // @grant GM_deleteValue // @grant GM_xmlhttpRequest // @grant GM_registerMenuCommand // @grant GM_addValueChangeListener // @require https://update.greasyfork.org/scripts/439099/1203718/MonkeyConfig%20Modern%20Reloaded.js // @connect api.nocaptchaai.com // @connect api.nopecha.com // @license MIT // @downloadURL https://update.greasyfork.icu/scripts/527564/Bypass%20It.user.js // @updateURL https://update.greasyfork.icu/scripts/527564/Bypass%20It.meta.js // ==/UserScript== const cfg = new MonkeyConfig({ menuCommand: true, params: { redirectToSocial: { type: 'checkbox', label: "Auto-Redirect to Social Media", default: false, }, ptcFaucet: { type: 'checkbox', label: "Opens PTC links", default: false }, apiKey1: { type: 'text', label: "noCaptcha Ai API Key", default: "", }, apiKey2: { type: 'text', label: "NopeCHA API Key (leave empty to use IP authentication)", default: "", }, siteDelays: { type: 'text', long: 3, label: "Site-Specific Delays (domain:delay)", default: 'example.com:50ms\nanotherexample.net:100ms' } } }); const noop = () => {}; const rawWindow = unsafeWindow; const currentUrl = location.href; const queryParams = new URLSearchParams(location.search); function waitForElement(selector, callback = noop) { const findElement = () => { if (selector.startsWith("//")) { return document.evaluate(selector, document, null, 9).singleNodeValue; } return document.querySelector(selector); }; return new Promise((resolve) => { const element = findElement(); if (document.contains(element)) { callback(element); return resolve(element); } const observer = new MutationObserver((mutations, observerInstance) => { const node = findElement(); if (document.contains(node)) { observerInstance.disconnect(); callback(node); resolve(node); } }); observer.observe(document.documentElement, { attributes: true, childList: true, subtree: true, }); }); } function navigateTo(url) { location = url; } function waitSeconds(seconds) { return new Promise((resolve) => setTimeout(resolve, seconds * 1000)); } function redirectToLink(selector) { waitForElement(selector).then((element) => navigateTo(element.href)); } function imageUrlToBase64(imageUrl) { if (!imageUrl) { console.error("No imageUrl provided"); return null; } return new Promise((resolve, reject) => { makeRequest(imageUrl, { responseType: "blob", }).then(blob => { const reader = new FileReader(); reader.onload = () => resolve(reader.result); reader.onerror = (error) => { console.error("FileReader error:", error); reject(error); }; reader.readAsDataURL(blob); }) }); } function onMatch(hostPattern, callback, ...args) { hostPattern = hostPattern.replace("www.", ""); if (hostPattern.length < 3) return; const isMatch = new RegExp(hostPattern).test(location.host); if (isMatch) callback(...args); } function onMatchClick(hostPattern, selector) { onMatch(hostPattern, simulateClick, selector) } function simulateClick(selector, delay = 0) { const clickFun = (element) => { const events = ["mouseover", "mousedown", "mouseup", "click"]; events.forEach((eventName) => { const event = new MouseEvent(eventName, { bubbles: true, }); element.dispatchEvent(event); }); } if (typeof selector != "string") { return clickFun(selector); } const selectors = selector.split(", "); if (selectors.length > 1) { selectors.forEach((sel) => simulateClick(sel, delay)); return; } waitForElement(selector, async function(element) { if (delay > 0) await waitSeconds(delay); clickFun(element); }); } function whenCaptchaSolved(callback, onWait = noop) { let intervalId; const stopChecking = () => clearInterval(intervalId); // waitForElement("//*[@id='captcha-result'] and normalize-space() = 'Verified!']", function() { // stopChecking(); // callback(); // }) const checkCaptcha = () => { try { const element = document.querySelector('#captcha-result .mb-2.badge.bg-success'); if (element && element.textContent.trim() === 'Verified!') { stopChecking(); callback(); } const captcha = rawWindow.turnstile || rawWindow.hcaptcha || rawWindow.grecaptcha; const response = captcha.getResponse(); if (response) { stopChecking(); callback(); } } catch (error) { onWait(stopChecking); } }; checkCaptcha(); intervalId = setInterval(checkCaptcha, 1000); } function GM_onMessage(label, callback = noop) { GM_addValueChangeListener("postMessage-" + label, function(name, oldValue, newValue, remote) { if (remote) { GM_deleteValue("postMessage-" + label); callback(newValue); } }); } function GM_sendMessage(label, value) { GM_setValue("postMessage-" + label, value); } function onOpenTab(callback) { const originalOpen = rawWindow.open; rawWindow.open = function(...args) { const newWindow = originalOpen.apply(rawWindow, args); callback(newWindow); return newWindow; }; } function clickWithTrusted() { // Create window proxy to disable Object.freeze const sandbox = new Proxy(window, { get(target, key) { if (key === 'Object') { return new Proxy(Object, { get(objTarget, objKey) { if (objKey === 'freeze') { return function(obj) { console.warn("Object.freeze disabled in sandbox."); return obj; }; } return Reflect.get(objTarget, objKey); } }); } return Reflect.get(target, key); } }); // Patch addEventListener to clone events and force isTrusted const originalAddEventListener = EventTarget.prototype.addEventListener; EventTarget.prototype.addEventListener = function(type, listener, options) { const wrappedListener = function(event) { const clonedEvent = Object.create(event); Object.defineProperty(clonedEvent, "isTrusted", { value: true, writable: false }); return listener.call(this, clonedEvent); }; return originalAddEventListener.call(this, type, wrappedListener, options); }; return sandbox; } function isVisible(element) { if (!element) return false; const style = window.getComputedStyle(element); const visible = style.display !== 'none' && style.visibility !== 'hidden' && style.opacity !== '0' && element.offsetWidth > 0 && element.offsetHeight > 0; if (!visible) return false; return isVisible(element.parentElement) || element.parentElement === null; }; function transformMethod(object, methodName, argumentProcessor) { const originalMethod = object[methodName]; Object.defineProperty(object, methodName, { value: function (...args) { const processedArgs = argumentProcessor(args); return originalMethod(...processedArgs); }, writable: false, configurable: false }); } function makeRequest(url, options = {}) { return new Promise((resolve, reject) => { GM_xmlhttpRequest({ url, method: options.method || "GET", responseType: options.responseType || "json", headers: options.headers || {}, data: options.data ? JSON.stringify(options.data) : null, //timeout: options.timeout || 0, onload: (response) => resolve(response.response), onerror: (error) => reject(error), ontimeout: (error) => reject(error), onabort: (error) => reject(error) }); }); } // Main execution (function () { "use strict"; //only click onMatchClick("cutyion.com", "#submit-button:not([disabled])"); onMatchClick("modsfire.com", ".download-button, .download-button[href]"); onMatchClick("aylink.co", ".btn-go, .complete[style*='display: block;'] a, a.btn:not(.btn-go)") onMatchClick("devnote.in|techyuth.xyz", "#scroll:not(.no), #getlinks[style*='display: block;'], .get-link:not(.disabled)"); onMatchClick("gplinks.co|cricketlegacy.com", "#VerifyBtn[style*='display: block;'], #NextBtn:not([href='#']), #captchaButton:not(.disabled)"); onMatchClick("(financewada|utkarshonlinetest).com|financenova.online|v2links.me", ".get_btn a[href], //div[contains(text(),'Continue')], .get-link:not(.disabled)"); onMatchClick("(wikijankari|idblogmarket|modijiurl|phonesparrow|naamlist|rajasthantopnews).com|gmsrweb.org", "center a[style*='display: block;'], .get-link:not(.disabled)"); cfg.get("redirectToSocial") && onMatchClick("(instagram|youtube|facebook).com", ".-cx-PRIVATE-Linkshim__followLink__, #invalid-token-redirect-goto-site-button, .selected"); onMatch("upfion.com", function() { simulateClick("#link-button:not([disabled])"); redirectToLink("a#link-button:not([disabled])"); }); onMatch("(m88(sut|usb)?|bet88li|fb88(dv|vao)?|yeumoney|google|vn8?8(wo|tk1|eu|zx|ko|es|tu|n)?).com|188.166.185.213|165.22.63.250|vn88.(hiphop|wtf|id|now|fan|group|solutions|ing)|vn88vc.wiki", function() { waitForElement(".getcodebtn", function(element) { element.click(); GM_sendMessage("close_tabs", currentUrl); }) waitForElement("//*[contains(@class, 'cursor-pointer') and contains(text(), 'footer')]", function() { simulateClick("a[href*='"+location.host+"']"); }) waitForElement("//*[contains(@class, 'cursor-pointer') and string-length(translate(normalize-space(text()), '0123456789', '')) = 0]", function(element) { GM_sendMessage("vietnam_code", element.innerText) }) const tabs = []; const urls = [ "m88.com", "vn88.id", "vn88.fan", "vn88.ing", "fb88.com", "vn88.now", "vn88.wtf", "vn8eu.com", "vn88n.com", "m88sut.com", "m88usb.com", "fb88dv.com", "vn88.group", "vn88wo.com", "vn88zx.com", "vn88ko.com", "vn88es.com", "vn88tu.com", "vn88tk1.com","vn88vc.wiki", "fb88vao.com", "vn88.hiphop", "vn88.solutions", "bet88li.com/m88", "188.166.185.213/w88", "165.22.63.250/188bet", ] urls.includes(queryParams.get("q")?.replace("https://", "")) && simulateClick(".mymGo ~ div a"); GM_onMessage("vietnam_code", function(newValue) { tabs.forEach(([_, tab]) => tab.close()); document.querySelector('[name="code"]').value = newValue; simulateClick(".box-form-button button"); }); waitForElement("[data-clipboard-text]:not([data-clipboard-text=''])", function(element) { const links = urls.filter(url => url.includes(element.dataset.clipboardText)); links.forEach(url => { const tab = GM_openInTab("https://www.google.com/url?q=https://" + url); tabs.push([url, tab]); }) GM_onMessage("close_tabs", function(newValue) { tabs.forEach(([url, tab]) => { if (new URL("https://" + url).host !== new URL(newValue).host) { tab.close(); } }); }); }) }); if (cfg.get("ptcFaucet")) { const regex = /^(visit for \d+ sec|visit(?: now)?|go|view|view now|view ads?|watch|start .* coins|start view ad)$/i; const findButton = () => [...document.querySelectorAll("button")].find(btn => regex.test(btn.textContent.trim())); onMatch("ourcoincash.xyz|(bitcotasks|freepayz|gwaher).com", function() { //TODO: replace the use of setInterval and fix the issue with tabs let tabObj; onOpenTab(function(tab) { tabObj = tab; }); rawWindow.addEventListener("beforeunload", function() { tabObj?.close(); }) findButton()?.click(); setInterval(function() { tabObj?.close(); findButton()?.click(); }, 120000) // 120 sec whenCaptchaSolved(function() { const btn = document.querySelector("button[type='submit']") isVisible(btn) && btn.click(); }) }) } onMatch("coinclix.co|geekgrove.net", async function() { // Add support for Google. Currently, it is not supported, and a refresh is needed when it appears. if (!cfg.get("autoRedirectToSocial")) { //TODO: Automatically enable for a temporary amount of time return alert("To bypass this, you need to enable Auto-Redirect to Social Media."); } const code = document.querySelector(".mb-2 code"); if (code) { //TODO: replace with something else const tab = GM_openInTab(document.querySelector("strong a")?.href); await waitSeconds(10); GM_sendMessage("geek_code", code.innerText); } GM_onMessage("geek_code", function(newValue) { document.querySelector("#link_input").value = newValue; simulateClick("#btn_link, .btn-primary[href]"); }); }) // Don't forget to add the site into the @match. const sites = cfg.get("siteDelays").replaceAll("ms", "").split(/\n|:/); if (location.host in sites) { const argumentProcessor = (cb, delay, ...args) => ([cb, sites[location.host] * 1000, ...args]); transformMethod(rawWindow, "setInterval", argumentProcessor); transformMethod(rawWindow, "setTimeout", argumentProcessor); } })(); (async function() { const API = "https://api.nopecha.com"; const key = cfg.get("apiKey2"); async function postSolve(task, grid, images) { const response = await makeRequest(API, { method: "POST", headers: { 'Content-Type': 'application/json' }, data: { type: "recaptcha", task, grid, image_data: images, key } }); let result; do { await waitSeconds(1); result = await makeRequest(`${API}?id=${response.data}`); } while (!result?.data); return result.data; } async function solveLayer(gridSize) { const task = document.querySelector('.rc-imageselect-instructions')?.textContent.trim(); const tileEls = document.querySelectorAll('.rc-image-tile-33, .rc-image-tile-44, .rc-image-tile-11'); const tileArray = Array.from(tileEls).slice(0, gridSize === '1x1' ? undefined : 1); if (!tileArray.length) return; const images = await Promise.all(tileArray.map(el => imageUrlToBase64(el.src))); const decisions = await postSolve(task, gridSize, images); console.log(tileEls, decisions); const clickableTiles = [...tileEls].filter((tile, index) => decisions[index]); if (!clickableTiles) return; for (const tile of clickableTiles) { await waitSeconds(1); tile.click(); } while (document.querySelectorAll('.rc-imageselect-dynamic-selected').length) { await waitSeconds(1); } const nextTiles = document.querySelectorAll('.rc-image-tile-11'); if (nextTiles.length && gridSize != '1x1') await solveLayer(task, '1x1'); } onMatch("www.google.com", async function() { if (!currentUrl.includes("bframe")) return; if (!key) { const { credit, ttl } = await makeRequest(`${API}/status`); if (credit === 0) { const time = `${Math.floor(ttl/3600)}h ${Math.floor((ttl%3600)/60)}m`; return console.log(`Free quota expired. Reset in ${time}.`); } } while (isVisible(document.body)) { const baseGrid = document.querySelectorAll('.rc-imageselect-tile').length === 9 ? '3x3' : '4x4'; await solveLayer(baseGrid); simulateClick("#recaptcha-verify-button"); await waitSeconds(2); }; }); })(); // There are several known bugs, so if possible, it is recommended to use the official chrome extensions for now. (async function(isEnabled) { if (!isEnabled) return; let isSolved = false; const isCheckboxPresent = () => !!document.querySelector('.recaptcha-checkbox'); const isCheckboxChecked = () => document.querySelector('#recaptcha-anchor')?.getAttribute('aria-checked') === 'true'; const isImageChallengePresent = () => !!document.querySelector('#rc-imageselect'); const isGrid4x4 = () => document.querySelectorAll('.rc-imageselect-tile').length === 16; const isGrid3x3 = () => document.querySelectorAll('.rc-imageselect-tile').length === 9; const getChallengeData = () => { const target = document.querySelector('.rc-imageselect-instructions strong')?.innerText; const imageUrl = document.querySelector('.rc-image-tile-33, .rc-image-tile-44')?.src; return [target, imageUrl]; }; const solveImageChallenge = async (target, imageUrl, gridType) => { return new Promise(async (resolve, reject) => { const response = await makeRequest("https://api.nocaptchaai.com/createTask", { method: 'POST', headers: { 'Content-Type': 'application/json', }, data: { clientKey: cfg.get('apiKey1'), task: { type: 'ReCaptchaV2Classification', questionType: gridType, image: (await imageUrlToBase64(imageUrl)).replace("data:image/jpeg;base64,", ""), question: target } } }) if (response.errorId) reject(response); const solution = response.solution; resolve(solution?.objects || solution?.hasObject); }); }; const hasError = () => { const errorElements = document.querySelectorAll('[class^="rc-imageselect-error-"]'); return Array.from(errorElements).some(isVisible); }; while (!isSolved) { await waitSeconds(2); if (isCheckboxPresent()) { if (isCheckboxChecked()) { isSolved = true; return; } await simulateClick('#recaptcha-anchor'); } else if (isImageChallengePresent()) { const gridType = isGrid4x4() ? "44" : isGrid3x3() ? "33" : null; if (gridType && isImageChallengePresent() && !isCheckboxChecked()) { const [target, imageUrl] = getChallengeData(); if (target && imageUrl) { const solution = await solveImageChallenge(target, imageUrl, gridType); if (solution) { const tiles = document.querySelectorAll('.rc-image-tile-wrapper'); for (const index of solution) { if (tiles[index]) { simulateClick(tiles[index]); await waitSeconds(0.4); } } await waitSeconds(1); await simulateClick("#recaptcha-verify-button"); if (isCheckboxChecked()) { isSolved = true; await waitSeconds(1); return; } } } } } else if (isCheckboxChecked()) { isSolved = true; await waitSeconds(1); return; } if (hasError()) { simulateClick("#recaptcha-reload-button"); await waitSeconds(1); } } })(cfg.get("apiKey1").length > 20);