depot/ops/nixos/nausicaa/default.nix

341 lines
8.6 KiB
Nix

# SPDX-FileCopyrightText: 2024 Luke Granger-Brown <depot@lukegb.com>
#
# SPDX-License-Identifier: Apache-2.0
{ depot, lib, pkgs, config, ... }:
let
inherit (depot.ops) secrets;
in {
imports = [
../lib/zfs.nix
../lib/graphical-client-wayland.nix
../lib/plasma.nix
#../lib/whitby-distributed.nix
#../lib/nixbuild-distributed.nix
../lib/rexxar-distributed.nix
../lib/quadv-ca/default.nix
((import ../../../third_party/lanzaboote.nix { }).nixosModules.lanzaboote)
../lib/open5gs.nix
../lib/seaweedfs.nix
];
boot = lib.mkMerge [{
initrd.availableKernelModules = [
"xhci_pci"
"ahci"
"nvme"
"usbhid"
"usb_storage"
"sd_mod"
"rtsx_pci_sdmmc"
];
initrd.kernelModules = [ "amdgpu" ];
kernelModules = [ "kvm-amd" ];
supportedFilesystems = [ "ntfs" ];
kernel.sysctl = {
"abi.vsyscall32" = "0";
};
# We're using Lanzaboote, so no systemd-boot.
lanzaboote = {
enable = true;
pkiBundle = "/etc/secureboot";
settings = {
reboot-for-bitlocker = true;
editor = false;
};
};
loader.efi.canTouchEfiVariables = true;
initrd.systemd.enable = true;
binfmt.emulatedSystems = [ "aarch64-linux" ];
kernelParams = [ "amd_pstate=active" ];
extraModulePackages = with config.boot.kernelPackages; [
ajantv2
];
} (lib.mkIf (lib.versionOlder config.boot.kernelPackages.kernel.version "6.8") {
kernelParams = [
# Scatter/Gather causes display flickering
"amdgpu.sg_display=0"
# SuspendThenHibernate workaround
"rtc_cmos.use_acpi_alarm=1"
];
})];
my.rundeck.expectedOnline = false;
fileSystems = let
zfs = device: {
device = device;
fsType = "zfs";
};
in {
"/" = zfs "zpool/local/root";
"/nix" = zfs "zpool/local/nix";
"/tmp" = zfs "zpool/local/tmp";
"/var" = zfs "zpool/safe/var";
"/home" = zfs "zpool/safe/home";
"/persist" = zfs "zpool/safe/persist";
"/boot" = {
device = "/dev/disk/by-label/NIXBOOT";
fsType = "vfat";
};
};
nix.settings.max-jobs = lib.mkDefault 12;
powerManagement.cpuFreqGovernor = lib.mkDefault "powersave";
hardware.enableRedistributableFirmware = true;
# Laptop, don't autodeploy.
my.deploy.enable = false;
# ZFS!
services.zfs.rollbackOnBoot.enable = true;
# Enable Podman
virtualisation.podman = {
enable = true;
dockerCompat = true;
};
# Enable LXD
virtualisation.lxd = {
enable = false;
zfsSupport = true;
recommendedSysctlSettings = true;
};
systemd.services.lxd.serviceConfig.path = lib.mkAfter (with pkgs; [
iptables
ebtables
]);
# Enable libvirtd.
virtualisation.libvirtd = {
enable = true;
qemu = {
swtpm.enable = true;
ovmf.packages = [
pkgs.OVMFFull.fd
];
};
};
security.polkit.enable = true;
networking.hostName = "nausicaa";
networking.domain = "int.as205479.net";
networking.hostId = "db370a50";
# Boot faster.
systemd.services.systemd-udev-settle.enable = false;
systemd.services.NetworkManager-wait-online.enable = false;
networking.networkmanager = {
enable = true;
wifi.backend = "iwd";
};
#my.ip.tailscale = "100.125.26.108";
#my.ip.tailscale6 = "fd7a:115c:a1e0:ab12:4843:cd96:627d:1a6c";
# Set your time zone.
time.timeZone = "Europe/London";
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
sbctl
pciutils
deluge
(writeShellScriptBin "windows" ''
set -ue
if [[ $EUID -ne 0 ]]; then
exec sudo "$0" "$@"
fi
efibootmgr -n 0003
systemctl reboot
'')
limesuiteWithGui
srsran
];
services.udev.packages = with pkgs; [
limesuiteWithGui
];
# Enable CUPS to print documents.
services.printing.enable = true;
services.printing.drivers = with depot.pkgs; [ intermec-cups-driver magicard-cups-driver ];
# Enable the X11 windowing system.
services.xserver = {
enable = true;
xkb.layout = "us";
windowManager.i3.enable = true;
videoDrivers = [ "modesetting" ];
};
services.libinput.enable = true;
services.displayManager = {
sddm = {
enable = true;
wayland.enable = true;
settings = {
Users.HideUsers = "deployer";
};
};
defaultSession = "plasma";
};
hardware.graphics.enable32Bit = true;
hardware.acpilight.enable = true;
hardware.bluetooth.enable = true;
hardware.sensor.iio.enable = true;
services.fprintd.enable = true;
services.hardware.openrgb = {
enable = true;
package = pkgs.openrgb-with-all-plugins;
};
services.udev.extraRules = ''
# Ethernet expansion card support
ACTION=="add", SUBSYSTEM=="usb", ATTR{idVendor}=="0bda", ATTR{idProduct}=="8156", ATTR{power/autosuspend}="20"
# RGB ANSI Keyboard
SUBSYSTEMS=="usb", ATTRS{idVendor}=="32ac", ATTRS{idProduct}=="0012", TAG+="uaccess"
# RGB Macropad
SUBSYSTEMS=="usb", ATTRS{idVendor}=="32ac", ATTRS{idProduct}=="0013", TAG+="uaccess"
'';
# Define a user account.
programs.adb.enable = true;
users.users.lukegb = {
extraGroups = [ "wheel" "networkmanager" "libvirtd" "lxd" "video" "dialout" "adbusers" ];
};
my.home-manager.system = {...}: {
home.packages = lib.mkAfter (with pkgs; [
steam
(writeScriptBin "javaws" ''
#!/bin/sh
exec ${depot.nix.pkgs.javaws-env}/bin/javaws-env "$@"
'')
factorio-space-age-experimental
(depot.nix.pkgs.secretsync.configure {
workingDir = "/home/lukegb/depot";
gitlabAccessToken = secrets.deployer.gitlabAccessToken;
manifestVariable = "SECRETS_MANIFEST";
variablesToFile = {
"OPS_SECRETS_DEFAULT_NIX" = "ops/secrets/default.nix";
};
})
efibootmgr
iw
(obs-studio.override { ajaSupport = true; })
vulkan-tools
depot.nix.pkgs.world-of-goo2
yt-dlp
openterface-qt
]);
};
# Things to persist.
services.openssh.hostKeys = [
{
path = "/persist/etc/ssh/ssh_host_ed25519_key";
type = "ed25519";
}
{
path = "/persist/etc/ssh/ssh_host_rsa_key";
type = "rsa";
bits = 4096;
}
];
environment.etc = {
"nixos" = { source = "/persist/etc/nixos/"; };
"secureboot" = { source = "/persist/etc/secureboot/"; };
};
systemd.tmpfiles.rules = [
#"L /etc/nixos - - - - /persist/etc/nixos"
"d /var/lib/libvirt 0755 root - - -"
"d /persist/etc/nixos 0700 root - - -"
"d /persist/etc/secureboot 0700 root - - -"
];
systemd.mounts = let
bindMount' = dir: {
unitConfig.RequiresMountsFor = dir;
options = "bind";
what = "/persist${dir}";
where = dir;
};
bindMountSvc = dir: svc: target: (bindMount' dir) // {
bindsTo = [svc];
partOf = [svc];
before = [svc];
wantedBy = [target];
};
bindMount = dir: (bindMount' dir) // {
wantedBy = ["multi-user.target"];
};
in [
(bindMountSvc "/var/lib/libvirt" "libvirtd.service" "multi-user.target")
(bindMountSvc "/etc/NetworkManager/system-connections" "NetworkManager.service" "network.target")
(bindMount "/root")
];
# Enable Thunderbolt device management.
services.hardware.bolt.enable = true;
services.redis.servers."".enable = true;
services.postgresql.enable = true;
services.postgresql.ensureDatabases = [ "lukegb" ];
services.postgresql.ensureUsers = [{
name = "lukegb";
}];
services.postgresql.authentication = ''
local all all trust
host all all 127.0.0.1/32 trust
host all all ::1/128 trust
'';
hardware.cpu.amd.updateMicrocode = true;
services.power-profiles-daemon.enable = true;
my.scrapeJournal.enable = false; # Laptop, don't pull too much.
services.avahi = {
enable = true;
openFirewall = true;
};
services.lldpd = {
enable = true;
};
my.services.open5gs.enable = true;
my.services.open5gs.webui.secretKeyFile = pkgs.writeText "open5gs-webui-not-so-secret-key" "not-very-secret";
systemd.targets.open5gs.wantedBy = lib.mkForce [];
my.services.seaweedfs.cli = {
enable = true;
settings.cluster = {
default = "rexxar";
rexxar = {
master = "rexxar.int.as205479.net:21000";
};
totoro = {
master = "totoro.int.as205479.net:21000";
};
};
};
services.sysprof.enable = true;
# This value determines the NixOS release with which your system is to be
# compatible, in order to avoid breaking some software such as database
# servers. You should change this only after NixOS release notes say you
# should.
system.stateVersion = "24.05"; # Did you read the comment?
}