From cbb51d26c8438aa210bc1fe3ebca82833969e234 Mon Sep 17 00:00:00 2001 From: ChUrl Date: Wed, 10 Aug 2022 21:39:19 +0200 Subject: [PATCH] use firefox module --- config/firefox/userChrome.css | 0 home/christoph/default.nix | 255 ++-------------------------------- modules/default.nix | 1 + 3 files changed, 10 insertions(+), 246 deletions(-) delete mode 100644 config/firefox/userChrome.css diff --git a/config/firefox/userChrome.css b/config/firefox/userChrome.css deleted file mode 100644 index e69de29b..00000000 diff --git a/home/christoph/default.nix b/home/christoph/default.nix index a698cf88..1f7b9f36 100644 --- a/home/christoph/default.nix +++ b/home/christoph/default.nix @@ -33,6 +33,13 @@ rec { doom.autoUpgrade = false; # Very volatile as the upgrade fails sometimes with bleeding edge emacs }; + modules.firefox = { + enable = true; + wayland = true; + vaapi = true; + disableTabBar = true; + }; + modules.flatpak = { enable = true; autoUpdate = true; @@ -43,6 +50,8 @@ rec { }; modules.misc = { + enable = true; + keepass = { enable = true; autostart = true; @@ -125,14 +134,6 @@ rec { # Enable wayland XDG_SESSION_TYPE = "wayland"; QT_QPA_PLATFORM = "wayland"; - MOZ_ENABLE_WAYLAND = 1; - - # Firefox vaapi test - EGL_PLATFORM = "wayland"; - LIBVA_DRIVER_NAME = "nvidia"; - MOZ_DISABLE_RDD_SANDBOX = 1; - - MOZ_USE_XINPUT2 = 1; # Don't use system wine, use bottles # WINEESYNC = 1; @@ -155,13 +156,6 @@ rec { # Add stuff for your user as you see fit: home.packages = with pkgs; [ - # Firefox hardware video acceleration - # TODO - libva - libva-utils - nvidia-vaapi-driver - vulkan-tools - # CLI Tools procs tokei @@ -356,237 +350,6 @@ rec { # ''; }; - firefox = { - enable = true; - - # firefox-unwrapped is the pure firefox browser, wrapFirefox adds configuration ontop - package = pkgs.wrapFirefox pkgs.firefox-unwrapped { - - forceWayland = true; - - # About policies: - # https://github.com/mozilla/policy-templates#enterprisepoliciesenabled - extraPolicies = { - # TODO: Investigate this - ExtensionSettings = { }; - - CaptivePortal = false; - DisableFirefoxStudies = true; - DisablePocket = true; - DisableTelemetry = true; - DisableFirefoxAccounts = true; - FirefoxHome = { - Pocket = false; - Snippets = false; - }; - UserMessaging = { - ExtensionRecommendations = false; - SkipOnboarding = true; - }; - }; - }; - - extensions = with pkgs.nur.repos.rycee.firefox-addons; [ - augmented-steam - betterttv - bypass-paywalls-clean - clearurls - cookie-autodelete - don-t-fuck-with-paste - h264ify - keepassxc-browser - localcdn - privacy-badger - search-by-image - single-file - skip-redirect - sponsorblock - tab-session-manager - to-deepl - transparent-standalone-image - tree-style-tab - ublacklist - ublock-origin - # umatrix # Many pages need manual intervention - unpaywall - view-image - vimium - ]; - - profiles = { - default = { - id = 0; # 0 is default profile - - settings = { - "app.update.auto" = false; - # "browser.startup.homepage" = "https://lobste.rs"; - "identity.fxaccounts.account.device.name" = nixosConfig.networking.hostName; - - # Firefox wayland hardware video acceleration - # https://github.com/elFarto/nvidia-vaapi-driver/#firefox= - "media.ffmpeg.vaapi.enabled" = true; - "widget.wayland-dmabuf-vaapi.enabled" = true; - "widget.dmabuf.force-enabled" = true; - "gfx.webrender.enabled" = true; # Should be set on gnome anyway - "media.rdd-ffmpeg.enabled" = true; - "media.av1.enabled" = false; - "gfx.x11-egl.force-enabled" = true; - - # Enable ETP for decent security (makes firefox containers and many - # common security/privacy add-ons redundant). - "browser.contentblocking.category" = "standard"; - "privacy.donottrackheader.enabled" = true; - "privacy.donottrackheader.value" = 1; - "privacy.purge_trackers.enabled" = true; - # 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; - # Enable userContent.css and userChrome.css for our theme modules - "toolkit.legacyUserProfileCustomizations.stylesheets" = true; - # Don't use the built-in password manager. A nixos user is more likely - # using an external one (you are using one, right?). - "signon.rememberSignons" = false; - # Do not check if Firefox is the default browser - "browser.shell.checkDefaultBrowser" = false; - # Disable the "new tab page" feature and show a blank tab instead - # https://wiki.mozilla.org/Privacy/Reviews/New_Tab - # https://support.mozilla.org/en-US/kb/new-tab-page-show-hide-and-customize-top-sites#w_how-do-i-turn-the-new-tab-page-off - "browser.newtabpage.enabled" = false; - "browser.newtab.url" = "about:blank"; - # Disable Activity Stream - # https://wiki.mozilla.org/Firefox/Activity_Stream - "browser.newtabpage.activity-stream.enabled" = false; - "browser.newtabpage.activity-stream.telemetry" = false; - # Disable new tab tile ads & preload - # http://www.thewindowsclub.com/disable-remove-ad-tiles-from-firefox - # http://forums.mozillazine.org/viewtopic.php?p=13876331#p13876331 - # https://wiki.mozilla.org/Tiles/Technical_Documentation#Ping - # https://gecko.readthedocs.org/en/latest/browser/browser/DirectoryLinksProvider.html#browser-newtabpage-directory-source - # https://gecko.readthedocs.org/en/latest/browser/browser/DirectoryLinksProvider.html#browser-newtabpage-directory-ping - "browser.newtabpage.enhanced" = false; - "browser.newtabpage.introShown" = true; - "browser.newtab.preload" = false; - "browser.newtabpage.directory.ping" = ""; - "browser.newtabpage.directory.source" = "data:text/plain,{}"; - # 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; - "browser.urlbar.shortcuts.bookmarks" = false; - "browser.urlbar.shortcuts.history" = true; - "browser.urlbar.shortcuts.tabs" = false; - "browser.urlbar.showSearchSuggestionsFirst" = false; - "browser.urlbar.speculativeConnect.enabled" = false; - # https://bugzilla.mozilla.org/1642623 - "browser.urlbar.dnsResolveSingleWordsAfterSearch" = 0; - # https://blog.mozilla.org/data/2021/09/15/data-and-firefox-suggest/ - "browser.urlbar.suggest.quicksuggest.nonsponsored" = false; - "browser.urlbar.suggest.quicksuggest.sponsored" = false; - # Show whole URL in address bar - "browser.urlbar.trimURLs" = 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 - "media.videocontrols.picture-in-picture.video-toggle.enabled" = true; - "extensions.pocket.enabled" = false; - "extensions.shield-recipe-client.enabled" = false; - "reader.parse-on-load.enabled" = false; # "reader view" - - # 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.getAddons.showPane" = false; # uses Google Analytics - "browser.discovery.enabled" = false; - # Reduce File IO / SSD abuse - # Otherwise, Firefox bombards the HD with writes. Not so nice for SSDs. - # This forces it to write every 30 minutes, rather than 15 seconds. - "browser.sessionstore.interval" = "1800000"; - # Disable battery API - # https://developer.mozilla.org/en-US/docs/Web/API/BatteryManager - # https://bugzilla.mozilla.org/show_bug.cgi?id=1313580 - "dom.battery.enabled" = false; - # Disable "beacon" asynchronous HTTP transfers (used for analytics) - # https://developer.mozilla.org/en-US/docs/Web/API/navigator.sendBeacon - "beacon.enabled" = false; - # Disable pinging URIs specified in HTML ping= attributes - # http://kb.mozillazine.org/Browser.send_pings - "browser.send_pings" = false; - # Disable gamepad API to prevent USB device enumeration - # https://www.w3.org/TR/gamepad/ - # https://trac.torproject.org/projects/tor/ticket/13023 - "dom.gamepad.enabled" = false; - # Don't try to guess domain names when entering an invalid domain name in URL bar - # http://www-archive.mozilla.org/docs/end-user/domain-guessing.html - "browser.fixup.alternate.enabled" = false; - # Disable telemetry - # https://wiki.mozilla.org/Platform/Features/Telemetry - # https://wiki.mozilla.org/Privacy/Reviews/Telemetry - # https://wiki.mozilla.org/Telemetry - # https://www.mozilla.org/en-US/legal/privacy/firefox.html#telemetry - # https://support.mozilla.org/t5/Firefox-crashes/Mozilla-Crash-Reporter/ta-p/1715 - # https://wiki.mozilla.org/Security/Reviews/Firefox6/ReviewNotes/telemetry - # https://gecko.readthedocs.io/en/latest/browser/experiments/experiments/manifest.html - # https://wiki.mozilla.org/Telemetry/Experiments - # https://support.mozilla.org/en-US/questions/1197144 - # https://firefox-source-docs.mozilla.org/toolkit/components/telemetry/telemetry/internals/preferences.html#id1 - "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; - "dom.security.https_only_mode" = true; - - # 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; - }; - - userChrome = builtins.readFile ../../config/firefox/userChrome.css; - }; - }; - }; - fzf = { enable = true; enableFishIntegration = true; diff --git a/modules/default.nix b/modules/default.nix index b96f3c34..bc19972f 100644 --- a/modules/default.nix +++ b/modules/default.nix @@ -4,6 +4,7 @@ imports = [ ./audio.nix ./emacs.nix + ./firefox.nix ./flatpak.nix ./gaming.nix ./misc.nix