diff options
| author | Janito Vaqueiro Ferreira Filho <janito@mullvad.net> | 2021-04-19 19:11:37 +0000 |
|---|---|---|
| committer | Janito Vaqueiro Ferreira Filho <janito@mullvad.net> | 2021-04-20 14:26:48 +0000 |
| commit | f267042992407ae14e3ad634523a4f997a61a366 (patch) | |
| tree | 3a67027e4bf59bc9b2fe2f272ebb26ed3ccd9aa3 /android/src | |
| parent | aa03ed5af6abe74e2cbb3a560209f7665ed9e9db (diff) | |
| download | mullvadvpn-f267042992407ae14e3ad634523a4f997a61a366.tar.xz mullvadvpn-f267042992407ae14e3ad634523a4f997a61a366.zip | |
Send `null` `LoginStatus` event if login fails
Diffstat (limited to 'android/src')
| -rw-r--r-- | android/src/main/kotlin/net/mullvad/mullvadvpn/service/endpoint/AccountCache.kt | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/android/src/main/kotlin/net/mullvad/mullvadvpn/service/endpoint/AccountCache.kt b/android/src/main/kotlin/net/mullvad/mullvadvpn/service/endpoint/AccountCache.kt index 77acea34c0..6f978cd46f 100644 --- a/android/src/main/kotlin/net/mullvad/mullvadvpn/service/endpoint/AccountCache.kt +++ b/android/src/main/kotlin/net/mullvad/mullvadvpn/service/endpoint/AccountCache.kt @@ -185,21 +185,30 @@ class AccountCache(private val endpoint: ServiceEndpoint) { private suspend fun doLogin(account: String) { val result = daemon.await().getAccountData(account) - val expiry = when (result) { - is GetAccountDataResult.Ok -> DateTime.parse(result.accountData.expiry, EXPIRY_FORMAT) - is GetAccountDataResult.RpcError -> null - else -> return + when (result) { + is GetAccountDataResult.Ok -> { + val expiry = DateTime.parse(result.accountData.expiry, EXPIRY_FORMAT) + + finishLogin(account, expiry) + } + is GetAccountDataResult.RpcError -> finishLogin(account, null) + else -> finishLogin(null, null) } + } + private suspend fun finishLogin(maybeAccount: String?, expiry: DateTime?) { synchronized(this) { markAccountAsNotNew() - accountNumber = account + accountNumber = maybeAccount accountExpiry = expiry - loginStatus = LoginStatus(account, expiry, false) + + loginStatus = maybeAccount?.let { account -> + LoginStatus(account, expiry, false) + } } - daemon.await().setAccount(account) + daemon.await().setAccount(maybeAccount) } private suspend fun doLogout() { |
