Bypass It

Automatically Bypass Restrictions and Get Straight to Your Destination!

  1. // ==UserScript==
  2. // @name Bypass It
  3. // @namespace http://tampermonkey.net/
  4. // @version 2025-04-29
  5. // @description Automatically Bypass Restrictions and Get Straight to Your Destination!
  6. // @supportURL https://greatest.deepsurf.us/scripts/527564/feedback
  7. // @author You
  8. // @match *://vn88.id/*
  9. // @match *://vn88.fan/*
  10. // @match *://vn88.ing/*
  11. // @match *://vn88.wtf/*
  12. // @match *://aylink.co/*
  13. // @match *://vn8eu.com/*
  14. // @match *://vn88n.com/*
  15. // @match *://gplinks.co/*
  16. // @match *://v2links.me/*
  17. // @match *://upfion.com/*
  18. // @match *://fb88dv.com/*
  19. // @match *://m88usb.com/*
  20. // @match *://vn88.group/*
  21. // @match *://vn88wo.com/*
  22. // @match *://vn88zx.com/*
  23. // @match *://vn88ko.com/*
  24. // @match *://vn88es.com/*
  25. // @match *://vn88tu.com/*
  26. // @match *://vn88my.com/*
  27. // @match *://v9bethi.com/*
  28. // @match *://www.m88.com/*
  29. // @match *://bet88li.com/*
  30. // @match *://cutyion.com/*
  31. // @match *://vn88tk1.com/*
  32. // @match *://vn88vc.wiki/*
  33. // @match *://fb88vao.com/*
  34. // @match *://coinclix.co/*
  35. // @match *://vn88.hiphop/*
  36. // @match *://gwaher.com/ptc
  37. // @match *://www.fb88.com/*
  38. // @match *://*.devnote.in/*
  39. // @match *://naamlist.com/*
  40. // @match *://modsfire.com/*
  41. // @match *://yeumoney.com/*
  42. // @match *://165.22.63.250/*
  43. // @match *://*.gmsrweb.org/*
  44. // @match *://modijiurl.com/*
  45. // @match *://geekgrove.net/*
  46. // @match *://www.m88sut.com/*
  47. // @match *://*.techyuth.xyz/*
  48. // @match *://vn88.solutions/*
  49. // @match *://financewada.com/*
  50. // @match *://188.166.185.213/*
  51. // @match *://gemini.google.com/*
  52. // @match *://cryptowidgets.net/*
  53. // @match *://*.wikijankari.com/*
  54. // @match *://cricketlegacy.com/*
  55. // @match *://ourcoincash.xyz/ptc*
  56. // @match *://*.idblogmarket.com/*
  57. // @match *://*.phonesparrow.com/*
  58. // @match *://financenova.online/*
  59. // @match *://bitcotasks.com//lead*
  60. // @match *://rajasthantopnews.com/*
  61. // @match *://www.google.com/url?q=*
  62. // @match *://freepayz.com/framed-ads
  63. // @match *://utkarshonlinetest.com/*
  64. // @match *://www.youtube.com/redirect*
  65. // @match *://www.facebook.com/flx/warn/*
  66. // @match *://gemini.google.com/app?msg=*
  67. // @match *://www.instagram.com/linkshim/*
  68. // @match https://www.google.com/recaptcha/api2/bframe*
  69. // @match https://www.google.com/recaptcha/api2/anchor*
  70. // @icon 
  71. // @grant GM_getValue
  72. // @grant GM_setValue
  73. // @grant GM_addStyle
  74. // @grant unsafeWindow
  75. // @grant GM_openInTab
  76. // @grant GM_deleteValue
  77. // @grant GM_xmlhttpRequest
  78. // @grant GM_registerMenuCommand
  79. // @grant GM_addValueChangeListener
  80. // @require https://update.greatest.deepsurf.us/scripts/439099/1203718/MonkeyConfig%20Modern%20Reloaded.js
  81. // @connect api.nocaptchaai.com
  82. // @connect api.nopecha.com
  83. // @license MIT
  84. // ==/UserScript==
  85. const cfg = new MonkeyConfig({
  86. menuCommand: true,
  87. params: {
  88. redirectToSocial: {
  89. type: 'checkbox',
  90. label: "Auto-Redirect to Social Media",
  91. default: false,
  92. },
  93. ptcFaucet: {
  94. type: 'checkbox',
  95. label: "Opens PTC links",
  96. default: false
  97. },
  98. apiKey1: {
  99. type: 'text',
  100. label: "noCaptcha Ai API Key",
  101. default: "",
  102. },
  103. apiKey2: {
  104. type: 'text',
  105. label: "NopeCHA API Key (leave empty to use IP authentication)",
  106. default: "",
  107. },
  108. siteDelays: {
  109. type: 'text',
  110. long: 3,
  111. label: "Site-Specific Delays (domain:delay)",
  112. default: 'example.com:50ms\nanotherexample.net:100ms'
  113. }
  114. }
  115. });
  116.  
  117. const noop = () => {};
  118. const rawWindow = unsafeWindow;
  119. const currentUrl = location.href;
  120. const queryParams = new URLSearchParams(location.search);
  121.  
  122. function waitForElement(selector, callback = noop) {
  123. const findElement = () => {
  124. if (selector.startsWith("//")) {
  125. return document.evaluate(selector, document, null, 9).singleNodeValue;
  126. }
  127. return document.querySelector(selector);
  128.  
  129. };
  130.  
  131. return new Promise((resolve) => {
  132. const element = findElement();
  133. if (document.contains(element)) {
  134. callback(element);
  135. return resolve(element);
  136. }
  137. const observer = new MutationObserver((mutations, observerInstance) => {
  138. const node = findElement();
  139. if (document.contains(node)) {
  140. observerInstance.disconnect();
  141. callback(node);
  142. resolve(node);
  143. }
  144. });
  145. observer.observe(document.documentElement, {
  146. attributes: true,
  147. childList: true,
  148. subtree: true,
  149. });
  150. });
  151. }
  152.  
  153. function navigateTo(url) {
  154. location = url;
  155. }
  156.  
  157. function waitSeconds(seconds) {
  158. return new Promise((resolve) => setTimeout(resolve, seconds * 1000));
  159. }
  160.  
  161. function redirectToLink(selector) {
  162. waitForElement(selector).then((element) => navigateTo(element.href));
  163. }
  164.  
  165. function imageUrlToBase64(imageUrl) {
  166. if (!imageUrl) {
  167. console.error("No imageUrl provided");
  168. return null;
  169. }
  170. return new Promise((resolve, reject) => {
  171. makeRequest(imageUrl, {
  172. responseType: "blob",
  173. }).then(blob => {
  174. const reader = new FileReader();
  175. reader.onload = () => resolve(reader.result);
  176. reader.onerror = (error) => {
  177. console.error("FileReader error:", error);
  178. reject(error);
  179. };
  180. reader.readAsDataURL(blob);
  181. })
  182. });
  183. }
  184.  
  185. function onMatch(hostPattern, callback, ...args) {
  186. hostPattern = hostPattern.replace("www.", "");
  187. if (hostPattern.length < 3) return;
  188.  
  189. const isMatch = new RegExp(hostPattern).test(location.host);
  190. if (isMatch) callback(...args);
  191. }
  192.  
  193. function onMatchClick(hostPattern, selector) {
  194. onMatch(hostPattern, simulateClick, selector)
  195. }
  196.  
  197. function simulateClick(selector, delay = 0) {
  198. const clickFun = (element) => {
  199. const events = ["mouseover", "mousedown", "mouseup", "click"];
  200. events.forEach((eventName) => {
  201. const event = new MouseEvent(eventName, {
  202. bubbles: true,
  203. });
  204. element.dispatchEvent(event);
  205. });
  206. }
  207. if (typeof selector != "string") {
  208. return clickFun(selector);
  209. }
  210. const selectors = selector.split(", ");
  211. if (selectors.length > 1) {
  212. selectors.forEach((sel) => simulateClick(sel, delay));
  213. return;
  214. }
  215.  
  216. waitForElement(selector, async function(element) {
  217. if (delay > 0) await waitSeconds(delay);
  218. clickFun(element);
  219. });
  220. }
  221.  
  222. function whenCaptchaSolved(callback, onWait = noop) {
  223. let intervalId;
  224. const stopChecking = () => clearInterval(intervalId);
  225.  
  226. // waitForElement("//*[@id='captcha-result'] and normalize-space() = 'Verified!']", function() {
  227. // stopChecking();
  228. // callback();
  229. // })
  230. const checkCaptcha = () => {
  231. try {
  232. const element = document.querySelector('#captcha-result .mb-2.badge.bg-success');
  233. if (element && element.textContent.trim() === 'Verified!') {
  234. stopChecking();
  235. callback();
  236. }
  237.  
  238. const captcha = rawWindow.turnstile || rawWindow.hcaptcha || rawWindow.grecaptcha;
  239. const response = captcha.getResponse();
  240.  
  241. if (response) {
  242. stopChecking();
  243. callback();
  244. }
  245. } catch (error) {
  246. onWait(stopChecking);
  247. }
  248. };
  249.  
  250. checkCaptcha();
  251. intervalId = setInterval(checkCaptcha, 1000);
  252. }
  253.  
  254. function GM_onMessage(label, callback = noop) {
  255. GM_addValueChangeListener("postMessage-" + label, function(name, oldValue, newValue, remote) {
  256. if (remote) {
  257. GM_deleteValue("postMessage-" + label);
  258. callback(newValue);
  259. }
  260. });
  261. }
  262.  
  263. function GM_sendMessage(label, value) {
  264. GM_setValue("postMessage-" + label, value);
  265. }
  266.  
  267. function onOpenTab(callback) {
  268. const originalOpen = rawWindow.open;
  269.  
  270. rawWindow.open = function(...args) {
  271. const newWindow = originalOpen.apply(rawWindow, args);
  272. callback(newWindow);
  273. return newWindow;
  274. };
  275. }
  276.  
  277. function clickWithTrusted() {
  278. // Create window proxy to disable Object.freeze
  279. const sandbox = new Proxy(window, {
  280. get(target, key) {
  281. if (key === 'Object') {
  282. return new Proxy(Object, {
  283. get(objTarget, objKey) {
  284. if (objKey === 'freeze') {
  285. return function(obj) {
  286. console.warn("Object.freeze disabled in sandbox.");
  287. return obj;
  288. };
  289. }
  290. return Reflect.get(objTarget, objKey);
  291. }
  292. });
  293. }
  294. return Reflect.get(target, key);
  295. }
  296. });
  297.  
  298. // Patch addEventListener to clone events and force isTrusted
  299. const originalAddEventListener = EventTarget.prototype.addEventListener;
  300. EventTarget.prototype.addEventListener = function(type, listener, options) {
  301. const wrappedListener = function(event) {
  302. const clonedEvent = Object.create(event);
  303. Object.defineProperty(clonedEvent, "isTrusted", {
  304. value: true,
  305. writable: false
  306. });
  307. return listener.call(this, clonedEvent);
  308. };
  309. return originalAddEventListener.call(this, type, wrappedListener, options);
  310. };
  311.  
  312. return sandbox;
  313. }
  314.  
  315. function isVisible(element) {
  316. if (!element) return false;
  317.  
  318. const style = window.getComputedStyle(element);
  319. const visible = style.display !== 'none' &&
  320. style.visibility !== 'hidden' &&
  321. style.opacity !== '0' &&
  322. element.offsetWidth > 0 &&
  323. element.offsetHeight > 0;
  324.  
  325. if (!visible) return false;
  326.  
  327. return isVisible(element.parentElement) || element.parentElement === null;
  328. };
  329.  
  330. function transformMethod(object, methodName, argumentProcessor) {
  331. const originalMethod = object[methodName];
  332.  
  333. Object.defineProperty(object, methodName, {
  334. value: function (...args) {
  335. const processedArgs = argumentProcessor(args);
  336. return originalMethod(...processedArgs);
  337. },
  338. writable: false,
  339. configurable: false
  340. });
  341. }
  342.  
  343. function makeRequest(url, options = {}) {
  344. return new Promise((resolve, reject) => {
  345. GM_xmlhttpRequest({
  346. url,
  347. method: options.method || "GET",
  348. responseType: options.responseType || "json",
  349. headers: options.headers || {},
  350. data: options.data ? JSON.stringify(options.data) : null,
  351. //timeout: options.timeout || 0,
  352. onload: (response) => resolve(response.response),
  353. onerror: (error) => reject(error),
  354. ontimeout: (error) => reject(error),
  355. onabort: (error) => reject(error)
  356. });
  357. });
  358. }
  359.  
  360. // Main execution
  361. (function () {
  362. "use strict";
  363. //only click
  364. onMatchClick("cutyion.com", "#submit-button:not([disabled])");
  365. onMatchClick("modsfire.com", ".download-button, .download-button[href]");
  366. onMatchClick("aylink.co", ".btn-go, .complete[style*='display: block;'] a, a.btn:not(.btn-go)")
  367. onMatchClick("devnote.in|techyuth.xyz", "#scroll:not(.no), #getlinks[style*='display: block;'], .get-link:not(.disabled)");
  368. onMatchClick("gplinks.co|cricketlegacy.com", "#VerifyBtn[style*='display: block;'], #NextBtn:not([href='#']), #captchaButton:not(.disabled)");
  369. onMatchClick("(financewada|utkarshonlinetest).com|financenova.online|v2links.me", ".get_btn a[href], //div[contains(text(),'Continue')], .get-link:not(.disabled)");
  370. onMatchClick("(wikijankari|idblogmarket|modijiurl|phonesparrow|naamlist|rajasthantopnews).com|gmsrweb.org", "center a[style*='display: block;'], .get-link:not(.disabled)");
  371. cfg.get("redirectToSocial") && onMatchClick("(instagram|youtube|facebook).com", ".-cx-PRIVATE-Linkshim__followLink__, #invalid-token-redirect-goto-site-button, .selected");
  372.  
  373. onMatch("upfion.com", function() {
  374. simulateClick("#link-button:not([disabled])");
  375. redirectToLink("a#link-button:not([disabled])");
  376. });
  377.  
  378. onMatch("(m88(sut|usb)?|bet88li|fb88(dv|vao)?|yeumoney|google|vn8?8(wo|tk1|eu|zx|ko|es|tu|n|my)?|v9bethi).com|188.166.185.213|165.22.63.250|vn88.(hiphop|wtf|id|now|fan|group|solutions|ing)|vn88vc.wiki", function() {
  379. waitForElement(".getcodebtn", function(element) {
  380. element.click();
  381. GM_sendMessage("close_tabs", currentUrl);
  382. })
  383. waitForElement("//*[contains(@class, 'cursor-pointer') and contains(text(), 'footer')]", function() {
  384. simulateClick("a[href*='"+location.host+"']");
  385. })
  386. waitForElement("//*[contains(@class, 'cursor-pointer') and string-length(translate(normalize-space(text()), '0123456789', '')) = 0]", function(element) {
  387. GM_sendMessage("vietnam_code", element.innerText)
  388. })
  389.  
  390. const tabs = [];
  391. const urls = [
  392. "m88.com", "vn88.id", "vn88.fan", "vn88.ing", "fb88.com", "vn88.now",
  393. "vn88.wtf", "vn8eu.com", "vn88n.com", "m88sut.com", "m88usb.com",
  394. "fb88dv.com", "vn88.group", "vn88wo.com", "vn88zx.com", "vn88ko.com",
  395. "vn88es.com", "vn88tu.com", "vn88tk1.com","vn88vc.wiki", "fb88vao.com",
  396. "vn88.hiphop", "vn88.solutions", "bet88li.com/m88", "188.166.185.213/w88",
  397. "165.22.63.250/188bet", "vn88my.com/m88", "v9bethi.com"
  398. ]
  399.  
  400. urls.includes(queryParams.get("q")?.replace("https://", "")) && simulateClick(".mymGo ~ div a");
  401.  
  402. GM_onMessage("vietnam_code", function(newValue) {
  403. tabs.forEach(([_, tab]) => tab.close());
  404. document.querySelector('[name="code"]').value = newValue;
  405. simulateClick(".box-form-button button");
  406. });
  407.  
  408. waitForElement("[data-clipboard-text]:not([data-clipboard-text=''])", function(element) {
  409. const links = urls.filter(url => url.includes(element.dataset.clipboardText));
  410. links.forEach(url => {
  411. const tab = GM_openInTab("https://www.google.com/url?q=https://" + url);
  412. tabs.push([url, tab]);
  413. })
  414. GM_onMessage("close_tabs", function(newValue) {
  415. tabs.forEach(([url, tab]) => {
  416. if (new URL("https://" + url).host !== new URL(newValue).host) {
  417. tab.close();
  418. }
  419. });
  420. });
  421. })
  422. });
  423.  
  424. if (cfg.get("ptcFaucet")) {
  425. const regex = /^(visit for \d+ sec|visit(?: now)?|go|view|view now|view ads?|watch|start .* coins|start view ad)$/i;
  426. const findButton = () => [...document.querySelectorAll("button")].find(btn => regex.test(btn.textContent.trim()));
  427.  
  428. onMatch("ourcoincash.xyz|(bitcotasks|freepayz|gwaher).com", function() {
  429. //TODO: replace the use of setInterval and fix the issue with tabs
  430. let tabObj;
  431. onOpenTab(function(tab) { tabObj = tab; });
  432. rawWindow.addEventListener("beforeunload", function() { tabObj?.close(); })
  433.  
  434. findButton()?.click();
  435.  
  436. setInterval(function() {
  437. tabObj?.close();
  438. findButton()?.click();
  439. }, 120000) // 120 sec
  440. whenCaptchaSolved(function() {
  441. const btn = document.querySelector("button[type='submit']")
  442. isVisible(btn) && btn.click();
  443. })
  444. })
  445. }
  446.  
  447. onMatch("coinclix.co|geekgrove.net", async function() {
  448. // Add support for Google. Currently, it is not supported, and a refresh is needed when it appears.
  449. if (!cfg.get("autoRedirectToSocial")) {
  450. //TODO: Automatically enable for a temporary amount of time
  451. return alert("To bypass this, you need to enable Auto-Redirect to Social Media.");
  452. }
  453. const code = document.querySelector(".mb-2 code");
  454. if (code) {
  455. //TODO: replace with something else
  456. const tab = GM_openInTab(document.querySelector("strong a")?.href);
  457. await waitSeconds(10);
  458. GM_sendMessage("geek_code", code.innerText);
  459.  
  460. }
  461. GM_onMessage("geek_code", function(newValue) {
  462. document.querySelector("#link_input").value = newValue;
  463. simulateClick("#btn_link, .btn-primary[href]");
  464. });
  465. })
  466.  
  467. // Don't forget to add the site into the @match.
  468. const sites = cfg.get("siteDelays").replaceAll("ms", "").split(/\n|:/);
  469. if (location.host in sites) {
  470. const argumentProcessor = (cb, delay, ...args) => ([cb, sites[location.host] * 1000, ...args]);
  471. transformMethod(rawWindow, "setInterval", argumentProcessor);
  472. transformMethod(rawWindow, "setTimeout", argumentProcessor);
  473. }
  474. })();
  475. // There are several known bugs, so if possible, it is recommended to use the official chrome extensions for now.
  476. (async function(isEnabled) {
  477. if (!isEnabled) return;
  478.  
  479. let isSolved = false;
  480.  
  481. const isCheckboxPresent = () => !!document.querySelector('.recaptcha-checkbox');
  482. const isCheckboxChecked = () => document.querySelector('#recaptcha-anchor')?.getAttribute('aria-checked') === 'true';
  483. const isImageChallengePresent = () => !!document.querySelector('#rc-imageselect');
  484. const isGrid4x4 = () => document.querySelectorAll('.rc-imageselect-tile').length === 16;
  485. const isGrid3x3 = () => document.querySelectorAll('.rc-imageselect-tile').length === 9;
  486. const getChallengeData = () => {
  487. const target = document.querySelector('.rc-imageselect-instructions strong')?.innerText;
  488. const imageUrl = document.querySelector('.rc-image-tile-33, .rc-image-tile-44')?.src;
  489. return [target, imageUrl];
  490. };
  491.  
  492. const solveImageChallenge = async (target, imageUrl, gridType) => {
  493. return new Promise(async (resolve, reject) => {
  494. const response = await makeRequest("https://api.nocaptchaai.com/createTask", {
  495. method: 'POST',
  496. headers: {
  497. 'Content-Type': 'application/json',
  498. },
  499. data: {
  500. clientKey: cfg.get('apiKey1'),
  501. task: {
  502. type: 'ReCaptchaV2Classification',
  503. questionType: gridType,
  504. image: (await imageUrlToBase64(imageUrl)).replace("data:image/jpeg;base64,", ""),
  505. question: target
  506. }
  507. }
  508. })
  509.  
  510. if (response.errorId) reject(response);
  511. const solution = response.solution;
  512. resolve(solution?.objects || solution?.hasObject);
  513. });
  514. };
  515.  
  516. const hasError = () => {
  517. const errorElements = document.querySelectorAll('[class^="rc-imageselect-error-"]');
  518. return Array.from(errorElements).some(isVisible);
  519. };
  520.  
  521. while (!isSolved) {
  522. await waitSeconds(2);
  523. if (isCheckboxPresent()) {
  524. if (isCheckboxChecked()) {
  525. isSolved = true;
  526. return;
  527. }
  528. await simulateClick('#recaptcha-anchor');
  529. } else if (isImageChallengePresent()) {
  530. const gridType = isGrid4x4() ? "44" : isGrid3x3() ? "33" : null;
  531. if (gridType && isImageChallengePresent() && !isCheckboxChecked()) {
  532. const [target, imageUrl] = getChallengeData();
  533. if (target && imageUrl) {
  534. const solution = await solveImageChallenge(target, imageUrl, gridType);
  535. if (solution) {
  536. const tiles = document.querySelectorAll('.rc-image-tile-wrapper');
  537. for (const index of solution) {
  538. if (tiles[index]) {
  539. simulateClick(tiles[index]);
  540. await waitSeconds(0.4);
  541. }
  542. }
  543. await waitSeconds(1);
  544. await simulateClick("#recaptcha-verify-button");
  545.  
  546. if (isCheckboxChecked()) {
  547. isSolved = true;
  548. await waitSeconds(1);
  549. return;
  550. }
  551. }
  552. }
  553. }
  554. } else if (isCheckboxChecked()) {
  555. isSolved = true;
  556. await waitSeconds(1);
  557. return;
  558. }
  559.  
  560. if (hasError()) {
  561. simulateClick("#recaptcha-reload-button");
  562. await waitSeconds(1);
  563. }
  564. }
  565. })(cfg.get("apiKey1").length > 20);