2016-08-06 10:13:20 +02:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.security.chromiumSuidSandbox;
|
|
|
|
sandbox = pkgs.chromium.sandbox;
|
|
|
|
in
|
|
|
|
{
|
2019-12-10 02:51:19 +01:00
|
|
|
imports = [
|
|
|
|
(mkRenamedOptionModule [ "programs" "unity3d" "enable" ] [ "security" "chromiumSuidSandbox" "enable" ])
|
|
|
|
];
|
|
|
|
|
2016-08-08 00:55:11 +02:00
|
|
|
options.security.chromiumSuidSandbox.enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2022-07-28 23:19:15 +02:00
|
|
|
description = lib.mdDoc ''
|
2016-08-08 00:55:11 +02:00
|
|
|
Whether to install the Chromium SUID sandbox which is an executable that
|
|
|
|
Chromium may use in order to achieve sandboxing.
|
2016-08-06 10:13:20 +02:00
|
|
|
|
2016-08-08 00:55:11 +02:00
|
|
|
If you get the error "The SUID sandbox helper binary was found, but is not
|
|
|
|
configured correctly.", turning this on might help.
|
2016-08-06 10:13:20 +02:00
|
|
|
|
2016-08-08 00:55:11 +02:00
|
|
|
Also, if the URL chrome://sandbox tells you that "You are not adequately
|
|
|
|
sandboxed!", turning this on might resolve the issue.
|
|
|
|
'';
|
|
|
|
};
|
2016-08-06 10:13:20 +02:00
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
environment.systemPackages = [ sandbox ];
|
2021-09-12 18:53:48 +02:00
|
|
|
security.wrappers.${sandbox.passthru.sandboxExecutableName} =
|
|
|
|
{ setuid = true;
|
|
|
|
owner = "root";
|
|
|
|
group = "root";
|
|
|
|
source = "${sandbox}/bin/${sandbox.passthru.sandboxExecutableName}";
|
|
|
|
};
|
2016-08-06 10:13:20 +02:00
|
|
|
};
|
|
|
|
}
|