generateDeviceKey  
  Generate a device key for provisioning a new mobile credential.
The key generated uses the NIST P-256 curve and leverages the Android Key Store for cryptographic operation execution. In all cases the generated key will be generated with the ability to produce digital signatures using the ECDSA algorithm, making it usable with the signature device authentication method as specified in ISO 18013-5. If the application consuming the SDK is running on a device using API level 31 (build code 'S') or greater, the generated key will also have the ability to perform key agreement making it usable with the ECDH agreed MAC device authentication method.
This function requires user authentication when both of the following conditions are met:     - The popOptions parameter is set.     - Biometric authentication has not occurred within the last 30 seconds,
In all other cases, no authentication is required.
Appropriate errors are thrown if a valid user authentication mechanism is not configured on the device or if authentication fails for any reason.
If the popOptions parameter is supplied a proof-of-possession (PoP) using the device private key is returned as a part of GeneratedDeviceKeyResult. The PoP itself takes the form of a JSON Web Token as per IETF RFC 7519.
Return
Information on the generated device key, represented as GeneratedDeviceKeyResult, which includes the public key and optionally a proof-of-possession (PoP) of the associated private key.
Parameters
Optional. Android activity used to perform user authentication when both UserAuthenticationBehavior.OnDeviceKeyAccess and popOptions are set.
OPTIONAL When provided, specifies how to generate a proof-of-possession (PoP) of the device private key. When not provided - no JWT is generated.
Throws
If an Activity is not supplied when required.
If the SDK API is called before the SDK is initialized.
If the user has not set up authentication.
If the user cancels the authentication process.
If biometric authentication is locked out.
For general authentication failures.
If the device key generation fails.
If user key has been compromised.