2025-06-07 17:02:29 +03:00
|
|
|
{
|
|
|
|
config,
|
|
|
|
pkgs,
|
|
|
|
...
|
|
|
|
}:
|
2025-06-07 16:58:34 +03:00
|
|
|
let
|
|
|
|
defaultUser = config.ataraxia.defaults.users.defaultUser;
|
|
|
|
in
|
|
|
|
{
|
|
|
|
imports = [
|
|
|
|
./hardware-configuration.nix
|
|
|
|
./boot.nix
|
|
|
|
];
|
|
|
|
|
|
|
|
ataraxia.defaults.role = "desktop";
|
2025-06-07 17:33:23 +03:00
|
|
|
ataraxia.defaults.hardware.cpuVendor = "amd";
|
|
|
|
ataraxia.defaults.hardware.gpuVendor = "amd";
|
2025-06-07 16:58:34 +03:00
|
|
|
# Impermanence
|
|
|
|
ataraxia.filesystems.zfs.enable = true;
|
|
|
|
ataraxia.filesystems.zfs.eraseOnBoot.enable = true;
|
|
|
|
ataraxia.filesystems.zfs.eraseOnBoot.snapshots = [
|
|
|
|
"rpool/nixos/root@empty"
|
|
|
|
"rpool/user/home@empty"
|
|
|
|
];
|
|
|
|
ataraxia.filesystems.zfs.mountpoints = [
|
|
|
|
"/etc/secrets"
|
|
|
|
"/media/libvirt"
|
|
|
|
"/nix"
|
|
|
|
"/persist"
|
|
|
|
"/srv"
|
|
|
|
"/var/lib/ccache"
|
|
|
|
"/var/lib/containers"
|
|
|
|
"/var/lib/docker"
|
|
|
|
"/var/lib/libvirt"
|
|
|
|
"/var/lib/postgresql"
|
|
|
|
"/var/log"
|
|
|
|
"/vol"
|
|
|
|
];
|
|
|
|
|
2025-06-07 17:21:28 +03:00
|
|
|
ataraxia.networkd = {
|
|
|
|
enable = true;
|
|
|
|
ifname = "enp8s0";
|
|
|
|
mac = "60:45:cb:a0:15:11";
|
|
|
|
bridge.enable = true;
|
|
|
|
ipv4 = [
|
|
|
|
{
|
|
|
|
address = "10.10.10.100/24";
|
|
|
|
gateway = "10.10.10.1";
|
|
|
|
dns = [
|
|
|
|
"10.10.10.1"
|
|
|
|
"9.9.9.9"
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2025-06-07 16:58:34 +03:00
|
|
|
# Home-manager
|
|
|
|
home-manager.users.${defaultUser} = {
|
|
|
|
ataraxia.defaults.role = "desktop";
|
2025-06-07 17:20:39 +03:00
|
|
|
|
|
|
|
persist.state.directories = [
|
|
|
|
".config/sops/age"
|
|
|
|
"nixos-config"
|
|
|
|
"projects"
|
|
|
|
];
|
|
|
|
|
2025-06-07 16:58:34 +03:00
|
|
|
home.stateVersion = "25.05";
|
|
|
|
};
|
|
|
|
|
|
|
|
# Services
|
|
|
|
services.postgresql.settings = {
|
|
|
|
full_page_writes = "off";
|
|
|
|
wal_init_zero = "off";
|
|
|
|
wal_recycle = "off";
|
|
|
|
};
|
2025-06-07 17:29:25 +03:00
|
|
|
ataraxia.vpn.sing-box.enable = true;
|
|
|
|
ataraxia.vpn.sing-box.config = "ataraxia-singbox";
|
|
|
|
services.tailscale = {
|
|
|
|
enable = true;
|
|
|
|
useRoutingFeatures = "client";
|
|
|
|
};
|
2025-06-07 16:58:34 +03:00
|
|
|
|
2025-06-07 17:02:29 +03:00
|
|
|
# Mesa from unstable channel
|
|
|
|
hardware.graphics.package = pkgs.mesaUnstable;
|
|
|
|
hardware.graphics.package32 = pkgs.mesaUnstablei686;
|
|
|
|
programs.hyprland.package = pkgs.hyprlandUnstable;
|
|
|
|
programs.hyprland.portalPackage = pkgs.hyprlandPortalUnstable;
|
|
|
|
|
2025-06-07 16:58:34 +03:00
|
|
|
# Auto-mount lan nfs share
|
|
|
|
fileSystems = {
|
|
|
|
"/media/files" = {
|
|
|
|
fsType = "ntfs";
|
|
|
|
device = "/dev/disk/by-partuuid/15fa11a1-a6d8-4962-9c03-74b209d7c46a";
|
|
|
|
options = [
|
|
|
|
"nofail"
|
|
|
|
"uid=${toString config.users.users.${defaultUser}.uid}"
|
|
|
|
"gid=${toString config.users.groups.users.gid}"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
"/media/win-sys" = {
|
|
|
|
fsType = "ntfs";
|
|
|
|
device = "/dev/disk/by-partuuid/4fba33e7-6b47-4e3b-b18b-882a58032673";
|
|
|
|
options = [
|
|
|
|
"nofail"
|
|
|
|
"uid=${toString config.users.users.${defaultUser}.uid}"
|
|
|
|
"gid=${toString config.users.groups.users.gid}"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
"/media/local-nfs" = {
|
|
|
|
device = "10.10.10.11:/";
|
|
|
|
fsType = "nfs4";
|
|
|
|
options = [
|
|
|
|
"nfsvers=4.2"
|
|
|
|
"x-systemd.automount"
|
|
|
|
"noauto"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
system.stateVersion = "25.05";
|
|
|
|
}
|