2023-10-17 14:12:26 +02:00
|
|
|
{ config
|
|
|
|
, lib
|
|
|
|
, pkgs
|
|
|
|
, ...
|
2023-10-05 17:45:31 +02:00
|
|
|
}: {
|
|
|
|
programs.firefox = {
|
|
|
|
enable = true;
|
2024-02-02 16:13:55 +01:00
|
|
|
package = pkgs.firefox;
|
2023-10-05 17:45:31 +02:00
|
|
|
|
|
|
|
profiles = {
|
|
|
|
default = {
|
|
|
|
isDefault = true;
|
|
|
|
|
|
|
|
settings = {
|
2024-03-25 18:21:09 +01:00
|
|
|
# Disable internal passwod manager
|
|
|
|
"signon.rememberSignons" = false;
|
2023-10-05 17:45:31 +02:00
|
|
|
# Extensions are managed with Nix, so don't update.
|
|
|
|
"extensions.update.autoUpdateDefault" = false;
|
|
|
|
"extensions.update.enabled" = false;
|
|
|
|
|
2024-03-25 18:21:09 +01:00
|
|
|
# Default to dark theme in DevTools panel
|
|
|
|
"devtools.theme" = "dark";
|
|
|
|
|
|
|
|
# Reduce search engine noise in the urlbar's completion window. The
|
|
|
|
# shortcuts and suggestions will still work, but Firefox won't clutter
|
|
|
|
# its UI with reminders that they exist.
|
|
|
|
"browser.urlbar.suggest.searches" = true; # Let's hope duckduckgo doesn't sell it all :)
|
|
|
|
"browser.urlbar.shortcuts.bookmarks" = false;
|
|
|
|
"browser.urlbar.shortcuts.history" = false;
|
|
|
|
"browser.urlbar.shortcuts.tabs" = false;
|
|
|
|
"browser.urlbar.showSearchSuggestionsFirst" = false;
|
|
|
|
"browser.urlbar.speculativeConnect.enabled" = false;
|
|
|
|
"browser.urlbar.suggest.quicksuggest.nonsponsored" = false;
|
|
|
|
"browser.urlbar.suggest.quicksuggest.sponsored" = false;
|
|
|
|
|
|
|
|
# Disable some not so useful functionality.
|
|
|
|
"browser.disableResetPrompt" = true; # "Looks like you haven't started Firefox in a while."
|
|
|
|
"browser.onboarding.enabled" = false; # "New to Firefox? Let's get started!" tour
|
|
|
|
"browser.aboutConfig.showWarning" = false; # Warning when opening about:config
|
|
|
|
"extensions.pocket.enabled" = false;
|
|
|
|
"extensions.shield-recipe-client.enabled" = false;
|
|
|
|
|
2023-10-05 17:45:31 +02:00
|
|
|
# Sync
|
|
|
|
# "services.sync.username" = config.etu.user.email;
|
|
|
|
|
|
|
|
"services.sync.engine.addons" = false; # Do not sync extensions.
|
|
|
|
|
|
|
|
"general.autoScroll" = true; # Middle click to scroll
|
|
|
|
|
|
|
|
"browser.startup.page" = 3; # Restore previous windows and tabs.
|
|
|
|
|
2024-03-25 18:21:09 +01:00
|
|
|
# Security-oriented defaults
|
|
|
|
"security.family_safety.mode" = 0;
|
|
|
|
# https://blog.mozilla.org/security/2016/10/18/phasing-out-sha-1-on-the-public-web/
|
|
|
|
"security.pki.sha1_enforcement_level" = 1;
|
|
|
|
# https://github.com/tlswg/tls13-spec/issues/1001
|
|
|
|
"security.tls.enable_0rtt_data" = false;
|
|
|
|
# Use Mozilla geolocation service instead of Google if given permission
|
|
|
|
"geo.provider.network.url" = "https://location.services.mozilla.com/v1/geolocate?key=%MOZILLA_API_KEY%";
|
|
|
|
"geo.provider.use_gpsd" = false;
|
|
|
|
# https://support.mozilla.org/en-US/kb/extension-recommendations
|
|
|
|
"browser.newtabpage.activity-stream.asrouter.userprefs.cfr" = false;
|
|
|
|
"browser.newtabpage.activity-stream.asrouter.userprefs.cfr.addons" = false;
|
|
|
|
"browser.newtabpage.activity-stream.asrouter.userprefs.cfr.features" = false;
|
|
|
|
"extensions.htmlaboutaddons.recommendations.enabled" = false;
|
|
|
|
"extensions.htmlaboutaddons.discover.enabled" = false;
|
|
|
|
"extensions.htmlaboutaddons.inline-options.enabled" = false;
|
|
|
|
"extensions.getAddons.showPane" = false; # uses Google Analytics
|
|
|
|
"browser.discovery.enabled" = false;
|
|
|
|
|
2023-10-05 17:45:31 +02:00
|
|
|
# Privacy enhancements
|
|
|
|
"browser.newtabpage.activity-stream.feeds.telemetry" = false;
|
|
|
|
"browser.newtabpage.activity-stream.telemetry" = false;
|
|
|
|
"browser.newtabpage.activity-stream.feeds.snippets" = false;
|
|
|
|
"browser.newtabpage.activity-stream.feeds.section.topstories" = false;
|
|
|
|
"browser.newtabpage.activity-stream.section.highlights.includePocket" = false;
|
|
|
|
"browser.newtabpage.activity-stream.showSponsored" = false;
|
|
|
|
"browser.newtabpage.activity-stream.feeds.discoverystreamfeed" = false;
|
|
|
|
"browser.newtabpage.activity-stream.showSponsoredTopSites" = false;
|
|
|
|
|
|
|
|
# Improve performance
|
|
|
|
"gfx.webrender.all" = true;
|
|
|
|
|
2024-03-25 18:21:09 +01:00
|
|
|
# Enable ETP for decent security (makes firefox containers and many
|
|
|
|
# common security/privacy add-ons redundant).
|
|
|
|
"browser.contentblocking.category" = "strict";
|
|
|
|
"privacy.purge_trackers.enabled" = true;
|
2023-10-05 17:45:31 +02:00
|
|
|
# Do Not Track header
|
|
|
|
"privacy.donottrackheader.enabled" = true;
|
|
|
|
"privacy.donottrackheader.value" = 1;
|
2024-03-25 18:21:09 +01:00
|
|
|
# Your customized toolbar settings are stored in
|
|
|
|
# 'browser.uiCustomization.state'. This tells firefox to sync it between
|
|
|
|
# machines. WARNING: This may not work across OSes. Since I use NixOS on
|
|
|
|
# all the machines I use Firefox on, this is no concern to me.
|
|
|
|
"services.sync.prefs.sync.browser.uiCustomization.state" = true;
|
2023-10-05 17:45:31 +02:00
|
|
|
|
|
|
|
# Enable userChrome customisations
|
2024-03-25 18:21:09 +01:00
|
|
|
"toolkit.legacyUserProfileCustomizations.stylesheets" = true;
|
|
|
|
|
|
|
|
# Reduce File IO / SSD abuse
|
|
|
|
# Otherwise, Firefox bombards the HD with writes. Not so nice for SSDs.
|
|
|
|
# This forces it to write every 15 minutes, rather than 15 seconds.
|
|
|
|
"browser.sessionstore.interval" = "900000";
|
|
|
|
# Disable battery API
|
|
|
|
"dom.battery.enabled" = false;
|
|
|
|
# Disable "beacon" asynchronous HTTP transfers (used for analytics)
|
|
|
|
"beacon.enabled" = false;
|
|
|
|
# Disable pinging URIs specified in HTML <a> ping= attributes
|
|
|
|
"browser.send_pings" = false;
|
|
|
|
# Disable gamepad API to prevent USB device enumeration
|
|
|
|
"dom.gamepad.enabled" = false;
|
|
|
|
# Don't try to guess domain names when entering an invalid domain name in URL bar
|
|
|
|
"browser.fixup.alternate.enabled" = false;
|
|
|
|
|
|
|
|
# Disable telemetry
|
|
|
|
"toolkit.telemetry.unified" = false;
|
|
|
|
"toolkit.telemetry.enabled" = false;
|
|
|
|
"toolkit.telemetry.server" = "data:,";
|
|
|
|
"toolkit.telemetry.archive.enabled" = false;
|
|
|
|
"toolkit.telemetry.coverage.opt-out" = true;
|
|
|
|
"toolkit.coverage.opt-out" = true;
|
|
|
|
"toolkit.coverage.endpoint.base" = "";
|
|
|
|
"experiments.supported" = false;
|
|
|
|
"experiments.enabled" = false;
|
|
|
|
"experiments.manifest.uri" = "";
|
|
|
|
"browser.ping-centre.telemetry" = false;
|
|
|
|
# https://mozilla.github.io/normandy/
|
|
|
|
"app.normandy.enabled" = false;
|
|
|
|
"app.normandy.api_url" = "";
|
|
|
|
"app.shield.optoutstudies.enabled" = false;
|
|
|
|
# Disable health reports (basically more telemetry)
|
|
|
|
# https://support.mozilla.org/en-US/kb/firefox-health-report-understand-your-browser-perf
|
|
|
|
# https://gecko.readthedocs.org/en/latest/toolkit/components/telemetry/telemetry/preferences.html
|
|
|
|
"datareporting.healthreport.uploadEnabled" = false;
|
|
|
|
"datareporting.healthreport.service.enabled" = false;
|
|
|
|
"datareporting.policy.dataSubmissionEnabled" = false;
|
|
|
|
|
|
|
|
# Disable crash reports
|
|
|
|
"breakpad.reportURL" = "";
|
|
|
|
"browser.tabs.crashReporting.sendReport" = false;
|
|
|
|
"browser.crashReports.unsubmittedCheck.autoSubmit2" = false; # don't submit backlogged reports
|
|
|
|
|
|
|
|
# Disable Form autofill
|
|
|
|
# https://wiki.mozilla.org/Firefox/Features/Form_Autofill
|
|
|
|
"browser.formfill.enable" = false;
|
|
|
|
"extensions.formautofill.addresses.enabled" = false;
|
|
|
|
"extensions.formautofill.available" = "off";
|
|
|
|
"extensions.formautofill.creditCards.available" = false;
|
|
|
|
"extensions.formautofill.creditCards.enabled" = false;
|
|
|
|
"extensions.formautofill.heuristics.enabled" = false;
|
2023-10-05 17:45:31 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
extensions = with config.nur.repos.rycee.firefox-addons; [
|
|
|
|
bitwarden
|
|
|
|
clearurls
|
|
|
|
consent-o-matic
|
|
|
|
darkreader
|
2024-01-22 15:50:26 +01:00
|
|
|
dearrow
|
|
|
|
deutsch-de-language-pack
|
|
|
|
dictionary-german
|
2024-02-13 14:56:32 +01:00
|
|
|
flagfox
|
|
|
|
ipvfoo
|
|
|
|
leechblock-ng
|
2023-10-05 17:45:31 +02:00
|
|
|
localcdn
|
|
|
|
plasma-integration
|
|
|
|
privacy-badger
|
|
|
|
rust-search-extension
|
|
|
|
sidebery
|
|
|
|
skip-redirect
|
|
|
|
sponsorblock
|
|
|
|
tab-stash
|
|
|
|
ublock-origin
|
|
|
|
unpaywall
|
|
|
|
];
|
|
|
|
|
|
|
|
search = {
|
|
|
|
force = true;
|
|
|
|
default = "DuckDuckGo";
|
2023-10-17 14:12:26 +02:00
|
|
|
order = [ "DuckDuckGo" "Nix Packages" "Nix Options" "NixOS Wiki" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
|
|
|
|
engines = {
|
|
|
|
"DuckDuckGo".metaData = {
|
|
|
|
alias = "@ddg";
|
|
|
|
};
|
|
|
|
"Nix Packages" = {
|
|
|
|
urls = [
|
|
|
|
{
|
|
|
|
template = "https://search.nixos.org/packages";
|
|
|
|
params = [
|
|
|
|
{
|
|
|
|
name = "type";
|
|
|
|
value = "packages";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "query";
|
|
|
|
value = "{searchTerms}";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
icon = "/run/current-system/sw/share/icons/hicolor/scalable/apps/nix-snowflake.svg";
|
|
|
|
|
2023-10-17 14:12:26 +02:00
|
|
|
definedAliases = [ "@np" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
};
|
|
|
|
"Nix Options" = {
|
|
|
|
urls = [
|
|
|
|
{
|
|
|
|
template = "https://search.nixos.org/options";
|
|
|
|
params = [
|
|
|
|
{
|
|
|
|
name = "type";
|
|
|
|
value = "options";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "query";
|
|
|
|
value = "{searchTerms}";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
icon = "/run/current-system/sw/share/icons/hicolor/scalable/apps/nix-snowflake.svg";
|
|
|
|
|
2023-10-17 14:12:26 +02:00
|
|
|
definedAliases = [ "@no" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
};
|
|
|
|
"Home-Manager Options" = {
|
|
|
|
urls = [
|
|
|
|
{
|
|
|
|
template = "https://mipmip.github.io/home-manager-option-search";
|
|
|
|
params = [
|
|
|
|
{
|
|
|
|
name = "query";
|
|
|
|
value = "{searchTerms}";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
icon = "/run/current-system/sw/share/icons/hicolor/scalable/apps/nix-snowflake.svg";
|
|
|
|
|
2023-10-17 14:12:26 +02:00
|
|
|
definedAliases = [ "@ho" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
"NixOS Wiki" = {
|
|
|
|
urls = [
|
|
|
|
{
|
|
|
|
template = "https://nixos.wiki/index.php?search={searchTerms}";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
iconUpdateURL = "https://nixos.wiki/favicon.png";
|
|
|
|
updateInterval = 24 * 60 * 60 * 1000;
|
2023-10-17 14:12:26 +02:00
|
|
|
definedAliases = [ "@nw" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
"Bing".metaData.hidden = true;
|
|
|
|
"Amazon.de".metaData.hidden = true;
|
|
|
|
"Google".metaData = {
|
|
|
|
alias = "@g";
|
|
|
|
hidden = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
bookmarks = [
|
|
|
|
{
|
|
|
|
toolbar = true;
|
|
|
|
bookmarks = [
|
|
|
|
{
|
|
|
|
name = "Home Manager";
|
|
|
|
url = "https://nixos.wiki/wiki/Home_Manager";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "wikipedia";
|
2023-10-17 14:12:26 +02:00
|
|
|
tags = [ "wiki" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
keyword = "wiki";
|
|
|
|
url = "https://en.wikipedia.org/wiki/Special:Search?search=%s&go=Go";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "kernel.org";
|
|
|
|
url = "https://www.kernel.org";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "Nix sites";
|
|
|
|
bookmarks = [
|
|
|
|
{
|
|
|
|
name = "homepage";
|
|
|
|
url = "https://nixos.org/";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "wiki";
|
2023-10-17 14:12:26 +02:00
|
|
|
tags = [ "wiki" "nix" ];
|
2023-10-05 17:45:31 +02:00
|
|
|
url = "https://nixos.wiki/";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "Nix sites";
|
|
|
|
bookmarks = [
|
|
|
|
{
|
|
|
|
name = "homepage";
|
|
|
|
url = "https://nixos.org/";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
name = "wiki";
|
|
|
|
url = "https://nixos.wiki/";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
home.sessionVariables = {
|
|
|
|
BROWSER = "firefox";
|
|
|
|
MOZ_USE_XINPUT2 = "1";
|
|
|
|
MOZ_ENABLE_WAYLAND = "1";
|
|
|
|
};
|
|
|
|
}
|