From fb6166ee6a894279e24901376226c5a8ae61daf2 Mon Sep 17 00:00:00 2001 From: Pat Nakajima Date: Fri, 13 Oct 2023 12:17:52 -0700 Subject: [PATCH] Derive topic identifier instead of using wallet address --- Package.resolved | 2 +- Sources/XMTP/Contacts.swift | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/Package.resolved b/Package.resolved index 875d144a..ffdbb7f1 100644 --- a/Package.resolved +++ b/Package.resolved @@ -150,7 +150,7 @@ "location" : "https://github.com/xmtp/xmtp-rust-swift", "state" : { "branch" : "main", - "revision" : "d1aaac47fc7c57645a6fe9e06972b957b3efa33c" + "revision" : "e857176b7e368c51e1dadcbbcce648bb20432f26" } } ], diff --git a/Sources/XMTP/Contacts.swift b/Sources/XMTP/Contacts.swift index 8761281f..725a0a16 100644 --- a/Sources/XMTP/Contacts.swift +++ b/Sources/XMTP/Contacts.swift @@ -34,12 +34,15 @@ class AllowList { var entries: [String: AllowState] = [:] static func load(from client: Client) async throws -> AllowList { - let envelopes = try await client.query(topic: .allowList(client.address)) + let publicKey = client.privateKeyBundleV1.identityKey.publicKey.secp256K1Uncompressed.bytes + let privateKey = client.privateKeyBundleV1.identityKey.secp256K1.bytes + + let identifier = try XMTPRust.generate_private_preferences_topic_identifier(RustVec(privateKey)).toString() + let envelopes = try await client.query(topic: .allowList(identifier)) let allowList = AllowList() for envelope in envelopes.envelopes { - let publicKey = client.privateKeyBundleV1.identityKey.publicKey.secp256K1Uncompressed.bytes - let privateKey = client.privateKeyBundleV1.identityKey.secp256K1.bytes + let payload = try XMTPRust.ecies_decrypt_k256_sha3_256( RustVec(publicKey), @@ -60,6 +63,7 @@ class AllowList { let publicKey = client.privateKeyBundleV1.identityKey.publicKey.secp256K1Uncompressed.bytes let privateKey = client.privateKeyBundleV1.identityKey.secp256K1.bytes + let identifier = try XMTPRust.generate_private_preferences_topic_identifier(RustVec(privateKey)).toString() let message = try XMTPRust.ecies_encrypt_k256_sha3_256( RustVec(publicKey), @@ -68,7 +72,7 @@ class AllowList { ) let envelope = Envelope( - topic: Topic.allowList(client.address), + topic: Topic.allowList(identifier), timestamp: Date(), message: Data(message) )