e53c99eb17
`pkgs` may be passed in externally, in which case `config.nixpkgs.config` will not be set. Follow-up to #257458.
279 lines
7 KiB
Nix
279 lines
7 KiB
Nix
{ pkgs, config, lib, ... }:
|
|
|
|
with lib;
|
|
|
|
let
|
|
cfg = config.programs.firefox;
|
|
|
|
nmh = cfg.nativeMessagingHosts;
|
|
|
|
policyFormat = pkgs.formats.json { };
|
|
|
|
organisationInfo = ''
|
|
When this option is in use, Firefox will inform you that "your browser
|
|
is managed by your organisation". That message appears because NixOS
|
|
installs what you have declared here such that it cannot be overridden
|
|
through the user interface. It does not mean that someone else has been
|
|
given control of your browser, unless of course they also control your
|
|
NixOS configuration.
|
|
'';
|
|
in
|
|
{
|
|
options.programs.firefox = {
|
|
enable = mkEnableOption (mdDoc "the Firefox web browser");
|
|
|
|
package = mkOption {
|
|
type = types.package;
|
|
default = pkgs.firefox;
|
|
description = mdDoc "Firefox package to use.";
|
|
defaultText = literalExpression "pkgs.firefox";
|
|
relatedPackages = [
|
|
"firefox"
|
|
"firefox-beta-bin"
|
|
"firefox-bin"
|
|
"firefox-devedition-bin"
|
|
"firefox-esr"
|
|
];
|
|
};
|
|
|
|
wrapperConfig = mkOption {
|
|
type = types.attrs;
|
|
default = {};
|
|
description = mdDoc "Arguments to pass to Firefox wrapper";
|
|
};
|
|
|
|
policies = mkOption {
|
|
type = policyFormat.type;
|
|
default = { };
|
|
description = mdDoc ''
|
|
Group policies to install.
|
|
|
|
See [Mozilla's documentation](https://github.com/mozilla/policy-templates/blob/master/README.md)
|
|
for a list of available options.
|
|
|
|
This can be used to install extensions declaratively! Check out the
|
|
documentation of the `ExtensionSettings` policy for details.
|
|
|
|
${organisationInfo}
|
|
'';
|
|
};
|
|
|
|
preferences = mkOption {
|
|
type = with types; attrsOf (oneOf [ bool int str ]);
|
|
default = { };
|
|
description = mdDoc ''
|
|
Preferences to set from `about:config`.
|
|
|
|
Some of these might be able to be configured more ergonomically
|
|
using policies.
|
|
|
|
${organisationInfo}
|
|
'';
|
|
};
|
|
|
|
preferencesStatus = mkOption {
|
|
type = types.enum [ "default" "locked" "user" "clear" ];
|
|
default = "locked";
|
|
description = mdDoc ''
|
|
The status of `firefox.preferences`.
|
|
|
|
`status` can assume the following values:
|
|
- `"default"`: Preferences appear as default.
|
|
- `"locked"`: Preferences appear as default and can't be changed.
|
|
- `"user"`: Preferences appear as changed.
|
|
- `"clear"`: Value has no effect. Resets to factory defaults on each startup.
|
|
'';
|
|
};
|
|
|
|
languagePacks = mkOption {
|
|
# Available languages can be found in https://releases.mozilla.org/pub/firefox/releases/${cfg.package.version}/linux-x86_64/xpi/
|
|
type = types.listOf (types.enum ([
|
|
"ach"
|
|
"af"
|
|
"an"
|
|
"ar"
|
|
"ast"
|
|
"az"
|
|
"be"
|
|
"bg"
|
|
"bn"
|
|
"br"
|
|
"bs"
|
|
"ca-valencia"
|
|
"ca"
|
|
"cak"
|
|
"cs"
|
|
"cy"
|
|
"da"
|
|
"de"
|
|
"dsb"
|
|
"el"
|
|
"en-CA"
|
|
"en-GB"
|
|
"en-US"
|
|
"eo"
|
|
"es-AR"
|
|
"es-CL"
|
|
"es-ES"
|
|
"es-MX"
|
|
"et"
|
|
"eu"
|
|
"fa"
|
|
"ff"
|
|
"fi"
|
|
"fr"
|
|
"fy-NL"
|
|
"ga-IE"
|
|
"gd"
|
|
"gl"
|
|
"gn"
|
|
"gu-IN"
|
|
"he"
|
|
"hi-IN"
|
|
"hr"
|
|
"hsb"
|
|
"hu"
|
|
"hy-AM"
|
|
"ia"
|
|
"id"
|
|
"is"
|
|
"it"
|
|
"ja"
|
|
"ka"
|
|
"kab"
|
|
"kk"
|
|
"km"
|
|
"kn"
|
|
"ko"
|
|
"lij"
|
|
"lt"
|
|
"lv"
|
|
"mk"
|
|
"mr"
|
|
"ms"
|
|
"my"
|
|
"nb-NO"
|
|
"ne-NP"
|
|
"nl"
|
|
"nn-NO"
|
|
"oc"
|
|
"pa-IN"
|
|
"pl"
|
|
"pt-BR"
|
|
"pt-PT"
|
|
"rm"
|
|
"ro"
|
|
"ru"
|
|
"sco"
|
|
"si"
|
|
"sk"
|
|
"sl"
|
|
"son"
|
|
"sq"
|
|
"sr"
|
|
"sv-SE"
|
|
"szl"
|
|
"ta"
|
|
"te"
|
|
"th"
|
|
"tl"
|
|
"tr"
|
|
"trs"
|
|
"uk"
|
|
"ur"
|
|
"uz"
|
|
"vi"
|
|
"xh"
|
|
"zh-CN"
|
|
"zh-TW"
|
|
]));
|
|
default = [ ];
|
|
description = mdDoc ''
|
|
The language packs to install.
|
|
'';
|
|
};
|
|
|
|
autoConfig = mkOption {
|
|
type = types.lines;
|
|
default = "";
|
|
description = mdDoc ''
|
|
AutoConfig files can be used to set and lock preferences that are not covered
|
|
by the policies.json for Mac and Linux. This method can be used to automatically
|
|
change user preferences or prevent the end user from modifiying specific
|
|
preferences by locking them. More info can be found in https://support.mozilla.org/en-US/kb/customizing-firefox-using-autoconfig.
|
|
'';
|
|
};
|
|
|
|
nativeMessagingHosts = mapAttrs (_: v: mkEnableOption (mdDoc v)) {
|
|
browserpass = "Browserpass support";
|
|
bukubrow = "Bukubrow support";
|
|
euwebid = "Web eID support";
|
|
ff2mpv = "ff2mpv support";
|
|
fxCast = "fx_cast support";
|
|
gsconnect = "GSConnect support";
|
|
jabref = "JabRef support";
|
|
passff = "PassFF support";
|
|
tridactyl = "Tridactyl support";
|
|
ugetIntegrator = "Uget Integrator support";
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
environment.systemPackages = [
|
|
(cfg.package.override {
|
|
extraPrefs = cfg.autoConfig;
|
|
extraNativeMessagingHosts = with pkgs; optionals nmh.ff2mpv [
|
|
ff2mpv
|
|
] ++ optionals nmh.euwebid [
|
|
web-eid-app
|
|
] ++ optionals nmh.gsconnect [
|
|
gnomeExtensions.gsconnect
|
|
] ++ optionals nmh.jabref [
|
|
jabref
|
|
] ++ optionals nmh.passff [
|
|
passff-host
|
|
];
|
|
cfg = let
|
|
# copy-pasted from the wrapper; TODO: figure out fix
|
|
applicationName = cfg.package.binaryName or (lib.getName cfg.package);
|
|
|
|
nixpkgsConfig = pkgs.config.${applicationName} or {};
|
|
optionConfig = cfg.wrapperConfig;
|
|
nmhConfig = {
|
|
enableBrowserpass = nmh.browserpass;
|
|
enableBukubrow = nmh.bukubrow;
|
|
enableTridactylNative = nmh.tridactyl;
|
|
enableUgetIntegrator = nmh.ugetIntegrator;
|
|
enableFXCastBridge = nmh.fxCast;
|
|
};
|
|
in nixpkgsConfig // optionConfig // nmhConfig;
|
|
})
|
|
];
|
|
|
|
environment.etc =
|
|
let
|
|
policiesJSON = policyFormat.generate "firefox-policies.json" { inherit (cfg) policies; };
|
|
in
|
|
mkIf (cfg.policies != { }) {
|
|
"firefox/policies/policies.json".source = "${policiesJSON}";
|
|
};
|
|
|
|
# Preferences are converted into a policy
|
|
programs.firefox.policies = {
|
|
Preferences = (mapAttrs
|
|
(_: value: { Value = value; Status = cfg.preferencesStatus; })
|
|
cfg.preferences);
|
|
ExtensionSettings = listToAttrs (map
|
|
(lang: nameValuePair
|
|
"langpack-${lang}@firefox.mozilla.org"
|
|
{
|
|
installation_mode = "normal_installed";
|
|
install_url = "https://releases.mozilla.org/pub/firefox/releases/${cfg.package.version}/linux-x86_64/xpi/${lang}.xpi";
|
|
}
|
|
)
|
|
cfg.languagePacks);
|
|
};
|
|
};
|
|
|
|
meta.maintainers = with maintainers; [ danth ];
|
|
}
|