Compare commits

...

4 commits

32 changed files with 213 additions and 195 deletions

View file

@ -5,7 +5,9 @@
lib,
...
}: let
inherit (osConfig.niksos) games bluetooth;
inherit (osConfig.niksos) desktop hardware;
inherit (desktop) games;
inherit (hardware) bluetooth;
in {
# 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 ([

View file

@ -1,5 +1,10 @@
{pkgs, ...}: {
home.packages = [
{
pkgs,
osConfig,
lib,
...
}: {
home.packages = lib.mkIf osConfig.niksos.desktop.apps [
(pkgs.kodi-wayland.withPackages (exts: [exts.inputstream-adaptive exts.inputstreamhelper]))
];
}

View file

@ -1,6 +1,6 @@
{osConfig, ...}: {
programs.nixcord = {
enable = true;
enable = osConfig.niksos.desktop.apps;
discord.enable = false;
vesktop.enable = true;
vesktopConfig = {

View file

@ -4,7 +4,7 @@
osConfig,
...
}: {
home.packages = [
home.packages = lib.mkIf osConfig.niksos.desktop.apps [
pkgs.spotify
pkgs.signal-desktop
];

View file

@ -1,6 +1,6 @@
{
{osConfig, ...}: {
services.udiskie = {
enable = true;
inherit (osConfig.services.udisks2) enable;
tray = "never"; #NOTE: Don't have a bar (yet?)
};
}

View file

@ -6,7 +6,6 @@
./other.nix
./repl
./starship.nix
./transfer.nix
./yazi.nix
./zoxide.nix
];

View file

@ -7,6 +7,6 @@
extraConfig.push.autoSetupRemote = true;
lfs.enable = true;
};
git-credential-oauth.enable = true;
git-credential-oauth.enable = true; #FIXME: need to relogin for each push for some reason.
};
}

View file

@ -4,25 +4,35 @@
osConfig,
inputs,
...
}: {
}: let
inherit (lib) optionals;
inherit (osConfig.niksos.hardware) bluetooth portable;
inherit (osConfig.niksos.desktop) apps;
in {
home.packages =
[
pkgs.ripgrep
pkgs.fzf
pkgs.p7zip
pkgs.dua
pkgs.usbutils
pkgs.pciutils
pkgs.inetutils
pkgs.aria2
pkgs.dua
pkgs.file
pkgs.ffmpeg
pkgs.gurk-rs
pkgs.playerctl
]
++ lib.optionals osConfig.niksos.bluetooth [
++ optionals apps [
# Kinda don't need to include these on more minimal installs.
pkgs.ffmpeg
pkgs.imagemagick
pkgs.ghostscript
]
++ optionals bluetooth [
pkgs.ear2ctl
]
++ lib.optionals osConfig.niksos.portable.enable [
++ optionals portable.enable [
inputs.somcli.defaultPackage.${pkgs.system}
];
}

View file

@ -1,37 +0,0 @@
{
pkgs,
osConfig,
...
}: {
home.packages = [
(pkgs.writeShellScriptBin "transfer" ''
PASSWORD=$(sed 's/.*="\(.*\)"/\1/' ${osConfig.age.secrets.transferSh.path})
if [ -z "$PASSWORD" ]; then
echo "Error: Password not found."
return 1
fi
file_path="$1"
if [ -z "$file_path" ]; then
echo "Usage: transfer <file>"
return 1
fi
response=$(curl -sD - --user "jsw:$PASSWORD" --progress-bar --upload-file "$file_path" "https://share.jsw.tf/$(basename "$file_path")")
if [ $? -eq 0 ]; then
DELETE=$(echo "$response" | grep x-url-delete | sed "s/.*\///")
URL=$(echo "$response" | tail -n1)
echo "Delete code: $DELETE"
echo "URL: $URL"
else
echo "Upload failed."
return 1
fi
echo
'')
];
}

View file

@ -5,7 +5,7 @@
...
}: let
inherit (lib) mkIf;
cfg = osConfig.niksos.desktop.hyprland;
cfg = osConfig.programs.hyprland.enable;
in {
imports = [
./fuzzel.nix

View file

@ -5,7 +5,7 @@
...
}: {
programs.fuzzel = {
enable = osConfig.niksos.desktop.hyprland;
inherit (osConfig.programs.hyprland) enable;
settings.main = {
launch-prefix = "${lib.getExe pkgs.uwsm} app --";
};

View file

@ -8,7 +8,9 @@
}: let
inherit (lib) getExe;
inherit (config.lib.stylix.colors) base0D;
inherit (osConfig.niksos) games portable;
inherit (osConfig.niksos) desktop hardware;
inherit (hardware) portable bluetooth;
inherit (desktop) games;
runOnce = program: "pgrep ${program} || uwsm app -- ${program}";
uwsm = getExe pkgs.uwsm;
@ -86,7 +88,7 @@ in {
"$m, Escape, exec, ${hyprlock}"
"$m, A, exec, ${pulsemixer}"
"$m, B, exec, ${bluetui}"
"$m, N, exec, ${nmtui}"
''
$m, S, exec, bash -c 'hyprctl notify -1 5000 "rgb(${base0D})" "$(${getExe (import ./scripts.nix {inherit pkgs;}).statusnotify})"'
@ -106,6 +108,7 @@ in {
"$m SHIFT, j, movewindow, d"
]
++ workspaces
++ lib.optional bluetooth "$m, B, exec, ${bluetui}"
++ lib.optionals games (let
torzu = "${
appE inputs.nixpkgs-torzu.legacyPackages.${pkgs.system}.torzu

View file

@ -15,7 +15,7 @@ in {
];
wayland.windowManager.hyprland = {
enable = osConfig.niksos.desktop.hyprland;
inherit (osConfig.programs.hyprland) enable;
settings = {
env = [
"QT_WAYLAND_DISABLE_WINDOWDECORATION,1"
@ -26,7 +26,7 @@ in {
"${uwsm} finalize"
"${hyprlock}" # Lock screen
]
++ lib.optional osConfig.niksos.portable.enable "powermode sync";
++ lib.optional osConfig.niksos.hardware.portable.enable "powermode sync";
};
};
}

View file

@ -6,7 +6,7 @@
inherit (config.lib.stylix.colors) base05;
in {
programs.hyprlock = {
enable = osConfig.niksos.desktop.hyprland;
inherit (osConfig.programs.hyprland) enable;
settings = {
general = {
@ -15,7 +15,7 @@ in {
hide_cursor = false;
no_fade_in = true;
};
auth."fingerprint:enabled" = true;
auth."fingerprint:enabled" = osConfig.niksos.hardware.fingerprint;
label = [
{

View file

@ -1,6 +1,8 @@
{osConfig, ...}: {
{osConfig, ...}: let
inherit (osConfig.niksos) desktop;
in {
services.mako = {
enable = osConfig.niksos.desktop.hyprland;
inherit (osConfig.programs.hyprland) enable;
settings.defaultTimeout = 5000;
};
}

View file

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

View file

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

View file

@ -9,27 +9,31 @@
services.fwupd.enable = false;
niksos = {
bluetooth = false;
desktop = {
enable = false;
hyprland = false;
kde = false;
apps = false;
games = false;
};
fingerprint = false;
games = false;
graphics = {
enable = false;
intel = false;
nvidia = false;
};
neovim = false;
portable = {
enable = false;
hyprland = {
powerSaver = "";
performance = "";
hardware = {
fingerprint = false;
bluetooth = false;
joycond = false;
graphics = {
enable = false;
intel = false;
nvidia = false;
};
portable = {
enable = false;
hyprland = {
powerSaver = "";
performance = "";
};
};
};
neovim = false;
server = false;
};

View file

@ -18,9 +18,23 @@ in {
];
options.niksos.desktop = {
enable = mkEO "enable desktop related programs.";
enable = mkEO "enable desktop related programs (+home manager).";
apps = mkEO "extra bloat.";
games = mkEO "gaming related programs";
hyprland = mkEO "enable hyprland related programs.";
kde = mkEO "enable kde specialisation.";
activeDesktop = lib.mkOption {
type = lib.types.enum ["hyprland" "kde"];
description = "What desktop should be the default, other enabled desktops will be specialized.";
default =
if cfg.hyprland
then "hyprland"
else if cfg.kde
then "kde"
else "hyprland";
example = "hyprland";
};
};
config.assertions = mkIf (cfg.hyprland
@ -29,5 +43,9 @@ in {
assertion = cfg.enable;
message = "You need to enable desktop for the hyprland/kde module to work";
}
{
assertion = config.niksos.desktop.enable;
message = "The games option needs desktop to be enabled for it to work properly (it enables home-manager).";
}
];
}

View file

@ -5,21 +5,9 @@
}: {
config = lib.mkIf config.niksos.desktop.enable {
# greetd display manager
services.greetd = let
session = {
command = lib.mkDefault "${lib.getExe config.programs.uwsm.package} start hyprland-uwsm.desktop";
user = "jsw";
};
in {
services.greetd = {
enable = true;
settings = {
terminal.vt = 1;
default_session = session;
initial_session = session;
};
settings.terminal.vt = 1;
};
programs.uwsm.enable = config.niksos.desktop.hyprland;
};
}

View file

@ -1,16 +1,37 @@
{
config,
pkgs,
lib,
pkgs,
config,
...
}: let
cfg = config.niksos.desktop.enable && config.niksos.desktop.hyprland;
inherit (config.niksos) desktop;
cfg = desktop.enable && desktop.hyprland;
active = cfg && desktop.activeDesktop == "hyprland";
ifActive = x: lib.mkIf active x;
in {
config = lib.mkIf cfg {
programs.hyprland = {
specialisation.de.configuration =
lib.mkIf cfg
&& !active {
niksos.desktop.activeDesktop = lib.mkForce "hyprland";
};
programs = ifActive {
hyprland = {
enable = true;
withUWSM = true;
};
environment.sessionVariables.NIXOS_OZONE_WL = "1"; # Makes electron apps use wayland.
uwsm.enable = true;
};
services.greetd.settings = let
session = {
command = "${lib.getExe config.programs.uwsm.package} start hyprland-uwsm.desktop";
user = "jsw";
};
in
ifActive {
default_session = session;
initial_session = session;
};
environment.sessionVariables.NIXOS_OZONE_WL = ifActive "1"; # Makes electron apps use wayland.
}

View file

@ -4,25 +4,28 @@
config,
...
}: let
cfg = config.niksos.desktop.enable && config.niksos.desktop.kde;
inherit (config.niksos) desktop;
cfg = desktop.enable && desktop.kde;
active = cfg && desktop.activeDesktop == "kde";
ifActive = x: lib.mkIf active x;
in {
specialisation.de.configuration = lib.mkIf cfg {
niksos.desktop.hyprland = lib.mkForce false;
services = {
greetd = let
session.command = "${pkgs.kdePackages.plasma-workspace}/bin/startplasma-wayland";
in {
enable = true;
settings = {
terminal.vt = 1;
default_session = session;
initial_session = session;
};
};
desktopManager.plasma6.enable = true;
specialisation.de.configuration =
lib.mkIf cfg
&& !active {
niksos.desktop.activeDesktop = lib.mkForce "kde";
};
home-manager.users.jsw.stylix.autoEnable = false;
services = ifActive {
greetd.settings = let
session.command = "${pkgs.kdePackages.plasma-workspace}/bin/startplasma-wayland";
in {
default_session = session;
initial_session = session;
};
desktopManager.plasma6.enable = true;
};
home-manager.users = ifActive {
jsw.stylix.autoEnable = false;
};
}

View file

@ -3,10 +3,8 @@
lib,
pkgs,
...
}: let
cfg = config.niksos.desktop.enable && config.niksos.desktop.hyprland;
in {
systemd.user.services.polkit-gnome-authentication-agent-1 = lib.mkIf cfg {
}: {
systemd.user.services.polkit-gnome-authentication-agent-1 = lib.mkIf config.programs.hyprland.enable {
description = "polkit-gnome-authentication-agent-1";
wantedBy = ["graphical-session.target"];
wants = ["graphical-session.target"];

View file

@ -3,10 +3,8 @@
config,
lib,
...
}: let
cfg = config.niksos.desktop.enable && config.niksos.desktop.hyprland;
in {
xdg.portal = lib.mkIf cfg {
}: {
xdg.portal = lib.mkIf config.programs.hyprland.enable {
enable = true;
xdgOpenUsePortal = true;
config = {

View file

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

View file

@ -1,5 +1,7 @@
{
hardware.enableRedistributableFirmware = true;
{lib, ...}: let
mkEO = lib.mkEnableOption;
in {
config.hardware.enableRedistributableFirmware = true;
imports = [
./bluetooth.nix
@ -9,4 +11,32 @@
./joycond.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,22 +4,22 @@
pkgs,
...
}: let
inherit (config.niksos) fingerprint desktop;
inherit (lib) mkIf mkEnableOption;
inherit (config.niksos) hardware desktop;
inherit (lib) mkIf;
uwsm = lib.getExe pkgs.uwsm;
foot = lib.getExe pkgs.foot;
hypr = config.programs.hyprland.enable;
in {
options.niksos.fingerprint = mkEnableOption "fingerprint support.";
config = mkIf fingerprint {
config = mkIf hardware.fingerprint {
services = {
fprintd.enable = true;
logind.extraConfig = mkIf desktop.hyprland ''
logind.extraConfig = mkIf hypr ''
# dont shutdown when power button is short-pressed
HandlePowerKey=ignore
'';
};
home-manager.users.jsw.wayland.windowManager.hyprland.settings = mkIf desktop.hyprland {
home-manager.users.jsw.wayland.windowManager.hyprland.settings = mkIf hypr {
bind = [
", XF86PowerOff, exec, ${uwsm} app -- pgrep fprintd-verify && exit 0 || ${foot} -a 'foot-fprintd' sh -c 'fprintd-verify && systemctl sleep'"
];

View file

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

View file

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

View file

@ -5,22 +5,8 @@
...
}: let
inherit (config) niksos;
cfg = niksos.portable;
cfg = niksos.hardware.portable;
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 = {
services = lib.mkIf cfg.enable {
logind = {
@ -31,7 +17,7 @@ in {
power-profiles-daemon.enable = true;
};
environment.systemPackages = lib.mkIf niksos.desktop.hyprland [
environment.systemPackages = lib.mkIf config.programs.hyprland.enable [
(pkgs.writeScriptBin "powermode" ''
#!/usr/bin/env bash

View file

@ -4,16 +4,9 @@
lib,
...
}: let
cfg = config.niksos.games;
cfg = config.niksos.desktop.games;
in {
options.niksos.games = lib.mkEnableOption "gaming related stuff.";
config = lib.mkIf cfg {
assertions = [
{
assertion = config.niksos.desktop.enable;
message = "The games option needs desktop to be enabled for it to work properly (it enables home-manager).";
}
];
# nixpkgs.overlays = [
# (final: prev: let
# version = "1.4.2";

View file

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