{ mainUser, self, ... }: { # ------------------------------------------------ # Imports # ------------------------------------------------ imports = [ ./hardware-configuration.nix ./modules self.nixosModules.base self.nixosModules.docker self.nixosModules.kmscon self.nixosModules.meta self.nixosModules.server ]; # State Version: DO NOT CHANGE system.stateVersion = "24.05"; # ------------------------------------------------ # User Settings # ------------------------------------------------ users.users = { ${mainUser} = { isNormalUser = true; extraGroups = [ "wheel" "adm" ]; }; # https://nixos.wiki/wiki/Distributed_build nixremote = { isNormalUser = true; createHome = true; home = "/var/lib/nixremote"; homeMode = "500"; openssh.authorizedKeys.keys = [ "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGOujvC5JLnyjqD1bzl/H0256Gxw/biu7spIHy3YJiDL" ]; }; }; networking = { hostName = "servivi"; resolvconf.enable = true; firewall.enable = false; }; time.timeZone = "America/Montreal"; # ------------------------------------------------ # `Self` Modules configuration # ------------------------------------------------ meta = { roleDescription = "Gaming PC in a previous life, it is now used as a build farm and hosts game servers"; hardwareDescription = "Headless Ryzen 5 3600"; }; roles.base = { enable = true; user = mainUser; }; roles.server = { enable = true; user = mainUser; tailscale.enable = true; sshd.enable = true; }; khepri.enable = true; services.kmscon.enable = true; home-manager.users.${mainUser} = { imports = [ self.homeManagerModules.neovim self.homeManagerModules.shell ]; programs = { bash = { enable = true; promptMainColor = "blue"; }; neovim = { enable = true; user = mainUser; }; }; }; }