From 8bc9666269ab28d3550af90ba429c6a74dd3bfa3 Mon Sep 17 00:00:00 2001 From: Gabriele Modena Date: Tue, 15 Oct 2024 23:07:05 +0200 Subject: [PATCH] installer: forcefully delete remotes when managing state. Remove remotes even if refs are installed. This can happen in case of manual installation or remotes and packages. If the user sets uninstallUnmanagedState = true forcefully remove any eventuall dangling dependency. --- modules/installer.nix | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/modules/installer.nix b/modules/installer.nix index 8fa7f1d..3c42807 100644 --- a/modules/installer.nix +++ b/modules/installer.nix @@ -173,15 +173,16 @@ let ''; flatpakAddRemote = installation: remotes: map (flatpakAddRemotesCmd installation) remotes; - flatpakDeleteRemotesCmd = installation: {}: '' + flatpakDeleteRemotesCmd = installation: uninstallUnmanagedState: {}: '' # Delete all remotes that are present in the old state but not the new one # $OLD_STATE and $NEW_STATE are globals, declared in the output of pkgs.writeShellScript. + # If uninstallUnmanagedState is true, then the remotes will be deleted forcefully. ${pkgs.jq}/bin/jq -r -n \ --argjson old "$OLD_STATE" \ --argjson new "$NEW_STATE" \ '(($old.remotes // []) - ($new.remotes // []))[]' \ | while read -r REMOTE_NAME; do - ${pkgs.flatpak}/bin/flatpak remote-delete --${installation} $REMOTE_NAME + ${pkgs.flatpak}/bin/flatpak remote-delete ${if uninstallUnmanagedState then " --force " else " " } --${installation} $REMOTE_NAME done ''; @@ -215,7 +216,7 @@ pkgs.writeShellScript "flatpak-managed-install" '' # Uninstall remotes that have been removed from services.flatpak.packages # since the previous activation. - ${flatpakDeleteRemotesCmd installation {}} + ${flatpakDeleteRemotesCmd installation uninstallUnmanagedState {}} # Install packages ${mkFlatpakInstallCmd installation updateApplications cfg.packages}