# LocalCDN [![Translate](https://www.localcdn.org/badges/translation.svg)](https://hosted.weblate.org/projects/localcdn/localcdn/) [![CDNs](https://www.localcdn.org/badges/cdn.svg)](https://codeberg.org/nobody/LocalCDN/src/branch/main/core/mappings.js) [![Frameworks](https://www.localcdn.org/badges/frameworks.svg)](https://codeberg.org/nobody/LocalCDN/src/branch/main/resources/) [![Firefox Add-on](https://www.localcdn.org/badges/amo-version.svg)](https://addons.mozilla.org/en-US/firefox/addon/localcdn-fork-of-decentraleyes/) [![Chrome Add-on](https://www.localcdn.org/badges/chrome-version.svg)](https://chrome.google.com/webstore/detail/localcdn/njdfdhgcmkocbgbhcioffdbicglldapd/) [![Buy Me a Coffee](https://www.localcdn.org/badges/buymeacoffee.svg)](https://www.buymeacoffee.com/LocalCDN) [![opencollective](https://www.localcdn.org/badges/opencollective.svg)](https://opencollective.com/LocalCDN) 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](https://www.localcdn.org/test/) to find out if you are properly protected. For more information, please read the [tutorial](https://www.localcdn.org/tutorial) or the [Wiki](https://codeberg.org/nobody/LocalCDN/wiki). You can also [download](https://addons.mozilla.org/en-US/firefox/addon/localcdn-fork-of-decentraleyes/) 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](https://codeberg.org/nobody/LocalCDN/src/branch/main/core/mappings.js#L71) that lists the source (all CDNs and the path to the frameworks) and a [resource file](https://codeberg.org/nobody/LocalCDN/src/branch/main/core/resources.js#L328) 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](https://codeberg.org/nobody/LocalCDN/src/branch/main/resources/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](screenshots/replacement_html_filter_off.png) #### LocalCDN with activated HTML filter (optional) [LocalCDN with activated HTML filter (optional)](screenshots/replacement_html_filter_on.png) #### Other CDN emulators [Other CDN emulators](screenshots/replacement_other_cdn_emulators.png) #### :warning: **Important** :warning: 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](https://codeberg.org/nobody/LocalCDN/wiki/Home#user-content-7-a-website-looks-weird-or-cannot-be-used-if-i-deactivate-localcdn-everything-works-what-is-the-problem) before opening an issue. [Here](https://www.localcdn.org/test/check) 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](screenshots/screenshot_light.png) #### Dark [Dark Theme](screenshots/screenshot_dark.png) #### Rule generator for uBlock Origin, uMatrix and AdGuard (after an update) [Rule generator after an update](screenshots/screenshot_after_update.png) #### Settings [Settings (Basic)](screenshots/screenshot_settings_1.png) [Settings (Advanced)](screenshots/screenshot_settings_2.png) [Settings (Other)](screenshots/screenshot_settings_3.png) [Settings (Info)](screenshots/screenshot_settings_4.png) #### Internal statistics [Internal statistics](screenshots/screenshot_statistics_light.png) [Internal statistics](screenshots/screenshot_statistics_dark.png) ## Contributing Code Suggestions in the form of **Issues**, and contributions in the form of **Merge/Pull Requests**, are highly welcome. ## Installation * Mozilla Firefox *(86 or higher)*: [get it on addons.mozilla.org](https://addons.mozilla.org/en-US/firefox/addon/localcdn-fork-of-decentraleyes/) * Firefox for Android: It's possible. Please read [here](https://codeberg.org/nobody/LocalCDN/wiki#user-content-13-can-i-use-localcdn-in-firefox-for-android-fenix). * Chromium based browser: [Chrome Web Store (by Emanuel Bennici)](https://chrome.google.com/webstore/detail/localcdn-fork-from-decent/njdfdhgcmkocbgbhcioffdbicglldapd) :warning: **Please note this Wiki article [FAQ: Chromium incompatibilities](https://codeberg.org/nobody/LocalCDN/wiki/Home#user-content-2-can-i-use-this-extension-in-my-chrome-browser)** :warning: #### Running the Code as temporary extension Please read this [guide](https://codeberg.org/nobody/LocalCDN/wiki/Home#user-content-5-you-recently-changed-something-in-the-code-and-i-would-like-to-test-it-how-do-you-do-that) 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](https://www.localcdn.org/contact/) (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](https://hosted.weblate.org/projects/localcdn/). ## 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](https://www.buymeacoffee.com/LocalCDN) [Open Collective](https://opencollective.com/LocalCDN) ## License [MPL-2.0](https://www.mozilla.org/MPL/2.0). #### External libraries * Color Picker (Taufik Nurrohman, https://github.com/taufik-nurrohman/color-picker, MIT License)