1

add external module support to flatpak module

This commit is contained in:
2022-08-08 23:35:12 +02:00
parent fd2801d7ed
commit ff6db464bf

View File

@ -3,6 +3,12 @@
with lib; with lib;
with mylib.modules; with mylib.modules;
# NOTE: The module is also used by other modules (gaming, audio).
# It is important that every flatpak interaction is handled through this module
# to prevent that anything is removed by a module although it is required by another one
# TODO: Also need a library function to enable and concatenate different flatpak overrides (also global overrides)
let let
cfg = config.modules.flatpak; cfg = config.modules.flatpak;
in { in {
@ -16,10 +22,26 @@ in {
autoPrune = mkBoolOpt false "Remove unused packages on nixos-rebuild"; autoPrune = mkBoolOpt false "Remove unused packages on nixos-rebuild";
# TODO: Add library function to make this easier # TODO: Add library function to make this easier
# The flatpak name should be included and a list of all enabled apps should be available # TODO: The flatpak name should be included and a list of all enabled apps should be available
# TODO: Do this for strings + packages
discord.enable = mkBoolOpt false "Enable Discord"; discord.enable = mkBoolOpt false "Enable Discord";
spotify.enable = mkBoolOpt false "Enable Spotify"; spotify.enable = mkBoolOpt false "Enable Spotify";
flatseal.enable = mkBoolOpt false "Enable Flatseal"; flatseal.enable = mkBoolOpt false "Enable Flatseal";
bottles.enable = mkBoolOpt false "Enable Bottles";
# This is mainly used by other modules to allow them to use flatpak packages
extraInstall = mkOption {
type = types.listOf types.str;
default = [ ];
description = "Flatpaks that will be installed additionally";
};
# This doesn't uninstall if any flatpak is still present in the extraInstall list
extraRemove = mkOption {
type = types.listOf types.str;
default = [ ];
description = "Flatpaks that will be removed additionally (use with extraInstall)";
};
}; };
config = mkIf cfg.enable { config = mkIf cfg.enable {
@ -56,16 +78,18 @@ in {
# TODO: I should find a smarter way than this to make it easy to add flatpak options # TODO: I should find a smarter way than this to make it easy to add flatpak options
{ {
# TODO: Enable this block only if any flatpak is enabled # TODO: Enable this block only if any flatpak is enabled
# TODO: Only install new flatpaks, check with flatpak list | grep <name> | wc -l
installFlatpaks = let installFlatpaks = let
to_install = builtins.concatLists [ to_install = builtins.concatLists [
(optionals cfg.discord.enable [ "com.discordapp.Discord" ]) (optionals cfg.discord.enable [ "com.discordapp.Discord" ])
(optionals cfg.spotify.enable [ "com.spotify.Client" ]) (optionals cfg.spotify.enable [ "com.spotify.Client" ])
(optionals cfg.flatseal.enable [ "com.github.tchx84.Flatseal" ]) (optionals cfg.flatseal.enable [ "com.github.tchx84.Flatseal" ])
(optionals cfg.bottles.enable [ "com.usebottles.bottles" ])
cfg.extraInstall
]; ];
to_install_str = builtins.concatStringsSep " " to_install; to_install_str = builtins.concatStringsSep " " to_install;
in in
# By using || we make sure this command never throws any errors
lib.hm.dag.entryAfter [ "writeBoundary" ] '' lib.hm.dag.entryAfter [ "writeBoundary" ] ''
sudo flatpak install -y ${to_install_str} || echo "Nothing to be installed" sudo flatpak install -y ${to_install_str} || echo "Nothing to be installed"
''; '';
@ -73,16 +97,19 @@ in {
{ {
# TODO: Enable this block only if any flatpak is disabled # TODO: Enable this block only if any flatpak is disabled
# TODO: Only remove flatpaks that are installed, check with flatpak list | grep <name> | wc -l
removeFlatpaks = let removeFlatpaks = let
to_remove = builtins.concatLists [ to_remove = builtins.concatLists [
(optionals (!cfg.discord.enable) [ "com.discordapp.Discord" ]) (optionals (!cfg.discord.enable) [ "com.discordapp.Discord" ])
(optionals (!cfg.spotify.enable) [ "com.spotify.Client" ]) (optionals (!cfg.spotify.enable) [ "com.spotify.Client" ])
(optionals (!cfg.flatseal.enable) [ "com.github.tchx84.Flatseal" ]) (optionals (!cfg.flatseal.enable) [ "com.github.tchx84.Flatseal" ])
(optionals (!cfg.bottles.enable) [ "com.usebottles.bottles" ])
# Remove only the flatpaks that are not present in extraInstall
(without cfg.extraRemove cfg.extraInstall)
]; ];
to_remove_str = builtins.concatStringsSep " " to_remove; to_remove_str = builtins.concatStringsSep " " to_remove;
in in
# By using || we make sure this command never throws any errors
lib.hm.dag.entryAfter [ "writeBoundary" ] '' lib.hm.dag.entryAfter [ "writeBoundary" ] ''
sudo flatpak uninstall -y ${to_remove_str} || echo "Nothing to be removed" sudo flatpak uninstall -y ${to_remove_str} || echo "Nothing to be removed"
''; '';
@ -94,6 +121,7 @@ in {
''; '';
}) })
# Execute this after flatpak removal as there can be leftovers
(mkIf cfg.autoPrune { (mkIf cfg.autoPrune {
pruneFlatpak = lib.hm.dag.entryAfter [ "writeBoundary" "removeFlatpak" ] '' pruneFlatpak = lib.hm.dag.entryAfter [ "writeBoundary" "removeFlatpak" ] ''
sudo flatpak uninstall --unused -y sudo flatpak uninstall --unused -y