Pier Angelo Vendrame pushed to branch base-browser-115.9.1esr-13.0-1 at The Tor Project / Applications / Tor Browser
Commits:
- 
5c690113
by Pier Angelo Vendrame at 2024-04-08T12:51:54+02:00
- 
d1e8e6ba
by Pier Angelo Vendrame at 2024-04-08T12:51:55+02:00
- 
a975b00f
by Pier Angelo Vendrame at 2024-04-08T12:51:56+02:00
3 changed files:
Changes:
| ... | ... | @@ -397,6 +397,9 @@ pref("browser.display.use_system_colors", false); | 
| 397 | 397 |  // Enforce non-native widget theme (true by default, defense in depth).
 | 
| 398 | 398 |  // Provides a uniform look and feel across platforms. Added with tor-browser#41496.
 | 
| 399 | 399 |  pref("widget.non-native-theme.enabled", true);
 | 
| 400 | +// tor-browser#41676: Set the TZ environment variable as a defense-in-depth.
 | |
| 401 | +// TODO: Remove this in ESR-128, as it has been removed in 116 with Bug 1837582.
 | |
| 402 | +pref("privacy.resistFingerprinting.testing.setTZtoUTC", true);
 | |
| 400 | 403 | |
| 401 | 404 |  // tor-browser#41943: lock and revisit after it gets flipped to true in stable Firefox
 | 
| 402 | 405 |  pref("javascript.options.spectre.disable_for_isolated_content", false, locked);
 | 
| ... | ... | @@ -4103,10 +4103,11 @@ void Document::SetDocumentURI(nsIURI* aURI) { | 
| 4103 | 4103 |    }
 | 
| 4104 | 4104 |  }
 | 
| 4105 | 4105 | |
| 4106 | -static void GetFormattedTimeString(PRTime aTime,
 | |
| 4106 | +static void GetFormattedTimeString(PRTime aTime, bool aUniversal,
 | |
| 4107 | 4107 |                                     nsAString& aFormattedTimeString) {
 | 
| 4108 | 4108 |    PRExplodedTime prtime;
 | 
| 4109 | -  PR_ExplodeTime(aTime, PR_LocalTimeParameters, &prtime);
 | |
| 4109 | +  PR_ExplodeTime(aTime, aUniversal ? PR_GMTParameters : PR_LocalTimeParameters,
 | |
| 4110 | +                 &prtime);
 | |
| 4110 | 4111 |    // "MM/DD/YYYY hh:mm:ss"
 | 
| 4111 | 4112 |    char formatedTime[24];
 | 
| 4112 | 4113 |    if (SprintfLiteral(formatedTime, "%02d/%02d/%04d %02d:%02d:%02d",
 | 
| ... | ... | @@ -4124,7 +4125,9 @@ void Document::GetLastModified(nsAString& aLastModified) const { | 
| 4124 | 4125 |    if (!mLastModified.IsEmpty()) {
 | 
| 4125 | 4126 |      aLastModified.Assign(mLastModified);
 | 
| 4126 | 4127 |    } else {
 | 
| 4127 | -    GetFormattedTimeString(PR_Now(), aLastModified);
 | |
| 4128 | +    GetFormattedTimeString(PR_Now(),
 | |
| 4129 | +                           ShouldResistFingerprinting(RFPTarget::Unknown),
 | |
| 4130 | +                           aLastModified);
 | |
| 4128 | 4131 |    }
 | 
| 4129 | 4132 |  }
 | 
| 4130 | 4133 | |
| ... | ... | @@ -11053,7 +11056,8 @@ void Document::RetrieveRelevantHeaders(nsIChannel* aChannel) { | 
| 11053 | 11056 | |
| 11054 | 11057 |    mLastModified.Truncate();
 | 
| 11055 | 11058 |    if (modDate != 0) {
 | 
| 11056 | -    GetFormattedTimeString(modDate, mLastModified);
 | |
| 11059 | +    GetFormattedTimeString(
 | |
| 11060 | +        modDate, ShouldResistFingerprinting(RFPTarget::Unknown), mLastModified);
 | |
| 11057 | 11061 |    }
 | 
| 11058 | 11062 |  }
 | 
| 11059 | 11063 | 
| ... | ... | @@ -591,7 +591,14 @@ nsresult txEXSLTFunctionCall::evaluate(txIEvalContext* aContext, | 
| 591 | 591 |        // http://exslt.org/date/functions/date-time/
 | 
| 592 | 592 | |
| 593 | 593 |        PRExplodedTime prtime;
 | 
| 594 | -      PR_ExplodeTime(PR_Now(), PR_LocalTimeParameters, &prtime);
 | |
| 594 | +      PR_ExplodeTime(
 | |
| 595 | +          PR_Now(),
 | |
| 596 | +          // We are not allowed to access the Document when evaluating this, so
 | |
| 597 | +          // fall back to the general function.
 | |
| 598 | +          nsContentUtils::ShouldResistFingerprinting(RFPTarget::Unknown)
 | |
| 599 | +              ? PR_GMTParameters
 | |
| 600 | +              : PR_LocalTimeParameters,
 | |
| 601 | +          &prtime);
 | |
| 595 | 602 | |
| 596 | 603 |        int32_t offset =
 | 
| 597 | 604 |            (prtime.tm_params.tp_gmt_offset + prtime.tm_params.tp_dst_offset) /
 |