167 lines
		
	
	
	
		
			5.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
	
		
			5.3 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| # Edit this configuration file to define what should be installed on
 | ||
| # your system. Help is available in the configuration.nix(5) man page, on
 | ||
| # https://search.nixos.org/options and in the NixOS manual (`nixos-help`).
 | ||
| {
 | ||
|   lib,
 | ||
|   pkgs,
 | ||
|   ...
 | ||
| }: {
 | ||
|   imports = [
 | ||
|     ./nvidia-drivers.nix
 | ||
|   ];
 | ||
| 
 | ||
|   # Use the systemd-boot EFI boot loader.
 | ||
|   boot.loader.systemd-boot.enable = true;
 | ||
|   boot.loader.efi.canTouchEfiVariables = true;
 | ||
| 
 | ||
|   # networking.hostName = "nixos"; # Define your hostname.
 | ||
|   # Pick only one of the below networking options.
 | ||
|   # networking.wireless.enable = true;  # Enables wireless support via wpa_supplicant.
 | ||
|   # networking.networkmanager.enable = true;  # Easiest to use and most distros use this by default.
 | ||
| 
 | ||
|   # Set your time zone.
 | ||
|   # time.timeZone = "Europe/Amsterdam";
 | ||
| 
 | ||
|   # Configure network proxy if necessary
 | ||
|   # networking.proxy.default = "http://user:password@proxy:port/";
 | ||
|   # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
 | ||
| 
 | ||
|   # Select internationalisation properties.
 | ||
|   # i18n.defaultLocale = "en_US.UTF-8";
 | ||
|   # console = {
 | ||
|   #   font = "Lat2-Terminus16";
 | ||
|   #   keyMap = "us";
 | ||
|   #   useXkbConfig = true; # use xkb.options in tty.
 | ||
|   # };
 | ||
| 
 | ||
|   # Enable the X11 windowing system.
 | ||
|   services.xserver.enable = true;
 | ||
|   # Enable wacom touchscreen device
 | ||
|   services.xserver.wacom.enable = true;
 | ||
| 
 | ||
|   # installed opentabletdriver
 | ||
|   hardware.opentabletdriver.enable = true;
 | ||
|   hardware.keyboard.qmk.enable = true;
 | ||
| 
 | ||
|   # Enable the GNOME Desktop Environment.
 | ||
|   services.displayManager.gdm.enable = true;
 | ||
|   services.desktopManager.gnome.enable = true;
 | ||
| 
 | ||
|   host = {
 | ||
|     ai.enable = true;
 | ||
|     users = {
 | ||
|       eve = {
 | ||
|         isDesktopUser = true;
 | ||
|         isTerminalUser = true;
 | ||
|         isPrincipleUser = true;
 | ||
|       };
 | ||
|     };
 | ||
|     hardware = {
 | ||
|       piperMouse.enable = true;
 | ||
|     };
 | ||
| 
 | ||
|     storage = {
 | ||
|       enable = true;
 | ||
|       pool = {
 | ||
|         mode = "";
 | ||
|         drives = ["wwn-0x5000039fd0cf05eb"];
 | ||
|       };
 | ||
|     };
 | ||
|   };
 | ||
| 
 | ||
|   services.tailscale.enable = true;
 | ||
|   # We were having weird build errors so this is disabled right now
 | ||
|   # error: The option `devices.emergent.folders.eve_records.path' was accessed but has no value defined. Try setting the option
 | ||
|   services.syncthing.enable = false;
 | ||
| 
 | ||
|   # Configure keymap in X11
 | ||
|   # services.xserver.xkb.layout = "us";
 | ||
|   # services.xserver.xkb.options = "eurosign:e,caps:escape";
 | ||
| 
 | ||
|   # Enable CUPS to print documents.
 | ||
|   # services.printing.enable = true;
 | ||
| 
 | ||
|   # Enable sound.
 | ||
|   # services.pulseaudio.enable = true;
 | ||
|   # OR
 | ||
|   # services.pipewire = {
 | ||
|   #   enable = true;
 | ||
|   #   pulse.enable = true;
 | ||
|   # };
 | ||
| 
 | ||
|   # Enable touchpad support (enabled default in most desktopManager).
 | ||
|   # services.libinput.enable = true;
 | ||
| 
 | ||
|   # Define a user account. Don't forget to set a password with ‘passwd’.
 | ||
|   # users.users.alice = {
 | ||
|   #   isNormalUser = true;
 | ||
|   #   extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user.
 | ||
|   #   packages = with pkgs; [
 | ||
|   #     tree
 | ||
|   #   ];
 | ||
|   # };
 | ||
| 
 | ||
|   # programs.firefox.enable = true;
 | ||
| 
 | ||
|   nixpkgs.config.allowUnfree = true;
 | ||
| 
 | ||
|   # Packages that can be installed without any extra configuration
 | ||
|   # See https://search.nixos.org/packages for all options
 | ||
|   environment.systemPackages = with pkgs; [
 | ||
|     wget
 | ||
|   ];
 | ||
| 
 | ||
|   # Packages that need to be installed with some extra configuration
 | ||
|   # See https://search.nixos.org/options for all options
 | ||
|   programs = {};
 | ||
| 
 | ||
|   # Some programs need SUID wrappers, can be configured further or are
 | ||
|   # started in user sessions.
 | ||
|   # programs.mtr.enable = true;
 | ||
|   # programs.gnupg.agent = {
 | ||
|   #   enable = true;
 | ||
|   #   enableSSHSupport = true;
 | ||
|   # };
 | ||
| 
 | ||
|   # List services that you want to enable:
 | ||
| 
 | ||
|   # Enable the OpenSSH daemon.
 | ||
|   # services.openssh.enable = true;
 | ||
| 
 | ||
|   # Open ports in the firewall.
 | ||
|   # networking.firewall.allowedTCPPorts = [ ... ];
 | ||
|   # networking.firewall.allowedUDPPorts = [ ... ];
 | ||
|   # Or disable the firewall altogether.
 | ||
|   # networking.firewall.enable = false;
 | ||
| 
 | ||
|   networking = {
 | ||
|     networkmanager.enable = true;
 | ||
|     useDHCP = lib.mkDefault true;
 | ||
|     hostId = "7e35eb97"; # arbitrary id number generated via this command: `head -c4 /dev/urandom | od -A none -t x4`
 | ||
|     hostName = "emergent"; # Define your hostname.
 | ||
|   };
 | ||
| 
 | ||
|   # Copy the NixOS configuration file and link it from the resulting system
 | ||
|   # (/run/current-system/configuration.nix). This is useful in case you
 | ||
|   # accidentally delete configuration.nix.
 | ||
|   # system.copySystemConfiguration = true;
 | ||
| 
 | ||
|   # This option defines the first version of NixOS you have installed on this particular machine,
 | ||
|   # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions.
 | ||
|   #
 | ||
|   # Most users should NEVER change this value after the initial install, for any reason,
 | ||
|   # even if you've upgraded your system to a new NixOS release.
 | ||
|   #
 | ||
|   # This value does NOT affect the Nixpkgs version your packages and OS are pulled from,
 | ||
|   # so changing it will NOT upgrade your system - see https://nixos.org/manual/nixos/stable/#sec-upgrading for how
 | ||
|   # to actually do that.
 | ||
|   #
 | ||
|   # This value being lower than the current NixOS release does NOT mean your system is
 | ||
|   # out of date, out of support, or vulnerable.
 | ||
|   #
 | ||
|   # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration,
 | ||
|   # and migrated your data accordingly.
 | ||
|   #
 | ||
|   # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion .
 | ||
|   system.stateVersion = "25.05"; # Did you read the comment?
 | ||
| }
 |