1354 lines
30 KiB
Nix
1354 lines
30 KiB
Nix
{
|
|
disko,
|
|
sops-nix,
|
|
style,
|
|
flakeInputs,
|
|
homeManagerModules,
|
|
home-manager,
|
|
home-manager-unstable,
|
|
helix,
|
|
nixosModules,
|
|
pubkey,
|
|
overlays,
|
|
}: {
|
|
ewwbar = {pkgs, ...}: {
|
|
# imports = with nixosModules; [];
|
|
environment.systemPackages = with pkgs; [eww upower jq];
|
|
|
|
# TODO: include the home-manager modules for daniel?
|
|
};
|
|
|
|
hyprland = {pkgs, ...}: {
|
|
imports = with nixosModules; [
|
|
ewwbar
|
|
pipewire
|
|
];
|
|
|
|
programs.hyprland = {
|
|
enable = true;
|
|
};
|
|
environment.systemPackages = with pkgs; [hyprpaper xwaylandvideobridge socat];
|
|
|
|
programs.hyprland = {
|
|
package = flakeInputs.hyprland.packages.${pkgs.system}.hyprland;
|
|
};
|
|
|
|
home-manager.users.daniel = {
|
|
imports = with homeManagerModules; [
|
|
hyprland
|
|
];
|
|
};
|
|
|
|
# TODO: include the home-manager modules for daniel?
|
|
};
|
|
|
|
sway = {pkgs, ...}: {
|
|
imports = with nixosModules; [
|
|
pipewire
|
|
];
|
|
|
|
systemd.user.services."wait-for-full-path" = {
|
|
description = "wait for systemd units to have full PATH";
|
|
wantedBy = ["xdg-desktop-portal.service"];
|
|
before = ["xdg-desktop-portal.service"];
|
|
path = with pkgs; [systemd coreutils gnugrep];
|
|
script = ''
|
|
ispresent () {
|
|
systemctl --user show-environment | grep -E '^PATH=.*/.nix-profile/bin'
|
|
}
|
|
while ! ispresent; do
|
|
sleep 0.1;
|
|
done
|
|
'';
|
|
serviceConfig = {
|
|
Type = "oneshot";
|
|
TimeoutStartSec = "60";
|
|
};
|
|
};
|
|
|
|
home-manager.users.daniel = {
|
|
imports = with homeManagerModules; [
|
|
sway
|
|
];
|
|
};
|
|
|
|
programs.sway = {
|
|
enable = true;
|
|
wrapperFeatures.gtk = true;
|
|
};
|
|
|
|
# services.xserver.libinput.enable = true;
|
|
|
|
# TODO: a lot of this probably needs de-duping with hyprland?
|
|
|
|
services.gnome.gnome-keyring.enable = true;
|
|
|
|
xdg.portal = {
|
|
enable = true;
|
|
wlr.enable = true;
|
|
# gtk.enable = true;
|
|
|
|
extraPortals = with pkgs; [
|
|
xdg-desktop-portal-wlr
|
|
xdg-desktop-portal-gtk
|
|
];
|
|
};
|
|
|
|
services.dbus.enable = true;
|
|
security.polkit.enable = true; # needed for home-manager integration
|
|
|
|
programs.thunar = {
|
|
enable = true;
|
|
plugins = with pkgs.xfce; [thunar-archive-plugin thunar-volman];
|
|
};
|
|
|
|
services.gvfs = {
|
|
enable = true;
|
|
};
|
|
|
|
environment = {
|
|
variables = {
|
|
VISUAL = "hx";
|
|
};
|
|
|
|
systemPackages = with pkgs; [
|
|
brightnessctl
|
|
feh
|
|
grim
|
|
libinput
|
|
libinput-gestures
|
|
libnotify
|
|
mako
|
|
noto-fonts
|
|
pamixer
|
|
playerctl
|
|
pulseaudio
|
|
pulsemixer
|
|
slurp
|
|
swaybg
|
|
swayidle
|
|
swaylock
|
|
swayosd
|
|
tofi
|
|
waybar
|
|
wl-clipboard
|
|
zathura
|
|
|
|
/*
|
|
gimp
|
|
inkscape
|
|
krita
|
|
lutris
|
|
nil
|
|
nixpkgs-fmt
|
|
pavucontrol
|
|
rclone
|
|
restic
|
|
steam
|
|
vlc
|
|
vulkan-tools
|
|
weechat
|
|
wine
|
|
*/
|
|
];
|
|
};
|
|
};
|
|
|
|
deno-netlify-ddns-client = import ./deno-netlify-ddns-client.nix;
|
|
|
|
fallback-hostname = {lib, ...}: {
|
|
networking.hostName = lib.mkDefault "set-a-hostname-dingus";
|
|
};
|
|
|
|
no-giant-logs = {lib, ...}: {
|
|
services.journald.extraConfig = lib.mkDefault "SystemMaxUse=1G";
|
|
};
|
|
|
|
allow-redistributable-firmware = {lib, ...}: {
|
|
hardware.enableRedistributableFirmware = lib.mkDefault true;
|
|
};
|
|
|
|
home-manager-defaults = {
|
|
imports = [
|
|
# enable home-manager
|
|
home-manager.nixosModules.home-manager
|
|
];
|
|
|
|
home-manager.useGlobalPkgs = true;
|
|
home-manager.backupFileExtension = "hm-backup";
|
|
};
|
|
|
|
home-manager-unstable-defaults = {
|
|
imports = [
|
|
# enable home-manager
|
|
home-manager-unstable.nixosModules.home-manager
|
|
];
|
|
|
|
home-manager.useGlobalPkgs = true;
|
|
home-manager.backupFileExtension = "hm-backup";
|
|
};
|
|
|
|
mdns-and-lan-service-discovery = {
|
|
services.avahi = {
|
|
enable = true;
|
|
reflector = true;
|
|
openFirewall = true;
|
|
nssmdns4 = true;
|
|
};
|
|
};
|
|
|
|
helix-text-editor = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = [
|
|
helix.packages.${pkgs.system}.helix
|
|
];
|
|
variables = {
|
|
EDITOR = "hx";
|
|
SYSTEMD_EDITOR = "hx";
|
|
VISUAL = "hx";
|
|
};
|
|
};
|
|
};
|
|
|
|
zellij-multiplexer = {pkgs, ...}: {
|
|
environment.systemPackages = [
|
|
pkgs.zellij
|
|
];
|
|
};
|
|
|
|
fish-shell = {
|
|
pkgs,
|
|
lib,
|
|
...
|
|
}: {
|
|
programs.fish = {
|
|
enable = true;
|
|
};
|
|
|
|
users = {
|
|
defaultUserShell = pkgs.fish;
|
|
};
|
|
};
|
|
|
|
nix-index = {
|
|
enable = true;
|
|
enableBashIntegration = true;
|
|
enableFishIntegration = true;
|
|
enableZshIntegration = true;
|
|
};
|
|
|
|
my-favorite-default-system-apps = {pkgs, ...}: {
|
|
imports = with nixosModules; [
|
|
helix-text-editor
|
|
zellij-multiplexer
|
|
fish-shell
|
|
];
|
|
|
|
environment = {
|
|
variables = {
|
|
PAGER = "bat --style=plain";
|
|
MANPAGER = "bat --style=plain";
|
|
};
|
|
systemPackages = with pkgs; [
|
|
curl
|
|
dua
|
|
bat
|
|
eza
|
|
fd
|
|
file
|
|
iputils
|
|
nettools
|
|
/*
|
|
nodePackages.bash-language-server # just pull in as needed?
|
|
shellcheck
|
|
shfmt
|
|
*/
|
|
killall
|
|
ripgrep
|
|
rsync
|
|
sd
|
|
];
|
|
};
|
|
|
|
programs = {
|
|
traceroute.enable = true;
|
|
git = {
|
|
enable = true;
|
|
package = pkgs.gitFull;
|
|
lfs.enable = true;
|
|
};
|
|
};
|
|
};
|
|
|
|
mosh = {lib, ...}: {
|
|
programs.mosh = {
|
|
enable = true;
|
|
openFirewall = lib.mkDefault true;
|
|
};
|
|
};
|
|
|
|
remote-disk-key-entry-on-boot = {
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}: {
|
|
/*
|
|
https://nixos.wiki/wiki/Remote_disk_unlocking
|
|
"When using DHCP, make sure your computer is always attached to the network and is able to get an IP adress, or the boot process will hang."
|
|
^ seems less than ideal
|
|
*/
|
|
boot.kernelParams = ["ip=dhcp"];
|
|
boot.initrd = {
|
|
# availableKernelModules = ["r8169"]; # ethernet drivers
|
|
systemd.users.root.shell = "/bin/cryptsetup-askpass";
|
|
network = {
|
|
enable = true;
|
|
ssh = {
|
|
enable = true;
|
|
port = 22;
|
|
authorizedKeys = [pubkey];
|
|
hostKeys = ["/etc/secrets/initrd/ssh_host_rsa_key"];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
ssh-server = {lib, ...}: {
|
|
# enable an ssh server and provide root access with my primary public key
|
|
|
|
users.users.root = {
|
|
openssh.authorizedKeys.keys = [pubkey];
|
|
};
|
|
|
|
services.openssh = {
|
|
enable = true;
|
|
|
|
settings = {
|
|
PasswordAuthentication = false;
|
|
KbdInteractiveAuthentication = false;
|
|
PermitRootLogin = lib.mkForce "prohibit-password";
|
|
};
|
|
|
|
openFirewall = lib.mkDefault true;
|
|
|
|
/*
|
|
listenAddresses = [
|
|
{ addr = "0.0.0.0"; port = 22; }
|
|
];
|
|
*/
|
|
};
|
|
};
|
|
|
|
password-manager = {pkgs, ...}: {
|
|
/*
|
|
programs.goldwarden = {
|
|
## NOTE: This didn't seem to work for me, but would be awesome! (but I can't remember why?)
|
|
enable = true;
|
|
};
|
|
*/
|
|
|
|
home-manager.users.daniel = {
|
|
imports = with homeManagerModules; [
|
|
password-manager
|
|
];
|
|
};
|
|
};
|
|
|
|
linux = {pkgs, ...}: {
|
|
home-manager.users.daniel = {
|
|
imports = with homeManagerModules; [
|
|
linux
|
|
];
|
|
};
|
|
};
|
|
|
|
tailscale = {lib, ...}: {
|
|
services.tailscale = {
|
|
enable = true;
|
|
useRoutingFeatures = lib.mkDefault "client";
|
|
};
|
|
};
|
|
|
|
cross-compiler = {config, ...}: {
|
|
boot.binfmt.emulatedSystems = ["aarch64-linux" "i686-linux"];
|
|
};
|
|
|
|
default-nix-configuration-and-overlays = {
|
|
lib,
|
|
config,
|
|
...
|
|
}: {
|
|
nixpkgs = {
|
|
overlays = with overlays; [
|
|
additions
|
|
modifications
|
|
unstable-packages
|
|
];
|
|
config.allowUnfree = true;
|
|
};
|
|
|
|
nix = {
|
|
nixPath = lib.mapAttrsToList (key: value: "${key}=${value.to.path}") config.nix.registry;
|
|
# registry = lib.mapAttrs (_: value: {flake = value;}) flakeInputs;
|
|
|
|
settings = {
|
|
trusted-users = ["root" "daniel"];
|
|
experimental-features = lib.mkDefault ["nix-command" "flakes"];
|
|
|
|
extra-platforms = ["i686-linux" "aarch64-linux"];
|
|
|
|
substituters = [
|
|
# TODO: dedupe with flake's config? is that even necessary?
|
|
"https://cache.nixos.org/"
|
|
"https://helix.cachix.org"
|
|
"https://nix-community.cachix.org"
|
|
"https://nix.h.lyte.dev"
|
|
"https://hyprland.cachix.org"
|
|
];
|
|
trusted-public-keys = [
|
|
# TODO: dedupe with flake's config? is that even necessary?
|
|
"cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY="
|
|
"helix.cachix.org-1:ejp9KQpR1FBI2onstMQ34yogDm4OgU2ru6lIwPvuCVs="
|
|
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
|
|
"h.lyte.dev:HeVWtne31ZG8iMf+c15VY3/Mky/4ufXlfTpT8+4Xbs0="
|
|
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
|
|
];
|
|
auto-optimise-store = true;
|
|
};
|
|
};
|
|
};
|
|
|
|
laptop = {pkgs, ...}: {
|
|
imports = with nixosModules; [
|
|
family-users
|
|
wifi
|
|
];
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
acpi
|
|
];
|
|
|
|
services.udev.extraRules = ''
|
|
ACTION=="add", SUBSYSTEM=="backlight", RUN+="${pkgs.coreutils}/bin/chgrp video /sys/class/backlight/%k/brightness"
|
|
ACTION=="add", SUBSYSTEM=="backlight", RUN+="${pkgs.coreutils}/bin/chmod g+w /sys/class/backlight/%k/brightness"
|
|
'';
|
|
|
|
services.upower.enable = true;
|
|
|
|
# NOTE: I previously let plasma settings handle this
|
|
services.logind = {
|
|
lidSwitch = "suspend-then-hibernate";
|
|
extraConfig = ''
|
|
KillUserProcesses=no
|
|
HandlePowerKey=suspend
|
|
HandlePowerKeyLongPress=poweroff
|
|
HandleRebootKey=reboot
|
|
HandleRebootKeyLongPress=poweroff
|
|
HandleSuspendKey=suspend
|
|
HandleSuspendKeyLongPress=hibernate
|
|
HandleHibernateKey=hibernate
|
|
HandleHibernateKeyLongPress=ignore
|
|
HandleLidSwitch=suspend
|
|
HandleLidSwitchExternalPower=suspend
|
|
HandleLidSwitchDocked=suspend
|
|
HandleLidSwitchDocked=suspend
|
|
IdleActionSec=11m
|
|
IdleAction=ignore
|
|
'';
|
|
};
|
|
};
|
|
|
|
touchscreen = {pkgs, ...}: {
|
|
environment.systemPackages = with pkgs; [
|
|
wvkbd # on-screen keyboard
|
|
flakeInputs.iio-hyprland.outputs.packages.${system}.default # auto-rotate hyprland displays
|
|
flakeInputs.hyprgrass.outputs.packages.${system}.hyprgrass # hyprland touch gestures
|
|
];
|
|
};
|
|
|
|
emacs = {pkgs, ...}: {
|
|
environment.systemPackages = with pkgs; [
|
|
emacs
|
|
];
|
|
|
|
home-manager.users.daniel = {
|
|
imports = with homeManagerModules; [
|
|
emacs
|
|
];
|
|
};
|
|
};
|
|
|
|
development-tools = {
|
|
pkgs,
|
|
lib,
|
|
...
|
|
}: {
|
|
imports = with nixosModules; [
|
|
postgres
|
|
podman
|
|
troubleshooting-tools
|
|
emacs
|
|
];
|
|
|
|
environment.sessionVariables.NIXOS_OZONE_WL = "1";
|
|
programs.neovim = {
|
|
enable = true;
|
|
/*
|
|
plugins = [
|
|
pkgs.vimPlugins.nvim-treesitter.withAllGrammars
|
|
];
|
|
*/
|
|
};
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
taplo # toml language server for editing helix configs per repo
|
|
picocom # serial
|
|
pgcli
|
|
oils-for-unix
|
|
watchexec
|
|
android-tools
|
|
stern
|
|
libresprite
|
|
# logseq
|
|
audacity
|
|
wol
|
|
shellcheck
|
|
skim
|
|
sops
|
|
gron
|
|
shfmt
|
|
vscode-langservers-extracted
|
|
nodePackages.bash-language-server
|
|
nodePackages.yaml-language-server
|
|
xh
|
|
curl
|
|
google-chrome
|
|
];
|
|
|
|
hardware.gpgSmartcards.enable = true;
|
|
|
|
services.udev.packages = with pkgs; [
|
|
# TODO: I think these get the whole package pulled in... should find out
|
|
# if there's a way to get just the rules and not 4 chromes
|
|
platformio
|
|
openocd
|
|
pkgs.yubikey-personalization
|
|
via
|
|
];
|
|
|
|
programs.adb.enable = true;
|
|
users.users.daniel.extraGroups = ["adbusers"];
|
|
|
|
home-manager.users.daniel = {
|
|
home.packages = with pkgs; [
|
|
yubikey-personalization
|
|
yubikey-manager
|
|
yubico-piv-tool
|
|
];
|
|
|
|
programs.direnv.mise = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.mise = {
|
|
enable = true;
|
|
enableFishIntegration = true;
|
|
enableBashIntegration = true;
|
|
enableZshIntegration = true;
|
|
};
|
|
|
|
programs.thunderbird = {
|
|
enable = true;
|
|
|
|
profiles = {
|
|
daniel = {
|
|
isDefault = true;
|
|
# name = "daniel";
|
|
};
|
|
};
|
|
};
|
|
|
|
programs.nushell = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.jujutsu = {
|
|
enable = lib.mkDefault true;
|
|
};
|
|
|
|
programs.k9s = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.vscode = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.jq = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.chromium = {
|
|
enable = true;
|
|
};
|
|
|
|
programs.btop = {
|
|
enable = true;
|
|
package = pkgs.btop.override {
|
|
rocmSupport = true;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
troubleshooting-tools = {pkgs, ...}: {
|
|
environment.systemPackages = with pkgs; [
|
|
comma
|
|
iftop
|
|
bottom
|
|
btop
|
|
dnsutils
|
|
dogdns
|
|
htop
|
|
inetutils
|
|
nmap
|
|
pciutils
|
|
hexyl
|
|
pkgs.unixtools.xxd
|
|
usbutils
|
|
comma
|
|
];
|
|
};
|
|
|
|
music-consumption = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
spotube
|
|
spotdl
|
|
];
|
|
};
|
|
};
|
|
|
|
video-tools = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
ffmpeg-full
|
|
obs-studio
|
|
];
|
|
};
|
|
};
|
|
|
|
android-dev = {pkgs, ...}: {
|
|
services.udev.packages = [
|
|
pkgs.android-udev-rules
|
|
];
|
|
environment.systemPackages = [pkgs.android-studio];
|
|
};
|
|
|
|
graphical-workstation = {
|
|
pkgs,
|
|
lib,
|
|
options,
|
|
config,
|
|
...
|
|
}: {
|
|
imports = with nixosModules; [
|
|
sway
|
|
hyprland
|
|
enable-flatpaks-and-appimages
|
|
fonts
|
|
development-tools
|
|
printing
|
|
music-consumption
|
|
video-tools
|
|
radio-tools
|
|
android-dev
|
|
];
|
|
|
|
xdg.portal.enable = true;
|
|
|
|
hardware =
|
|
if builtins.hasAttr "graphics" options.hardware
|
|
then {
|
|
graphics = {
|
|
enable = true;
|
|
enable32Bit = true;
|
|
/*
|
|
driSupport32Bit = true;
|
|
driSupport = true;
|
|
*/
|
|
};
|
|
}
|
|
else {
|
|
opengl = {
|
|
enable = true;
|
|
driSupport32Bit = true;
|
|
driSupport = true;
|
|
};
|
|
};
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
libnotify
|
|
slides
|
|
slack
|
|
discord
|
|
];
|
|
variables = {
|
|
/*
|
|
GTK_THEME = "Catppuccin-Mocha-Compact-Sapphire-Dark";
|
|
GTK_USE_PORTAL = "1";
|
|
*/
|
|
};
|
|
};
|
|
};
|
|
|
|
# gnome = {};
|
|
# intel = {};
|
|
|
|
radio-tools = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
chirp
|
|
];
|
|
};
|
|
};
|
|
|
|
kde-connect = {
|
|
programs.kdeconnect.enable = true;
|
|
|
|
/*
|
|
# handled by enabling
|
|
networking.firewall = {
|
|
allowedTCPPortRanges = [ { from = 1714; to = 1764; } ];
|
|
allowedUDPPortRanges = [ { from = 1714; to = 1764; } ];
|
|
};
|
|
*/
|
|
};
|
|
|
|
fonts = {pkgs, ...}: {
|
|
fonts.packages = [
|
|
(
|
|
# allow nixpkgs 24.11 and unstable to both work
|
|
if builtins.hasAttr "nerd-fonts" pkgs
|
|
then (pkgs.nerd-fonts.symbols-only)
|
|
else (pkgs.nerdfonts.override {fonts = ["NerdFontsSymbolsOnly"];})
|
|
)
|
|
pkgs.iosevkaLyteTerm
|
|
];
|
|
};
|
|
|
|
plasma6 = {
|
|
pkgs,
|
|
lib,
|
|
...
|
|
}: {
|
|
imports = with nixosModules; [
|
|
kde-connect
|
|
pipewire
|
|
];
|
|
|
|
services.xserver.enable = true;
|
|
services.displayManager.sddm = {
|
|
enable = true;
|
|
wayland.enable = true;
|
|
};
|
|
services.desktopManager.plasma6.enable = true;
|
|
programs.dconf.enable = true;
|
|
|
|
services.xrdp.enable = false;
|
|
services.xrdp.defaultWindowManager = "plasma";
|
|
services.xrdp.openFirewall = false;
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
wl-clipboard
|
|
inkscape
|
|
krita
|
|
noto-fonts
|
|
vlc
|
|
wl-clipboard
|
|
|
|
kdePackages.qtvirtualkeyboard
|
|
maliit-keyboard
|
|
maliit-framework
|
|
|
|
kdePackages.kate
|
|
kdePackages.kcalc
|
|
kdePackages.filelight
|
|
kdePackages.krdc
|
|
kdePackages.krfb
|
|
kdePackages.kclock
|
|
kdePackages.kweather
|
|
kdePackages.ktorrent
|
|
kdePackages.kdeplasma-addons
|
|
|
|
unstable-packages.kdePackages.krdp
|
|
|
|
/*
|
|
kdePackages.kdenlive
|
|
kdePackages.merkuro
|
|
kdePackages.neochat
|
|
kdePackages.kdevelop
|
|
kdePackages.kdialog
|
|
*/
|
|
];
|
|
|
|
programs.gnupg.agent.pinentryPackage = lib.mkForce pkgs.pinentry-qt;
|
|
};
|
|
|
|
lutris = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
wineWowPackages.waylandFull
|
|
lutris
|
|
winetricks
|
|
];
|
|
};
|
|
};
|
|
|
|
gaming = {pkgs, ...}: {
|
|
imports = with nixosModules; [
|
|
lutris
|
|
steam
|
|
];
|
|
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
ludusavi
|
|
# ludusavi uses rclone
|
|
rclone
|
|
];
|
|
};
|
|
};
|
|
|
|
pipewire = {
|
|
services.pipewire = {
|
|
enable = true;
|
|
alsa.enable = true;
|
|
alsa.support32Bit = true;
|
|
pulse.enable = true;
|
|
jack.enable = true;
|
|
# wireplumber.enable = true; # this is default now
|
|
wireplumber.extraConfig = {
|
|
"monitor.bluez.properties" = {
|
|
"bluez5.enable-sbc-xq" = true;
|
|
"bluez5.enable-msbc" = true;
|
|
"bluez5.enable-hw-volume" = true;
|
|
"bluez5.roles" = ["hsp_hs" "hsp_ag" "hfp_hf" "hfp_ag"];
|
|
};
|
|
};
|
|
extraConfig.pipewire."91-null-sinks" = {
|
|
"context.objects" = [
|
|
{
|
|
# A default dummy driver. This handles nodes marked with the "node.always-driver"
|
|
# properyty when no other driver is currently active. JACK clients need this.
|
|
factory = "spa-node-factory";
|
|
args = {
|
|
"factory.name" = "support.node.driver";
|
|
"node.name" = "Dummy-Driver";
|
|
"priority.driver" = 8000;
|
|
};
|
|
}
|
|
{
|
|
factory = "adapter";
|
|
args = {
|
|
"factory.name" = "support.null-audio-sink";
|
|
"node.name" = "Microphone-Proxy";
|
|
"node.description" = "Microphone";
|
|
"media.class" = "Audio/Source/Virtual";
|
|
"audio.position" = "MONO";
|
|
};
|
|
}
|
|
{
|
|
factory = "adapter";
|
|
args = {
|
|
"factory.name" = "support.null-audio-sink";
|
|
"node.name" = "Main-Output-Proxy";
|
|
"node.description" = "Main Output";
|
|
"media.class" = "Audio/Sink";
|
|
"audio.position" = "FL,FR";
|
|
};
|
|
}
|
|
];
|
|
};
|
|
/*
|
|
extraConfig.pipewire."92-low-latency" = {
|
|
context.properties = {
|
|
default.clock.rate = 48000;
|
|
default.clock.quantum = 32;
|
|
default.clock.min-quantum = 32;
|
|
default.clock.max-quantum = 32;
|
|
};
|
|
};
|
|
*/
|
|
};
|
|
|
|
# recommended by https://nixos.wiki/wiki/PipeWire
|
|
security.rtkit.enable = true;
|
|
|
|
/*
|
|
services.pipewire = {
|
|
enable = true;
|
|
|
|
wireplumber.enable = true;
|
|
pulse.enable = true;
|
|
jack.enable = true;
|
|
|
|
alsa = {
|
|
enable = true;
|
|
support32Bit = true;
|
|
};
|
|
};
|
|
|
|
hardware = {
|
|
pulseaudio = {
|
|
enable = false;
|
|
support32Bit = true;
|
|
};
|
|
};
|
|
|
|
security = {
|
|
# I forget why I need these exactly...
|
|
polkit.enable = true;
|
|
|
|
rtkit.enable = true;
|
|
};
|
|
*/
|
|
};
|
|
|
|
music-production = {pkgs, ...}: {
|
|
/*
|
|
TODO: may want to force nixpkgs-stable for a more-stable music production
|
|
environment?
|
|
*/
|
|
imports = [
|
|
{
|
|
environment.systemPackages = with pkgs; [
|
|
helvum # pipewire graph/patchbay GUI
|
|
ardour # DAW
|
|
helm # synth
|
|
];
|
|
}
|
|
];
|
|
|
|
/*
|
|
TODO: things to look into for music production:
|
|
- https://linuxmusicians.com/viewtopic.php?t=27016
|
|
- KXStudio?
|
|
- falktx (https://github.com/DISTRHO/Cardinal)
|
|
*/
|
|
};
|
|
|
|
podman = {pkgs, ...}: {
|
|
environment = {
|
|
systemPackages = with pkgs; [
|
|
podman-compose
|
|
];
|
|
};
|
|
|
|
virtualisation = {
|
|
podman = {
|
|
enable = true;
|
|
dockerCompat = true;
|
|
dockerSocket.enable = true;
|
|
defaultNetwork.settings.dns_enabled = true;
|
|
# networkSocket.enable = true;
|
|
};
|
|
|
|
oci-containers = {
|
|
backend = "podman";
|
|
};
|
|
};
|
|
|
|
networking = {
|
|
extraHosts = ''
|
|
127.0.0.1 host.docker.internal
|
|
::1 host.docker.internal
|
|
127.0.0.1 host.containers.internal
|
|
::1 host.containers.internal
|
|
'';
|
|
};
|
|
};
|
|
|
|
virtual-machines = {pkgs, ...}: {
|
|
virtualisation.libvirtd.enable = true;
|
|
users.users.daniel.extraGroups = ["libvirtd"];
|
|
};
|
|
|
|
virtual-machines-gui = {pkgs, ...}: {
|
|
programs.virt-manager.enable = true;
|
|
};
|
|
|
|
postgres = {pkgs, ...}: {
|
|
# this is really just for development usage
|
|
services.postgresql = {
|
|
enable = true;
|
|
ensureDatabases = ["daniel"];
|
|
ensureUsers = [
|
|
{
|
|
name = "daniel";
|
|
ensureDBOwnership = true;
|
|
}
|
|
];
|
|
# enableTCPIP = true;
|
|
|
|
package = pkgs.postgresql_15;
|
|
|
|
authentication = pkgs.lib.mkOverride 10 ''
|
|
#type database DBuser auth-method
|
|
local all postgres peer map=superuser_map
|
|
local all daniel peer map=superuser_map
|
|
local sameuser all peer map=superuser_map
|
|
|
|
# lan ipv4
|
|
host all all 10.0.0.0/24 trust
|
|
host all all 127.0.0.1/32 trust
|
|
|
|
# tailnet ipv4
|
|
host all all 100.64.0.0/10 trust
|
|
'';
|
|
|
|
identMap = ''
|
|
# ArbitraryMapName systemUser DBUser
|
|
superuser_map root postgres
|
|
superuser_map postgres postgres
|
|
superuser_map daniel postgres
|
|
|
|
superuser_map /^(.*)$ \1 # Let other names login as themselves
|
|
'';
|
|
};
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
pgcli
|
|
];
|
|
};
|
|
|
|
printing = {pkgs, ...}: {
|
|
services.printing.enable = true;
|
|
services.printing.browsing = true;
|
|
services.printing.browsedConf = ''
|
|
BrowseDNSSDSubTypes _cups,_print
|
|
BrowseLocalProtocols all
|
|
BrowseRemoteProtocols all
|
|
CreateIPPPrinterQueues All
|
|
|
|
BrowseProtocols all
|
|
'';
|
|
services.printing.drivers = [pkgs.gutenprint];
|
|
};
|
|
|
|
enable-flatpaks-and-appimages = {
|
|
services.flatpak.enable = true;
|
|
programs.appimage.binfmt = true;
|
|
};
|
|
|
|
wifi = {lib, ...}: let
|
|
inherit (lib) mkDefault;
|
|
in {
|
|
networking.networkmanager = {
|
|
enable = mkDefault true;
|
|
# ensureProfiles = {
|
|
# profiles = {
|
|
# home-wifi = {
|
|
# id="home-wifi";
|
|
# permissions = "";
|
|
# type = "wifi";
|
|
# };
|
|
# wifi = {
|
|
# ssid = "";
|
|
# };
|
|
# wifi-security = {
|
|
# # auth-alg = "";
|
|
# # key-mgmt = "";
|
|
# psk = "";
|
|
# };
|
|
# };
|
|
# };
|
|
};
|
|
systemd.services.NetworkManager-wait-online.enable = mkDefault false;
|
|
|
|
/*
|
|
TODO: networking.networkmanager.wifi.backend = "iwd"; ?
|
|
TODO: powersave?
|
|
TODO: can I pre-configure my usual wifi networks with SSIDs and PSKs loaded from secrets?
|
|
*/
|
|
hardware.wirelessRegulatoryDatabase = true;
|
|
boot.extraModprobeConfig = ''
|
|
options cfg80211 ieee80211_regdom="US"
|
|
'';
|
|
};
|
|
|
|
steam = {pkgs, ...}: {
|
|
# programs.gamescope.enable = true;
|
|
|
|
programs.steam = {
|
|
enable = true;
|
|
|
|
/*
|
|
extest.enable = true;
|
|
gamescopeSession.enable = true;
|
|
|
|
extraPackages = with pkgs; [
|
|
gamescope
|
|
];
|
|
*/
|
|
|
|
extraCompatPackages = with pkgs; [
|
|
proton-ge-bin
|
|
];
|
|
|
|
localNetworkGameTransfers.openFirewall = true;
|
|
remotePlay.openFirewall = true;
|
|
};
|
|
|
|
hardware.steam-hardware.enable = true;
|
|
services.udev.packages = with pkgs; [steam];
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
dualsensectl # for interfacing with dualsense controllers programmatically
|
|
];
|
|
|
|
# remote play ports - should be unnecessary due to programs.steam.remotePlay.openFirewall = true;
|
|
/*
|
|
networking.firewall.allowedUDPPortRanges = [ { from = 27031; to = 27036; } ];
|
|
networking.firewall.allowedTCPPortRanges = [ { from = 27036; to = 27037; } ];
|
|
*/
|
|
};
|
|
|
|
root = {
|
|
pkgs,
|
|
lib,
|
|
...
|
|
}: {
|
|
users.users.root = {
|
|
home = "/root";
|
|
createHome = true;
|
|
openssh.authorizedKeys.keys = [pubkey];
|
|
shell = lib.mkForce pkgs.fish;
|
|
};
|
|
home-manager.users.root = {
|
|
imports = [homeManagerModules.common];
|
|
|
|
home = {
|
|
username = "root";
|
|
homeDirectory = "/root";
|
|
stateVersion = pkgs.lib.mkDefault "24.05";
|
|
};
|
|
};
|
|
};
|
|
|
|
daniel = {pkgs, ...}: let
|
|
username = "daniel";
|
|
in {
|
|
users.groups.${username} = {};
|
|
users.users.${username} = {
|
|
isNormalUser = true;
|
|
home = "/home/${username}/.home";
|
|
createHome = true;
|
|
openssh.authorizedKeys.keys = [pubkey];
|
|
group = username;
|
|
extraGroups = ["users" "wheel" "video" "dialout" "uucp" "kvm"];
|
|
packages = [];
|
|
};
|
|
home-manager.users.daniel = {
|
|
imports = [homeManagerModules.common];
|
|
|
|
home = {
|
|
username = "daniel";
|
|
homeDirectory = "/home/daniel/.home";
|
|
stateVersion = pkgs.lib.mkDefault "24.05";
|
|
};
|
|
|
|
accounts.email.accounts = {
|
|
primary = {
|
|
primary = true;
|
|
address = "daniel@lyte.dev";
|
|
};
|
|
legacy = {
|
|
address = "wraithx2@gmail.com";
|
|
};
|
|
io = {
|
|
# TODO: finalize deprecation
|
|
address = "daniel@lytedev.io";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
valerie = let
|
|
username = "valerie";
|
|
in {
|
|
users.groups.${username} = {};
|
|
users.users.${username} = {
|
|
isNormalUser = true;
|
|
home = "/home/${username}";
|
|
createHome = true;
|
|
openssh.authorizedKeys.keys = [pubkey];
|
|
group = username;
|
|
extraGroups = ["users" "video"];
|
|
packages = [];
|
|
};
|
|
};
|
|
|
|
flanfam = let
|
|
username = "flanfam";
|
|
in {
|
|
users.groups.${username} = {};
|
|
users.users.${username} = {
|
|
isNormalUser = true;
|
|
home = "/home/${username}";
|
|
createHome = true;
|
|
openssh.authorizedKeys.keys = [pubkey];
|
|
group = username;
|
|
extraGroups = ["users" "video"];
|
|
packages = [];
|
|
};
|
|
};
|
|
|
|
family-users = {
|
|
imports = with nixosModules; [
|
|
# daniel # part of common
|
|
valerie
|
|
flanfam
|
|
];
|
|
};
|
|
|
|
# a common module that is intended to be imported by all NixOS systems
|
|
common = {
|
|
lib,
|
|
pkgs,
|
|
modulesPath,
|
|
...
|
|
}: {
|
|
imports = with nixosModules; [
|
|
(modulesPath + "/installer/scan/not-detected.nix")
|
|
default-nix-configuration-and-overlays
|
|
|
|
# allow any machine to make use of sops secrets
|
|
sops-nix.nixosModules.sops
|
|
|
|
# allow disko modules to manage disk config
|
|
disko.nixosModules.disko
|
|
|
|
fallback-hostname
|
|
no-giant-logs
|
|
allow-redistributable-firmware
|
|
mdns-and-lan-service-discovery
|
|
tailscale
|
|
ssh-server
|
|
|
|
my-favorite-default-system-apps
|
|
mosh
|
|
|
|
daniel
|
|
root
|
|
];
|
|
|
|
# boot.tmp.useTmpfs = true;
|
|
systemd.services.nix-daemon = {
|
|
environment.TMPDIR = "/var/tmp";
|
|
};
|
|
boot.tmp.cleanOnBoot = true;
|
|
# boot.uki.tries = 3;
|
|
# services.irqbalance.enable = true;
|
|
|
|
# this is not ready for primetime yet
|
|
# services.kanidm = {
|
|
# enableClient = true;
|
|
# enablePam = true;
|
|
# package = pkgs.kanidm;
|
|
|
|
# clientSettings.uri = "https://idm.h.lyte.dev";
|
|
# unixSettings = {
|
|
# # hsm_pin_path = "/somewhere/else";
|
|
# pam_allowed_login_groups = [];
|
|
# };
|
|
# };
|
|
# systemd.tmpfiles.rules = [
|
|
# "d /etc/kanidm 1755 nobody users -"
|
|
# ];
|
|
|
|
# module has the incorrect file permissions out of the box
|
|
# environment.etc = {
|
|
/*
|
|
"kanidm" = {
|
|
enable = true;
|
|
user = "nobody";
|
|
group = "users";
|
|
mode = "0755";
|
|
};
|
|
*/
|
|
# "kanidm/unixd" = {
|
|
# user = "kanidm-unixd";
|
|
# group = "kanidm-unixd";
|
|
# mode = "0700";
|
|
# };
|
|
# "kanidm/config" = {
|
|
# user = "nobody";
|
|
# group = "users";
|
|
# mode = "0755";
|
|
# };
|
|
# };
|
|
|
|
programs.gnupg.agent = {
|
|
enable = true;
|
|
pinentryPackage = lib.mkDefault pkgs.pinentry-tty;
|
|
};
|
|
|
|
time = {
|
|
timeZone = "America/Chicago";
|
|
};
|
|
|
|
i18n = {
|
|
defaultLocale = lib.mkDefault "en_US.UTF-8";
|
|
};
|
|
|
|
services = {
|
|
xserver.xkb = {
|
|
layout = lib.mkDefault "us";
|
|
|
|
# have the caps-lock key instead be a ctrl key
|
|
options = lib.mkDefault "ctrl:nocaps";
|
|
};
|
|
smartd.enable = true;
|
|
fwupd.enable = true;
|
|
};
|
|
|
|
console = {
|
|
# font = "Lat2-Terminus16"; # TODO: would like this font for non-hidpi displays, but this is not dynamic enough?
|
|
useXkbConfig = lib.mkDefault true;
|
|
earlySetup = lib.mkDefault true;
|
|
|
|
colors = with style.colors; [
|
|
bg
|
|
red
|
|
green
|
|
orange
|
|
blue
|
|
purple
|
|
yellow
|
|
fg3
|
|
fgdim
|
|
red
|
|
green
|
|
orange
|
|
blue
|
|
purple
|
|
yellow
|
|
fg
|
|
];
|
|
};
|
|
|
|
networking = {
|
|
useDHCP = lib.mkDefault true;
|
|
firewall = {
|
|
enable = lib.mkDefault true;
|
|
allowPing = lib.mkDefault true;
|
|
};
|
|
};
|
|
|
|
system.stateVersion = lib.mkDefault "24.05";
|
|
};
|
|
|
|
# intended to be auto-logged in and only run a certain application
|
|
# flanfamkiosk = {};
|
|
}
|