Help

Introduction

LocalCDN is a web browser extension that emulates Content Delivery Networks to improve your online privacy. It intercepts traffic, finds supported frameworks/libraries locally, and injects them into the website. Feel free to use the following testing utility to find out if you are properly protected. For more information read the tutorial or our Wiki pages.

What is "HTML filter"? (Firefox only)

In most cases LocalCDN can easily replace embedded frameworks and improves privacy. In some cases the website may try to prevent this by setting certain options in the HTML source code. LocalCDN reads the HTML source code before it is displayed in the browser and removes these options.

Why is it necessary to remove crossorigin and integrity attributes?

The crossorigin attribute prevents the replacement because the source is no longer cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.js but moz-extension://UUID/resources/jquery/1.12.4. crossorigin forces the browser to ignore other sources.

To save disk space and to deliver more frameworks LocalCDN upgrades a framework. An integrity tag is the hash value of a file. If the check fails, the browser won't include a framework. The integrity check will fail because the hash values for e.g. jQuery 1.10.1 and jQuery 1.12.4 are different.

Unfortunately, it sometimes happens that special characters are then displayed incorrectly. In this case you can deactivate the setting again, to display the umlauts correctly.

Some websites look strange or are not easy to use

There are two possible reasons: Either a framework/library is required that LocalCDN doesn't (yet) deliver or an SOP.

A SOP (Same origin policy) is a security mechanism that determines what data the browser is allowed to load. It helps to isolate malicious documents and thus reduce possible attack vectors. This policy prevents the browser from loading the external frameworks of LocalCDN.

If the layout of a website is incorrect or cannot be used, then it is usually due to this policy, even though the add-on works flawlessly. Unfortunately there is no solution for this at the moment.

Why is there a "Block Google Fonts" option?

LocalCDN can replace "Google Material Icons". To catch the connection your adblocker (e.g. uBlock Origin, uMatrix or AdGuard) must allow the request. LocalCDN listens on these requests and if the query contains "Google Material Icons", the resource will be replaced. If you uncheck the "Block requests for missing content" option, non-existent resources will be allowed to pass and "Google Fonts" will be loaded, because "Google Material Icons" and "Google Fonts" use the same domain. If you don't want this, you can block "Google Fonts" on LocalCDN.

What about the statistics? Is anything transferred to any servers?

Don't panic, nothing will be transmitted. It would be against all my principles. The statistics (JSON format) contains the following information: Date, CDN+counter and framework+counter. That's all. I've an example here:

"2020-08-10": {
    "frameworks": {
        "resources/jquery/1.12.4/jquery.min.jsm": 5
    },
    "cdns": {
        "ajax.googleapis.com": 5
    }
}

The statistics contain no information about the browser, operating system, requesting website, IP addresses or any other information. Just date, CDN+counter and framework+counter. It shows you which frameworks are replaced by LocalCDNs how often and which CDNs were requested.

How do I know that's true?

The extension storage can be viewed directly with the Firefox browser. Open the URL "about:debugging", switch to "Storage" and select "Extension Storage". Under the key "internalStatisticsData" you will find the collected data. Just copy it and put it into a JSON PrettyPrinter to make it more readable. Please note that you have to remove the first and last quotation mark and the key to it. You should be able to see this clearly in this video.

What will be synchronized when I select "sync" as storage type?

Sync will only work if you are logged in with a Firefox account on the device and have allowed add-ons to sync in the settings. A separate sync server under your control will also work. This will synchronize most of the settings of LocalCDN across all devices.

If you don't have a sync account, nothing will be synchronized. In that case it makes no difference what type of storage you have selected.

Things that are never synchronized:

  • Amount injected (Numbers of injections)
  • Internal statistics (Yes, No)
  • Internal statistics (Data)

Settings that will be synchronized:

  • Display injection counts on icon (Yes, No)
  • Disable release notes (Yes, No)
  • Disable link prefetching (Yes, No)
  • Strip metadata from allowed requests (Yes, No)
  • Deactivate LocalCDN for these domains (Yes, No, URLs)
  • Block requests for missing resources (Yes, No)
  • Block Google Fonts (Yes, No, URLs)
  • Enable logging in browser console (Yes, No)
  • Apply HTML filter for these domains (Yes, No, URLs)
  • Invert HTML filter (Yes, No)
  • Choose an icon for this extension (Default, Light, Blue/Grey)

More information about Firefox Sync: