nixos-config/hosts/eddie/configuration.nix

519 lines
12 KiB
Nix
Raw Normal View History

2025-02-08 22:48:41 -05:00
{
nix-config,
config,
pkgs,
inputs,
...
}:
2024-09-22 01:04:11 -04:00
{
2025-02-04 10:21:52 -05:00
2025-02-08 22:48:41 -05:00
imports = with nix-config.nixosModules; [
./hardware-configuration.nix
./razer-speaker-fix.nix
2025-02-05 00:50:55 -05:00
2025-02-16 16:24:34 -05:00
sops-config
2025-02-08 22:48:41 -05:00
niri
2025-02-16 16:24:34 -05:00
kanata
filesystems
2025-02-16 16:39:10 -05:00
sound
2025-02-08 22:48:41 -05:00
];
2024-09-22 01:04:11 -04:00
2024-12-31 12:05:58 -05:00
nixpkgs = {
config = {
allowUnfree = true;
};
2025-02-08 22:48:41 -05:00
overlays = builtins.attrValues nix-config.overlays ++ [
inputs.niri.overlays.niri
inputs.emacs-overlay.overlays.default
inputs.audio.overlays.default
inputs.nix-rice.overlays.default
2025-02-09 20:20:17 -05:00
(final: prev: {
wineWowPackages.stagingFull = nix-config.pkgs-stable.wineWowPackages.stagingFull.overrideAttrs (old: {
patches = old.patches ++ [ ../../patches/wine-6006.patch ];
waylandSupport = true;
fontconfigSupport = true;
vulkanSupport = true;
});
})
2025-02-08 22:48:41 -05:00
];
2024-12-31 12:05:58 -05:00
};
2025-02-04 10:21:52 -05:00
nix = {
2024-12-31 12:05:58 -05:00
settings = {
2025-02-08 22:48:41 -05:00
experimental-features = [
"nix-command"
"flakes"
];
substituters = [
"https://nix-community.cachix.org"
"https://cache.garnix.io"
];
2025-02-04 10:21:52 -05:00
trusted-public-keys = [
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
2025-02-04 20:58:42 -05:00
"cache.garnix.io:CTFPyKSLcx5RMJKfLo5EEPUObbA78b0YQ2DTCJXqr9g="
2025-02-04 10:21:52 -05:00
];
};
};
2025-02-16 16:24:34 -05:00
# Set your time zone.
time.timeZone = "America/Toronto";
2025-02-16 16:24:34 -05:00
# Select internationalisation properties.
i18n.defaultLocale = "en_CA.UTF-8";
2024-10-02 18:35:14 -04:00
environment.systemPackages = with pkgs; [
wget
2024-11-18 10:54:45 -05:00
libGL
2024-10-02 18:35:14 -04:00
home-manager
curl
git-lfs
tailscale
rsync
gnupg
clinfo
2024-10-05 12:36:08 -04:00
alsa-utils
alsa-oss
2024-10-28 17:34:14 -04:00
psutils
2024-10-07 23:39:25 -04:00
util-linux
2024-10-18 09:11:27 -04:00
libgtop
2024-10-28 17:34:14 -04:00
fontconfig
2024-11-06 14:33:49 -05:00
freetype
2024-11-18 10:54:45 -05:00
egl-wayland
glfw-wayland
2024-11-22 16:26:46 -05:00
openssl
appimage-run
2025-01-26 00:19:35 -05:00
xwayland-satellite
xwayland-run
2025-02-11 19:35:11 -05:00
cifs-utils
2025-02-14 16:37:28 -05:00
ddcutil
ddcui
2024-10-02 18:35:14 -04:00
];
2024-09-23 23:35:58 -04:00
# Bootloader.
2024-10-02 18:35:14 -04:00
boot = {
2025-01-19 16:00:05 -05:00
loader = {
systemd-boot.enable = true;
systemd-boot.configurationLimit = 8;
efi.canTouchEfiVariables = true;
};
2025-02-04 13:13:24 -05:00
kernelPackages = pkgs.linuxPackages_latest;
2025-02-19 12:37:50 -05:00
kernelModules = [ "i2c-dev" "ddcci-backlight" "amd_3d_vcache" "uinput" ];
2025-02-14 17:37:01 -05:00
extraModulePackages = with config.boot.kernelPackages; [ ddcci-driver ];
initrd.systemd.enable = true;
2025-02-08 22:48:41 -05:00
initrd.kernelModules = [
"nvidia"
"nvidia_modeset"
"nvidia_uvm"
"nvidia_drm"
"snd-virmidi"
];
kernelParams = [
"nvidia_drm.fbdev=1"
"nvidia_drm.modeset=1"
];
2024-09-24 16:11:23 -04:00
};
2025-02-08 22:48:41 -05:00
systemd.services.tailscaled.after = [ "NetworkManager-wait-online.service" ];
systemd.sleep.extraConfig = ''
2025-02-08 22:48:41 -05:00
HibernateDelaySec=2h
'';
2024-10-02 18:35:14 -04:00
2025-01-13 15:26:20 -05:00
documentation = {
dev.enable = true;
2025-02-04 10:21:52 -05:00
man.generateCaches = true;
2025-01-13 15:26:20 -05:00
};
2024-09-24 16:11:23 -04:00
hardware = {
2025-02-14 16:37:28 -05:00
i2c.enable = true;
2025-02-19 12:37:50 -05:00
uinput.enable = true;
2024-10-07 23:39:25 -04:00
openrazer = {
enable = true;
users = [ "emenel" ];
};
2024-10-02 18:35:14 -04:00
graphics = {
enable = true;
enable32Bit = true;
extraPackages = [
2024-10-04 10:35:41 -04:00
pkgs.rocmPackages.clr.icd
2024-11-22 16:26:46 -05:00
pkgs.amdvlk
];
extraPackages32 = [
pkgs.driversi686Linux.amdvlk
2024-10-02 18:35:14 -04:00
];
};
2024-09-24 16:11:23 -04:00
2024-10-01 16:57:09 -04:00
enableAllFirmware = true;
2025-01-19 16:00:05 -05:00
firmware = [
pkgs.sof-firmware
pkgs.alsa-firmware
];
2024-10-01 16:57:09 -04:00
2024-09-24 16:11:23 -04:00
nvidia = {
2024-11-22 16:26:46 -05:00
open = true;
# Modesetting is required.
2024-09-24 16:11:23 -04:00
modesetting.enable = true;
powerManagement.enable = true;
2024-09-26 22:00:05 -04:00
powerManagement.finegrained = true;
2024-09-24 16:11:23 -04:00
2025-01-08 19:04:23 -05:00
# forceFullCompositionPipeline = true;
2024-09-24 16:11:23 -04:00
2024-11-29 12:28:08 -05:00
package = config.boot.kernelPackages.nvidiaPackages.beta;
2024-09-24 16:11:23 -04:00
prime = {
2024-11-18 10:54:45 -05:00
amdgpuBusId = "PCI:101:0:0";
2024-11-15 13:32:58 -05:00
nvidiaBusId = "PCI:1:0:0";
2024-09-24 16:11:23 -04:00
offload = {
enable = true;
enableOffloadCmd = true;
};
#reverseSync.enable = true;
#sync.enable = true;
};
nvidiaSettings = true;
};
2025-02-14 14:52:10 -05:00
brillo.enable = true;
2024-09-24 16:11:23 -04:00
};
services.fstrim.enable = true;
services.logind = {
extraConfig = ''
2025-02-08 22:48:41 -05:00
IdleAction=lock
2025-02-14 17:37:01 -05:00
IdleActionSec=15m
'';
};
services.udev = {
extraRules = ''
2025-02-19 12:37:50 -05:00
KERNEL=="uinput", MODE="0660", GROUP="uinput", OPTIONS+="static_node=uinput"
2025-02-08 22:48:41 -05:00
DEVPATH=="/devices/virtual/misc/cpu_dma_latency", OWNER="root", GROUP="audio", MODE="0660"
2025-02-14 16:37:28 -05:00
ACTION=="add", SUBSYSTEM=="backlight", KERNEL=="ddcci*", RUN+="${pkgs.coreutils-full}/bin/chgrp video /sys/class/backlight/%k/brightness"
ACTION=="add", SUBSYSTEM=="backlight", KERNEL=="ddcci*", RUN+="${pkgs.coreutils-full}/bin/chmod a+w /sys/class/backlight/%k/brightness"
2025-02-16 16:24:34 -05:00
ACTION=="add", SUBSYSTEM=="i2c-dev", ATTR{name}=="AMDGPU DM*", TAG+="ddcci", TAG+="systemd", ENV{SYSTEMD_WANTS}+="ddcci@$kernel.service"
2025-02-14 16:37:28 -05:00
ACTION=="add", SUBSYSTEM=="i2c-dev", ATTR{name}=="NVIDIA i2c adapter*", TAG+="ddcci", TAG+="systemd", ENV{SYSTEMD_WANTS}+="ddcci@$kernel.service"
2025-02-16 16:24:34 -05:00
SUBSYSTEM=="i2c", ACTION=="add", ATTR{name}=="AMDGPU DM aux hw bus 3", RUN+="${pkgs.bash}/bin/bash -c 'sleep 30; printf ddcci\ 0x37 > /sys/bus/i2c/devices/i2c-17/new_device'"
2025-02-08 22:48:41 -05:00
'';
packages = [
pkgs.via
pkgs.vial
2025-02-14 16:37:28 -05:00
pkgs.ddcutil
(pkgs.writeTextFile {
name = "on-battery";
text = ''
2025-02-08 22:48:41 -05:00
# Rule for when switching to battery
SUBSYSTEM=="power_supply", ENV{POWER_SUPPLY_ONLINE}=="0", RUN+="${pkgs.power-profiles-daemon}/bin/powerprofilesctl set balanced"
'';
destination = "/etc/udev/rules.d/60-onbattery.rules";
})
(pkgs.writeTextFile {
name = "on-power";
text = ''
2025-02-08 22:48:41 -05:00
# Rule for when switching to ac
SUBSYSTEM=="power_supply", ENV{POWER_SUPPLY_ONLINE}=="1", RUN+="${pkgs.power-profiles-daemon}/bin/powerprofilesctl set performance"
'';
destination = "/etc/udev/rules.d/61-onpower.rules";
})
(pkgs.writeTextFile {
name = "hibernate-low-battery";
text = ''
2025-02-08 22:48:41 -05:00
# Suspend the system when battery level drops to 5% or lower
SUBSYSTEM=="power_supply", ATTR{status}=="Discharging", ATTR{capacity}=="[0-5]", RUN+="${pkgs.systemd}/bin/systemctl hibernate"
'';
destination = "/etc/udev/rules.d/99-hibernate-low-battery.rules";
})
(pkgs.writeTextFile {
name = "on-battery-power-saver";
text = ''
2025-02-08 22:48:41 -05:00
# Switch to power-saver when battery below 50%
SUBSYSTEM=="power_supply", ATTR{status}=="Discharging", ATTR{capacity}=="[0-5][0-9]", RUN+="${pkgs.power-profiles-daemon}/bin/powerprofilesctl set power-saver"
'';
destination = "/etc/udev/rules.d/62-power-save-battery.rules";
})
];
};
2024-09-28 21:03:16 -04:00
2024-09-30 20:46:21 -04:00
security.polkit.enable = true;
security.rtkit.enable = true;
2025-02-08 22:48:41 -05:00
security.pam.services.swaylock = { };
security.pam.services.hyprlock = { };
2025-02-16 16:24:34 -05:00
security.pam.services.greetd.enableGnomeKeyring = true;
2024-09-30 20:46:21 -04:00
2025-02-08 22:48:41 -05:00
services.xserver.videoDrivers = [
"nvidia"
"modesetting"
];
2024-09-24 16:11:23 -04:00
2024-11-09 14:14:31 -05:00
networking = {
hostName = "eddie";
domain = "local";
2025-02-08 22:48:41 -05:00
nameservers = [
"1.1.1.1"
"1.0.0.1"
];
networkmanager = {
enable = true;
wifi.powersave = true;
};
2024-11-09 14:14:31 -05:00
};
2024-09-22 01:04:11 -04:00
2024-11-09 14:14:31 -05:00
services.resolved = {
enable = true;
extraConfig = ''
2025-02-08 22:48:41 -05:00
LLMNR=no
ReadEtcHosts=no
DNSSEC=no
'';
2024-11-09 14:14:31 -05:00
};
2024-09-22 01:04:11 -04:00
services.xserver.enable = true;
# Enable the GNOME Desktop Environment.
services.xserver.displayManager.gdm.enable = true;
2024-10-05 12:36:08 -04:00
services.xserver.desktopManager.gnome.enable = true;
2024-10-02 13:09:41 -04:00
services.xserver.deviceSection = ''Option "TearFree" "true"''; # For amdgpu.
2025-01-13 15:26:20 -05:00
# services.xserver.enableTearFree = true;
2024-10-07 23:39:25 -04:00
services.gnome.gnome-keyring.enable = true;
services.gnome.gnome-settings-daemon.enable = true;
2024-10-07 23:39:25 -04:00
2024-11-22 16:26:46 -05:00
services.picom = {
enable = true;
vSync = true;
};
2025-02-07 18:15:39 -05:00
programs.labwc.enable = true;
2025-02-11 19:35:11 -05:00
programs.ssh.startAgent = true;
2025-02-07 18:15:39 -05:00
2025-01-12 14:13:18 -05:00
programs.nh = {
enable = true;
2025-01-19 16:00:05 -05:00
clean = {
enable = true;
dates = "daily";
extraArgs = "--keep-since 4d --keep 3";
};
2025-01-12 14:13:18 -05:00
flake = "/home/emenel/source/nixos-config";
2025-02-04 13:13:24 -05:00
package = pkgs.nh;
2025-01-12 14:13:18 -05:00
};
2024-09-24 16:11:23 -04:00
programs.dconf.enable = true;
2024-12-23 00:31:40 -05:00
programs.gpaste.enable = true;
2025-01-12 14:13:18 -05:00
programs.xwayland.enable = true;
2024-09-24 16:11:23 -04:00
2024-09-22 01:04:11 -04:00
services.xserver.xkb = {
layout = "us";
variant = "";
};
2025-01-06 15:25:02 -05:00
services.printing = {
enable = true;
drivers = [
pkgs.epson-escpr
pkgs.epson-escpr2
];
};
2024-09-24 23:46:34 -04:00
services.tailscale.enable = true;
2024-10-07 23:39:25 -04:00
services.envfs.enable = true;
2024-09-24 23:46:34 -04:00
2025-01-12 14:13:18 -05:00
services.gnome.sushi.enable = true;
2025-01-26 00:19:35 -05:00
xdg.portal = {
enable = true;
2025-02-05 11:55:58 -05:00
xdgOpenUsePortal = true;
2025-01-26 00:19:35 -05:00
extraPortals = [
pkgs.xdg-desktop-portal-gnome
pkgs.xdg-desktop-portal-gtk
pkgs.xdg-desktop-portal
2025-01-30 11:25:14 -05:00
pkgs.xdg-desktop-portal-wlr
pkgs.gnome-keyring
2025-01-26 00:19:35 -05:00
];
};
2024-09-27 15:36:18 -04:00
2024-10-04 10:35:41 -04:00
programs.steam = {
enable = true;
2024-10-14 12:21:14 -04:00
protontricks.enable = true;
2024-10-04 10:35:41 -04:00
extraCompatPackages = [ pkgs.proton-ge-bin ];
};
2024-09-23 09:46:14 -04:00
# enable fish and launch it from bash for interactive shells
programs.fish.enable = true;
2024-10-01 16:57:09 -04:00
environment.pathsToLink = [ "/share/fish" ];
2024-09-23 09:46:14 -04:00
programs.bash = {
2025-02-08 22:48:41 -05:00
interactiveShellInit = ''
if [[ $(${pkgs.procps}/bin/ps --no-header --pid=$PPID --format=comm) != "fish" && -z ''${BASH_EXECUTION_STRING} ]]
then
shopt -q login_shell && LOGIN_OPTION='--login' || LOGIN_OPTION=""
exec ${pkgs.fish}/bin/fish $LOGIN_OPTION
fi
'';
};
2024-09-23 23:35:58 -04:00
services.flatpak.enable = true;
2024-10-01 21:18:52 -04:00
services.dbus.implementation = "broker";
2024-09-30 22:57:34 -04:00
#programs.gnupg.enable = true;
programs.git.enable = true;
2024-09-30 09:10:52 -04:00
environment.gnome.excludePackages = with pkgs; [
cheese
geary
gnome-music
2024-10-01 16:57:09 -04:00
gnome-tour
2024-09-30 09:10:52 -04:00
];
2024-10-04 10:35:41 -04:00
services.accounts-daemon.enable = true;
services.gnome.gnome-online-accounts.enable = true;
2025-02-08 22:48:41 -05:00
programs.virt-manager.enable = true;
virtualisation = {
libvirtd = {
enable = true;
qemu = {
package = pkgs.qemu_kvm;
swtpm.enable = true;
ovmf.enable = true;
ovmf.packages = [ pkgs.OVMFFull.fd ];
};
};
spiceUSBRedirection.enable = true;
};
services.qemuGuest.enable = true;
services.spice-vdagentd.enable = true;
2024-09-29 13:45:20 -04:00
2024-10-04 10:35:41 -04:00
programs.appimage = {
2024-09-28 20:28:06 -04:00
enable = true;
2024-10-04 10:35:41 -04:00
binfmt = true;
2025-01-10 08:10:23 -05:00
package = pkgs.appimage-run.override {
extraPkgs = pkgs: [ pkgs.libxcrypt.out ];
};
2024-09-28 20:28:06 -04:00
};
2024-09-22 01:04:11 -04:00
2024-12-31 12:05:58 -05:00
programs.nix-ld.enable = true;
programs.nix-ld.libraries = with pkgs; [
2025-02-08 22:48:41 -05:00
zlib
zstd
stdenv.cc.cc
curlFull
openssl.out
attr
libssh
libxcrypt.out
bzip2
libxml2
acl
libsodium
util-linux
xz
systemd
fontconfig
freetype
gnutls
util-linux
libGL.dev
psutils
egl-wayland
eglexternalplatform
glfw-wayland
glfw
libGLU.dev
libuv.out
libressl.out
libudev-zero.out
2024-11-06 14:33:49 -05:00
];
2025-02-04 20:58:42 -05:00
fonts = {
enableDefaultPackages = true;
fontDir.enable = true;
fontconfig = {
enable = true;
useEmbeddedBitmaps = true;
};
packages = with pkgs; [
fira-code
font-awesome
fira
cooper-hewitt
ibm-plex
jetbrains-mono
iosevka
spleen
fira-code-symbols
2025-02-18 13:01:44 -05:00
blackout
2025-02-04 20:58:42 -05:00
powerline-fonts
noto-fonts-color-emoji
noto-fonts
noto-fonts-cjk-sans
noto-fonts-emoji
nerd-fonts.jetbrains-mono
nerd-fonts.fira-code
nerd-fonts._0xproto
2025-02-05 00:50:55 -05:00
nerd-fonts.symbols-only
2025-02-04 20:58:42 -05:00
];
2024-12-04 13:04:38 -05:00
};
2024-10-18 09:11:27 -04:00
2024-10-28 11:20:08 -04:00
powerManagement = {
enable = true;
};
2024-10-01 16:57:09 -04:00
services.power-profiles-daemon = {
enable = true;
2025-02-04 13:13:24 -05:00
package = pkgs.power-profiles-daemon;
};
2024-11-04 11:13:56 -05:00
2024-10-01 16:57:09 -04:00
# enable the OpenSSH daemon.
2024-09-22 01:04:11 -04:00
services.openssh.enable = true;
2024-09-28 20:28:06 -04:00
2024-11-29 12:28:08 -05:00
services.avahi = {
enable = true;
publish.enable = true;
publish.userServices = true;
openFirewall = true;
2024-11-29 12:28:08 -05:00
nssmdns4 = true;
};
2025-02-11 19:35:11 -05:00
services.samba = {
enable = true;
package = pkgs.sambaFull;
openFirewall = true;
};
services.samba-wsdd = {
enable = true;
openFirewall = true;
};
2024-11-09 14:14:31 -05:00
2025-02-19 12:37:50 -05:00
users.groups.uinput = { };
2024-10-05 12:36:08 -04:00
# add user accounts
users.users.emenel = {
isNormalUser = true;
description = "emenel";
2025-02-08 22:48:41 -05:00
extraGroups = [
"networkmanager"
"network"
"wheel"
"uinput"
"uucp"
"dialout"
"input"
"audio"
"video"
"libvirtd"
"nvidia"
"cups"
"openrazer"
"plugdev"
2025-02-14 16:37:28 -05:00
"i2c-dev"
2025-02-08 22:48:41 -05:00
];
2024-10-05 12:36:08 -04:00
packages = with pkgs; [
git
];
};
2024-09-28 20:28:06 -04:00
#do not change
system.stateVersion = "24.05";
2024-09-22 01:04:11 -04:00
}