-
Notifications
You must be signed in to change notification settings - Fork 526
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
FYI: 2510: webaudio #1194
Comments
Firefox 89.0.1 (64-bit) Linux Debian offlineAudioContext AudioContext All differs from Windows except OscillatorNode on AudioContext |
Thanks.
|
FWIW: Same results with Firefox 89.0; 64-bit; Fedora 34; glibc 2.33 |
@rusty-snake : do you mean same results as I listed in OP? I was going to say something about 2glop's debian result, as the math entropy shows Fedora and Debian to be the same [1]. But I pinky swear from memory that I've been given a Fedora audio result before that matched Windows (at least on offlineAudio and keys) .. but since I can't find it, I thought I would just shut up and wait til I get some recorded data - so that just makes me wonder what else if anything can touch the result (e.g. like chromium) [1] code FF30: Linux 64bit: Debian (Buster) Fedora (v32), Manjaro (20.1), MX Linux: all FF80+ |
Same as @2glops |
Ahh OK. That makes more sense. It's equivalency already leaked in math |
FYI: also for #1216 paper: A Study of Feasibility and Diversity of Web Audio Fingerprints Looking at section C: Breakdown of Audio FPs by user agents, I count the following for Firefox So the bottom four items are "new" methods they tested which overall looks increased entropy. TBH, I thought android would yield a lot more. So that's about it. The TZP test is basically the one used in the wild by most scripts, based on OpenWMP. FWIW it's not as sophisticated as it could be, and I've even seen a win/linux match which is either a missed result, or simply not defined enough - edit: that is the The good news is that webaudio FPing may soon be resolved with RFP, fingers crossed. Until then looks like (not sure what they are all combined) windows is potentially the worst at 6 results (5 win and 1 win/mac), mac at 3 or 4, linux at 3, and android at 2. |
The above paper's entropy for Firefox is solely for user-gesture-required I contacted the authors, and got their test code and data. Their test also collected the // android
// 2 results
35.7499681673944
// windows
// 20 results: NT 6.1/6.2/6.3/10.0; v68-88"
35.7383295930922
// mac
// 7 results: 10.10, 10.11, 10.12, 10.13, 10.15; v78-88
35.7383295930922 <- same as windows
// 1 result: 11.2; v86
35.73833039775491
// 1 result: hybrid values whatever that means mac 10.15; v87
35.73833039775491 <-- same as other mac value
35.7383295930922 <-- same as windows
// linux
// 3 results: ubuntu v72-88"
35.73833402246237
// 1 result: ubuntu v77"
35.74996018782258 in other words: 5 buckets (although linux and android tests are a bit sparse to say the least), and mostly OS equivalency
|
This is just so I can outline my reasons for moving
25182510 to RFP alts and making it inactive within that sectionwebaudio results within Firefox, AFAICT, are very low, if they exist at all on desktop
There are essentially two parts: one that does not require user gestures (offlineAudioContext), and one that does (AudioContext). But given that it's not exactly hard to elicit a user gesture, we could probably ignore that distinction except to say that scripts don't like to hang around waiting for user gestures IMO and be dependent on them
🔻 offlineAudioContext
takes a wave (sine, triangle) at volume zero, at a set frequency and other variables and fingerprints it. This explains it nicely
What causes entropy here is supposed to only be math libraries used and floating points. It is not supposed to touch the hardware. The webaudio API uses a limited set of math functions with a limited range. Any entropy here is almost certainly already present elsewhere (math)
I say supposed to, but it has been shown that chromium browsers results are affected by the CPU (or something), despite using the same method, calculations, math libraries etc across all platforms.
I've personally seen the fingerprint change after a kernel update on android (that's my android10 results above). In testing math entropy, I (and others) can't seem to find any in chromium
Firefox and chromium implement webaudio different math libraries and how they calculate things: e.g.
final_playback_rate *= fdlibm::pow(2, detune_->FinalValue() / 1200);
float computedPlaybackRate = aPlaybackRate * exp2(aDetune / 1200.f);
chromium even includes a test in-tree for checking that the webAudio fingerprint matches a hardcoded one
On the flip side
This is practically the reverse of what chromium shows. Chromium seems to be affected by hardware, but FF isn't: but chromium has no math entropy, while FF does.
Anyway, the fact remains that FF entropy from webaudio seems unlikely for desktop, and if it does exist it will be a very few possible results (not that each result has equal users). A disabled webaudio API is going to be much more fingerprintable than not disabling it
🔻 AudioContext
This has two aspects: one is keys, the other is computational, and relies on some reported key values AFAIK. RFP covers at least two of these keys:
ac-outputLatency
is calculated per OS, andac-sampleRate
is returned as44100
Much less data to go on from my perspective, but with RFP enabled, I haven't seen any different values aside from the RFP ones across platforms, and not in the computation hashes.
Note: Android (without RFP) is wonky: 1612093 and returns different values on each run .. but we don't care about android parity here
🔻 real-world study
title: Who Touched My Browser Fingerprint?: A Large-scale Measurement Study and Classification of Fingerprint Dynamics
url: https://dl.acm.org/doi/10.1145/3419394.3423614
pdf: https://yinzhicao.org/fpmeasurement/imc20.pdf
interesting static values' distinct groups
115k
41k
2k
1.2k
114
<-- (23 of those were unique)AFAICT, that audio test is about audioContext keys, if you read the paper. The point is that audio is one of the lowest entropy items around, and that's not even when you factor in the browser and OS (which you can't hide)
🔻 tl;dr
Generally speaking, we value security over privacy/tracking over fingerprinting. But even from a FPing perspective, disabling the API is going to be much worse: e.g. out of 200+mn desktop users, how many would disable webaudio? A tiny percentage of less than 1% is my educated guess. Not to be confused with Tor Browser, which can do what it likes for an enforced set of users.
Also, keep in mind that RFP randomized canvas (which almost all FP scripts use), and that most scripts are (for now) naive, and thus swallow that random poison pill. Arkenfox doesn't claim to defeat advanced scripts, but an enabled webaudio is going to be less identifying than a disabled one.
There is also the usability factor, of one less item to flip or troubleshoot
🔻 FYI
test: https://arkenfox.github.io/TZP/tzp.html#audio
note: I'm going to totally destroy that test and replace it, so don't get too attached to it
The fingerprint, with RFP on is as follows. offlineAudioContext should be the same across platforms AFAICT, but AudioContext may differ per platform (which is just equivalency since you cannot hide your OS, not entropy)
windows
feel free to post you results and OS info, especially if they differ
The text was updated successfully, but these errors were encountered: