nixdots/hosts/voyager/default.nix

130 lines
3 KiB
Nix
Raw Normal View History

2024-06-19 14:10:37 +00:00
# Edit this configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page, on
# https://search.nixos.org/options and in the NixOS manual (`nixos-help`).
{ config, lib, pkgs, ... }:
{
imports =
[ # Include the results of the hardware scan.
./hardware-configuration.nix
];
boot.supportedFilesystems = [ "btrfs" ];
hardware.enableAllFirmware = true;
# My flake disables this by default for security reasons. However, with an encrypted setup,
# which requires entering password before booting anyways, this is not a security concern, and
# changing kernel params can be useful sometimes for debugging
boot.loader.systemd-boot.editor = true;
# CPU usage configuration for nix
nix.settings = {
max-jobs = 8;
cores = 6;
};
# NixOS release from which this machine was first installed
# (for stateful data, like file locations and db versions)
# Leave this alone!
system.stateVersion = "24.05";
myOptions = {
system = {
hostname = "voyager";
username = "itsdrike";
sound.enable = true;
bluetooth.enable = true;
2024-06-19 14:54:20 +00:00
impermanence = {
root = {
enable = true;
# Some people use /nix/persist/system for this, leaving persistent files in /nix subvolume
# I much prefer using a standalone subvolume for this though.
persistentMountPoint = "/persist";
2024-06-19 15:15:53 +00:00
extraDirectories = [
"/var/log"
];
2024-06-19 14:54:20 +00:00
};
2024-06-19 15:41:40 +00:00
home = {
enable = true;
persistentMountPoint = "/persist/home";
extraDirectories = [
"Downloads"
"Personal"
"Media"
"dots"
".local/share/gnupg"
".local/share/wakatime"
".local/share/nvim"
".local/state/nvim"
".local/share/zsh"
".local/cargo"
".local/go"
];
extraFiles = [
".config/git/git-credentials"
];
};
2024-06-19 14:54:20 +00:00
# Configure automatic root subvolume wiping on boot from initrd
autoWipeBtrfs = {
enable = true;
2024-06-19 16:11:37 +00:00
devices."/dev/disk/by-label/NIXOS-FS".subvolumes = [ "root" ];
2024-06-19 14:54:20 +00:00
};
};
2024-06-19 14:10:37 +00:00
};
device = {
roles = {
type = "laptop";
virtual-machine = false;
};
cpu.type = "amd";
2024-06-19 14:27:57 +00:00
gpu.type = "amd";
2024-06-19 14:10:37 +00:00
hasTPM = true;
};
security = {
auditd = {
enable = true;
2024-06-19 17:05:50 +00:00
autoPrune.enable = true;
2024-06-19 14:10:37 +00:00
};
};
workstation = {
printing.enable = true;
};
home-manager = {
enable = true;
stateVersion = "24.05";
git = {
userName = "ItsDrike";
userEmail = "itsdrike@protonmail.com";
signing = {
enable = true;
key = "FA2745890B7048C0";
};
};
wms.hyprland = {
enable = true;
monitor = [
"eDP-1, 1920x1080@60, 0x0, 1"
];
};
programs = {
spotify.enable = true;
};
};
};
}