Sebastian Stenzel 5 年之前
父节点
当前提交
29182156df
共有 1 个文件被更改,包括 7 次插入3 次删除
  1. 7 3
      main/ui/src/main/java/org/cryptomator/ui/launcher/UiLauncher.java

+ 7 - 3
main/ui/src/main/java/org/cryptomator/ui/launcher/UiLauncher.java

@@ -62,10 +62,10 @@ public class UiLauncher {
 		Desktop.getDesktop().addAppEventListener((AppReopenedListener) e -> showMainWindowAsync(hasTrayIcon));
 
 		// auto unlock
-		Collection<Vault> vaultsWithAutoUnlockEnabled = vaults.filtered(v -> v.getVaultSettings().unlockAfterStartup().get());
-		if (!vaultsWithAutoUnlockEnabled.isEmpty()) {
+		Collection<Vault> vaultsToAutoUnlock = vaults.filtered(this::shouldAttemptAutoUnlock);
+		if (!vaultsToAutoUnlock.isEmpty()) {
 			fxApplicationStarter.get(hasTrayIcon).thenAccept(app -> {
-				for (Vault vault : vaultsWithAutoUnlockEnabled){
+				for (Vault vault : vaultsToAutoUnlock){
 					app.startUnlockWorkflow(vault);
 				}
 			});
@@ -73,6 +73,10 @@ public class UiLauncher {
 
 		launchEventHandler.startHandlingLaunchEvents(hasTrayIcon);
 	}
+	
+	private boolean shouldAttemptAutoUnlock(Vault vault) {
+		return vault.isLocked() && vault.getVaultSettings().unlockAfterStartup().get();
+	}
 
 	private void showMainWindowAsync(boolean hasTrayIcon) {
 		fxApplicationStarter.get(hasTrayIcon).thenAccept(FxApplication::showMainWindow);