{ config, pkgs, ... }: { imports = [ ]; boot.loader.systemd-boot.enable = true; boot.loader.efi.canTouchEfiVariables = true; networking.hostName = "alex-desktop"; nix.settings.experimental-features = [ "nix-command" "flakes" ]; networking.networkmanager.enable = true; time.timeZone = "America/Denver"; i18n.defaultLocale = "en_US.UTF-8"; i18n.extraLocaleSettings = { LC_ADDRESS = "en_US.UTF-8"; LC_IDENTIFICATION = "en_US.UTF-8"; LC_MEASUREMENT = "en_US.UTF-8"; LC_MONETARY = "en_US.UTF-8"; LC_NAME = "en_US.UTF-8"; LC_NUMERIC = "en_US.UTF-8"; LC_PAPER = "en_US.UTF-8"; LC_TELEPHONE = "en_US.UTF-8"; LC_TIME = "en_US.UTF-8"; }; services.xserver.enable = true; services.displayManager.gdm.enable = true; services.desktopManager.gnome.enable = true; systemd.targets.sleep.enable = false; systemd.targets.suspend.enable = false; systemd.targets.hibernate.enable = false; systemd.targets.hybrid-sleep.enable = false; services.xserver.xkb = { layout = "us"; variant = ""; }; services.printing.enable = true; services.pulseaudio.enable = false; security.rtkit.enable = true; services.pipewire = { enable = true; alsa.enable = true; alsa.support32Bit = true; pulse.enable = true; wireplumber = { enable = true; extraConfig = { "disable-x11" = { "wireplumber.settings" = { "support.x11" = false; }; }; }; }; }; users.users.alex = { isNormalUser = true; description = "alex"; extraGroups = [ "networkmanager" "wheel" "docker" "libvirtd" "adbusers" "kvm" ]; shell = pkgs.fish; packages = with pkgs; [ ]; }; home-manager.users.alex = { pgks, ...}: { home.stateVersion = "24.11"; imports = [ ./home-manager/alex.home.nix ./home-manager/desktop.home.nix ]; }; home-manager.useGlobalPkgs = true; home-manager.backupFileExtension = "backup"; programs.firefox.enable = true; services.fwupd.enable = true; hardware.enableAllFirmware = true; hardware.firmware = with pkgs; [ linux-firmware ]; programs.nix-ld.enable = true; nixpkgs.config.allowUnfree = true; environment.systemPackages = with pkgs; [ vim wget curl docker fish git zfs gcc-unwrapped iputils tmux libguestfs-with-appliance iperf mangohud mlocate kdePackages.kdeconnect-kde # wineWowPackages.stable # wine # (wine.override { wineBuild = "wine64"; }) # wine64 # wineWowPackages.staging # winetricks # wineWowPackages.waylandFull # mesa-gl-headers # mesa # driversi686Linux.mesa # mesa-demos ]; services.tailscale.enable = true; services.openssh.enable = true; virtualisation.docker.enable = true; virtualisation.libvirtd.enable = true; programs.virt-manager.enable = true; programs.fish.enable = true; services.flatpak.enable = true; hardware.steam-hardware.enable = true; networking.firewall.enable = false; hardware.graphics = { enable32Bit = true; enable = true; }; fileSystems."/steam-data" = { device = "/dev/disk/by-uuid/437358fd-b9e4-46e2-bd45-f6b368acaac1"; fsType = "ext4"; }; boot.supportedFilesystems = [ "zfs" ]; boot.zfs.forceImportRoot = false; networking.hostId = "eafe9999"; boot.zfs.extraPools = [ "data" "data2" ]; systemd.timers."nix-garbage-collect-weekly" = { wantedBy = [ "timers.target" ]; timerConfig = { OnCalendar = "weekly"; Persistent = true; }; }; systemd.services."nix-garbage-collect-weekly" = { serviceConfig = { Type = "oneshot"; ExecStart = "/run/current-system/sw/bin/nix-collect-garbage --delete-older-than 7d"; }; }; # fingerprint # services.fprintd = { # enable = true; # package = pkgs.fprintd.override { # libfprint = pkgs.libfprint; # }; # }; # services.gnome.gnome-keyring.enable = true; # security.polkit.enable = true; # security.pam.services.gdm.fprintAuth = true; # security.pam.services.gdm.enableGnomeKeyring = true; # security.pam.services.sudo.fprintAuth = true; # services.udev.extraRules = '' # ACTION=="add", SUBSYSTEM=="usb", ATTR{idVendor}=="04f3", ATTR{idProduct}=="0c3d", TEST=="power/control", ATTR{power/control}="on" # ''; # This value determines the NixOS release from which the default # settings for stateful data, like file locations and database versions # on your system were taken. It‘s perfectly fine and recommended to leave # this value at the release version of the first install of this system. # Before changing this value read the documentation for this option # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). system.stateVersion = "24.11"; # Did you read the comment? }