LocalCDN-Firefox-Chrome-Brave/README.md

11 KiB

LocalCDN

Translate CDNs Frameworks Firefox Add-on Chrome Add-on Buy Me a Coffee opencollective

LocalCDN is a fork of Decentraleyes and a web browser extension that emulates Content Delivery Networks to improve your online privacy. It intercepts traffic, finds supported resources locally, and injects them into the environment. All of this happens automatically, so no prior configuration is required. Feel free to use the following testing utility to find out if you are properly protected. For more information, please read the tutorial or the Wiki. You can also download the extension directly from Mozilla and just try it.

What are the advantages?

  • Supports cloud storage by browsers sync feature (Firefox Sync or own Sync-Server) if enabled
  • Removes integrity and crossorigin tags from embedded script and style elements to replace even more frameworks
  • Font Awesome
  • Google Material Icons
  • jQuery
  • Bootstrap CSS
  • Bootstrap JavaScript
  • AngularJS, AngularJS-Animate, AngularJS-Sanitize, AngularJS-Cookies and AngularJS-Touch
  • React, Vue.js, Chart.js and many other frameworks/libraries
  • MathJax (minimal)
  • TinyMCE (without plugins)
  • Internal statistics about CDNs and frameworks (day, week, month, year)
  • Export/Import your config
  • Prepared rules for uBlock Origin, uMatrix, AdGuard and NoScript

Note: LocalCDN is no silver bullet, but it does prevent a lot of websites from making you send these kinds of requests. Ultimately, you can make LocalCDN block requests for any missing CDN resources, too.

How does it work?

LocalCDN uses redirection for certain requests. There is a mapping file that lists the source (all CDNs and the path to the frameworks) and a resource file that defines the destination.

Currently only JavaScript and CSS files are redirected. However, some CSS files internally refer to other files, e.g. Font Awesome. All requests are redirected to a local file, e.g. jQuery. This is the reason why the extension is over 17 MB in size. Only if LocalCDN cannot find a local resource (and the option is enabled), a request will be blocked.

An adblocker (e.g. uBlock Origin, uMatrix or AdGuard) decides which requests are allowed. Only if your adblocker allows a request, it will be intercepted by LocalCDN. LocalCDN catches the request after an adblocker and not before.

What's the different of LocalCDN in comparison to other CDN emulators?

LocalCDN

LocalCDN

LocalCDN with activated HTML filter (optional)

LocalCDN with activated HTML filter (optional)

Other CDN emulators

Other CDN emulators

⚠️ Important ⚠️

In some cases, LocalCDN is not allowed to replace requested resources because the website sets up a strong Same Origin Policy (SOP). Please read Broken JavaScript or CSS on some websites before opening an issue. Here you can also find an online tool to test a website. This test covers the most common causes and provides solutions.

Screenshots

Light

Light Theme

Dark

Dark Theme

Rule generator for uBlock Origin, uMatrix and AdGuard (after an update)

Rule generator after an update

Settings

Settings (Basic)

Settings (Advanced)

Settings (Other)

Settings (Info)

Internal statistics

Internal statistics Internal statistics

Contributing Code

Suggestions in the form of Issues, and contributions in the form of Merge Requests, are highly welcome.

Installation

Running the Code as temporary extension

Please read this guide to run the extension from source.

Important: All tagged commits are signed with GPG. It's likely best to ignore unsigned commits, unless you really know what you're doing. Please send an email if you have any questions or security concerns.

Contact

Just open an issue with your question or write an email (PGP possible!).

Submitting Translations

The language you want is not completely translated or you are a language talent? Please help us by translating this add-on on Weblate.

Donations

LocalCDN is free and open-source. If you like LocalCDN you can support continued development by making a donation. Any help would be greatly appreciated!

  • IBAN: DE22 5003 1000 1069 4660 16 (BIC: TRODDEF1XXX)
  • Bitcoin: 1C4GRNyuUFkp9dMDjUkV4TwDwdfxdgLzde
  • Ether: 0x2df49c1186f8b615c2059f29c3ed7f9f86d49552
  • Monero: 46j26ggSZNT9rN7VeFYXp2PsKEMyJSSYneBVKXY4xeemdfZfCpNg6tQEXQZpWiTTuGX3SbnDPwuh3167cCoYSrqN72H9jPk

Buy me a coffee Open Collective

License

MPL-2.0.

External libraries