Stop Nefarious Redirects

Block unauthorized redirects and prevent history manipulation

当前为 2024-05-28 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Stop Nefarious Redirects
  3. // @namespace http://tampermonkey.net/
  4. // @version 4.1
  5. // @description Block unauthorized redirects and prevent history manipulation
  6. // @match http://*/*
  7. // @match https://*/*
  8. // @grant GM_setValue
  9. // @grant GM_getValue
  10. // @grant GM_xmlhttpRequest
  11. // @license MIT
  12. // @run-at document-start
  13. // @icon data:image/webp;base64,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
  14. // ==/UserScript==
  15.  
  16. const manualBlacklist = new Set([
  17. 'getrunkhomuto.info'
  18. ]);
  19.  
  20. // List of allowed popups domains
  21. const allowedPopups = [
  22. '500px.com', 'accuweather.com', 'adobe.com', 'adulttime.com', 'alibaba.com', 'amazon.com', 'amazonaws.com',
  23. 'amd.com', 'americanexpress.com', 'anaconda.com', 'angular.io', 'ap.org', 'apache.org', 'apnews.com',
  24. 'apple.com', 'arstechnica.com', 'artstation.com', 'asana.com', 'asus.com', 'atlassian.com', 'autodesk.com',
  25. 'axios.com', 'battle.net', 'bbc.co.uk', 'bbc.com', 'behance.net', 'bestbuy.com', 'bing.com', 'bitbucket.org',
  26. 'blogger.com', 'bloomberg.com', 'bmw.com', 'boeing.com', 'booking.co.uk', 'booking.com', 'bootstrapcdn.com',
  27. 'breitbart.com', 'buzzfeed.com', 'canva.com', 'capitalone.com', 'cbsnews.com', 'character.ai', 'chase.com',
  28. 'chaturbate.com', 'cisco.com', 'citi.com', 'cnbc.com', 'cnet.com', 'cnn.com', 'codecademy.com', 'constantcontact.com',
  29. 'coursera.org', 'craigslist.org', 'dailymail.co.uk', 'dell.com', 'deviantart.com', 'discord.com', 'disney.com',
  30. 'django.com', 'docker.com', 'docusign.com', 'dribbble.com', 'dropbox.com', 'duckduckgo.com', 'duolingo.com',
  31. 'duosecurity.com', 'ebay.com', 'economist.com', 'edx.org', 'elsevier.com', 'engadget.com', 'epicgames.com',
  32. 'eporner.com', 'espn.com', 'etsy.com', 'eurogamer.net', 'expedia.com', 'facebook.com', 'fandom.com', 'fedex.com',
  33. 'figma.com', 'finance.yahoo.com', 'flickr.com', 'flipkart.com', 'forbes.com', 'foxnews.com', 'framer.com',
  34. 'freecodecamp.org', 'gamespot.com', 'gartner.com', 'gettyimages.com', 'git-scm.com', 'github.com', 'gizmodo.com',
  35. 'go.com', 'godaddy.com', 'gog.com', 'goldmansachs.com', 'google.com', 'healthline.com', 'hilton.com', 'homedepot.com',
  36. 'hp.com', 'hubspot.com', 'huffpost.com', 'hulu.com', 'humblebundle.com', 'ibm.com', 'ieee.org', 'ifixit.com',
  37. 'ign.com', 'ikea.com', 'imdb.com', 'imgur.com', 'indeed.com', 'instagram.com', 'instructure.com', 'intel.com',
  38. 'intuit.com', 'invisionapp.com', 'itch.io', 'java.com', 'jetbrains.com', 'joomla.org', 'jquery.com', 'khanacademy.org',
  39. 'kotaku.com', 'kotlinlang.org', 'laravel.com', 'lenovo.com', 'lg.com', 'lifehacker.com', 'linkedin.com', 'live.com',
  40. 'lowes.com', 'lynda.com', 'macys.com', 'mailchimp.com', 'marriott.com', 'mashable.com', 'masterclass.com',
  41. 'mcdonalds.com', 'medium.com', 'mercedes-benz.com', 'microsoft.com', 'microsoftonline.commit.edu', 'mongodb.com',
  42. 'moodle.org', 'mozilla.org', 'msn.com', 'msnbc.com', 'nasa.gov', 'nationalgeographic.com', 'nbc.com', 'nbcnews.com',
  43. 'netflix.com', 'new.reddit.com', 'nextdoor.com', 'nih.gov', 'npr.org', 'nvidia.comnypost.com', 'nytimes.com',
  44. 'office.com', 'okta.com', 'onlyfans.com', 'openai.com', 'oracle.com', 'oreilly.com', 'origin.com', 'outlook.com',
  45. 'overstock.com', 'patreon.com', 'paypal.com', 'pcgamer.com', 'pexels.com', 'php.net', 'pinterest.com', 'pixabay.com',
  46. 'pluralsight.com', 'polygon.com', 'pornhub.com', 'python.org', 'quizlet.com', 'quora.com', 'reactjs.org', 'realtor.com',
  47. 'reddit.com', 'redhat.com', 'roblox.com', 'rubyonrails.org', 'salesforce.com', 'samsung.co.kr', 'samsung.com',
  48. 'sap.com', 'sciencedirect.com', 'scopus.com', 'sears.com', 'sharepoint.com', 'shutterstock.com', 'siemens.com',
  49. 'sketch.com', 'skillshare.com', 'skype.com', 'slack.com', 'sony.com', 'soundcloud.com', 'spotify.com', 'spring.io',
  50. 'stackoverflow.com', 'steamcommunity.com', 'steampowered.com', 'surveymonkey.com', 'symantec.com', 'target.com',
  51. 'techcrunch.com', 'temu.com', 'tesla.com', 'texasinstruments.com', 'theguardian.com', 'thenextweb.com', 'theverge.com',
  52. 'tiktok.com', 'time.com', 'toyota.com', 'trello.com', 'trip.com', 'tripadvisor.com', 'tumblr.com', 'twitch.tv',
  53. 'twitter.com', 'uber.com', 'ucla.edu', 'ucsf.edu', 'udemy.com', 'unity.com', 'unsplash.com', 'ups.com', 'usatoday.com',
  54. 'usnews.com', 'usps.com', 'verizon.com', 'Vice.com', 'vice.com', 'vimeo.com', 'vk.com', 'vmware.com', 'volkswagen.com',
  55. 'vox.com', 'walmart.com', 'washingtonpost.com', 'weather.com', 'weather.gov', 'webmd.com', 'whatsapp.com', 'wikimedia.org',
  56. 'wikipedia.org', 'wired.com', 'wordpress.com', 'wsj.com', 'wunderground.com', 'x.com', 'xerox.com', 'xfinity.com',
  57. 'yahoo.com', 'yelp.com', 'youtube.com', 'zapier.com', 'zendesk.com', 'zeplin.iozillow.com', 'zoom.us'
  58. ];
  59.  
  60. (function() {
  61. 'use strict';
  62.  
  63. console.log('Script initialization started.');
  64.  
  65. /**
  66. * Get the current automated blacklist
  67. * @returns {Set} The automated blacklist
  68. */
  69. function getAutomatedBlacklist() {
  70. return new Set(GM_getValue('blacklist', []));
  71. }
  72.  
  73. /**
  74. * Add a URL to the automated blacklist
  75. * @param {string} url - The URL to add to the blacklist
  76. */
  77. function addToAutomatedBlacklist(url) {
  78. const encodedUrl = encodeURIComponent(url);
  79. const blacklist = getAutomatedBlacklist();
  80. if (!blacklist.has(encodedUrl)) {
  81. blacklist.add(encodedUrl);
  82. GM_setValue('blacklist', Array.from(blacklist));
  83. console.log('Added to automated blacklist:', url);
  84. }
  85. }
  86.  
  87. /**
  88. * Check if navigation to a URL is allowed
  89. * @param {string} url - The URL to check
  90. * @returns {boolean} True if navigation is allowed, false otherwise
  91. */
  92. function isNavigationAllowed(url) {
  93. if (!isUrlBlocked(url)) {
  94. console.log('Navigation allowed to:', url);
  95. lastKnownGoodUrl = url;
  96. return true;
  97. } else {
  98. console.error('Blocked navigation to:', url);
  99. addToAutomatedBlacklist(url);
  100. if (lastKnownGoodUrl) {
  101. window.location.replace(lastKnownGoodUrl);
  102. }
  103. return false;
  104. }
  105. }
  106.  
  107. const originalAssign = window.location.assign.bind(window.location);
  108. const originalOpen = window.open;
  109.  
  110. console.log('Original window.location.assign and window.open saved.');
  111.  
  112. window.location.assign = function(url) {
  113. console.log('Redirect attempt detected:', url);
  114. if (!allowedPopups.some(domain => url.includes(domain)) && !isNavigationAllowed(url)) {
  115. console.log('Redirect to undesired domain blocked:', url);
  116. return;
  117. }
  118. console.log('Redirect allowed to:', url);
  119. return originalAssign(url);
  120. };
  121.  
  122. console.log('window.location.assign overridden with custom logic.');
  123.  
  124. window.open = function(url, name, features) {
  125. console.log('Popup attempt detected:', url);
  126. if (allowedPopups.some(domain => url.includes(domain)) || isNavigationAllowed(url)) {
  127. console.log('Popup allowed for:', url);
  128. return originalOpen(url, name, features);
  129. }
  130. console.log('Blocked a popup from:', url);
  131. return null;
  132. };
  133.  
  134. console.log('window.open overridden with custom logic.');
  135.  
  136. let lastKnownGoodUrl = window.location.href;
  137.  
  138. const locationProxy = new Proxy(window.location, {
  139. set(target, prop, value) {
  140. if (prop === 'href' || prop === 'assign' || prop === 'replace') {
  141. if (!isNavigationAllowed(value)) {
  142. return false;
  143. }
  144. }
  145. return Reflect.set(target, prop, value);
  146. },
  147. get(target, prop) {
  148. if (prop === 'assign' || prop === 'replace') {
  149. return function(url) {
  150. if (isNavigationAllowed(url)) {
  151. target[prop](url); // Properly assign the URL
  152. }
  153. };
  154. }
  155. return Reflect.get(target, prop);
  156. }
  157. });
  158.  
  159. Object.defineProperty(window, 'location', {
  160. configurable: true,
  161. enumerable: true,
  162. get() {
  163. return locationProxy;
  164. }
  165. });
  166.  
  167. window.addEventListener('popstate', function(event) {
  168. if (!isNavigationAllowed(window.location.href)) {
  169. console.error('Blocked navigation to:', window.location.href);
  170. history.pushState(null, "", lastKnownGoodUrl);
  171. window.location.replace(lastKnownGoodUrl);
  172. event.preventDefault();
  173. }
  174. });
  175.  
  176. /**
  177. * Handle history manipulation
  178. * @param {Function} originalMethod - The original history method
  179. * @param {*} data - The state data
  180. * @param {string} title - The page title
  181. * @param {string|null} url - The URL
  182. * @returns {*} The result of calling the original method
  183. */
  184. function handleHistoryManipulation(originalMethod, data, title, url) {
  185. if (!isUrlBlocked(url)) {
  186. return originalMethod.call(history, data, title, url);
  187. }
  188. console.error('Blocked history manipulation to:', url);
  189. }
  190.  
  191. const originalPushState = history.pushState;
  192. const originalReplaceState = history.replaceState;
  193.  
  194. history.pushState = function(data, title, url) {
  195. return handleHistoryManipulation(originalPushState, data, title, url);
  196. };
  197.  
  198. history.replaceState = function(data, title, url) {
  199. return handleHistoryManipulation(originalReplaceState, data, title, url);
  200. };
  201.  
  202. /**
  203. * Check if a URL is blocked based on the blacklist
  204. * @param {string} url - The URL to check
  205. * @returns {boolean} True if the URL is blocked, false otherwise
  206. */
  207. function isUrlBlocked(url) {
  208. const encodedUrl = encodeURIComponent(url);
  209. const automatedBlacklist = getAutomatedBlacklist();
  210. const isBlocked = [...manualBlacklist, ...automatedBlacklist].some(blockedUrl => encodedUrl.includes(blockedUrl));
  211. if (isBlocked) {
  212. console.log(`Blocked URL: ${url}`);
  213. }
  214. return isBlocked;
  215. }
  216.  
  217. console.log('Redirect control script with blacklist initialized.');
  218. })();