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 ,
. . .
} :
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
./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
2025-03-13 17:41:05 -04:00
2025-04-11 18:43:57 -04:00
# ./pkgs/app/utilities/bacula.nix
2025-05-03 12:34:07 -04:00
# ./pkgs/app/servers/ff-sync.nix
2025-04-11 18:43:57 -04:00
./pkgs/virtualisation/docker.nix
./pkgs/virtualisation/vbox.nix
2025-03-13 17:41:05 -04:00
# ./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;
2025-03-13 17:41:05 -04:00
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
2025-04-16 13:59:06 -04:00
# systemd.services."systemd-journald-tty12" = {
# description = "Forward syslog to TTY12";
# serviceConfig = {
# ExecStart = "/bin/sh -c 'journalctl -f > /dev/tty12'";
# };
# wantedBy = [ "multi-user.target" ];
# };
2024-10-14 17:28:31 -04:00
2025-05-03 12:43:09 -04:00
programs = {
firefox . enable = true ;
zsh . enable = true ;
nix-ld . enable = true ;
fuse . userAllowOther = true ;
} ;
2024-10-14 17:28:31 -04:00
services = {
2025-04-11 18:43:57 -04:00
blueman . enable = true ;
2024-10-14 17:28:31 -04:00
printing . enable = true ;
ollama = {
enable = true ;
acceleration = " c u d a " ;
models = " / v a r / l i b / o l l a m a / m o d e l s " ;
environmentVariables = { } ;
} ;
2025-04-09 20:56:29 -04:00
open-webui = {
enable = true ;
package = pkgs . open-webui ;
port = 4040 ;
# host = "192.18.12.40";
openFirewall = true ;
environment = {
ANONYMIZED_TELEMETRY = " F a l s e " ;
DO_NOT_TRACK = " T r u e " ;
SCARF_NO_ANALYTICS = " T r u e " ;
OLLAMA_API_BASE_URL = " h t t p : / / 1 2 7 . 0 . 0 . 1 : 1 1 4 3 4 / a p i " ;
OLLAMA_BASE_URL = " h t t p : / / 1 2 7 . 0 . 0 . 1 : 1 1 4 3 4 " ;
ENABLE_WEBSOCKET_SUPPORT = " T r u e " ;
WEBSOCKET_MANAGER = " r e d i s " ;
WEBSOCKET_REDIS_URL = " r e d i s : / / 1 2 7 . 0 . 0 . 1 : 6 3 7 9 / 1 " ;
GLOBAL_LOG_LEVEL = " D E B U G " ;
} ;
} ;
# comfyui = {
# enable = true;
# package = pkgs.comfyui-nvidia;
# host = "0.0.0.0";
# models = builtins.attrValues pkgs.nixified-ai.models;
# customNodes = with comfyui.pkgs; [
# comfyui-gguf
# comfyui-impact-pack
# ];
# };
redis = {
package = pkgs . redis ;
vmOverCommit = true ;
servers = {
bots = {
enable = true ;
port = 6379 ;
} ;
} ;
} ;
2024-10-14 17:28:31 -04:00
input-remapper = {
enable = true ;
enableUdevRules = true ;
package = pkgs . input-remapper ;
serviceWantedBy = [ " g r a p h i c a l . t a r g e t " ] ;
} ;
# dbus.implementation = "dbus"; # The option `services.dbus.implementation' has conflicting definition values: - In `/nix/store/60sn02zhawl3kwn0r515zff3h6hg6ydz-source/nixos/modules/programs/wayland/uwsm.nix': "broker"
2025-04-11 18:43:57 -04:00
udisks2 = {
enable = true ;
package = pkgs . udisks2 ;
mountOnMedia = true ;
} ;
2024-10-14 17:28:31 -04:00
logrotate . enable = true ;
openssh = {
enable = true ;
ports = [ 22 ] ;
settings = {
PasswordAuthentication = true ;
AllowUsers = [ " w a y n e " ] ; # Allows all users by default. Can be [ "user1" "user2" ]
UseDns = true ;
X11Forwarding = false ;
PermitRootLogin = " n o " ; # "yes", "without-password", "prohibit-password", "forced-commands-only", "no"
} ;
} ;
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 ;
2025-04-16 13:59:06 -04:00
package = pkgs . pipewire ;
systemWide = false ; # uses pipewire group
2024-10-14 17:28:31 -04:00
alsa . enable = true ;
alsa . support32Bit = true ;
2025-04-16 13:59:06 -04:00
audio . enable = config . services . pipewire . alsa . enable || config . services . pipewire . jack . enable || config . services . pipewire . pulse . enable ;
2024-10-14 17:28:31 -04:00
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)
2025-04-16 13:59:06 -04:00
# media-session.enable = true;
2024-11-29 18:31:17 -05:00
# wireplumber.enable = true;
2025-04-16 13:59:06 -04:00
socketActivation = true ;
extraConfig . pipewire = {
log . level = 4 ;
} ;
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
} ;
2025-03-13 17:41:05 -04:00
samba = {
2025-04-11 18:43:57 -04:00
enable = false ;
2025-03-13 17:41:05 -04:00
openFirewall = true ;
package = pkgs . samba4Full ;
settings = {
global = {
security = " u s e r " ;
" s e r v e r m i n p r o t o c o l " = " S M B 2 _ 1 0 " ;
" c l i e n t m i n p r o t o c o l " = " S M B 2 _ 1 0 " ;
" s e r v e r m a x p r o t o c o l " = " S M B 3 _ 1 1 " ;
" c l i e n t m a x p r o t o c o l " = " S M B 3 _ 1 1 " ;
} ;
} ;
} ;
2025-04-11 18:43:57 -04:00
keybase . enable = true ;
kbfs = {
enable = true ;
mountPoint = " k e y b a s e " ;
extraFlags = [
" - l a b e l : k b f s "
" - m o u n t - t y p e : n o r m a l "
] ;
} ;
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 = " m o c h a " ;
font = " N o t o S a n s " ;
fontSize = " 9 " ;
loginBackground = 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
2025-04-11 18:43:57 -04:00
zsh ghostty # 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
2025-03-13 17:41:05 -04:00
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
2025-04-16 13:59:06 -04:00
# kdePackages.wayland kdePackages.wayland-protocols kdePackages.xwaylandvideobridge kdePackages.kwayland kdePackages.wayqt kdePackages.qtwayland kdePackages.layer-shell-qt # marked broken kdePackages.kwayland-integration
2025-03-13 17:41:05 -04:00
kdePackages . kdeplasma-addons kdePackages . qtstyleplugin-kvantum kdePackages . full kdePackages . qtwebengine
kdePackages . qtpositioning kdePackages . qtlocation kdePackages . ark kdePackages . dolphin
2025-05-03 12:34:07 -04:00
kdePackages . dolphin-plugins
2025-03-13 17:41:05 -04:00
kdePackages . konsole
2025-04-16 13:59:06 -04:00
# kdePackages.qtwayland kdePackages.qtsvg
kdePackages . kio kdePackages . kio-fuse kdePackages . kio-extras kdePackages . kio-admin
2025-03-13 17:41:05 -04:00
kdePackages . kdenetwork-filesharing
kdePackages . kwallet kdePackages . kwalletmanager kdePackages . kwallet-pam
2025-05-03 12:34:07 -04:00
kdePackages . polkit-kde-agent-1 kdePackages . kirigami
hyprpolkitagent polkit
2025-03-13 17:41:05 -04:00
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
2025-03-13 17:41:05 -04:00
cifs-utils mesa libGL udiskie samba
2025-04-16 13:59:06 -04:00
glibc # cmake cpio meson
libsForQt5 . kwayland libsForQt5 . qt5 . qtwayland libsForQt5 . kwayland-integration # libsForQt5.xwaylandvideobridge
2025-05-03 12:34:07 -04:00
# libsForQt5.polkit-kde-agent
2025-03-13 17:41:05 -04:00
# libsForQt5.qtstyleplugin-kvantum libsForQt5.qt5.qtwayland libsForQt5.kio-extras # libsForQt5.qt5.qtgraphicaleffects
2025-05-03 12:34:07 -04:00
2025-03-13 17:41:05 -04:00
#kio-fuse
2024-11-01 12:04:24 -04:00
catppuccin-sddm-corners
2025-03-13 17:41:05 -04:00
sddm-astronaut
2024-10-14 17:28:31 -04:00
# steam-run
2025-04-16 13:59:06 -04:00
lxqt . pavucontrol-qt pw-viz playerctl
2024-11-01 12:04:24 -04:00
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 = " 2 4 . 1 1 " ; # Did you read the comment?
2024-10-14 17:28:31 -04:00
}