Refactor additional packages

This commit is contained in:
DashieTM 2024-09-08 17:30:48 +02:00
parent 2e90a3b7a1
commit b83ccc7bfe
3 changed files with 161 additions and 86 deletions

View file

@ -26,16 +26,30 @@
Note that these are installed even if base packages is disabled, e.g. you can also use this as the only packages to install.
'';
};
special_programs = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special program configuration to be added which require programs.something notation.
'';
};
special_services = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special services configuration to be added which require an services.something notation.
'';
};
};
};
config = (
lib.optionalAttrs (options ? environment.systemPackages) {
environment.systemPackages = config.mods.base_packages.additional_packages;
}
// (lib.mkIf config.mods.base_packages.enable (
lib.optionalAttrs (options ? environment.systemPackages) {
environment.systemPackages = with pkgs; [
config = lib.optionalAttrs (options ? environment.systemPackages) {
environment.systemPackages =
if config.mods.base_packages.enable then
with pkgs;
[
adwaita-icon-theme
dbus
dconf
@ -58,10 +72,15 @@
seahorse
upower
xorg.xkbutils
];
]
++ config.mods.base_packages.additional_packages
else
config.mods.base_packages.additional_packages;
gtk.iconCache.enable = false;
services = {
services =
if config.mods.base_packages.enable then
{
upower.enable = true;
dbus = {
enable = true;
@ -72,9 +91,14 @@
nssmdns4 = true;
openFirewall = true;
};
};
}
// config.mods.base_packages.special_services
else
config.mods.base_packages.special_services;
programs = {
programs =
if config.mods.base_packages.enable then
{
nix-ld = {
enable = true;
libraries = with pkgs; [
@ -94,8 +118,10 @@
};
ssh.startAgent = true;
gnupg.agent.enable = true;
};
}
))
);
// config.mods.base_packages.special_programs
else
config.mods.base_packages.special_programs;
};
}

View file

@ -22,6 +22,22 @@
Will be installed regardless of default home manager packages are installed.
'';
};
special_programs = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special program configuration to be added which require programs.something notation.
'';
};
special_services = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special services configuration to be added which require an services.something notation.
'';
};
matrixClient = lib.mkOption {
default = pkgs.nheko;
example = null;
@ -59,13 +75,9 @@
description = "Additional browser -> second to firefox, the only installed browser if firefox is disabled";
};
};
config =
(lib.optionalAttrs (options ? home.packages) {
home.packages = config.mods.home_packages.additional_packages;
})
// lib.mkIf config.mods.home_packages.useDefaultPackages (
lib.optionalAttrs (options ? home.packages) {
config = lib.optionalAttrs (options ? home.packages) {
home.packages =
if config.mods.home_packages.useDefaultPackages then
with pkgs;
[
# TODO add fcp once fixed....
@ -107,14 +119,24 @@
zenith
zoxide
]
++ config.mods.home_packages.additional_packages;
++ config.mods.home_packages.additional_packages
else
config.mods.home_packages.additional_packages;
xdg.configFile."direnv/direnv.toml".source = (pkgs.formats.toml { }).generate "direnv" {
global = {
warn_timeout = "-1s";
};
};
}
);
programs =
if config.mods.home_packages.useDefaultPackages then
config.mods.home_packages.special_programs
else
config.mods.home_packages.special_programs;
services =
if config.mods.home_packages.useDefaultPackages then
config.mods.home_packages.special_services
else
config.mods.home_packages.special_services;
};
}

View file

@ -21,14 +21,28 @@
Additional media packages.
'';
};
special_programs = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special program configuration to be added which require programs.something notation.
'';
};
config = (
lib.optionalAttrs (options ? home.packages) {
home.packages = config.mods.media.additionalPackages;
}
// (lib.mkIf config.mods.media.useBasePackages (
lib.optionalAttrs (options ? home.packages) {
home.packages = with pkgs; [
special_services = lib.mkOption {
default = { };
example = { };
type = with lib.types; attrsOf anything;
description = ''
special services configuration to be added which require an services.something notation.
'';
};
};
config = lib.optionalAttrs (options ? home.packages) {
home.packages =
if config.mods.media.useBasePackages then
with pkgs;
[
# base audio
pipewire
wireplumber
@ -54,10 +68,23 @@
gimp
krita
yt-dlp
];
programs.obs-studio.enable = true;
programs.obs-studio.plugins = with pkgs; [ obs-studio-plugins.obs-vaapi ];
]
++ config.mods.media.additionalPackages
else
config.mods.media.additionalPackages;
programs =
if config.mods.media.useBasePackages then
{
obs-studio.enable = true;
obs-studio.plugins = with pkgs; [ obs-studio-plugins.obs-vaapi ];
}
))
);
// config.mods.media.special_programs
else
config.mods.media.special_programs;
services =
if config.mods.media.useBasePackages then
config.mods.media.special_services
else
config.mods.media.special_services;
};
}