133 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Nix
		
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.7 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`).
 | 
						||
 | 
						||
{ config, lib, pkgs, ... }:
 | 
						||
 | 
						||
{
 | 
						||
  imports =
 | 
						||
    [ # Include the results of the hardware scan.
 | 
						||
      ./hardware-configuration.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/Brussels";
 | 
						||
 | 
						||
  # 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;
 | 
						||
 | 
						||
  # 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.
 | 
						||
  # sound.enable = true;
 | 
						||
  # hardware.pulseaudio.enable = true;
 | 
						||
 | 
						||
  # Pipewire
 | 
						||
  security.rtkit.enable = true;
 | 
						||
  services.pipewire = {
 | 
						||
    enable = true;
 | 
						||
    alsa.enable = true;
 | 
						||
    alsa.support32Bit = true;
 | 
						||
    pulse.enable = true;
 | 
						||
    jack.enable = true;
 | 
						||
  };
 | 
						||
 | 
						||
  # Enable touchpad support (enabled default in most desktopManager).
 | 
						||
  # services.xserver.libinput.enable = true;
 | 
						||
 | 
						||
  # Define a user account. Don't forget to set a password with ‘passwd’.
 | 
						||
  users.users.user = {
 | 
						||
    isNormalUser = true;
 | 
						||
    extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user.
 | 
						||
    openssh.authorizedKeys.keys = [
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIKAa3tMzSCRuprEACrBsKI0F/o73o6J9L1qR3TaZn/N8 user@Kell"
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIBxMq4kubz4wWr4S8xU3GRkPcn6XRS3y7IP+qylN5QAp user@Aloria"
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIHtzTFdvLEvXpv69qAWLTipl4hgsKgRrRrWJRecsFthG user@Riva"
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOxtJRtlAphl8euicVUR/6C7o+tyhpYmcbMBLHnldEIX server@mallorea"
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAILazQU/Y9I5PkMZoG/Lzc6mDR7s+aRHzqJoFUhYSse4P PocoF1"
 | 
						||
	"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIFoUYcVMsDw6tmjfdOuQkwaXx8fohKJs/6/5HoLzTP6x Tablet"
 | 
						||
    ];
 | 
						||
    packages = with pkgs; [];
 | 
						||
  };
 | 
						||
 | 
						||
  nix.settings.experimental-features = [ "nix-command" "flakes" ];
 | 
						||
  # List packages installed in system profile. To search, run:
 | 
						||
  # $ nix search wget
 | 
						||
  environment.systemPackages = with pkgs; [
 | 
						||
    vim
 | 
						||
    wget
 | 
						||
    curl
 | 
						||
    git
 | 
						||
  ];
 | 
						||
 | 
						||
 | 
						||
  environment.variables.EDITOR = "vim";
 | 
						||
  # 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;
 | 
						||
 | 
						||
  # 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.
 | 
						||
  #
 | 
						||
  # 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 = "23.11"; # Did you read the comment?
 | 
						||
}
 |