Skip to content
This repository has been archived by the owner on Apr 17, 2024. It is now read-only.

ANR reports on different devices when using AndroidX Crypto, pointing to com.google.crypto.tink #638

Closed
tryadelion opened this issue Sep 30, 2022 · 13 comments
Assignees
Labels

Comments

@tryadelion
Copy link

Help us help you

We are a software company using the androidx crypto library that implements Tink

Describe the bug:

We have detected a growing number of ANR (Application Not Responding) reports focalized on the Tink layer of the crypto library.

What was the expected behavior?

no ANR happening

How can we reproduce the bug?

we have a background service scheduled every one to five minutes that performs a read on the preferences, compares to a calculated value, and stores it, a few ms of execution time. the preferences are protected by encryption using the crypto library capabilities, so values read are decrypted and values stored are encrypted.

Do you have any debugging information?

ANR with 40 events with 26 users.

org.bouncycastle.crypto.digests.SHA1Digest.processBlockExecuting service OUR_SERVICE_ID

ANR with 22 events with 21 users
com.google.crypto.tink.integration.android.AndroidKeystoreAesGcm.decryptInternalExecuting service OUR_SERVICE_ID

ANR with 22 events with 19 users
com.google.crypto.tink.integration.android.AndroidKeystoreAesGcm.encryptInternalExecuting service OUR_SERVICE_ID

Provide your version information:

kotlin, Tink version unknown, AndroidX Crypto library version: 1.1.0-alpha03

@juergw
Copy link
Contributor

juergw commented Jan 12, 2023

AndroidKeystoreAesGcm is the class that calls to AndroidKeystore service to encrypt or decrypt the keys that are then used to encrypt or decrypt the shared preferences. Unfortunately, AndroidKeystore may fail in some situations, for example, if there are too many requests at the same time. Because of this, AndroidKeystoreAesGcm retries the call if it fails. See a056e3d.

Does your background service create lots of EncryptedSharedPreferences objects at the same time? Are you using StrongBox?

@tryadelion
Copy link
Author

Greetings - it's certainly possible a few dozen calls can happen in a relatively short period of time, we update a few fields based on server query results asynchronously which means they can happen at a time, but it shouldn't be more than that. is there an optimal solution?
We are not aware of StrongBox.

@juergw juergw self-assigned this Jan 16, 2023
@juergw
Copy link
Contributor

juergw commented Jan 16, 2023

What you could try is to minimize the creation of new EncryptedSharedPreference objects. For example, create the ones you need at startup, and keep reusing them. And do the same for the MasterKey object: only create one of them at startup. And, if these objects may be created in different threads, make sure you have a global lock around them, so that only one thread at a time is creating these objects.

One thing I will do is to improve the retry in AndroidKeystoreAesGcm: it should only retry temporary errors. If decryption failed because of a bad ciphertext, it should not retry.

@juergw
Copy link
Contributor

juergw commented Jan 30, 2023

I have now fixed the retry in AndroidKeystoreAesGcm, see 0712922.

@tryadelion
Copy link
Author

tryadelion commented Feb 14, 2023

Greetings, thank you for the fix. I know it probably isn't your domain, @juergw , but Is there a way to know when it could reach the AndroidX Crypto library?

In the meanwhile, we've been trying to find a way to reduce to a minimum the creation of new EncryptedSharedPreference without compromising our system, is there any recommended approach you can think of, and maybe a way to ensure the work is done in a non-blocking thread?

@juergw
Copy link
Contributor

juergw commented Feb 15, 2023

We plan to soon release a new version of Tink, and then (I think) also soon after a new AndroidX Crypto release can be made, which uses the new Tink release. But I can't give you exact dates.

I can't really give you any additional tips, sorry.

@tholenst tholenst added the p2 label Mar 20, 2023
@juergw
Copy link
Contributor

juergw commented Mar 21, 2023

Sorry, I forgot to update this issue.

Tink v 1.8.0 has been released, which includes the fix I mentioned above: https://github.com/tink-crypto/tink-java/releases/tag/v1.8.0

There has also been a new alpha release of androidx security:
https://developer.android.com/jetpack/androidx/releases/security#1.1.0-alpha05

But note that that release still uses Tink v.1.7.0 as dependency, https://mvnrepository.com/artifact/androidx.security/security-crypto/1.1.0-alpha05.

So you need to make sure that you use the newest version of Tink.

Because I think the issues here have been addressed, I'm going to close this issue now.

@juergw juergw closed this as completed Mar 21, 2023
@tryadelion
Copy link
Author

greetings @juergw , thanks for letting us know.
We can't seem to find those changes within 1.8.0, was it maybe squashed?

@juergw
Copy link
Contributor

juergw commented Mar 21, 2023

The 1.8 version of Tink is published to maven from the new repository, the source code is now here:

https://github.com/tink-crypto/tink-java/blob/1.8/src/main/java/com/google/crypto/tink/integration/android/AndroidKeystoreAesGcm.java

and it does include the changes. I also checked the source .zip file attached to https://github.com/tink-crypto/tink-java/releases/tag/v1.8.0, and it was also there. So I don't think its missing. Can you point me to where you don't see the change?

@juergw juergw reopened this Mar 21, 2023
@juergw
Copy link
Contributor

juergw commented Apr 26, 2023

Note that there is now a new version 1.1.0-alpha06 of androidx security which includes Tink Java version 1.8.0.

Does this solve the issue?

@tryadelion
Copy link
Author

We will update and check for any issues, thank you for letting us know, we'll update as soon as we can.

@juergw
Copy link
Contributor

juergw commented May 15, 2023

Any update on this? Is this still an issue?

@tryadelion
Copy link
Author

Hi, we haven't experienced this issue since we upgraded, so all indication is that it is solved. If we encounter something similar again we'll open a ticket. Thank you very much for your support.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
Projects
None yet
Development

No branches or pull requests

3 participants