Skip to content
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

Add Amazon Pay API binding #8028

Merged
merged 19 commits into from
Mar 6, 2024
Merged

Add Amazon Pay API binding #8028

merged 19 commits into from
Mar 6, 2024

Conversation

amk-stripe
Copy link
Collaborator

@amk-stripe amk-stripe commented Mar 1, 2024

Summary

Add Amazon Pay API bindings

Motivation

https://jira.corp.stripe.com/browse/MOBILESDK-1679

I set shouldRefreshIfIntentRequiresAction to true for the AmazonPay payment type. This is because we will need this set when we remove the redirect trampoline from AmazonPay and setting it now means that that change will be backwards compatible (i.e. old SDK versions will be work properly even when the redirect trampoline is removed).

Testing

  • Added tests
  • Modified tests
  • Manually verified

Also manually verified (via debugger) that we do not currently refresh even when shouldRefreshIfIntentRequiresAction=true

Screenshots

Changelog

[Added]8028 Added support for Amazon Pay to API bindings.

Copy link
Contributor

github-actions bot commented Mar 1, 2024

Diffuse output:

OLD: paymentsheet-example-release-master.apk (signature: V1, V2)
NEW: paymentsheet-example-release-pr.apk (signature: V1, V2)

          │           compressed           │         uncompressed         
          ├───────────┬───────────┬────────┼───────────┬───────────┬──────
 APK      │ old       │ new       │ diff   │ old       │ new       │ diff 
──────────┼───────────┼───────────┼────────┼───────────┼───────────┼──────
      dex │   3.9 MiB │   3.9 MiB │ +107 B │   8.6 MiB │   8.6 MiB │ +8 B 
     arsc │   2.5 MiB │   2.5 MiB │    0 B │   2.5 MiB │   2.5 MiB │  0 B 
 manifest │   5.1 KiB │   5.1 KiB │    0 B │  25.4 KiB │  25.4 KiB │  0 B 
      res │ 970.6 KiB │ 970.6 KiB │    0 B │   1.5 MiB │   1.5 MiB │  0 B 
   native │   2.6 MiB │   2.6 MiB │    0 B │     6 MiB │     6 MiB │  0 B 
    asset │     3 MiB │     3 MiB │   -2 B │     3 MiB │     3 MiB │ -2 B 
    other │ 211.5 KiB │ 211.5 KiB │   -7 B │ 472.5 KiB │ 472.5 KiB │  0 B 
──────────┼───────────┼───────────┼────────┼───────────┼───────────┼──────
    total │  13.1 MiB │  13.1 MiB │  +98 B │    22 MiB │    22 MiB │ +6 B 

 DEX     │ old   │ new   │ diff      
─────────┼───────┼───────┼───────────
   files │     1 │     1 │ 0         
 strings │ 42674 │ 42674 │ 0 (+1 -1) 
   types │ 14550 │ 14550 │ 0 (+0 -0) 
 classes │ 12296 │ 12296 │ 0 (+0 -0) 
 methods │ 60748 │ 60748 │ 0 (+0 -0) 
  fields │ 40163 │ 40163 │ 0 (+0 -0) 

 ARSC    │ old  │ new  │ diff 
─────────┼──────┼──────┼──────
 configs │  328 │  328 │  0   
 entries │ 7269 │ 7269 │  0
APK
    compressed     │   uncompressed   │                               
──────────┬────────┼───────────┬──────┤                               
 size     │ diff   │ size      │ diff │ path                          
──────────┼────────┼───────────┼──────┼───────────────────────────────
  3.9 MiB │ +107 B │   8.6 MiB │ +8 B │ ∆ classes.dex                 
 68.2 KiB │   -4 B │ 153.6 KiB │  0 B │ ∆ META-INF/CERT.SF            
  7.2 KiB │   -2 B │   7.1 KiB │ -2 B │ ∆ assets/dexopt/baseline.prof 
 54.7 KiB │   -2 B │ 153.5 KiB │  0 B │ ∆ META-INF/MANIFEST.MF        
  1.2 KiB │   -1 B │   1.2 KiB │  0 B │ ∆ META-INF/CERT.RSA           
──────────┼────────┼───────────┼──────┼───────────────────────────────
    4 MiB │  +98 B │   8.9 MiB │ +6 B │ (total)
DEX
STRINGS:

   old   │ new   │ diff      
  ───────┼───────┼───────────
   42674 │ 42674 │ 0 (+1 -1) 
  + ~~R8{backend:dex,compilation-mode:release,has-checksums:false,min-api:21,pg-map-id:17d4df2,r8-mode:full,version:8.2.47}
  
  - ~~R8{backend:dex,compilation-mode:release,has-checksums:false,min-api:21,pg-map-id:e286369,r8-mode:full,version:8.2.47}

Copy link
Collaborator Author

@amk-stripe amk-stripe Mar 1, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This activity is a more complex than necessary in that it supports selecting different payment intent types, but there's only one option (Payment) right now. This is because we'll soon be adding some other payment intent types and it will be easier to add them later on if I just keep this a little extra complicated for now.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense/be possible to refactor all of the LPMs to have a shared architecture? Obviously not on this PR, but just wondering if it's possible or makes sense.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, it would make sense and be possible. Maybe not for all of the LPMs, but for many of them.

A lot of the LPM example activities are of the form:

  • (optionally) some number of radio buttons to select which payment type to use
  • a pay button

And I think all of those activities could fairly easily use the same architecture.

Some of the LPM example activities (e.g. iDEAL) have more complex forms and I'm not sure it'd be worth the effort to generalize those ones (it seems harder and there are fewer of them, so the ROI of sharing the architecture seems lower)

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense, especially for the examples. Definitely worth keeping this idea in our back pocket.

@amk-stripe amk-stripe marked this pull request as ready for review March 2, 2024 00:16
@amk-stripe amk-stripe requested review from a team as code owners March 2, 2024 00:16
Copy link
Collaborator

@jaynewstrom-stripe jaynewstrom-stripe left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought there was also something we needed to do to remove the next actions from LUXE. (in lpms.json).

@amk-stripe amk-stripe force-pushed the amazon-pay-bindings branch from 148664a to 44d2513 Compare March 5, 2024 21:54
@amk-stripe amk-stripe enabled auto-merge (squash) March 5, 2024 22:01
@@ -1,6 +1,7 @@
# CHANGELOG

## XX.XX.XX - 2023-XX-XX
* [Added][8028](https://github.com/stripe/stripe-android/pull/8028) Added support for Amazon Pay to API bindings.
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you add this under a ### Payments header?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done -- thanks for reminding me about this!

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would it make sense/be possible to refactor all of the LPMs to have a shared architecture? Obviously not on this PR, but just wondering if it's possible or makes sense.

@amk-stripe amk-stripe force-pushed the amazon-pay-bindings branch from c77c40b to 6335519 Compare March 5, 2024 23:45
@amk-stripe amk-stripe merged commit 6a2150a into master Mar 6, 2024
15 checks passed
@amk-stripe amk-stripe deleted the amazon-pay-bindings branch March 6, 2024 00:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants