From 47bcb318f5368a9d155d63c55714c942ecee0d25 Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Mon, 19 Feb 2024 13:57:11 -0800 Subject: [PATCH 1/2] add the ability to pass in a DB url --- Sources/XMTPiOS/Client.swift | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Sources/XMTPiOS/Client.swift b/Sources/XMTPiOS/Client.swift index 3a949a7b..12589750 100644 --- a/Sources/XMTPiOS/Client.swift +++ b/Sources/XMTPiOS/Client.swift @@ -53,6 +53,7 @@ public struct ClientOptions { public var mlsAlpha = false public var mlsEncryptionKey: Data? + public var mlsDbPath: String? public init( api: Api = Api(), @@ -128,12 +129,12 @@ public final class Client { signingKey: SigningKey? ) async throws -> FfiXmtpClient? { if options?.mlsAlpha == true, options?.api.env.supportsMLS == true { - let dbURL = URL.documentsDirectory.appendingPathComponent("xmtp-\(options?.api.env.rawValue ?? "")-\(address).db3") + let dbURL = options?.mlsDbPath ?? URL.documentsDirectory.appendingPathComponent("xmtp-\(options?.api.env.rawValue ?? "")-\(address).db3").path let v3Client = try await LibXMTP.createClient( logger: XMTPLogger(), host: (options?.api.env ?? .local).url, isSecure: options?.api.env.isSecure == true, - db: dbURL.path, + db: dbURL, encryptionKey: options?.mlsEncryptionKey, accountAddress: address, legacyIdentitySource: source, From 777cf8c8c297533e990d85d34354c05529ad2d77 Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Mon, 19 Feb 2024 14:10:20 -0800 Subject: [PATCH 2/2] set a default encryption key if one is not passed --- Sources/XMTPiOS/Client.swift | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/Sources/XMTPiOS/Client.swift b/Sources/XMTPiOS/Client.swift index 12589750..e4e42fa1 100644 --- a/Sources/XMTPiOS/Client.swift +++ b/Sources/XMTPiOS/Client.swift @@ -130,12 +130,27 @@ public final class Client { ) async throws -> FfiXmtpClient? { if options?.mlsAlpha == true, options?.api.env.supportsMLS == true { let dbURL = options?.mlsDbPath ?? URL.documentsDirectory.appendingPathComponent("xmtp-\(options?.api.env.rawValue ?? "")-\(address).db3").path + + var encryptionKey = options?.mlsEncryptionKey + if (encryptionKey == nil) { + let preferences = UserDefaults.standard + let key = "xmtp-key" + if preferences.data(forKey: key) == nil { + let data = Data(try Crypto.secureRandomBytes(count: 32)) + preferences.set(data, forKey: key) + preferences.synchronize() + encryptionKey = data + } else { + encryptionKey = preferences.data(forKey: key) + } + } + let v3Client = try await LibXMTP.createClient( logger: XMTPLogger(), host: (options?.api.env ?? .local).url, isSecure: options?.api.env.isSecure == true, db: dbURL, - encryptionKey: options?.mlsEncryptionKey, + encryptionKey: encryptionKey, accountAddress: address, legacyIdentitySource: source, legacySignedPrivateKeyProto: try privateKeyBundleV1.toV2().identityKey.serializedData()