If we do want to hide the preferences, we should maybe one-off reset the preference values for privacy.globalprivacycontrol.enabled and privacy.donottrackheader.enabled. These technically existed in ESR 115, so we would be hiding the means for a user to return to our default.
They only matter if we move to a persistent mode. In FF both are enforced in PB Mode. But in TB DNT is not enabled in PB Mode since we do not use ETP (I think this is the cause now, but I also think in the past it was with a patch - we should check that, and by we I mean Pier).
Personally I think we should lock anything we want in stable, as long as the UI is taken care of first - and we still need to make about config warning interstitial sticky and scary
I think removing the UI would be enough.
Locks should be reserved to preferences that are real footguns (this one doesn't seem to be: toggling the default will be fingerprintable, but I guess the default shouldn't be a big deal to anyone).
We still have some time before 14.0a1 gets built, I think we could do it immediately, not to think about migrations (theoretically, when we hide UI elements we should also migrate to the new default).
I guess I said this because if users don't gain anything from switching a pref (and in this case will actually make them more fingerprintable), then we might as well lock it, but it's a weak opinion not grounded on any maintenance reality or existing policy.
privacy.globalprivacycontrol.enabled (which is the normal window control since we use privacy.globalprivacycontrol.pbmode.enabled = true) is already false
privacy.donottrackheader.enabled is also already false (it's only enabled in ETP Strict by default) but I guess defense in depth, although TBH it's not an issue if it did change and everyone is still the same (besides the fact it's a useless header)?
Re-opening this. I realised that we need to make sure that privacy.globalprivacycontrol.enabled and privacy.globalprivacycontrol.pbmode.enabled have the same value. Otherwise non-private windows are fingerprintable using the request headers.
I would vote for setting privacy.globalprivacycontrol.enabled to true to keep it the same as the private browsing (majority) default.
non PB mode is not supported. non PB mode is already fingerprintable without this distinction (albeit this is passive) .. that said, and I will quote myself
You could consider making it also on in normal windows in prep for persistent mode
edit: just to clarify .. we should do this for FPing as well, as one day we will be able to blur the lines between PB vs all mode
also, we should try and be consistent moving forward with all these *pbmode prefs - where normally the non pbmode pref means all windows and overrides the pbmode setting
So I did a quick check in windows. RFP overrides pbmode, so we're good. All the rest except GPC are also fine (assuming ETP strict doesn't do something, but we don't use that)
so yup: make privacy.globalprivacycontrol.enabled = true