Skip to content

Generate key pair and signing (NIST P-256 (aka secp256r1) EC key pair using ECDSA) using Local Authentication for Android

Notifications You must be signed in to change notification settings

prongbang/android-biometric-signature

Repository files navigation

android-biometric-signature

Generate key pair and signing (NIST P-256 (aka secp256r1) EC key pair using ECDSA) using Local Authentication for Android.

Setup

  • build.gradle
buildscript {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}
  • settings.gradle
dependencyResolutionManagement {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}
  • app/build.gradle
implementation 'com.github.prongbang:android-biometric-signature:1.0.6'

How to use

  • Create field payloadBiometricSignature
private val payloadBiometricSignature = object : BiometricSignature() {
    override fun payload(): String = UUID.randomUUID().toString()
}
  • Create field customKeyStoreAliasKey
private val customKeyStoreAliasKey = object : KeyStoreAliasKey {
    override fun key(): String = "com.prongbang.signx.seckey"
}
  • Create field promptInfo
private val promptInfo = Biometric.PromptInfo(
    title = "BIOMETRIC",
    subtitle = "Please scan biometric to Login Application",
    description = "description here",
    negativeButton = "CANCEL"
)
  • Generate KeyPair with Biometric
private val registrationBiometricPromptManager by lazy {
    SignatureBiometricPromptManager.newInstance(
        this@MainActivity,
        keyStoreAliasKey = customKeyStoreAliasKey
    )
}
registrationBiometricPromptManager.createKeyPair(
    promptInfo,
    object : SignatureBiometricPromptManager.Result {
        override fun callback(biometric: Biometric) {
            when (biometric.status) {
                Biometric.Status.SUCCEEDED -> {
                    val publicKey = biometric.keyPair?.publicKey
                    Log.i("SUCCEEDED", "PublicKey: $publicKey")
                }
                Biometric.Status.ERROR -> {
                    Log.i("ERROR", "ERROR")
                }
                Biometric.Status.CANCEL -> {
                    Log.i("CANCEL", "CANCEL")
                }
            }
        }
    })
  • Sign with Biometric
private val signatureBiometricPromptManager by lazy {
    SignatureBiometricPromptManager.newInstance(
        this@MainActivity,
        keyStoreAliasKey = customKeyStoreAliasKey,
        biometricSignature = payloadBiometricSignature,
    )
}
signatureBiometricPromptManager.sign(
    promptInfo,
    object : SignatureBiometricPromptManager.Result {
        override fun callback(biometric: Biometric) {
            when (biometric.status) {
                Biometric.Status.SUCCEEDED -> {
                    val signature = biometric.signature
                    Log.i("SUCCEEDED", "signature: $signature")
                }
                Biometric.Status.ERROR -> {
                    Log.i("ERROR", "ERROR")
                }
                Biometric.Status.CANCEL -> {
                    Log.i("CANCEL", "CANCEL")
                }
            }
        }
    })
  • Verify with Biometric
private val verifyBiometricPromptManager by lazy {
    SignatureBiometricPromptManager.newInstance(
        this@MainActivity,
        keyStoreAliasKey = customKeyStoreAliasKey,
        biometricSignature = payloadBiometricSignature,
    )
}
verifyBiometricPromptManager.verify(
    promptInfo,
    object : SignatureBiometricPromptManager.Result {
        override fun callback(biometric: Biometric) {
            when (biometric.status) {
                Biometric.Status.SUCCEEDED -> {
                    val verify = biometric.verify
                    Log.i("SUCCEEDED", "verify: $verify")
                }
                Biometric.Status.ERROR -> {
                    Log.i("ERROR", "ERROR")
                }
                Biometric.Status.CANCEL -> {
                    Log.i("CANCEL", "CANCEL")
                }
            }
        }
    })

Documentation

About

Generate key pair and signing (NIST P-256 (aka secp256r1) EC key pair using ECDSA) using Local Authentication for Android

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages