Files
nix-config/systems/x86_64-linux/matt-nixos/default.nix
2026-03-26 10:30:40 -05:00

139 lines
3.7 KiB
Nix

# Snowfall Lib provides a customized `lib` instance with access to your flake's library
{
# as well as the libraries available from your flake's inputs.
lib,
# # An instance of `pkgs` with your overlays and packages applied is also available.
# pkgs,
# # You also have access to your flake's inputs.
# inputs,
# Additional metadata is provided by Snowfall Lib.
namespace, # The namespace used for your flake, defaulting to "internal" if not set.
# system, # The system architecture for this host (eg. `x86_64-linux`).
# target, # The Snowfall Lib target for this system (eg. `x86_64-iso`).
# format, # A normalized name for the system target (eg. `iso`).
# virtual, # A boolean to determine whether this system is a virtual target using nixos-generators.
# systems, # An attribute map of your defined hosts.
# All other arguments come from the system system.
...
}:
{
imports = [
./boot.nix
./filesystems.nix
./sops.nix
./services/lsfg-vk
./services/ratbagd
./services/restic
];
${namespace} = {
headless.enable = false;
sops.enable = true;
bootloader.lanzaboote.enable = true;
desktop = {
hyprland = {
enable = false;
wallpaperSource = "bing";
};
gnome = {
enable = true;
vscodium.enable = true;
};
};
gaming.enable = true;
hardware = {
disko = {
enable = true;
enableLuks = true;
};
amd = {
enable = true;
lact.enable = true;
coolercontrol.enable = true;
};
};
impermanence = {
enable = true;
# extraDirectories = [
# {
# directory = "/var/cache/ccache";
# user = "nobody";
# group = "nobody";
# mode = "u=rwx,g=rwx,o=rx";
# }
# ];
};
network = {
hostName = "matt-nixos";
iwd.enable = true;
networkmanager.enable = true;
};
services = {
nebula = {
enable = true;
secretsPrefix = "matt-nixos/nebula";
secretsFile = lib.snowfall.fs.get-file "secrets/desktop-secrets.yaml";
hostSecretName = "matt-nixos";
};
};
};
# security.wrappers.librepods = {
# source = "${pkgs.${namespace}.librepods}/bin/librepods";
# owner = "matt";
# group = "users";
# setuid = false;
# capabilities = "cap_net_admin+p";
# };
specialisation = {
#"linux_cachyos-rc-lto".configuration = {
# boot = {
# kernelPackages = lib.mkOverride 90 pkgs.${namespace}.linuxPackages_cachyos-rc-lto-znver4;
# };
#};
"plasma" = {
configuration = {
${namespace} = {
sops.enable = true;
desktop = {
plasma.enable = lib.mkForce true;
hyprland.enable = lib.mkForce false;
gnome.enable = lib.mkForce false;
};
home.extraOptions = {
${namespace} = {
desktop = {
gnome = lib.mkForce { enable = false; };
plasma = lib.mkForce { enable = true; };
};
programs = {
hyprland = lib.mkForce { enable = false; };
kitty = lib.mkForce { enable = false; };
mako = lib.mkForce { enable = false; };
nwg-dock = lib.mkForce { enable = false; };
nwg-drawer = lib.mkForce { enable = false; };
nwg-panel = lib.mkForce { enable = false; };
waybar = lib.mkForce { enable = false; };
wlogout = lib.mkForce { enable = false; };
wofi = lib.mkForce { enable = false; };
};
};
};
};
};
};
};
}