-
Notifications
You must be signed in to change notification settings - Fork 50
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[bug] Contactless transaction failed com.stripe.core.aidIrpc.AidIRpcException: Failed to send request to AIDL server. #809
Comments
Update: I have now updated to the latest version of the terminal SDK, beta 20, which is backed by Android SDK 3.7.1. The issue is still easily repeatable. Here is a serial number if you want to internally investigate this:
I might be able to sort out an APK for you to test as well, please feel free to get in touch as we are particularly concerned about this one. |
Update: This is still happening. Here is a video demonstrating the error occurring after a card read failure. https://www.youtube.com/watch?v=t9nXQoPK6nY I've been in touch with a few people from Stripe today on the developer Discord. Here's the threads: https://discord.com/channels/841573134531821608/1285245446662393918 https://discord.com/channels/841573134531821608/1285272503220043839 Unfortunately we didn't get to a solution. As I mentioned in the threads, this is a regression that is blocking us from shipping updates to the Google Play store. We can't downgrade back to an older version of the Terminal SDK without this problem because of the requirement for new updates to target We are really stuck here, please help! |
hey @nabilfreeman thanks for reporting this issue. We are internally looking into this and will update once we know more or if we need more information. |
Thank you @nazli-stripe ! I am at hand to provide any information & try stuff for you if you need. Please feel free to write here or contact me via the email on our Stripe Account |
Hi @nabilfreeman - we're looking into this and wanted to eliminate the possibility of this being a device memory issue. Could you please try the following:
Additionally, if you have access to another Android device, it would be helpful if you could test the app there as well. This will help us determine if the issue is device-specific or more general. If you're able to reproduce, can you please provide device UUIDs + PaymentIntent IDs as well? |
Hi @mindy-stripe, thank you very much to you and your team for picking this up. Memory readingsI can only see average memory usage from the last 3 hours in the Android settings - screenshot at the end of this post. So to provide you with some more data, I used This is on a Pixel 6a with nothing else running, completely stock (it is a developer phone, so there is essentially nothing installed on it). It has 6GB of RAM. Immediately after cold boot
Upon launching our app
Upon opening the "Payment" screen (where the Tap to Pay button is rendered)
Card reader screen open (no card read yet)
At this point even without reading the card the screen automatically dismissed, we got the "JENA keeps stopping" alert and the "Contactless transaction failed" error, and I took another memory reading.
Card reader screen open (after failed card read)
I am not experienced enough with Android memory management to offer an opinion on what these values could mean. The Additional observationsWhile gathering the above data I observed a couple of instances of the "Failed to send request to AIDS server" throwing before the payment sheet opened. Another deviceWill try and gain access to another Android device with higher specs as soon as possible, and try to replicate the steps and issues recorded in the video I shared in the previous comment. I hope this information helps. Please let me know if you need anything else. |
Hi @mindy-stripe, do you have an update here? This is easily repeatable every day in production still. We are now considering pulling the feature due to its unreliability. |
hey @nabilfreeman thanks for your patience. One thing the team noted is that it appears the app connects and disconnects from TTP reader for every transaction. Spinning up the TTP process like this for every transaction could cause memort management issues. Is there a need to connect per transaction and disconnect when done? For the card read, the purple tap icon is positioned exactly where you should tap the card. In the video it looks like you are tapping slightly above that. Tapping right behind the icon might help with the inconsistencies there |
Hi @nabilfreeman, any updates about whether or not Nazli's suggestions about connecting once per session instead of once per transaction or tapping the card in the right place on the device worked for you? If we don't get a response soon, we will close this ticket due to inactivity. |
I don’t think either of these things apply.
I feel that I have provided significant information to you guys including telemetry, followed your memory theory and reported back with readings above. I’ve done through all my Stripe reps to try and get this escalated and even offered to come to the London office to reproduce the issue in person, but I don’t feel much interest coming back to actually fix this. To be honest I was very disappointed in the last response which is why i didn’t reply. It is a response I would have expected from a co like Google, but not Stripe. Maybe it’s a separation of responsibility issue or something as I suspect the root cause to the issue is in the Android SDK managed by another team. Anyway, I eagerly await Stripe Terminal Android version 4 as I assume Tap to Pay has been significantly reworked in that one? |
If you had come back and said something like the following I would have been a lot more understanding: “sorry, we can’t solve this because it’s a beta library running an older version of the Terminal Android SDK. The other team would just tell us to update to the latest version rather than debug it, and there’s not much we can do because we are just interfacing to that library” I hope this ticket doesn’t get closed as “false report, user was tapping in the wrong place” |
Interesting, we just updated to beta-22 and hit the same error @nabilfreeman is experiencing.
We'll be rolling back to 19 until this is fixed, @nazli-stripe let me know if you end up needing further details to help you debug it. Edit: Downgrading to beta-19 has not solved the issue, I believe this is because of a change in expo's ecosystem introduced from a dep change, somewhere. Edit: Rollback was successful, here's my new versus old package.json "dependencies": {
"@expo-google-fonts/open-sans": "^0.2.3",
"@react-native-async-storage/async-storage": "1.23.1",
"@react-native-community/datetimepicker": "8.0.1",
"@react-native-community/netinfo": "11.3.1",
"@react-native-google-signin/google-signin": "^11.0.0",
"@react-navigation/drawer": "^6.6.15",
"@react-navigation/native": "6.1.17",
"@react-navigation/stack": "6.3.29",
"@reduxjs/toolkit": "^1.9.5",
"@shopify/react-native-skia": "1.2.3",
"@stripe/stripe-terminal-react-native": "^0.0.1-beta.19",
"async-mutex": "^0.4.0",
"expo": "^51.0.38",
"expo-apple-authentication": "~6.4.2",
"expo-application": "~5.9.1",
"expo-build-properties": "~0.12.5",
"expo-checkbox": "~3.0.0",
"expo-crypto": "~13.0.2",
"expo-dev-client": "~4.0.28",
"expo-font": "~12.0.4",
"expo-location": "~17.0.1",
"expo-secure-store": "~13.0.2",
"expo-splash-screen": "~0.27.6",
"expo-status-bar": "~1.12.1",
"expo-updates": "~0.25.27",
"expo-web-browser": "^13.0.3",
"install": "^0.13.0",
"luxon": "^3.4.2",
"npm": "^10.8.1",
"patch-package": "^8.0.0",
"react": "18.2.0",
"react-native": "0.74.5",
"react-native-app-intro-slider": "^4.0.4",
"react-native-dropdown-picker": "^5.4.7-beta.1",
"react-native-gesture-handler": "~2.16.1",
"react-native-reanimated": "~3.10.1",
"react-native-safe-area-context": "4.10.5",
"react-native-screens": "3.31.1",
"react-native-toast-notifications": "^3.4.0",
"react-navigation-header-buttons": "^11.0.0",
"react-redux": "^8.1.2",
"expo-device": "~6.0.2"
},
"devDependencies": {
"@babel/core": "^7.24.0",
"@types/luxon": "^3.3.1",
"@types/react": "~18.2.79",
"@typescript-eslint/eslint-plugin": "^5.43.0",
"@typescript-eslint/parser": "^5.43.0",
"eslint": "^8.32.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-import": "^2.28.1",
"eslint-plugin-n": "^16.0.1",
"eslint-plugin-promise": "^6.1.1",
"eslint-plugin-react": "^7.33.2",
"prettier": "^2.8.8",
"prettier-eslint": "^16.1.2",
"typescript": "^5.2.2"
}, Old (Pre Rollback) "dependencies": {
"@expo-google-fonts/open-sans": "^0.2.3",
"@react-native-async-storage/async-storage": "1.23.1",
"@react-native-community/datetimepicker": "8.2.0",
"@react-native-community/netinfo": "11.4.1",
"@react-native-google-signin/google-signin": "^11.0.0",
"@react-navigation/drawer": "^6.6.15",
"@react-navigation/native": "6.1.17",
"@react-navigation/stack": "6.3.29",
"@reduxjs/toolkit": "^1.9.5",
"@shopify/react-native-skia": "1.5.0",
"@stripe/stripe-terminal-react-native": "^0.0.1-beta.22",
"async-mutex": "^0.4.0",
"expo": "^52.0.6",
"expo-apple-authentication": "~7.1.0",
"expo-application": "~6.0.1",
"expo-build-properties": "~0.13.1",
"expo-checkbox": "~4.0.0",
"expo-crypto": "~14.0.1",
"expo-dev-client": "~5.0.1",
"expo-device": "~7.0.1",
"expo-font": "~13.0.1",
"expo-location": "~18.0.1",
"expo-secure-store": "~14.0.0",
"expo-splash-screen": "~0.29.9",
"expo-status-bar": "~2.0.0",
"expo-updates": "~0.26.7",
"expo-web-browser": "~14.0.1",
"install": "^0.13.0",
"luxon": "^3.4.2",
"npm": "^10.8.1",
"patch-package": "^8.0.0",
"react": "18.3.1",
"react-native": "^0.76.2",
"react-native-app-intro-slider": "^4.0.4",
"react-native-dropdown-picker": "^5.4.7-beta.1",
"react-native-gesture-handler": "~2.20.2",
"react-native-reanimated": "~3.16.1",
"react-native-safe-area-context": "4.12.0",
"react-native-screens": "~4.0.0",
"react-native-toast-notifications": "^3.4.0",
"react-navigation-header-buttons": "^11.0.0",
"react-redux": "^8.1.2"
},
"devDependencies": {
"@babel/core": "^7.24.0",
"@types/luxon": "^3.3.1",
"@types/react": "~18.3.12",
"@typescript-eslint/eslint-plugin": "^5.43.0",
"@typescript-eslint/parser": "^5.43.0",
"eslint": "^8.32.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-import": "^2.28.1",
"eslint-plugin-n": "^16.0.1",
"eslint-plugin-promise": "^6.1.1",
"eslint-plugin-react": "^7.33.2",
"prettier": "^2.8.8",
"prettier-eslint": "^16.1.2",
"typescript": "^5.2.2"
}, @nabilfreeman
I think there is an issue here, somewhere. Probably with an expo or react update? |
Describe the bug
See the attached photo. Repeatably on Android, after calling
collectPaymentMethod
to present the Tap to Pay card reader, the reader screen dismisses and this error in thrown. The full text in the alert body is the entirety of the error message:Contactless transaction failed com.stripe.core.aidIrpc.AidIRpcException: Failed to send request to AIDL server.
It appears this issue was introduced after updating from
targetSdkVersion
&compileSdkVersion
33 to 34.It is still possible to take a contactless payment on Android, so this appears to be intermittent.
My best guess is that this is related to card read errors ("Try again" and loud beep on Android). After two or three of these, the sheet closes and the error is triggered.
In general, it seems that the Android tap to pay reader is very unreliable, and the user has to endure several "Try again" errors before successfully processing the payment. This was the case before updating the
targetSdkVersion
, so I am not sure if it is related.To Reproduce
Steps to reproduce the behavior:
collectPaymentMethod({ paymentIntent })
collectPaymentMethod
promise rejects with the error message in the issue title.Expected behavior
Screenshots
Stripe Terminal React Native SDK version
^0.0.1-beta.19
Smartphone (please complete the following information):
Additional context
In Expo
app.json
plugins:The text was updated successfully, but these errors were encountered: