nixos-config/modules/common.nix
2025-03-21 14:21:58 +00:00

74 lines
1.6 KiB
Nix

{ config, pkgs, ... }:
{
# Bootloader: systemd-boot with EFI support
boot = {
loader = {
systemd-boot.enable = true;
efi.canTouchEfiVariables = true;
};
# Enable support for LUKS
initrd = {
luks.devices = {
"root" = {
device = "/dev/sda1"; # Encrypted root partition
preLVM = true;
allowDiscards = true; # Enable if using an SSD with TRIM support
};
};
systemd.enable = true; # Required for LUKS support
availableKernelModules = [ "dm-crypt" "dm-mod" "ext4" ]; # Required for LUKS support
};
# Kernel parameters for root and cryptsetup
kernelParams = [ "root=/dev/mapper/root" "cryptdevice=/dev/sda1:root" ];
};
# File systems
fileSystems."/" = {
device = "/dev/mapper/root"; # LUKS unlocked device
fsType = "ext4";
};
# EFI partition mount (usually /boot or /boot/efi)
fileSystems."/boot" = {
device = "/dev/sda2"; # EFI partition
fsType = "vfat";
options = [ "nofail" "defaults" ];
};
# Swap file (4GB)
swapDevices = [
{
device = "/swapfile";
size = 4096; # 4GB
}
];
# Locale and timezone
time.timeZone = "Europe/London";
i18n.defaultLocale = "en_GB.UTF-8";
# Enable SSH
services.openssh = {
enable = true;
settings = {
PermitRootLogin = "no";
PasswordAuthentication = false;
};
};
# Enable Docker
virtualisation.docker.enable = true;
# PipeWire for audio
services.pipewire = {
enable = true;
pulse.enable = true;
};
# Bluetooth
services.blueman.enable = true;
}