Source code

Revision control

Copy as Markdown

Other Tools

/* 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/. */
const lazy = {};
ChromeUtils.defineLazyGetter(lazy, "makeRange", () => {
const { ExtensionParent } = ChromeUtils.importESModule(
"resource://gre/modules/ExtensionParent.sys.mjs"
);
// Defined in ext-browsingData.js
return ExtensionParent.apiManager.global.makeRange;
});
ChromeUtils.defineESModuleGetters(lazy, {
Sanitizer: "resource:///modules/Sanitizer.sys.mjs",
});
export class BrowsingDataDelegate {
// Unused for now
constructor() {}
// This method returns undefined for all data types that are _not_ handled by
// this delegate.
handleRemoval(dataType, options) {
// TODO (Bug 1803799): Use Sanitizer.sanitize() instead of internal cleaners.
let o = { progress: {} };
switch (dataType) {
case "downloads":
return lazy.Sanitizer.items.downloads.clear(lazy.makeRange(options), o);
case "formData":
return lazy.Sanitizer.items.formdata.clear(lazy.makeRange(options), o);
case "history":
return lazy.Sanitizer.items.history.clear(lazy.makeRange(options), o);
default:
return undefined;
}
}
settings() {
const PREF_DOMAIN = "privacy.cpd.";
// The following prefs are the only ones in Firefox that match corresponding
// values used by Chrome when rerturning settings.
const PREF_LIST = ["cache", "cookies", "history", "formdata", "downloads"];
// since will be the start of what is returned by Sanitizer.getClearRange
// divided by 1000 to convert to ms.
// If Sanitizer.getClearRange returns undefined that means the range is
// currently "Everything", so we should set since to 0.
let clearRange = lazy.Sanitizer.getClearRange();
let since = clearRange ? clearRange[0] / 1000 : 0;
let options = { since };
let dataToRemove = {};
let dataRemovalPermitted = {};
for (let item of PREF_LIST) {
// The property formData needs a different case than the
// formdata preference.
const name = item === "formdata" ? "formData" : item;
// We assume the pref exists, and throw if it doesn't.
dataToRemove[name] = Services.prefs.getBoolPref(`${PREF_DOMAIN}${item}`);
// Firefox doesn't have the same concept of dataRemovalPermitted
// as Chrome, so it will always be true.
dataRemovalPermitted[name] = true;
}
return Promise.resolve({
options,
dataToRemove,
dataRemovalPermitted,
});
}
}