{ config, self, ... }: let inherit (config.vars) mainUser; in { # ------------------------------------------------ # Imports # ------------------------------------------------ imports = [ ./hardware-configuration.nix ./modules self.nixosModules.docker self.nixosModules.kmscon self.nixosModules.server ]; home-manager.users = rec { root = { imports = [ self.homeManagerModules.neovim ]; programs.neovim = { enable = true; enableIde = true; user = mainUser; }; }; ${mainUser} = root; }; # State Version: DO NOT CHANGE system.stateVersion = "24.11"; # ------------------------------------------------ # User Settings # ------------------------------------------------ vars = { mainUser = "matt"; promptMainColor = "yellow"; }; users.users.${mainUser} = { isNormalUser = true; extraGroups = [ "wheel" "adm" ]; }; networking = { hostName = "homie"; resolvconf.enable = true; firewall.enable = false; }; time.timeZone = "America/Montreal"; # ------------------------------------------------ # `Self` Modules configuration # ------------------------------------------------ roles.server = { user = mainUser; tailscale.enable = true; sshd.enable = true; }; khepri.enable = true; services.kmscon.enable = true; }