{ pkgs, nixgl, ... }: let # quick variables to specify # locked true/false lock-false = { Value = false; Status = "locked"; }; lock-true = { Value = true; Status = "locked"; }; # path to nixGL binary (needed for webGL) nixGL = "${nixgl.packages.${pkgs.system}.nixGLIntel}/bin/nixGLIntel"; # modify firefox base package AND wrapper # - set user prefs # - fix webGL my-firefox = (pkgs.firefox.override { # start wrapper override # file: mozilla.cfg # modifies user prefs that firefox would normally not # let me hardcode. i want to hardcode them. extraPrefs = ''// // Automatically click cookiebanners although uBlock Origin might block them lockPref("cookiebanners.bannerClicking.enabled", true); lockPref("cookiebanners.service.mode", 2); lockPref("cookiebanners.service.mode.privateBrowsing", 2); // DNT although PrivacyBadger from policy handles this lockPref("privacy.donottrackheader.enabled", true); lockPref("privacy.donottrackheader.value", 1); // New sidebar lockPref("sidebar.revamp", true); lockPref("sidebar.verticalTabs", true); lockPref("sidebar.visibility", "always-show"); lockPref("sidebar.main.tools", "history,bookmarks"); //''; }) # end wrapper override .overrideAttrs (old: { # start base package override # modify run (build) command for firefox so that # we can always have nixGL be called first before firefox # ... this fixes webGL on GNU/Guix. this is likely not needed if you # are just running nixOS buildCommand = old.buildCommand + '' sed -i "s#firefox-wrapped\"#firefox-wrapped\" \"${nixGL}\"#1" "$out/bin/firefox" ''; }); # end base package override in { programs.firefox = { # enable firefox and # pass in our custom (modified) package from above enable = true; package = my-firefox; # set firefox policies that i want # (all that can be modified by firefox policy templates) # see: https://mozilla.github.io/policy-templates/ policies = { EnableTrackingProtection = { Value = true; Locked = true; Cryptomining = true; Fingerprinting = true; EmailTracking = true; }; # Certificates Certificates = { ImportEnterpriseRoots = true; Install = [ "freya_ca.crt" "tinternet.crt" ]; }; # Cookies Cookies = { Behavior = "reject-foreign"; BehaviorPrivateBrowsing = "reject-foreign"; Locked = true; }; # DNS DNSOverHTTPS = { Enabled = false; Locked = true; }; # Disable Bad DisableAppUpdate = true; DisableAccounts = true; DisableFirefoxAccounts = true; DisableFirefoxScreenshots = true; DisableFirefoxStudies = true; DisablePocket = true; DisableTelemetry = true; AutofillAddressEnabled = false; AutofillCreditCardEnabled = false; # Disable Certain Messages UserMessaging = { WhatsNew = false; ExtensionRecommendations = false; FeatureRecommendations = false; UrlbarInterventions = false; SkipOnboarding = true; MoreFromMozilla = false; Labs = false; Locked = true; }; # Disable Password Manager DisableMasterPasswordCreation = true; PasswordManagerEnabled = false; PrimaryPassword = false; OfferToSaveLogins = false; # Remove Special Pages OverrideFirstRunPage = ""; OverridePostUpdatePage = ""; # Start Page Homepage = { StartPage = "previous-session"; Locked = true; }; # Home Page FirefoxHome = { Search = true; TopSites = false; SponsoredTopSites = false; Highlights = false; Pocket = false; SponsoredPocket = false; Snippets = false; Locked = true; }; # Search Suggestions SearchSuggestEnabled = true; FirefoxSuggest = { WebSuggestions = false; SponsoredSuggestions = false; ImproveSuggest = false; Locked = true; }; # Save All on Shutdown SanitizeOnShutdown = { Cache = false; Cookies = false; Downloads = false; Histroy = false; Sessions = false; SiteSettings = false; OfflineApps = false; Locked = true; }; # Popups PopupBlocking = { Default = true; Locked = true; }; # Allow Bypasses DisableSecurityBypass = { InvalidCertificate = false; SafeBrowsing = false; }; # PictureInPicure PictureInPicture = { Enabled = true; Locked = true; }; # Topbar SearchBar = "unified"; DisplayMenuBar = "default-off"; DisplayBookmarksToolbar = "newtab"; NoDefaultBookmarks = true; # Miscellaneous HttpsOnlyMode = "force_enabled"; HardwareAcceleration = true; DontCheckDefaultBrowser = true; PromptForDownloadLocation = false; PrivateBrowsingModeAvailability = 0; # Extensions ExtensionSettings = { "*".installation_mode = "blocked"; # uBlock Origin "uBlock0@raymondhill.net" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/ublock-origin/latest.xpi"; installation_mode = "force_installed"; }; # Bitwarden "{446900e4-71c2-419f-a6a7-df9c091e268b}" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/bitwarden-password-manager/latest.xpi"; installation_mode = "force_installed"; }; # User Agent Switcher "user-agent-switcher@ninetailed.ninja" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/uaswitcher/latest.xpi"; installation_mode = "force_installed"; }; # SponsorBlock "sponsorBlocker@ajay.app" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/sponsorblock/latest.xpi"; installation_mode = "force_installed"; }; # Privacy Badger "jid1-MnnxcxisBPnSXQ@jetpack" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/privacy-badger17/latest.xpi"; installation_mode = "force_installed"; }; # FoxyProxy "foxyproxy@eric.h.jung" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/foxyproxy-standard/latest.xpi"; installation_mode = "force_installed"; }; # Redirector "redirector@einaregilsson.com" = { install_url = "https://addons.mozilla.org/firefox/downloads/latest/redirector/latest.xpi"; installation_mode = "force_installed"; }; }; # about:config Preferences # ... set policies that cannot be set using policies.json directly Preferences = { # allow userChrom.css "toolkit.legacyUserProfileCustomizations.stylesheets" = lock-true; # dark theme "extensions.activeThemeID" = { Value = "firefox-compact-dark@mozilla.org"; Status = "locked"; }; "layout.css.prefers-color-scheme.content-override" = { Value = 0; Status = "locked"; }; # homepage "browser.startup.homepage" = { Value = "about:home"; Status = "locked"; }; "browser.newtabpage.enabed" = lock-true; "browser.newtabpage.url" = { Value = "about:home"; Status = "locked"; }; # autofill "browser.autofill.enabled" = lock-false; "browser.formfill.enable" = lock-false; # search enable "browser.urlbar.suggest.recentsearches" = lock-true; "browser.urlbar.suggest.bookmark" = lock-true; "browser.urlbar.suggest.clipboard" = lock-true; "browser.urlbar.suggest.history" = lock-true; # search disable "browser.urlbar.suggest.addons" = lock-false; "browser.urlbar.suggest.calculator" = lock-false; "browser.urlbar.suggest.engines" = lock-false; "browser.urlbar.suggest.fakespot" = lock-false; "browser.urlbar.suggest.mdn" = lock-false; "browser.urlbar.suggest.openpage" = lock-false; "browser.urlbar.suggest.pocket" = lock-false; "browser.urlbar.suggest.remotetab" = lock-false; "browser.urlbar.suggest.topsites" = lock-false; "browser.urlbar.suggest.trending" = lock-false; "browser.urlbar.suggest.weather" = lock-false; "browser.urlbar.suggest.yelp" = lock-false; # privacy "privacy.globalprivacycontrol.enabled" = lock-true; # security "security.OCSP.enabled" = { Value = 0; Status = "locked"; }; "browser.contentblocking.category" = { Value = "strict"; Status = "locked"; }; "xpinstall.whitelist.required" = lock-true; "signon.management.page.breach-alerts.enabled" = lock-false; # graphics "dom.webgpu.enabled" = lock-true; "media.eme.enabled" = lock-true; # user messaging # ... disable shit that is annoying "browser.newtabpage.activity-stream.feeds.section.topstories" = lock-false; "browser.newtabpage.activity-stream.feeds.snippets" = lock-false; "browser.newtabpage.activity-stream.section.highlights.includePocket" = lock-false; "browser.newtabpage.activity-stream.section.highlights.includeBookmarks" = lock-false; "browser.newtabpage.activity-stream.section.highlights.includeDownloads" = lock-false; "browser.newtabpage.activity-stream.section.highlights.includeVisited" = lock-false; "browser.newtabpage.activity-stream.showSponsored" = lock-false; "browser.newtabpage.activity-stream.system.showSponsored" = lock-false; "browser.newtabpage.activity-stream.showSponsoredTopSites" = lock-false; "browser.newtabpage.activity-stream.showWeather" = lock-false; "browser.newtabpage.activity-stream.newtabWallpapers.enabled" = lock-false; "browser.newtabpage.activity-stream.newtabWallpapers.v2.enabled" = lock-false; "browser.newtabpage.activity-stream.default.sites" = { Value = ""; Status = "locked"; }; # safebrowsing "browser.safebrowsing.malware.enabled" = lock-true; "browser.safebrowsing.phishing.enabled" = lock-true; "browser.safebrowsing.downloads.enabled" = lock-true; "browser.safebrowsing.downloads.remote.block_uncommon" = lock-false; "browser.safebrowsing.downloads.remote.block_potentially_unwanted" = lock-false; # sidebar "browser.tabs.inTitlebar" = { Value = 0; Status = "locked"; }; "browser.tabs.warnOnClose" = lock-true; "browser.tabs.firefox-view" = lock-false; "browser.tabs.closeTabByDblclick" = lock-true; "ui.key.menuAccessKeyFocuses" = lock-false; # general settings "general.autoScroll" = lock-false; "general.smoothScroll" = lock-true; "widget.gtk.overlay-scrollbars.enabled" = lock-false; "accessibility.browsewithcaret" = lock-false; "accessibility.typeaheadfind" = lock-false; "media.hardwaremediakeys.enabled" = lock-true; "browser.crashReports.unsubmittedCheck.autoSubmit2" = lock-false; "browser.aboutConfig.showWarning" = lock-false; }; }; # create profile for me :3 profiles = { "freya" = { search = { force = true; default = "DuckDuckGo"; engines = { "Google".metaData.hidden = true; "Bing".metaData.hidden = true; "Amazon.com".metaData.hidden = true; "eBay".metaData.hidden = true; "Twitter".metaData.hidden = true; }; }; # firefox doesnt make styling the toolbar easy using about:config # since its just a massive json string. so i did it here in css. userChrome = '' /* sidebar hack to flip contents the way i want them (arrows on the left) */ #nav-bar-customization-target { flex-direction: row-reverse; } /* remove broken padding from sidebar hack */ #unified-extensions-button { padding-left: 0 !important; } /* remove padding beside search bar */ toolbarspring { display: none !important; } /* remove overflow menu and everything in it */ #nav-bar-overflow-button, #firefox-view-button, #alltabs-button { visibility: collapse; } ''; }; }; }; }