system/configuration.nix

245 lines
7.0 KiB
Nix
Raw Normal View History

2024-11-01 12:04:24 -04:00
# NixOS's declarative configuration calculates which software packages need to be installed and then soft-links the storage paths of these packages in the Nix Store to /run/current-system, and by modifying environment variables like PATH
2024-12-03 13:21:22 -05:00
{
lib,
config,
pkgs,
zen-browser,
hyprland,
inputs,
agenix,
pkgs-unstable,
pia,
ghostty,
2024-12-03 13:21:22 -05:00
...
}:
2024-10-14 17:28:31 -04:00
let
unstable = import <nixpkgs> {
overlays = pkgs.overlays;
};
2024-10-14 18:35:04 -04:00
in
2024-10-14 17:28:31 -04:00
{
2024-12-03 13:21:22 -05:00
imports = [
./environment.nix
./hardware-configuration.nix
2024-10-14 17:28:31 -04:00
2024-12-03 13:21:22 -05:00
# (import ./modules/containers.nix { inherit pkgs inputs config lib pkgs-unstable ;})
./modules/containers.nix
./modules/display.nix
./modules/files.nix
./modules/fonts.nix
./modules/musnix.nix
./modules/network.nix
./modules/nix.nix
# ./modules/qt.nix
./modules/security.nix
./modules/tailscale.nix
./modules/users.nix
./modules/wm.nix
./modules/xdg.nix
# ./flakes/scribeVault.nix
2024-12-03 13:21:22 -05:00
];
2024-10-14 17:28:31 -04:00
programs.hyprland = {
enable = true;
xwayland.enable = true;
# package = pkgs.hyprland;
# package = hyprland.packages.${pkgs.stdenv.hostPlatform.system}.hyprland;
portalPackage = pkgs.xdg-desktop-portal-hyprland;
2024-10-14 17:28:31 -04:00
# portalPackage = inputs.hyprland.packages.${pkgs.stdenv.hostPlatform.system}.xdg-desktop-portal-hyprland;
};
# Redirect syslog to TTY12
systemd.services."systemd-journald-tty12" = {
description = "Forward syslog to TTY12";
serviceConfig = {
ExecStart = "/bin/sh -c 'journalctl -f > /dev/tty12'";
};
wantedBy = [ "multi-user.target" ];
};
2024-11-29 18:31:17 -05:00
systemd.services.logid = {
description = "Logitech Configuration Daemon";
startLimitIntervalSec = 0;
after = [ "multi-user.target" ];
wants = [ "multi-user.target" ];
serviceConfig = {
Type = "simple";
ExecStart = "/run/current-system/sw/bin/logid";
User = "root";
};
wantedBy = [ "multi-user.target" ];
};
2024-10-14 17:28:31 -04:00
# Install firefox.
programs.firefox.enable = true;
programs.zsh.enable = true;
programs.nix-ld.enable = true;
# programs.nix-ld.libraries = with pkgs; [
# libusb
# kdePackages.qt5compat kdePackages.full
# libsForQt5.full
# libGL
# gcc glib xorg.libXext
# ];
virtualisation.docker = {
enable = true;
# enableNvidia = true; depreciated
2024-10-14 17:28:31 -04:00
rootless = {
enable = true;
setSocketVariable = true;
};
daemon.settings = {
userland-proxy = false;
ipv6 = false;
};
};
services = {
printing.enable = true;
ollama = {
enable = true;
acceleration = "cuda";
models = "/var/lib/ollama/models";
environmentVariables = {};
};
input-remapper = {
enable = true;
enableUdevRules = true;
package = pkgs.input-remapper;
serviceWantedBy = [ "graphical.target" ];
};
# dbus.implementation = "dbus"; # The option `services.dbus.implementation' has conflicting definition values: - In `/nix/store/60sn02zhawl3kwn0r515zff3h6hg6ydz-source/nixos/modules/programs/wayland/uwsm.nix': "broker"
udisks2.enable = true;
logrotate.enable = true;
openssh = {
enable = true;
ports = [ 22 ];
settings = {
PasswordAuthentication = true;
AllowUsers = [ "wayne" ]; # Allows all users by default. Can be [ "user1" "user2" ]
UseDns = true;
X11Forwarding = false;
PermitRootLogin = "no"; # "yes", "without-password", "prohibit-password", "forced-commands-only", "no"
};
};
# kmonad = {
# enable = true;
# keyboards = {
# myKMonadOutput = {
# device = "/dev/input/by-id/usb-Hanvon_Ugee_Shortcut_Remote_000000000000000-event-kbd";
# config = builtins.readFile /home/wayne/.config/kmonad/hanvon-ugee.kbd;
# };
# };
# };
2024-11-01 12:04:24 -04:00
avahi = { # Printing
2024-10-14 17:28:31 -04:00
enable = true;
nssmdns4 = true;
openFirewall = true;
};
pipewire = {
enable = true;
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
2024-11-29 18:31:17 -05:00
jack.enable = true;
2024-10-14 17:28:31 -04:00
# use the example session manager (no others are packaged yet so this is enabled by default,
# no need to redefine it in your config for now)
#media-session.enable = true;
2024-11-29 18:31:17 -05:00
# wireplumber.enable = true;
2024-10-14 17:28:31 -04:00
};
2024-12-03 13:21:22 -05:00
# hardware.openrgb = {
# enable = false;
# package = pkgs.openrgb-with-all-plugins;
# motherboard = "intel";
# server.port = 6742;
# };
pia = {
2024-11-29 18:46:42 -05:00
enable = true;
2024-12-03 13:21:22 -05:00
authUserPassFile = config.age.secrets.pia.path;
2024-11-29 18:46:42 -05:00
};
home-assistant = {
extraPackages = python3Packages: with python3Packages; [
pip
pynvim # mopidy-tidal # Mopidy-WebSettings
virtualenv setuptools wheel
];
};
samba = {
enable = true;
openFirewall = true;
package = pkgs.samba4Full;
settings = {
global = {
security = "user";
"server min protocol" = "SMB2_10";
"client min protocol" = "SMB2_10";
"server max protocol" = "SMB3_11";
"client max protocol" = "SMB3_11";
};
};
};
2024-10-14 17:28:31 -04:00
};
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
2024-11-01 12:04:24 -04:00
(pkgs.catppuccin-sddm.override {
flavor = "mocha";
font = "Noto Sans";
fontSize = "9";
# background = "${/home/wayne/Pictures/marvin.png}";
2024-11-01 12:04:24 -04:00
loginBackground = true;
# clockEnabled = true;
})
2024-10-14 17:28:31 -04:00
vim # Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default.
wget git sshfs
2024-11-29 18:31:17 -05:00
pciutils usbutils
zsh ghostty.packages.x86_64-linux.default
2024-10-14 17:28:31 -04:00
2024-11-01 12:04:24 -04:00
cryptsetup agenix.packages.x86_64-linux.default
2024-10-14 17:28:31 -04:00
home-manager
wpa_supplicant
lynx
nix-index nix-prefetch-scripts nix-prefetch
docker_27 docker-compose compose2nix
mongodb-compass mongosh
2024-10-14 17:28:31 -04:00
2024-11-01 12:04:24 -04:00
# direnv nix-direnv
2024-10-14 17:28:31 -04:00
# xdg-desktop-portal-hyprland
clinfo glxinfo vulkan-tools wayland-utils wl-clipboard
kdePackages.kdeplasma-addons kdePackages.qtstyleplugin-kvantum kdePackages.full kdePackages.qtwebengine
kdePackages.qtpositioning kdePackages.qtlocation kdePackages.ark kdePackages.dolphin
kdePackages.dolphin-plugins # kdePackages.kwallet kdePackages.kwalletmanager
kdePackages.konsole
kdePackages.qtwayland kdePackages.qtsvg kdePackages.kio kdePackages.kio-fuse kdePackages.kio-extras
kdePackages.kdenetwork-filesharing
kdePackages.kwallet kdePackages.kwalletmanager kdePackages.kwallet-pam
# plasma5Packages.kwallet plasma5Packages.kwalletmanager plasma5Packages.kwallet-pam
gtk2
gnome-themes-extra
2024-10-14 17:28:31 -04:00
evtest input-remapper dbus uwsm # keyd
2024-11-01 12:04:24 -04:00
egl-wayland
2024-10-14 17:28:31 -04:00
cudaPackages.cudatoolkit # cudaPackages.cuda-samples
cifs-utils mesa libGL udiskie samba
glibc
2024-10-14 17:28:31 -04:00
# libsForQt5.qtstyleplugin-kvantum libsForQt5.qt5.qtwayland libsForQt5.kio-extras # libsForQt5.qt5.qtgraphicaleffects
#kio-fuse
2024-11-01 12:04:24 -04:00
catppuccin-sddm-corners
sddm-astronaut
2024-10-14 17:28:31 -04:00
# steam-run
2024-11-01 12:04:24 -04:00
lxqt.pavucontrol-qt
2024-11-29 18:31:17 -05:00
i2c-tools
2024-11-01 12:04:24 -04:00
android-udev-rules
2024-12-01 14:11:41 -05:00
tailscale
2024-11-29 18:31:17 -05:00
logiops
2024-10-14 17:28:31 -04:00
];
2024-12-06 13:12:42 -05:00
system.stateVersion = "24.11"; # Did you read the comment?
2024-10-14 17:28:31 -04:00
}