From 701a261606906e2d14ac5becda76815cefd51b5f Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Wed, 21 Feb 2024 22:45:34 -0800 Subject: [PATCH 1/2] feat: add function to delete database --- .../java/org/xmtp/android/library/Client.kt | 32 ++++++++++++------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/library/src/main/java/org/xmtp/android/library/Client.kt b/library/src/main/java/org/xmtp/android/library/Client.kt index 568e27e22..d621ec4b3 100644 --- a/library/src/main/java/org/xmtp/android/library/Client.kt +++ b/library/src/main/java/org/xmtp/android/library/Client.kt @@ -82,6 +82,7 @@ class Client() { lateinit var apiClient: ApiClient lateinit var contacts: Contacts lateinit var conversations: Conversations + var dbPath: String = "" var logger: XMTPLogger = XMTPLogger() val libXMTPVersion: String = getVersionInfo() private var libXMTPClient: FfiXmtpClient? = null @@ -160,6 +161,7 @@ class Client() { privateKeyBundleV1: PrivateKeyBundleV1, apiClient: ApiClient, libXMTPClient: FfiXmtpClient? = null, + dbPath: String = "" ) : this() { this.address = address this.privateKeyBundleV1 = privateKeyBundleV1 @@ -168,6 +170,7 @@ class Client() { this.libXMTPClient = libXMTPClient this.conversations = Conversations(client = this, libXMTPConversations = libXMTPClient?.conversations()) + this.dbPath = dbPath } fun buildFrom( @@ -179,7 +182,7 @@ class Client() { val clientOptions = options ?: ClientOptions() val apiClient = GRPCApiClient(environment = clientOptions.api.env, secure = clientOptions.api.isSecure) - val v3Client: FfiXmtpClient? = if (isAlphaMlsEnabled(options)) { + val (v3Client, dbPath) = if (isAlphaMlsEnabled(options)) { runBlocking { ffiXmtpClient( options, @@ -190,13 +193,14 @@ class Client() { address ) } - } else null + } else Pair(null, " ") return Client( address = address, privateKeyBundleV1 = bundle, apiClient = apiClient, - libXMTPClient = v3Client + libXMTPClient = v3Client, + dbPath = dbPath ) } @@ -226,7 +230,7 @@ class Client() { apiClient, options ) - val libXMTPClient: FfiXmtpClient? = + val (libXMTPClient, dbPath) = ffiXmtpClient( options, account, @@ -236,7 +240,7 @@ class Client() { account.address ) val client = - Client(account.address, privateKeyBundleV1, apiClient, libXMTPClient) + Client(account.address, privateKeyBundleV1, apiClient, libXMTPClient, dbPath) client.ensureUserContactPublished() client } catch (e: java.lang.Exception) { @@ -261,7 +265,7 @@ class Client() { val newOptions = options ?: ClientOptions() val apiClient = GRPCApiClient(environment = newOptions.api.env, secure = newOptions.api.isSecure) - val v3Client: FfiXmtpClient? = if (isAlphaMlsEnabled(options)) { + val (v3Client, dbPath) = if (isAlphaMlsEnabled(options)) { runBlocking { ffiXmtpClient( options, @@ -272,13 +276,14 @@ class Client() { address ) } - } else null + } else Pair(null, "") return Client( address = address, privateKeyBundleV1 = v1Bundle, apiClient = apiClient, - libXMTPClient = v3Client + libXMTPClient = v3Client, + dbPath = dbPath ) } @@ -293,12 +298,13 @@ class Client() { privateKeyBundleV1: PrivateKeyBundleV1, legacyIdentitySource: LegacyIdentitySource, accountAddress: String, - ): FfiXmtpClient? { + ): Pair { + var dbPath = "" val v3Client: FfiXmtpClient? = if (isAlphaMlsEnabled(options)) { val alias = "xmtp-${options!!.api.env}-${accountAddress.lowercase()}" - val dbPath = if (options.dbPath == null) { + dbPath = if (options.dbPath == null) { val dbDir = File(appContext?.filesDir?.absolutePath, "xmtp_db") dbDir.mkdir() dbDir.absolutePath + "/$alias.db3" @@ -364,7 +370,7 @@ class Client() { } } Log.i(TAG, "LibXMTP $libXMTPVersion") - return v3Client + return Pair(v3Client, dbPath) } /** @@ -586,6 +592,10 @@ class Client() { return !statuses.contains(false) } + fun deleteLocalDatabase() { + File(dbPath).delete() + } + val privateKeyBundle: PrivateKeyBundle get() = PrivateKeyBundleBuilder.buildFromV1Key(privateKeyBundleV1) From 07486c691a6f03879bda3b2830b99a856df20366 Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Fri, 23 Feb 2024 07:19:25 -0800 Subject: [PATCH 2/2] write a test for it --- .../org/xmtp/android/library/ClientTest.kt | 44 +++++++++++++++++++ .../java/org/xmtp/android/library/Client.kt | 6 +-- 2 files changed, 47 insertions(+), 3 deletions(-) diff --git a/library/src/androidTest/java/org/xmtp/android/library/ClientTest.kt b/library/src/androidTest/java/org/xmtp/android/library/ClientTest.kt index d75ef654b..98c287ed6 100644 --- a/library/src/androidTest/java/org/xmtp/android/library/ClientTest.kt +++ b/library/src/androidTest/java/org/xmtp/android/library/ClientTest.kt @@ -2,6 +2,7 @@ package org.xmtp.android.library import androidx.test.ext.junit.runners.AndroidJUnit4 import androidx.test.platform.app.InstrumentationRegistry +import kotlinx.coroutines.runBlocking import org.junit.Assert.assertEquals import org.junit.Assert.fail import org.junit.Ignore @@ -124,6 +125,49 @@ class ClientTest { assert(client.canMessageV3(listOf(client.address))) } + @Test + fun testCanDeleteDatabase() { + val context = InstrumentationRegistry.getInstrumentation().targetContext + val fakeWallet = PrivateKeyBuilder() + val fakeWallet2 = PrivateKeyBuilder() + var client = + Client().create( + account = fakeWallet, + options = ClientOptions( + ClientOptions.Api(XMTPEnvironment.LOCAL, false), + enableAlphaMls = true, + appContext = context + ) + ) + val client2 = + Client().create( + account = fakeWallet2, + options = ClientOptions( + ClientOptions.Api(XMTPEnvironment.LOCAL, false), + enableAlphaMls = true, + appContext = context + ) + ) + client.conversations.newGroup(listOf(client2.address,)) + runBlocking { client.conversations.syncGroups() } + assertEquals(client.conversations.listGroups().size, 1) + + client.deleteLocalDatabase() + + client = + Client().create( + account = fakeWallet, + options = ClientOptions( + ClientOptions.Api(XMTPEnvironment.LOCAL, false), + enableAlphaMls = true, + appContext = context + ) + ) + + runBlocking { client.conversations.syncGroups() } + assertEquals(client.conversations.listGroups().size, 0) + } + @Test fun testCreatesAV3DevClient() { val context = InstrumentationRegistry.getInstrumentation().targetContext diff --git a/library/src/main/java/org/xmtp/android/library/Client.kt b/library/src/main/java/org/xmtp/android/library/Client.kt index d621ec4b3..7b39f3a04 100644 --- a/library/src/main/java/org/xmtp/android/library/Client.kt +++ b/library/src/main/java/org/xmtp/android/library/Client.kt @@ -82,10 +82,10 @@ class Client() { lateinit var apiClient: ApiClient lateinit var contacts: Contacts lateinit var conversations: Conversations - var dbPath: String = "" var logger: XMTPLogger = XMTPLogger() val libXMTPVersion: String = getVersionInfo() private var libXMTPClient: FfiXmtpClient? = null + private var dbPath: String = "" companion object { private const val TAG = "Client" @@ -161,7 +161,7 @@ class Client() { privateKeyBundleV1: PrivateKeyBundleV1, apiClient: ApiClient, libXMTPClient: FfiXmtpClient? = null, - dbPath: String = "" + dbPath: String = "", ) : this() { this.address = address this.privateKeyBundleV1 = privateKeyBundleV1 @@ -182,7 +182,7 @@ class Client() { val clientOptions = options ?: ClientOptions() val apiClient = GRPCApiClient(environment = clientOptions.api.env, secure = clientOptions.api.isSecure) - val (v3Client, dbPath) = if (isAlphaMlsEnabled(options)) { + val (v3Client, dbPath) = if (isAlphaMlsEnabled(options)) { runBlocking { ffiXmtpClient( options,