From 80e38f86696c522e467a2c474fdffa0da7f2e4bd Mon Sep 17 00:00:00 2001 From: mp-bw <59324545+mp-bw@users.noreply.github.com> Date: Fri, 24 Mar 2023 16:34:48 -0400 Subject: [PATCH] [PM-1567] Fix for vault timeout 'never' not persisting (#2440) --- src/Core/Services/StateService.cs | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/Core/Services/StateService.cs b/src/Core/Services/StateService.cs index 598891929..5e04b6e3c 100644 --- a/src/Core/Services/StateService.cs +++ b/src/Core/Services/StateService.cs @@ -526,8 +526,7 @@ namespace Bit.Core.Services { var reconciledOptions = ReconcileOptions(new StorageOptions { UserId = userId }, await GetDefaultStorageOptionsAsync()); - return await GetValueAsync(Constants.VaultTimeoutKey(reconciledOptions.UserId), reconciledOptions) ?? - Constants.VaultTimeoutDefault; + return await GetValueAsync(Constants.VaultTimeoutKey(reconciledOptions.UserId), reconciledOptions); } public async Task SetVaultTimeoutAsync(int? value, string userId = null) @@ -542,7 +541,7 @@ namespace Bit.Core.Services var reconciledOptions = ReconcileOptions(new StorageOptions { UserId = userId }, await GetDefaultStorageOptionsAsync()); return await GetValueAsync(Constants.VaultTimeoutActionKey(reconciledOptions.UserId), - reconciledOptions) ?? VaultTimeoutAction.Lock; + reconciledOptions); } public async Task SetVaultTimeoutActionAsync(VaultTimeoutAction? value, string userId = null) @@ -1444,6 +1443,14 @@ namespace Bit.Core.Services } _state.Accounts[account.Profile.UserId] = account; } + + // Check if account has logged in before by checking a guaranteed non-null pref + if (await GetVaultTimeoutActionAsync(account.Profile.UserId) == null) + { + // Account has never logged in, set defaults + await SetVaultTimeoutAsync(Constants.VaultTimeoutDefault, account.Profile.UserId); + await SetVaultTimeoutActionAsync(VaultTimeoutAction.Lock, account.Profile.UserId); + } } private StorageOptions ReconcileOptions(StorageOptions requestedOptions, StorageOptions defaultOptions)