2024-07-27 06:49:29 +00:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
pkgs,
|
|
|
|
lib,
|
|
|
|
...
|
|
|
|
}:
|
2022-03-05 16:20:37 +00:00
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
{
|
|
|
|
options.proxmoxLXC = {
|
2024-07-27 06:49:29 +00:00
|
|
|
enable = mkOption {
|
|
|
|
default = true;
|
|
|
|
type = types.bool;
|
|
|
|
description = lib.mdDoc "Whether to enable the Proxmox VE LXC module.";
|
|
|
|
};
|
2022-03-05 16:20:37 +00:00
|
|
|
privileged = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2022-03-05 16:20:37 +00:00
|
|
|
Whether to enable privileged mounts
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
manageNetwork = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2022-03-05 16:20:37 +00:00
|
|
|
Whether to manage network interfaces through nix options
|
|
|
|
When false, systemd-networkd is enabled to accept network
|
|
|
|
configuration from proxmox.
|
|
|
|
'';
|
|
|
|
};
|
2022-05-18 14:49:53 +00:00
|
|
|
manageHostName = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2022-05-18 14:49:53 +00:00
|
|
|
Whether to manage hostname through nix options
|
|
|
|
When false, the hostname is picked up from /etc/hostname
|
|
|
|
populated by proxmox.
|
|
|
|
'';
|
|
|
|
};
|
2022-03-05 16:20:37 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
config =
|
|
|
|
let
|
|
|
|
cfg = config.proxmoxLXC;
|
|
|
|
in
|
2024-07-27 06:49:29 +00:00
|
|
|
mkIf cfg.enable {
|
2022-03-05 16:20:37 +00:00
|
|
|
system.build.tarball = pkgs.callPackage ../../lib/make-system-tarball.nix {
|
2024-07-27 06:49:29 +00:00
|
|
|
storeContents = [
|
|
|
|
{
|
|
|
|
object = config.system.build.toplevel;
|
|
|
|
symlink = "none";
|
|
|
|
}
|
|
|
|
];
|
2022-03-05 16:20:37 +00:00
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
contents = [
|
|
|
|
{
|
|
|
|
source = config.system.build.toplevel + "/init";
|
|
|
|
target = "/sbin/init";
|
|
|
|
}
|
|
|
|
];
|
2022-03-05 16:20:37 +00:00
|
|
|
|
|
|
|
extraCommands = "mkdir -p root etc/systemd/network";
|
|
|
|
};
|
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
boot.postBootCommands = ''
|
|
|
|
# After booting, register the contents of the Nix store in the Nix
|
|
|
|
# database.
|
|
|
|
if [ -f /nix-path-registration ]; then
|
|
|
|
${config.nix.package.out}/bin/nix-store --load-db < /nix-path-registration &&
|
|
|
|
rm /nix-path-registration
|
|
|
|
fi
|
|
|
|
|
|
|
|
# nixos-rebuild also requires a "system" profile
|
|
|
|
${config.nix.package.out}/bin/nix-env -p /nix/var/nix/profiles/system --set /run/current-system
|
|
|
|
'';
|
|
|
|
|
2022-03-05 16:20:37 +00:00
|
|
|
boot = {
|
|
|
|
isContainer = true;
|
|
|
|
loader.initScript.enable = true;
|
|
|
|
};
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
console.enable = true;
|
|
|
|
|
2022-03-05 16:20:37 +00:00
|
|
|
networking = mkIf (!cfg.manageNetwork) {
|
|
|
|
useDHCP = false;
|
|
|
|
useHostResolvConf = false;
|
|
|
|
useNetworkd = true;
|
2022-05-18 14:49:53 +00:00
|
|
|
# pick up hostname from /etc/hostname generated by proxmox
|
|
|
|
hostName = mkIf (!cfg.manageHostName) (mkForce "");
|
2022-03-05 16:20:37 +00:00
|
|
|
};
|
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
# unprivileged LXCs can't set net.ipv4.ping_group_range
|
|
|
|
security.wrappers.ping = mkIf (!cfg.privileged) {
|
|
|
|
owner = "root";
|
|
|
|
group = "root";
|
|
|
|
capabilities = "cap_net_raw+p";
|
|
|
|
source = "${pkgs.iputils.out}/bin/ping";
|
|
|
|
};
|
|
|
|
|
2022-03-05 16:20:37 +00:00
|
|
|
services.openssh = {
|
|
|
|
enable = mkDefault true;
|
|
|
|
startWhenNeeded = mkDefault true;
|
|
|
|
};
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
systemd = {
|
2024-07-27 06:49:29 +00:00
|
|
|
mounts = mkIf (!cfg.privileged) [
|
|
|
|
{
|
|
|
|
enable = false;
|
|
|
|
where = "/sys/kernel/debug";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
# By default only starts getty on tty0 but first on LXC is tty1
|
|
|
|
services."autovt@".unitConfig.ConditionPathExists = [
|
|
|
|
""
|
|
|
|
"/dev/%I"
|
|
|
|
];
|
|
|
|
|
|
|
|
# These are disabled by `console.enable` but console via tty is the default in Proxmox
|
|
|
|
services."getty@tty1".enable = lib.mkForce true;
|
|
|
|
services."autovt@".enable = lib.mkForce true;
|
2024-06-05 15:53:02 +00:00
|
|
|
};
|
2022-03-05 16:20:37 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
}
|