diff options
| author | Alex Klyubin <klyubin@google.com> | 2015-04-21 15:17:24 -0700 |
|---|---|---|
| committer | Alex Klyubin <klyubin@google.com> | 2015-04-24 10:54:45 -0700 |
| commit | ad9ba10ecda10c14e46d00f40fc3e431cc2d9bc2 (patch) | |
| tree | 2c1234ccb7344f0a70d62e3e6b9066158c508e85 /keystore/java/android/security/KeyStoreKeyGeneratorSpi.java | |
| parent | 71223ebe1b2264b7463a02c8dafd779eb3b8c210 (diff) | |
| download | frameworks_base-ad9ba10ecda10c14e46d00f40fc3e431cc2d9bc2.zip frameworks_base-ad9ba10ecda10c14e46d00f40fc3e431cc2d9bc2.tar.gz frameworks_base-ad9ba10ecda10c14e46d00f40fc3e431cc2d9bc2.tar.bz2 | |
No runtime exceptions during normal use of AndroidKeyStore crypto.
This changes the implementation of AndroidKeyStore-backed Cipher and
Mac to avoid throwing runtime exceptions during normal use. Runtime
exceptions will now be thrown only due to truly exceptional and
unrecoverable errors (e.g., keystore unreachable, or crypto primitive
not initialized).
This also changes the implementation of Cipher to cache any errors
encountered in Cipher.update until Cipher.doFinal which then throws
them as checked exceptions.
Bug: 20525947
Change-Id: I3c4ad57fe70abfbb817a79402f722a0208660727
Diffstat (limited to 'keystore/java/android/security/KeyStoreKeyGeneratorSpi.java')
| -rw-r--r-- | keystore/java/android/security/KeyStoreKeyGeneratorSpi.java | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/keystore/java/android/security/KeyStoreKeyGeneratorSpi.java b/keystore/java/android/security/KeyStoreKeyGeneratorSpi.java index 87e7ee6..dde3b8f 100644 --- a/keystore/java/android/security/KeyStoreKeyGeneratorSpi.java +++ b/keystore/java/android/security/KeyStoreKeyGeneratorSpi.java @@ -200,7 +200,8 @@ public abstract class KeyStoreKeyGeneratorSpi extends KeyGeneratorSpi { int errorCode = mKeyStore.generateKey( keyAliasInKeystore, args, additionalEntropy, flags, new KeyCharacteristics()); if (errorCode != KeyStore.NO_ERROR) { - throw KeyStore.getCryptoOperationException(errorCode); + throw new IllegalStateException( + "Keystore operation failed", KeyStore.getKeyStoreException(errorCode)); } String keyAlgorithmJCA = KeymasterUtils.getJcaSecretKeyAlgorithm(mKeymasterAlgorithm, mKeymasterDigest); |
