Skip to content

Instantly share code, notes, and snippets.

@webketje
Last active December 18, 2024 12:56
Show Gist options
  • Save webketje/fd7b8d4a979acc064a6930cc5d1dbc68 to your computer and use it in GitHub Desktop.
Save webketje/fd7b8d4a979acc064a6930cc5d1dbc68 to your computer and use it in GitHub Desktop.
Business Insider Subscribed - userscript

Business Insider subscribed - userscript

A Tampermonkey userscript you can use to read articles on businessinsider.com as if you were subscribed, that is - without paywall.

How does it work?

Business Insider subscribed hijacks the network request which otherwise loads the paywall. When the website API or code changes in areas relevant to this userscript, it may no longer work. If you find that the script no longer works, please report it in the comments below.

Is it fair?

Business Insider article content is delivered to your computer but hidden after the fact with browser scripting. This method of paywalling is cheap and better for SEO, but also easy to breach. So easy in fact that you can simply Disable Javascript for a page in your browser site settings and reload it, or for the raw version right-click, view page source. All this script does is automating the manual procedure for you whilst preserving page interactivity.

// ==UserScript==
// @name Business Insider Subscribed
// @namespace https://openuserjs.org/users/webketje
// @version 1.0.0
// @description Read businessinsider.com articles as if you were subscribed (without paywall).
// @author webketje
// @license MIT
// @tag news
// @downloadURL https://openuserjs.org/install/webketje/Business_Insider_Subscribed.min.user.js
// @updateURL https://openuserjs.org/meta/webketje/Business_Insider_Subscribed.meta.js
// @homepageURL https://gist.github.com/webketje/fd7b8d4a979acc064a6930cc5d1dbc68
// @supportURL https://gist.github.com/webketje/fd7b8d4a979acc064a6930cc5d1dbc68#comments
// @match https://www.businessinsider.com/*
// @icon 
// @grant unsafeWindow
// @run-at document-start
// @noframes
// ==/UserScript==
(function (global) {
'use strict';
var offendingUrl = '/ajax/render-component?path=paywall/template'
var cachedFetch = global.fetch
global.fetch = function (url, options) {
if (url === offendingUrl) {
const nopaywall = { query: { path: 'paywall/template' }, rendered: '<div></div>' }
global.fetch = cachedFetch
return Promise.resolve(nopaywall)
}
return cachedFetch(url, options)
}
})(unsafeWindow || window);
2024-12-18 - v1.0.0
- Initial release
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment