flutter-stripe/flutter_stripe

Android App crashes in Release mode with com.android.application version >= 8

lokus1980 opened this issue · 52 comments

Hello,

As the title suggests, this Stripe library does not work on any of my Android phones (for example, the Pixel 6 with Android 14).

Detailed log from the crash in Release build: crash.log

I have tested on multiple phones with Android 10 and Android 14. It always works in Debug mode but crashes instantly in Release mode. Please help.

Flutter: 3.24.1 (latest version)
flutter_stripe: 11.0.0 (latest version)

Also, I have done every single installation step as described here:
https://pub.dev/packages/flutter_stripe

That's the piece of code that shows the payment sheet:
payment sheet

Video from Debug build (works):
https://github.com/user-attachments/assets/ef3eba99-6180-4f5a-8a09-0933f76e5641

Video from Release build (crashes):
https://github.com/user-attachments/assets/bc5daedd-4ef3-4fcf-9116-17815776cddc

This blocks me from releasing the app to production as the payment feature is the core functionality here. The only thing I need for my MVP is to allow customers to pay by card. Nothing else is required at this stage and even this scenario does not work. And I don't want to publish a Debug version to production...

Please help. I have invested lots of time integrating Stripe with my backend but it's not usable end to end as the mobile app (currently my only API client) is not working at all. Thank you.

so deadobject exception means the paymentsheetactivity got killed by the android OS. Can it be that you do not have applied all the steps for android as described here?

I am using paymentsheet as well and do not have this issue

Yes @remonh87, I have done all the steps like in the instruction and getting:

09-04 06:41:30.289   719   885 D EGL_emulation: app_time_stats: avg=20.57ms min=9.28ms max=216.36ms count=49
09-04 06:41:30.307   374   448 W VsyncModulator: setTransactionSchedule: Unexpected EarlyEnd
09-04 06:41:30.412   511   531 W ActivityTaskManager: Activity top resumed state loss timeout for ActivityRecord{9568b9 u0 com.gameos.goxp.dev/com.stripe.android.paymentsheet.PaymentSheetActivity t54 f} isExiting}
09-04 06:41:30.469  1155  1200 W .gms.persistent: Couldn't lock the profile file /data/misc/profiles/cur/0/com.google.android.gms/primary.prof: Failed to lock file '/data/misc/profiles/cur/0/com.google.android.gms/primary.prof': Try again
09-04 06:41:30.479  1155  1200 W .gms.persistent: Could not forcefully load profile /data/misc/profiles/cur/0/com.google.android.gms/primary.prof
09-04 06:41:30.624   719   820 V WindowManagerShell: Transition animation finished (aborted=false), notifying core (#25)android.os.BinderProxy@5b8c221@0
09-04 06:41:30.625   511   528 V WindowManager: Finish Transition #25: created at 09-04 06:41:29.910 collect-started=0.016ms request-sent=0.033ms started=5.287ms ready=59.43ms sent=93.22ms finished=714.556ms
09-04 06:41:30.625   511   525 W WindowManager: Exception thrown during dispatchAppVisibility Window{19ad775 u0 com.gameos.goxp.dev/com.stripe.android.paymentsheet.PaymentSheetActivity EXITING}
09-04 06:41:30.625   511   525 W WindowManager: android.os.DeadObjectException
09-04 06:41:30.625   511   525 W WindowManager: 	at android.os.BinderProxy.transactNative(Native Method)
09-04 06:41:30.625   511   525 W WindowManager: 	at android.os.BinderProxy.transact(BinderProxy.java:584)
09-04 06:41:30.625   511   525 W WindowManager: 	at android.view.IWindow$Stub$Proxy.dispatchAppVisibility(IWindow.java:546)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.WindowState.sendAppVisibilityToClients(WindowState.java:3271)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.WindowContainer.sendAppVisibilityToClients(WindowContainer.java:1221)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.WindowToken.setClientVisible(WindowToken.java:409)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.setClientVisible(ActivityRecord.java:6946)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.postApplyAnimation(ActivityRecord.java:5637)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.commitVisibility(ActivityRecord.java:5580)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.Transition.finishTransition(Transition.java:1151)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.TransitionController.finishTransition(TransitionController.java:868)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.finishTransition(WindowOrganizerController.java:396)
09-04 06:41:30.625   511   525 W WindowManager: 	at android.window.IWindowOrganizerController$Stub.onTransact(IWindowOrganizerController.java:286)
09-04 06:41:30.625   511   525 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.onTransact(WindowOrganizerController.java:181)
09-04 06:41:30.625   511   525 W WindowManager: 	at android.os.Binder.execTransactInternal(Binder.java:1339)
09-04 06:41:30.625   511   525 W WindowManager: 	at android.os.Binder.execTransact(Binder.java:1275)
09-04 06:41:30.627   511   525 I Process : Sending signal. PID: 6297 SIG: 9
09-04 06:41:30.627   511   525 W WindowManager: Exception thrown during dispatchAppVisibility Window{717fed8 u0 com.gameos.goxp.dev/com.gameos.goxp.dev.MainActivity EXITING}
09-04 06:41:30.627   511   525 W WindowManager: android.os.DeadObjectException
09-04 06:41:30.627   511   525 W WindowManager: 	at android.os.BinderProxy.transactNative(Native Method)
09-04 06:41:30.627   511   525 W WindowManager: 	at android.os.BinderProxy.transact(BinderProxy.java:584)
09-04 06:41:30.627   511   525 W WindowManager: 	at android.view.IWindow$Stub$Proxy.dispatchAppVisibility(IWindow.java:546)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.WindowState.sendAppVisibilityToClients(WindowState.java:3271)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.WindowContainer.sendAppVisibilityToClients(WindowContainer.java:1221)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.WindowToken.setClientVisible(WindowToken.java:409)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.setClientVisible(ActivityRecord.java:6946)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.postApplyAnimation(ActivityRecord.java:5637)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.ActivityRecord.commitVisibility(ActivityRecord.java:5580)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.Transition.finishTransition(Transition.java:1151)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.TransitionController.finishTransition(TransitionController.java:868)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.finishTransition(WindowOrganizerController.java:396)
09-04 06:41:30.627   511   525 W WindowManager: 	at android.window.IWindowOrganizerController$Stub.onTransact(IWindowOrganizerController.java:286)
09-04 06:41:30.627   511   525 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.onTransact(WindowOrganizerController.java:181)
09-04 06:41:30.627   511   525 W WindowManager: 	at android.os.Binder.execTransactInternal(Binder.java:1339)
09-04 06:41:30.627   511   525 W WindowManager: 	at android.os.Binder.execTransact(Binder.java:1275)
09-04 06:41:30.627   511   525 I Process : Sending signal. PID: 6297 SIG: 9
09-04 06:41:30.631   511   531 W ActivityManager: setHasOverlayUi called on unknown pid: 6297
09-04 06:41:30.633   719   820 V WindowManagerShell: Track 0 became idle
09-04 06:41:30.634   719   820 V WindowManagerShell: All active transition animations finished
09-04 06:41:30.654   374   374 E BpTransactionCompletedListener: Failed to transact (-32)
09-04 06:41:30.654   374   374 E BpTransactionCompletedListener: Failed to transact (-32)
09-04 06:41:30.654   374   374 E BpTransactionCompletedListener: Failed to transact (-32)
09-04 06:41:31.290   719   885 D EGL_emulation: app_time_stats: avg=17.25ms min=8.51ms max=32.39ms count=58

Now, please look at my configuration and see if you can spot anything:

Flutter: 3.24.1 (latest stable version)
flutter_stripe: 11.0.0 (latest version)

Flutter Doctor report:
[✓] Flutter (Channel stable, 3.24.1, on macOS 14.6.1 23G93 darwin-arm64, locale en-AU)
[✓] Android toolchain - develop for Android devices (Android SDK version 34.0.0)
[✓] Xcode - develop for iOS and macOS (Xcode 15.4)
[✓] Chrome - develop for the web
[✓] Android Studio (version 2023.1)
[✓] VS Code (version 1.92.2)
[✓] Connected device (4 available)
[✓] Network resources

Pubspec.yaml:

name: goxp
description: GoXP app
publish_to: 'none'
version: 0.2.0+154

environment:
  sdk: '>=3.5.0 <4.0.0'

dependencies:
  flutter:
    sdk: flutter
  amplify_api: ^2.3.0
  amplify_auth_cognito: ^2.3.0
  amplify_authenticator: ^2.1.1
  amplify_flutter: ^2.3.0
  badges: ^3.1.1
  collection: ^1.18.0
  cupertino_icons: ^1.0.2
  equatable: ^2.0.5
  flutter_native_splash: ^2.3.1
  flutter_rating_bar: ^4.0.1
  flutter_redux: ^0.10.0
  flutter_stripe: ^11.0.0
  form_builder_validators: ^11.0.0
  go_router: ^14.2.0
  http_parser: ^4.0.2
  http: ^1.1.0
  image_picker: ^1.0.4
  mocktail: ^1.0.3
  redux: ^5.0.0
  settings_ui: ^2.0.2
  url_launcher: ^6.3.0
  uuid: ^4.3.3

dev_dependencies:
  integration_test:
    sdk: flutter
  flutter_test:
    sdk: flutter

  flutter_launcher_icons: ^0.13.1
  flutter_lints: ^4.0.0
  change_app_package_name: ^1.2.0

flutter:
  uses-material-design: true

  assets:
    - assets/images/
    - assets/images/initialisation/
    - assets/icons/

  fonts:
    - family: Poppins
      fonts:
        - asset: assets/fonts/poppins/Poppins-Thin.ttf
          weight: 100
        - asset: assets/fonts/poppins/Poppins-ThinItalic.ttf
          weight: 100
          style: italic
        - asset: assets/fonts/poppins/Poppins-ExtraLight.ttf
          weight: 200
        - asset: assets/fonts/poppins/Poppins-ExtraLightItalic.ttf
          weight: 200
          style: italic
        - asset: assets/fonts/poppins/Poppins-Light.ttf
          weight: 300
        - asset: assets/fonts/poppins/Poppins-LightItalic.ttf
          weight: 300
          style: italic
        - asset: assets/fonts/poppins/Poppins-Regular.ttf
        - asset: assets/fonts/poppins/Poppins-Italic.ttf
          style: italic
        - asset: assets/fonts/poppins/Poppins-Medium.ttf
          weight: 500
        - asset: assets/fonts/poppins/Poppins-MediumItalic.ttf
          weight: 500
          style: italic
        - asset: assets/fonts/poppins/Poppins-SemiBold.ttf
          weight: 600
        - asset: assets/fonts/poppins/Poppins-SemiBoldItalic.ttf
          weight: 600
          style: italic
        - asset: assets/fonts/poppins/Poppins-Bold.ttf
          weight: 700
        - asset: assets/fonts/poppins/Poppins-BoldItalic.ttf
          weight: 700
          style: italic
        - asset: assets/fonts/poppins/Poppins-ExtraBold.ttf
          weight: 800
        - asset: assets/fonts/poppins/Poppins-ExtraBoldItalic.ttf
          weight: 800
          style: italic
        - asset: assets/fonts/poppins/Poppins-Black.ttf
          weight: 800
        - asset: assets/fonts/poppins/Poppins-BlackItalic.ttf
          weight: 800
          style: italic

flutter_launcher_icons:
  image_path: "assets/icons/app_icon.png"
  android: true
  ios: true
  adaptive_icon_background: "assets/icons/background.png"
  adaptive_icon_foreground: "assets/icons/foreground.png"

flutter_native_splash:
  color: "#0D0160"
  color_dark: "#0D0160"
  image_ios: assets/images/splash/splash.png
  ios_content_mode: scaleAspectFill
  android_12:
    image: android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
  image_android: assets/images/splash/splash.png
  android_gravity: center

main.dart:

Future<void> main() async {
  WidgetsFlutterBinding.ensureInitialized();

  Stripe.publishableKey =
      "pk_test_*********";
  Stripe.merchantIdentifier = 'merchant.flutter.stripe.test';
  Stripe.urlScheme = 'goxpdev';
  await Stripe.instance.applySettings();
  ...
  runApp(...);
}

styles.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is off -->
    <style name="LaunchTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- Show a splash screen on the activity. Automatically removed when
             Flutter draws its first frame -->
        <item name="android:windowBackground">@drawable/launch_background</item>
    </style>
    <!-- Theme applied to the Android Window as soon as the process has started.
         This theme determines the color of the Android Window while your
         Flutter UI initializes, as well as behind your Flutter UI while its
         running.
         This Theme is only used starting with V2 of Flutter's Android embedding. -->
    <style name="NormalTheme" parent="Theme.MaterialComponents">
        <item name="android:windowBackground">?android:colorBackground</item>
    </style>
</resources>

styles.xml (values-night):

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- Theme applied to the Android Window while the process is starting when the OS's Dark Mode setting is on -->
    <!-- TODO document the necessary change -->
    <style name="LaunchTheme" parent="Theme.AppCompat.DayNight.NoActionBar">
        <!-- Show a splash screen on the activity. Automatically removed when
             Flutter draws its first frame -->
        <item name="android:windowBackground">@drawable/launch_background</item>
    </style>
    <!-- Theme applied to the Android Window as soon as the process has started.
         This theme determines the color of the Android Window while your
         Flutter UI initializes, as well as behind your Flutter UI while its
         running.
         
         This Theme is only used starting with V2 of Flutter's Android embedding. -->
    <style name="NormalTheme" parent="Theme.MaterialComponents">
        <item name="android:windowBackground">?android:colorBackground</item>
    </style>
</resources>

android/build.gradle:

allprojects {
    repositories {
        google()
        mavenCentral()
    }
}

rootProject.buildDir = '../build'
subprojects {
    project.buildDir = "${rootProject.buildDir}/${project.name}"
}
subprojects {
    project.evaluationDependsOn(':app')
}

tasks.register("clean", Delete) {
    delete rootProject.buildDir
}

android/app/build.gradle:

plugins {
    id "com.android.application"
    id "kotlin-android"
    id "dev.flutter.flutter-gradle-plugin"
    id "com.google.gms.google-services"
    id "com.google.firebase.crashlytics"
}

def localProperties = new Properties()
def localPropertiesFile = rootProject.file('local.properties')
if (localPropertiesFile.exists()) {
    localPropertiesFile.withReader('UTF-8') { reader ->
        localProperties.load(reader)
    }
}

def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
if (flutterVersionCode == null) {
    flutterVersionCode = '1'
}

def flutterVersionName = localProperties.getProperty('flutter.versionName')
if (flutterVersionName == null) {
    flutterVersionName = '1.0'
}

android {
    namespace "com.gameos.goxp.dev"
    compileSdk 34

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_17
        targetCompatibility JavaVersion.VERSION_17
    }

    sourceSets {
        main.java.srcDirs += 'src/main/kotlin'
    }

    defaultConfig {
        // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
        applicationId "com.gameos.goxp.dev"
        // You can update the following values to match your application needs.
        // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration.
        minSdkVersion 24
        targetSdkVersion 33
        // targetSdkVersion flutter.targetSdkVersion
        versionCode flutterVersionCode.toInteger()
        versionName flutterVersionName
    }

    buildTypes {
        release {
            // TODO: Add your own signing config for the release build.
            // Signing with the debug keys for now, so `flutter run --release` works.
            signingConfig signingConfigs.debug
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

flutter {
    source '../..'
}

dependencies {
    implementation 'com.google.firebase:firebase-iid:21.1.0'
    implementation 'com.google.android.gms:play-services-base:18.1.0'
}

proguard-rules.pro:

-dontwarn com.stripe.android.pushProvisioning.PushProvisioningActivity$g
-dontwarn com.stripe.android.pushProvisioning.PushProvisioningActivityStarter$Args
-dontwarn com.stripe.android.pushProvisioning.PushProvisioningActivityStarter$Error
-dontwarn com.stripe.android.pushProvisioning.PushProvisioningActivityStarter
-dontwarn com.stripe.android.pushProvisioning.PushProvisioningEphemeralKeyProvider

gradle-wraper.properties:

distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

MainActivity.kt:

package com.gameos.goxp.dev

import io.flutter.embedding.android.FlutterActivity
import io.flutter.embedding.android.FlutterFragmentActivity

class MainActivity: FlutterFragmentActivity() {
}

and the code that is presenting the payment sheet:

  Future<void> _bookCurrentExperience(Store<AppState> store, BookCurrentExperience action, NextDispatcher next) async {
    store.dispatch(const ShowLoader());
    try {
      final experienceId = store.state.experienceState.currentExperience!.id;
      final priceOptionId = action.priceOptionId;
      final experienceModifiedAt = store.state.experienceState.currentExperience!.modifiedAt;
      // 1. create payment intent on the server
      final paymentIntent = await _createPaymentIntent(experienceId, priceOptionId, experienceModifiedAt);
      // 2. set publishable key
      // Stripe.publishableKey = paymentIntent.publishableKey;
      // 3. initialize the payment sheet
      await Stripe.instance.initPaymentSheet(
        paymentSheetParameters: SetupPaymentSheetParameters(
          customFlow: false,
          merchantDisplayName: 'GoXP',
          paymentIntentClientSecret: paymentIntent.clientSecret,
          customerEphemeralKeySecret: paymentIntent.ephemeralKey,
          customerId: paymentIntent.stripeCustomerId,
        ),
      );
      // 4. present payment sheet
      await Stripe.instance.presentPaymentSheet();
      safePrint("Payment completed!!!");
      // TODO: navigate to "Thank for booking your experience. Check your inbox for a confirmation email"
      next(action);
    } catch (e) {
      // TODO: show a popup with an error message
      safePrint(e);
    } finally {
      store.dispatch(const HideLoader());
    }
  }

I am running out of ideas. I tried lots of things like fiddling with customFlow, targetSdkVersion, flutter-stripe version and still getting the android.os.DeadObjectException. Also, I disabled my loader animation thinking that maybe it would come in the way but it also didn't help. My app is very simple, just a few screens for now and no crazy stuff except for a few calls to our REST API.

Once again, the Debug build works, but the Release/Prod build fails, as shown in the log at the top.

Please help.

@lokus1980 can u please provide an image for settings.gradle file, and there are 3 things to try android/build.gradle:

  • first you should know that there is an updated syntax for this whole file(android/build.gradle)
  • second try targetSdk to be 34
  • third add these to dependencies:
    • implementation 'com.google.android.gms:play-services-wallet:19.3.0'
    • implementation 'com.stripe:stripe-android:20.37.2'
    • implementation 'androidx.appcompat:appcompat:1.6.1'
      wish u benefit from this

Hi @ibrahimMobileArts, I have applied your suggested changes and the app is still crashing.

Here's the content of my settings.gradle:

pluginManagement {
    def flutterSdkPath = {
        def properties = new Properties()
        file("local.properties").withInputStream { properties.load(it) }
        def flutterSdkPath = properties.getProperty("flutter.sdk")
        assert flutterSdkPath != null, "flutter.sdk not set in local.properties"
        return flutterSdkPath
    }()

    includeBuild("$flutterSdkPath/packages/flutter_tools/gradle")

    repositories {
        google()
        mavenCentral()
        gradlePluginPortal()
    }
}

plugins {
    id "dev.flutter.flutter-plugin-loader" version "1.0.0"
    id "com.android.application" version "8.2.2" apply false
    id "org.jetbrains.kotlin.android" version "1.9.0" apply false
    id "com.google.gms.google-services" version "4.4.0" apply false
    id "com.google.firebase.crashlytics" version "2.9.9" apply false
}

include ":app"

I think there must be some weird bug in this library as, like I said, the app works in a Debug build (so all settings, libs and things are like they should) but in a Release build it crashes when I try to shoe the Payment Sheet. I don't know what else I can do to make it work in Release build. I'll try to run the demo app included in this library whether it works in Release build as if it suffers from the same problem, you would have a case that is easy to reproduce on your end.

Also, what did you mean exactly by "first you should know that there is an updated syntax for this whole file"?
Can you please send an example of the correct syntax so I can try it?

OK, the demo app (that is included in this library) crashes at the same point as my app.

I just launched the server and then the app, went to the payment sheet screen and it crashes with my test Stripe keys:

Here's the video of the crash:
https://github.com/user-attachments/assets/5b6d5453-94c3-4d9e-85ed-05dcfe1303fa

So the problem seems to be in the library, not in my app.

Please launch the demo app in a Release mode and you will see the crash on your end too :)

Just try flutter run --release.

Hi @ibrahimMobileArts, I have applied your suggested changes and the app is still crashing.

Here's the content of my settings.gradle:

pluginManagement {
    def flutterSdkPath = {
        def properties = new Properties()
        file("local.properties").withInputStream { properties.load(it) }
        def flutterSdkPath = properties.getProperty("flutter.sdk")
        assert flutterSdkPath != null, "flutter.sdk not set in local.properties"
        return flutterSdkPath
    }()

    includeBuild("$flutterSdkPath/packages/flutter_tools/gradle")

    repositories {
        google()
        mavenCentral()
        gradlePluginPortal()
    }
}

plugins {
    id "dev.flutter.flutter-plugin-loader" version "1.0.0"
    id "com.android.application" version "8.2.2" apply false
    id "org.jetbrains.kotlin.android" version "1.9.0" apply false
    id "com.google.gms.google-services" version "4.4.0" apply false
    id "com.google.firebase.crashlytics" version "2.9.9" apply false
}

include ":app"

I think there must be some weird bug in this library as, like I said, the app works in a Debug build (so all settings, libs and things are like they should) but in a Release build it crashes when I try to shoe the Payment Sheet. I don't know what else I can do to make it work in Release build. I'll try to run the demo app included in this library whether it works in Release build as if it suffers from the same problem, you would have a case that is easy to reproduce on your end.

Also, what did you mean exactly by "first you should know that there is an updated syntax for this whole file"? Can you please send an example of the correct syntax so I can try it?

this is an example, even though i don't think its the problem anymore:
plugins {
id "com.android.application"
id "kotlin-android"
// The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins.
id "dev.flutter.flutter-gradle-plugin"
id 'com.google.gms.google-services'
id "com.google.firebase.crashlytics"
}

def localProperties = new Properties()
def localPropertiesFile = rootProject.file("local.properties")
if (localPropertiesFile.exists()) {
localPropertiesFile.withReader("UTF-8") { reader ->
localProperties.load(reader)
}
}

def flutterVersionCode = localProperties.getProperty("flutter.versionCode")
if (flutterVersionCode == null) {
flutterVersionCode = "1"
}

def flutterVersionName = localProperties.getProperty("flutter.versionName")
if (flutterVersionName == null) {
flutterVersionName = "1.0"
}

android {
namespace = "app.app.app"
compileSdk = 34
ndkVersion = flutter.ndkVersion

compileOptions {
    sourceCompatibility = JavaVersion.VERSION_17
    targetCompatibility = JavaVersion.VERSION_17
}

defaultConfig {
    // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
    applicationId = "app.app.app"
    // You can update the following values to match your application needs.
    // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-gradle-build-configuration.
    minSdk = 23
    targetSdk = 34
    versionCode = flutterVersionCode.toInteger()
    versionName = flutterVersionName
}

buildTypes {
    release {
        // TODO: Add your own signing config for the release build.
        // Signing with the debug keys for now, so `flutter run --release` works.
        signingConfig = signingConfigs.debug
    }
}

}

flutter {
source = "../.."
}

dependencies {
// Import the Firebase BoM
implementation platform('com.google.firebase:firebase-bom:33.1.1')
implementation 'com.google.firebase:firebase-analytics'
implementation 'androidx.appcompat:appcompat:1.6.1'
implementation 'com.stripe:stripe-android:20.37.2'
implementation 'com.google.android.gms:play-services-wallet:19.3.0'

// Add the dependencies for any other desired Firebase products
// https://firebase.google.com/docs/android/setup#available-libraries
}

Hi @ibrahimMobileArts and @remonh87.

As in my previous message, the demo app included in this library crashes the same way as my app in Release mode.
Video: https://github.com/user-attachments/assets/5b6d5453-94c3-4d9e-85ed-05dcfe1303fa
Below is the log from the crash.

I have tested it both with Stripe test and live API keys. That's a serious bug I think. It crashes the same way on emulators and real devices (like a stock Google Pixel 6 with Android 14). This makes this Flutter library unusable in production.

Can you please run the demo app in Release mode (flutter run --release or deploy the apk build by flutter build apk) to reproduce the error on your end and see if you can fix it please?

09-10 05:06:34.893   722   866 D EGL_emulation: app_time_stats: avg=6526.96ms min=14.81ms max=103900.69ms count=16
09-10 05:06:35.028   509   529 W ActivityTaskManager: Activity top resumed state loss timeout for ActivityRecord{2f79811 u0 com.flutter.stripe.example/com.stripe.android.customersheet.CustomerSheetActivity t65 f} isExiting}
09-10 05:06:35.110   722   793 V WindowManagerShell: Transition animation finished (aborted=false), notifying core (#10)android.os.BinderProxy@8f21c5d@0
09-10 05:06:35.111   509   526 V WindowManager: Finish Transition #10: created at 09-10 05:06:34.449 collect-started=0.032ms request-sent=4.088ms started=5.79ms ready=176.244ms sent=269.208ms finished=661.281ms
09-10 05:06:35.113   509  1885 W WindowManager: Exception thrown during dispatchAppVisibility Window{433c4f u0 com.flutter.stripe.example/com.flutter.stripe.example.MainActivity EXITING}
09-10 05:06:35.113   509  1885 W WindowManager: android.os.DeadObjectException
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.os.BinderProxy.transactNative(Native Method)
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.os.BinderProxy.transact(BinderProxy.java:584)
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.view.IWindow$Stub$Proxy.dispatchAppVisibility(IWindow.java:546)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.WindowState.sendAppVisibilityToClients(WindowState.java:3271)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.WindowContainer.sendAppVisibilityToClients(WindowContainer.java:1221)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.WindowToken.setClientVisible(WindowToken.java:409)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.ActivityRecord.setClientVisible(ActivityRecord.java:6946)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.ActivityRecord.postApplyAnimation(ActivityRecord.java:5637)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.ActivityRecord.commitVisibility(ActivityRecord.java:5580)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.Transition.finishTransition(Transition.java:1151)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.TransitionController.finishTransition(TransitionController.java:868)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.finishTransition(WindowOrganizerController.java:396)
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.window.IWindowOrganizerController$Stub.onTransact(IWindowOrganizerController.java:286)
09-10 05:06:35.113   509  1885 W WindowManager: 	at com.android.server.wm.WindowOrganizerController.onTransact(WindowOrganizerController.java:181)
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.os.Binder.execTransactInternal(Binder.java:1344)
09-10 05:06:35.113   509  1885 W WindowManager: 	at android.os.Binder.execTransact(Binder.java:1275)
09-10 05:06:35.115   509  1885 I Process : Sending signal. PID: 12454 SIG: 9
09-10 05:06:35.118   722   793 V WindowManagerShell: Track 0 became idle
09-10 05:06:35.118   722   793 V WindowManagerShell: All active transition animations finished
09-10 05:06:35.120   509   891 D ActivityManager: sync unfroze 10020 com.google.android.gms for 6

And that's my flutter doctor report again if that helps:

Flutter Doctor report:
[✓] Flutter (Channel stable, 3.24.1, on macOS 14.6.1 23G93 darwin-arm64, locale en-AU)
[✓] Android toolchain - develop for Android devices (Android SDK version 34.0.0)
[✓] Xcode - develop for iOS and macOS (Xcode 15.4)
[✓] Chrome - develop for the web
[✓] Android Studio (version 2023.1)
[✓] VS Code (version 1.92.2)
[✓] Connected device (4 available)
[✓] Network resources

Also, my Java (as maybe here there's something wrong?):

openjdk 22.0.1 2024-04-16
OpenJDK Runtime Environment Homebrew (build 22.0.1)
OpenJDK 64-Bit Server VM Homebrew (build 22.0.1, mixed mode, sharing)

@lokus1980 hello, sorry am not sure about your problem exactly, however please try few things i foundx while comparing to my working code:

  • from MainActivity.kt, remove "import io.flutter.embedding.android.FlutterActivity"
  • try this in the gradle-wrapper file: distributionUrl=https://services.gradle.org/distributions/gradle-8.4-all.zip
  • is there any chance in your code that you call one of the stripe functions twice? (_createPaymentIntent, initPaymentSheet or presentPaymentSheet) cause according to provided function it seems fine, but in the video there are 2 steps(2 buttons)
  • is everything fine on ios?
  • do you have styles.xml for android 14 ? i will attach an image:
Screenshot 2024-09-10 at 10 10 09 AM

Hi @ibrahimMobileArts, before I try your suggestions, can you please check a few things for me?

The video you saw in my previous message is not from my app but the demo app included in this library. It's crashing on all my Android phones too. Please download it here: https://github.com/flutter-stripe/flutter_stripe/tree/main/example

  1. Can you please run your app in release mode and see if it's not crashing when making a payment? (flutter run --release)? Are you using Payment Sheet in your app? This one is crashing on the demo app.
  2. Can you please run the demo app (included in the flutter_stripe library) and run it in release mode (flutter run --release) and select Customer Sheet and then "Init customer sheet" and "Select payment method now"?
Screenshot 2024-09-10 at 6 43 32 PM Screenshot 2024-09-10 at 6 44 39 PM

@lokus1980 i just finished running my app using flutter run --release and i made a payment and everything works fine, did you try the library's demo app on android 12 or below?

Thank you @ibrahimMobileArts for checking this!

Are you making payments in your app via Payment Sheet (https://docs.page/flutter-stripe/flutter_stripe/sheet)?

Can you please share what Flutter and Java version you have on your machine?

Are you running everything on Mac or Windows?

Flutter 3.24.1 / Dart 3.5.1
java version "1.8.0_421"
running on Mac

Thank you, I'll try your Java version and see if that helps. The rest is the same as on my machine.

I tried some older versions of Java, and also a phone with Android 12.
Tried different versions of Gradle (8.2 and 8.7).

It is still crashing when showing a Payment Sheet.

I am running out of ideas 😬

Is there an alternative method of making a payment by card in this library?

I can reproduce it on the example app. Will spend some time tonight to see if I can fix something. Can you try an older version of Flutter Stripe.

The interesting thing is that I cannot reproduce it in my other production app so it has to be some config somewhere

CC: @jonasbark

@lokus1980 so it looks like some gradle / android dependency issue. I didn't came further in our repo but I was able to run release with a paymentsheet with a fresh flutter project. Feel free to have a look and compare: https://github.com/remonh87/test_app_stripe . I will look a bit further later this week to triage it further but it is a needle in a haystack

Thanks @remonh87 so much for being able to reproduce the issue on your end. It's a relief that it's not only happening on my machine/phones only. I'll try to compare the demo app with your one (that works in the release build) to understand what is causing this issue. If we find it, let's fix the demo app for others 😉

Hi @remonh87 - great success! By comparing your app with the demo one, I have found the issue. It all comes down to this change to make the app work in release mode.

Screenshot 2024-09-11 at 12 13 34 PM

So it was com.android.application not working with the flutter_stripe library and I had to downgrade this plugin's version to 7.3.0. My app works as intended. Thanks a lot for your time and effort to help save the day!

Thanks for investigating @remonh87 @lokus1980 ! I'll dig deeper the next few days as that required change is a bit concerning

I did get another crash when running the latest example app in release mode:

E/AndroidRuntime(30058): FATAL EXCEPTION: main
E/AndroidRuntime(30058): Process: com.flutter.stripe.example, PID: 30058
E/AndroidRuntime(30058): L.l: Compose Runtime internal error. Unexpected or incorrect use of the Compose internal runtime API (pending composition has not been applied). Please report to Google or use https://goo.gle/compose-feedback
E/AndroidRuntime(30058): 	at L.o.v(SourceFile:30)
E/AndroidRuntime(30058): 	at L.s.A(SourceFile:82)
...

and using the latest stripe-android 20.49.0 version:

E/AndroidRuntime(30663): java.lang.IncompatibleClassChangeError: Class 'android.content.res.XmlBlock$Parser' does not implement interface 'N8.a' in call to 'int N8.a.next()' (declaration of 'g0.a' appears in /data/app/~~jM-88922nRTEcjnOKtLMqg==/com.flutter.stripe.example-9S2AjNxzCruXSVtE3OOZag==/base.apk)
E/AndroidRuntime(30663): 	at g0.a.a(SourceFile:6)
E/AndroidRuntime(30663): 	at t0.f.c(SourceFile:46)

Downgrading com.android.application is indeed the only fix I found.

Yes, that is a bit concerning @jonasbark but because a freshly generated Flutter app with the latest Flutter version uses com.android.application in version 7.3.0, I'm sure the Flutter team is aware of some issues related to version 8.x.x.

So it does not necessarily mean that flutter_stripe has some bug but it's a general Flutter issue that is not really compatible with com.android.application v8+. I would stick to version 7.3.0 and move on as that's the default version that Flutter is supporting right now by looking into a freshly generated app. Once they release a Flutter version supporting com.android.application v8+, we can try it with flutter_stripe again. For now I would not worry too much about it.

The only things I would do for now are to:

  • mention this issue in the readme/setup-instruction of this library (so that no one tries to bump up from version 7.3.0 to 8+)
  • fix the sample app bundled in this lib so that people are not confused as to why it's crashing in release mode

@jonasbark - I have created a branch with the fixes mentioned above but I don't have permissions to push that branch and create a pull request. Can you please help?

Most libraries are requiring to have

Gradle 8.0
Android Gradle plugin 8.1.0
Google services Gradle plugin 4.4.1

as well as Java version at least 17 or newer, not 1.8 @ibrahimMobileArts

https://docs.gradle.org/current/userguide/compatibility.html

The app crashes with such gradle plugin settings

    id "dev.flutter.flutter-plugin-loader" version "1.0.0"
    id "com.android.application" version "7.1.2" apply false
    id "org.jetbrains.kotlin.android" version "1.8.0" apply false
    id 'com.google.gms.google-services' version '4.3.10' apply false
    id 'com.google.firebase.crashlytics' version '2.9.5' apply false   

Gradle 7.4

The app was running smoothly now i suddenly started getting this error even though no changes were made

A problem occurred configuring project ':stripe_android'.

flutter_stripe: Stripe Android SDK requires com.android.application plugin lower than 8.0.0.
See #1909

We added a warning in the latest stripe android plugin that was released yesterday. Problem is that if you have a higher gradle plugin it can crash the app with issues mentioned above. We have to wait on Stripe to bump their Android dependencies in the sdk.

We added a warning in the latest stripe android plugin that was released yesterday. Problem is that if you have a higher gradle plugin it can crash the app with issues mentioned above. We have to wait on Stripe to bump their Android dependencies in the sdk.

So what would be the recommendations for
for gradel-wrapper.properties
---> distributionUrl=https://services.gradle.org/distributions/gradle-8.7-all.zip
for settings.gradle
---> id "com.android.application" version '8.5.1' apply false
----> id "org.jetbrains.kotlin.android" version "2.0.10" apply false

As i tried downgrading but i got other issues

Warning: SDK processing. This version only understands SDK XML versions up to 3 but an SDK XML file of version 4 was encountered. This can happen if you use versions of Android Studio and the command-line tools that were released at different times.
Note: Some input files use or override a deprecated API.
Note: Recompile with -Xlint:deprecation for details.
Note: Some input files use unchecked or unsafe operations.
Note: Recompile with -Xlint:unchecked for details.
ERROR:D8: com.android.tools.r8.kotlin.H

The app crashes with such gradle plugin settings

    id "dev.flutter.flutter-plugin-loader" version "1.0.0"
    id "com.android.application" version "7.1.2" apply false
    id "org.jetbrains.kotlin.android" version "1.8.0" apply false
    id 'com.google.gms.google-services' version '4.3.10' apply false
    id 'com.google.firebase.crashlytics' version '2.9.5' apply false   

Gradle 7.4

I had same problem, using latest flutter version. Now working:

Do i have to delete the android folder as i have configs for other as well

In the new version

flutter_stripe: ^11.2.0

Updateandroid/build.gradle,Downgrading the Android Gradle plugin version solved my problem

buildscript {
    dependencies {
        classpath "com.android.tools.build:gradle:7.4.2"
    }
}

Okay so tried everything

Downgrading the gradle version not compatible
Downgrading the flutter version have to re work everything for other packages
Tried to used the older stripe version not compatible

Can we get a details on when the issue will be fixed?

Downgrading gradle worked for me. In gradle-wrapper.properties i used this:

distributionUrl=https://services.gradle.org/distributions/gradle-7.6.3-all.zip

and then in the settings.gradle plugins, this:

id "com.android.application" version '7.4.2' apply false

Hello, anyone can help me because I upgrade flutter_stripe: ^11.1.0 to flutter_stripe: ^11.2.0, then for running in android I got error:

###settings.gradle:
plugins {
id "dev.flutter.flutter-plugin-loader" version "1.0.0"
id("com.android.application") version "8.3.0" apply false
id("com.android.library") version "8.3.0" apply false
id("org.jetbrains.kotlin.android") version "1.9.23" apply false
id "org.jetbrains.kotlin.jvm" version "1.9.23" apply false
id "com.google.gms.google-services" version "4.4.0" apply false
id 'org.gradle.toolchains.foojay-resolver-convention' version '0.5.0'
}

###Gradle-wrapper.properties:
distributionUrl=https://services.gradle.org/distributions/gradle-8.7-all.zip

###Error:
Running Gradle task 'assembleVibogramDebug'...
FAILURE: Build failed with an exception.

  • Where:
    Build file '/Users/*******/.pub-cache/hosted/pub.dev/stripe_android-11.2.0/android/build.gradle' line: 73
  • What went wrong:
    A problem occurred configuring project ':stripe_android'.

flutter_stripe: Stripe Android SDK requires com.android.application plugin lower than 8.0.0.

I found easy solution which is will be fix your problem with flutter_stripe: ^11.2.0

Add stripe_android: 11.0.0 inside dependency_overrides in pubspec.yaml
The problem will fix, easy peasy

dependency_overrides:
stripe_android: 11.0.0

May you need in the future:
flutter clean
flutter pub cache repair
rm -rf ~/.pub-cache
cd android
./gradlew clean
rm -rf .gradle
flutter pub get
flutter pub upgrade
flutter pub outdated
sudo gem install cocoapods
pod repo update

Enjoy

As the build error already states the single line you'll likely need to adjust is downgrading the com.android.application plugin to e.g. 7.3.0. You can find a working example here:

https://github.com/flutter-stripe/flutter_stripe/blob/main/example/android/settings.gradle#L21

Most libraries are requiring to have

Gradle 8.0
Android Gradle plugin 8.1.0
Google services Gradle plugin 4.4.1

as well as Java version at least 17 or newer, not 1.8 @ibrahimMobileArts

https://docs.gradle.org/current/userguide/compatibility.html

Can you name some that are incompatible?

I found easy solution which is will be fix your problem with flutter_stripe: ^11.2.0

Add stripe_android: 11.0.0 inside dependency_overrides in pubspec.yaml The problem will fix, easy peasy

dependency_overrides: stripe_android: 11.0.0

May you need in the future: flutter clean flutter pub cache repair rm -rf ~/.pub-cache cd android ./gradlew clean rm -rf .gradle flutter pub get flutter pub upgrade flutter pub outdated sudo gem install cocoapods pod repo update

Enjoy

@alipilot149 then you're still stuck with the issue we have here. Does your Android app crash in release mode when opening the Stripe Payment Sheet?

No, it works great

I'm glad it works for you. I tried your combination and it still crashes in release version:

E/AndroidRuntime(30561): FATAL EXCEPTION: main
E/AndroidRuntime(30561): Process: com.flutter.stripe.example, PID: 30561
E/AndroidRuntime(30561): L.l: Compose Runtime internal error. Unexpected or incorrect use of the Compose internal runtime API (pending composition has not been applied). Please report to Google or use https://goo.gle/compose-feedback

These versions for me works:

plugins {
id "dev.flutter.flutter-plugin-loader" version "1.0.0"
id("com.android.application") version "8.3.0" apply false
id("com.android.library") version "8.3.0" apply false
id("org.jetbrains.kotlin.android") version "1.9.23" apply false
id "org.jetbrains.kotlin.jvm" version "1.9.23" apply false
id "com.google.gms.google-services" version "4.4.0" apply false
id 'org.gradle.toolchains.foojay-resolver-convention' version '0.5.0'
}
and
distributionUrl=https://services.gradle.org/distributions/gradle-8.7-all.zip
and
dependencies {
def billing_version = "7.0.0"
implementation "com.android.billingclient:billing-ktx:$billing_version"
implementation(platform("com.google.firebase:firebase-bom:32.8.0"))
implementation 'com.google.firebase:firebase-messaging'
implementation 'androidx.browser:browser:1.8.0'
implementation 'androidx.multidex:multidex:2.0.1'
implementation 'com.stripe:stripe-android:20.48.0'
}

and:
dependencies:
flutter_stripe: ^11.2.0

dependency_overrides:
stripe_android: 11.0.0

I wish these info may help you to set correctly.

I just released stripe_android in version 11.2.1 that no longer errors out when com.android.application gradle plugin > 8.0.0 is used.

For anyone facing OPs issue: the only reliable way I found to still make it work when your app crashes is

        release {
            ...
            minifyEnabled false
            shrinkResources false
            ...
        }

Hello,

Is this issue resolved ?

I don't seem to face any issue in release mode, using :

  flutter_stripe: 11.2.0

  Gradle: 8.10.2

  com.android.application: 8.6.0
  org.jetbrains.kotlin.android: 2.0.20
 app/build.gradle 
        release {
            minifyEnabled true
            shrinkResources true
            [...]
        }

And without any dependency override.

I did not face the issue myself previously but came accross this issue from the README doc while upgrading my project dependencies and migrating to AGP 8+.

I was facing a big trouble for two days after I upgrade to Channel stable, 3.24.4,, it was crashing in the release mode and when I fix it , then it crashes in the debug mode , so finally I create a new project with the same name and I moved all my folder to it , and finally it works great with (distributionUrl=https://services.gradle.org/distributions/gradle-8.7-bin.zip), and every think looks great , I am using flutter_stripe 11.2.0. I hope this will be a good information.

I've tried downgrading and upgrading, but nothing seems to work in release mode . I keep getting the following error.

fluter_stripe 11.2.0
gradle 8.7.2

Caused by Ha.b: No start tag found
    at androidx.compose.ui.graphics.vector.compat.XmlVectorParser_androidKt.seekToStartTag(XmlVectorParser.android.kt:135)
    at androidx.compose.ui.res.PainterResources_androidKt.loadVectorResource(PainterResources.android.kt:93)
    at androidx.compose.ui.res.PainterResources_androidKt.painterResource(PainterResources.android.kt:65)
    at com.stripe.android.uicore.elements.TextFieldUIKt.TrailingIcon(TextFieldUI.kt:385)
    at com.stripe.android.uicore.elements.TextFieldUIKt$TextFieldUi$5$1.invoke(TextFieldUI.kt:287)
    at com.stripe.android.uicore.elements.TextFieldUIKt$TextFieldUi$5$1.invoke(TextFieldUI.kt:277)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:108)
    at androidx.compose.runtime.internal.ComposableLambdaImpl.invoke(ComposableLambda.jvm.kt:35)
    at androidx.compose.runtime.CompositionLocalKt.CompositionLocalProvider(CompositionLocal.kt:228)
    at com.stripe.android.uicore.elements.compat.CompatTextFieldKt$Decoration$colorAndEmphasis$1$1.invoke(CompatTextField.kt:348)
    at com.stripe.android.uicore.elements.compat.CompatTextFieldKt$Decoration$colorAndEmphasis$1$1.invoke(CompatTextField.kt:341)

Hi all, are there any new updates for this matter? I also have now upgraded to gradle 8.7 based upon the comments above and still crashing on release mode upon using the payment sheet using flutter_stripe 11.2.0. Are there any other current workarounds other than to set these two to false?
minifyEnabled false
shrinkResources false

I also attempted to set to dependency_overrides:
stripe_android: 11.0.0

But this still crashes.

Thank you.