Refactor additional packages
This commit is contained in:
parent
2e90a3b7a1
commit
b83ccc7bfe
3 changed files with 161 additions and 86 deletions
|
|
@ -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;
|
||||
};
|
||||
}
|
||||
))
|
||||
);
|
||||
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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;
|
||||
};
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue