Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

nixos/firefox: init #174975

Merged
merged 1 commit into from Nov 11, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
10 changes: 10 additions & 0 deletions nixos/doc/manual/from_md/release-notes/rl-2211.section.xml
Expand Up @@ -1390,6 +1390,16 @@ signald -d /var/lib/signald/db \
for those who want to use it.
</para>
</listitem>
<listitem>
<para>
A NixOS module for Firefox has been added which allows
preferences and
<link xlink:href="https://github.com/mozilla/policy-templates/blob/master/README.md">policies</link>
to be set. This also allows extensions to be installed via the
<literal>ExtensionSettings</literal> policy. The new options
are under <literal>programs.firefox</literal>.
</para>
</listitem>
</itemizedlist>
</section>
</section>
2 changes: 2 additions & 0 deletions nixos/doc/manual/release-notes/rl-2211.section.md
Expand Up @@ -420,4 +420,6 @@ Available as [services.patroni](options.html#opt-services.patroni.enable).

- The `mame` package does not ship with its tools anymore in the default output. They were moved to a separate `tools` output instead. For convenience, `mame-tools` package was added for those who want to use it.

- A NixOS module for Firefox has been added which allows preferences and [policies](https://github.com/mozilla/policy-templates/blob/master/README.md) to be set. This also allows extensions to be installed via the `ExtensionSettings` policy. The new options are under `programs.firefox`.

<!-- To avoid merge conflicts, consider adding your item at an arbitrary place in the list instead. -->
1 change: 1 addition & 0 deletions nixos/modules/module-list.nix
Expand Up @@ -157,6 +157,7 @@
./programs/extra-container.nix
./programs/feedbackd.nix
./programs/file-roller.nix
./programs/firefox.nix
./programs/firejail.nix
./programs/fish.nix
./programs/flashrom.nix
Expand Down
91 changes: 91 additions & 0 deletions nixos/modules/programs/firefox.nix
@@ -0,0 +1,91 @@
{ pkgs, config, lib, ... }:

with lib;

let
cfg = config.programs.firefox;

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 {
description = mdDoc "Firefox package to use.";
type = types.package;
default = pkgs.firefox;
defaultText = literalExpression "pkgs.firefox";
relatedPackages = [
"firefox"
"firefox-beta-bin"
"firefox-bin"
"firefox-devedition-bin"
"firefox-esr"
"firefox-esr-wayland"
"firefox-wayland"
];
};

policies = mkOption {
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}
'';
type = policyFormat.type;
default = {};
};

preferences = mkOption {
description = mdDoc ''
Preferences to set from `about://config`.

Some of these might be able to be configured more ergonomically
using policies.

${organisationInfo}
'';
type = with types; attrsOf (oneOf [ bool int string ]);
default = {};
};
};

config = mkIf cfg.enable {
environment.systemPackages = [ cfg.package ];

environment.etc."firefox/policies/policies.json".source =
let policiesJSON =
policyFormat.generate
"firefox-policies.json"
{ inherit (cfg) policies; };
in mkIf (cfg.policies != {}) "${policiesJSON}";

# Preferences are converted into a policy
programs.firefox.policies =
mkIf (cfg.preferences != {})
{
Preferences = (mapAttrs (name: value: {
Value = value;
Status = "locked";
}) cfg.preferences);
};
};

meta.maintainers = with maintainers; [ danth ];
}