Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 1ade004e authored by Treehugger Robot's avatar Treehugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Keystore 2.0: Fix diagnosing invalid key in CipherSpiBase." am: be1b1d55

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1646146

Change-Id: Id4280de7e3f6f6693e0d03c901f4e9665803b92b
parents 02ee21ec be1b1d55
Loading
Loading
Loading
Loading
+9 −6
Original line number Diff line number Diff line
@@ -123,8 +123,9 @@ abstract class AndroidKeyStoreCipherSpiBase extends CipherSpi implements KeyStor
            throws InvalidKeyException {
        resetAll();

        if (!(key instanceof AndroidKeyStorePrivateKey
                || key instanceof AndroidKeyStoreSecretKey)) {
        // Public key operations get diverted to the default provider.
        if (opmode == Cipher.ENCRYPT_MODE
                && (key instanceof PrivateKey || key instanceof PublicKey)) {
            try {
                mCipher = Cipher.getInstance(getTransform());
                String transform = getTransform();
@@ -184,8 +185,9 @@ abstract class AndroidKeyStoreCipherSpiBase extends CipherSpi implements KeyStor
            SecureRandom random) throws InvalidKeyException, InvalidAlgorithmParameterException {
        resetAll();

        if (!(key instanceof AndroidKeyStorePrivateKey
                || key instanceof AndroidKeyStoreSecretKey)) {
        // Public key operations get diverted to the default provider.
        if (opmode == Cipher.ENCRYPT_MODE
                && (key instanceof PrivateKey || key instanceof PublicKey)) {
            try {
                mCipher = Cipher.getInstance(getTransform());
                mCipher.init(opmode, key, params, random);
@@ -213,8 +215,9 @@ abstract class AndroidKeyStoreCipherSpiBase extends CipherSpi implements KeyStor
            SecureRandom random) throws InvalidKeyException, InvalidAlgorithmParameterException {
        resetAll();

        if (!(key instanceof AndroidKeyStorePrivateKey
                || key instanceof AndroidKeyStoreSecretKey)) {
        // Public key operations get diverted to the default provider.
        if (opmode == Cipher.ENCRYPT_MODE
                && (key instanceof PrivateKey || key instanceof PublicKey)) {
            try {
                mCipher = Cipher.getInstance(getTransform());
                mCipher.init(opmode, key, params, random);