Bypass It

Automatically Bypass Restrictions and Get Straight to Your Destination!

目前为 2025-03-01 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name Bypass It
  3. // @namespace http://tampermonkey.net/
  4. // @version 2025-03-01 (1)
  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 *://aylink.co/*
  9. // @match *://v2links.me/*
  10. // @match *://upfion.com/*
  11. // @match *://cutyion.com/*
  12. // @match *://*.devnote.in/*
  13. // @match *://naamlist.com/*
  14. // @match *://modsfire.com/*
  15. // @match *://*.gmsrweb.org/*
  16. // @match *://modijiurl.com/*
  17. // @match *://*.techyuth.xyz/*
  18. // @match *://financewada.com/*
  19. // @match *://cryptowidgets.net/*
  20. // @match *://*.wikijankari.com/*
  21. // @match *://*.idblogmarket.com/*
  22. // @match *://*.phonesparrow.com/*
  23. // @match *://financenova.online/*
  24. // @match *://rajasthantopnews.com/*
  25. // @match *://utkarshonlinetest.com/*
  26. // @match *://www.youtube.com/redirect*
  27. // @match *://www.facebook.com/flx/warn/*
  28. // @match *://www.instagram.com/linkshim/*
  29. // @icon 
  30. // @grant GM_getValue
  31. // @grant GM_setValue
  32. // @grant unsafeWindow
  33. // @grant GM_openInTab
  34. // @grant GM_xmlhttpRequest
  35. // @grant GM_registerMenuCommand
  36. // @license MIT
  37. // @noframes
  38. // ==/UserScript==
  39.  
  40. const noop = () => {};
  41. const rawWindow = unsafeWindow;
  42. const currentUrl = location.href;
  43. const autoRedirectToSocial = GM_getValue("autoRedirectToSocial", false);
  44.  
  45. /**
  46. * Waits for an element matching the selector to appear in the DOM.
  47. * @param {string} selector - The CSS selector of the element.
  48. * @returns {Promise<Element>} - A promise that resolves with the found element.
  49. */
  50. function waitForElement(selector) {
  51. const findElement = () => {
  52. if (selector.startsWith("//")) {
  53. return document.evaluate(selector, document, null, 9).singleNodeValue;
  54. }
  55. return document.querySelector(selector);
  56.  
  57. };
  58.  
  59. return new Promise((resolve) => {
  60. const element = findElement();
  61. if (document.contains(element)) {
  62. return resolve(element);
  63. }
  64. const observer = new MutationObserver((mutations, observerInstance) => {
  65. const node = findElement();
  66. if (document.contains(node)) {
  67. observerInstance.disconnect();
  68. resolve(node);
  69. }
  70. });
  71. observer.observe(document.documentElement, {
  72. attributes: true,
  73. childList: true,
  74. subtree: true,
  75. });
  76. });
  77. }
  78.  
  79. /**
  80. * Navigates the browser to the specified URL.
  81. * @param {string} url - The destination URL.
  82. */
  83. function navigateTo(url) {
  84. location = url;
  85. }
  86.  
  87. /**
  88. * Returns a promise that resolves after a specified number of seconds.
  89. * @param {number} seconds - The delay in seconds.
  90. * @returns {Promise<void>}
  91. */
  92. function waitSeconds(seconds) {
  93. return new Promise((resolve) => setTimeout(resolve, seconds * 1000));
  94. }
  95.  
  96. /**
  97. * Waits for an element matching the selector and then redirects to its href.
  98. * @param {string} selector - The CSS selector of the link element.
  99. */
  100. function autoRedirectToLink(selector) {
  101. waitForElement(selector).then((element) => navigateTo(element.href));
  102. }
  103.  
  104. /**
  105. * Creates a menu command in the Tampermonkey UI that toggles a boolean state.
  106. * @param {string} key - The key used to store and retrieve the boolean state in GM storage.
  107. * @param {string} title - The title displayed in the menu, which is prefixed with a checkmark or cross.
  108. */
  109. function createMenu(key, title) {
  110. const isActive = GM_getValue(key, false);
  111. const prefix = isActive ? "✔️ " : "❌ ";
  112.  
  113. GM_registerMenuCommand(prefix + title, function() {
  114. GM_setValue(key, !isActive);
  115. createMenu(key, title);
  116. alert(`${title} has been ${!isActive ? "enabled" : "disabled"}.`);
  117. }, {
  118. id: key
  119. });
  120. }
  121.  
  122. /**
  123. * Converts an image URL to a Base64 string.
  124. * This function fetches the image using an HTTP GET request and converts it into a Base64-encoded string.
  125. *
  126. * @param {string} imageUrl - The URL of the image to convert.
  127. * @returns {Promise<string|null>} A Promise that resolves with the Base64-encoded image string, or null if an error occurs.
  128. */
  129. function imageUrlToBase64(imageUrl) {
  130. if (!imageUrl) {
  131. console.error("No imageUrl provided");
  132. return null;
  133. }
  134. try {
  135. return new Promise((resolve, reject) => {
  136. GM_xmlhttpRequest({
  137. method: "GET",
  138. url: imageUrl,
  139. responseType: "blob",
  140. onload: function(response) {
  141. if (!response.response) {
  142. reject("No response received");
  143. return;
  144. }
  145.  
  146. const blob = response.response;
  147. const reader = new FileReader();
  148. reader.onload = () => resolve(reader.result);
  149. reader.onerror = (error) => {
  150. console.error("FileReader error:", error);
  151. reject(error);
  152. };
  153. reader.readAsDataURL(blob);
  154. },
  155. onerror: function(error) {
  156. console.error("Error fetching image:", error);
  157. reject(error);
  158. }
  159. });
  160. });
  161. } catch (error) {
  162. console.error("Error converting image to Base64:", error);
  163. return null;
  164. }
  165. }
  166.  
  167. /**
  168. * Sends a Base64-encoded image to a language model and receives a descriptive response based on specific icon classes.
  169. * This function sends the image as Base64 and asks the model to describe it with one of the provided icon classes.
  170. *
  171. * @param {string} base64Image - The Base64-encoded image string.
  172. * @param {Array<string>} iconClasses - An array of strings representing the icon classes to use for the description.
  173. * @returns {Promise<string|null>} A Promise that resolves with the description of the image in English, or null if an error occurs.
  174. */
  175. async function getGeminiResponse(base64Image, iconClasses) {
  176. if (!window.ai) {
  177. console.error("window.ai is not available. Ensure the Prompt API is enabled.");
  178. return;
  179. }
  180.  
  181. try {
  182. // Validate Gemini Nano availability
  183. const capabilities = await window.ai.languageModel.capabilities();
  184. if (!capabilities || !capabilities.available) {
  185. console.error("Gemini Nano is not available. Ensure the model is downloaded.");
  186. return;
  187. }
  188.  
  189. // Create session with system prompt to enforce English responses
  190. const session = await window.ai.languageModel.create({
  191. systemPrompt: "Analyze the given image and describe it using one of the provided categories. Be direct and concise.",
  192. expectedInputLanguages: ["en"]
  193. });
  194.  
  195. // Construct the prompt using the base64Image and iconClasses
  196. let result = await session.prompt(
  197. `Analyze the image: ${base64Image} and describe this image using one of: ${iconClasses.join(", ")}. Be direct.`
  198. );
  199.  
  200. console.log("Gemini Nano Response:", result);
  201. return result; // Ensure you're getting the correct response
  202. } catch (error) {
  203. console.error("Error with Gemini Nano:", error);
  204. throw error; // Better error propagation
  205. }
  206. }
  207.  
  208. /**
  209. * Executes a callback when the current host matches a pattern.
  210. * @param {string|RegExp} hostPattern - The host pattern or RegExp to match against location.host.
  211. * @param {Function} callback - The function to execute when matched.
  212. * @param {...any} args - Arguments to pass to the callback.
  213. */
  214. function runWhenHostMatches(hostPattern, callback, ...args) {
  215. const isMatch = new RegExp(hostPattern).test(location.host);
  216.  
  217. if (isMatch) callback(...args);
  218. }
  219.  
  220. /**
  221. * Simulates a click on an element (or multiple elements) specified by a selector.
  222. * Dispatches "mouseover", "mousedown", "mouseup", and "click" events.
  223. * @param {string} selector - The CSS selector of the element(s) to click.
  224. * @param {number} [delay=0] - Optional delay in seconds before clicking.
  225. */
  226. function simulateClick(selector, delay = 0) {
  227. const events = ["mouseover", "mousedown", "mouseup", "click"];
  228. const selectors = selector.split(", ");
  229. // If multiple selectors are provided, iterate over each.
  230. if (selectors.length > 1) {
  231. selectors.forEach((sel) => simulateClick(sel, delay));
  232. return;
  233. }
  234.  
  235. waitForElement(selector).then(async (element) => {
  236. if (delay > 0) {
  237. await waitSeconds(delay);
  238. }
  239.  
  240. events.forEach((eventName) => {
  241. const event = new MouseEvent(eventName, {
  242. bubbles: true,
  243. });
  244. element.dispatchEvent(event);
  245. });
  246. });
  247. }
  248.  
  249. /**
  250. * Calls the callback function once a captcha challenge is solved.
  251. * Checks for available captcha libraries (turnstile, hcaptcha, or grecaptcha).
  252. * @param {Function} callback - The function to execute when the captcha is solved.
  253. * @param {Function} [onWait=noop] - Optional function to call if waiting.
  254. */
  255. function whenCaptchaSolved(callback, onWait = noop) {
  256. let intervalId;
  257. const stopChecking = () => clearInterval(intervalId);
  258.  
  259. const checkCaptcha = () => {
  260. try {
  261. const captcha = rawWindow.turnstile || rawWindow.hcaptcha || rawWindow.grecaptcha;
  262. const response = captcha.getResponse();
  263.  
  264. if (response) {
  265. stopChecking();
  266. callback();
  267. }
  268. } catch (error) {
  269. onWait(stopChecking);
  270. }
  271. };
  272.  
  273. checkCaptcha();
  274. intervalId = setInterval(checkCaptcha, 1000);
  275. }
  276.  
  277. // Main execution
  278. (function () {
  279. "use strict";
  280. runWhenHostMatches("modsfire.com", simulateClick, ".download-button, .download-button[href]");
  281. runWhenHostMatches("(financewada|utkarshonlinetest).com|financenova.online|v2links.me", simulateClick, ".get_btn a[href], //div[contains(text(),'Continue')], .get-link:not(.disabled)");
  282.  
  283. runWhenHostMatches("devnote.in|techyuth.xyz", simulateClick, "#scroll:not(.no), #getlinks[style*='display: block;'], .get-link:not(.disabled)");
  284. autoRedirectToSocial && runWhenHostMatches("(instagram|youtube|facebook).com", simulateClick, ".-cx-PRIVATE-Linkshim__followLink__, #invalid-token-redirect-goto-site-button, .selected");
  285. createMenu("autoRedirectToSocial", "Auto-Redirect to Social Media");
  286.  
  287. runWhenHostMatches("(wikijankari|idblogmarket|modijiurl|phonesparrow|naamlist|rajasthantopnews).com|gmsrweb.org", simulateClick, "center a[style*='display: block;'], .get-link:not(.disabled)");
  288.  
  289. runWhenHostMatches("aylink.co", simulateClick, ".btn-go, .complete[style*='display: block;'] a, a.btn:not(.btn-go)")
  290.  
  291. /*
  292. Sometimes, the AI model may provide inaccurate responses. Unfortunately, I can't control this. Sorry!
  293. https://danduh.github.io/window-ai/
  294. */
  295. runWhenHostMatches("cryptowidgets.net", function () {
  296. waitForElement('.captcha-icon img').then(async function (element) {
  297. const base64 = await imageUrlToBase64(element.src);
  298. if (!base64) return console.log("Failed to convert image.");
  299.  
  300. const icons = document.querySelectorAll('#icon-options i');
  301. const iconClasses = Array.from(icons).map(icon => icon.classList[1]);
  302.  
  303. console.log("Base64 Image:", base64);
  304.  
  305. const description = await getGeminiResponse(base64, iconClasses);
  306. console.log("Final Description:", description);
  307. simulateClick(`.${description}`);
  308. });
  309. });
  310. runWhenHostMatches("upfion.com", function() {
  311. simulateClick("#link-button:not([disabled])");
  312. waitForElement("a#link-button:not([disabled])").then((element) => navigateTo(element.href));
  313. });
  314. runWhenHostMatches("cutyion.com", simulateClick, "#submit-button:not([disabled])");
  315. })();

QingJ © 2025

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