mirror of
https://github.com/SchildiChat/SchildiChat-android.git
synced 2024-12-27 10:03:06 +01:00
Delete ThreadToReplyMapInterceptor
Add documentation comments
This commit is contained in:
parent
45a63b73bd
commit
8ee3f2c6cb
@ -1,105 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2021 The Matrix.org Foundation C.I.C.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package org.matrix.android.sdk.internal.network
|
||||
|
||||
import okhttp3.Interceptor
|
||||
import okhttp3.Request
|
||||
import okhttp3.Response
|
||||
import okhttp3.ResponseBody
|
||||
import okhttp3.ResponseBody.Companion.toResponseBody
|
||||
import org.matrix.android.sdk.api.extensions.tryOrNull
|
||||
import org.matrix.android.sdk.api.network.ApiInterceptorListener
|
||||
import org.matrix.android.sdk.api.network.ApiPath
|
||||
import org.matrix.android.sdk.internal.di.MatrixScope
|
||||
import timber.log.Timber
|
||||
import javax.inject.Inject
|
||||
|
||||
/**
|
||||
* The goal of this interceptor is to map thread events to be handled as replies.
|
||||
* The interceptor is responsible for mapping a thread event:
|
||||
* "m.relates_to":{
|
||||
* "event_id":"$eventId",
|
||||
* "rel_type":"io.element.thread"
|
||||
* }
|
||||
* to an equivalent reply event:
|
||||
* m.relates_to":{
|
||||
* "m.in_reply_to":{
|
||||
* "event_id":"$eventId"
|
||||
* }
|
||||
*/
|
||||
@MatrixScope
|
||||
internal class ThreadToReplyMapInterceptor @Inject constructor() : Interceptor {
|
||||
|
||||
init {
|
||||
Timber.d("MapThreadToReplyInterceptor.init")
|
||||
}
|
||||
|
||||
override fun intercept(chain: Interceptor.Chain): Response {
|
||||
val request = chain.request()
|
||||
|
||||
val response = chain.proceed(request)
|
||||
|
||||
if (isSyncRequest(request)) {
|
||||
Timber.i(" ------> found SYNC REQUEST")
|
||||
|
||||
return response.body?.let {
|
||||
val contentType = it.contentType()
|
||||
val rawBody = it.string()
|
||||
Timber.i(" ------> $rawBody")
|
||||
|
||||
if(rawBody.contains("\"rel_type\":\"io.element.thread\"")){
|
||||
Timber.i(" ------> Thread found")
|
||||
val start = rawBody.indexOf("\"rel_type\":\"io.element.thread\"") - "\"m.relates_to\":{\"event_id\":\"-GoMTnxkfmZczOPvbjcK43WqNib3wiJVaeO_vRxwHIDA\",\"".length +1
|
||||
val end = rawBody.indexOf("\"rel_type\":\"io.element.thread\"") + "\"rel_type\":\"io.element.thread\"".length +2
|
||||
val substr = rawBody.subSequence(start,end)
|
||||
val newRaw = rawBody.replaceRange(start,end,"\"m.relates_to\":{\"m.in_reply_to\":{\"event_id\":\"\$HDddlX2bJQmVS0bN5R9HDzcrGDap18b3cFDDYjTjctc\"}},")
|
||||
Timber.i(" ------> ${substr}")
|
||||
Timber.i(" ------> new raw $newRaw")
|
||||
val newBody = newRaw.toResponseBody(contentType)
|
||||
response.newBuilder().body(newBody).build()
|
||||
|
||||
}else{
|
||||
val newBody = rawBody.toResponseBody(contentType)
|
||||
response.newBuilder().body(newBody).build()
|
||||
}
|
||||
} ?: response
|
||||
|
||||
// response.peekBody(Long.MAX_VALUE).string().let { networkResponse ->
|
||||
// Timber.i(" ------> ThreadToReplyMapInterceptor $networkResponse")
|
||||
// }
|
||||
}
|
||||
|
||||
// val path = request.url.encodedPath
|
||||
// if(path.contains("/sync/")){
|
||||
// Timber.i("-----> SYNC REQUEST --> $responseBody")
|
||||
//
|
||||
//
|
||||
// }
|
||||
|
||||
// val body = ResponseBody.create()
|
||||
// val newResponse = response.newBuilder().body(body)
|
||||
return response
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns true if the request is a sync request, false otherwise
|
||||
* Example of a sync request:
|
||||
* https://matrix-client.matrix.org/_matrix/client/r0/sync?filter=0&set_presence=online&t...
|
||||
*/
|
||||
private fun isSyncRequest(request: Request): Boolean =
|
||||
ApiPath.SYNC.method == request.method && request.url.encodedPath.contains(ApiPath.SYNC.path)
|
||||
}
|
@ -138,6 +138,9 @@ internal class ThreadsAwarenessHandler @Inject constructor(
|
||||
})
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle events mainly coming from the RoomSyncHandler
|
||||
*/
|
||||
fun handleIfNeeded(realm: Realm,
|
||||
roomId: String,
|
||||
event: Event) {
|
||||
@ -150,6 +153,9 @@ internal class ThreadsAwarenessHandler @Inject constructor(
|
||||
event.mxDecryptionResult = event.mxDecryptionResult?.copy(payload = payload)
|
||||
}
|
||||
|
||||
/**
|
||||
* Handle events while they are being decrypted
|
||||
*/
|
||||
fun handleIfNeededDuringDecryption(realm: Realm,
|
||||
roomId: String?,
|
||||
event: Event,
|
||||
@ -236,9 +242,17 @@ internal class ThreadsAwarenessHandler @Inject constructor(
|
||||
return EventMapper.map(eventEntity)
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns True if the event is a thread
|
||||
* @param event
|
||||
*/
|
||||
private fun isThreadEvent(event: Event): Boolean =
|
||||
event.content.toModel<MessageRelationContent>()?.relatesTo?.type == "io.element.thread"
|
||||
|
||||
/**
|
||||
* Returns the root thread eventId or null otherwise
|
||||
* @param event
|
||||
*/
|
||||
private fun getRootThreadEventId(event: Event): String? =
|
||||
event.content.toModel<MessageRelationContent>()?.relatesTo?.eventId
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user