196 lines
7.9 KiB
C++
196 lines
7.9 KiB
C++
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
#ifndef mozilla_BounceTrackingProtection_h__
|
|
#define mozilla_BounceTrackingProtection_h__
|
|
|
|
#include "BounceTrackingMapEntry.h"
|
|
#include "BounceTrackingStorageObserver.h"
|
|
#include "mozilla/Logging.h"
|
|
#include "mozilla/MozPromise.h"
|
|
#include "nsIBounceTrackingProtection.h"
|
|
#include "nsIBTPRemoteExceptionList.h"
|
|
#include "mozilla/Maybe.h"
|
|
#include "nsIObserver.h"
|
|
#include "nsWeakReference.h"
|
|
#include "nsTHashSet.h"
|
|
|
|
class nsIPrincipal;
|
|
class nsITimer;
|
|
|
|
namespace mozilla {
|
|
|
|
class BounceTrackingAllowList;
|
|
class BounceTrackingState;
|
|
class BounceTrackingStateGlobal;
|
|
class BounceTrackingProtectionStorage;
|
|
class ClearDataCallback;
|
|
class OriginAttributes;
|
|
|
|
namespace dom {
|
|
class CanonicalBrowsingContext;
|
|
class WindowContext;
|
|
class WindowGlobalParent;
|
|
} // namespace dom
|
|
|
|
using ClearDataMozPromise =
|
|
MozPromise<RefPtr<BounceTrackingPurgeEntry>, uint32_t, true>;
|
|
|
|
extern LazyLogModule gBounceTrackingProtectionLog;
|
|
|
|
class BounceTrackingProtection final : public nsIBounceTrackingProtection,
|
|
public nsIObserver,
|
|
public nsSupportsWeakReference {
|
|
NS_DECL_ISUPPORTS
|
|
NS_DECL_NSIOBSERVER
|
|
NS_DECL_NSIBOUNCETRACKINGPROTECTION
|
|
|
|
public:
|
|
static already_AddRefed<BounceTrackingProtection> GetSingleton();
|
|
|
|
// Record telemetry about which mode the feature is in.
|
|
static void RecordModePrefTelemetry();
|
|
|
|
// This algorithm is called when detecting the end of an extended navigation.
|
|
// This could happen if a user-initiated navigation is detected in process
|
|
// navigation start for bounce tracking, or if the client bounce detection
|
|
// timer expires after process response received for bounce tracking without
|
|
// observing a client redirect.
|
|
[[nodiscard]] nsresult RecordStatefulBounces(
|
|
BounceTrackingState* aBounceTrackingState);
|
|
|
|
// Stores a user activation flag with a timestamp for the given principal. The
|
|
// timestamp defaults to the current time, but can be overridden via
|
|
// aActivationTime. If aWindowContext is provided, this will add the
|
|
// given principal's activation to the extended navigation's
|
|
// BounceTrackingRecord as well.
|
|
// Parent process only. Prefer the WindowContext variant if possible.
|
|
[[nodiscard]] static nsresult RecordUserActivation(
|
|
nsIPrincipal* aPrincipal, Maybe<PRTime> aActivationTime = Nothing(),
|
|
dom::CanonicalBrowsingContext* aTopBrowsingContext = nullptr);
|
|
|
|
// Same as above but can be called from any process given a WindowContext.
|
|
// Gecko callers should prefer this method because it takes care of IPC and
|
|
// gets the principal user activation. IPC messages from the content to parent
|
|
// passing a principal should be avoided for security reasons. aActivationTime
|
|
// defaults to PR_Now().
|
|
[[nodiscard]] static nsresult RecordUserActivation(
|
|
dom::WindowContext* aWindowContext);
|
|
|
|
// Clears expired user interaction flags for the given state global. If
|
|
// aStateGlobal == nullptr, clears expired user interaction flags for all
|
|
// state globals.
|
|
[[nodiscard]] nsresult ClearExpiredUserInteractions(
|
|
BounceTrackingStateGlobal* aStateGlobal = nullptr);
|
|
|
|
// Logs a warning to the DevTools website console if we recently purged a site
|
|
// matching the given principal. Purge log data is not persisted across
|
|
// restarts so we only know whether a purge happened during this session. For
|
|
// private browsing mode closing the last private browsing window clears purge
|
|
// information.
|
|
void MaybeLogPurgedWarningForSite(nsIPrincipal* aPrincipal,
|
|
BounceTrackingState* aBounceTrackingState);
|
|
|
|
private:
|
|
BounceTrackingProtection() = default;
|
|
~BounceTrackingProtection() = default;
|
|
|
|
// Initializes the singleton instance of BounceTrackingProtection.
|
|
[[nodiscard]] nsresult Init();
|
|
|
|
// Listens for feature pref changes and enables / disables BTP.
|
|
static void OnPrefChange(const char* aPref, void* aData);
|
|
|
|
// Called by OnPrefChange when the mode pref changes.
|
|
// isStartup indicates whether this is the initial mode change after startup.
|
|
nsresult OnModeChange(bool aIsStartup);
|
|
|
|
// Schedules or cancels the periodic bounce tracker purging. If this method is
|
|
// called while purging is already scheduled it will cancel the existing timer
|
|
// and then start a new timer.
|
|
nsresult UpdateBounceTrackingPurgeTimer(bool aShouldEnable);
|
|
|
|
// Flag to ensure we only call into glean telemetry when the feature mode
|
|
// actually changed.
|
|
static Maybe<uint32_t> sLastRecordedModeTelemetry;
|
|
|
|
// Timer which periodically runs PurgeBounceTrackers.
|
|
nsCOMPtr<nsITimer> mBounceTrackingPurgeTimer;
|
|
|
|
// Used to notify BounceTrackingState of storage and cookie access.
|
|
RefPtr<BounceTrackingStorageObserver> mStorageObserver;
|
|
|
|
// Storage for user agent globals.
|
|
RefPtr<BounceTrackingProtectionStorage> mStorage;
|
|
|
|
// Interface to remote settings exception list.
|
|
nsCOMPtr<nsIBTPRemoteExceptionList> mRemoteExceptionList;
|
|
RefPtr<GenericNonExclusivePromise> mRemoteExceptionListInitPromise;
|
|
|
|
// In-memory copy of the remote settings exception list.
|
|
nsTHashSet<nsCStringHashKey> mRemoteSiteHostExceptions;
|
|
|
|
// Lazily initializes the remote exception list.
|
|
RefPtr<GenericNonExclusivePromise> EnsureRemoteExceptionListService();
|
|
|
|
// Clear state for classified bounce trackers. To be called on an interval.
|
|
using PurgeBounceTrackersMozPromise =
|
|
MozPromise<nsTArray<RefPtr<BounceTrackingPurgeEntry>>, nsresult, true>;
|
|
RefPtr<PurgeBounceTrackersMozPromise> PurgeBounceTrackers();
|
|
|
|
// Report purged trackers to the anti-tracking database via
|
|
// nsITrackingDBService.
|
|
static void ReportPurgedTrackersToAntiTrackingDB(
|
|
const nsTArray<RefPtr<BounceTrackingPurgeEntry>>& aPurgedSiteHosts);
|
|
|
|
// Clear state for classified bounce trackers for a specific state global.
|
|
// aClearPromises is populated with promises for each host that is cleared.
|
|
[[nodiscard]] nsresult PurgeBounceTrackersForStateGlobal(
|
|
BounceTrackingStateGlobal* aStateGlobal,
|
|
BounceTrackingAllowList& aBounceTrackingAllowList,
|
|
nsTArray<RefPtr<ClearDataMozPromise>>& aClearPromises);
|
|
|
|
// Helper which calls nsIClearDataService to clear data for given host and
|
|
// OriginAttributes.
|
|
// After a successful call aClearPromise will be populated.
|
|
[[nodiscard]] nsresult PurgeStateForHostAndOriginAttributes(
|
|
const nsACString& aHost, PRTime bounceTime,
|
|
const OriginAttributes& aOriginAttributes,
|
|
ClearDataMozPromise** aClearPromise);
|
|
|
|
// Whether a purge operation is currently in progress. This avoids running
|
|
// multiple purge operations at the same time.
|
|
bool mPurgeInProgress = false;
|
|
|
|
// Imports user activation permissions from permission manager if needed. This
|
|
// is important so we don't purge data for sites the user has interacted with
|
|
// before the feature was enabled.
|
|
[[nodiscard]] nsresult MaybeMigrateUserInteractionPermissions();
|
|
|
|
// Log a warning about the classification of a site as a bounce tracker. The
|
|
// message is logged to the devtools console aBounceTrackingState is
|
|
// associated with.
|
|
[[nodiscard]] static nsresult LogBounceTrackersClassifiedToWebConsole(
|
|
BounceTrackingState* aBounceTrackingState,
|
|
const nsTArray<nsCString>& aSiteHosts);
|
|
|
|
// Comparator for sorting purge log entries by purge timestamp.
|
|
class PurgeEntryTimeComparator {
|
|
public:
|
|
bool Equals(const BounceTrackingPurgeEntry* a,
|
|
const BounceTrackingPurgeEntry* b) const {
|
|
MOZ_ASSERT(a && b);
|
|
return a->PurgeTimeRefConst() == b->PurgeTimeRefConst();
|
|
}
|
|
|
|
bool LessThan(const BounceTrackingPurgeEntry* a,
|
|
const BounceTrackingPurgeEntry* b) const {
|
|
MOZ_ASSERT(a && b);
|
|
return a->PurgeTimeRefConst() < b->PurgeTimeRefConst();
|
|
}
|
|
};
|
|
};
|
|
|
|
} // namespace mozilla
|
|
|
|
#endif
|