Run all nixng containers under particular user/group
This commit is contained in:
parent
fe960448c6
commit
a22c34716e
10 changed files with 117 additions and 23 deletions
|
@ -6,6 +6,7 @@
|
|||
...
|
||||
}: let
|
||||
cfg = config.services.radicale;
|
||||
cfgInit = config.init.services.radicale;
|
||||
|
||||
settingsFormat = pkgs.formats.ini {
|
||||
listToValue = lib.concatMapStringsSep ", " (lib.generators.mkValueStringDefault {});
|
||||
|
@ -14,23 +15,16 @@ in {
|
|||
options.services.radicale = {
|
||||
enable = lib.mkEnableOption "radicale";
|
||||
package = lib.mkPackageOption pkgs "radicale" {};
|
||||
user = lib.mkOption {
|
||||
description = "radicale user";
|
||||
type = lib.types.str;
|
||||
default = "radicale";
|
||||
};
|
||||
group = lib.mkOption {
|
||||
description = "radicale group";
|
||||
type = lib.types.str;
|
||||
default = "radicale";
|
||||
};
|
||||
|
||||
settings = lib.mkOption {
|
||||
type = settingsFormat.type;
|
||||
default = {};
|
||||
|
||||
description = ''
|
||||
Configuration for Radicale. See
|
||||
<https://radicale.org/v3.html#configuration>.
|
||||
'';
|
||||
|
||||
example = lib.literalExpression ''
|
||||
server = {
|
||||
hosts = [ "0.0.0.0:5232" "[::]:5232" ];
|
||||
|
@ -46,6 +40,7 @@ in {
|
|||
'';
|
||||
};
|
||||
};
|
||||
|
||||
config = lib.mkIf cfg.enable (let
|
||||
configFile = settingsFormat.generate "radicale.ini" cfg.settings;
|
||||
in {
|
||||
|
@ -62,20 +57,15 @@ in {
|
|||
|
||||
environment.systemPackages = [cfg.package];
|
||||
|
||||
users.users.${cfg.user} = nglib.mkDefaultRec {
|
||||
users.users.${cfgInit.user} = nglib.mkDefaultRec {
|
||||
description = "radicale";
|
||||
group = cfg.group;
|
||||
group = cfgInit.group;
|
||||
createHome = false;
|
||||
home = "/var/empty";
|
||||
useDefaultShell = true;
|
||||
uid = config.ids.uids.radicale;
|
||||
};
|
||||
|
||||
users.groups.${cfg.group} = nglib.mkDefaultRec {gid = config.ids.gids.radicale;};
|
||||
|
||||
ids = {
|
||||
uids.radicale = 408;
|
||||
gids.radicale = 408;
|
||||
};
|
||||
users.groups.${cfgInit.group} = nglib.mkDefaultRec {gid = config.ids.gids.radicale;};
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue