Skip to content

Commit

Permalink
Revert "Dual Send 1to1 Conversations in V3 (#306)"
Browse files Browse the repository at this point in the history
This reverts commit bded2b7.
  • Loading branch information
nplasterer committed Nov 14, 2024
1 parent 3b17b28 commit 01898a7
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 72 deletions.
40 changes: 0 additions & 40 deletions library/src/androidTest/java/org/xmtp/android/library/GroupTest.kt
Original file line number Diff line number Diff line change
Expand Up @@ -75,46 +75,6 @@ class GroupTest {
runBlocking { Client().createV3(account = davonV3Wallet, options = options) }
}

@Test
fun testsCanDualSendConversations() {
val v2Convo = runBlocking { alixClient.conversations.newConversation(bo.walletAddress) }
runBlocking {
alixClient.conversations.syncConversations()
boClient.conversations.syncConversations()
}
val alixDm = runBlocking { alixClient.findDm(bo.walletAddress) }
val boDm = runBlocking { boClient.findDm(alix.walletAddress) }

assertEquals(alixDm?.id, boDm?.id)
assertEquals(runBlocking { alixClient.conversations.list().size }, 1)
assertEquals(runBlocking { alixClient.conversations.listDms().size }, 1)
assertEquals(runBlocking { boClient.conversations.listDms().size }, 1)
assertEquals(runBlocking { boClient.conversations.list().size }, 1)
assertEquals(v2Convo.topic, runBlocking { boClient.conversations.list().first().topic })
}

@Test
fun testsCanDualSendMessages() {
val alixV2Convo = runBlocking { alixClient.conversations.newConversation(bo.walletAddress) }
val boV2Convo = runBlocking { boClient.conversations.list().first() }
runBlocking { boClient.conversations.syncConversations() }
val alixDm = runBlocking { alixClient.findDm(bo.walletAddress) }
val boDm = runBlocking { boClient.findDm(alix.walletAddress) }

runBlocking { alixV2Convo.send("first") }
runBlocking { boV2Convo.send("second") }

runBlocking {
alixDm?.sync()
boDm?.sync()
}

assertEquals(runBlocking { alixV2Convo.messages().size }, 2)
assertEquals(runBlocking { alixV2Convo.messages().size }, runBlocking { boV2Convo.messages().size })
assertEquals(boDm?.messages()?.size, 2)
assertEquals(alixDm?.messages()?.size, 3) // We send the group membership update to the dm
}

@Test
fun testCanCreateAGroupWithDefaultPermissions() {
val boGroup = runBlocking {
Expand Down
12 changes: 1 addition & 11 deletions library/src/main/java/org/xmtp/android/library/ConversationV1.kt
Original file line number Diff line number Diff line change
Expand Up @@ -195,16 +195,6 @@ data class ConversationV1(
}

suspend fun send(prepared: PreparedMessage): String {
if (client.v3Client != null) {
try {
val dm = client.conversations.findOrCreateDm(peerAddress)
prepared.encodedContent?.let {
dm.send(it)
}
} catch (e: Exception) {
Log.e("ConversationV1 send", e.message.toString())
}
}
client.publish(envelopes = prepared.envelopes)
if (client.contacts.consentList.state(address = peerAddress) == ConsentState.UNKNOWN) {
client.contacts.allow(addresses = listOf(peerAddress))
Expand Down Expand Up @@ -279,7 +269,7 @@ data class ConversationV1(
)
client.contacts.hasIntroduced[peerAddress] = true
}
return PreparedMessage(envelopes, encodedContent)
return PreparedMessage(envelopes)
}

private fun generateId(envelope: Envelope): String =
Expand Down
12 changes: 1 addition & 11 deletions library/src/main/java/org/xmtp/android/library/ConversationV2.kt
Original file line number Diff line number Diff line change
Expand Up @@ -200,16 +200,6 @@ data class ConversationV2(
}

suspend fun send(prepared: PreparedMessage): String {
if (client.v3Client != null) {
try {
val dm = client.conversations.findOrCreateDm(peerAddress)
prepared.encodedContent?.let {
dm.send(it)
}
} catch (e: Exception) {
Log.e("ConversationV1 send", e.message.toString())
}
}
client.publish(envelopes = prepared.envelopes)
if (client.contacts.consentList.state(address = peerAddress) == ConsentState.UNKNOWN) {
client.contacts.allow(addresses = listOf(peerAddress))
Expand Down Expand Up @@ -280,7 +270,7 @@ data class ConversationV2(
timestamp = Date(),
message = MessageBuilder.buildFromMessageV2(v2 = message.messageV2).toByteArray(),
)
return PreparedMessage(listOf(envelope), encodedContent)
return PreparedMessage(listOf(envelope))
}

private fun generateId(envelope: Envelope): String =
Expand Down
15 changes: 8 additions & 7 deletions library/src/main/java/org/xmtp/android/library/Conversations.kt
Original file line number Diff line number Diff line change
Expand Up @@ -193,6 +193,7 @@ data class Conversations(
}

suspend fun findOrCreateDm(peerAddress: String): Dm {
if (client.hasV2Client) throw XMTPException("Only supported for V3 only clients.")
if (peerAddress.lowercase() == client.address.lowercase()) {
throw XMTPException("Recipient is sender")
}
Expand Down Expand Up @@ -299,13 +300,6 @@ data class Conversations(
client.contacts.allow(addresses = listOf(peerAddress))
val conversation = Conversation.V2(conversationV2)
conversationsByTopic[conversation.topic] = conversation
if (client.v3Client != null) {
try {
client.conversations.findOrCreateDm(peerAddress)
} catch (e: Exception) {
Log.e("newConversation", e.message.toString())
}
}
return conversation
}

Expand All @@ -332,6 +326,7 @@ data class Conversations(
before: Date? = null,
limit: Int? = null,
): List<Dm> {
if (client.hasV2Client) throw XMTPException("Only supported for V3 only clients.")
val ffiDms = libXMTPConversations?.listDms(
opts = FfiListConversationsOptions(
after?.time?.nanoseconds?.toLong(DurationUnit.NANOSECONDS),
Expand All @@ -352,6 +347,9 @@ data class Conversations(
order: ConversationOrder = ConversationOrder.CREATED_AT,
consentState: ConsentState? = null,
): List<Conversation> {
if (client.hasV2Client)
throw XMTPException("Only supported for V3 only clients.")

val ffiConversations = libXMTPConversations?.list(
FfiListConversationsOptions(
after?.time?.nanoseconds?.toLong(DurationUnit.NANOSECONDS),
Expand Down Expand Up @@ -555,6 +553,7 @@ data class Conversations(
}

fun streamConversations(): Flow<Conversation> = callbackFlow {
if (client.hasV2Client) throw XMTPException("Only supported for V3 only clients.")
val conversationCallback = object : FfiConversationCallback {
override fun onConversation(conversation: FfiConversation) {
if (conversation.groupMetadata().conversationType() == "dm") {
Expand Down Expand Up @@ -657,6 +656,7 @@ data class Conversations(
}

fun streamAllConversationMessages(): Flow<DecodedMessage> = callbackFlow {
if (client.hasV2Client) throw XMTPException("Only supported for V3 only clients.")
val messageCallback = object : FfiMessageCallback {
override fun onMessage(message: FfiMessage) {
val conversation = client.findConversation(message.convoId.toHex())
Expand Down Expand Up @@ -684,6 +684,7 @@ data class Conversations(
}

fun streamAllConversationDecryptedMessages(): Flow<DecryptedMessage> = callbackFlow {
if (client.hasV2Client) throw XMTPException("Only supported for V3 only clients.")
val messageCallback = object : FfiMessageCallback {
override fun onMessage(message: FfiMessage) {
val conversation = client.findConversation(message.convoId.toHex())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package org.xmtp.android.library
import org.web3j.crypto.Hash
import org.xmtp.android.library.messages.Envelope
import org.xmtp.proto.message.api.v1.MessageApiOuterClass.PublishRequest
import org.xmtp.proto.message.contents.Content.EncodedContent

// This houses a fully prepared message that can be published
// as soon as the API client has connectivity.
Expand All @@ -15,8 +14,7 @@ data class PreparedMessage(
// The first envelope should send the message to the conversation itself.
// Any more are for required intros/invites etc.
// A client can just publish these when it has connectivity.
val envelopes: List<Envelope>,
val encodedContent: EncodedContent? = null
val envelopes: List<Envelope>
) {
companion object {
fun fromSerializedData(data: ByteArray): PreparedMessage {
Expand Down

0 comments on commit 01898a7

Please sign in to comment.