2016-10-08 16:10:56 +02:00
|
|
|
{ config, lib , pkgs, ...}:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
with import ./systemd-unit-options.nix { inherit config lib; };
|
|
|
|
with import ./systemd-lib.nix { inherit config lib pkgs; };
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.systemd.nspawn;
|
|
|
|
assertions = [
|
|
|
|
# boot = true -> processtwo != true
|
|
|
|
];
|
|
|
|
|
|
|
|
checkExec = checkUnitConfig "Exec" [
|
|
|
|
(assertOnlyFields [
|
|
|
|
"Boot" "ProcessTwo" "Parameters" "Environment" "User" "WorkingDirectory"
|
|
|
|
"Capability" "DropCapability" "KillSignal" "Personality" "MachineId"
|
|
|
|
"PrivateUsers"
|
|
|
|
])
|
|
|
|
(assertValueOneOf "Boot" boolValues)
|
|
|
|
(assertValueOneOf "ProcessTwo" boolValues)
|
|
|
|
(assertValueOneOf "PrivateUsers" (boolValues ++ [ "pick" ]))
|
|
|
|
];
|
|
|
|
|
|
|
|
checkFiles = checkUnitConfig "Files" [
|
|
|
|
(assertOnlyFields [
|
|
|
|
"ReadOnly" "Volatile" "Bind" "BindReadOnly" "TemporaryFileSystems"
|
|
|
|
"PrivateUsersChown"
|
|
|
|
])
|
|
|
|
(assertValueOneOf "ReadOnly" boolValues)
|
|
|
|
(assertValueOneOf "Volatile" (boolValues ++ [ "state" ]))
|
|
|
|
(assertValueOneOf "PrivateUsersChown" boolValues)
|
|
|
|
];
|
|
|
|
|
|
|
|
checkNetwork = checkUnitConfig "Network" [
|
|
|
|
(assertOnlyFields [
|
|
|
|
"Private" "VirtualEthernet" "VirtualEthernetExtra" "Interface" "MACVLAN"
|
|
|
|
"IPVLAN" "Bridge" "Zone" "Port"
|
|
|
|
])
|
|
|
|
(assertValueOneOf "Private" boolValues)
|
|
|
|
(assertValueOneOf "VirtualEthernet" boolValues)
|
|
|
|
];
|
|
|
|
|
|
|
|
instanceOptions = {
|
2016-10-20 18:31:54 +02:00
|
|
|
options = {
|
|
|
|
|
|
|
|
execConfig = mkOption {
|
|
|
|
default = {};
|
|
|
|
example = { Parameters = "/bin/sh"; };
|
|
|
|
type = types.addCheck (types.attrsOf unitOption) checkExec;
|
|
|
|
description = ''
|
|
|
|
Each attribute in this set specifies an option in the
|
|
|
|
<literal>[Exec]</literal> section of this unit. See
|
|
|
|
<citerefentry><refentrytitle>systemd.nspawn</refentrytitle>
|
|
|
|
<manvolnum>5</manvolnum></citerefentry> for details.
|
|
|
|
'';
|
|
|
|
};
|
2016-10-08 16:10:56 +02:00
|
|
|
|
2016-10-20 18:31:54 +02:00
|
|
|
filesConfig = mkOption {
|
|
|
|
default = {};
|
|
|
|
example = { Bind = [ "/home/alice" ]; };
|
|
|
|
type = types.addCheck (types.attrsOf unitOption) checkFiles;
|
|
|
|
description = ''
|
|
|
|
Each attribute in this set specifies an option in the
|
|
|
|
<literal>[Files]</literal> section of this unit. See
|
|
|
|
<citerefentry><refentrytitle>systemd.nspawn</refentrytitle>
|
|
|
|
<manvolnum>5</manvolnum></citerefentry> for details.
|
|
|
|
'';
|
|
|
|
};
|
2016-10-08 16:10:56 +02:00
|
|
|
|
2016-10-20 18:31:54 +02:00
|
|
|
networkConfig = mkOption {
|
|
|
|
default = {};
|
|
|
|
example = { Private = false; };
|
|
|
|
type = types.addCheck (types.attrsOf unitOption) checkNetwork;
|
|
|
|
description = ''
|
|
|
|
Each attribute in this set specifies an option in the
|
|
|
|
<literal>[Network]</literal> section of this unit. See
|
|
|
|
<citerefentry><refentrytitle>systemd.nspawn</refentrytitle>
|
|
|
|
<manvolnum>5</manvolnum></citerefentry> for details.
|
|
|
|
'';
|
|
|
|
};
|
2016-10-08 16:10:56 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
instanceToUnit = name: def:
|
|
|
|
{ text = ''
|
|
|
|
[Exec]
|
|
|
|
${attrsToSection def.execConfig}
|
|
|
|
|
|
|
|
[Files]
|
|
|
|
${attrsToSection def.filesConfig}
|
|
|
|
|
|
|
|
[Network]
|
|
|
|
${attrsToSection def.networkConfig}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
in {
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
systemd.nspawn = mkOption {
|
|
|
|
default = {};
|
2016-10-20 18:31:54 +02:00
|
|
|
type = with types; attrsOf (submodule instanceOptions);
|
2016-10-08 16:10:56 +02:00
|
|
|
description = "Definition of systemd-nspawn configurations.";
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
config =
|
|
|
|
let
|
|
|
|
units = mapAttrs' (n: v: nameValuePair "${n}.nspawn" (instanceToUnit n v)) cfg.instances;
|
|
|
|
in mkIf (cfg != {}) {
|
|
|
|
|
|
|
|
environment.etc."systemd/nspawn".source = generateUnits "nspawn" units [] [];
|
|
|
|
|
|
|
|
systemd.services."systemd-nspawn@" = {
|
|
|
|
wantedBy = [ "machine.target" ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|