-
Notifications
You must be signed in to change notification settings - Fork 10.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Some PDFs trigger canvas fingerprinting warning false-positives #7026
Comments
To understand the issue we need to know algorithm for detecting of canvas fingerprinting. If it's just a generic CANVAS access there is nothing we can do. However if it's just access to some specific function such as getImageData or toDataURL then there might be change to fix that. We are using toDataURL to generate thumbs. I wonder if we can detect that and disable this optimization for tor. |
I got a brief response from the Tor devs, and it sounds like any attempt to peek at the contents of the canvas will trigger their check. I haven't had a chance to dig into the code yet, but they specifically mentioned I think, from my perspective, I'd prefer an option to simply disable the features (like thumbs) that can't be implemented without peeking into the canvas over some kind of detection scheme specifically for Tor. Obviously, that only works if those features can be isolated. I could imagine disabling happening as a compile-time option that entirely eliminates the code from the library or just a flag that disables it at the time the PDF gets loaded into the page. |
Some feature can be disabled, some would have affect on the PDF display. FWIW getImageData is not used during display of the PDF above, but there are PDFs that might trigger that. Workaround for thumbs can be their disabling for Tor browser or display them in non-optimal way. |
The detection function appears to be It gets called a few times in the canvas code. Looks like the canvas API calls that trigger the fingerprinting warning alert are:
|
Looks like https://github.com/mozilla/pdf.js/blob/master/src/display/canvas.js#L1381 |
@xcolour we can disable this check (it will affect the display quality for some old windows machines). Now we need to decide how we are going to detect if reading back from the canvas might trigger the issue. Has Tor any signs to detect it? |
Probably http://stackoverflow.com/a/28202492 |
This comment has been minimized.
This comment has been minimized.
Given that, as mentioned above in e.g. #7026 (comment), we cannot generally remove certain |
We have observed that some PDFs cause canvas fingerprinting (https://en.wikipedia.org/wiki/Canvas_fingerprinting) warnings to trigger in certain browsers. This issue seems to trigger specifically in image-heavy PDFs.
For example: https://www.aclu.org/foia-document/some-key-sso-cyber-milestone-dates-fall-2005.
We have seen warnings trigger in the most recent version of the Tor Browser Bundle (5.5.2) as well as with the Chrome extension Canvas Fingerprint Block (https://chrome.google.com/webstore/detail/canvasfingerprintblock/ipmjngkmngdcdpmgmiebdmfbkcecdndc).
This issue was noted a while back by the Tor project (https://trac.torproject.org/projects/tor/ticket/10570). They appear to have resolved it by whitelisting the locally-available version of PDF.js provided by Firefox, but that fix doesn't seem to apply to PDF.js when it's served by the website.
We use the PDF.js provided via the "PDF" Drupal extension version "7.x-1.6" with PDF.js version "1.1.215".
I understand that canvas fingerprinting is an intentionally obfuscated de-anonymization technique and that detection is necessarily heuristic. It may be that PDF.js is doing something that is legitimately indistinguishable from canvas fingerprinting, but it would be nice if there were a way to avoid tripping the detection algorithms. Some of our more privacy-conscious site visitors have noted that it's a bit creepy to be warned by your browser that you're being tracked while trying to read FOIA docs!
Thanks for reading and let me know if this is too open-ended for your issue tracker. I'll be happy to re-submit to your dev mailing list.
I've opened a parallel ticket for the Tor Browser team: https://trac.torproject.org/projects/tor/ticket/18390#ticket.
The text was updated successfully, but these errors were encountered: