summaryrefslogtreecommitdiffhomepage
path: root/android/src
diff options
context:
space:
mode:
authorJanito Vaqueiro Ferreira Filho <janito@mullvad.net>2021-04-19 19:11:37 +0000
committerJanito Vaqueiro Ferreira Filho <janito@mullvad.net>2021-04-20 14:26:48 +0000
commitf267042992407ae14e3ad634523a4f997a61a366 (patch)
tree3a67027e4bf59bc9b2fe2f272ebb26ed3ccd9aa3 /android/src
parentaa03ed5af6abe74e2cbb3a560209f7665ed9e9db (diff)
downloadmullvadvpn-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.kt23
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() {