From 577e692e32e3c26d80b17d59b923dfcc1ec1c957 Mon Sep 17 00:00:00 2001 From: Adam Brown Date: Sat, 10 Sep 2022 19:50:19 +0100 Subject: [PATCH] removing invites from the database after rejecting them and allowing them to fail with 403 (if the user no longer has access) --- .../kotlin/app/dapk/st/graph/AppModule.kt | 6 ++++- .../app/dapk/st/profile/ProfileViewModel.kt | 5 ++++- .../app/dapk/st/matrix/room/RoomService.kt | 10 ++++++++- .../room/internal/DefaultRoomService.kt | 22 ++++++++++++++++++- .../matrix/room/internal/RoomInviteRemover.kt | 7 ++++++ 5 files changed, 46 insertions(+), 4 deletions(-) create mode 100644 matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/RoomInviteRemover.kt diff --git a/app/src/main/kotlin/app/dapk/st/graph/AppModule.kt b/app/src/main/kotlin/app/dapk/st/graph/AppModule.kt index d8874d9..e56cf2e 100644 --- a/app/src/main/kotlin/app/dapk/st/graph/AppModule.kt +++ b/app/src/main/kotlin/app/dapk/st/graph/AppModule.kt @@ -303,6 +303,7 @@ internal class MatrixModules( } } + val overviewStore = store.overviewStore() installRoomService( storeModule.value.memberStore(), roomMessenger = { @@ -316,6 +317,9 @@ internal class MatrixModules( ) } } + }, + roomInviteRemover = { + overviewStore.removeInvites(listOf(it)) } ) @@ -323,7 +327,7 @@ internal class MatrixModules( installSyncService( credentialsStore, - store.overviewStore(), + overviewStore, store.roomStore(), store.syncStore(), store.filterStore(), diff --git a/features/profile/src/main/kotlin/app/dapk/st/profile/ProfileViewModel.kt b/features/profile/src/main/kotlin/app/dapk/st/profile/ProfileViewModel.kt index ff4a017..ab7fb5b 100644 --- a/features/profile/src/main/kotlin/app/dapk/st/profile/ProfileViewModel.kt +++ b/features/profile/src/main/kotlin/app/dapk/st/profile/ProfileViewModel.kt @@ -1,5 +1,6 @@ package app.dapk.st.profile +import android.util.Log import androidx.lifecycle.viewModelScope import app.dapk.st.core.Lce import app.dapk.st.core.extensions.ErrorTracker @@ -95,7 +96,9 @@ class ProfileViewModel( fun rejectRoomInvite(roomId: RoomId) { launchCatching { roomService.rejectJoinRoom(roomId) }.fold( - onError = {} + onError = { + Log.e("!!!", it.message, it) + } ) } diff --git a/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/RoomService.kt b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/RoomService.kt index 92bc1d0..1f933a9 100644 --- a/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/RoomService.kt +++ b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/RoomService.kt @@ -9,6 +9,7 @@ import app.dapk.st.matrix.common.RoomId import app.dapk.st.matrix.common.RoomMember import app.dapk.st.matrix.common.UserId import app.dapk.st.matrix.room.internal.DefaultRoomService +import app.dapk.st.matrix.room.internal.RoomInviteRemover import app.dapk.st.matrix.room.internal.RoomMembers import app.dapk.st.matrix.room.internal.RoomMembersCache @@ -40,9 +41,16 @@ interface RoomService : MatrixService { fun MatrixServiceInstaller.installRoomService( memberStore: MemberStore, roomMessenger: ServiceDepFactory, + roomInviteRemover: RoomInviteRemover, ) { this.install { (httpClient, _, services, logger) -> - SERVICE_KEY to DefaultRoomService(httpClient, logger, RoomMembers(memberStore, RoomMembersCache()), roomMessenger.create(services)) + SERVICE_KEY to DefaultRoomService( + httpClient, + logger, + RoomMembers(memberStore, RoomMembersCache()), + roomMessenger.create(services), + roomInviteRemover + ) } } diff --git a/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/DefaultRoomService.kt b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/DefaultRoomService.kt index 4ad8ef5..2448e4c 100644 --- a/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/DefaultRoomService.kt +++ b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/DefaultRoomService.kt @@ -8,6 +8,8 @@ import app.dapk.st.matrix.http.emptyJsonBody import app.dapk.st.matrix.http.jsonBody import app.dapk.st.matrix.room.RoomMessenger import app.dapk.st.matrix.room.RoomService +import io.ktor.client.plugins.* +import io.ktor.http.* import kotlinx.serialization.SerialName import kotlinx.serialization.Serializable @@ -16,7 +18,9 @@ class DefaultRoomService( private val logger: MatrixLogger, private val roomMembers: RoomMembers, private val roomMessenger: RoomMessenger, + private val roomInviteRemover: RoomInviteRemover, ) : RoomService { + override suspend fun joinedMembers(roomId: RoomId): List { val response = httpClient.execute(joinedMembersRequest(roomId)) return response.joined.map { (userId, member) -> @@ -68,7 +72,23 @@ class DefaultRoomService( } override suspend fun rejectJoinRoom(roomId: RoomId) { - httpClient.execute(rejectJoinRoomRequest(roomId)) + runCatching { httpClient.execute(rejectJoinRoomRequest(roomId)) }.fold( + onSuccess = {}, + onFailure = { + when (it) { + is ClientRequestException -> { + if (it.response.status == HttpStatusCode.Forbidden) { + // allow error + } else { + throw it + } + } + + else -> throw it + } + } + ) + roomInviteRemover.remove(roomId) } } diff --git a/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/RoomInviteRemover.kt b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/RoomInviteRemover.kt new file mode 100644 index 0000000..e5da0a9 --- /dev/null +++ b/matrix/services/room/src/main/kotlin/app/dapk/st/matrix/room/internal/RoomInviteRemover.kt @@ -0,0 +1,7 @@ +package app.dapk.st.matrix.room.internal + +import app.dapk.st.matrix.common.RoomId + +fun interface RoomInviteRemover { + suspend fun remove(roomId: RoomId) +} \ No newline at end of file