Makes MatrixClient Closeable outside of logout function.

This commit is contained in:
ganfra 2023-03-30 20:52:32 +02:00
parent af4d845e6a
commit af12d8b89e
3 changed files with 7 additions and 4 deletions

View file

@ -170,7 +170,7 @@ class RustMatrixClient constructor(
}
}
private fun close() {
override fun close() {
slidingSyncUpdateJob?.cancel()
stopSync()
slidingSync.setObserver(null)
@ -179,10 +179,10 @@ class RustMatrixClient constructor(
visibleRoomsSlidingSyncList.destroy()
slidingSync.destroy()
verificationService.destroy()
client.destroy()
}
override suspend fun logout() = withContext(dispatchers.io) {
close()
try {
client.logout()
} catch (failure: Throwable) {
@ -190,7 +190,7 @@ class RustMatrixClient constructor(
}
baseDirectory.deleteSessionDirectory(userID = client.userId())
sessionStore.removeSession(client.userId())
client.destroy()
close()
}
override suspend fun loadUserDisplayName(): Result<String> = withContext(dispatchers.io) {