# Custom desktop with AMD Ryzen 5 2600, 16GB RAM, AMD Rx 6700, and 1TB SSD + 2TB HDD. { config, lib, pkgs, ... }: let archiveDirectory = "/mnt/Archive"; domain = "raffauflabs.com"; mediaDirectory = "/mnt/Media"; in { imports = [ ./filesystems.nix ./hardware.nix ./home.nix ]; age.secrets = { cloudflare.file = ../../secrets/cloudflare.age; lastfmId = { owner = "navidrome"; file = ../../secrets/lastFM/apiKey.age; }; lastfmSecret = { owner = "navidrome"; file = ../../secrets/lastFM/secret.age; }; spotifyId = { owner = "navidrome"; file = ../../secrets/spotify/clientId.age; }; spotifySecret = { owner = "navidrome"; file = ../../secrets/spotify/clientSecret.age; }; }; boot.loader = { efi.canTouchEfiVariables = true; systemd-boot.enable = true; }; networking.hostName = "mauville"; services = { samba = { enable = true; openFirewall = true; securityType = "user"; shares = { Media = { browseable = "yes"; comment = "Media @ ${config.networking.hostName}"; path = mediaDirectory; "read only" = "no"; "guest ok" = "yes"; "create mask" = "0755"; "directory mask" = "0755"; }; Archive = { browseable = "yes"; comment = "Archive @ ${config.networking.hostName}"; path = archiveDirectory; "create mask" = "0755"; "directory mask" = "0755"; "guest ok" = "yes"; "read only" = "no"; }; }; }; samba-wsdd = { enable = true; openFirewall = true; }; }; system.stateVersion = "23.11"; ar = { apps = { firefox.enable = true; nicotine-plus.enable = true; podman.enable = true; steam.enable = true; virt-manager.enable = true; }; base = { enable = true; zramSwap.size = 100; }; desktop = { greetd = { enable = true; autologin = { enable = true; user = "aly"; }; }; hyprland.enable = true; steam.enable = true; }; users = { aly = { enable = true; password = "$y$j9T$SHPShqI2IpRE101Ey2ry/0$0mhW1f9LbVY02ifhJlP9XVImge9HOpf23s9i1JFLIt9"; }; dustin = { enable = true; password = "$y$j9T$3mMCBnUQ.xjuPIbSof7w0.$fPtRGblPRSwRLj7TFqk1nzuNQk2oVlgvb/bE47sghl."; }; }; services = { syncthing = { enable = true; syncMusic = true; musicPath = "${mediaDirectory}/Music"; }; tailscale.enable = true; }; }; raffauflabs = { inherit domain; enable = true; containers = { oci = { audiobookshelf.enable = true; freshRSS.enable = true; plexMediaServer.enable = true; transmission.enable = true; }; }; services = { ddclient = { enable = true; passwordFile = config.age.secrets.cloudflare.path; protocol = "cloudflare"; }; forgejo.enable = true; navidrome = { enable = true; lastfm = { idFile = config.age.secrets.lastfmId.path; secretFile = config.age.secrets.lastfmSecret.path; }; spotify = { idFile = config.age.secrets.spotifyId.path; secretFile = config.age.secrets.spotifySecret.path; }; }; }; }; }