Task: moved hardware options into the niksos.hardware suboptions.

This commit is contained in:
Jurn Wubben 2025-07-09 00:22:25 +02:00
parent 0924f9c267
commit 678c3cb4f7
15 changed files with 99 additions and 82 deletions

View file

@ -5,8 +5,9 @@
lib, lib,
... ...
}: let }: let
inherit (osConfig.niksos) desktop bluetooth; inherit (osConfig.niksos) desktop hardware;
inherit (desktop) games; inherit (desktop) games;
inherit (hardware) bluetooth;
in { in {
# Also look at system/programs/games.nix (some programs have to be overlayed or have systemwide modules that have to be installed.) # Also look at system/programs/games.nix (some programs have to be overlayed or have systemwide modules that have to be installed.)
home.packages = lib.mkIf games ([ home.packages = lib.mkIf games ([

View file

@ -4,25 +4,27 @@
osConfig, osConfig,
inputs, inputs,
... ...
}: { }: let
inherit (lib) optionals;
inherit (osConfig.niksos.hardware) bluetooth portable;
in {
home.packages = home.packages =
[ [
pkgs.ripgrep pkgs.ripgrep
pkgs.p7zip pkgs.p7zip
pkgs.dua
pkgs.ffmpeg
pkgs.usbutils pkgs.usbutils
pkgs.pciutils pkgs.pciutils
pkgs.inetutils pkgs.inetutils
pkgs.aria2 pkgs.aria2
pkgs.dua
pkgs.file pkgs.file
pkgs.ffmpeg
pkgs.gurk-rs
pkgs.playerctl
] ]
++ lib.optionals osConfig.niksos.bluetooth [ ++ optionals bluetooth [
pkgs.ear2ctl pkgs.ear2ctl
] ]
++ lib.optionals osConfig.niksos.portable.enable [ ++ optionals portable.enable [
inputs.somcli.defaultPackage.${pkgs.system} inputs.somcli.defaultPackage.${pkgs.system}
]; ];
} }

View file

@ -8,7 +8,8 @@
}: let }: let
inherit (lib) getExe; inherit (lib) getExe;
inherit (config.lib.stylix.colors) base0D; inherit (config.lib.stylix.colors) base0D;
inherit (osConfig.niksos) desktop portable bluetooth; inherit (osConfig.niksos) desktop hardware;
inherit (hardware) portable bluetooth;
inherit (desktop) games; inherit (desktop) games;
runOnce = program: "pgrep ${program} || uwsm app -- ${program}"; runOnce = program: "pgrep ${program} || uwsm app -- ${program}";

View file

@ -26,7 +26,7 @@ in {
"${uwsm} finalize" "${uwsm} finalize"
"${hyprlock}" # Lock screen "${hyprlock}" # Lock screen
] ]
++ lib.optional osConfig.niksos.portable.enable "powermode sync"; ++ lib.optional osConfig.niksos.hardware.portable.enable "powermode sync";
}; };
}; };
} }

View file

@ -15,7 +15,7 @@ in {
hide_cursor = false; hide_cursor = false;
no_fade_in = true; no_fade_in = true;
}; };
auth."fingerprint:enabled" = true; auth."fingerprint:enabled" = osConfig.niksos.hardware.fingerprint;
label = [ label = [
{ {

View file

@ -5,8 +5,10 @@
niksos = { niksos = {
server = true; server = true;
graphics.nvidia = false; #FIXME: Compile error hardware.graphics = {
graphics.intel = true; nvidia = false; #FIXME: Compile error
intel = true;
};
}; };
services.immich = { services.immich = {

View file

@ -23,18 +23,21 @@
# programs.evolution.enable = true; # FIXME: move to appropiate place. # programs.evolution.enable = true; # FIXME: move to appropiate place.
niksos = { niksos = {
joycond = false; #NOTE: enable when game night lol hardware = {
fingerprint = true; joycond = false; #NOTE: enable when game night lol
bluetooth = true; fingerprint = true;
portable = { bluetooth = true;
enable = true;
hyprland = { portable = {
powerSaver = '' enable = true;
hyprctl keyword monitor eDP-1,2880x1920@60,0x0,1.5,vrr,1 hyprland = {
''; powerSaver = ''
performance = '' hyprctl keyword monitor eDP-1,2880x1920@60,0x0,1.5,vrr,1
hyprctl keyword monitor eDP-1,2880x1920@120,0x0,1.5,vrr,1 '';
''; performance = ''
hyprctl keyword monitor eDP-1,2880x1920@120,0x0,1.5,vrr,1
'';
};
}; };
}; };

View file

@ -9,7 +9,6 @@
services.fwupd.enable = false; services.fwupd.enable = false;
niksos = { niksos = {
bluetooth = false;
desktop = { desktop = {
enable = false; enable = false;
hyprland = false; hyprland = false;
@ -17,20 +16,24 @@
apps = false; apps = false;
games = false; games = false;
}; };
fingerprint = false; hardware = {
graphics = { fingerprint = false;
enable = false; bluetooth = false;
intel = false; joycond = false;
nvidia = false; graphics = {
}; enable = false;
neovim = false; intel = false;
portable = { nvidia = false;
enable = false; };
hyprland = { portable = {
powerSaver = ""; enable = false;
performance = ""; hyprland = {
powerSaver = "";
performance = "";
};
}; };
}; };
neovim = false;
server = false; server = false;
}; };

View file

@ -4,9 +4,7 @@
pkgs, pkgs,
... ...
}: { }: {
options.niksos.bluetooth = lib.mkEnableOption "bluetooth related stuff."; config = lib.mkIf config.niksos.hardware.bluetooth {
config = lib.mkIf config.niksos.bluetooth {
hardware.bluetooth = { hardware.bluetooth = {
enable = true; enable = true;
input.General.ClassicBondedOnly = false; input.General.ClassicBondedOnly = false;

View file

@ -1,5 +1,7 @@
{ {lib, ...}: let
hardware.enableRedistributableFirmware = true; mkEO = lib.mkEnableOption;
in {
config.hardware.enableRedistributableFirmware = true;
imports = [ imports = [
./bluetooth.nix ./bluetooth.nix
@ -9,4 +11,32 @@
./joycond.nix ./joycond.nix
./power.nix ./power.nix
]; ];
options.niksos.hardware = {
bluetooth = mkEO "bluetooth related stuff.";
fingerprint = mkEO "fingerprint support.";
graphics = {
enable = mkEO "core graphics";
intel = mkEO "additional intel drivers";
nvidia = mkEO "additoinal nvidia drivers";
};
joycond = mkEO "support for nintendo switch controllers.";
portable = {
enable = mkEO "battery optimisers";
hyprland = let
gen = mode:
lib.mkOption {
default = "";
description = "Shell commands to run when switching to ${mode} mode.";
type = lib.types.lines;
};
in {
powerSaver = gen "power-saver";
performance = gen "performance";
};
};
};
} }

View file

@ -4,13 +4,12 @@
pkgs, pkgs,
... ...
}: let }: let
inherit (config.niksos) fingerprint desktop; inherit (config.niksos) hardware desktop;
inherit (lib) mkIf mkEnableOption; inherit (lib) mkIf mkEnableOption;
uwsm = lib.getExe pkgs.uwsm; uwsm = lib.getExe pkgs.uwsm;
foot = lib.getExe pkgs.foot; foot = lib.getExe pkgs.foot;
in { in {
options.niksos.fingerprint = mkEnableOption "fingerprint support."; config = mkIf hardware.fingerprint {
config = mkIf fingerprint {
services = { services = {
fprintd.enable = true; fprintd.enable = true;
logind.extraConfig = mkIf desktop.hyprland '' logind.extraConfig = mkIf desktop.hyprland ''

View file

@ -5,20 +5,14 @@
... ...
}: let }: let
inherit (lib) optionals mkEnableOption mkDefault; inherit (lib) optionals mkEnableOption mkDefault;
inherit (config.niksos) graphics; inherit (config.niksos.hardware) graphics;
inherit (graphics) enable; inherit (graphics) enable nvidia intel;
nvidia = graphics.enable && graphics.nvidia; Nvidia = enable && nvidia;
intel = graphics.enable && graphics.intel; Intel = enable && intel;
in { in {
options.niksos.graphics = {
enable = mkEnableOption "core graphics";
intel = mkEnableOption "additional intel drivers";
nvidia = mkEnableOption "additoinal nvidia drivers";
};
config = { config = {
niksos.graphics.enable = mkDefault true; niksos.hardware.graphics.enable = mkDefault true;
hardware.graphics = { hardware.graphics = {
inherit enable; inherit enable;
@ -29,10 +23,10 @@ in {
vaapiVdpau vaapiVdpau
libvdpau-va-gl libvdpau-va-gl
] ]
++ optionals intel [ ++ optionals Intel [
pkgs.intel-media-driver pkgs.intel-media-driver
] ]
++ optionals nvidia [ ++ optionals Nvidia [
nvidia-vaapi-driver nvidia-vaapi-driver
]; ];
extraPackages32 = with pkgs.pkgsi686Linux; extraPackages32 = with pkgs.pkgsi686Linux;
@ -41,18 +35,18 @@ in {
vaapiVdpau vaapiVdpau
libvdpau-va-gl libvdpau-va-gl
] ]
++ optionals intel [ ++ optionals Intel [
pkgs.pkgsi686Linux.intel-media-driver pkgs.pkgsi686Linux.intel-media-driver
] ]
++ optionals nvidia [ ++ optionals Nvidia [
pkgs.pkgsi686Linux.nvidia-vaapi-driver pkgs.pkgsi686Linux.nvidia-vaapi-driver
]; ];
}; };
hardware.nvidia = { hardware.nvidia = {
modesetting.enable = nvidia; modesetting.enable = Nvidia;
open = false; open = false;
}; };
services.xserver.videoDrivers = optionals nvidia ["nvidia"]; services.xserver.videoDrivers = optionals Nvidia ["nvidia"];
}; };
} }

View file

@ -3,9 +3,7 @@
lib, lib,
... ...
}: { }: {
options.niksos.joycond = lib.mkEnableOption "support for nintendo switch controllers."; config.services = lib.mkIf config.niksos.hardware.joycond {
config.services = lib.mkIf config.niksos.joycond {
usbmuxd.enable = true; usbmuxd.enable = true;
joycond.enable = true; joycond.enable = true;
}; };

View file

@ -5,22 +5,8 @@
... ...
}: let }: let
inherit (config) niksos; inherit (config) niksos;
cfg = niksos.portable; cfg = niksos.hardware.portable;
in { in {
options.niksos.portable = {
enable = lib.mkEnableOption "battery optimisers";
hyprland = let
gen = mode:
lib.mkOption {
default = "";
description = "Shell commands to run when switching to ${mode} mode.";
type = lib.types.lines;
};
in {
powerSaver = gen "power-saver";
performance = gen "performance";
};
};
config = { config = {
services = lib.mkIf cfg.enable { services = lib.mkIf cfg.enable {
logind = { logind = {

View file

@ -1,7 +1,7 @@
{config, ...}: { {config, ...}: {
services.openssh = { services.openssh = {
enable = true; enable = true;
openFirewall = !config.niksos.portable.enable; openFirewall = !config.niksos.hardware.portable.enable;
settings.UseDns = true; settings.UseDns = true;
}; };
} }