Task: moved hardware options into the niksos.hardware suboptions.
This commit is contained in:
parent
0924f9c267
commit
678c3cb4f7
15 changed files with 99 additions and 82 deletions
|
|
@ -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 ([
|
||||||
|
|
|
||||||
|
|
@ -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}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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}";
|
||||||
|
|
|
||||||
|
|
@ -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";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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 = [
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -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 = {
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
'';
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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 ''
|
||||||
|
|
|
||||||
|
|
@ -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"];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -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 = {
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue