Skip to main content

Key Refresh

Update the client's and server's secret shares without altering the wallet's public address or key.

Step 1 : Create Session


Step 2 : Perform Key-Refresh


  • Call trioSession.keyRefresh() which returns Result of Success with Refreshed-Keyshare ByteArray or Failure with exception.

Example


Example.kt
suspend fun performKeyRefresh(keyshare: ByteArray, trioSession: TrioSession): ByteArray {
return withContext(Dispatchers.IO) {
trioSession.keyRefresh(
keyshare = keyshare
).getOrThrow()
}
}
  • keyshare is the client's "share" of the MPC wallet.
  • trioSession.keyRefresh() performs message exchange between mobile and server to "refresh" the MPC wallet. Refer to Key Refresh for more details.
  • Result of trioSession.keyRefresh() could be a Success with ByteArray (client's new share of the MPC wallet) or Failure with Exception
  • This process enhances the long-term security of the MPC wallet by proactively updating the client's and server's secret shares.
  • The wallet's public address or key remains unchanged during this process.