Skip to content

Commit

Permalink
sign actions wait for precallback completion
Browse files Browse the repository at this point in the history
  • Loading branch information
cameronvoell committed Dec 22, 2023
1 parent c00864f commit a11f243
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import expo.modules.xmtpreactnativesdk.wrappers.DecryptedLocalAttachment
import expo.modules.xmtpreactnativesdk.wrappers.EncryptedLocalAttachment
import expo.modules.xmtpreactnativesdk.wrappers.PreparedLocalMessage
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.delay
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.Job
import kotlinx.coroutines.launch
Expand Down Expand Up @@ -78,12 +79,28 @@ class ReactNativeSigner(var module: XMTPModule, override var address: String) :

override suspend fun sign(data: ByteArray): Signature {
val request = SignatureRequest(message = String(data, Charsets.UTF_8))
when {
request.message.contains("enable") -> {
waitForCallback { module.waitForPreEnableIdentityCallback }
}
request.message.contains("create") -> {
waitForCallback { module.waitForPreCreateIdentityCallback }
}
}

module.sendEvent("sign", mapOf("id" to request.id, "message" to request.message))
return suspendCancellableCoroutine { continuation ->
continuations[request.id] = continuation
}
}

// Helper function to wait for a callback
private suspend fun waitForCallback(check: () -> Boolean) {
while (!check()) {
delay(100) // Wait for 100ms before checking again
}
}

override suspend fun sign(message: String): Signature =
sign(message.toByteArray())
}
Expand Down Expand Up @@ -126,6 +143,8 @@ class XMTPModule : Module() {
private val isDebugEnabled = BuildConfig.DEBUG // TODO: consider making this configurable
private val conversations: MutableMap<String, Conversation> = mutableMapOf()
private val subscriptions: MutableMap<String, Job> = mutableMapOf()
var waitForPreEnableIdentityCallback: Boolean = false
var waitForPreCreateIdentityCallback: Boolean = false

override fun definition() = ModuleDefinition {
Name("XMTP")
Expand All @@ -151,10 +170,14 @@ class XMTPModule : Module() {
logV("auth")
val reactSigner = ReactNativeSigner(module = this@XMTPModule, address = address)
signer = reactSigner

waitForPreEnableIdentityCallback = hasEnableIdentityCallback == true
waitForPreCreateIdentityCallback = hasCreateIdentityCallback == true
val preCreateIdentityCallback: PreEventCallback? =
preCreateIdentityCallback.takeIf { hasCreateIdentityCallback == true }
val preEnableIdentityCallback: PreEventCallback? =
preEnableIdentityCallback.takeIf { hasEnableIdentityCallback == true }

val options = ClientOptions(
api = apiEnvironments(environment, appVersion),
preCreateIdentityCallback = preCreateIdentityCallback,
Expand All @@ -175,6 +198,9 @@ class XMTPModule : Module() {
AsyncFunction("createRandom") { environment: String, appVersion: String?, hasCreateIdentityCallback: Boolean?, hasEnableIdentityCallback: Boolean? ->
logV("createRandom")
val privateKey = PrivateKeyBuilder()

waitForPreEnableIdentityCallback = hasEnableIdentityCallback == true
waitForPreCreateIdentityCallback = hasCreateIdentityCallback == true
val preCreateIdentityCallback: PreEventCallback? =
preCreateIdentityCallback.takeIf { hasCreateIdentityCallback == true }
val preEnableIdentityCallback: PreEventCallback? =
Expand Down Expand Up @@ -590,6 +616,18 @@ class XMTPModule : Module() {
val client = clients[clientAddress] ?: throw XMTPException("No client")
client.contacts.consentList.entries.map { ConsentWrapper.encode(it.value) }
}

Function("preEnableIdentityCallbackCompleted") {
logV("preEnableIdentityCallbackCompleted")
waitForPreEnableIdentityCallback = false
true
}

Function("preCreateIdentityCallbackCompleted") {
logV("preEnableIdentityCallbackCompleted")
waitForPreCreateIdentityCallback = false
true
}
}

//
Expand Down
8 changes: 8 additions & 0 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,14 @@ export async function consentList(
})
}

export function preEnableIdentityCallbackCompleted() {
XMTPModule.preEnableIdentityCallbackCompleted()
}

export function preCreateIdentityCallbackCompleted() {
XMTPModule.preCreateIdentityCallbackCompleted()
}

export const emitter = new EventEmitter(XMTPModule ?? NativeModulesProxy.XMTP)

export * from './lib/ContentCodec'
Expand Down
4 changes: 4 additions & 0 deletions src/lib/Client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -236,6 +236,8 @@ export class Client<ContentTypes> {
opts,
async () => {
await this.executeCallback(opts?.preEnableIdentityCallback)
console.log("enable: notify ready for signing!")
XMTPModule.preCreateIdentityCallbackCompleted()
}
)

Expand All @@ -244,6 +246,8 @@ export class Client<ContentTypes> {
opts,
async () => {
await this.executeCallback(opts?.preCreateIdentityCallback)
console.log("create: notify ready for signing!")
XMTPModule.preEnableIdentityCallbackCompleted()
}
)

Expand Down

0 comments on commit a11f243

Please sign in to comment.