KeyStoreManager
  public
  
  final
  
  class
  KeyStoreManager
  
    extends Object
  
  
  
  
  
  
| java.lang.Object | |
| ↳ | android.security.keystore.KeyStoreManager | 
This class provides methods for interacting with keys stored within the Android Keystore.
Summary
| Constants | |
|---|---|
| int | MODULE_HASHWhen passed into getSupplementaryAttestationInfo, getSupplementaryAttestationInfo returns the DER-encoded structure corresponding to the `Modules` schema described in the KeyMint HAL's KeyCreationResult.aidl. | 
| Public methods | |
|---|---|
| 
        
        
        
        
        
        List<X509Certificate> | 
      getGrantedCertificateChainFromId(long id)
      Returns a  | 
| 
        
        
        
        
        
        Key | 
      getGrantedKeyFromId(long id)
      Returns the key with the specified  | 
| 
        
        
        
        
        
        KeyPair | 
      getGrantedKeyPairFromId(long id)
      Returns a  | 
| 
        
        
        
        
        
        byte[] | 
      getSupplementaryAttestationInfo(int tag)
      Returns tag-specific data required to interpret a tag's attested value. | 
| 
        
        
        
        
        
        long | 
      grantKeyAccess(String alias, int uid)
      Grants access to the key owned by the calling app stored under the specified  | 
| 
        
        
        
        
        
        void | 
      revokeKeyAccess(String alias, int uid)
      Revokes access to the key in the app's namespace stored under the specified  | 
| Inherited methods | |
|---|---|
Constants
MODULE_HASH
public static final int MODULE_HASH
When passed into getSupplementaryAttestationInfo, getSupplementaryAttestationInfo returns the DER-encoded structure corresponding to the `Modules` schema described in the KeyMint HAL's KeyCreationResult.aidl. The SHA-256 hash of this encoded structure is what's included with the tag in attestations. To ensure the returned encoded structure is the one attested to, clients should verify its SHA-256 hash matches the one in the attestation. Note that the returned structure can vary between boots.
Constant Value: -1879047468 (0x900002d4)
Public methods
getGrantedCertificateChainFromId
public List<X509Certificate> getGrantedCertificateChainFromId (long id)
Returns a List of X509Certificate instances representing the certificate
 chain for the key that was previously shared with the app under the provided id.
 
If a PrivateKey has not been granted to the caller with the
 specified id, then an UnrecoverableKeyException is thrown.
| Parameters | |
|---|---|
| id | long: the ID of the asymmetric key that was shared with the app | 
| Returns | |
|---|---|
| List<X509Certificate> | a List of X509Certificates with the certificate at index 0 corresponding to
 the private key shared with the app
 This value cannot be null. | 
| Throws | |
|---|---|
| UnrecoverableKeyException | if the specified key cannot be recovered | 
| KeyPermanentlyInvalidatedException | if the specified key was authorized to only be used if the user has been authenticated and a change has been made to the users lockscreen or biometric enrollment that permanently invalidates the key | 
See also:
getGrantedKeyFromId
public Key getGrantedKeyFromId (long id)
Returns the key with the specified id that was previously shared with the
 app.
 
This method can return instances of both SecretKey and PrivateKey. If a key with the provide id has not been granted to the
 caller, then an UnrecoverableKeyException is thrown.
| Parameters | |
|---|---|
| id | long: the ID of the key that was shared with the app | 
| Returns | |
|---|---|
| Key | the Keythat was shared with the app
 This value cannot benull. | 
| Throws | |
|---|---|
| UnrecoverableKeyException | if the specified key cannot be recovered | 
| KeyPermanentlyInvalidatedException | if the specified key was authorized to only be used if the user has been authenticated and a change has been made to the users lockscreen or biometric enrollment that permanently invalidates the key | 
See also:
getGrantedKeyPairFromId
public KeyPair getGrantedKeyPairFromId (long id)
Returns a KeyPair containing the public and private key associated with
 the key that was previously shared with the app under the provided id.
 
If a PrivateKey has not been granted to the caller with the
 specified id, then an UnrecoverableKeyException is thrown.
| Parameters | |
|---|---|
| id | long: the ID of the private key that was shared with the app | 
| Returns | |
|---|---|
| KeyPair | a KeyPair containing the public and private key shared with the app
 This value cannot be null. | 
| Throws | |
|---|---|
| UnrecoverableKeyException | if the specified key cannot be recovered | 
| KeyPermanentlyInvalidatedException | if the specified key was authorized to only be used if the user has been authenticated and a change has been made to the users lockscreen or biometric enrollment that permanently invalidates the key | 
getSupplementaryAttestationInfo
public byte[] getSupplementaryAttestationInfo (int tag)
Returns tag-specific data required to interpret a tag's attested value. When performing key attestation, the obtained attestation certificate contains a list of tags and their corresponding attested values. For some tags, additional information about the attested value can be queried via this API. See individual tags for specifics.
| Parameters | |
|---|---|
| tag | int: tag for which info is being requested
 Value isMODULE_HASH | 
| Returns | |
|---|---|
| byte[] | tag-specific info
 This value cannot be null. | 
| Throws | |
|---|---|
| KeyStoreException | if the requested info is not available | 
grantKeyAccess
public long grantKeyAccess (String alias, int uid)
Grants access to the key owned by the calling app stored under the specified alias
 to another app on the device with the provided uid.
 
This method supports granting access to instances of both SecretKey
 and PrivateKey. The resulting ID will persist across reboots and can be
 used by the grantee app for the life of the key or until access is revoked with revokeKeyAccess(java.lang.String, int).
 
If the provided alias does not correspond to a key in the Android KeyStore, then
 an UnrecoverableKeyException is thrown.
| Parameters | |
|---|---|
| alias | String: the alias of the key to be granted to another app
 This value cannot benull. | 
| uid | int: the uid of the app to which the key should be granted | 
| Returns | |
|---|---|
| long | the ID of the granted key; this can be shared with the specified app, and that
 app can use getGrantedKeyFromId(long)to access the key | 
| Throws | |
|---|---|
| UnrecoverableKeyException | if the specified key cannot be recovered | 
| KeyStoreException | if an error is encountered when attempting to grant access to the key | 
See also:
revokeKeyAccess
public void revokeKeyAccess (String alias, int uid)
Revokes access to the key in the app's namespace stored under the specified alias that was previously granted to another app on the device with the provided
 uid.
 
If the provided alias does not correspond to a key in the Android KeyStore, then
 an UnrecoverableKeyException is thrown.
| Parameters | |
|---|---|
| alias | String: the alias of the key to be revoked from another app
 This value cannot benull. | 
| uid | int: the uid of the app from which the key access should be revoked | 
| Throws | |
|---|---|
| UnrecoverableKeyException | if the specified key cannot be recovered | 
| KeyStoreException | if an error is encountered when attempting to revoke access to the key | 
