mirror of
https://github.com/bitwarden/android.git
synced 2025-01-08 09:17:36 +03:00
271e6b3d92
* [Reset Password v1] Update Temp Password * fixed order of operations for reset temp password flow * Refactored bool with auth result * Finished removal of temp password flow from set password * iOS extension support plus extension bugfixes Co-authored-by: addison <addisonbeck1@gmail.com> Co-authored-by: Matt Portune <mportune@bitwarden.com>
90 lines
3.3 KiB
C#
90 lines
3.3 KiB
C#
using Bit.App.Resources;
|
|
using System;
|
|
using System.Threading.Tasks;
|
|
using Bit.Core.Exceptions;
|
|
using Bit.Core.Models.Request;
|
|
using Xamarin.Forms;
|
|
|
|
namespace Bit.App.Pages
|
|
{
|
|
public class UpdateTempPasswordPageViewModel : BaseChangePasswordViewModel
|
|
{
|
|
public UpdateTempPasswordPageViewModel()
|
|
{
|
|
PageTitle = AppResources.UpdateMasterPassword;
|
|
TogglePasswordCommand = new Command(TogglePassword);
|
|
ToggleConfirmPasswordCommand = new Command(ToggleConfirmPassword);
|
|
SubmitCommand = new Command(async () => await SubmitAsync());
|
|
}
|
|
|
|
public Command SubmitCommand { get; }
|
|
public Command TogglePasswordCommand { get; }
|
|
public Command ToggleConfirmPasswordCommand { get; }
|
|
public Action UpdateTempPasswordSuccessAction { get; set; }
|
|
public Action LogOutAction { get; set; }
|
|
|
|
public void TogglePassword()
|
|
{
|
|
ShowPassword = !ShowPassword;
|
|
(Page as UpdateTempPasswordPage).MasterPasswordEntry.Focus();
|
|
}
|
|
|
|
public void ToggleConfirmPassword()
|
|
{
|
|
ShowPassword = !ShowPassword;
|
|
(Page as UpdateTempPasswordPage).ConfirmMasterPasswordEntry.Focus();
|
|
}
|
|
|
|
public async Task SubmitAsync()
|
|
{
|
|
if (!await ValidateMasterPasswordAsync())
|
|
{
|
|
return;
|
|
}
|
|
|
|
// Retrieve details for key generation
|
|
var kdf = await _userService.GetKdfAsync();
|
|
var kdfIterations = await _userService.GetKdfIterationsAsync();
|
|
var email = await _userService.GetEmailAsync();
|
|
|
|
// Create new key and hash new password
|
|
var key = await _cryptoService.MakeKeyAsync(MasterPassword, email, kdf, kdfIterations);
|
|
var masterPasswordHash = await _cryptoService.HashPasswordAsync(MasterPassword, key);
|
|
|
|
// Create new encKey for the User
|
|
var newEncKey = await _cryptoService.RemakeEncKeyAsync(key);
|
|
|
|
// Create request
|
|
var request = new UpdateTempPasswordRequest
|
|
{
|
|
Key = newEncKey.Item2.EncryptedString,
|
|
NewMasterPasswordHash = masterPasswordHash,
|
|
MasterPasswordHint = Hint
|
|
};
|
|
|
|
// Initiate API action
|
|
try
|
|
{
|
|
await _deviceActionService.ShowLoadingAsync(AppResources.UpdatingPassword);
|
|
await _apiService.PutUpdateTempPasswordAsync(request);
|
|
await _deviceActionService.HideLoadingAsync();
|
|
|
|
UpdateTempPasswordSuccessAction?.Invoke();
|
|
}
|
|
catch (ApiException e)
|
|
{
|
|
await _deviceActionService.HideLoadingAsync();
|
|
if (e?.Error != null)
|
|
{
|
|
await _platformUtilsService.ShowDialogAsync(e.Error.GetSingleMessage(),
|
|
AppResources.AnErrorHasOccurred, AppResources.Ok);
|
|
}
|
|
else
|
|
{
|
|
await _platformUtilsService.ShowDialogAsync(AppResources.UpdatePasswordError,
|
|
AppResources.AnErrorHasOccurred, AppResources.Ok);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|