mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-18 17:38:46 +01:00
91b7dcbb11
Fixes #628
66 lines
3.2 KiB
Markdown
66 lines
3.2 KiB
Markdown
CanvasBlocker [![codebeat badge](https://codebeat.co/badges/0edd6c9f-250a-4f1e-9c64-0958741522af)](https://codebeat.co/projects/github-com-kkapsner-canvasblocker-master)
|
|
=====
|
|
|
|
This add-on allows users to prevent websites from using some Javascript APIs to fingerprint them. Users can choose to block the APIs entirely on some or all websites (which may break some websites) or just block or fake its fingerprinting-friendly readout API.
|
|
|
|
**IMPORTANT**: you should only have ONE addon/setting set that protects an API. Otherwise you could face massive performance issues. (E.g. EclipsedMoon for Palemoon has 'canvas.poison' which is known to cause issues: https://github.com/kkapsner/CanvasBlocker/issues/253#issuecomment-459499290)
|
|
But setting privacy.resistFingerprinting to true and/or using the new fingerprinting protection introduced with Firefox 67 is fine.
|
|
|
|
-----
|
|
|
|
Protected "fingerprinting" APIs:
|
|
* canvas 2d
|
|
* webGL
|
|
* audio
|
|
* history
|
|
* window (disabled by default)
|
|
* DOMRect
|
|
* SVG
|
|
* TextMetrics
|
|
* navigator (disabled by default)
|
|
* screen
|
|
|
|
More information on fingerprinting can be found at:
|
|
* <canvas>: https://www.browserleaks.com/canvas
|
|
* audio:
|
|
* https://audiofingerprint.openwpm.com/ (very poorly written = slow)
|
|
* https://webtransparency.cs.princeton.edu/webcensus/#audio-fp
|
|
* DOMRect:
|
|
* http://jcarlosnorte.com/security/2016/03/06/advanced-tor-browser-fingerprinting.html
|
|
* https://browserleaks.com/rects
|
|
* https://github.com/ghacksuserjs/ghacks-user.js/wiki/Appendix-A---Test-Sites
|
|
|
|
-----
|
|
|
|
Beta versions can be found at https://canvasblocker.kkapsner.de/versions/.
|
|
|
|
-----
|
|
|
|
The different block modes are:
|
|
* fake: Canvas Blocker's default setting, and my favorite! All websites not on the white list or black list can use the protected APIs. But values obtained by the APIs are altered so that a consistent fingerprinting is not possible
|
|
* ask for permission: If a website is not listed on the white list or black list, the user will be asked if the website should be allowed to use the protected APIs each time they are called.
|
|
* block everything: Ignore all lists and block the protected APIs on all websites.
|
|
* allow only white list: Only websites in the white list are allowed to use the protected APIs.
|
|
* block only black list: Block the protected APIs only for websites on the black list.
|
|
* allow everything: Ignore all lists and allow the protected APIs on all websites.
|
|
|
|
-----
|
|
|
|
You can contribute to CanvasBlocker by translating it and/or improving the translations. For further instructions go to https://github.com/kkapsner/CanvasBlocker/issues/420.
|
|
|
|
Special thanks to:
|
|
* spodermenpls for finding all the typos
|
|
* Thorin-Oakenpants for the icon idea
|
|
* anthologist and unbranched for the Italian translation
|
|
* Maleficient for the French translation
|
|
* yfdyh000 and KrasnayaPloshchad for the Chinese translation
|
|
* micrococo for the Spanish translation
|
|
* STim99 for the Russian translation
|
|
|
|
-----
|
|
|
|
If you want to support this addon you can donate to the following addresses:
|
|
* bitcoin: 159Y9BLcfHyrp6wj6f3syEuk92xkRVTiie
|
|
* bitcoin cash:qrchnszkdwv9knhg9wjucrqy43rpl4klkq7jhkc8dz
|
|
* monero: 482QYZaagALWtPmwbptwBaexDYmcVsJrhJp2VVjTgjYA3Kk1YyMdSg9Wz2qz1Gh31E843PFVCDWS4hR4Bjf6ipWuB9iz2cs
|