Browse Source

Merge pull request #2303 from element-hq/misc/jme/remove-session-preferences-on-logout

Remove session preferences on logout.
pull/2343/head
Jorge Martin Espinosa 8 months ago committed by GitHub
parent
commit
eff515e544
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 1
      changelog.d/+remove-session-preferences-on-logout.misc
  2. 13
      libraries/preferences/impl/src/main/kotlin/io/element/android/libraries/preferences/impl/store/DefaultSessionPreferencesStoreFactory.kt

1
changelog.d/+remove-session-preferences-on-logout.misc

@ -0,0 +1 @@
Remove session preferences on user log out.

13
libraries/preferences/impl/src/main/kotlin/io/element/android/libraries/preferences/impl/store/DefaultSessionPreferencesStoreFactory.kt

@ -21,6 +21,8 @@ import io.element.android.libraries.di.AppScope
import io.element.android.libraries.di.ApplicationContext import io.element.android.libraries.di.ApplicationContext
import io.element.android.libraries.di.SingleIn import io.element.android.libraries.di.SingleIn
import io.element.android.libraries.matrix.api.core.SessionId import io.element.android.libraries.matrix.api.core.SessionId
import io.element.android.libraries.sessionstorage.api.observer.SessionListener
import io.element.android.libraries.sessionstorage.api.observer.SessionObserver
import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.CoroutineScope
import java.util.concurrent.ConcurrentHashMap import java.util.concurrent.ConcurrentHashMap
import javax.inject.Inject import javax.inject.Inject
@ -28,9 +30,20 @@ import javax.inject.Inject
@SingleIn(AppScope::class) @SingleIn(AppScope::class)
class DefaultSessionPreferencesStoreFactory @Inject constructor( class DefaultSessionPreferencesStoreFactory @Inject constructor(
@ApplicationContext private val context: Context, @ApplicationContext private val context: Context,
sessionObserver: SessionObserver,
) { ) {
private val cache = ConcurrentHashMap<SessionId, DefaultSessionPreferencesStore>() private val cache = ConcurrentHashMap<SessionId, DefaultSessionPreferencesStore>()
init {
sessionObserver.addListener(object : SessionListener {
override suspend fun onSessionCreated(userId: String) = Unit
override suspend fun onSessionDeleted(userId: String) {
val sessionPreferences = cache.remove(SessionId(userId))
sessionPreferences?.clear()
}
})
}
fun get(sessionId: SessionId, sessionCoroutineScope: CoroutineScope): DefaultSessionPreferencesStore = cache.getOrPut(sessionId) { fun get(sessionId: SessionId, sessionCoroutineScope: CoroutineScope): DefaultSessionPreferencesStore = cache.getOrPut(sessionId) {
DefaultSessionPreferencesStore(context, sessionId, sessionCoroutineScope) DefaultSessionPreferencesStore(context, sessionId, sessionCoroutineScope)
} }

Loading…
Cancel
Save