Bypass It

Automatically Bypass Restrictions and Get Straight to Your Destination!

当前为 2025-03-08 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Bypass It
  3. // @namespace http://tampermonkey.net/
  4. // @version 2025-03-08 (2)
  5. // @description Automatically Bypass Restrictions and Get Straight to Your Destination!
  6. // @supportURL https://gf.qytechs.cn/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 *://v2links.me/*
  16. // @match *://upfion.com/*
  17. // @match *://fb88dv.com/*
  18. // @match *://m88usb.com/*
  19. // @match *://vn88.group/*
  20. // @match *://vn88wo.com/*
  21. // @match *://vn88zx.com/*
  22. // @match *://vn88ko.com/*
  23. // @match *://vn88es.com/*
  24. // @match *://vn88tu.com/*
  25. // @match *://www.m88.com/*
  26. // @match *://bet88li.com/*
  27. // @match *://cutyion.com/*
  28. // @match *://vn88tk1.com/*
  29. // @match *://vn88vc.wiki/*
  30. // @match *://fb88vao.com/*
  31. // @match *://vn88.hiphop/*
  32. // @match *://www.fb88.com/*
  33. // @match *://*.devnote.in/*
  34. // @match *://naamlist.com/*
  35. // @match *://modsfire.com/*
  36. // @match *://yeumoney.com/*
  37. // @match *://*.gmsrweb.org/*
  38. // @match *://modijiurl.com/*
  39. // @match *://www.m88sut.com/*
  40. // @match *://*.techyuth.xyz/*
  41. // @match *://vn88.solutions/*
  42. // @match *://financewada.com/*
  43. // @match *://188.166.185.213/*
  44. // @match *://gemini.google.com/*
  45. // @match *://cryptowidgets.net/*
  46. // @match *://*.wikijankari.com/*
  47. // @match *://*.idblogmarket.com/*
  48. // @match *://*.phonesparrow.com/*
  49. // @match *://financenova.online/*
  50. // @match *://rajasthantopnews.com/*
  51. // @match *://www.google.com/url?q=*
  52. // @match *://utkarshonlinetest.com/*
  53. // @match *://www.youtube.com/redirect*
  54. // @match *://www.facebook.com/flx/warn/*
  55. // @match *://www.instagram.com/linkshim/*
  56. // @icon 
  57. // @grant GM_getValue
  58. // @grant GM_setValue
  59. // @grant unsafeWindow
  60. // @grant GM_openInTab
  61. // @grant GM_deleteValue
  62. // @grant GM_xmlhttpRequest
  63. // @grant GM_registerMenuCommand
  64. // @grant GM_addValueChangeListener
  65. // @license MIT
  66. // @noframes
  67. // ==/UserScript==
  68.  
  69. const noop = () => {};
  70. const rawWindow = unsafeWindow;
  71. const currentUrl = location.href;
  72. const queryParams = new URLSearchParams(location.search);
  73. const autoRedirectToSocial = GM_getValue("autoRedirectToSocial", false);
  74.  
  75.  
  76. /**
  77. * Waits for an element matching the selector to appear in the DOM.
  78. * @param {string} selector - The CSS selector of the element.
  79. * @returns {Promise<Element>} - A promise that resolves with the found element.
  80. */
  81. function waitForElement(selector, callback = noop) {
  82. const findElement = () => {
  83. if (selector.startsWith("//")) {
  84. return document.evaluate(selector, document, null, 9).singleNodeValue;
  85. }
  86. return document.querySelector(selector);
  87.  
  88. };
  89.  
  90. return new Promise((resolve) => {
  91. const element = findElement();
  92. if (document.contains(element)) {
  93. callback(element);
  94. return resolve(element);
  95. }
  96. const observer = new MutationObserver((mutations, observerInstance) => {
  97. const node = findElement();
  98. if (document.contains(node)) {
  99. observerInstance.disconnect();
  100. callback(node);
  101. resolve(node);
  102. }
  103. });
  104. observer.observe(document.documentElement, {
  105. attributes: true,
  106. childList: true,
  107. subtree: true,
  108. });
  109. });
  110. }
  111.  
  112. /**
  113. * Navigates the browser to the specified URL.
  114. * @param {string} url - The destination URL.
  115. */
  116. function navigateTo(url) {
  117. location = url;
  118. }
  119.  
  120. /**
  121. * Returns a promise that resolves after a specified number of seconds.
  122. * @param {number} seconds - The delay in seconds.
  123. * @returns {Promise<void>}
  124. */
  125. function waitSeconds(seconds) {
  126. return new Promise((resolve) => setTimeout(resolve, seconds * 1000));
  127. }
  128.  
  129. /**
  130. * Waits for an element matching the selector and then redirects to its href.
  131. * @param {string} selector - The CSS selector of the link element.
  132. */
  133. function autoRedirectToLink(selector) {
  134. waitForElement(selector).then((element) => navigateTo(element.href));
  135. }
  136.  
  137. /**
  138. * Creates a menu command in the Tampermonkey UI that toggles a boolean state.
  139. * @param {string} key - The key used to store and retrieve the boolean state in GM storage.
  140. * @param {string} title - The title displayed in the menu, which is prefixed with a checkmark or cross.
  141. */
  142. function createMenu(key, title) {
  143. const isActive = GM_getValue(key, false);
  144. const prefix = isActive ? "✔️ " : "❌ ";
  145.  
  146. GM_registerMenuCommand(prefix + title, function() {
  147. GM_setValue(key, !isActive);
  148. createMenu(key, title);
  149. alert(`${title} has been ${!isActive ? "enabled" : "disabled"}.`);
  150. }, {
  151. id: key
  152. });
  153. }
  154.  
  155. /**
  156. * Converts an image URL to a Base64 string.
  157. * This function fetches the image using an HTTP GET request and converts it into a Base64-encoded string.
  158. *
  159. * @param {string} imageUrl - The URL of the image to convert.
  160. * @returns {Promise<string|null>} A Promise that resolves with the Base64-encoded image string, or null if an error occurs.
  161. */
  162. function imageUrlToBase64(imageUrl) {
  163. if (!imageUrl) {
  164. console.error("No imageUrl provided");
  165. return null;
  166. }
  167. try {
  168. return new Promise((resolve, reject) => {
  169. GM_xmlhttpRequest({
  170. method: "GET",
  171. url: imageUrl,
  172. responseType: "blob",
  173. onload: function(response) {
  174. if (!response.response) {
  175. reject("No response received");
  176. return;
  177. }
  178.  
  179. const blob = response.response;
  180. const reader = new FileReader();
  181. reader.onload = () => resolve(reader.result);
  182. reader.onerror = (error) => {
  183. console.error("FileReader error:", error);
  184. reject(error);
  185. };
  186. reader.readAsDataURL(blob);
  187. },
  188. onerror: function(error) {
  189. console.error("Error fetching image:", error);
  190. reject(error);
  191. }
  192. });
  193. });
  194. } catch (error) {
  195. console.error("Error converting image to Base64:", error);
  196. return null;
  197. }
  198. }
  199.  
  200. /**
  201. * Sends a Base64-encoded image to a language model and receives a descriptive response based on specific icon classes.
  202. * This function sends the image as Base64 and asks the model to describe it with one of the provided icon classes.
  203. *
  204. * @param {string} base64Image - The Base64-encoded image string.
  205. * @param {Array<string>} iconClasses - An array of strings representing the icon classes to use for the description.
  206. * @returns {Promise<string|null>} A Promise that resolves with the description of the image in English, or null if an error occurs.
  207. */
  208. async function getGeminiResponse(base64Image, iconClasses) {
  209. if (!window.ai) {
  210. console.error("window.ai is not available. Ensure the Prompt API is enabled.");
  211. return;
  212. }
  213.  
  214. try {
  215. // Validate Gemini Nano availability
  216. const capabilities = await window.ai.languageModel.capabilities();
  217. if (!capabilities || !capabilities.available) {
  218. console.error("Gemini Nano is not available. Ensure the model is downloaded.");
  219. return;
  220. }
  221.  
  222. // Create session with system prompt to enforce English responses
  223. const session = await window.ai.languageModel.create({
  224. systemPrompt: "Analyze the given image and describe it using one of the provided categories. Be direct and concise.",
  225. expectedInputLanguages: ["en"]
  226. });
  227.  
  228. // Construct the prompt using the base64Image and iconClasses
  229. let result = await session.prompt(
  230. `Analyze the image: ${base64Image} and describe this image using one of: ${iconClasses.join(", ")}. Be direct.`
  231. );
  232.  
  233. console.log("Gemini Nano Response:", result);
  234. return result; // Ensure you're getting the correct response
  235. } catch (error) {
  236. console.error("Error with Gemini Nano:", error);
  237. throw error; // Better error propagation
  238. }
  239. }
  240.  
  241. /**
  242. * Executes a callback when the current host matches a pattern.
  243. * @param {string|RegExp} hostPattern - The host pattern or RegExp to match against location.host.
  244. * @param {Function} callback - The function to execute when matched.
  245. * @param {...any} args - Arguments to pass to the callback.
  246. */
  247. function runWhenHostMatches(hostPattern, callback, ...args) {
  248. const isMatch = new RegExp(hostPattern).test(location.host);
  249.  
  250. if (isMatch) callback(...args);
  251. }
  252.  
  253. /**
  254. * Simulates a click on an element (or multiple elements) specified by a selector.
  255. * Dispatches "mouseover", "mousedown", "mouseup", and "click" events.
  256. * @param {string} selector - The CSS selector of the element(s) to click.
  257. * @param {number} [delay=0] - Optional delay in seconds before clicking.
  258. */
  259. function simulateClick(selector, delay = 0) {
  260. const events = ["mouseover", "mousedown", "mouseup", "click"];
  261. const selectors = selector.split(", ");
  262. // If multiple selectors are provided, iterate over each.
  263. if (selectors.length > 1) {
  264. selectors.forEach((sel) => simulateClick(sel, delay));
  265. return;
  266. }
  267.  
  268. waitForElement(selector, async function(element) {
  269. if (delay > 0) {
  270. await waitSeconds(delay);
  271. }
  272.  
  273. events.forEach((eventName) => {
  274. const event = new MouseEvent(eventName, {
  275. bubbles: true,
  276. });
  277. element.dispatchEvent(event);
  278. });
  279. });
  280. }
  281.  
  282. /**
  283. * Calls the callback function once a captcha challenge is solved.
  284. * Checks for available captcha libraries (turnstile, hcaptcha, or grecaptcha).
  285. * @param {Function} callback - The function to execute when the captcha is solved.
  286. * @param {Function} [onWait=noop] - Optional function to call if waiting.
  287. */
  288. function whenCaptchaSolved(callback, onWait = noop) {
  289. let intervalId;
  290. const stopChecking = () => clearInterval(intervalId);
  291.  
  292. const checkCaptcha = () => {
  293. try {
  294. const captcha = rawWindow.turnstile || rawWindow.hcaptcha || rawWindow.grecaptcha;
  295. const response = captcha.getResponse();
  296.  
  297. if (response) {
  298. stopChecking();
  299. callback();
  300. }
  301. } catch (error) {
  302. onWait(stopChecking);
  303. }
  304. };
  305.  
  306. checkCaptcha();
  307. intervalId = setInterval(checkCaptcha, 1000);
  308. }
  309.  
  310. /**
  311. * Listens for messages with a specific label and triggers a callback when received.
  312. * @param {string} label - The identifier for the message.
  313. * @param {Function} [callback=noop] - The function to call when a message is received.
  314. */
  315. function GM_onMessage(label, callback = noop) {
  316. GM_addValueChangeListener("postMessage-" + label, function(name, oldValue, newValue, remote) {
  317. if (remote) {
  318. callback(newValue);
  319. GM_deleteValue(label);
  320. }
  321. });
  322. }
  323.  
  324. /**
  325. * Sends a message with a specific label by storing it in Greasemonkey storage.
  326. * @param {string} label - The identifier for the message.
  327. * @param {*} value - The data to be sent (must be serializable).
  328. */
  329. function GM_sendMessage(label, value) {
  330. GM_setValue("postMessage-" + label, value);
  331. }
  332.  
  333. // Main execution
  334. (function () {
  335. "use strict";
  336. runWhenHostMatches("modsfire.com", simulateClick, ".download-button, .download-button[href]");
  337. runWhenHostMatches("(financewada|utkarshonlinetest).com|financenova.online|v2links.me", simulateClick, ".get_btn a[href], //div[contains(text(),'Continue')], .get-link:not(.disabled)");
  338.  
  339. runWhenHostMatches("devnote.in|techyuth.xyz", simulateClick, "#scroll:not(.no), #getlinks[style*='display: block;'], .get-link:not(.disabled)");
  340. autoRedirectToSocial && runWhenHostMatches("(instagram|youtube|facebook).com", simulateClick, ".-cx-PRIVATE-Linkshim__followLink__, #invalid-token-redirect-goto-site-button, .selected");
  341. createMenu("autoRedirectToSocial", "Auto-Redirect to Social Media");
  342.  
  343. runWhenHostMatches("(wikijankari|idblogmarket|modijiurl|phonesparrow|naamlist|rajasthantopnews).com|gmsrweb.org", simulateClick, "center a[style*='display: block;'], .get-link:not(.disabled)");
  344.  
  345. runWhenHostMatches("aylink.co", simulateClick, ".btn-go, .complete[style*='display: block;'] a, a.btn:not(.btn-go)")
  346.  
  347. /*
  348. Sometimes, the AI model may provide inaccurate responses. Unfortunately, I can't control this. Sorry!
  349. https://danduh.github.io/window-ai/
  350. */
  351. runWhenHostMatches("cryptowidgets.net", function () {
  352. waitForElement('.captcha-icon img').then(async function (element) {
  353. const base64 = await imageUrlToBase64(element.src);
  354. if (!base64) return console.log("Failed to convert image.");
  355.  
  356. const icons = document.querySelectorAll('#icon-options i');
  357. const iconClasses = Array.from(icons).map(icon => icon.classList[1]);
  358.  
  359. console.log("Base64 Image:", base64);
  360.  
  361. const description = await getGeminiResponse(base64, iconClasses);
  362. console.log("Final Description:", description);
  363. simulateClick(`.${description}`);
  364. });
  365. });
  366. runWhenHostMatches("upfion.com", function() {
  367. simulateClick("#link-button:not([disabled])");
  368. waitForElement("a#link-button:not([disabled])").then((element) => navigateTo(element.href));
  369. });
  370. runWhenHostMatches("cutyion.com", simulateClick, "#submit-button:not([disabled])");
  371.  
  372. runWhenHostMatches("(www.)?(m88|m88sut|m88usb|bet88li|fb88|fb88dv|yeumoney|google|vn88wo|vn88tk1|vn8eu|fb88vao|vn88zx|vn88ko|vn88es|vn88tu|vn88n|vn88es).com|188.166.185.213|vn88.(hiphop|wtf|id|now|fan|group|solutions|ing)|vn88vc.wiki", function() {
  373. simulateClick(".getcodebtn");
  374.  
  375. waitForElement("//*[contains(@class, 'cursor-pointer') and contains(text(), 'footer')]", function() {
  376. simulateClick("a[href*='"+location.host+"']");
  377. })
  378. waitForElement("//*[contains(@class, 'cursor-pointer') and string-length(translate(normalize-space(text()), '0123456789', '')) = 0]", function(element) {
  379. GM_sendMessage("vietnam_code", element.innerText)
  380. })
  381.  
  382. // Google search results don’t always display the exact content that a website wants for every page
  383. // const searchLinks = [...document.querySelectorAll('div#search a[href]:not([class])')].map(a => a.href)
  384. const urls = [
  385. "m88.com/",
  386. "m88sut.com/",
  387. "m88usb.com/",
  388. "bet88li.com/m88",
  389. "www.fb88.com/",
  390. "fb88dv.com/",
  391. "188.166.185.213/w88",
  392. "vn88.fan",
  393. "vn88.group",
  394. "vn88.solutions",
  395. "vn88.ing",
  396. "vn88wo.com",
  397. "vn88tk1.com",
  398. "vn88.now",
  399. "vn8eu.com",
  400. "vn88vc.wiki",
  401. "fb88vao.com",
  402. "vn88zx.com",
  403. "vn88.wtf",
  404. "vn88ko.com",
  405. "vn88.id",
  406. "vn88.hiphop",
  407. "vn88es.com",
  408. "vn88n.com",
  409. "vn88tu.com",
  410. ];
  411. urls.includes(queryParams.get("q").replace("https://", "")) && simulateClick(".mymGo ~ div a");
  412.  
  413.  
  414. GM_onMessage("vietnam_code", function(newValue) {
  415. document.querySelector('[name="code"]').value = newValue;
  416. simulateClick(".box-form-button button");
  417. });
  418.  
  419. waitForElement("[data-clipboard-text]:not([data-clipboard-text=''])", function(element) {
  420. const links = urls.filter(url => url.includes(element.dataset.clipboardText));
  421. const tabs = [];
  422. links.forEach(async (url, index) => {
  423. await waitSeconds(index);
  424. let tab = GM_openInTab("https://www.google.com/url?q=https://" + url) //TODO: replace with window.open and then use postMessage
  425. tabs.push(tab);
  426. })
  427. window.addEventListener("beforeunload", function() {
  428. tabs.forEach(tab => tab.close());
  429. })
  430. })
  431. })
  432. })();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址