106 lines
5.2 KiB
Kotlin
Raw Normal View History

2020-05-11 16:19:26 +10:00
package org.thoughtcrime.securesms.loki.protocol
import android.content.Context
import android.util.Log
import nl.komponents.kovenant.Promise
import nl.komponents.kovenant.functional.map
2020-05-13 10:24:20 +10:00
import org.thoughtcrime.securesms.ApplicationContext
2020-05-12 16:28:35 +10:00
import org.thoughtcrime.securesms.crypto.storage.TextSecureSessionStore
2020-05-11 16:19:26 +10:00
import org.thoughtcrime.securesms.database.Address
import org.thoughtcrime.securesms.database.DatabaseFactory
2020-05-13 12:29:31 +10:00
import org.thoughtcrime.securesms.loki.utilities.recipient
import org.thoughtcrime.securesms.loki.utilities.timeout
2020-05-11 16:19:26 +10:00
import org.thoughtcrime.securesms.recipients.Recipient
import org.thoughtcrime.securesms.sms.MessageSender
import org.thoughtcrime.securesms.util.GroupUtil
import org.thoughtcrime.securesms.util.TextSecurePreferences
2020-05-12 16:28:35 +10:00
import org.whispersystems.libsignal.SignalProtocolAddress
2020-05-13 12:29:31 +10:00
import org.whispersystems.signalservice.api.messages.SignalServiceContent
2020-05-12 16:28:35 +10:00
import org.whispersystems.signalservice.api.messages.SignalServiceGroup
import org.whispersystems.signalservice.api.push.SignalServiceAddress
2020-07-08 17:05:26 +10:00
import org.whispersystems.signalservice.loki.api.SnodeAPI
2020-07-15 12:24:43 +10:00
import org.whispersystems.signalservice.loki.api.fileserver.FileServerAPI
2020-08-04 15:33:37 +10:00
import org.whispersystems.signalservice.loki.protocol.shelved.multidevice.MultiDeviceProtocol
2020-05-22 10:41:31 +10:00
import java.util.*
2020-05-11 16:19:26 +10:00
object ClosedGroupsProtocol {
2020-05-12 16:28:35 +10:00
@JvmStatic
fun shouldIgnoreContentMessage(context: Context, address: Address, groupID: String?, senderPublicKey: String): Boolean {
if (!address.isClosedGroup || groupID == null) { return false }
/*
2020-07-15 12:24:43 +10:00
FileServerAPI.shared.getDeviceLinks(senderPublicKey).timeout(6000).get()
2020-05-13 12:29:31 +10:00
val senderMasterPublicKey = MultiDeviceProtocol.shared.getMasterDevice(senderPublicKey)
val publicKeyToCheckFor = senderMasterPublicKey ?: senderPublicKey
*/
2020-05-13 12:29:31 +10:00
val members = DatabaseFactory.getGroupDatabase(context).getGroupMembers(groupID, true)
return !members.contains(recipient(context, senderPublicKey))
2020-05-13 12:29:31 +10:00
}
@JvmStatic
fun getMessageDestinations(context: Context, groupID: String): List<Address> {
if (GroupUtil.isRSSFeed(groupID)) { return listOf() }
2020-05-12 15:29:00 +10:00
if (GroupUtil.isOpenGroup(groupID)) {
return listOf( Address.fromSerialized(groupID) )
2020-05-12 15:29:00 +10:00
} else {
// TODO: Shared sender keys
return DatabaseFactory.getGroupDatabase(context).getGroupMembers(groupID, false).map { it.address }
/*
2020-07-15 12:24:43 +10:00
return FileServerAPI.shared.getDeviceLinks(members.map { it.address.serialize() }.toSet()).map {
val result = members.flatMap { member ->
MultiDeviceProtocol.shared.getAllLinkedDevices(member.address.serialize()).map { Address.fromSerialized(it) }
}.toMutableSet()
val userMasterPublicKey = TextSecurePreferences.getMasterHexEncodedPublicKey(context)
if (userMasterPublicKey != null && result.contains(Address.fromSerialized(userMasterPublicKey))) {
result.remove(Address.fromSerialized(userMasterPublicKey))
}
val userPublicKey = TextSecurePreferences.getLocalNumber(context)
if (userPublicKey != null && result.contains(Address.fromSerialized(userPublicKey))) {
result.remove(Address.fromSerialized(userPublicKey))
}
result.toList()
2020-05-12 15:29:00 +10:00
}
*/
2020-05-12 15:29:00 +10:00
}
}
@JvmStatic
fun leaveLegacyGroup(context: Context, recipient: Recipient): Boolean {
2020-05-11 16:54:31 +10:00
if (!recipient.address.isClosedGroup) { return true }
2020-05-11 16:19:26 +10:00
val threadID = DatabaseFactory.getThreadDatabase(context).getThreadIdFor(recipient)
val message = GroupUtil.createGroupLeaveMessage(context, recipient).orNull()
if (threadID < 0 || message == null) { return false }
MessageSender.send(context, message, threadID, false, null)
/*
2020-05-11 16:54:31 +10:00
val masterPublicKey = TextSecurePreferences.getMasterHexEncodedPublicKey(context)
2020-05-13 12:29:31 +10:00
val publicKeyToRemove = masterPublicKey ?: TextSecurePreferences.getLocalNumber(context)
*/
val userPublicKey = TextSecurePreferences.getLocalNumber(context)
2020-05-11 16:19:26 +10:00
val groupDatabase = DatabaseFactory.getGroupDatabase(context)
val groupID = recipient.address.toGroupString()
groupDatabase.setActive(groupID, false)
groupDatabase.remove(groupID, Address.fromSerialized(userPublicKey))
2020-05-11 16:19:26 +10:00
return true
}
2020-05-12 16:28:35 +10:00
@JvmStatic
fun establishSessionsWithMembersIfNeeded(context: Context, members: List<String>) {
@Suppress("NAME_SHADOWING") val members = members.toMutableSet()
/*
2020-05-12 16:28:35 +10:00
val allDevices = members.flatMap { member ->
MultiDeviceProtocol.shared.getAllLinkedDevices(member)
}.toMutableSet()
2020-05-13 12:29:31 +10:00
val userMasterPublicKey = TextSecurePreferences.getMasterHexEncodedPublicKey(context)
if (userMasterPublicKey != null && allDevices.contains(userMasterPublicKey)) {
allDevices.remove(userMasterPublicKey)
2020-05-12 16:28:35 +10:00
}
*/
2020-05-12 16:28:35 +10:00
val userPublicKey = TextSecurePreferences.getLocalNumber(context)
if (userPublicKey != null && members.contains(userPublicKey)) {
members.remove(userPublicKey)
2020-05-12 16:28:35 +10:00
}
for (member in members) {
ApplicationContext.getInstance(context).sendSessionRequestIfNeeded(member)
2020-05-12 16:28:35 +10:00
}
}
2020-05-11 16:19:26 +10:00
}