Skip to content

Commit

Permalink
Merge pull request #444 from xmtp/np/fix-more-async-issues
Browse files Browse the repository at this point in the history
fix: remove all RunBlockings from the code
  • Loading branch information
nplasterer authored Jul 24, 2024
2 parents 52b1540 + 20950f3 commit e436b7c
Showing 1 changed file with 19 additions and 20 deletions.
39 changes: 19 additions & 20 deletions android/src/main/java/expo/modules/xmtpreactnativesdk/XMTPModule.kt
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.Job
import kotlinx.coroutines.launch
import kotlinx.coroutines.runBlocking
import kotlinx.coroutines.suspendCancellableCoroutine
import kotlinx.coroutines.withContext
import org.json.JSONObject
Expand Down Expand Up @@ -349,29 +348,29 @@ class XMTPModule : Module() {
}
}

AsyncFunction("sign") { inboxId: String, digest: List<Int>, keyType: String, preKeyIndex: Int ->
logV("sign")
val client = clients[inboxId] ?: throw XMTPException("No client")
val digestBytes =
digest.foldIndexed(ByteArray(digest.size)) { i, a, v ->
a.apply {
set(
i,
v.toByte()
)
AsyncFunction("sign") Coroutine { inboxId: String, digest: List<Int>, keyType: String, preKeyIndex: Int ->
withContext(Dispatchers.IO) {
logV("sign")
val client = clients[inboxId] ?: throw XMTPException("No client")
val digestBytes =
digest.foldIndexed(ByteArray(digest.size)) { i, a, v ->
a.apply {
set(
i,
v.toByte()
)
}
}
val privateKeyBundle = client.keys
val signedPrivateKey = if (keyType == "prekey") {
privateKeyBundle.preKeysList[preKeyIndex]
} else {
privateKeyBundle.identityKey
}
val privateKeyBundle = client.keys
val signedPrivateKey = if (keyType == "prekey") {
privateKeyBundle.preKeysList[preKeyIndex]
} else {
privateKeyBundle.identityKey
}
val signature = runBlocking {
val privateKey = PrivateKeyBuilder.buildFromSignedPrivateKey(signedPrivateKey)
PrivateKeyBuilder(privateKey).sign(digestBytes)
val signature = PrivateKeyBuilder(privateKey).sign(digestBytes)
signature.toByteArray().map { it.toInt() and 0xFF }
}
signature.toByteArray().map { it.toInt() and 0xFF }
}

AsyncFunction("exportPublicKeyBundle") { inboxId: String ->
Expand Down

0 comments on commit e436b7c

Please sign in to comment.