From 124eedc869dcd2519a6b100f50a1fd35a9aaa838 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Thu, 31 Oct 2024 14:48:51 -0500 Subject: [PATCH 01/22] Refactor BraintreeClient Constructors (#1199) * Refactor BraintreeClient constructors and remove BraintreeClientParams and BraintreeOptions * Fix doc typo --- .../api/core/BraintreeClient.kt | 71 +++++--------- .../api/core/BraintreeClientParams.kt | 42 -------- .../api/core/BraintreeOptions.kt | 12 --- .../api/core/BraintreeClientUnitTest.kt | 96 ++++++++----------- 4 files changed, 66 insertions(+), 155 deletions(-) delete mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClientParams.kt delete mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeOptions.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt index 4cdfc055be..6582383a53 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt @@ -4,7 +4,6 @@ import android.content.Context import android.content.pm.ActivityInfo import android.net.Uri import androidx.annotation.RestrictTo -import androidx.annotation.VisibleForTesting import com.braintreepayments.api.sharedutils.HttpResponseCallback import com.braintreepayments.api.sharedutils.HttpResponseTiming import com.braintreepayments.api.sharedutils.ManifestValidator @@ -17,7 +16,7 @@ import org.json.JSONObject */ @Suppress("LargeClass", "LongParameterList", "TooManyFunctions") @RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) -class BraintreeClient @VisibleForTesting internal constructor( +class BraintreeClient internal constructor( /** * @suppress @@ -34,41 +33,26 @@ class BraintreeClient @VisibleForTesting internal constructor( */ val authorization: Authorization, - private val analyticsClient: AnalyticsClient, - private val httpClient: BraintreeHttpClient, - private val graphQLClient: BraintreeGraphQLClient, - private val configurationLoader: ConfigurationLoader, - private val manifestValidator: ManifestValidator, - private val time: Time, private val returnUrlScheme: String, - private val braintreeDeepLinkReturnUrlScheme: String, + /** * @suppress */ val appLinkReturnUri: Uri?, + + private val analyticsClient: AnalyticsClient = AnalyticsClient(applicationContext), + private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), + private val graphQLClient: BraintreeGraphQLClient = BraintreeGraphQLClient(), + private val configurationLoader: ConfigurationLoader = ConfigurationLoader(applicationContext, httpClient), + private val manifestValidator: ManifestValidator = ManifestValidator(), + private val time: Time = Time(), ) { private val crashReporter: CrashReporter private var launchesBrowserSwitchAsNewTask: Boolean = false - // NOTE: this constructor is used to make dependency injection easy - internal constructor( - params: BraintreeClientParams, - time: Time = Time() - ) : this( - applicationContext = params.applicationContext, - integrationType = params.integrationType, - authorization = params.authorization, - analyticsClient = params.analyticsClient, - httpClient = params.httpClient, - graphQLClient = params.graphQLClient, - configurationLoader = params.configurationLoader, - manifestValidator = params.manifestValidator, - time = time, - returnUrlScheme = params.returnUrlScheme, - braintreeDeepLinkReturnUrlScheme = params.braintreeReturnUrlScheme, - appLinkReturnUri = params.appLinkReturnUri - ) + private val braintreeDeepLinkReturnUrlScheme: String = + "${getAppPackageNameWithoutUnderscores(applicationContext)}.braintree.deeplinkhandler" /** * @suppress @@ -78,27 +62,14 @@ class BraintreeClient @VisibleForTesting internal constructor( authorization: String, returnUrlScheme: String? = null, appLinkReturnUri: Uri? = null, + integrationType: IntegrationType? = null, ) : this( - BraintreeOptions( - context = context, - authorization = Authorization.fromString(authorization), - returnUrlScheme = returnUrlScheme, - appLinkReturnUri = appLinkReturnUri - ) - ) - - internal constructor(options: BraintreeOptions) : this(BraintreeClientParams(options)) - - internal constructor( - context: Context, - authorization: Authorization, - integrationType: IntegrationType - ) : this( - BraintreeOptions( - context = context, - authorization = authorization, - integrationType = integrationType, - ) + applicationContext = context.applicationContext, + authorization = Authorization.fromString(authorization), + returnUrlScheme = returnUrlScheme + ?: "${getAppPackageNameWithoutUnderscores(context.applicationContext)}.braintree", + appLinkReturnUri = appLinkReturnUri, + integrationType = integrationType ?: IntegrationType.CUSTOM, ) init { @@ -370,4 +341,10 @@ class BraintreeClient @VisibleForTesting internal constructor( val message = "Valid authorization required. See $clientSDKSetupURL for more info." return BraintreeException(message) } + + companion object { + private fun getAppPackageNameWithoutUnderscores(context: Context): String { + return context.applicationContext.packageName.replace("_", "") + } + } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClientParams.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClientParams.kt deleted file mode 100644 index c162696fc3..0000000000 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClientParams.kt +++ /dev/null @@ -1,42 +0,0 @@ -package com.braintreepayments.api.core - -import android.content.Context -import android.net.Uri -import com.braintreepayments.api.BrowserSwitchClient -import com.braintreepayments.api.sharedutils.ManifestValidator - -internal data class BraintreeClientParams( - val context: Context, - val authorization: Authorization, - val returnUrlScheme: String, - val appLinkReturnUri: Uri?, - val httpClient: BraintreeHttpClient = BraintreeHttpClient(), - val graphQLClient: BraintreeGraphQLClient = BraintreeGraphQLClient(), - val analyticsClient: AnalyticsClient = AnalyticsClient(context), - val browserSwitchClient: BrowserSwitchClient = BrowserSwitchClient(), - val manifestValidator: ManifestValidator = ManifestValidator(), - val configurationLoader: ConfigurationLoader = ConfigurationLoader(context, httpClient), - val integrationType: IntegrationType, -) { - - constructor(options: BraintreeOptions) : this( - context = options.context, - authorization = options.authorization, - returnUrlScheme = options.returnUrlScheme ?: createDefaultReturnUrlScheme(options.context), - appLinkReturnUri = options.appLinkReturnUri, - integrationType = options.integrationType ?: IntegrationType.CUSTOM - ) - - val applicationContext: Context = context.applicationContext - val braintreeReturnUrlScheme = - "${getAppPackageNameWithoutUnderscores(context)}.braintree.deeplinkhandler" - - companion object { - - private fun getAppPackageNameWithoutUnderscores(context: Context) = - context.applicationContext.packageName.replace("_", "") - - private fun createDefaultReturnUrlScheme(context: Context) = - "${getAppPackageNameWithoutUnderscores(context)}.braintree" - } -} diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeOptions.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeOptions.kt deleted file mode 100644 index d4afae4dcc..0000000000 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeOptions.kt +++ /dev/null @@ -1,12 +0,0 @@ -package com.braintreepayments.api.core - -import android.content.Context -import android.net.Uri - -internal data class BraintreeOptions( - val context: Context, - val authorization: Authorization, - val returnUrlScheme: String? = null, - val appLinkReturnUri: Uri? = null, - val integrationType: IntegrationType? = null, -) diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt index deb4689927..f906d88533 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt @@ -66,8 +66,7 @@ class BraintreeClientUnitTest { .configuration(configuration) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val callback = mockk(relaxed = true) sut.getConfiguration(callback) @@ -81,8 +80,7 @@ class BraintreeClientUnitTest { .configurationError(configFetchError) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val callback = mockk(relaxed = true) sut.getConfiguration(callback) @@ -110,8 +108,7 @@ class BraintreeClientUnitTest { .configuration(configuration) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val httpResponseCallback = mockk(relaxed = true) val networkResponseCallbackSlot = slot() @@ -135,8 +132,7 @@ class BraintreeClientUnitTest { .configurationError(configError) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val httpResponseCallback = mockk(relaxed = true) sut.sendGET("sample-url", httpResponseCallback) @@ -164,8 +160,7 @@ class BraintreeClientUnitTest { .configuration(configuration) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val networkResponseCallbackSlot = slot() val httpResponseCallback = mockk(relaxed = true) @@ -191,8 +186,7 @@ class BraintreeClientUnitTest { .configurationError(exception) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val httpResponseCallback = mockk(relaxed = true) sut.sendPOST("sample-url", "{}", emptyMap(), httpResponseCallback) @@ -204,8 +198,7 @@ class BraintreeClientUnitTest { val configurationLoader = MockkConfigurationLoaderBuilder() .configuration(mockk(relaxed = true)) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) sut.sendPOST( url = "sample-url", @@ -230,8 +223,7 @@ class BraintreeClientUnitTest { val configurationLoader = MockkConfigurationLoaderBuilder() .configuration(mockk(relaxed = true)) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val headers = mapOf("name" to "value") sut.sendPOST( @@ -273,8 +265,7 @@ class BraintreeClientUnitTest { .configuration(configuration) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val httpResponseCallback = mockk(relaxed = true) val networkResponseCallbackSlot = slot() @@ -298,8 +289,7 @@ class BraintreeClientUnitTest { .configurationError(exception) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) val httpResponseCallback = mockk(relaxed = true) sut.sendGraphQLPOST(JSONObject(), httpResponseCallback) @@ -330,8 +320,7 @@ class BraintreeClientUnitTest { val time: Time = mockk() every { time.currentTime } returns 123 - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params, time) + val sut = createBraintreeClient(configurationLoader, time) sut.sendAnalyticsEvent("event.started") verify { @@ -350,8 +339,7 @@ class BraintreeClientUnitTest { .configurationError(Exception("error")) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) sut.sendAnalyticsEvent("event.started") verify { analyticsClient wasNot Called } @@ -367,8 +355,7 @@ class BraintreeClientUnitTest { ) } returns true - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) assertTrue( sut.isUrlSchemeDeclaredInAndroidManifest("a-url-scheme", FragmentActivity::class.java) ) @@ -381,15 +368,14 @@ class BraintreeClientUnitTest { manifestValidator.getActivityInfo(applicationContext, FragmentActivity::class.java) } returns activityInfo - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) assertSame(activityInfo, sut.getManifestActivityInfo(FragmentActivity::class.java)) } @Test fun returnUrlScheme_returnsUrlSchemeBasedOnApplicationIdByDefault() { val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient(BraintreeOptions(context, authorization)) + val sut = BraintreeClient(context, authorization.toString()) assertEquals("com.braintreepayments.api.core.test.braintree", sut.getReturnUrlScheme()) } @@ -398,10 +384,9 @@ class BraintreeClientUnitTest { val context = ApplicationProvider.getApplicationContext() val returnUrlScheme = "custom-url-scheme" val sut = BraintreeClient( - BraintreeOptions( - context, authorization, returnUrlScheme = - returnUrlScheme - ) + context = context, + authorization = authorization.toString(), + returnUrlScheme = returnUrlScheme ) assertEquals("custom-url-scheme", sut.getReturnUrlScheme()) } @@ -409,7 +394,7 @@ class BraintreeClientUnitTest { @Test fun returnUrlScheme_whenDefaultDeepLinkHandlerEnabled_returnsDefaultDeepLinkHandlerScheme() { val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient(BraintreeOptions(context, authorization)) + val sut = BraintreeClient(context, authorization.toString()) sut.launchesBrowserSwitchAsNewTask(true) assertEquals( "com.braintreepayments.api.core.test.braintree.deeplinkhandler", @@ -420,14 +405,18 @@ class BraintreeClientUnitTest { @Test fun integrationType_returnsCustomByDefault() { val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient(BraintreeOptions(context, authorization)) + val sut = BraintreeClient(context, authorization.toString()) assertEquals("custom", sut.integrationType.stringValue) } @Test fun integrationType_returnsIntegrationTypeDefinedInConstructor() { val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient(context, authorization, IntegrationType.DROP_IN) + val sut = BraintreeClient( + context = context, + authorization = authorization.toString(), + integrationType = IntegrationType.DROP_IN + ) assertEquals("dropin", sut.integrationType.stringValue) } @@ -438,8 +427,7 @@ class BraintreeClientUnitTest { val configurationLoader = MockkConfigurationLoaderBuilder() .configuration(configuration) .build() - val params = createDefaultParams(configurationLoader) - val sut = BraintreeClient(params) + val sut = createBraintreeClient(configurationLoader) sut.reportCrash() val callbackSlot = slot() @@ -459,20 +447,20 @@ class BraintreeClientUnitTest { } } - private fun createDefaultParams( - configurationLoader: ConfigurationLoader - ): BraintreeClientParams = - BraintreeClientParams( - context = context, - authorization = authorization, - returnUrlScheme = "sample-return-url-scheme", - appLinkReturnUri = Uri.parse("https://example.com"), - httpClient = braintreeHttpClient, - graphQLClient = braintreeGraphQLClient, - analyticsClient = analyticsClient, - browserSwitchClient = browserSwitchClient, - manifestValidator = manifestValidator, - configurationLoader = configurationLoader, - integrationType = IntegrationType.CUSTOM - ) + private fun createBraintreeClient( + configurationLoader: ConfigurationLoader, + time: Time = Time() + ) = BraintreeClient( + applicationContext = applicationContext, + integrationType = IntegrationType.CUSTOM, + authorization = authorization, + returnUrlScheme = "sample-return-url-scheme", + appLinkReturnUri = Uri.parse("https://example.com"), + httpClient = braintreeHttpClient, + graphQLClient = braintreeGraphQLClient, + analyticsClient = analyticsClient, + manifestValidator = manifestValidator, + configurationLoader = configurationLoader, + time = time + ) } From 4d0211a990f8e16ca249cf6cd153c9e9ed77a299 Mon Sep 17 00:00:00 2001 From: warmkesselj <150195168+warmkesselj@users.noreply.github.com> Date: Mon, 4 Nov 2024 09:52:07 -0800 Subject: [PATCH 02/22] Update heroku server endpoints (#1198) --- Demo/src/main/java/com/braintreepayments/demo/Settings.java | 4 ++-- .../api/testutils/TestClientTokenBuilder.java | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/Demo/src/main/java/com/braintreepayments/demo/Settings.java b/Demo/src/main/java/com/braintreepayments/demo/Settings.java index ed7d33fc28..569a954f25 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/Settings.java +++ b/Demo/src/main/java/com/braintreepayments/demo/Settings.java @@ -14,10 +14,10 @@ public class Settings { static final String SANDBOX_ENV_NAME = "Sandbox"; static final String PRODUCTION_ENV_NAME = "Production"; - private static final String PRODUCTION_BASE_SERVER_URL = "https://executive-sample-merchant.herokuapp.com"; + private static final String PRODUCTION_BASE_SERVER_URL = "https://braintree-production-merchant-455d21469113.herokuapp.com"; private static final String PRODUCTION_TOKENIZATION_KEY = "production_t2wns2y2_dfy45jdj3dxkmz5m"; - private static final String SANDBOX_BASE_SERVER_URL = "https://braintree-sample-merchant.herokuapp.com"; + private static final String SANDBOX_BASE_SERVER_URL = "https://braintree-demo-merchant-63b7a2204f6e.herokuapp.com"; private static final String SANDBOX_TOKENIZATION_KEY = "sandbox_tmxhyf7d_dcpspy2brwdjr3qn"; static final String LOCAL_PAYMENTS_TOKENIZATION_KEY = "sandbox_f252zhq7_hh4cpc39zq4rgjcg"; diff --git a/TestUtils/src/main/java/com/braintreepayments/api/testutils/TestClientTokenBuilder.java b/TestUtils/src/main/java/com/braintreepayments/api/testutils/TestClientTokenBuilder.java index f48a9376ad..f433af7cc2 100644 --- a/TestUtils/src/main/java/com/braintreepayments/api/testutils/TestClientTokenBuilder.java +++ b/TestUtils/src/main/java/com/braintreepayments/api/testutils/TestClientTokenBuilder.java @@ -54,9 +54,9 @@ private String fetchClientToken() { URL url; if (withCustomerId) { - url = new URL("https://braintree-sample-merchant.herokuapp.com/client_token?customer_id=" + UUID.randomUUID().toString()); + url = new URL("https://braintree-demo-merchant-63b7a2204f6e.herokuapp.com/client_token?customer_id=" + UUID.randomUUID().toString()); } else { - url = new URL("https://braintree-sample-merchant.herokuapp.com/client_token"); + url = new URL("https://braintree-demo-merchant-63b7a2204f6e.herokuapp.com/client_token"); } HttpURLConnection connection = (HttpURLConnection) url.openConnection(); From ed091367fb2a417423e3ee683b2635d983c00ee7 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Tue, 5 Nov 2024 12:49:15 -0600 Subject: [PATCH 03/22] Add MerchantRepository for holding BraintreeClient properties (#1202) * Move properties from BraintreeClient to MerchantRepository * Add kdocs for MerchantRepository --- .../api/core/BraintreeClient.kt | 71 ++- .../api/core/MerchantRepository.kt | 26 + .../api/core/BraintreeClientUnitTest.kt | 47 +- .../api/googlepay/GooglePayClient.kt | 14 +- .../googlepay/GooglePayClientUnitTest.java | 281 +++++++-- .../api/localpayment/LocalPaymentApi.kt | 6 +- .../localpayment/LocalPaymentApiUnitTest.java | 142 ++--- .../LocalPaymentClientUnitTest.java | 5 - .../api/paypal/PayPalClient.kt | 4 +- .../api/paypal/PayPalInternalClient.kt | 14 +- .../api/paypal/PayPalClientUnitTest.java | 117 ++-- .../paypal/PayPalInternalClientUnitTest.java | 540 ++++++++++++------ .../shopperinsights/ShopperInsightsClient.kt | 4 +- .../ShopperInsightsClientUnitTest.kt | 21 +- .../testutils/MockBraintreeClientBuilder.java | 22 - .../api/threedsecure/ThreeDSecureClient.kt | 6 +- .../ThreeDSecureClientUnitTest.java | 236 +++++--- .../braintreepayments/api/venmo/VenmoApi.kt | 6 +- .../api/venmo/VenmoClient.kt | 14 +- .../api/venmo/VenmoApiUnitTest.java | 30 +- .../api/venmo/VenmoClientUnitTest.java | 307 +++++++--- 21 files changed, 1241 insertions(+), 672 deletions(-) create mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt index 6582383a53..cb3a5529a8 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt @@ -17,35 +17,18 @@ import org.json.JSONObject @Suppress("LargeClass", "LongParameterList", "TooManyFunctions") @RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) class BraintreeClient internal constructor( - - /** - * @suppress - */ - val applicationContext: Context, - - /** - * @suppress - */ - val integrationType: IntegrationType, - - /** - * @suppress - */ - val authorization: Authorization, - - private val returnUrlScheme: String, - - /** - * @suppress - */ - val appLinkReturnUri: Uri?, - + applicationContext: Context, + integrationType: IntegrationType, + authorization: Authorization, + returnUrlScheme: String, + appLinkReturnUri: Uri?, private val analyticsClient: AnalyticsClient = AnalyticsClient(applicationContext), private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), private val graphQLClient: BraintreeGraphQLClient = BraintreeGraphQLClient(), private val configurationLoader: ConfigurationLoader = ConfigurationLoader(applicationContext, httpClient), private val manifestValidator: ManifestValidator = ManifestValidator(), private val time: Time = Time(), + private val merchantRepository: MerchantRepository = MerchantRepository.instance ) { private val crashReporter: CrashReporter @@ -80,6 +63,16 @@ class BraintreeClient internal constructor( // statistics access via the sdk console crashReporter = CrashReporter(this) crashReporter.start() + + merchantRepository.let { + it.applicationContext = applicationContext + it.integrationType = integrationType + it.authorization = authorization + it.returnUrlScheme = returnUrlScheme + if (appLinkReturnUri != null) { + it.appLinkReturnUri = appLinkReturnUri + } + } } /** @@ -88,11 +81,11 @@ class BraintreeClient internal constructor( * @param callback [ConfigurationCallback] */ fun getConfiguration(callback: ConfigurationCallback) { - if (authorization is InvalidAuthorization) { + if (merchantRepository.authorization is InvalidAuthorization) { callback.onResult(null, createAuthError()) return } - configurationLoader.loadConfiguration(authorization) { configuration, configError, timing -> + configurationLoader.loadConfiguration(merchantRepository.authorization) { configuration, configError, timing -> if (configuration != null) { callback.onResult(configuration, null) } else { @@ -123,7 +116,7 @@ class BraintreeClient internal constructor( experiment = params.experiment, paymentMethodsDisplayed = params.paymentMethodsDisplayed ) - sendAnalyticsEvent(event, configuration, authorization) + sendAnalyticsEvent(event, configuration, merchantRepository.authorization) } } @@ -136,7 +129,7 @@ class BraintreeClient internal constructor( analyticsClient.sendEvent( it, event, - integrationType, + merchantRepository.integrationType, authorization ) } @@ -146,13 +139,13 @@ class BraintreeClient internal constructor( * @suppress */ fun sendGET(url: String, responseCallback: HttpResponseCallback) { - if (authorization is InvalidAuthorization) { + if (merchantRepository.authorization is InvalidAuthorization) { responseCallback.onResult(null, createAuthError()) return } getConfiguration { configuration, configError -> if (configuration != null) { - httpClient.get(url, configuration, authorization) { response, httpError -> + httpClient.get(url, configuration, merchantRepository.authorization) { response, httpError -> response?.let { try { sendAnalyticsTimingEvent(url, response.timing) @@ -180,7 +173,7 @@ class BraintreeClient internal constructor( additionalHeaders: Map = emptyMap(), responseCallback: HttpResponseCallback, ) { - if (authorization is InvalidAuthorization) { + if (merchantRepository.authorization is InvalidAuthorization) { responseCallback.onResult(null, createAuthError()) return } @@ -190,7 +183,7 @@ class BraintreeClient internal constructor( path = url, data = data, configuration = configuration, - authorization = authorization, + authorization = merchantRepository.authorization, additionalHeaders = additionalHeaders ) { response, httpError -> response?.let { @@ -214,7 +207,7 @@ class BraintreeClient internal constructor( * @suppress */ fun sendGraphQLPOST(json: JSONObject?, responseCallback: HttpResponseCallback) { - if (authorization is InvalidAuthorization) { + if (merchantRepository.authorization is InvalidAuthorization) { responseCallback.onResult(null, createAuthError()) return } @@ -223,7 +216,7 @@ class BraintreeClient internal constructor( graphQLClient.post( json?.toString(), configuration, - authorization + merchantRepository.authorization ) { response, httpError -> response?.let { try { @@ -262,7 +255,7 @@ class BraintreeClient internal constructor( return if (launchesBrowserSwitchAsNewTask) { braintreeDeepLinkReturnUrlScheme } else { - returnUrlScheme + merchantRepository.returnUrlScheme } } @@ -271,7 +264,7 @@ class BraintreeClient internal constructor( */ fun isUrlSchemeDeclaredInAndroidManifest(urlScheme: String?, klass: Class?): Boolean { return manifestValidator.isUrlSchemeDeclaredInAndroidManifest( - applicationContext, + merchantRepository.applicationContext, urlScheme, klass ) @@ -281,7 +274,7 @@ class BraintreeClient internal constructor( * @suppress */ fun getManifestActivityInfo(klass: Class?): ActivityInfo? { - return manifestValidator.getActivityInfo(applicationContext, klass) + return manifestValidator.getActivityInfo(merchantRepository.applicationContext, klass) } /** @@ -290,10 +283,10 @@ class BraintreeClient internal constructor( internal fun reportCrash() = getConfiguration { configuration, _ -> analyticsClient.reportCrash( - applicationContext, + merchantRepository.applicationContext, configuration, - integrationType, - authorization + merchantRepository.integrationType, + merchantRepository.authorization ) } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt new file mode 100644 index 0000000000..d8ad972c5c --- /dev/null +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt @@ -0,0 +1,26 @@ +package com.braintreepayments.api.core + +import android.content.Context +import android.net.Uri +import androidx.annotation.RestrictTo + +/** + * An internal repository that holds properties set by the integrating merchant. + */ +@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) +class MerchantRepository { + + lateinit var applicationContext: Context + lateinit var integrationType: IntegrationType + lateinit var authorization: Authorization + lateinit var returnUrlScheme: String + var appLinkReturnUri: Uri? = null + + companion object { + + /** + * Singleton instance of the MerchantRepository. + */ + val instance: MerchantRepository by lazy { MerchantRepository() } + } +} diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt index f906d88533..e8709acd07 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt @@ -34,6 +34,7 @@ class BraintreeClientUnitTest { private lateinit var manifestValidator: ManifestValidator private lateinit var browserSwitchClient: BrowserSwitchClient private lateinit var expectedAuthException: BraintreeException + private lateinit var merchantRepository: MerchantRepository @Before fun beforeEach() { @@ -48,6 +49,7 @@ class BraintreeClientUnitTest { analyticsClient = mockk(relaxed = true) manifestValidator = mockk(relaxed = true) browserSwitchClient = mockk(relaxed = true) + merchantRepository = mockk(relaxed = true) val clientSDKSetupURL = "https://developer.paypal.com/braintree/docs/guides/client-sdk/setup/android/v4#initialization" @@ -402,24 +404,6 @@ class BraintreeClientUnitTest { ) } - @Test - fun integrationType_returnsCustomByDefault() { - val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient(context, authorization.toString()) - assertEquals("custom", sut.integrationType.stringValue) - } - - @Test - fun integrationType_returnsIntegrationTypeDefinedInConstructor() { - val context = ApplicationProvider.getApplicationContext() - val sut = BraintreeClient( - context = context, - authorization = authorization.toString(), - integrationType = IntegrationType.DROP_IN - ) - assertEquals("dropin", sut.integrationType.stringValue) - } - @Test @Throws(JSONException::class) fun reportCrash_reportsCrashViaAnalyticsClient() { @@ -447,20 +431,39 @@ class BraintreeClientUnitTest { } } + @Test + fun `when BraintreeClient is initialized, merchantRepository properties are set`() { + createBraintreeClient(merchantRepository = merchantRepository) + verify { merchantRepository.returnUrlScheme = "sample-return-url-scheme" } + verify { merchantRepository.applicationContext = applicationContext } + verify { merchantRepository.authorization = authorization } + verify { merchantRepository.appLinkReturnUri = Uri.parse("https://example.com") } + verify { merchantRepository.integrationType = IntegrationType.CUSTOM } + } + + @Test + fun `when BraintreeClient is initialized and appLinkReturnUri is null, it is not set on the MerchantRepository`() { + createBraintreeClient(appLinkReturnUri = null, merchantRepository = merchantRepository) + verify(exactly = 0) { merchantRepository.appLinkReturnUri = null } + } + private fun createBraintreeClient( - configurationLoader: ConfigurationLoader, - time: Time = Time() + configurationLoader: ConfigurationLoader = mockk(), + time: Time = Time(), + appLinkReturnUri: Uri? = Uri.parse("https://example.com"), + merchantRepository: MerchantRepository = MerchantRepository.instance ) = BraintreeClient( applicationContext = applicationContext, integrationType = IntegrationType.CUSTOM, authorization = authorization, returnUrlScheme = "sample-return-url-scheme", - appLinkReturnUri = Uri.parse("https://example.com"), + appLinkReturnUri = appLinkReturnUri, httpClient = braintreeHttpClient, graphQLClient = braintreeGraphQLClient, analyticsClient = analyticsClient, manifestValidator = manifestValidator, configurationLoader = configurationLoader, - time = time + time = time, + merchantRepository = merchantRepository, ) } diff --git a/GooglePay/src/main/java/com/braintreepayments/api/googlepay/GooglePayClient.kt b/GooglePay/src/main/java/com/braintreepayments/api/googlepay/GooglePayClient.kt index 7d36e53d10..ec99a7f1b0 100644 --- a/GooglePay/src/main/java/com/braintreepayments/api/googlepay/GooglePayClient.kt +++ b/GooglePay/src/main/java/com/braintreepayments/api/googlepay/GooglePayClient.kt @@ -9,6 +9,7 @@ import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.Configuration import com.braintreepayments.api.core.ErrorWithResponse.Companion.fromJson +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.MetadataBuilder import com.braintreepayments.api.core.TokenizationKey import com.braintreepayments.api.core.UserCanceledException @@ -31,7 +32,8 @@ import org.json.JSONObject class GooglePayClient internal constructor( private val braintreeClient: BraintreeClient, private val internalGooglePayClient: GooglePayInternalClient = GooglePayInternalClient(), - private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance + private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { /** * Initializes a new [GooglePayClient] instance @@ -154,7 +156,7 @@ class GooglePayClient internal constructor( if (configuration != null) { callback.onTokenizationParametersResult( GooglePayTokenizationParameters.Success( - getTokenizationParameters(configuration, braintreeClient.authorization), + getTokenizationParameters(configuration, merchantRepository.authorization), getAllowedCardNetworks(configuration) ) ) @@ -201,7 +203,7 @@ class GooglePayClient internal constructor( braintreeClient.getConfiguration { configuration: Configuration?, configError: Exception? -> if (configuration?.isGooglePayEnabled == true) { - setGooglePayRequestDefaults(configuration, braintreeClient.authorization, request) + setGooglePayRequestDefaults(configuration, merchantRepository.authorization, request) val paymentDataRequest = PaymentDataRequest.fromJson(request.toJson()) @@ -315,7 +317,7 @@ class GooglePayClient internal constructor( ): PaymentMethodTokenizationParameters { val metadata = - MetadataBuilder().integration(braintreeClient.integrationType) + MetadataBuilder().integration(merchantRepository.integrationType) .sessionId(analyticsParamRepository.sessionId).version().build() val version = try { @@ -467,7 +469,7 @@ class GooglePayClient internal constructor( .put("braintree:merchantId", configuration.merchantId) .put( "braintree:metadata", JSONObject().put("source", "client") - .put("integration", braintreeClient.integrationType) + .put("integration", merchantRepository.integrationType) .put("sessionId", analyticsParamRepository.sessionId) .put("version", googlePayVersion) .put("platform", "android").toString() @@ -507,7 +509,7 @@ class GooglePayClient internal constructor( ) .put( "braintree:metadata", JSONObject().put("source", "client") - .put("integration", braintreeClient.integrationType) + .put("integration", merchantRepository.integrationType) .put("sessionId", analyticsParamRepository.sessionId) .put("version", googlePayVersion) .put("platform", "android").toString() diff --git a/GooglePay/src/test/java/com/braintreepayments/api/googlepay/GooglePayClientUnitTest.java b/GooglePay/src/test/java/com/braintreepayments/api/googlepay/GooglePayClientUnitTest.java index 5be5268685..23dd571dd3 100644 --- a/GooglePay/src/test/java/com/braintreepayments/api/googlepay/GooglePayClientUnitTest.java +++ b/GooglePay/src/test/java/com/braintreepayments/api/googlepay/GooglePayClientUnitTest.java @@ -23,6 +23,7 @@ import com.braintreepayments.api.core.BraintreeClient; import com.braintreepayments.api.core.BraintreeException; import com.braintreepayments.api.core.Configuration; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; import com.braintreepayments.api.paypal.PayPalAccountNonce; @@ -63,6 +64,8 @@ public class GooglePayClientUnitTest { private AnalyticsParamRepository analyticsParamRepository; + private MerchantRepository merchantRepository = mock(MerchantRepository.class); + @Before public void beforeEach() { activity = mock(FragmentActivity.class); @@ -93,7 +96,12 @@ public void isReadyToPay_sendsReadyToPayRequest() throws JSONException { GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.isReadyToPay(activity, null, readyToPayCallback); ArgumentCaptor captor = @@ -125,7 +133,12 @@ public void isReadyToPay_whenExistingPaymentMethodRequired_sendsIsReadyToPayRequ GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.isReadyToPay(activity, readyForGooglePayRequest, readyToPayCallback); ArgumentCaptor captor = @@ -147,15 +160,21 @@ public void isReadyToPay_returnsFalseWhenGooglePayIsNotEnabled() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString(Fixtures.TOKENIZATION_KEY)) .activityInfo(activityInfo) .build(); + + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.TOKENIZATION_KEY)); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder() .isReadyToPay(true) .build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.isReadyToPay(activity, null, readyToPayCallback); verify(readyToPayCallback).onGooglePayReadinessResult(any(GooglePayReadinessResult.NotReadyToPay.class)); @@ -174,15 +193,21 @@ public void createPaymentAuthRequest_resetsSessionId() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString(Fixtures.TOKENIZATION_KEY)) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.TOKENIZATION_KEY)); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder() .isReadyToPay(true) .build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(mock(), mock()); @@ -203,10 +228,11 @@ public void createPaymentAuthRequest_callsBackIntentData() throws JSONException BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = new GooglePayRequest("USD", "1.00", GooglePayTotalPriceStatus.TOTAL_PRICE_STATUS_FINAL); googlePayRequest.setAllowPrepaidCards(true); googlePayRequest.setBillingAddressFormat(GooglePayBillingAddressFormat.FULL); @@ -219,7 +245,12 @@ public void createPaymentAuthRequest_callsBackIntentData() throws JSONException GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(googlePayRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -329,16 +360,22 @@ public void createPaymentAuthRequest_includesATokenizationKeyWhenPresent() throw BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString(Fixtures.TOKENIZATION_KEY)) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.TOKENIZATION_KEY)); + GooglePayRequest googlePayRequest = new GooglePayRequest("USD", "1.00", GooglePayTotalPriceStatus.TOTAL_PRICE_STATUS_FINAL); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(googlePayRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -375,16 +412,22 @@ public void createPaymentAuthRequest_doesNotIncludeATokenizationKeyWhenNotPresen BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)); + GooglePayRequest googlePayRequest = new GooglePayRequest("USD", "1.00", GooglePayTotalPriceStatus.TOTAL_PRICE_STATUS_FINAL); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(googlePayRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -421,16 +464,22 @@ public void createPaymentAuthRequest_sendsAnalyticsEvent() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = new GooglePayRequest("USD", "1.00", GooglePayTotalPriceStatus.TOTAL_PRICE_STATUS_FINAL); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(googlePayRequest, intentDataCallback); InOrder order = inOrder(braintreeClient); @@ -443,15 +492,21 @@ public void createPaymentAuthRequest_whenMerchantNotConfigured_returnsExceptionT Configuration configuration = new TestConfigurationBuilder().buildConfiguration(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(configuration) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -483,14 +538,20 @@ public void createPaymentAuthRequest_whenSandbox_setsTestEnvironment() throws JS BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -522,14 +583,20 @@ public void createPaymentAuthRequest_whenProduction_setsProductionEnvironment() BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -562,16 +629,22 @@ public void createPaymentAuthRequest_withGoogleMerchantName_sendGoogleMerchantNa BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + baseRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -605,17 +678,23 @@ public void createPaymentAuthRequest_whenGooglePayCanProcessPayPal_tokenizationP BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -653,10 +732,11 @@ public void createPaymentAuthRequest_whenPayPalDisabledByRequest_tokenizationPro BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); googlePayRequest.setPayPalEnabled(false); @@ -664,7 +744,12 @@ public void createPaymentAuthRequest_whenPayPalDisabledByRequest_tokenizationPro GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -703,17 +788,23 @@ public void createPaymentAuthRequest_whenPayPalDisabledInConfigurationAndGoogleP BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -753,17 +844,23 @@ public void createPaymentAuthRequest_usesGooglePayConfigurationClientId() throws BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -810,17 +907,23 @@ public void createPaymentAuthRequest_whenGooglePayConfigurationLacksClientId_tok BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -859,17 +962,23 @@ public void createPaymentAuthRequest_whenConfigurationContainsElo_addsEloAndEloD BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayRequest googlePayRequest = baseRequest; googlePayRequest.setGoogleMerchantName("google-merchant-name-override"); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -908,14 +1017,20 @@ public void createPaymentAuthRequest_whenManifestInvalid_forwardsExceptionToList BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(null) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(baseRequest, intentDataCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( @@ -952,16 +1067,22 @@ public void tokenize_withCardToken_returnsGooglePayNonce() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + PaymentData pd = PaymentData.fromJson(paymentDataJson); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(pd, activityResultCallback); ArgumentCaptor captor = @@ -990,16 +1111,22 @@ public void tokenize_withPayPalToken_returnsPayPalAccountNonce() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + PaymentData pd = PaymentData.fromJson(paymentDataJson); GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(pd, activityResultCallback); ArgumentCaptor captor = @@ -1022,7 +1149,12 @@ public void tokenize_whenPaymentDataExists_returnsResultToListener_andSendsAnaly GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); String paymentDataJson = Fixtures.RESPONSE_GOOGLE_PAY_CARD; PaymentData paymentData = PaymentData.fromJson(paymentDataJson); @@ -1049,7 +1181,12 @@ public void tokenize_whenErrorExists_returnsErrorToListener_andSendsAnalytics() GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); Exception error = new Exception("Error"); GooglePayPaymentAuthResult @@ -1072,7 +1209,12 @@ public void tokenize_whenUserCanceledErrorExists_returnsErrorToListener_andSends GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); UserCanceledException userCanceledError = new UserCanceledException("User canceled Google Pay."); @@ -1102,14 +1244,20 @@ public void getAllowedCardNetworks_returnsSupportedNetworks() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString("sandbox_tokenization_string")) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString("sandbox_tokenization_string")); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); Collection allowedCardNetworks = sut.getAllowedCardNetworks(configuration); @@ -1136,13 +1284,19 @@ public void getTokenizationParameters_returnsCorrectParameters() { Authorization authorization = Authorization.fromString(Fixtures.TOKENIZATION_KEY); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(authorization) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(authorization); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); Bundle tokenizationParameters = sut.getTokenizationParameters(configuration, authorization).getParameters(); @@ -1169,13 +1323,19 @@ public void getTokenizationParameters_doesNotIncludeATokenizationKeyWhenNotPrese Authorization authorization = Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(authorization) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(authorization); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); Bundle tokenizationParameters = sut.getTokenizationParameters(configuration, authorization).getParameters(); @@ -1194,13 +1354,18 @@ public void getTokenizationParameters_includesATokenizationKeyWhenPresent() { Authorization authorization = Authorization.fromString(Fixtures.TOKENIZATION_KEY); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(authorization) .activityInfo(activityInfo) .build(); - GooglePayInternalClient internalGooglePayClient = - new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + when(merchantRepository.getAuthorization()).thenReturn(authorization); + + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); Bundle tokenizationParameters = sut.getTokenizationParameters(configuration, authorization).getParameters(); @@ -1219,13 +1384,19 @@ public void getTokenizationParameters_forwardsParametersAndAllowedCardsToCallbac BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(Authorization.fromString(Fixtures.TOKENIZATION_KEY)) .activityInfo(activityInfo) .build(); + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.TOKENIZATION_KEY)); + GooglePayInternalClient internalGooglePayClient = new MockGooglePayInternalClientBuilder().build(); - GooglePayClient sut = new GooglePayClient(braintreeClient, internalGooglePayClient, analyticsParamRepository); + GooglePayClient sut = new GooglePayClient( + braintreeClient, + internalGooglePayClient, + analyticsParamRepository, + merchantRepository + ); sut.getTokenizationParameters(tokenizationParameters -> { assertTrue(tokenizationParameters instanceof GooglePayTokenizationParameters.Success); diff --git a/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentApi.kt b/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentApi.kt index 6ceb0f2198..e3444afa46 100644 --- a/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentApi.kt +++ b/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentApi.kt @@ -2,13 +2,15 @@ package com.braintreepayments.api.localpayment import com.braintreepayments.api.core.AnalyticsParamRepository import com.braintreepayments.api.core.BraintreeClient +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.localpayment.LocalPaymentNonce.Companion.fromJSON import org.json.JSONException import org.json.JSONObject internal class LocalPaymentApi( private val braintreeClient: BraintreeClient, - private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance + private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { fun createPaymentMethod( @@ -66,7 +68,7 @@ internal class LocalPaymentApi( val metaData = JSONObject() .put("source", "client") - .put("integration", braintreeClient.integrationType.stringValue) + .put("integration", merchantRepository.integrationType.stringValue) .put("sessionId", analyticsParamRepository.sessionId) payload.put("_meta", metaData) diff --git a/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentApiUnitTest.java b/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentApiUnitTest.java index 297f3e631a..e076511105 100644 --- a/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentApiUnitTest.java +++ b/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentApiUnitTest.java @@ -18,6 +18,7 @@ import com.braintreepayments.api.core.AnalyticsParamRepository; import com.braintreepayments.api.core.BraintreeClient; import com.braintreepayments.api.core.IntegrationType; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.core.PostalAddress; import com.braintreepayments.api.sharedutils.HttpResponseCallback; import com.braintreepayments.api.testutils.Fixtures; @@ -39,35 +40,37 @@ public class LocalPaymentApiUnitTest { private LocalPaymentInternalTokenizeCallback localPaymentInternalTokenizeCallback; private AnalyticsParamRepository analyticsParamRepository; + private MerchantRepository merchantRepository = mock(MerchantRepository.class); @Before public void beforeEach() { analyticsParamRepository = mock(AnalyticsParamRepository.class); localPaymentInternalAuthRequestCallback = - mock(LocalPaymentInternalAuthRequestCallback.class); + mock(LocalPaymentInternalAuthRequestCallback.class); localPaymentInternalTokenizeCallback = - mock(LocalPaymentInternalTokenizeCallback.class); + mock(LocalPaymentInternalTokenizeCallback.class); when(analyticsParamRepository.getSessionId()).thenReturn("sample-session-id"); + when(merchantRepository.getIntegrationType()).thenReturn(IntegrationType.CUSTOM); } @Test public void createPaymentMethod_sendsCorrectPostParams() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .returnUrlScheme("sample-scheme") - .build(); + .returnUrlScheme("sample-scheme") + .build(); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); sut.createPaymentMethod( - getIdealLocalPaymentRequest(), - localPaymentInternalAuthRequestCallback + getIdealLocalPaymentRequest(), + localPaymentInternalAuthRequestCallback ); String expectedPath = "/v1/local_payments/create"; ArgumentCaptor bodyCaptor = ArgumentCaptor.forClass(String.class); verify(braintreeClient).sendPOST( - eq(expectedPath), bodyCaptor.capture(), anyMap(), - any(HttpResponseCallback.class)); + eq(expectedPath), bodyCaptor.capture(), anyMap(), + any(HttpResponseCallback.class)); String requestBody = bodyCaptor.getValue(); JSONObject json = new JSONObject(requestBody); @@ -88,8 +91,8 @@ public void createPaymentMethod_sendsCorrectPostParams() throws JSONException { assertEquals("local-merchant-account-id", json.getString("merchantAccountId")); assertTrue(json.getJSONObject("experienceProfile").getBoolean("noShipping")); assertEquals( - "My Brand!", - json.getJSONObject("experienceProfile").getString("brandName") + "My Brand!", + json.getJSONObject("experienceProfile").getString("brandName") ); String expectedCancelUrl = Uri.parse("sample-scheme://local-payment-cancel").toString(); String expectedReturnUrl = Uri.parse("sample-scheme://local-payment-success").toString(); @@ -101,18 +104,19 @@ public void createPaymentMethod_sendsCorrectPostParams() throws JSONException { public void createPaymentMethod_onPOSTError_forwardsErrorToCallback() { Exception error = new Exception("error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .sendPOSTErrorResponse(error) - .build(); + .sendPOSTErrorResponse(error) + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); sut.createPaymentMethod( - getIdealLocalPaymentRequest(), - localPaymentInternalAuthRequestCallback + getIdealLocalPaymentRequest(), + localPaymentInternalAuthRequestCallback ); verify(localPaymentInternalAuthRequestCallback).onLocalPaymentInternalAuthResult( - isNull(), - same(error) + isNull(), + same(error) ); } @@ -120,19 +124,20 @@ public void createPaymentMethod_onPOSTError_forwardsErrorToCallback() { @Test public void createPaymentMethod_onJSONError_forwardsJSONErrorToCallback() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .sendPOSTSuccessfulResponse(Fixtures.ERROR_RESPONSE) - .build(); + .sendPOSTSuccessfulResponse(Fixtures.ERROR_RESPONSE) + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); sut.createPaymentMethod( - getIdealLocalPaymentRequest(), - localPaymentInternalAuthRequestCallback + getIdealLocalPaymentRequest(), + localPaymentInternalAuthRequestCallback ); ArgumentCaptor captor = ArgumentCaptor.forClass(Exception.class); verify(localPaymentInternalAuthRequestCallback).onLocalPaymentInternalAuthResult( - isNull(), - captor.capture() + isNull(), + captor.capture() ); assertTrue(captor.getValue() instanceof JSONException); @@ -141,26 +146,27 @@ public void createPaymentMethod_onJSONError_forwardsJSONErrorToCallback() { @Test public void createPaymentMethod_onPOSTSuccess_returnsResultWithOriginalRequestToCallback() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .sendPOSTSuccessfulResponse(Fixtures.PAYMENT_METHODS_LOCAL_PAYMENT_CREATE_RESPONSE) - .build(); + .sendPOSTSuccessfulResponse(Fixtures.PAYMENT_METHODS_LOCAL_PAYMENT_CREATE_RESPONSE) + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); LocalPaymentRequest request = getIdealLocalPaymentRequest(); sut.createPaymentMethod(request, localPaymentInternalAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(LocalPaymentAuthRequestParams.class); + ArgumentCaptor.forClass(LocalPaymentAuthRequestParams.class); verify(localPaymentInternalAuthRequestCallback).onLocalPaymentInternalAuthResult( - captor.capture(), - isNull() + captor.capture(), + isNull() ); LocalPaymentAuthRequestParams result = captor.getValue(); assertNotNull(result); assertSame(request, result.getRequest()); assertEquals( - "https://checkout.paypal.com/latinum?token=payment-token", - result.getApprovalUrl() + "https://checkout.paypal.com/latinum?token=payment-token", + result.getApprovalUrl() ); assertEquals("local-payment-id-123", result.getPaymentId()); } @@ -168,39 +174,39 @@ public void createPaymentMethod_onPOSTSuccess_returnsResultWithOriginalRequestTo @Test public void tokenize_sendsCorrectPostParams() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .integration(IntegrationType.CUSTOM) - .build(); + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); String webUrl = "sample-scheme://local-payment-success?paymentToken=successTokenId"; sut.tokenize( - "local-merchant-account-id", webUrl, "sample-correlation-id", - localPaymentInternalTokenizeCallback + "local-merchant-account-id", webUrl, "sample-correlation-id", + localPaymentInternalTokenizeCallback ); ArgumentCaptor bodyCaptor = ArgumentCaptor.forClass(String.class); String expectedUrl = "/v1/payment_methods/paypal_accounts"; verify(braintreeClient).sendPOST( - eq(expectedUrl), bodyCaptor.capture(),anyMap(), - any(HttpResponseCallback.class)); + eq(expectedUrl), bodyCaptor.capture(), anyMap(), + any(HttpResponseCallback.class)); String requestBody = bodyCaptor.getValue(); JSONObject expectedJSON = new JSONObject(); expectedJSON.put("merchant_account_id", "local-merchant-account-id"); JSONObject paypalAccount = new JSONObject() - .put("intent", "sale") - .put("response", new JSONObject().put("webURL", webUrl)) - .put("options", new JSONObject().put("validate", false)) - .put("response_type", "web") - .put("correlation_id", "sample-correlation-id"); + .put("intent", "sale") + .put("response", new JSONObject().put("webURL", webUrl)) + .put("options", new JSONObject().put("validate", false)) + .put("response_type", "web") + .put("correlation_id", "sample-correlation-id"); expectedJSON.put("paypal_account", paypalAccount); JSONObject metaData = new JSONObject() - .put("source", "client") - .put("integration", "custom") - .put("sessionId", "sample-session-id"); + .put("source", "client") + .put("integration", "custom") + .put("sessionId", "sample-session-id"); expectedJSON.put("_meta", metaData); JSONAssert.assertEquals(expectedJSON, new JSONObject(requestBody), true); @@ -210,15 +216,15 @@ public void tokenize_sendsCorrectPostParams() throws JSONException { public void tokenize_onPOSTError_forwardsErrorToCallback() { Exception error = new Exception("error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .integration(IntegrationType.CUSTOM) - .sendPOSTErrorResponse(error) - .build(); + .sendPOSTErrorResponse(error) + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); String webUrl = "sample-scheme://local-payment-success?paymentToken=successTokenId"; sut.tokenize( - "local-merchant-account-id", webUrl, "sample-correlation-id", - localPaymentInternalTokenizeCallback + "local-merchant-account-id", webUrl, "sample-correlation-id", + localPaymentInternalTokenizeCallback ); verify(localPaymentInternalTokenizeCallback).onResult(isNull(), same(error)); @@ -227,15 +233,15 @@ public void tokenize_onPOSTError_forwardsErrorToCallback() { @Test public void tokenize_onJSONError_forwardsErrorToCallback() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .integration(IntegrationType.CUSTOM) - .sendPOSTSuccessfulResponse("not-json") - .build(); + .sendPOSTSuccessfulResponse("not-json") + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); String webUrl = "sample-scheme://local-payment-success?paymentToken=successTokenId"; sut.tokenize( - "local-merchant-account-id", webUrl, "sample-correlation-id", - localPaymentInternalTokenizeCallback + "local-merchant-account-id", webUrl, "sample-correlation-id", + localPaymentInternalTokenizeCallback ); ArgumentCaptor captor = ArgumentCaptor.forClass(Exception.class); @@ -247,21 +253,21 @@ public void tokenize_onJSONError_forwardsErrorToCallback() { @Test public void tokenize_onPOSTSuccess_returnsResultToCallback() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .integration(IntegrationType.CUSTOM) - .sendPOSTSuccessfulResponse(Fixtures.PAYMENT_METHODS_LOCAL_PAYMENT_RESPONSE) - .build(); + .sendPOSTSuccessfulResponse(Fixtures.PAYMENT_METHODS_LOCAL_PAYMENT_RESPONSE) + .build(); + + LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository, merchantRepository); - LocalPaymentApi sut = new LocalPaymentApi(braintreeClient, analyticsParamRepository); String webUrl = "sample-scheme://local-payment-success?paymentToken=successTokenId"; sut.tokenize( - "local-merchant-account-id", webUrl, "sample-correlation-id", - localPaymentInternalTokenizeCallback + "local-merchant-account-id", webUrl, "sample-correlation-id", + localPaymentInternalTokenizeCallback ); ArgumentCaptor captor = ArgumentCaptor.forClass(LocalPaymentNonce.class); verify(localPaymentInternalTokenizeCallback).onResult( - captor.capture(), - (Exception) isNull() + captor.capture(), + (Exception) isNull() ); LocalPaymentNonce result = captor.getValue(); diff --git a/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentClientUnitTest.java b/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentClientUnitTest.java index 8ca95359fd..22f8b84217 100644 --- a/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentClientUnitTest.java +++ b/LocalPayment/src/test/java/com/braintreepayments/api/localpayment/LocalPaymentClientUnitTest.java @@ -476,7 +476,6 @@ public void tokenize_whenPostFailure_notifiesCallbackOfErrorAlongWithAnalyticsEv BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(payPalEnabledConfig) .sendPOSTErrorResponse(postError) - .integration(IntegrationType.CUSTOM) .build(); LocalPaymentApi localPaymentApi = new MockLocalPaymentApiBuilder() @@ -522,7 +521,6 @@ public void tokenize_whenResultOKAndSuccessful_tokenizesWithLocalPaymentApi() BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(payPalEnabledConfig) - .integration(IntegrationType.CUSTOM) .build(); when(dataCollector.getClientMetadataId(activity, payPalEnabledConfig, false)).thenReturn( "sample-correlation-id"); @@ -553,7 +551,6 @@ public void tokenize_whenResultOKAndTokenizationSucceeds_sendsResultToCallback() BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(payPalEnabledConfig) - .integration(IntegrationType.CUSTOM) .build(); when(dataCollector.getClientMetadataId(any(Context.class), same(payPalEnabledConfig), eq(false))).thenReturn("client-metadata-id"); @@ -635,7 +632,6 @@ public void tokenize_whenResultOK_onConfigurationError_returnsError() Exception configError = new Exception("config error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configurationError(configError) - .integration(IntegrationType.CUSTOM) .build(); when(dataCollector.getClientMetadataId(activity, payPalEnabledConfig, true)).thenReturn( "sample-correlation-id"); @@ -702,7 +698,6 @@ public void onBrowserSwitchResult_sends_the_correct_value_of_hasUserLocationCons when(browserSwitchResult.getReturnUrl()).thenReturn(Uri.parse(webUrl)); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(payPalEnabledConfig) - .integration(IntegrationType.CUSTOM) .build(); when(dataCollector.getClientMetadataId(any(Context.class), same(payPalEnabledConfig), anyBoolean())).thenReturn("client-metadata-id"); diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt index 21181f35fa..ccdfbd46ad 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt @@ -10,6 +10,7 @@ import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.BraintreeRequestCodes import com.braintreepayments.api.core.Configuration import com.braintreepayments.api.core.LinkType +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.UserCanceledException import com.braintreepayments.api.paypal.PayPalPaymentIntent.Companion.fromString import com.braintreepayments.api.sharedutils.Json @@ -22,6 +23,7 @@ import org.json.JSONObject class PayPalClient internal constructor( private val braintreeClient: BraintreeClient, private val internalPayPalClient: PayPalInternalClient = PayPalInternalClient(braintreeClient), + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { /** @@ -150,7 +152,7 @@ class PayPalClient internal constructor( return BrowserSwitchOptions() .requestCode(BraintreeRequestCodes.PAYPAL.code) - .appLinkUri(braintreeClient.appLinkReturnUri) + .appLinkUri(merchantRepository.appLinkReturnUri) .url(Uri.parse(paymentAuthRequest.approvalUrl)) .launchAsNewTask(braintreeClient.launchesBrowserSwitchAsNewTask()) .metadata(metadata) diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt index 55601fceff..cfb9427d40 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt @@ -7,6 +7,7 @@ import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.Configuration import com.braintreepayments.api.core.DeviceInspector +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.datacollector.DataCollector import com.braintreepayments.api.datacollector.DataCollectorInternalRequest import com.braintreepayments.api.paypal.PayPalPaymentResource.Companion.fromJson @@ -17,11 +18,12 @@ internal class PayPalInternalClient( private val braintreeClient: BraintreeClient, private val dataCollector: DataCollector = DataCollector(braintreeClient), private val apiClient: ApiClient = ApiClient(braintreeClient), - private val deviceInspector: DeviceInspector = DeviceInspector() + private val deviceInspector: DeviceInspector = DeviceInspector(), + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { - private val cancelUrl = "${braintreeClient.appLinkReturnUri}://onetouch/v1/cancel" - private val successUrl = "${braintreeClient.appLinkReturnUri}://onetouch/v1/success" - private val appLink = braintreeClient.appLinkReturnUri?.toString() + private val cancelUrl = "${merchantRepository.appLinkReturnUri}://onetouch/v1/cancel" + private val successUrl = "${merchantRepository.appLinkReturnUri}://onetouch/v1/success" + private val appLink = merchantRepository.appLinkReturnUri?.toString() fun sendRequest( context: Context, @@ -50,7 +52,7 @@ internal class PayPalInternalClient( val requestBody = payPalRequest.createRequestBody( configuration = configuration, - authorization = braintreeClient.authorization, + authorization = merchantRepository.authorization, successUrl = successUrl, cancelUrl = cancelUrl, appLink = appLinkReturn @@ -155,7 +157,7 @@ internal class PayPalInternalClient( fun isAppSwitchEnabled(payPalRequest: PayPalRequest): Boolean { return (payPalRequest is PayPalVaultRequest) && - payPalRequest.enablePayPalAppSwitch + payPalRequest.enablePayPalAppSwitch } fun isPayPalInstalled(context: Context): Boolean { diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java index de3084e69b..ea68b5b6ed 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java @@ -19,6 +19,7 @@ import com.braintreepayments.api.core.BraintreeClient; import com.braintreepayments.api.core.BraintreeRequestCodes; import com.braintreepayments.api.core.Configuration; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; @@ -41,6 +42,8 @@ public class PayPalClientUnitTest { private PayPalTokenizeCallback payPalTokenizeCallback; private PayPalPaymentAuthCallback paymentAuthCallback; + private MerchantRepository merchantRepository; + @Before public void beforeEach() throws JSONException { activity = mock(FragmentActivity.class); @@ -50,6 +53,8 @@ public void beforeEach() throws JSONException { payPalTokenizeCallback = mock(PayPalTokenizeCallback.class); paymentAuthCallback = mock(PayPalPaymentAuthCallback.class); + + merchantRepository = mock(MerchantRepository.class); } @Test @@ -72,7 +77,7 @@ public void createPaymentAuthRequest_callsBackPayPalResponse_sendsStartedAnalyti BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -126,7 +131,7 @@ public void createPaymentAuthRequest_whenLaunchesBrowserSwitchAsNewTaskEnabled_s new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) .launchesBrowserSwitchAsNewTask(true).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -156,12 +161,12 @@ public void createPaymentAuthRequest_setsAppLinkReturnUrl() { new MockPayPalInternalClientBuilder().sendRequestSuccess(paymentAuthRequest) .build(); - BraintreeClient braintreeClient = - new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) - .appLinkReturnUri(Uri.parse("www.example.com")) - .build(); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("www.example.com")); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) + .build(); + + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -170,7 +175,7 @@ public void createPaymentAuthRequest_setsAppLinkReturnUrl() { PayPalPaymentAuthRequest request = captor.getValue(); assertTrue(request instanceof PayPalPaymentAuthRequest.ReadyToLaunch); - assertEquals(braintreeClient.getAppLinkReturnUri(), + assertEquals(merchantRepository.getAppLinkReturnUri(), ((PayPalPaymentAuthRequest.ReadyToLaunch) request).getRequestParams().getBrowserSwitchOptions().getAppLinkUri()); } @@ -181,7 +186,7 @@ public void createPaymentAuthRequest_whenPayPalNotEnabled_returnsError() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalDisabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, new PayPalCheckoutRequest("1.00", true), paymentAuthCallback); @@ -210,7 +215,7 @@ public void createPaymentAuthRequest_whenCheckoutRequest_whenConfigError_forward .configurationError(authError) .build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, new PayPalCheckoutRequest("1.00", true), paymentAuthCallback); ArgumentCaptor captor = @@ -235,7 +240,7 @@ public void requestBillingAgreement_whenConfigError_forwardsErrorToListener() { .configurationError(authError) .build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, new PayPalVaultRequest(true), paymentAuthCallback); ArgumentCaptor captor = @@ -261,7 +266,7 @@ public void createPaymentAuthRequest_whenVaultRequest_sendsPayPalRequestViaInter PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalRequest, paymentAuthCallback); verify(payPalInternalClient).sendRequest(same(activity), same(payPalRequest), @@ -277,7 +282,7 @@ public void createPaymentAuthRequest_whenCheckoutRequest_sendsPayPalRequestViaIn PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalRequest, paymentAuthCallback); verify(payPalInternalClient).sendRequest(same(activity), same(payPalRequest), @@ -292,34 +297,34 @@ public void createPaymentAuthRequest_whenVaultRequest_sendsAppSwitchStartedEvent payPalVaultRequest.setMerchantAccountId("sample-merchant-account-id"); PayPalPaymentAuthRequestParams paymentAuthRequest = new PayPalPaymentAuthRequestParams( - payPalVaultRequest, - null, - "https://example.com/approval/url", - "sample-client-metadata-id", - null, - "https://example.com/success/url" + payPalVaultRequest, + null, + "https://example.com/approval/url", + "sample-client-metadata-id", + null, + "https://example.com/success/url" ); PayPalInternalClient payPalInternalClient = - new MockPayPalInternalClientBuilder().sendRequestSuccess(paymentAuthRequest) - .build(); + new MockPayPalInternalClientBuilder().sendRequestSuccess(paymentAuthRequest) + .build(); when(payPalInternalClient.isPayPalInstalled(activity)).thenReturn(true); when(payPalInternalClient.isAppSwitchEnabled(payPalVaultRequest)).thenReturn(true); BraintreeClient braintreeClient = - new MockBraintreeClientBuilder().configuration(payPalEnabledConfig).build(); + new MockBraintreeClientBuilder().configuration(payPalEnabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(PayPalPaymentAuthRequest.class); + ArgumentCaptor.forClass(PayPalPaymentAuthRequest.class); verify(paymentAuthCallback).onPayPalPaymentAuthRequest(captor.capture()); PayPalPaymentAuthRequest request = captor.getValue(); assertTrue(request instanceof PayPalPaymentAuthRequest.ReadyToLaunch); PayPalPaymentAuthRequestParams paymentAuthRequestCaptured = - ((PayPalPaymentAuthRequest.ReadyToLaunch) request).getRequestParams(); + ((PayPalPaymentAuthRequest.ReadyToLaunch) request).getRequestParams(); BrowserSwitchOptions browserSwitchOptions = paymentAuthRequestCaptured.getBrowserSwitchOptions(); assertEquals(BraintreeRequestCodes.PAYPAL.getCode(), browserSwitchOptions.getRequestCode()); @@ -354,7 +359,7 @@ public void tokenize_withBillingAgreement_tokenizesResponseOnSuccess() throws JS PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -396,9 +401,9 @@ public void tokenize_withOneTimePayment_tokenizesResponseOnSuccess() throws JSON when(browserSwitchResult.getReturnUrl()).thenReturn(uri); PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( - browserSwitchResult); + browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -443,7 +448,7 @@ public void tokenize_whenCancelUriReceived_notifiesCancellationAndSendsAnalytics PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -481,9 +486,9 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_callsBackResult() when(browserSwitchResult.getReturnUrl()).thenReturn(uri); PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( - browserSwitchResult); + browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -502,30 +507,30 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_callsBackResult() @Test public void tokenize_whenPayPalInternalClientTokenizeResult_sendsAppSwitchSucceededEvents() - throws JSONException { + throws JSONException { PayPalAccountNonce payPalAccountNonce = mock(PayPalAccountNonce.class); PayPalInternalClient payPalInternalClient = - new MockPayPalInternalClientBuilder().tokenizeSuccess(payPalAccountNonce).build(); + new MockPayPalInternalClientBuilder().tokenizeSuccess(payPalAccountNonce).build(); String approvalUrl = - "sample-scheme://onetouch/v1/success?PayerID=HERMES-SANDBOX-PAYER-ID&paymentId=HERMES-SANDBOX-PAYMENT-ID&token=EC-HERMES-SANDBOX-EC-TOKEN&switch_initiated_time=17166111926211"; + "sample-scheme://onetouch/v1/success?PayerID=HERMES-SANDBOX-PAYER-ID&paymentId=HERMES-SANDBOX-PAYMENT-ID&token=EC-HERMES-SANDBOX-EC-TOKEN&switch_initiated_time=17166111926211"; BrowserSwitchFinalResult.Success browserSwitchResult = mock(BrowserSwitchFinalResult.Success.class); when(browserSwitchResult.getRequestMetadata()).thenReturn( - new JSONObject().put("client-metadata-id", "sample-client-metadata-id") - .put("merchant-account-id", "sample-merchant-account-id") - .put("intent", "authorize").put("approval-url", approvalUrl) - .put("success-url", "https://example.com/success") - .put("payment-type", "single-payment")); + new JSONObject().put("client-metadata-id", "sample-client-metadata-id") + .put("merchant-account-id", "sample-merchant-account-id") + .put("intent", "authorize").put("approval-url", approvalUrl) + .put("success-url", "https://example.com/success") + .put("payment-type", "single-payment")); Uri uri = Uri.parse(approvalUrl); when(browserSwitchResult.getReturnUrl()).thenReturn(uri); PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( - browserSwitchResult); + browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -552,19 +557,19 @@ public void tokenize_whenPayPalNotEnabled_sendsAppSwitchFailedEvents() throws JS BrowserSwitchFinalResult.Success browserSwitchResult = mock(BrowserSwitchFinalResult.Success.class); when(browserSwitchResult.getRequestMetadata()).thenReturn( - new JSONObject().put("client-metadata-id", "sample-client-metadata-id") - .put("merchant-account-id", "sample-merchant-account-id") - .put("intent", "authorize").put("approval-url", "https://some-scheme/onetouch/v1/cancel?token=SOME-BA&switch_initiated_time=17166111926211") - .put("success-url", "https://example.com/cancel") - .put("payment-type", "single-payment")); + new JSONObject().put("client-metadata-id", "sample-client-metadata-id") + .put("merchant-account-id", "sample-merchant-account-id") + .put("intent", "authorize").put("approval-url", "https://some-scheme/onetouch/v1/cancel?token=SOME-BA&switch_initiated_time=17166111926211") + .put("success-url", "https://example.com/cancel") + .put("payment-type", "single-payment")); Uri uri = Uri.parse(approvalUrl); when(browserSwitchResult.getReturnUrl()).thenReturn(uri); PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( - browserSwitchResult); + browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -576,7 +581,7 @@ public void tokenize_whenPayPalNotEnabled_sendsAppSwitchFailedEvents() throws JS @Test public void tokenize_whenCancelUriReceived_sendsAppSwitchCanceledEvents() - throws JSONException { + throws JSONException { PayPalInternalClient payPalInternalClient = new MockPayPalInternalClientBuilder().build(); String approvalUrl = "https://some-scheme/onetouch/v1/cancel?switch_initiated_time=17166111926211"; @@ -584,19 +589,19 @@ public void tokenize_whenCancelUriReceived_sendsAppSwitchCanceledEvents() BrowserSwitchFinalResult.Success browserSwitchResult = mock(BrowserSwitchFinalResult.Success.class); when(browserSwitchResult.getRequestMetadata()).thenReturn( - new JSONObject().put("client-metadata-id", "sample-client-metadata-id") - .put("merchant-account-id", "sample-merchant-account-id") - .put("intent", "authorize").put("approval-url", approvalUrl) - .put("success-url", "https://example.com/success") - .put("payment-type", "single-payment")); + new JSONObject().put("client-metadata-id", "sample-client-metadata-id") + .put("merchant-account-id", "sample-merchant-account-id") + .put("intent", "authorize").put("approval-url", approvalUrl) + .put("success-url", "https://example.com/success") + .put("payment-type", "single-payment")); Uri uri = Uri.parse(approvalUrl); when(browserSwitchResult.getReturnUrl()).thenReturn(uri); PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( - browserSwitchResult); + browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java index 8a4214ced1..d743584131 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java @@ -23,6 +23,7 @@ import com.braintreepayments.api.core.ClientToken; import com.braintreepayments.api.core.Configuration; import com.braintreepayments.api.core.DeviceInspector; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.core.PostalAddress; import com.braintreepayments.api.core.TokenizationKey; import com.braintreepayments.api.core.TokenizeCallback; @@ -61,6 +62,8 @@ public class PayPalInternalClientUnitTest { PayPalInternalClientCallback payPalInternalClientCallback; + private MerchantRepository merchantRepository = mock(MerchantRepository.class); + @Before public void beforeEach() throws JSONException { context = mock(Context.class); @@ -77,13 +80,20 @@ public void beforeEach() throws JSONException { @Test public void sendRequest_withPayPalVaultRequest_sendsAllParameters() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .appLinkReturnUri(Uri.parse("https://example.com")) - .build(); + .configuration(configuration) + .build(); when(clientToken.getBearer()).thenReturn("client-token-bearer"); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PostalAddress shippingAddressOverride = new PostalAddress(); shippingAddressOverride.setRecipientName("Brianna Tree"); @@ -119,26 +129,26 @@ public void sendRequest_withPayPalVaultRequest_sendsAllParameters() throws JSONE JSONObject actual = new JSONObject(result); JSONObject expected = new JSONObject() - .put("authorization_fingerprint", "client-token-bearer") - .put("return_url", "https://example.com://onetouch/v1/success") - .put("cancel_url", "https://example.com://onetouch/v1/cancel") - .put("offer_paypal_credit", true) - .put("description", "Billing Agreement Description") - .put("experience_profile", new JSONObject() - .put("no_shipping", false) - .put("landing_page_type", "billing") - .put("brand_name", "sample-display-name") - .put("locale_code", "US") - .put("address_override", false)) - .put("shipping_address", new JSONObject() - .put("line1", "123 Fake St.") - .put("line2", "Apt. v.0") - .put("city", "Oakland") - .put("state", "CA") - .put("postal_code", "12345") - .put("country_code", "US") - .put("recipient_name", "Brianna Tree")) - .put("merchant_account_id", "sample-merchant-account-id"); + .put("authorization_fingerprint", "client-token-bearer") + .put("return_url", "https://example.com://onetouch/v1/success") + .put("cancel_url", "https://example.com://onetouch/v1/cancel") + .put("offer_paypal_credit", true) + .put("description", "Billing Agreement Description") + .put("experience_profile", new JSONObject() + .put("no_shipping", false) + .put("landing_page_type", "billing") + .put("brand_name", "sample-display-name") + .put("locale_code", "US") + .put("address_override", false)) + .put("shipping_address", new JSONObject() + .put("line1", "123 Fake St.") + .put("line2", "Apt. v.0") + .put("city", "Oakland") + .put("state", "CA") + .put("postal_code", "12345") + .put("country_code", "US") + .put("recipient_name", "Brianna Tree")) + .put("merchant_account_id", "sample-merchant-account-id"); JSONAssert.assertEquals(expected, actual, true); } @@ -146,14 +156,20 @@ public void sendRequest_withPayPalVaultRequest_sendsAllParameters() throws JSONE @Test public void sendRequest_withPayPalCheckoutRequest_sendsAllParameters() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .appLinkReturnUri(Uri.parse("https://example.com")) - .build(); + .configuration(configuration) + .build(); when(clientToken.getBearer()).thenReturn("client-token-bearer"); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PostalAddress shippingAddressOverride = new PostalAddress(); shippingAddressOverride.setRecipientName("Brianna Tree"); shippingAddressOverride.setStreetAddress("123 Fake St."); @@ -202,40 +218,40 @@ public void sendRequest_withPayPalCheckoutRequest_sendsAllParameters() throws JS JSONObject actual = new JSONObject(result); JSONObject expected = new JSONObject() - .put("amount", "1.00") - .put("currency_iso_code", "USD") - .put("intent", "authorize") - .put("authorization_fingerprint", "client-token-bearer") - .put("return_url", "https://example.com://onetouch/v1/success") - .put("cancel_url", "https://example.com://onetouch/v1/cancel") - .put("offer_pay_later", true) - .put("request_billing_agreement", true) - .put("billing_agreement_details", new JSONObject() - .put("description", "Billing Agreement Description")) - .put("line_items", new JSONArray() - .put(new JSONObject() - .put("kind", "debit") - .put("name", "Item 0") - .put("quantity", "1") - .put("unit_amount", "2") - .put("description", "A new item") - .put("product_code", "abc-123") - .put("unit_tax_amount", "1.50") - .put("url", "http://example.com"))) - .put("experience_profile", new JSONObject() - .put("no_shipping", false) - .put("landing_page_type", "login") - .put("brand_name", "sample-display-name") - .put("locale_code", "US") - .put("address_override", false)) - .put("line1", "123 Fake St.") - .put("line2", "Apt. v.0") - .put("city", "Oakland") - .put("state", "CA") - .put("postal_code", "12345") - .put("country_code", "US") - .put("recipient_name", "Brianna Tree") - .put("merchant_account_id", "sample-merchant-account-id"); + .put("amount", "1.00") + .put("currency_iso_code", "USD") + .put("intent", "authorize") + .put("authorization_fingerprint", "client-token-bearer") + .put("return_url", "https://example.com://onetouch/v1/success") + .put("cancel_url", "https://example.com://onetouch/v1/cancel") + .put("offer_pay_later", true) + .put("request_billing_agreement", true) + .put("billing_agreement_details", new JSONObject() + .put("description", "Billing Agreement Description")) + .put("line_items", new JSONArray() + .put(new JSONObject() + .put("kind", "debit") + .put("name", "Item 0") + .put("quantity", "1") + .put("unit_amount", "2") + .put("description", "A new item") + .put("product_code", "abc-123") + .put("unit_tax_amount", "1.50") + .put("url", "http://example.com"))) + .put("experience_profile", new JSONObject() + .put("no_shipping", false) + .put("landing_page_type", "login") + .put("brand_name", "sample-display-name") + .put("locale_code", "US") + .put("address_override", false)) + .put("line1", "123 Fake St.") + .put("line2", "Apt. v.0") + .put("city", "Oakland") + .put("state", "CA") + .put("postal_code", "12345") + .put("country_code", "US") + .put("recipient_name", "Brianna Tree") + .put("merchant_account_id", "sample-merchant-account-id"); JSONAssert.assertEquals(expected, actual, true); } @@ -243,12 +259,18 @@ public void sendRequest_withPayPalCheckoutRequest_sendsAllParameters() throws JS @Test public void sendRequest_withTokenizationKey_sendsClientKeyParam() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); when(tokenizationKey.getBearer()).thenReturn("tokenization-key-bearer"); - - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); @@ -270,13 +292,20 @@ public void sendRequest_withTokenizationKey_sendsClientKeyParam() throws JSONExc @Test public void sendRequest_withEmptyDisplayName_fallsBackToPayPalConfigurationDisplayName() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(false); payPalRequest.setDisplayName(""); @@ -294,17 +323,24 @@ public void sendRequest_withEmptyDisplayName_fallsBackToPayPalConfigurationDispl JSONObject actual = new JSONObject(result); assertEquals("paypal_merchant", - ((JSONObject) actual.get("experience_profile")).get("brand_name")); + ((JSONObject) actual.get("experience_profile")).get("brand_name")); } @Test public void sendRequest_withLocaleNotSpecified_omitsLocale() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setLocaleCode(null); @@ -326,13 +362,20 @@ public void sendRequest_withLocaleNotSpecified_omitsLocale() throws JSONExceptio @Test public void sendRequest_withMerchantAccountIdNotSpecified_omitsMerchantAccountId() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setMerchantAccountId(null); @@ -354,13 +397,20 @@ public void sendRequest_withMerchantAccountIdNotSpecified_omitsMerchantAccountId @Test public void sendRequest_withShippingAddressOverrideNotSpecified_sendsAddressOverrideFalse() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setShippingAddressOverride(null); @@ -378,19 +428,25 @@ public void sendRequest_withShippingAddressOverrideNotSpecified_sendsAddressOver JSONObject actual = new JSONObject(result); assertEquals(false, - ((JSONObject) actual.get("experience_profile")).get("address_override")); + ((JSONObject) actual.get("experience_profile")).get("address_override")); } @Test public void sendRequest_withShippingAddressSpecified_sendsAddressOverrideBasedOnShippingAdressEditability() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .build(); + .configuration(configuration) + .build(); when(clientToken.getBearer()).thenReturn("client-token-bearer"); - - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setShippingAddressEditable(false); @@ -414,13 +470,20 @@ public void sendRequest_withShippingAddressSpecified_sendsAddressOverrideBasedOn @Test public void sendRequest_withPayPalVaultRequest_omitsEmptyBillingAgreementDescription() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setBillingAgreementDescription(""); @@ -442,13 +505,20 @@ public void sendRequest_withPayPalVaultRequest_omitsEmptyBillingAgreementDescrip @Test public void sendRequest_withPayPalCheckoutRequest_fallsBackToPayPalConfigurationCurrencyCode() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(Configuration.fromJson(Fixtures.CONFIGURATION_WITH_LIVE_PAYPAL_INR)) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(Configuration.fromJson(Fixtures.CONFIGURATION_WITH_LIVE_PAYPAL_INR)) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); @@ -470,11 +540,18 @@ public void sendRequest_withPayPalCheckoutRequest_fallsBackToPayPalConfiguration @Test public void sendRequest_withPayPalCheckoutRequest_omitsEmptyLineItems() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); payPalRequest.setLineItems(new ArrayList()); @@ -499,12 +576,19 @@ public void sendRequest_whenRiskCorrelationIdNotNull_setsClientMetadataIdToRiskC when(dataCollector.getClientMetadataId(same(context), any(), same(configuration))).thenReturn("sample-client-metadata-id"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); payPalRequest.setRiskCorrelationId("risk-correlation-id"); @@ -512,7 +596,7 @@ public void sendRequest_whenRiskCorrelationIdNotNull_setsClientMetadataIdToRiskC sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), isNull()); PayPalPaymentAuthRequestParams payPalPaymentAuthRequestParams = captor.getValue(); @@ -524,19 +608,26 @@ public void sendRequest_whenRiskCorrelationIdNull_setsClientMetadataIdFromPayPal when(dataCollector.getClientMetadataId(same(context), any(), any())).thenReturn("sample-client-metadata-id"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), (Exception) isNull()); PayPalPaymentAuthRequestParams payPalPaymentAuthRequestParams = captor.getValue(); @@ -546,13 +637,20 @@ public void sendRequest_whenRiskCorrelationIdNull_setsClientMetadataIdFromPayPal @Test public void sendRequest_withPayPalCheckoutRequest_whenRequestBillingAgreementFalse_andBillingAgreementDescriptionSet_doesNotSettBillingAgreementDescription() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(tokenizationKey) - .build(); + .configuration(configuration) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); payPalRequest.setShouldRequestBillingAgreement(false); @@ -579,13 +677,20 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess( when(dataCollector.getClientMetadataId(context, configuration, true)).thenReturn("sample-client-metadata-id"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .appLinkReturnUri(Uri.parse("https://example.com")) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_BA_TOKEN_PARAM) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_BA_TOKEN_PARAM) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setMerchantAccountId("sample-merchant-account-id"); @@ -594,11 +699,11 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess( sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), (Exception) isNull()); String expectedUrl = - "https://checkout.paypal.com/one-touch-login-sandbox/index.html?ba_token=fake-ba-token&action=create_payment_resource&amount=1.00&authorization_fingerprint=63cc461306c35080ce674a3372bffe1580b4130c7fd33d33968aa76bb93cdd06%7Ccreated_at%3D2015-10-13T18%3A49%3A48.371382792%2B0000%26merchant_id%3Ddcpspy2brwdjr3qn%26public_key%3D9wwrzqk3vr3t4nc8&cancel_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fcancel&controller=client_api%2Fpaypal_hermes¤cy_iso_code=USD&experience_profile%5Baddress_override%5D=false&experience_profile%5Bno_shipping%5D=false&merchant_id=dcpspy2brwdjr3qn&return_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fsuccess&offer_paypal_credit=true&version=1"; + "https://checkout.paypal.com/one-touch-login-sandbox/index.html?ba_token=fake-ba-token&action=create_payment_resource&amount=1.00&authorization_fingerprint=63cc461306c35080ce674a3372bffe1580b4130c7fd33d33968aa76bb93cdd06%7Ccreated_at%3D2015-10-13T18%3A49%3A48.371382792%2B0000%26merchant_id%3Ddcpspy2brwdjr3qn%26public_key%3D9wwrzqk3vr3t4nc8&cancel_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fcancel&controller=client_api%2Fpaypal_hermes¤cy_iso_code=USD&experience_profile%5Baddress_override%5D=false&experience_profile%5Bno_shipping%5D=false&merchant_id=dcpspy2brwdjr3qn&return_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fsuccess&offer_paypal_credit=true&version=1"; PayPalPaymentAuthRequestParams payPalPaymentAuthRequestParams = captor.getValue(); assertTrue(payPalPaymentAuthRequestParams.isBillingAgreement()); assertEquals("sample-merchant-account-id", payPalPaymentAuthRequestParams.getMerchantAccountId()); @@ -611,13 +716,20 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess( @Test public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_returnsPayPalURL() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .appLinkReturnUri(Uri.parse("https://example.com")) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_PAYPAL_REDIRECT_URL) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_PAYPAL_REDIRECT_URL) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); payPalRequest.setUserAuthenticationEmail("example@mail.com"); @@ -628,7 +740,7 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_ sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), (Exception) isNull()); PayPalPaymentAuthRequestParams payPalPaymentAuthRequestParams = captor.getValue(); @@ -646,20 +758,27 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_ @Test public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_returnsApprovalURL() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .appLinkReturnUri(Uri.parse("https://example.com")) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_APPROVAL_URL) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_APPROVAL_URL) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), (Exception) isNull()); String expectedUrl = "https://www.example.com/some?ba_token=fake-ba-token"; @@ -674,13 +793,20 @@ public void sendRequest_withPayPalCheckoutRequest_callsBackPayPalResponseOnSucce when(dataCollector.getClientMetadataId(context, configuration, true)).thenReturn("sample-client-metadata-id"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_TOKEN_PARAM) - .appLinkReturnUri(Uri.parse("https://example.com")) - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE_WITH_TOKEN_PARAM) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); payPalRequest.setIntent(PayPalPaymentIntent.AUTHORIZE); @@ -691,11 +817,11 @@ public void sendRequest_withPayPalCheckoutRequest_callsBackPayPalResponseOnSucce sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); ArgumentCaptor captor = ArgumentCaptor.forClass( - PayPalPaymentAuthRequestParams.class); + PayPalPaymentAuthRequestParams.class); verify(payPalInternalClientCallback).onResult(captor.capture(), (Exception) isNull()); String expectedUrl = - "https://checkout.paypal.com/one-touch-login-sandbox/index.html?token=fake-token&action=create_payment_resource&amount=1.00&authorization_fingerprint=63cc461306c35080ce674a3372bffe1580b4130c7fd33d33968aa76bb93cdd06%7Ccreated_at%3D2015-10-13T18%3A49%3A48.371382792%2B0000%26merchant_id%3Ddcpspy2brwdjr3qn%26public_key%3D9wwrzqk3vr3t4nc8&cancel_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fcancel&controller=client_api%2Fpaypal_hermes¤cy_iso_code=USD&experience_profile%5Baddress_override%5D=false&experience_profile%5Bno_shipping%5D=false&merchant_id=dcpspy2brwdjr3qn&return_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fsuccess&offer_paypal_credit=true&version=1"; + "https://checkout.paypal.com/one-touch-login-sandbox/index.html?token=fake-token&action=create_payment_resource&amount=1.00&authorization_fingerprint=63cc461306c35080ce674a3372bffe1580b4130c7fd33d33968aa76bb93cdd06%7Ccreated_at%3D2015-10-13T18%3A49%3A48.371382792%2B0000%26merchant_id%3Ddcpspy2brwdjr3qn%26public_key%3D9wwrzqk3vr3t4nc8&cancel_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fcancel&controller=client_api%2Fpaypal_hermes¤cy_iso_code=USD&experience_profile%5Baddress_override%5D=false&experience_profile%5Bno_shipping%5D=false&merchant_id=dcpspy2brwdjr3qn&return_url=com.braintreepayments.api.test.braintree%3A%2F%2Fonetouch%2Fv1%2Fsuccess&offer_paypal_credit=true&version=1"; PayPalPaymentAuthRequestParams payPalPaymentAuthRequestParams = captor.getValue(); assertFalse(payPalPaymentAuthRequestParams.isBillingAgreement()); assertEquals(PayPalPaymentIntent.AUTHORIZE, payPalPaymentAuthRequestParams.getIntent()); @@ -710,12 +836,19 @@ public void sendRequest_withPayPalCheckoutRequest_callsBackPayPalResponseOnSucce public void sendRequest_propagatesHttpErrors() { Exception httpError = new Exception("http error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .sendPOSTErrorResponse(httpError) - .build(); + .configuration(configuration) + .sendPOSTErrorResponse(httpError) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); @@ -726,29 +859,43 @@ public void sendRequest_propagatesHttpErrors() { @Test public void sendRequest_propagatesMalformedJSONResponseErrors() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(configuration) - .authorizationSuccess(clientToken) - .sendPOSTSuccessfulResponse("{bad:") - .build(); + .configuration(configuration) + .sendPOSTSuccessfulResponse("{bad:") + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); verify(payPalInternalClientCallback).onResult((PayPalPaymentAuthRequestParams) isNull(), - any(JSONException.class)); + any(JSONException.class)); } @Test public void sendRequest_onConfigurationFailure_forwardsError() { Exception configurationError = new Exception("configuration error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) - .configurationError(configurationError) - .build(); + .configurationError(configurationError) + .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); @@ -762,7 +909,13 @@ public void tokenize_tokenizesWithApiClient() { PayPalAccount payPalAccount = mock(PayPalAccount.class); PayPalInternalTokenizeCallback callback = mock(PayPalInternalTokenizeCallback.class); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); sut.tokenize(payPalAccount, callback); @@ -773,22 +926,28 @@ public void tokenize_tokenizesWithApiClient() { public void tokenize_onTokenizeResult_returnsAccountNonceToCallback() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); ApiClient apiClient = new MockApiClientBuilder() - .tokenizeRESTSuccess( - new JSONObject(Fixtures.PAYMENT_METHODS_PAYPAL_ACCOUNT_RESPONSE)) - .build(); + .tokenizeRESTSuccess( + new JSONObject(Fixtures.PAYMENT_METHODS_PAYPAL_ACCOUNT_RESPONSE)) + .build(); PayPalAccount payPalAccount = mock(PayPalAccount.class); PayPalInternalTokenizeCallback callback = mock(PayPalInternalTokenizeCallback.class); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); sut.tokenize(payPalAccount, callback); ArgumentCaptor captor = - ArgumentCaptor.forClass(PayPalAccountNonce.class); + ArgumentCaptor.forClass(PayPalAccountNonce.class); verify(callback).onResult(captor.capture(), (Exception) isNull()); PayPalAccountNonce expectedNonce = PayPalAccountNonce.fromJSON( - new JSONObject(Fixtures.PAYMENT_METHODS_PAYPAL_ACCOUNT_RESPONSE)); + new JSONObject(Fixtures.PAYMENT_METHODS_PAYPAL_ACCOUNT_RESPONSE)); PayPalAccountNonce result = captor.getValue(); assertEquals(expectedNonce.getString(), result.getString()); } @@ -798,12 +957,18 @@ public void tokenize_onTokenizeError_returnsErrorToCallback() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); Exception error = new Exception("error"); ApiClient apiClient = new MockApiClientBuilder() - .tokenizeRESTError(error) - .build(); + .tokenizeRESTError(error) + .build(); PayPalAccount payPalAccount = mock(PayPalAccount.class); PayPalInternalTokenizeCallback callback = mock(PayPalInternalTokenizeCallback.class); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); sut.tokenize(payPalAccount, callback); @@ -815,12 +980,19 @@ public void payPalDataCollector_passes_correct_arguments_to_getClientMetadataId( Configuration configuration = Configuration.fromJson(Fixtures.CONFIGURATION_WITH_LIVE_PAYPAL); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(configuration) - .authorizationSuccess(clientToken) .returnUrlScheme("sample-scheme") .sendPOSTSuccessfulResponse(Fixtures.PAYPAL_HERMES_RESPONSE) .build(); - PayPalInternalClient sut = new PayPalInternalClient(braintreeClient, dataCollector, apiClient, deviceInspector); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository + ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); payPalRequest.setIntent(PayPalPaymentIntent.AUTHORIZE); diff --git a/ShopperInsights/src/main/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClient.kt b/ShopperInsights/src/main/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClient.kt index becd62b804..2011056c21 100644 --- a/ShopperInsights/src/main/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClient.kt +++ b/ShopperInsights/src/main/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClient.kt @@ -6,6 +6,7 @@ import com.braintreepayments.api.core.AnalyticsParamRepository import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.ExperimentalBetaApi +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.TokenizationKey import com.braintreepayments.api.shopperinsights.ShopperInsightsAnalytics.GET_RECOMMENDED_PAYMENTS_FAILED import com.braintreepayments.api.shopperinsights.ShopperInsightsAnalytics.GET_RECOMMENDED_PAYMENTS_STARTED @@ -30,6 +31,7 @@ class ShopperInsightsClient internal constructor( private val api: ShopperInsightsApi = ShopperInsightsApi( EligiblePaymentsApi(braintreeClient, analyticsParamRepository) ), + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { /** @@ -72,7 +74,7 @@ class ShopperInsightsClient internal constructor( return } - if (braintreeClient.authorization is TokenizationKey) { + if (merchantRepository.authorization is TokenizationKey) { callbackFailure( callback = callback, error = BraintreeException( diff --git a/ShopperInsights/src/test/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClientUnitTest.kt b/ShopperInsights/src/test/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClientUnitTest.kt index ea6f81abc7..11f84afb38 100644 --- a/ShopperInsights/src/test/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClientUnitTest.kt +++ b/ShopperInsights/src/test/java/com/braintreepayments/api/shopperinsights/ShopperInsightsClientUnitTest.kt @@ -4,11 +4,12 @@ import android.content.Context import androidx.test.core.app.ApplicationProvider import com.braintreepayments.api.core.AnalyticsEventParams import com.braintreepayments.api.core.AnalyticsParamRepository -import com.braintreepayments.api.core.Authorization import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException +import com.braintreepayments.api.core.ClientToken import com.braintreepayments.api.core.ExperimentalBetaApi -import com.braintreepayments.api.testutils.Fixtures +import com.braintreepayments.api.core.MerchantRepository +import com.braintreepayments.api.core.TokenizationKey import com.braintreepayments.api.testutils.MockkBraintreeClientBuilder import io.mockk.every import io.mockk.just @@ -39,14 +40,21 @@ class ShopperInsightsClientUnitTest { private lateinit var api: ShopperInsightsApi private lateinit var braintreeClient: BraintreeClient private lateinit var analyticsParamRepository: AnalyticsParamRepository + private lateinit var merchantRepository: MerchantRepository private lateinit var context: Context + private val clientToken = mockk() + @Before fun beforeEach() { api = mockk(relaxed = true) braintreeClient = mockk(relaxed = true) analyticsParamRepository = mockk(relaxed = true) - sut = ShopperInsightsClient(braintreeClient, analyticsParamRepository, api) + merchantRepository = mockk(relaxed = true) + + every { merchantRepository.authorization } returns clientToken + + sut = ShopperInsightsClient(braintreeClient, analyticsParamRepository, api, merchantRepository) context = ApplicationProvider.getApplicationContext() } @@ -392,11 +400,10 @@ class ShopperInsightsClientUnitTest { @Test fun `test getRecommendPaymentMethods is called with a tokenization key, error is sent`() { - val braintreeClient = MockkBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.TOKENIZATION_KEY)) - .build() + every { merchantRepository.authorization } returns mockk() + val braintreeClient = MockkBraintreeClientBuilder().build() - sut = ShopperInsightsClient(braintreeClient, analyticsParamRepository, api) + sut = ShopperInsightsClient(braintreeClient, analyticsParamRepository, api, merchantRepository) val request = ShopperInsightsRequest("some-email", null) sut.getRecommendedPaymentMethods(request) { result -> diff --git a/TestUtils/src/main/java/com/braintreepayments/api/testutils/MockBraintreeClientBuilder.java b/TestUtils/src/main/java/com/braintreepayments/api/testutils/MockBraintreeClientBuilder.java index 0eed0176fd..36852509b1 100644 --- a/TestUtils/src/main/java/com/braintreepayments/api/testutils/MockBraintreeClientBuilder.java +++ b/TestUtils/src/main/java/com/braintreepayments/api/testutils/MockBraintreeClientBuilder.java @@ -33,11 +33,8 @@ public class MockBraintreeClientBuilder { private Configuration configuration; private Exception configurationError; - private Authorization authorization; - private IntegrationType integration; private String returnUrlScheme; - private Uri appLinkReturnUri; private ActivityInfo activityInfo; @@ -53,11 +50,6 @@ public MockBraintreeClientBuilder configurationError(Exception configurationErro return this; } - public MockBraintreeClientBuilder authorizationSuccess(Authorization authorization) { - this.authorization = authorization; - return this; - } - public MockBraintreeClientBuilder activityInfo(ActivityInfo activityInfo) { this.activityInfo = activityInfo; return this; @@ -93,11 +85,6 @@ public MockBraintreeClientBuilder sendGraphQLPOSTErrorResponse(Exception error) return this; } - public MockBraintreeClientBuilder integration(IntegrationType integration) { - this.integration = integration; - return this; - } - public MockBraintreeClientBuilder returnUrlScheme(String returnUrlScheme) { this.returnUrlScheme = returnUrlScheme; return this; @@ -109,21 +96,12 @@ public MockBraintreeClientBuilder launchesBrowserSwitchAsNewTask( return this; } - public MockBraintreeClientBuilder appLinkReturnUri( - Uri appLinkReturnUri) { - this.appLinkReturnUri = appLinkReturnUri; - return this; - } - public BraintreeClient build() { BraintreeClient braintreeClient = mock(BraintreeClient.class); - when(braintreeClient.getIntegrationType()).thenReturn(integration); - when(braintreeClient.getAuthorization()).thenReturn(authorization); when(braintreeClient.getReturnUrlScheme()).thenReturn(returnUrlScheme); when(braintreeClient.getManifestActivityInfo(any())).thenReturn(activityInfo); when(braintreeClient.launchesBrowserSwitchAsNewTask()).thenReturn( launchesBrowserSwitchAsNewTask); - when(braintreeClient.getAppLinkReturnUri()).thenReturn(appLinkReturnUri); doAnswer((Answer) invocation -> { ConfigurationCallback callback = (ConfigurationCallback) invocation.getArguments()[0]; diff --git a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureClient.kt b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureClient.kt index 14efbce75c..121487ecf4 100644 --- a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureClient.kt +++ b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureClient.kt @@ -7,6 +7,7 @@ import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.BuildConfig import com.braintreepayments.api.core.Configuration import com.braintreepayments.api.core.InvalidArgumentException +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.threedsecure.ThreeDSecureParams.Companion.fromJson import com.cardinalcommerce.cardinalmobilesdk.models.CardinalActionCode import org.json.JSONException @@ -24,7 +25,8 @@ import org.json.JSONObject class ThreeDSecureClient internal constructor( private val braintreeClient: BraintreeClient, private val cardinalClient: CardinalClient = CardinalClient(), - private val api: ThreeDSecureAPI = ThreeDSecureAPI(braintreeClient) + private val api: ThreeDSecureAPI = ThreeDSecureAPI(braintreeClient), + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { /** * Initializes a new [ThreeDSecureClient] instance @@ -161,7 +163,7 @@ class ThreeDSecureClient internal constructor( val lookupJSON = JSONObject() try { lookupJSON - .put("authorizationFingerprint", braintreeClient.authorization.bearer) + .put("authorizationFingerprint", merchantRepository.authorization.bearer) .put("braintreeLibraryVersion", "Android-${BuildConfig.VERSION_NAME}") .put("nonce", request.nonce) .put( diff --git a/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/ThreeDSecureClientUnitTest.java b/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/ThreeDSecureClientUnitTest.java index 1a20707e15..8db8436e20 100644 --- a/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/ThreeDSecureClientUnitTest.java +++ b/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/ThreeDSecureClientUnitTest.java @@ -21,6 +21,7 @@ import com.braintreepayments.api.core.BraintreeClient; import com.braintreepayments.api.core.BraintreeException; import com.braintreepayments.api.core.Configuration; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.sharedutils.HttpResponseCallback; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; @@ -45,6 +46,7 @@ public class ThreeDSecureClientUnitTest { private FragmentActivity activity; private ThreeDSecureAPI threeDSecureAPI; + private MerchantRepository merchantRepository = mock(MerchantRepository.class); private ThreeDSecurePaymentAuthRequestCallback paymentAuthRequestCallback; private ThreeDSecureTokenizeCallback threeDSecureTokenizeCallback; @@ -74,8 +76,9 @@ public void beforeEach() throws JSONException { billingAddress.setGivenName("billing-given-name"); basicRequest.setBillingAddress(billingAddress); - threeDSecureParams = - ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_V2_LOOKUP_RESPONSE); + threeDSecureParams = ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_V2_LOOKUP_RESPONSE); + + when(merchantRepository.getAuthorization()).thenReturn(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)); } // region prepareLookup @@ -88,13 +91,15 @@ public void prepareLookup_returnsValidLookupJSONString() .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecurePrepareLookupCallback callback = mock(ThreeDSecurePrepareLookupCallback.class); sut.prepareLookup(activity, basicRequest, callback); @@ -130,13 +135,15 @@ public void prepareLookup_returnsValidLookupJSONString_whenCardinalSetupFails() .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecurePrepareLookupCallback callback = mock(ThreeDSecurePrepareLookupCallback.class); sut.prepareLookup(activity, basicRequest, callback); @@ -170,13 +177,15 @@ public void prepareLookup_initializesCardinal() throws BraintreeException { .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecurePrepareLookupCallback callback = mock(ThreeDSecurePrepareLookupCallback.class); sut.prepareLookup(activity, basicRequest, callback); @@ -194,13 +203,15 @@ public void prepareLookup_whenCardinalClientInitializeFails_forwardsError() .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecurePrepareLookupCallback callback = mock(ThreeDSecurePrepareLookupCallback.class); sut.prepareLookup(activity, basicRequest, callback); @@ -220,13 +231,15 @@ public void prepareLookup_withoutCardinalJWT_postsException() throws BraintreeEx .buildConfiguration(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(configuration) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecurePrepareLookupCallback callback = mock(ThreeDSecurePrepareLookupCallback.class); sut.prepareLookup(activity, basicRequest, callback); @@ -257,9 +270,12 @@ public void createPaymentAuthRequest_sendsAnalyticEvent() throws BraintreeExcept .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); sut.createPaymentAuthRequest(activity, basicRequest, paymentAuthRequestCallback); verify(braintreeClient).sendAnalyticsEvent(ThreeDSecureAnalytics.VERIFY_STARTED, new AnalyticsEventParams()); @@ -285,9 +301,12 @@ public void createPaymentAuthRequest_sendsParamsInLookupRequest() billingAddress.setGivenName("billing-given-name"); request.setBillingAddress(billingAddress); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, request, paymentAuthRequestCallback); String expectedUrl = "/v1/payment_methods/a-nonce/three_d_secure/lookup"; @@ -322,9 +341,12 @@ public void createPaymentAuthRequest_performsLookup_WhenCardinalSDKInitFails() billingAddress.setGivenName("billing-given-name"); request.setBillingAddress(billingAddress); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, request, paymentAuthRequestCallback); ArgumentCaptor pathCaptor = ArgumentCaptor.forClass(String.class); @@ -364,9 +386,12 @@ public void createPaymentAuthRequest_callsLookupListener() throws BraintreeExcep billingAddress.setGivenName("billing-given-name"); request.setBillingAddress(billingAddress); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, request, paymentAuthRequestCallback); @@ -379,9 +404,12 @@ public void createPaymentAuthRequest_withInvalidRequest_postsException() throws BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecureRequest request = new ThreeDSecureRequest(); request.setAmount("5"); @@ -402,13 +430,15 @@ public void createPaymentAuthRequest_initializesCardinal() throws BraintreeExcep .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, basicRequest, paymentAuthRequestCallback); verify(cardinalClient).initialize(same(activity), same(threeDSecureEnabledConfig), @@ -424,13 +454,15 @@ public void createPaymentAuthRequest_whenCardinalClientInitializeFails_forwardsE .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, basicRequest, paymentAuthRequestCallback); @@ -450,13 +482,15 @@ public void createPaymentAuthRequest_whenCardinalSetupFailed_sendsAnalyticEvent( .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, basicRequest, paymentAuthRequestCallback); verify(braintreeClient).sendAnalyticsEvent(ThreeDSecureAnalytics.VERIFY_STARTED, new AnalyticsEventParams()); @@ -472,13 +506,15 @@ public void createPaymentAuthRequest_withoutCardinalJWT_postsException() throws .buildConfiguration(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(configuration) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); sut.createPaymentAuthRequest(activity, basicRequest, paymentAuthRequestCallback); @@ -504,13 +540,15 @@ public void sendAnalyticsAndCallbackResult_whenAuthenticatingWithCardinal_sendsA .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecureParams threeDSecureParams = ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_V2_LOOKUP_RESPONSE); @@ -527,14 +565,16 @@ public void sendAnalyticsAndCallbackResult_whenChallengeIsRequired_sendsAnalytic .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .returnUrlScheme("sample-return-url://") .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecureParams threeDSecureParams = ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_LOOKUP_RESPONSE); @@ -552,13 +592,15 @@ public void sendAnalyticsAndCallbackResult_whenChallengeIsNotPresented_returnsRe .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecureParams threeDSecureParams = ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_LOOKUP_RESPONSE_NO_ACS_URL); @@ -580,13 +622,15 @@ public void sendAnalyticsAndCallbackResult_callsBackThreeDSecureResultForLaunch( .build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(Authorization.fromString(Fixtures.BASE64_CLIENT_TOKEN)) .configuration(threeDSecureEnabledConfig) .build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - new ThreeDSecureAPI(braintreeClient)); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + new ThreeDSecureAPI(braintreeClient), + merchantRepository + ); ThreeDSecureParams threeDSecureParams = ThreeDSecureParams.fromJson(Fixtures.THREE_D_SECURE_V2_LOOKUP_RESPONSE); @@ -609,9 +653,12 @@ public void tokenize_whenErrorExists_forwardsErrorToCallback_andSendsAnalytics() CardinalClient cardinalClient = new MockCardinalClientBuilder().build(); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); Exception threeDSecureError = new Exception("3DS error."); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult(null, null, null, threeDSecureError); @@ -634,9 +681,12 @@ public void tokenize_whenValidateResponseTimeout_returnsErrorAndSendsAnalytics() when(validateResponse.getActionCode()).thenReturn(CardinalActionCode.TIMEOUT); when(validateResponse.getErrorDescription()).thenReturn("Error"); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult("jwt", validateResponse, threeDSecureParams, null); @@ -663,9 +713,12 @@ public void tokenize_whenValidateResponseCancel_returnsUserCanceledErrorAndSends ValidateResponse validateResponse = mock(ValidateResponse.class); when(validateResponse.getActionCode()).thenReturn(CardinalActionCode.CANCEL); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult("jwt", validateResponse, threeDSecureParams, null); @@ -696,9 +749,12 @@ public void tokenize_whenValidateResponseSuccess_onAuthenticateCardinalJWTResult }).when(threeDSecureAPI).authenticateCardinalJWT(any(ThreeDSecureParams.class), anyString(), any(ThreeDSecureResultCallback.class)); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult("jwt", validateResponse, threeDSecureParams, null); @@ -733,9 +789,12 @@ public void tokenize_whenValidateResponseSuccess_onAuthenticateCardinalJWTResult }).when(threeDSecureAPI).authenticateCardinalJWT(any(ThreeDSecureParams.class), anyString(), any(ThreeDSecureResultCallback.class)); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult("jwt", validateResponse, threeDSecureParams, null); @@ -771,9 +830,12 @@ public void tokenize_whenValidateResponseSuccess_onAuthenticateCardinalJWTError_ }).when(threeDSecureAPI).authenticateCardinalJWT(any(ThreeDSecureParams.class), anyString(), any(ThreeDSecureResultCallback.class)); - ThreeDSecureClient sut = - new ThreeDSecureClient(braintreeClient, cardinalClient, - threeDSecureAPI); + ThreeDSecureClient sut = new ThreeDSecureClient( + braintreeClient, + cardinalClient, + threeDSecureAPI, + merchantRepository + ); ThreeDSecurePaymentAuthResult paymentAuthResult = new ThreeDSecurePaymentAuthResult("jwt", validateResponse, threeDSecureParams, null); diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoApi.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoApi.kt index f4c7138126..88624c65d0 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoApi.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoApi.kt @@ -5,6 +5,7 @@ import com.braintreepayments.api.core.AnalyticsParamRepository import com.braintreepayments.api.core.ApiClient import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.MetadataBuilder import com.braintreepayments.api.venmo.VenmoAccountNonce.Companion.fromJSON import org.json.JSONArray @@ -14,7 +15,8 @@ import org.json.JSONObject internal class VenmoApi( private val braintreeClient: BraintreeClient, private val apiClient: ApiClient, - private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance + private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { @Suppress("LongMethod") @@ -82,7 +84,7 @@ internal class VenmoApi( val braintreeData = MetadataBuilder() .sessionId(analyticsParamRepository.sessionId) - .integration(braintreeClient.integrationType) + .integration(merchantRepository.integrationType) .version() .build() diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt index f2296ff55e..764c51b45e 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt @@ -16,6 +16,7 @@ import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.BraintreeRequestCodes import com.braintreepayments.api.core.ClientToken import com.braintreepayments.api.core.Configuration +import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.MetadataBuilder import org.json.JSONException import org.json.JSONObject @@ -29,7 +30,8 @@ class VenmoClient internal constructor( private val apiClient: ApiClient = ApiClient(braintreeClient), private val venmoApi: VenmoApi = VenmoApi(braintreeClient, apiClient), private val sharedPrefsWriter: VenmoSharedPrefsWriter = VenmoSharedPrefsWriter(), - private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance + private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, + private val merchantRepository: MerchantRepository = MerchantRepository.instance, ) { /** * Used for linking events from the client to server side request @@ -117,7 +119,7 @@ class VenmoClient internal constructor( try { createPaymentAuthRequest( context, request, configuration, - braintreeClient.authorization, finalVenmoProfileId, + merchantRepository.authorization, finalVenmoProfileId, paymentContextId, callback ) } catch (e: JSONException) { @@ -146,7 +148,7 @@ class VenmoClient internal constructor( val metadata = MetadataBuilder() .sessionId(analyticsParamRepository.sessionId) - .integration(braintreeClient.integrationType) + .integration(merchantRepository.integrationType) .version() .build() @@ -228,14 +230,14 @@ class VenmoClient internal constructor( val paymentMethodNonce = parse(deepLinkUri.toString(), "payment_method_nonce") val username = parse(deepLinkUri.toString(), "username") - val isClientTokenAuth = (braintreeClient.authorization is ClientToken) + val isClientTokenAuth = (merchantRepository.authorization is ClientToken) if (paymentContextId != null) { venmoApi.createNonceFromPaymentContext(paymentContextId) { nonce: VenmoAccountNonce?, error: Exception? -> if (nonce != null) { isVaultRequest = sharedPrefsWriter.getVenmoVaultOption( - braintreeClient.applicationContext + merchantRepository.applicationContext ) if (isVaultRequest && isClientTokenAuth) { vaultVenmoAccountNonce( @@ -262,7 +264,7 @@ class VenmoClient internal constructor( } } else if (paymentMethodNonce != null && username != null) { isVaultRequest = sharedPrefsWriter.getVenmoVaultOption( - braintreeClient.applicationContext + merchantRepository.applicationContext ) if (isVaultRequest && isClientTokenAuth) { diff --git a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoApiUnitTest.java b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoApiUnitTest.java index a2d76a2132..d2d15d9859 100644 --- a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoApiUnitTest.java +++ b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoApiUnitTest.java @@ -12,6 +12,7 @@ import static org.mockito.Mockito.when; import com.braintreepayments.api.core.AnalyticsParamRepository; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.testutils.MockApiClientBuilder; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; @@ -38,6 +39,7 @@ public class VenmoApiUnitTest { private BraintreeClient braintreeClient; private ApiClient apiClient; private AnalyticsParamRepository analyticsParamRepository; + private MerchantRepository merchantRepository = mock(MerchantRepository.class); @Before public void beforeEach() { @@ -50,7 +52,7 @@ public void beforeEach() { @Test public void createPaymentContext_createsPaymentContextViaGraphQL() throws JSONException { - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -104,7 +106,7 @@ public void createPaymentContext_createsPaymentContextViaGraphQL() throws JSONEx @Test public void createPaymentContext_whenTransactionAmountOptionsMissing() throws JSONException { - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -137,7 +139,7 @@ public void createPaymentContext_whenGraphQLPostSuccess_includesPaymentContextID .sendGraphQLPOSTSuccessfulResponse( Fixtures.VENMO_GRAPHQL_CREATE_PAYMENT_METHOD_CONTEXT_RESPONSE) .build(); - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -154,7 +156,7 @@ public void createPaymentContext_whenGraphQLPostSuccess_missingPaymentContextID_ .sendGraphQLPOSTSuccessfulResponse( Fixtures.VENMO_GRAPHQL_CREATE_PAYMENT_METHOD_RESPONSE_WITHOUT_PAYMENT_CONTEXT_ID) .build(); - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -177,7 +179,7 @@ public void createPaymentContext_whenGraphQLPostError_forwardsErrorToCallback() BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .sendGraphQLPOSTErrorResponse(error) .build(); - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -190,7 +192,7 @@ public void createPaymentContext_whenGraphQLPostError_forwardsErrorToCallback() @Test public void createPaymentContext_withTotalAmountAndSetsFinalAmountToTrue() throws JSONException { - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -216,7 +218,7 @@ public void createPaymentContext_withTotalAmountAndSetsFinalAmountToTrue() throw @Test public void createPaymentContext_withTotalAmountAndSetsFinalAmountToFalse() throws JSONException { - VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi venmoAPI = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -242,7 +244,7 @@ public void createPaymentContext_withTotalAmountAndSetsFinalAmountToFalse() thro @Test public void createNonceFromPaymentContext_queriesGraphQLPaymentContext() throws JSONException { - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); sut.createNonceFromPaymentContext("payment-context-id", mock(VenmoInternalCallback.class)); ArgumentCaptor captor = ArgumentCaptor.forClass(JSONObject.class); @@ -259,7 +261,7 @@ public void createNonceFromPaymentContext_whenGraphQLPostSuccess_forwardsNonceTo .sendGraphQLPOSTSuccessfulResponse(graphQLResponse) .build(); - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoInternalCallback callback = mock(VenmoInternalCallback.class); sut.createNonceFromPaymentContext("payment-context-id", callback); @@ -275,7 +277,7 @@ public void createNonceFromPaymentContext_whenGraphQLPostResponseMalformed_calls .sendGraphQLPOSTSuccessfulResponse("not-json") .build(); - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoInternalCallback callback = mock(VenmoInternalCallback.class); sut.createNonceFromPaymentContext("payment-context-id", callback); @@ -292,7 +294,7 @@ public void createNonceFromPaymentContext_whenGraphQLPostError_forwardsErrorToCa .sendGraphQLPOSTErrorResponse(error) .build(); - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoInternalCallback callback = mock(VenmoInternalCallback.class); sut.createNonceFromPaymentContext("payment-context-id", callback); @@ -302,7 +304,7 @@ public void createNonceFromPaymentContext_whenGraphQLPostError_forwardsErrorToCa @Test public void vaultVenmoAccountNonce_performsVaultRequest() throws JSONException { - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); sut.vaultVenmoAccountNonce("nonce", mock(VenmoInternalCallback.class)); ArgumentCaptor accountBuilderCaptor = @@ -320,7 +322,7 @@ public void vaultVenmoAccountNonce_tokenizeRESTSuccess_callsBackNonce() throws J .tokenizeRESTSuccess(new JSONObject( Fixtures.VENMO_PAYMENT_METHOD_CONTEXT_WITH_NULL_PAYER_INFO_JSON)) .build(); - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoInternalCallback callback = mock(VenmoInternalCallback.class); sut.vaultVenmoAccountNonce("nonce", callback); @@ -338,7 +340,7 @@ public void vaultVenmoAccountNonce_tokenizeRESTError_forwardsErrorToCallback() { ApiClient apiClient = new MockApiClientBuilder() .tokenizeRESTError(error) .build(); - VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository); + VenmoApi sut = new VenmoApi(braintreeClient, apiClient, analyticsParamRepository, merchantRepository); VenmoInternalCallback callback = mock(VenmoInternalCallback.class); sut.vaultVenmoAccountNonce("nonce", callback); diff --git a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java index 971818bf08..89f81a09f8 100644 --- a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java +++ b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java @@ -22,6 +22,7 @@ import com.braintreepayments.api.core.AnalyticsParamRepository; import com.braintreepayments.api.core.ApiClient; import com.braintreepayments.api.core.IntegrationType; +import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; import com.braintreepayments.api.core.Authorization; @@ -64,6 +65,8 @@ public class VenmoClientUnitTest { private final String LINK_TYPE = "universal"; private final AnalyticsEventParams expectedAnalyticsParams = new AnalyticsEventParams(); private final AnalyticsEventParams expectedVaultAnalyticsParams = new AnalyticsEventParams(); + + private final MerchantRepository merchantRepository = mock(MerchantRepository.class); @Before public void beforeEach() throws JSONException { @@ -92,16 +95,18 @@ public void beforeEach() throws JSONException { paymentAuthResult = new VenmoPaymentAuthResult.Success(browserSwitchResult); when(analyticsParamRepository.getSessionId()).thenReturn("session-id"); + when(merchantRepository.getIntegrationType()).thenReturn(IntegrationType.CUSTOM); + when(merchantRepository.getApplicationContext()).thenReturn(context); } @Test public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddressWithEcdDisabled() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .integration(IntegrationType.CUSTOM) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -113,8 +118,14 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres request.setProfileId("sample-venmo-merchant"); request.setCollectCustomerBillingAddress(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); @@ -130,11 +141,11 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVenmoAuthChallenge() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .integration(IntegrationType.CUSTOM) - .authorizationSuccess(clientToken) .returnUrlScheme("com.example") .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -143,8 +154,14 @@ public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVen request.setProfileId("sample-venmo-merchant"); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); InOrder inOrder = Mockito.inOrder(venmoPaymentAuthRequestCallback, braintreeClient); @@ -186,8 +203,14 @@ public void createPaymentAuthRequest_whenConfigurationException_forwardsExceptio request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = @@ -209,8 +232,14 @@ public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToList request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = @@ -226,10 +255,10 @@ public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToList public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchantId() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .integration(IntegrationType.CUSTOM) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -238,8 +267,14 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = @@ -258,10 +293,10 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithProfileIdAndAccessToken() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .integration(IntegrationType.CUSTOM) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -270,8 +305,14 @@ public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithPro request.setProfileId("second-pwv-profile-id"); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = @@ -298,8 +339,14 @@ public void createPaymentAuthRequest_sendsAnalyticsEvent() { request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED,new AnalyticsEventParams()); } @@ -308,9 +355,10 @@ public void createPaymentAuthRequest_sendsAnalyticsEvent() { public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTrue() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -319,8 +367,14 @@ public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTru request.setProfileId(null); request.setShouldVault(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(sharedPrefsWriter).persistVenmoVaultOption(context, true); @@ -330,9 +384,10 @@ public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTru public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFalse() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -341,8 +396,14 @@ public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFa request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(sharedPrefsWriter).persistVenmoVaultOption(context, false); @@ -352,9 +413,10 @@ public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFa public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") .build(); @@ -363,8 +425,14 @@ public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse request.setProfileId(null); request.setShouldVault(false); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(sharedPrefsWriter).persistVenmoVaultOption(context, false); @@ -385,8 +453,14 @@ public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_a VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setShouldVault(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = @@ -402,12 +476,18 @@ public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_a public void tokenize_withPaymentContextId_requestFromVenmoApi() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -421,12 +501,18 @@ public void tokenize_withPaymentContextId_requestFromVenmoApi() { public void tokenize_withPaymentAuthResult_whenUserCanceled_returnsCancelAndSendsAnalytics() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(CANCEL_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -444,17 +530,23 @@ public void tokenize_onGraphQLPostSuccess_returnsNonceToListener_andSendsAnalyti throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE))) .build(); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -475,17 +567,23 @@ public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAn BraintreeException graphQLError = new BraintreeException("graphQL error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .sendGraphQLPOSTErrorResponse(graphQLError) .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() .createNonceFromPaymentContextError(graphQLError) .build(); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -502,10 +600,9 @@ public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAn public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce nonce = mock(VenmoAccountNonce.class); when(nonce.getString()).thenReturn("some-nonce"); @@ -520,8 +617,14 @@ public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -530,13 +633,18 @@ public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() @Test public void tokenize_postsPaymentMethodNonceOnSuccess() { - BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) - .build(); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -548,10 +656,9 @@ public void tokenize_postsPaymentMethodNonceOnSuccess() { public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) - .authorizationSuccess(clientToken) .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( @@ -564,8 +671,14 @@ public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONExcepti when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -575,16 +688,19 @@ public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONExcepti @Test public void tokenize_doesNotPerformRequestIfTokenizationKeyUsed() { - BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - - .authorizationSuccess(tokenizationKey) - .build(); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); - when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); + when(merchantRepository.getAuthorization()).thenReturn(tokenizationKey); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -595,10 +711,9 @@ public void tokenize_doesNotPerformRequestIfTokenizationKeyUsed() { @Test public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListener_andSendsAnalytics() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL_WITHOUT_RESOURCE_ID); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = mock(VenmoAccountNonce.class); @@ -608,8 +723,14 @@ public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListe when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -627,12 +748,10 @@ public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListe public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToCallback_andSendsAnalytics() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) - .sendGraphQLPOSTSuccessfulResponse( - Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) + .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = VenmoAccountNonce.fromJSON( new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); @@ -644,8 +763,14 @@ public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToC when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -661,11 +786,9 @@ public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToC @Test public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_andSendsAnalytics() { - BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) - .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL_WITHOUT_RESOURCE_ID); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); Exception error = new Exception("error"); @@ -675,8 +798,14 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -697,12 +826,10 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a public void tokenize_withPaymentContext_withFailedVaultCall_forwardsErrorToCallback_andSendsAnalytics() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .authorizationSuccess(clientToken) - .sendGraphQLPOSTSuccessfulResponse( - Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) + .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) .build(); - when(braintreeClient.getApplicationContext()).thenReturn(context); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); + when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = VenmoAccountNonce.fromJSON( new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); @@ -715,8 +842,14 @@ public void tokenize_withPaymentContext_withFailedVaultCall_forwardsErrorToCallb when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); - VenmoClient sut = - new VenmoClient(braintreeClient, apiClient, venmoApi, sharedPrefsWriter, analyticsParamRepository); + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository + ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); From a35476b07a25a3dfdc65c6bfd0c1ee38ebee5d07 Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Fri, 8 Nov 2024 08:22:05 -0800 Subject: [PATCH 04/22] update json string in demo app (#1204) --- .../java/com/braintreepayments/demo/ShopperInsightsFragment.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt b/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt index 172a1f126e..32d1ca475e 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt +++ b/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt @@ -185,7 +185,7 @@ class ShopperInsightsFragment : BaseFragment() { shopperInsightsClient.getRecommendedPaymentMethods( request, - "dummy_experiment" + """{"exp_name":"PaymentReady","treatment_name":"test"}""" ) { result -> when (result) { is ShopperInsightsResult.Success -> { From a70a4df35e53db26d3b2e8b8602b603efc627790 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Wed, 13 Nov 2024 09:02:25 -0600 Subject: [PATCH 05/22] Add section in the v5 migration guide for handing CCT picture-in-picture (#1205) * Add section in the v5 migration guide for handing CCT picture-in-picture * Fix CCT title in table of contents --- v5_MIGRATION_GUIDE.md | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/v5_MIGRATION_GUIDE.md b/v5_MIGRATION_GUIDE.md index fb5cee2e5b..40deaf1d67 100644 --- a/v5_MIGRATION_GUIDE.md +++ b/v5_MIGRATION_GUIDE.md @@ -21,6 +21,7 @@ basics for updating your Braintree integration from v4 to v5. 1. [Visa Checkout](#visa-checkout) 1. [Samsung Pay](#samsung-pay) 1. [PayPal Native Checkout](#paypal-native-checkout) +1. [Chrome Custom Tab Picture-in-Picture](#chrome-custom-tab-picture-in-picture) ## Supported Versions @@ -690,3 +691,27 @@ The Samsung Pay integration is no longer supported. Please remove it from your a The PayPal Native Checkout integration is no longer supported. Please remove it from your app and use the PayPal (web) integration. + +## Chrome Custom Tab Picture-in-Picture +Google has added a Picture-in-Picture feature to Chrome Custom Tabs. Users are now able to minimize the checkout flow at +any point while the Chrome Custom Tab is active. + +When the Chrome Custom Tab is minimized and your app is resumed, calling `handleReturnToApp()` on the launcher class +will return `NoResult` instead of `Success` or `Failure`. At this point you can prompt the user to return to the Chrome +Custom Tab and complete the checkout flow. + +PayPal Example: +```kotlin +override fun onResume() { + super.onResume() + + getPendingRequest()?.let { pendingRequest -> + when (val paymentAuthResult = payPalLauncher.handleReturnToApp(pendingRequest, intent)) { + is PayPalPaymentAuthResult.NoResult -> { + // Prompt user to return to the Chrome Custom Tab to complete the checkout flow + } + ... + } + } +} +``` From c9d4246eccb6926a0985b5e6d409147d6fb38470 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Thu, 14 Nov 2024 10:02:28 -0600 Subject: [PATCH 06/22] Add SdkComponent and move configuration fetch out of BraintreeClient (#1203) * Move getting configuration out of BraintreeClient and move dependencies that require context to a SdkComponent singleton * Update unit tests * Add latency analytics event to configuration call * Add a TODO for removing the circular dependency between AnalyticsClient and ConfigurationLoader --- .../api/core/AnalyticsClient.kt | 35 +-- .../api/core/AnalyticsUploadWorker.kt | 2 +- .../api/core/AnalyticsWriteToDbWorker.kt | 2 +- .../api/core/BraintreeClient.kt | 92 +++----- .../api/core/ConfigurationLoader.kt | 50 +++-- .../api/core/ConfigurationLoaderCallback.kt | 4 +- .../api/core/ConfigurationLoaderResult.kt | 16 ++ .../api/core/CoreAnalytics.kt | 2 +- .../api/core/SdkComponent.kt | 51 +++++ .../api/core/AnalyticsClientUnitTest.kt | 34 ++- .../api/core/BraintreeClientUnitTest.kt | 19 +- .../api/core/ConfigurationLoaderUnitTest.kt | 204 ++++++++++++------ .../core/MockkConfigurationLoaderBuilder.kt | 14 +- 13 files changed, 325 insertions(+), 200 deletions(-) create mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderResult.kt create mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/SdkComponent.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt index 517fd69540..339cd47707 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt @@ -15,28 +15,29 @@ import java.util.concurrent.TimeUnit @Suppress("SwallowedException", "TooGenericExceptionCaught") internal class AnalyticsClient( - context: Context, private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), - private val analyticsDatabase: AnalyticsDatabase = AnalyticsDatabase.getInstance(context.applicationContext), - private val workManager: WorkManager = WorkManager.getInstance(context.applicationContext), + private val analyticsDatabase: AnalyticsDatabase = AnalyticsDatabaseProvider().analyticsDatabase, + private val workManager: WorkManager = WorkManagerProvider().workManager, private val deviceInspector: DeviceInspector = DeviceInspector(), private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, - private val time: Time = Time() + private val time: Time = Time(), + private val configurationLoader: ConfigurationLoader = ConfigurationLoader.instance, + private val merchantRepository: MerchantRepository = MerchantRepository.instance ) { - private val applicationContext = context.applicationContext + private val applicationContext: Context + get() = merchantRepository.applicationContext - fun sendEvent( - configuration: Configuration, - event: AnalyticsEvent, - integration: IntegrationType?, - authorization: Authorization - ): UUID { - scheduleAnalyticsWriteInBackground(event, authorization) - return scheduleAnalyticsUploadInBackground( - configuration, - authorization, - integration - ) + fun sendEvent(event: AnalyticsEvent) { + configurationLoader.loadConfiguration { result -> + if (result is ConfigurationLoaderResult.Success) { + scheduleAnalyticsWriteInBackground(event, merchantRepository.authorization) + scheduleAnalyticsUploadInBackground( + configuration = result.configuration, + authorization = merchantRepository.authorization, + integration = merchantRepository.integrationType + ) + } + } } private fun scheduleAnalyticsWriteInBackground( diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsUploadWorker.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsUploadWorker.kt index 503ce4a728..956bd85830 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsUploadWorker.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsUploadWorker.kt @@ -16,7 +16,7 @@ internal class AnalyticsUploadWorker( ) : Worker(context, params) { override fun doWork(): Result { - val analyticsClient = AnalyticsClient(applicationContext) + val analyticsClient = AnalyticsClient() return analyticsClient.performAnalyticsUpload(inputData) } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsWriteToDbWorker.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsWriteToDbWorker.kt index da6eab6e5f..de8318c3be 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsWriteToDbWorker.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsWriteToDbWorker.kt @@ -16,7 +16,7 @@ internal class AnalyticsWriteToDbWorker( ) : Worker(context, params) { override fun doWork(): Result { - val analyticsClient = AnalyticsClient(applicationContext) + val analyticsClient = AnalyticsClient() return analyticsClient.performAnalyticsWrite(inputData) } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt index cb3a5529a8..1b50b82002 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt @@ -22,13 +22,14 @@ class BraintreeClient internal constructor( authorization: Authorization, returnUrlScheme: String, appLinkReturnUri: Uri?, - private val analyticsClient: AnalyticsClient = AnalyticsClient(applicationContext), + sdkComponent: SdkComponent = SdkComponent.create(applicationContext), private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), private val graphQLClient: BraintreeGraphQLClient = BraintreeGraphQLClient(), - private val configurationLoader: ConfigurationLoader = ConfigurationLoader(applicationContext, httpClient), + private val configurationLoader: ConfigurationLoader = ConfigurationLoader.instance, private val manifestValidator: ManifestValidator = ManifestValidator(), private val time: Time = Time(), - private val merchantRepository: MerchantRepository = MerchantRepository.instance + private val merchantRepository: MerchantRepository = MerchantRepository.instance, + private val analyticsClient: AnalyticsClient = AnalyticsClient(), ) { private val crashReporter: CrashReporter @@ -81,17 +82,15 @@ class BraintreeClient internal constructor( * @param callback [ConfigurationCallback] */ fun getConfiguration(callback: ConfigurationCallback) { - if (merchantRepository.authorization is InvalidAuthorization) { - callback.onResult(null, createAuthError()) - return - } - configurationLoader.loadConfiguration(merchantRepository.authorization) { configuration, configError, timing -> - if (configuration != null) { - callback.onResult(configuration, null) - } else { - callback.onResult(null, configError) + configurationLoader.loadConfiguration { result -> + when (result) { + is ConfigurationLoaderResult.Success -> { + callback.onResult(result.configuration, null) + result.timing?.let { sendAnalyticsTimingEvent("/v1/configuration", it) } + } + + is ConfigurationLoaderResult.Failure -> callback.onResult(null, result.error) } - timing?.let { sendAnalyticsTimingEvent("/v1/configuration", it) } } } @@ -102,47 +101,25 @@ class BraintreeClient internal constructor( eventName: String, params: AnalyticsEventParams = AnalyticsEventParams() ) { - val timestamp = time.currentTime - getConfiguration { configuration, _ -> - val event = AnalyticsEvent( - name = eventName, - timestamp = timestamp, - payPalContextId = params.payPalContextId, - linkType = params.linkType, - isVaultRequest = params.isVaultRequest, - startTime = params.startTime, - endTime = params.endTime, - endpoint = params.endpoint, - experiment = params.experiment, - paymentMethodsDisplayed = params.paymentMethodsDisplayed - ) - sendAnalyticsEvent(event, configuration, merchantRepository.authorization) - } - } - - private fun sendAnalyticsEvent( - event: AnalyticsEvent, - configuration: Configuration?, - authorization: Authorization - ) { - configuration?.let { - analyticsClient.sendEvent( - it, - event, - merchantRepository.integrationType, - authorization - ) - } + val event = AnalyticsEvent( + name = eventName, + timestamp = time.currentTime, + payPalContextId = params.payPalContextId, + linkType = params.linkType, + isVaultRequest = params.isVaultRequest, + startTime = params.startTime, + endTime = params.endTime, + endpoint = params.endpoint, + experiment = params.experiment, + paymentMethodsDisplayed = params.paymentMethodsDisplayed + ) + analyticsClient.sendEvent(event) } /** * @suppress */ fun sendGET(url: String, responseCallback: HttpResponseCallback) { - if (merchantRepository.authorization is InvalidAuthorization) { - responseCallback.onResult(null, createAuthError()) - return - } getConfiguration { configuration, configError -> if (configuration != null) { httpClient.get(url, configuration, merchantRepository.authorization) { response, httpError -> @@ -173,10 +150,6 @@ class BraintreeClient internal constructor( additionalHeaders: Map = emptyMap(), responseCallback: HttpResponseCallback, ) { - if (merchantRepository.authorization is InvalidAuthorization) { - responseCallback.onResult(null, createAuthError()) - return - } getConfiguration { configuration, configError -> if (configuration != null) { httpClient.post( @@ -207,10 +180,6 @@ class BraintreeClient internal constructor( * @suppress */ fun sendGraphQLPOST(json: JSONObject?, responseCallback: HttpResponseCallback) { - if (merchantRepository.authorization is InvalidAuthorization) { - responseCallback.onResult(null, createAuthError()) - return - } getConfiguration { configuration, configError -> if (configuration != null) { graphQLClient.post( @@ -230,7 +199,7 @@ class BraintreeClient internal constructor( endpoint = finalQuery ) sendAnalyticsEvent( - CoreAnalytics.apiRequestLatency, + CoreAnalytics.API_REQUEST_LATENCY, params ) } @@ -302,7 +271,7 @@ class BraintreeClient internal constructor( ) sendAnalyticsEvent( - CoreAnalytics.apiRequestLatency, + CoreAnalytics.API_REQUEST_LATENCY, AnalyticsEventParams( startTime = timing.startTime, endTime = timing.endTime, @@ -328,13 +297,6 @@ class BraintreeClient internal constructor( this.launchesBrowserSwitchAsNewTask = launchesBrowserSwitchAsNewTask } - private fun createAuthError(): BraintreeException { - val clientSDKSetupURL = - "https://developer.paypal.com/braintree/docs/guides/client-sdk/setup/android/v4#initialization" - val message = "Valid authorization required. See $clientSDKSetupURL for more info." - return BraintreeException(message) - } - companion object { private fun getAppPackageNameWithoutUnderscores(context: Context): String { return context.applicationContext.packageName.replace("_", "") diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt index f0fb6e8dcc..657c312415 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt @@ -1,24 +1,33 @@ package com.braintreepayments.api.core -import android.content.Context import android.net.Uri import android.util.Base64 import com.braintreepayments.api.sharedutils.HttpClient +import com.braintreepayments.api.sharedutils.Time import org.json.JSONException internal class ConfigurationLoader( - private val httpClient: BraintreeHttpClient, - private val configurationCache: ConfigurationCache + private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), + private val merchantRepository: MerchantRepository = MerchantRepository.instance, + private val configurationCache: ConfigurationCache = ConfigurationCacheProvider().configurationCache, + private val time: Time = Time(), + /** + * TODO: AnalyticsClient must be lazy due to the circular dependency between ConfigurationLoader and AnalyticsClient + * This should be refactored to remove the circular dependency. + */ + lazyAnalyticsClient: Lazy = lazy { AnalyticsClient(httpClient) }, ) { - constructor(context: Context, httpClient: BraintreeHttpClient) : this( - httpClient, ConfigurationCache.getInstance(context) - ) + private val analyticsClient: AnalyticsClient by lazyAnalyticsClient - fun loadConfiguration(authorization: Authorization, callback: ConfigurationLoaderCallback) { + fun loadConfiguration(callback: ConfigurationLoaderCallback) { + val authorization = merchantRepository.authorization if (authorization is InvalidAuthorization) { - val message = authorization.errorMessage + val clientSDKSetupURL = + "https://developer.paypal.com/braintree/docs/guides/client-sdk/setup/android/v4#initialization" + val message = "Valid authorization required. See $clientSDKSetupURL for more info." + // NOTE: timing information is null when configuration comes from cache - callback.onResult(null, BraintreeException(message), null) + callback.onResult(ConfigurationLoaderResult.Failure(BraintreeException(message))) return } val configUrl = Uri.parse(authorization.configUrl) @@ -29,7 +38,7 @@ internal class ConfigurationLoader( val cachedConfig = getCachedConfiguration(authorization, configUrl) cachedConfig?.let { - callback.onResult(cachedConfig, null, null) + callback.onResult(ConfigurationLoaderResult.Success(it)) } ?: run { httpClient.get( configUrl, null, authorization, HttpClient.RETRY_MAX_3_TIMES @@ -40,16 +49,26 @@ internal class ConfigurationLoader( try { val configuration = Configuration.fromJson(responseBody) saveConfigurationToCache(configuration, authorization, configUrl) - callback.onResult(configuration, null, timing) + callback.onResult(ConfigurationLoaderResult.Success(configuration, timing)) + + analyticsClient.sendEvent( + AnalyticsEvent( + name = CoreAnalytics.API_REQUEST_LATENCY, + timestamp = time.currentTime, + startTime = timing?.startTime, + endTime = timing?.endTime, + endpoint = "/v1/configuration" + ) + ) } catch (jsonException: JSONException) { - callback.onResult(null, jsonException, null) + callback.onResult(ConfigurationLoaderResult.Failure(jsonException)) } } else { httpError?.let { error -> val errorMessageFormat = "Request for configuration has failed: %s" val errorMessage = String.format(errorMessageFormat, error.message) val configurationException = ConfigurationException(errorMessage, error) - callback.onResult(null, configurationException, null) + callback.onResult(ConfigurationLoaderResult.Failure(configurationException)) } } } @@ -82,5 +101,10 @@ internal class ConfigurationLoader( private fun createCacheKey(authorization: Authorization, configUrl: String): String { return Base64.encodeToString("$configUrl${authorization.bearer}".toByteArray(), 0) } + + /** + * Singleton instance of the ConfigurationLoader. + */ + val instance: ConfigurationLoader by lazy { ConfigurationLoader() } } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderCallback.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderCallback.kt index 7808d48a05..12dbd7e456 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderCallback.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderCallback.kt @@ -1,7 +1,5 @@ package com.braintreepayments.api.core -import com.braintreepayments.api.sharedutils.HttpResponseTiming - internal fun interface ConfigurationLoaderCallback { - fun onResult(result: Configuration?, error: Exception?, timing: HttpResponseTiming?) + fun onResult(result: ConfigurationLoaderResult) } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderResult.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderResult.kt new file mode 100644 index 0000000000..b546c59a5f --- /dev/null +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoaderResult.kt @@ -0,0 +1,16 @@ +package com.braintreepayments.api.core + +import com.braintreepayments.api.sharedutils.HttpResponseTiming + +/** + * Result of calling [ConfigurationLoader.loadConfiguration] + */ +internal sealed class ConfigurationLoaderResult { + + data class Success( + val configuration: Configuration, + val timing: HttpResponseTiming? = null + ) : ConfigurationLoaderResult() + + data class Failure(val error: Exception) : ConfigurationLoaderResult() +} diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/CoreAnalytics.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/CoreAnalytics.kt index 99da467571..930c831ea4 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/CoreAnalytics.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/CoreAnalytics.kt @@ -1,5 +1,5 @@ package com.braintreepayments.api.core internal object CoreAnalytics { - const val apiRequestLatency = "core:api-request-latency" + const val API_REQUEST_LATENCY = "core:api-request-latency" } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/SdkComponent.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/SdkComponent.kt new file mode 100644 index 0000000000..ee021e4f28 --- /dev/null +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/SdkComponent.kt @@ -0,0 +1,51 @@ +package com.braintreepayments.api.core + +import android.content.Context +import androidx.work.WorkManager + +/** + * Component class that is created when the BT SDK is launched. It contains dependencies that need to be injected that + * contain Context. + */ +internal class SdkComponent( + applicationContext: Context, +) { + val analyticsDatabase: AnalyticsDatabase = AnalyticsDatabase.getInstance(applicationContext) + val workManager: WorkManager = WorkManager.getInstance(applicationContext) + val configurationCache: ConfigurationCache = ConfigurationCache.getInstance(applicationContext) + + companion object { + private var instance: SdkComponent? = null + + /** + * Creates and returns a new instance of [SdkComponent], or returns the existing instance. + */ + fun create(applicationContext: Context): SdkComponent { + return instance ?: SdkComponent(applicationContext).also { sdkComponent -> + instance = sdkComponent + } + } + + /** + * Returns the instance of [SdkComponent] + */ + fun getInstance(): SdkComponent { + return checkNotNull(instance) + } + } +} + +internal class AnalyticsDatabaseProvider { + val analyticsDatabase: AnalyticsDatabase + get() = SdkComponent.getInstance().analyticsDatabase +} + +internal class WorkManagerProvider { + val workManager: WorkManager + get() = SdkComponent.getInstance().workManager +} + +internal class ConfigurationCacheProvider { + val configurationCache: ConfigurationCache + get() = SdkComponent.getInstance().configurationCache +} diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt index f7142c8296..927a2d4364 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt @@ -40,6 +40,9 @@ class AnalyticsClientUnitTest { private lateinit var workManager: WorkManager private lateinit var analyticsDatabase: AnalyticsDatabase private lateinit var analyticsEventBlobDao: AnalyticsEventBlobDao + private val merchantRepository: MerchantRepository = mockk(relaxed = true) + + private lateinit var configurationLoader: ConfigurationLoader private lateinit var sut: AnalyticsClient @@ -67,17 +70,24 @@ class AnalyticsClientUnitTest { every { analyticsDatabase.analyticsEventBlobDao() } returns analyticsEventBlobDao every { analyticsParamRepository.sessionId } returns sessionId - + every { analyticsParamRepository.sessionId } returns sessionId every { time.currentTime } returns 123 + every { merchantRepository.authorization } returns authorization + every { merchantRepository.applicationContext } returns context + + configurationLoader = MockkConfigurationLoaderBuilder() + .configuration(configuration) + .build() sut = AnalyticsClient( - context = context, httpClient = httpClient, analyticsDatabase = analyticsDatabase, workManager = workManager, deviceInspector = deviceInspector, analyticsParamRepository = analyticsParamRepository, - time = time + time = time, + configurationLoader = configurationLoader, + merchantRepository = merchantRepository ) } @@ -95,7 +105,7 @@ class AnalyticsClientUnitTest { val event = AnalyticsEvent(eventName, timestamp = 123) - sut.sendEvent(configuration, event, integration, authorization) + sut.sendEvent(event) val workSpec = workRequestSlot.captured.workSpec assertEquals(AnalyticsWriteToDbWorker::class.java.name, workSpec.workerClassName) @@ -132,7 +142,7 @@ class AnalyticsClientUnitTest { timestamp = 456 ) - sut.sendEvent(configuration, event, integration, authorization) + sut.sendEvent(event) val workSpec = workRequestSlot.captured.workSpec assertEquals(30000, workSpec.initialDelay) @@ -203,8 +213,14 @@ class AnalyticsClientUnitTest { .putString(AnalyticsClient.WORK_INPUT_KEY_SESSION_ID, sessionId) .putString(AnalyticsClient.WORK_INPUT_KEY_INTEGRATION, integration.stringValue) .build() - val sut = - AnalyticsClient(context, httpClient, analyticsDatabase, workManager, deviceInspector) + val sut = AnalyticsClient( + httpClient = httpClient, + analyticsDatabase = analyticsDatabase, + workManager = workManager, + deviceInspector = deviceInspector, + configurationLoader = configurationLoader, + merchantRepository = merchantRepository + ) sut.performAnalyticsUpload(inputData) // or confirmVerified(httpClient) @@ -513,7 +529,7 @@ class AnalyticsClientUnitTest { } returns metadata val event = AnalyticsEvent(eventName, timestamp) - sut.sendEvent(configuration, event, integration, authorization) + sut.sendEvent(event) sut.reportCrash(context, configuration, integration, null) @@ -523,7 +539,7 @@ class AnalyticsClientUnitTest { @Test fun `sendEvent enqueues work to upload analytic events with sessionId in the name`() { - sut.sendEvent(configuration, AnalyticsEvent("event-name", timestamp), integration, authorization) + sut.sendEvent(AnalyticsEvent("event-name", timestamp)) verify { workManager.enqueueUniqueWork( diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt index e8709acd07..74f5e0d473 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt @@ -327,26 +327,11 @@ class BraintreeClientUnitTest { verify { analyticsClient.sendEvent( - configuration, match { it.name == "event.started" && it.timestamp == 123L }, - IntegrationType.CUSTOM, - authorization ) } } - @Test - fun sendAnalyticsEvent_whenConfigurationLoadFails_doesNothing() { - val configurationLoader = MockkConfigurationLoaderBuilder() - .configurationError(Exception("error")) - .build() - - val sut = createBraintreeClient(configurationLoader) - sut.sendAnalyticsEvent("event.started") - - verify { analyticsClient wasNot Called } - } - @Test fun isUrlSchemeDeclaredInAndroidManifest_forwardsInvocationToManifestValidator() { every { @@ -416,10 +401,10 @@ class BraintreeClientUnitTest { val callbackSlot = slot() verify { - configurationLoader.loadConfiguration(authorization, capture(callbackSlot)) + configurationLoader.loadConfiguration(capture(callbackSlot)) } - callbackSlot.captured.onResult(configuration, null, null) + callbackSlot.captured.onResult(ConfigurationLoaderResult.Success(configuration)) verify { analyticsClient.reportCrash( diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt index ba49fd8f50..586e79b127 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt @@ -1,43 +1,57 @@ package com.braintreepayments.api.core import android.util.Base64 -import com.braintreepayments.api.testutils.Fixtures import com.braintreepayments.api.sharedutils.HttpClient import com.braintreepayments.api.sharedutils.HttpResponse import com.braintreepayments.api.sharedutils.HttpResponseTiming import com.braintreepayments.api.sharedutils.NetworkResponseCallback -import io.mockk.* -import org.robolectric.RobolectricTestRunner +import com.braintreepayments.api.sharedutils.Time +import com.braintreepayments.api.testutils.Fixtures +import io.mockk.every +import io.mockk.mockk +import io.mockk.slot +import io.mockk.verify import org.json.JSONException -import org.junit.Assert.assertEquals +import org.junit.Before import org.junit.Test import org.junit.runner.RunWith -import java.lang.Exception +import org.robolectric.RobolectricTestRunner +import kotlin.test.assertEquals +import kotlin.test.assertTrue @RunWith(RobolectricTestRunner::class) class ConfigurationLoaderUnitTest { - private var configurationCache: ConfigurationCache = mockk(relaxed = true) - private var braintreeHttpClient: BraintreeHttpClient = mockk(relaxed = true) - private var callback: ConfigurationLoaderCallback = mockk(relaxed = true) - private var authorization: Authorization = mockk(relaxed = true) + private val configurationCache: ConfigurationCache = mockk(relaxed = true) + private val braintreeHttpClient: BraintreeHttpClient = mockk(relaxed = true) + private val callback: ConfigurationLoaderCallback = mockk(relaxed = true) + private val authorization: Authorization = mockk(relaxed = true) + private val merchantRepository: MerchantRepository = mockk(relaxed = true) + private val analyticsClient: AnalyticsClient = mockk(relaxed = true) + private val time: Time = mockk(relaxed = true) + + @Before + fun setUp() { + every { merchantRepository.authorization } returns authorization + } @Test fun loadConfiguration_loadsConfigurationForTheCurrentEnvironment() { every { authorization.configUrl } returns "https://example.com/config" + every { merchantRepository.authorization } returns authorization - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) val expectedConfigUrl = "https://example.com/config?configVersion=3" val callbackSlot = slot() verify { braintreeHttpClient.get( - expectedConfigUrl, - null, - authorization, - HttpClient.RETRY_MAX_3_TIMES, - capture(callbackSlot) + expectedConfigUrl, + null, + authorization, + HttpClient.RETRY_MAX_3_TIMES, + capture(callbackSlot) ) } @@ -46,7 +60,10 @@ class ConfigurationLoaderUnitTest { HttpResponse(Fixtures.CONFIGURATION_WITH_ACCESS_TOKEN, HttpResponseTiming(0, 0)), null ) - verify { callback.onResult(ofType(Configuration::class), null, HttpResponseTiming(0, 0)) } + val successSlot = slot() + verify { callback.onResult(capture(successSlot)) } + + assertTrue { successSlot.captured is ConfigurationLoaderResult.Success } } @Test @@ -54,18 +71,18 @@ class ConfigurationLoaderUnitTest { every { authorization.configUrl } returns "https://example.com/config" every { authorization.bearer } returns "bearer" - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) val expectedConfigUrl = "https://example.com/config?configVersion=3" val callbackSlot = slot() verify { braintreeHttpClient.get( - expectedConfigUrl, - null, - authorization, - HttpClient.RETRY_MAX_3_TIMES, - capture(callbackSlot) + expectedConfigUrl, + null, + authorization, + HttpClient.RETRY_MAX_3_TIMES, + capture(callbackSlot) ) } @@ -86,71 +103,72 @@ class ConfigurationLoaderUnitTest { @Test fun loadConfiguration_onJSONParsingError_forwardsExceptionToErrorResponseListener() { every { authorization.configUrl } returns "https://example.com/config" - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) val callbackSlot = slot() verify { braintreeHttpClient.get( - ofType(String::class), - null, - authorization, - HttpClient.RETRY_MAX_3_TIMES, - capture(callbackSlot) + ofType(String::class), + null, + authorization, + HttpClient.RETRY_MAX_3_TIMES, + capture(callbackSlot) ) } val httpResponseCallback = callbackSlot.captured httpResponseCallback.onResult(HttpResponse("not json", HttpResponseTiming(0, 0)), null) - verify { - callback.onResult(null, ofType(JSONException::class), null) - } + + val errorSlot = slot() + verify { callback.onResult(capture(errorSlot)) } + + assertTrue { (errorSlot.captured as ConfigurationLoaderResult.Failure).error is JSONException } } @Test fun loadConfiguration_onHttpError_forwardsExceptionToErrorResponseListener() { every { authorization.configUrl } returns "https://example.com/config" - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) val callbackSlot = slot() verify { braintreeHttpClient.get( - ofType(String::class), - null, - authorization, - HttpClient.RETRY_MAX_3_TIMES, - capture(callbackSlot) + ofType(String::class), + null, + authorization, + HttpClient.RETRY_MAX_3_TIMES, + capture(callbackSlot) ) } val httpResponseCallback = callbackSlot.captured val httpError = Exception("http error") httpResponseCallback.onResult(null, httpError) - val errorSlot = slot() - verify { - callback.onResult(null, capture(errorSlot), null) - } + val errorSlot = slot() + verify { callback.onResult(capture(errorSlot)) } - val error = errorSlot.captured as ConfigurationException assertEquals( - "Request for configuration has failed: http error", - error.message + (errorSlot.captured as ConfigurationLoaderResult.Failure).error.message, + "Request for configuration has failed: http error" ) } @Test - fun loadConfiguration_whenInvalidToken_forwardsExceptionToCallback() { - val authorization: Authorization = InvalidAuthorization("invalid", "token invalid") - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) - val errorSlot = slot() - verify { - callback.onResult(null, capture(errorSlot), null) - } + fun loadConfiguration_whenInvalidToken_exception_is_returned() { + every { merchantRepository.authorization } returns InvalidAuthorization("invalid", "token invalid") + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) + val errorSlot = slot() + verify { callback.onResult(capture(errorSlot)) } - val exception = errorSlot.captured - assertEquals("token invalid", exception.message) + assertEquals( + (errorSlot.captured as ConfigurationLoaderResult.Failure).error.message, + "Valid authorization required. See " + + "https://developer.paypal.com/braintree/docs/guides/client-sdk/setup/android/v4#initialization " + + "for more info." + ) } @Test @@ -163,18 +181,72 @@ class ConfigurationLoaderUnitTest { every { authorization.bearer } returns "bearer" every { configurationCache.getConfiguration(cacheKey) } returns Fixtures.CONFIGURATION_WITH_ACCESS_TOKEN - val sut = ConfigurationLoader(braintreeHttpClient, configurationCache) - sut.loadConfiguration(authorization, callback) + val sut = ConfigurationLoader(braintreeHttpClient, merchantRepository, configurationCache) + sut.loadConfiguration(callback) verify(exactly = 0) { braintreeHttpClient.get( - ofType(String::class), - null, - authorization, - ofType(Int::class), - ofType(NetworkResponseCallback::class) + ofType(String::class), + null, + authorization, + ofType(Int::class), + ofType(NetworkResponseCallback::class) + ) + } + + val successSlot = slot() + verify { callback.onResult(capture(successSlot)) } + + assertTrue { successSlot.captured is ConfigurationLoaderResult.Success } + } + + @Test + fun `when loadConfiguration is called and configuration is fetched from the API, analytics event is sent`() { + every { authorization.configUrl } returns "https://example.com/config" + every { merchantRepository.authorization } returns authorization + every { time.currentTime } returns 123 + + val sut = ConfigurationLoader( + httpClient = braintreeHttpClient, + merchantRepository = merchantRepository, + configurationCache = configurationCache, + time = time, + lazyAnalyticsClient = lazy { analyticsClient } + ) + sut.loadConfiguration(callback) + + val expectedConfigUrl = "https://example.com/config?configVersion=3" + val callbackSlot = slot() + verify { + braintreeHttpClient.get( + expectedConfigUrl, + null, + authorization, + HttpClient.RETRY_MAX_3_TIMES, + capture(callbackSlot) ) } - verify { callback.onResult(ofType(Configuration::class), null, null) } + + val httpResponseCallback = callbackSlot.captured + httpResponseCallback.onResult( + HttpResponse(Fixtures.CONFIGURATION_WITH_ACCESS_TOKEN, HttpResponseTiming(0, 10)), null + ) + + verify { + analyticsClient.sendEvent( + AnalyticsEvent( + name = CoreAnalytics.API_REQUEST_LATENCY, + timestamp = 123, + startTime = 0, + endTime = 10, + endpoint = "/v1/configuration" + ) + ) + } + + val successSlot = slot() + verify { callback.onResult(capture(successSlot)) } + + assertTrue { successSlot.captured is ConfigurationLoaderResult.Success } } } diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/MockkConfigurationLoaderBuilder.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/MockkConfigurationLoaderBuilder.kt index 38f7905861..e20efb196a 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/MockkConfigurationLoaderBuilder.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/MockkConfigurationLoaderBuilder.kt @@ -6,7 +6,7 @@ import io.mockk.mockk internal class MockkConfigurationLoaderBuilder { private var configuration: Configuration? = null - private var configurationError: Exception? = null + private lateinit var configurationError: Exception fun configuration(configuration: Configuration): MockkConfigurationLoaderBuilder { this.configuration = configuration @@ -20,12 +20,12 @@ internal class MockkConfigurationLoaderBuilder { fun build(): ConfigurationLoader { val configurationLoader = mockk(relaxed = true) - every { configurationLoader.loadConfiguration(any(), any()) } answers { - val callback = secondArg() - if (configuration != null) { - callback.onResult(configuration, null, null) - } else if (configurationError != null) { - callback.onResult(null, configurationError, null) + every { configurationLoader.loadConfiguration(any()) } answers { + val callback = firstArg() + configuration?.let { + callback.onResult(ConfigurationLoaderResult.Success(it)) + } ?: run { + callback.onResult(ConfigurationLoaderResult.Failure(configurationError)) } } return configurationLoader From 15daa429a05d7b710a623b21495a4cf404811ed3 Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Fri, 15 Nov 2024 08:18:17 -0700 Subject: [PATCH 07/22] update ShopperInsights demo (#1212) --- .../com/braintreepayments/demo/ShopperInsightsFragment.kt | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt b/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt index 32d1ca475e..65ad45b48e 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt +++ b/Demo/src/main/java/com/braintreepayments/demo/ShopperInsightsFragment.kt @@ -192,16 +192,16 @@ class ShopperInsightsFragment : BaseFragment() { if (result.response.isPayPalRecommended) { payPalVaultButton.isEnabled = true shopperInsightsClient.sendPayPalPresentedEvent( - "dummy_paypal_presented_experiment", - listOf("PayPal, Apple Pay, Google Pay") + """{"exp_name":"PaymentReady","treatment_name":"control"}""", + listOf("PayPal", "Venmo", "other") ) } if (result.response.isVenmoRecommended) { venmoButton.isEnabled = true shopperInsightsClient.sendVenmoPresentedEvent( - "dummy_venmo_presented_experiment", - listOf("Apple Pay, Venmo, Google Pay") + """{"exp_name":"PaymentReady","treatment_name":"test"}""", + listOf("Venmo", "PayPal", "other") ) } From 8add87736563c3cfe4e1e47f449a2d1db8c2e1f5 Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Fri, 15 Nov 2024 08:20:24 -0700 Subject: [PATCH 08/22] Update APP_LINK_SETUP.md (#1213) --- APP_LINK_SETUP.md | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/APP_LINK_SETUP.md b/APP_LINK_SETUP.md index 40e4d26c32..c48c54720f 100644 --- a/APP_LINK_SETUP.md +++ b/APP_LINK_SETUP.md @@ -8,9 +8,10 @@ Before using this feature, you must register your App Link domain in the Braintr 1. Log into your Control Panel (e.g. [Sandbox](https://sandbox.braintreegateway.com/login), or [Production](https://www.braintreegateway.com/login)). 2. Click on the **gear icon** in the top right corner. A drop-down menu will open. -3. Click **Processing** from the drop-down menu. -4. Scroll to the **Payment Methods** section. -5. Next to **PayPal**, click the **Options** link. This will take you to your linked PayPal Account(s) page. +3. Select **Account Settings** from the drop-down menu. +4. In the **Processing Options** tab, go to **Payment Methods** section. +5. Next to **PayPal**, click the **Link Sandbox** link. This will give you option to link your Braintree and PayPal accounts. + - If your accounts are already linked, you'd see an **Options** button instead. 6. Click the **View Domain Names** button. This will take you to the **PayPal Domain Names** page. - Note: If you have a single PayPal account, it will be at the bottom of the page. If you have multiple PayPal accounts, it will be at the top right of the page. 7. Click the **+ Add** link on the top right of the page or scroll to the **Specify Your Domain Names** section. From 0eda811522ae028dfd6007c273c87b8ed1fd16c3 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Fri, 15 Nov 2024 10:17:35 -0600 Subject: [PATCH 09/22] Expose AnalyticsClient to all modules (#1210) --- .../api/core/AnalyticsClient.kt | 23 ++++++++++++++++--- .../api/core/BraintreeClient.kt | 14 +---------- .../api/core/ConfigurationLoader.kt | 5 ++-- .../api/core/AnalyticsClientUnitTest.kt | 18 +++++++++------ .../api/core/BraintreeClientUnitTest.kt | 4 +--- .../api/core/ConfigurationLoaderUnitTest.kt | 5 ++-- 6 files changed, 37 insertions(+), 32 deletions(-) diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt index 339cd47707..d2f580d3b1 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt @@ -1,6 +1,7 @@ package com.braintreepayments.api.core import android.content.Context +import androidx.annotation.RestrictTo import androidx.work.Data import androidx.work.ExistingWorkPolicy import androidx.work.ListenableWorker @@ -13,8 +14,9 @@ import org.json.JSONObject import java.util.* import java.util.concurrent.TimeUnit +@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) @Suppress("SwallowedException", "TooGenericExceptionCaught") -internal class AnalyticsClient( +class AnalyticsClient internal constructor( private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), private val analyticsDatabase: AnalyticsDatabase = AnalyticsDatabaseProvider().analyticsDatabase, private val workManager: WorkManager = WorkManagerProvider().workManager, @@ -27,10 +29,25 @@ internal class AnalyticsClient( private val applicationContext: Context get() = merchantRepository.applicationContext - fun sendEvent(event: AnalyticsEvent) { + fun sendEvent( + eventName: String, + analyticsEventParams: AnalyticsEventParams = AnalyticsEventParams() + ) { + val analyticsEvent = AnalyticsEvent( + name = eventName, + timestamp = time.currentTime, + payPalContextId = analyticsEventParams.payPalContextId, + linkType = analyticsEventParams.linkType, + isVaultRequest = analyticsEventParams.isVaultRequest, + startTime = analyticsEventParams.startTime, + endTime = analyticsEventParams.endTime, + endpoint = analyticsEventParams.endpoint, + experiment = analyticsEventParams.experiment, + paymentMethodsDisplayed = analyticsEventParams.paymentMethodsDisplayed + ) configurationLoader.loadConfiguration { result -> if (result is ConfigurationLoaderResult.Success) { - scheduleAnalyticsWriteInBackground(event, merchantRepository.authorization) + scheduleAnalyticsWriteInBackground(analyticsEvent, merchantRepository.authorization) scheduleAnalyticsUploadInBackground( configuration = result.configuration, authorization = merchantRepository.authorization, diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt index 1b50b82002..efc3d56cab 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt @@ -101,19 +101,7 @@ class BraintreeClient internal constructor( eventName: String, params: AnalyticsEventParams = AnalyticsEventParams() ) { - val event = AnalyticsEvent( - name = eventName, - timestamp = time.currentTime, - payPalContextId = params.payPalContextId, - linkType = params.linkType, - isVaultRequest = params.isVaultRequest, - startTime = params.startTime, - endTime = params.endTime, - endpoint = params.endpoint, - experiment = params.experiment, - paymentMethodsDisplayed = params.paymentMethodsDisplayed - ) - analyticsClient.sendEvent(event) + analyticsClient.sendEvent(eventName, params) } /** diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt index 657c312415..99430577aa 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt @@ -52,9 +52,8 @@ internal class ConfigurationLoader( callback.onResult(ConfigurationLoaderResult.Success(configuration, timing)) analyticsClient.sendEvent( - AnalyticsEvent( - name = CoreAnalytics.API_REQUEST_LATENCY, - timestamp = time.currentTime, + eventName = CoreAnalytics.API_REQUEST_LATENCY, + analyticsEventParams = AnalyticsEventParams( startTime = timing?.startTime, endTime = timing?.endTime, endpoint = "/v1/configuration" diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt index 927a2d4364..50dd581f41 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt @@ -103,9 +103,7 @@ class AnalyticsClientUnitTest { ) } returns mockk() - val event = AnalyticsEvent(eventName, timestamp = 123) - - sut.sendEvent(event) + sut.sendEvent(eventName) val workSpec = workRequestSlot.captured.workSpec assertEquals(AnalyticsWriteToDbWorker::class.java.name, workSpec.workerClassName) @@ -142,7 +140,14 @@ class AnalyticsClientUnitTest { timestamp = 456 ) - sut.sendEvent(event) + sut.sendEvent( + eventName = eventName, + analyticsEventParams = AnalyticsEventParams( + payPalContextId = "fake-paypal-context-id", + linkType = "fake-link-type", + isVaultRequest = true, + ) + ) val workSpec = workRequestSlot.captured.workSpec assertEquals(30000, workSpec.initialDelay) @@ -528,8 +533,7 @@ class AnalyticsClientUnitTest { deviceInspector.getDeviceMetadata(context, configuration, sessionId, integration) } returns metadata - val event = AnalyticsEvent(eventName, timestamp) - sut.sendEvent(event) + sut.sendEvent(eventName) sut.reportCrash(context, configuration, integration, null) @@ -539,7 +543,7 @@ class AnalyticsClientUnitTest { @Test fun `sendEvent enqueues work to upload analytic events with sessionId in the name`() { - sut.sendEvent(AnalyticsEvent("event-name", timestamp)) + sut.sendEvent("event-name") verify { workManager.enqueueUniqueWork( diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt index 74f5e0d473..ecba21eace 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt @@ -326,9 +326,7 @@ class BraintreeClientUnitTest { sut.sendAnalyticsEvent("event.started") verify { - analyticsClient.sendEvent( - match { it.name == "event.started" && it.timestamp == 123L }, - ) + analyticsClient.sendEvent("event.started") } } diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt index 586e79b127..49501d9727 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt @@ -234,9 +234,8 @@ class ConfigurationLoaderUnitTest { verify { analyticsClient.sendEvent( - AnalyticsEvent( - name = CoreAnalytics.API_REQUEST_LATENCY, - timestamp = 123, + eventName = CoreAnalytics.API_REQUEST_LATENCY, + analyticsEventParams = AnalyticsEventParams( startTime = 0, endTime = 10, endpoint = "/v1/configuration" From 973452939180382510c01d4f371cb2c7df7d7dde Mon Sep 17 00:00:00 2001 From: Sarah Koop Date: Fri, 15 Nov 2024 15:56:54 -0600 Subject: [PATCH 10/22] Update PULL_REQUEST_TEMPLATE.MD (#1214) --- .github/PULL_REQUEST_TEMPLATE.MD | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/PULL_REQUEST_TEMPLATE.MD b/.github/PULL_REQUEST_TEMPLATE.MD index 884be23864..aff29f2ded 100644 --- a/.github/PULL_REQUEST_TEMPLATE.MD +++ b/.github/PULL_REQUEST_TEMPLATE.MD @@ -10,6 +10,7 @@ Thank you for your contribution to Braintree. - [ ] Added a changelog entry - [ ] Relevant test coverage + - [ ] Tested and confirmed payment flows affected by this change are functioning as expected ### Authors > List GitHub usernames for everyone who contributed to this pull request. From 9966290f91eea97bbc27850055c98d91f7368126 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Mon, 18 Nov 2024 15:00:00 -0600 Subject: [PATCH 11/22] Convert HttpClient to Kotlin (#1215) * Convert HttpClient to Kotlin * Convert SynchronousHttpClient to Kotlin * Delete old SynchronusHttpClient and fix detekt * Update SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.kt Co-authored-by: Jax DesMarais-Leder --------- Co-authored-by: Jax DesMarais-Leder --- .../api/core/BraintreeGraphQLClient.kt | 3 +- .../api/core/BraintreeHttpClient.kt | 9 +- .../api/core/ConfigurationLoader.kt | 2 +- .../api/core/BraintreeHttpClientUnitTest.kt | 10 +- .../api/core/ConfigurationLoaderUnitTest.kt | 12 +- .../api/sharedutils/HttpClient.java | 134 ------------------ .../api/sharedutils/HttpClient.kt | 110 ++++++++++++++ .../sharedutils/SynchronousHttpClient.java | 93 ------------ .../api/sharedutils/SynchronousHttpClient.kt | 66 +++++++++ .../api/sharedutils/HttpClientUnitTest.java | 28 ++-- .../SynchronousHttpClientUnitTest.java | 52 ------- 11 files changed, 207 insertions(+), 312 deletions(-) delete mode 100644 SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.java create mode 100644 SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.kt delete mode 100644 SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.java create mode 100644 SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeGraphQLClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeGraphQLClient.kt index 5accb21b41..5692a181bd 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeGraphQLClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeGraphQLClient.kt @@ -85,8 +85,7 @@ internal class BraintreeGraphQLClient( @Throws(SSLException::class) private fun createDefaultHttpClient(): HttpClient { - val socketFactory = - TLSSocketFactory(TLSCertificatePinning.createCertificateInputStream()) + val socketFactory = TLSSocketFactory(TLSCertificatePinning.createCertificateInputStream()) return HttpClient(socketFactory, BraintreeGraphQLResponseParser()) } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeHttpClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeHttpClient.kt index a5c1b848b2..be7d7b7f49 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeHttpClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeHttpClient.kt @@ -30,7 +30,7 @@ internal class BraintreeHttpClient( configuration: Configuration?, authorization: Authorization?, callback: NetworkResponseCallback - ) = get(path, configuration, authorization, HttpClient.NO_RETRY, callback) + ) = get(path, configuration, authorization, RetryStrategy.NO_RETRY, callback) /** * Make a HTTP GET request to Braintree using the base url, path and authorization provided. @@ -45,7 +45,7 @@ internal class BraintreeHttpClient( path: String, configuration: Configuration?, authorization: Authorization?, - @RetryStrategy retryStrategy: Int, + retryStrategy: RetryStrategy, callback: NetworkResponseCallback ) { if (authorization is InvalidAuthorization) { @@ -76,7 +76,7 @@ internal class BraintreeHttpClient( if (authorization is TokenizationKey) { request.addHeader(CLIENT_KEY_HEADER, authorization.bearer) } - httpClient.sendRequest(request, retryStrategy, callback) + httpClient.sendRequest(request, callback, retryStrategy) } /** @@ -185,8 +185,7 @@ internal class BraintreeHttpClient( @Throws(SSLException::class) private fun createDefaultHttpClient(): HttpClient { - val socketFactory = - TLSSocketFactory(TLSCertificatePinning.createCertificateInputStream()) + val socketFactory = TLSSocketFactory(TLSCertificatePinning.createCertificateInputStream()) return HttpClient(socketFactory, BraintreeHttpResponseParser()) } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt index 99430577aa..4c28e0f5a4 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt @@ -41,7 +41,7 @@ internal class ConfigurationLoader( callback.onResult(ConfigurationLoaderResult.Success(it)) } ?: run { httpClient.get( - configUrl, null, authorization, HttpClient.RETRY_MAX_3_TIMES + configUrl, null, authorization, HttpClient.RetryStrategy.RETRY_MAX_3_TIMES ) { response, httpError -> val responseBody = response?.body val timing = response?.timing diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeHttpClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeHttpClientUnitTest.kt index 8cb6e8439c..8b0e600d7d 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeHttpClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeHttpClientUnitTest.kt @@ -1,10 +1,10 @@ package com.braintreepayments.api.core -import com.braintreepayments.api.testutils.Fixtures -import com.braintreepayments.api.testutils.FixturesHelper import com.braintreepayments.api.sharedutils.HttpClient import com.braintreepayments.api.sharedutils.HttpRequest import com.braintreepayments.api.sharedutils.NetworkResponseCallback +import com.braintreepayments.api.testutils.Fixtures +import com.braintreepayments.api.testutils.FixturesHelper import io.mockk.every import io.mockk.just import io.mockk.mockk @@ -62,7 +62,7 @@ class BraintreeHttpClientUnitTest { val httpRequestSlot = slot() every { - httpClient.sendRequest(capture(httpRequestSlot), HttpClient.NO_RETRY, callback) + httpClient.sendRequest(capture(httpRequestSlot), callback, HttpClient.RetryStrategy.NO_RETRY) } returns Unit val sut = BraintreeHttpClient(httpClient) @@ -82,7 +82,7 @@ class BraintreeHttpClientUnitTest { val httpRequestSlot = slot() val callback = mockk() every { - httpClient.sendRequest(capture(httpRequestSlot), HttpClient.NO_RETRY, callback) + httpClient.sendRequest(capture(httpRequestSlot), callback, HttpClient.RetryStrategy.NO_RETRY) } returns Unit val sut = BraintreeHttpClient(httpClient) @@ -107,7 +107,7 @@ class BraintreeHttpClientUnitTest { val httpRequestSlot = slot() val callback = mockk() every { - httpClient.sendRequest(capture(httpRequestSlot), HttpClient.NO_RETRY, callback) + httpClient.sendRequest(capture(httpRequestSlot), callback, HttpClient.RetryStrategy.NO_RETRY) } returns Unit val sut = BraintreeHttpClient(httpClient) diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt index 49501d9727..5eebabb78a 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/ConfigurationLoaderUnitTest.kt @@ -50,7 +50,7 @@ class ConfigurationLoaderUnitTest { expectedConfigUrl, null, authorization, - HttpClient.RETRY_MAX_3_TIMES, + HttpClient.RetryStrategy.RETRY_MAX_3_TIMES, capture(callbackSlot) ) } @@ -81,7 +81,7 @@ class ConfigurationLoaderUnitTest { expectedConfigUrl, null, authorization, - HttpClient.RETRY_MAX_3_TIMES, + HttpClient.RetryStrategy.RETRY_MAX_3_TIMES, capture(callbackSlot) ) } @@ -112,7 +112,7 @@ class ConfigurationLoaderUnitTest { ofType(String::class), null, authorization, - HttpClient.RETRY_MAX_3_TIMES, + HttpClient.RetryStrategy.RETRY_MAX_3_TIMES, capture(callbackSlot) ) } @@ -138,7 +138,7 @@ class ConfigurationLoaderUnitTest { ofType(String::class), null, authorization, - HttpClient.RETRY_MAX_3_TIMES, + HttpClient.RetryStrategy.RETRY_MAX_3_TIMES, capture(callbackSlot) ) } @@ -189,7 +189,7 @@ class ConfigurationLoaderUnitTest { ofType(String::class), null, authorization, - ofType(Int::class), + any(), ofType(NetworkResponseCallback::class) ) } @@ -222,7 +222,7 @@ class ConfigurationLoaderUnitTest { expectedConfigUrl, null, authorization, - HttpClient.RETRY_MAX_3_TIMES, + HttpClient.RetryStrategy.RETRY_MAX_3_TIMES, capture(callbackSlot) ) } diff --git a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.java b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.java deleted file mode 100644 index 0453489960..0000000000 --- a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.java +++ /dev/null @@ -1,134 +0,0 @@ -package com.braintreepayments.api.sharedutils; - -import androidx.annotation.IntDef; -import androidx.annotation.RestrictTo; -import androidx.annotation.VisibleForTesting; - -import java.lang.annotation.Retention; -import java.lang.annotation.RetentionPolicy; -import java.net.MalformedURLException; -import java.net.URISyntaxException; -import java.net.URL; -import java.util.HashMap; -import java.util.Map; - -import javax.net.ssl.SSLSocketFactory; - -@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) -public class HttpClient { - - @IntDef({NO_RETRY, RETRY_MAX_3_TIMES}) - @Retention(RetentionPolicy.SOURCE) - public @interface RetryStrategy { - } - - public static final int NO_RETRY = 0; - public static final int RETRY_MAX_3_TIMES = 1; - - static final int MAX_RETRY_ATTEMPTS = 3; - - private final Scheduler scheduler; - private final SynchronousHttpClient syncHttpClient; - - private final Map retryCountMap; - - public HttpClient(SSLSocketFactory socketFactory, HttpResponseParser httpResponseParser) { - this(new SynchronousHttpClient(socketFactory, httpResponseParser), new ThreadScheduler()); - } - - @VisibleForTesting - HttpClient(SynchronousHttpClient syncHttpClient, Scheduler scheduler) { - this.syncHttpClient = syncHttpClient; - this.scheduler = scheduler; - this.retryCountMap = new HashMap<>(); - } - - public String sendRequest(HttpRequest request) throws Exception { - return syncHttpClient.request(request).getBody(); - } - - public void sendRequest(HttpRequest request, NetworkResponseCallback callback) { - sendRequest(request, HttpClient.NO_RETRY, callback); - } - - public void sendRequest(HttpRequest request, @RetryStrategy int retryStrategy, - NetworkResponseCallback callback) { - scheduleRequest(request, retryStrategy, callback); - } - - private void scheduleRequest(final HttpRequest request, @RetryStrategy final int retryStrategy, - final NetworkResponseCallback callback) { - resetRetryCount(request); - - scheduler.runOnBackground(() -> { - try { - HttpResponse httpResponse = syncHttpClient.request(request); - notifySuccessOnMainThread(callback, httpResponse); - } catch (Exception e) { - switch (retryStrategy) { - case HttpClient.NO_RETRY: - notifyErrorOnMainThread(callback, e); - break; - case HttpClient.RETRY_MAX_3_TIMES: - retryGet(request, retryStrategy, callback); - break; - } - } - }); - } - - private void retryGet(final HttpRequest request, @RetryStrategy final int retryStrategy, - final NetworkResponseCallback callback) { - URL url = null; - try { - url = request.getURL(); - } catch (MalformedURLException | URISyntaxException ignore) { - } - - if (url != null) { - int retryCount = getNumRetriesSoFar(url); - boolean shouldRetry = ((retryCount + 1) < MAX_RETRY_ATTEMPTS); - if (shouldRetry) { - scheduleRequest(request, retryStrategy, callback); - retryCountMap.put(url, retryCount + 1); - } else { - String message = "Retry limit has been exceeded. Try again later."; - HttpClientException retryLimitException = new HttpClientException(message); - notifyErrorOnMainThread(callback, retryLimitException); - } - } - } - - private int getNumRetriesSoFar(URL url) { - Integer retryCount = retryCountMap.get(url); - if (retryCount == null) { - return 0; - } - return retryCount; - } - - private void resetRetryCount(HttpRequest request) { - URL url = null; - try { - url = request.getURL(); - } catch (MalformedURLException | URISyntaxException ignore) { - } - - if (url != null) { - retryCountMap.remove(url); - } - } - - private void notifySuccessOnMainThread(final NetworkResponseCallback callback, - final HttpResponse response) { - if (callback != null) { - scheduler.runOnMain(() -> callback.onResult(response, null)); - } - } - - private void notifyErrorOnMainThread(final NetworkResponseCallback callback, final Exception e) { - if (callback != null) { - scheduler.runOnMain(() -> callback.onResult(null, e)); - } - } -} diff --git a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.kt b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.kt new file mode 100644 index 0000000000..169d3e6eca --- /dev/null +++ b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/HttpClient.kt @@ -0,0 +1,110 @@ +package com.braintreepayments.api.sharedutils + +import androidx.annotation.RestrictTo +import java.net.MalformedURLException +import java.net.URISyntaxException +import java.net.URL +import javax.net.ssl.SSLSocketFactory + +@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) +class HttpClient internal constructor( + private val syncHttpClient: SynchronousHttpClient, + private val scheduler: Scheduler +) { + enum class RetryStrategy { NO_RETRY, RETRY_MAX_3_TIMES } + + private val retryCountMap: MutableMap = HashMap() + + constructor( + socketFactory: SSLSocketFactory, + httpResponseParser: HttpResponseParser + ) : this( + syncHttpClient = SynchronousHttpClient(socketFactory, httpResponseParser), + scheduler = ThreadScheduler() + ) + + @Throws(Exception::class) + fun sendRequest(request: HttpRequest): String { + return syncHttpClient.request(request).body ?: "" + } + + fun sendRequest( + request: HttpRequest, + callback: NetworkResponseCallback?, + retryStrategy: RetryStrategy = RetryStrategy.NO_RETRY, + ) { + scheduleRequest(request, retryStrategy, callback) + } + + @Suppress("TooGenericExceptionCaught") + private fun scheduleRequest( + request: HttpRequest, + retryStrategy: RetryStrategy, + callback: NetworkResponseCallback? + ) { + resetRetryCount(request) + + scheduler.runOnBackground { + try { + val httpResponse = syncHttpClient.request(request) + callback?.let { + scheduler.runOnMain { callback.onResult(httpResponse, null) } + } + } catch (e: Exception) { + when (retryStrategy) { + RetryStrategy.NO_RETRY -> notifyErrorOnMainThread(callback, e) + RetryStrategy.RETRY_MAX_3_TIMES -> retryGet(request, retryStrategy, callback) + } + } + } + } + + private fun retryGet( + request: HttpRequest, + retryStrategy: RetryStrategy, + callback: NetworkResponseCallback? + ) { + var url: URL? = null + try { + url = request.url + } catch (ignore: MalformedURLException) { + } catch (ignore: URISyntaxException) { + } + + if (url != null) { + val retryCount = getNumRetriesSoFar(url) + val shouldRetry = ((retryCount + 1) < MAX_RETRY_ATTEMPTS) + if (shouldRetry) { + scheduleRequest(request, retryStrategy, callback) + retryCountMap[url] = retryCount + 1 + } else { + val message = "Retry limit has been exceeded. Try again later." + val retryLimitException = HttpClientException(message) + notifyErrorOnMainThread(callback, retryLimitException) + } + } + } + + private fun getNumRetriesSoFar(url: URL): Int { + val retryCount = retryCountMap[url] ?: return 0 + return retryCount + } + + private fun resetRetryCount(request: HttpRequest) { + try { + request.url?.let { retryCountMap.remove(it) } + } catch (ignore: MalformedURLException) { + } catch (ignore: URISyntaxException) { + } + } + + private fun notifyErrorOnMainThread(callback: NetworkResponseCallback?, e: Exception) { + if (callback != null) { + scheduler.runOnMain { callback.onResult(null, e) } + } + } + + companion object { + private const val MAX_RETRY_ATTEMPTS: Int = 3 + } +} diff --git a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.java b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.java deleted file mode 100644 index 8cccfbf5e8..0000000000 --- a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.java +++ /dev/null @@ -1,93 +0,0 @@ -package com.braintreepayments.api.sharedutils; - -import androidx.annotation.RestrictTo; - -import java.io.OutputStream; -import java.net.HttpURLConnection; -import java.net.URL; -import java.util.Map; - -import javax.net.ssl.HttpsURLConnection; -import javax.net.ssl.SSLException; -import javax.net.ssl.SSLSocketFactory; - -/** - * This class performs an http request on the calling thread. The external caller is - * responsible for thread scheduling to ensure that this is not called on the main thread. - */ -@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) -class SynchronousHttpClient { - - private SSLSocketFactory socketFactory; - private final HttpResponseParser parser; - - SynchronousHttpClient(SSLSocketFactory socketFactory, HttpResponseParser parser) { - this.parser = parser; - if (socketFactory != null) { - this.socketFactory = socketFactory; - } else { - try { - this.socketFactory = TLSSocketFactory.newInstance(); - } catch (SSLException e) { - this.socketFactory = null; - } - } - } - - void setSSLSocketFactory(SSLSocketFactory socketFactory) { - this.socketFactory = socketFactory; - } - - HttpResponse request(HttpRequest httpRequest) throws Exception { - if (httpRequest.getPath() == null) { - throw new IllegalArgumentException("Path cannot be null"); - } - URL url = httpRequest.getURL(); - - long startTime = System.currentTimeMillis(); - - HttpURLConnection connection = (HttpURLConnection) url.openConnection(); - if (connection instanceof HttpsURLConnection) { - if (socketFactory == null) { - throw new SSLException("SSLSocketFactory was not set or failed to initialize"); - } - ((HttpsURLConnection) connection).setSSLSocketFactory(socketFactory); - } - - String requestMethod = httpRequest.getMethod(); - connection.setRequestMethod(requestMethod); - - connection.setReadTimeout(httpRequest.getReadTimeout()); - connection.setConnectTimeout(httpRequest.getConnectTimeout()); - - // apply request headers - Map headers = httpRequest.getHeaders(); - for (Map.Entry entry : headers.entrySet()) { - connection.setRequestProperty(entry.getKey(), entry.getValue()); - } - - if (requestMethod != null && requestMethod.equals("POST")) { - connection.setRequestProperty("Content-Type", "application/json"); - connection.setDoOutput(true); - - OutputStream outputStream = connection.getOutputStream(); - outputStream.write(httpRequest.getData()); - outputStream.flush(); - outputStream.close(); - - httpRequest.dispose(); - } - - try { - int responseCode = connection.getResponseCode(); - long endTime = System.currentTimeMillis(); - - String responseBody = parser.parse(responseCode, connection); - - HttpResponseTiming timing = new HttpResponseTiming(startTime, endTime); - return new HttpResponse(responseBody, timing); - } finally { - connection.disconnect(); - } - } -} diff --git a/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.kt b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.kt new file mode 100644 index 0000000000..9584c124b0 --- /dev/null +++ b/SharedUtils/src/main/java/com/braintreepayments/api/sharedutils/SynchronousHttpClient.kt @@ -0,0 +1,66 @@ +package com.braintreepayments.api.sharedutils + +import androidx.annotation.RestrictTo +import java.net.HttpURLConnection +import javax.net.ssl.HttpsURLConnection +import javax.net.ssl.SSLSocketFactory + +/** + * This class performs an http request on the calling thread. The external caller is + * responsible for thread scheduling to ensure that this is not called on the main thread. + */ +@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) +internal class SynchronousHttpClient( + private val socketFactory: SSLSocketFactory, + private val parser: HttpResponseParser +) { + + @Throws(Exception::class) + fun request(httpRequest: HttpRequest): HttpResponse { + requireNotNull(httpRequest.path) { "Path cannot be null" } + + val url = httpRequest.url + val startTime = System.currentTimeMillis() + + val connection = url.openConnection() as HttpURLConnection + if (connection is HttpsURLConnection) { + connection.sslSocketFactory = socketFactory + } + + val requestMethod = httpRequest.method + connection.requestMethod = requestMethod + + connection.readTimeout = httpRequest.readTimeout + connection.connectTimeout = httpRequest.connectTimeout + + // apply request headers + val headers = httpRequest.headers + for ((key, value) in headers) { + connection.setRequestProperty(key, value) + } + + if (requestMethod != null && requestMethod == "POST") { + connection.setRequestProperty("Content-Type", "application/json") + connection.doOutput = true + + val outputStream = connection.outputStream + outputStream.write(httpRequest.data) + outputStream.flush() + outputStream.close() + + httpRequest.dispose() + } + + try { + val responseCode = connection.responseCode + val endTime = System.currentTimeMillis() + + return HttpResponse( + body = parser.parse(responseCode, connection), + timing = HttpResponseTiming(startTime, endTime) + ) + } finally { + connection.disconnect() + } + } +} diff --git a/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/HttpClientUnitTest.java b/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/HttpClientUnitTest.java index 79e114b8e9..2d038b1f2e 100644 --- a/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/HttpClientUnitTest.java +++ b/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/HttpClientUnitTest.java @@ -36,7 +36,7 @@ public void sendRequest_sendsRequestOnBackgroundThread() throws Exception { HttpClient sut = new HttpClient(syncHttpClient, threadScheduler); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.NO_RETRY); verifyNoInteractions(syncHttpClient); threadScheduler.flushBackgroundThread(); @@ -46,14 +46,14 @@ public void sendRequest_sendsRequestOnBackgroundThread() throws Exception { @Test public void sendRequest_whenBaseHttpClientThrowsException_notifiesErrorViaCallbackOnMainThread() - throws Exception { + throws Exception { HttpClient sut = new HttpClient(syncHttpClient, threadScheduler); Exception exception = new Exception("error"); when(syncHttpClient.request(httpRequest)).thenThrow(exception); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.NO_RETRY); threadScheduler.flushBackgroundThread(); verify(callback, never()).onResult(null, exception); @@ -64,14 +64,14 @@ public void sendRequest_whenBaseHttpClientThrowsException_notifiesErrorViaCallba @Test public void sendRequest_onBaseHttpClientRequestSuccess_notifiesSuccessViaCallbackOnMainThread() - throws Exception { + throws Exception { HttpClient sut = new HttpClient(syncHttpClient, threadScheduler); HttpResponse response = new HttpResponse("response body", new HttpResponseTiming(123, 456)); when(syncHttpClient.request(httpRequest)).thenReturn(response); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.NO_RETRY); threadScheduler.flushBackgroundThread(); verify(callback, never()).onResult(response, null); @@ -86,7 +86,7 @@ public void sendRequest_whenCallbackIsNull_doesNotNotifySuccess() throws Excepti HttpResponse response = new HttpResponse("response body", new HttpResponseTiming(123, 456)); when(syncHttpClient.request(httpRequest)).thenReturn(response); - sut.sendRequest(httpRequest, null); + sut.sendRequest(httpRequest, null, HttpClient.RetryStrategy.NO_RETRY); threadScheduler.flushBackgroundThread(); verify(threadScheduler, never()).runOnMain(any(Runnable.class)); @@ -99,7 +99,7 @@ public void sendRequest_whenCallbackIsNull_doesNotNotifyError() throws Exception Exception exception = new Exception("error"); when(syncHttpClient.request(httpRequest)).thenThrow(exception); - sut.sendRequest(httpRequest, null); + sut.sendRequest(httpRequest, null, HttpClient.RetryStrategy.NO_RETRY); threadScheduler.flushBackgroundThread(); verify(threadScheduler, never()).runOnMain(any(Runnable.class)); @@ -113,7 +113,7 @@ public void sendRequest_whenRetryMax3TimesEnabled_retriesRequest3Times() throws when(syncHttpClient.request(httpRequest)).thenThrow(exception); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, HttpClient.RETRY_MAX_3_TIMES, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.RETRY_MAX_3_TIMES); threadScheduler.flushBackgroundThread(); verify(syncHttpClient, times(3)).request(httpRequest); @@ -121,14 +121,14 @@ public void sendRequest_whenRetryMax3TimesEnabled_retriesRequest3Times() throws @Test public void sendRequest_whenRetryMax3TimesEnabled_notifiesMaxRetriesLimitExceededOnForegroundThread() - throws Exception { + throws Exception { HttpClient sut = new HttpClient(syncHttpClient, threadScheduler); Exception exception = new Exception("error"); when(syncHttpClient.request(httpRequest)).thenThrow(exception); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, HttpClient.RETRY_MAX_3_TIMES, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.RETRY_MAX_3_TIMES); threadScheduler.flushBackgroundThread(); verify(callback, never()).onResult((HttpResponse) isNull(), any(Exception.class)); @@ -152,15 +152,15 @@ public void sendRequest_whenRetryMax3TimesEnabled_futureRequestsAreAllowed() thr when(syncHttpClient.request(httpRequest)).thenThrow(exception); NetworkResponseCallback callback = mock(NetworkResponseCallback.class); - sut.sendRequest(httpRequest, HttpClient.RETRY_MAX_3_TIMES, callback); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.RETRY_MAX_3_TIMES); threadScheduler.flushBackgroundThread(); reset(syncHttpClient); when(syncHttpClient.request(httpRequest)) - .thenThrow(exception) - .thenReturn(response); - sut.sendRequest(httpRequest, HttpClient.RETRY_MAX_3_TIMES, callback); + .thenThrow(exception) + .thenReturn(response); + sut.sendRequest(httpRequest, callback, HttpClient.RetryStrategy.RETRY_MAX_3_TIMES); threadScheduler.flushBackgroundThread(); threadScheduler.flushMainThread(); diff --git a/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/SynchronousHttpClientUnitTest.java b/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/SynchronousHttpClientUnitTest.java index 06dbec62e6..56da950aae 100644 --- a/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/SynchronousHttpClientUnitTest.java +++ b/SharedUtils/src/test/java/com/braintreepayments/api/sharedutils/SynchronousHttpClientUnitTest.java @@ -94,28 +94,6 @@ public void request_setsRequestMethod() throws Exception { verify(connection).setRequestMethod("GET"); } - @Test - public void request_whenConnectionIsHttps_usesDefaultSSLSocketFactoryWhenNoFactoryIsSet() - throws Exception { - final HttpRequest httpRequest = spy(new HttpRequest() - .path("sample/path") - .method("GET") - .baseUrl("https://www.sample.com")); - - URL url = mock(URL.class); - when(httpRequest.getURL()).thenReturn(url); - - HttpsURLConnection connection = mock(HttpsURLConnection.class); - when(url.openConnection()).thenReturn(connection); - - when(connection.getResponseCode()).thenReturn(200); - when(httpResponseParser.parse(200, connection)).thenReturn("http_ok"); - - SynchronousHttpClient sut = new SynchronousHttpClient(null, httpResponseParser); - sut.request(httpRequest); - verify(connection).setSSLSocketFactory(any(TLSSocketFactory.class)); - } - @Test public void request_whenConnectionIsHttps_setsSSLSocketFactory() throws Exception { final HttpRequest httpRequest = spy(new HttpRequest() @@ -137,36 +115,6 @@ public void request_whenConnectionIsHttps_setsSSLSocketFactory() throws Exceptio verify(connection).setSSLSocketFactory(sslSocketFactory); } - @Test - public void request_whenConnectionIsHttps_andSSLSocketFactoryIsNull_throwsSSLException() - throws Exception { - final HttpRequest httpRequest = spy(new HttpRequest() - .path("sample/path") - .method("GET") - .baseUrl("https://www.sample.com")); - - URL url = mock(URL.class); - when(httpRequest.getURL()).thenReturn(url); - - HttpsURLConnection connection = mock(HttpsURLConnection.class); - when(url.openConnection()).thenReturn(connection); - - when(connection.getResponseCode()).thenReturn(200); - when(httpResponseParser.parse(200, connection)).thenReturn("http_ok"); - - final SynchronousHttpClient sut = new SynchronousHttpClient(null, httpResponseParser); - sut.setSSLSocketFactory(null); - SSLException exception = assertThrows(SSLException.class, new ThrowingRunnable() { - @Override - public void run() throws Throwable { - sut.request(httpRequest); - } - }); - - assertEquals(exception.getMessage(), - "SSLSocketFactory was not set or failed to initialize"); - } - @Test public void request_setsHttpReadTimeout() throws Exception { final HttpRequest httpRequest = spy(new HttpRequest() From 12e3bb0c472d9adda8fdda93d49d8957d1299d3f Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Thu, 21 Nov 2024 11:39:05 -0600 Subject: [PATCH 12/22] Add app switch analytics calls for Venmo (#1218) * WIP - Add app switch analytics calls for Venmo * refactoring * fix tests * Add url parameter for passing the appSwitchUrl for Venmo analytic events * Save Venmo URL to VenmoRepository and send value with Venmo analytic events * Venmo Analytics - add additional app switch and handle return events --------- Co-authored-by: Sai --- .../api/core/AnalyticsClient.kt | 9 +- .../api/core/AnalyticsEvent.kt | 3 +- .../api/core/AnalyticsEventParams.kt | 3 +- .../api/core/ConfigurationLoader.kt | 4 +- .../api/core/AnalyticsClientUnitTest.kt | 7 +- .../api/venmo/VenmoAnalytics.kt | 9 +- .../api/venmo/VenmoClient.kt | 5 +- .../api/venmo/VenmoLauncher.kt | 56 +++- .../api/venmo/VenmoRepository.kt | 22 ++ .../api/venmo/VenmoClientUnitTest.java | 306 ++++++++++-------- .../api/venmo/VenmoLauncherUnitTest.kt | 133 +++++++- 11 files changed, 401 insertions(+), 156 deletions(-) create mode 100644 Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoRepository.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt index d2f580d3b1..6f5a893139 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsClient.kt @@ -26,6 +26,7 @@ class AnalyticsClient internal constructor( private val configurationLoader: ConfigurationLoader = ConfigurationLoader.instance, private val merchantRepository: MerchantRepository = MerchantRepository.instance ) { + private val applicationContext: Context get() = merchantRepository.applicationContext @@ -43,7 +44,8 @@ class AnalyticsClient internal constructor( endTime = analyticsEventParams.endTime, endpoint = analyticsEventParams.endpoint, experiment = analyticsEventParams.experiment, - paymentMethodsDisplayed = analyticsEventParams.paymentMethodsDisplayed + paymentMethodsDisplayed = analyticsEventParams.paymentMethodsDisplayed, + appSwitchUrl = analyticsEventParams.appSwitchUrl ) configurationLoader.loadConfiguration { result -> if (result is ConfigurationLoaderResult.Success) { @@ -239,6 +241,7 @@ class AnalyticsClient internal constructor( .putOpt(FPTI_KEY_MERCHANT_EXPERIMENT, event.experiment) .putOpt(FPTI_KEY_MERCHANT_PAYMENT_METHODS_DISPLAYED, event.paymentMethodsDisplayed.ifEmpty { null }) + .putOpt(FPTI_KEY_URL, event.appSwitchUrl) return json.toString() } @@ -270,6 +273,9 @@ class AnalyticsClient internal constructor( } companion object { + + val lazyInstance: Lazy = lazy { AnalyticsClient() } + private const val FPTI_ANALYTICS_URL = "https://api-m.paypal.com/v1/tracking/batch/events" private const val FPTI_KEY_PAYPAL_CONTEXT_ID = "paypal_context_id" @@ -288,6 +294,7 @@ class AnalyticsClient internal constructor( private const val FPTI_KEY_ENDPOINT = "endpoint" private const val FPTI_KEY_MERCHANT_EXPERIMENT = "experiment" private const val FPTI_KEY_MERCHANT_PAYMENT_METHODS_DISPLAYED = "payment_methods_displayed" + private const val FPTI_KEY_URL = "url" private const val FPTI_BATCH_KEY_VENMO_INSTALLED = "venmo_installed" private const val FPTI_BATCH_KEY_PAYPAL_INSTALLED = "paypal_installed" diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEvent.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEvent.kt index ba56b2a6ff..f4278b9816 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEvent.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEvent.kt @@ -15,5 +15,6 @@ internal data class AnalyticsEvent( val endTime: Long? = null, val endpoint: String? = null, val experiment: String? = null, - val paymentMethodsDisplayed: List = emptyList() + val paymentMethodsDisplayed: List = emptyList(), + val appSwitchUrl: String? = null ) diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEventParams.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEventParams.kt index a8a9cd4605..fa309fb55b 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEventParams.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/AnalyticsEventParams.kt @@ -27,5 +27,6 @@ data class AnalyticsEventParams @JvmOverloads constructor( var endTime: Long? = null, var endpoint: String? = null, val experiment: String? = null, - val paymentMethodsDisplayed: List = emptyList() + val paymentMethodsDisplayed: List = emptyList(), + val appSwitchUrl: String? = null ) diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt index 4c28e0f5a4..cbd415cb6a 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/ConfigurationLoader.kt @@ -15,7 +15,9 @@ internal class ConfigurationLoader( * TODO: AnalyticsClient must be lazy due to the circular dependency between ConfigurationLoader and AnalyticsClient * This should be refactored to remove the circular dependency. */ - lazyAnalyticsClient: Lazy = lazy { AnalyticsClient(httpClient) }, + lazyAnalyticsClient: Lazy = lazy { + AnalyticsClient(httpClient = httpClient) + }, ) { private val analyticsClient: AnalyticsClient by lazyAnalyticsClient diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt index 50dd581f41..c18742f405 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/AnalyticsClientUnitTest.kt @@ -47,6 +47,7 @@ class AnalyticsClientUnitTest { private lateinit var sut: AnalyticsClient private var timestamp: Long = 0 + private val returnUrlScheme = "com.braintreepayments.demo.braintree" @Before @Throws(InvalidArgumentException::class, GeneralSecurityException::class, IOException::class) @@ -74,6 +75,7 @@ class AnalyticsClientUnitTest { every { time.currentTime } returns 123 every { merchantRepository.authorization } returns authorization every { merchantRepository.applicationContext } returns context + every { merchantRepository.returnUrlScheme } returns returnUrlScheme configurationLoader = MockkConfigurationLoaderBuilder() .configuration(configuration) @@ -103,7 +105,7 @@ class AnalyticsClientUnitTest { ) } returns mockk() - sut.sendEvent(eventName) + sut.sendEvent(eventName, AnalyticsEventParams(appSwitchUrl = returnUrlScheme)) val workSpec = workRequestSlot.captured.workSpec assertEquals(AnalyticsWriteToDbWorker::class.java.name, workSpec.workerClassName) @@ -115,7 +117,8 @@ class AnalyticsClientUnitTest { "event_name": "sample-event-name", "t": 123, "is_vault": false, - "tenant_name": "Braintree" + "tenant_name": "Braintree", + "url": "$returnUrlScheme" } """ val actualJSON = workSpec.input.getString(WORK_INPUT_KEY_ANALYTICS_JSON)!! diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoAnalytics.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoAnalytics.kt index 119b12b9a6..19319683c1 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoAnalytics.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoAnalytics.kt @@ -8,7 +8,14 @@ internal object VenmoAnalytics { const val TOKENIZE_SUCCEEDED = "venmo:tokenize:succeeded" const val APP_SWITCH_CANCELED = "venmo:tokenize:app-switch:canceled" - // Additional Detail Events + // Launching App Switch events + const val APP_SWITCH_STARTED = "venmo:tokenize:app-switch:started" const val APP_SWITCH_SUCCEEDED = "venmo:tokenize:app-switch:succeeded" const val APP_SWITCH_FAILED = "venmo:tokenize:app-switch:failed" + + // Handle return events + const val HANDLE_RETURN_STARTED = "venmo:tokenize:handle-return:started" + const val HANDLE_RETURN_SUCCEEDED = "venmo:tokenize:handle-return:succeeded" + const val HANDLE_RETURN_FAILED = "venmo:tokenize:handle-return:failed" + const val HANDLE_RETURN_NO_RESULT = "venmo:tokenize:handle-return:no-result" } diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt index 764c51b45e..a7748e07a7 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt @@ -32,6 +32,7 @@ class VenmoClient internal constructor( private val sharedPrefsWriter: VenmoSharedPrefsWriter = VenmoSharedPrefsWriter(), private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, private val merchantRepository: MerchantRepository = MerchantRepository.instance, + private val venmoRepository: VenmoRepository = VenmoRepository.instance ) { /** * Used for linking events from the client to server side request @@ -183,6 +184,8 @@ class VenmoClient internal constructor( .appendQueryParameter("customerClient", "MOBILE_APP") .build() + venmoRepository.venmoUrl = venmoBaseURL + val browserSwitchOptions = BrowserSwitchOptions() .requestCode(BraintreeRequestCodes.VENMO.code) .url(venmoBaseURL) @@ -335,7 +338,7 @@ class VenmoClient internal constructor( private val analyticsParams: AnalyticsEventParams get() { - val eventParameters = AnalyticsEventParams() + val eventParameters = AnalyticsEventParams(appSwitchUrl = venmoRepository.venmoUrl.toString()) eventParameters.payPalContextId = payPalContextId eventParameters.linkType = LINK_TYPE eventParameters.isVaultRequest = isVaultRequest diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoLauncher.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoLauncher.kt index bb9316f1a6..e66dbcb0f5 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoLauncher.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoLauncher.kt @@ -7,15 +7,26 @@ import com.braintreepayments.api.BrowserSwitchClient import com.braintreepayments.api.BrowserSwitchException import com.braintreepayments.api.BrowserSwitchFinalResult import com.braintreepayments.api.BrowserSwitchStartResult +import com.braintreepayments.api.core.AnalyticsClient +import com.braintreepayments.api.core.AnalyticsEventParams import com.braintreepayments.api.core.BraintreeException /** * Responsible for launching the Venmo app to authenticate users */ class VenmoLauncher internal constructor( - private val browserSwitchClient: BrowserSwitchClient + private val browserSwitchClient: BrowserSwitchClient, + private val venmoRepository: VenmoRepository, + lazyAnalyticsClient: Lazy, ) { - constructor() : this(BrowserSwitchClient()) + + constructor() : this( + browserSwitchClient = BrowserSwitchClient(), + venmoRepository = VenmoRepository.instance, + lazyAnalyticsClient = AnalyticsClient.lazyInstance + ) + + private val analyticsClient: AnalyticsClient by lazyAnalyticsClient /** * Launches the Venmo authentication flow by switching to the Venmo app or a mobile browser, if @@ -32,9 +43,11 @@ class VenmoLauncher internal constructor( activity: ComponentActivity, paymentAuthRequest: VenmoPaymentAuthRequest.ReadyToLaunch ): VenmoPendingRequest { + analyticsClient.sendEvent(VenmoAnalytics.APP_SWITCH_STARTED, analyticsEventParams) try { assertCanPerformBrowserSwitch(activity, paymentAuthRequest.requestParams) } catch (browserSwitchException: BrowserSwitchException) { + analyticsClient.sendEvent(VenmoAnalytics.APP_SWITCH_FAILED, analyticsEventParams) val manifestInvalidError = createBrowserSwitchError(browserSwitchException) return VenmoPendingRequest.Failure(manifestInvalidError) } @@ -43,8 +56,15 @@ class VenmoLauncher internal constructor( paymentAuthRequest.requestParams.browserSwitchOptions ) return when (request) { - is BrowserSwitchStartResult.Failure -> VenmoPendingRequest.Failure(request.error) - is BrowserSwitchStartResult.Started -> VenmoPendingRequest.Started(request.pendingRequest) + is BrowserSwitchStartResult.Failure -> { + analyticsClient.sendEvent(VenmoAnalytics.APP_SWITCH_FAILED, analyticsEventParams) + VenmoPendingRequest.Failure(request.error) + } + + is BrowserSwitchStartResult.Started -> { + analyticsClient.sendEvent(VenmoAnalytics.APP_SWITCH_SUCCEEDED, analyticsEventParams) + VenmoPendingRequest.Started(request.pendingRequest) + } } } @@ -71,15 +91,23 @@ class VenmoLauncher internal constructor( pendingRequest: VenmoPendingRequest.Started, intent: Intent ): VenmoPaymentAuthResult { + analyticsClient.sendEvent(VenmoAnalytics.HANDLE_RETURN_STARTED, analyticsEventParams) return when (val browserSwitchResult = browserSwitchClient.completeRequest(intent, pendingRequest.pendingRequestString)) { - is BrowserSwitchFinalResult.Success -> VenmoPaymentAuthResult.Success( - browserSwitchResult - ) + is BrowserSwitchFinalResult.Success -> { + analyticsClient.sendEvent(VenmoAnalytics.HANDLE_RETURN_SUCCEEDED, analyticsEventParams) + VenmoPaymentAuthResult.Success(browserSwitchResult) + } - is BrowserSwitchFinalResult.Failure -> VenmoPaymentAuthResult.Failure(browserSwitchResult.error) + is BrowserSwitchFinalResult.Failure -> { + analyticsClient.sendEvent(VenmoAnalytics.HANDLE_RETURN_FAILED, analyticsEventParams) + VenmoPaymentAuthResult.Failure(browserSwitchResult.error) + } - is BrowserSwitchFinalResult.NoResult -> VenmoPaymentAuthResult.NoResult + is BrowserSwitchFinalResult.NoResult -> { + analyticsClient.sendEvent(VenmoAnalytics.HANDLE_RETURN_NO_RESULT, analyticsEventParams) + VenmoPaymentAuthResult.NoResult + } } } @@ -104,14 +132,18 @@ class VenmoLauncher internal constructor( browserSwitchClient.assertCanPerformBrowserSwitch(activity, params.browserSwitchOptions) } + private val analyticsEventParams by lazy { + AnalyticsEventParams(appSwitchUrl = venmoRepository.venmoUrl.toString()) + } + companion object { private const val VENMO_PACKAGE_NAME = "com.venmo" private fun createBrowserSwitchError(exception: BrowserSwitchException): Exception { return BraintreeException( "AndroidManifest.xml is incorrectly configured or another app defines the same " + - "browser switch url as this app. See https://developer.paypal.com/" + - "braintree/docs/guides/client-sdk/setup/android/v4#browser-switch-setup " + - "for the correct configuration: " + exception.message + "browser switch url as this app. See https://developer.paypal.com/" + + "braintree/docs/guides/client-sdk/setup/android/v4#browser-switch-setup " + + "for the correct configuration: " + exception.message ) } } diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoRepository.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoRepository.kt new file mode 100644 index 0000000000..2c3f8d7c36 --- /dev/null +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoRepository.kt @@ -0,0 +1,22 @@ +package com.braintreepayments.api.venmo + +import android.net.Uri + +/** + * An internal, in memory repository that holds properties specific for the Venmo payment flow. + */ +internal class VenmoRepository { + + /** + * The Venmo URL that is used to load the CCT or app switch into the Venmo payment flow. + */ + var venmoUrl: Uri? = null + + companion object { + + /** + * Singleton instance of the VenmoRepository. + */ + val instance: VenmoRepository by lazy { VenmoRepository() } + } +} diff --git a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java index 89f81a09f8..5f4ae2d88d 100644 --- a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java +++ b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java @@ -41,6 +41,8 @@ import org.mockito.Mockito; import org.robolectric.RobolectricTestRunner; +import java.util.ArrayList; + @RunWith(RobolectricTestRunner.class) public class VenmoClientUnitTest { @@ -63,10 +65,32 @@ public class VenmoClientUnitTest { private final Uri CANCEL_URL = Uri.parse("sample-scheme://x-callback-url/vzero/auth/venmo/cancel"); private final String LINK_TYPE = "universal"; - private final AnalyticsEventParams expectedAnalyticsParams = new AnalyticsEventParams(); - private final AnalyticsEventParams expectedVaultAnalyticsParams = new AnalyticsEventParams(); - + private final Uri appSwitchUrl = Uri.parse("https://example.com"); + private final AnalyticsEventParams expectedAnalyticsParams = new AnalyticsEventParams( + null, + LINK_TYPE, + false, + null, + null, + null, + null, + new ArrayList<>(), + appSwitchUrl.toString() + ); + private final AnalyticsEventParams expectedVaultAnalyticsParams = new AnalyticsEventParams( + null, + LINK_TYPE, + true, + null, + null, + null, + null, + new ArrayList<>(), + appSwitchUrl.toString() + ); + private final MerchantRepository merchantRepository = mock(MerchantRepository.class); + private final VenmoRepository venmoRepository = mock(VenmoRepository.class); @Before public void beforeEach() throws JSONException { @@ -75,16 +99,10 @@ public void beforeEach() throws JSONException { apiClient = mock(ApiClient.class); analyticsParamRepository = mock(AnalyticsParamRepository.class); - expectedAnalyticsParams.setLinkType(LINK_TYPE); - expectedAnalyticsParams.setVaultRequest(false); - - expectedVaultAnalyticsParams.setLinkType(LINK_TYPE); - expectedVaultAnalyticsParams.setVaultRequest(true); - venmoEnabledConfiguration = - Configuration.fromJson(Fixtures.CONFIGURATION_WITH_PAY_WITH_VENMO); + Configuration.fromJson(Fixtures.CONFIGURATION_WITH_PAY_WITH_VENMO); venmoDisabledConfiguration = - Configuration.fromJson(Fixtures.CONFIGURATION_WITHOUT_ACCESS_TOKEN); + Configuration.fromJson(Fixtures.CONFIGURATION_WITHOUT_ACCESS_TOKEN); venmoTokenizeCallback = mock(VenmoTokenizeCallback.class); venmoPaymentAuthRequestCallback = mock(VenmoPaymentAuthRequestCallback.class); sharedPrefsWriter = mock(VenmoSharedPrefsWriter.class); @@ -97,22 +115,23 @@ public void beforeEach() throws JSONException { when(analyticsParamRepository.getSessionId()).thenReturn("session-id"); when(merchantRepository.getIntegrationType()).thenReturn(IntegrationType.CUSTOM); when(merchantRepository.getApplicationContext()).thenReturn(context); + when(venmoRepository.getVenmoUrl()).thenReturn(appSwitchUrl); } @Test public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddressWithEcdDisabled() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -124,7 +143,8 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -133,22 +153,22 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.Failure); assertEquals( - "Cannot collect customer data when ECD is disabled. Enable this feature in the Control Panel to collect this data.", - ((VenmoPaymentAuthRequest.Failure) paymentAuthRequest).getError().getMessage()); + "Cannot collect customer data when ECD is disabled. Enable this feature in the Control Panel to collect this data.", + ((VenmoPaymentAuthRequest.Failure) paymentAuthRequest).getError().getMessage()); } @Test public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVenmoAuthChallenge() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .returnUrlScheme("com.example") - .build(); + .configuration(venmoEnabledConfiguration) + .returnUrlScheme("com.example") + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("sample-venmo-merchant"); @@ -160,15 +180,16 @@ public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVen venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); InOrder inOrder = Mockito.inOrder(venmoPaymentAuthRequestCallback, braintreeClient); - inOrder.verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED,new AnalyticsEventParams()); + inOrder.verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED, new AnalyticsEventParams()); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); inOrder.verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); @@ -196,8 +217,8 @@ public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVen @Test public void createPaymentAuthRequest_whenConfigurationException_forwardsExceptionToListener() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configurationError(new Exception("Configuration fetching error")) - .build(); + .configurationError(new Exception("Configuration fetching error")) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -209,12 +230,13 @@ public void createPaymentAuthRequest_whenConfigurationException_forwardsExceptio venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.Failure); @@ -225,8 +247,8 @@ public void createPaymentAuthRequest_whenConfigurationException_forwardsExceptio @Test public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToListener() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoDisabledConfiguration) - .build(); + .configuration(venmoDisabledConfiguration) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -238,12 +260,13 @@ public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToList venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.Failure); @@ -254,14 +277,14 @@ public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToList @Test public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchantId() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -273,12 +296,13 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.ReadyToLaunch); @@ -292,14 +316,14 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant @Test public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithProfileIdAndAccessToken() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId("second-pwv-profile-id"); @@ -311,12 +335,13 @@ public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithPro venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.ReadyToLaunch); @@ -332,8 +357,8 @@ public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithPro @Test public void createPaymentAuthRequest_sendsAnalyticsEvent() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -345,23 +370,24 @@ public void createPaymentAuthRequest_sendsAnalyticsEvent() { venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); - verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED,new AnalyticsEventParams()); + verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED, new AnalyticsEventParams()); } @Test public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTrue() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -373,7 +399,8 @@ public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTru venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -383,14 +410,14 @@ public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTru @Test public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFalse() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -402,7 +429,8 @@ public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFa venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -412,14 +440,14 @@ public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFa @Test public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -431,7 +459,8 @@ public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -442,13 +471,13 @@ public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_andSendsAnalytics() { BraintreeException graphQLError = new BraintreeException("GraphQL error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .sendGraphQLPOSTErrorResponse(graphQLError) - .build(); + .configuration(venmoEnabledConfiguration) + .sendGraphQLPOSTErrorResponse(graphQLError) + .build(); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextError(graphQLError) - .build(); + .createPaymentContextError(graphQLError) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setShouldVault(true); @@ -459,12 +488,13 @@ public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_a venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.Failure); @@ -475,8 +505,8 @@ public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_a @Test public void tokenize_withPaymentContextId_requestFromVenmoApi() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); @@ -486,13 +516,14 @@ public void tokenize_withPaymentContextId_requestFromVenmoApi() { venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); verify(venmoApi).createNonceFromPaymentContext(eq("a-resource-id"), - any(VenmoInternalCallback.class)); + any(VenmoInternalCallback.class)); verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.APP_SWITCH_SUCCEEDED, expectedAnalyticsParams); } @@ -500,8 +531,8 @@ public void tokenize_withPaymentContextId_requestFromVenmoApi() { @Test public void tokenize_withPaymentAuthResult_whenUserCanceled_returnsCancelAndSendsAnalytics() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(CANCEL_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); @@ -511,7 +542,8 @@ public void tokenize_withPaymentAuthResult_whenUserCanceled_returnsCancelAndSend venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -527,17 +559,17 @@ public void tokenize_withPaymentAuthResult_whenUserCanceled_returnsCancelAndSend @Test public void tokenize_onGraphQLPostSuccess_returnsNonceToListener_andSendsAnalytics() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( - new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE))) - .build(); + .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( + new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE))) + .build(); VenmoClient sut = new VenmoClient( braintreeClient, @@ -545,7 +577,8 @@ public void tokenize_onGraphQLPostSuccess_returnsNonceToListener_andSendsAnalyti venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -566,15 +599,15 @@ public void tokenize_onGraphQLPostSuccess_returnsNonceToListener_andSendsAnalyti public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAnalytics() { BraintreeException graphQLError = new BraintreeException("graphQL error"); BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .sendGraphQLPOSTErrorResponse(graphQLError) - .build(); + .configuration(venmoEnabledConfiguration) + .sendGraphQLPOSTErrorResponse(graphQLError) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextError(graphQLError) - .build(); + .createNonceFromPaymentContextError(graphQLError) + .build(); VenmoClient sut = new VenmoClient( braintreeClient, @@ -582,7 +615,8 @@ public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAn venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -599,8 +633,8 @@ public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAn @Test public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); @@ -608,8 +642,8 @@ public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() when(nonce.getString()).thenReturn("some-nonce"); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextSuccess(nonce) - .build(); + .createNonceFromPaymentContextSuccess(nonce) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -623,7 +657,8 @@ public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -643,27 +678,28 @@ public void tokenize_postsPaymentMethodNonceOnSuccess() { venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); verify(venmoApi).createNonceFromPaymentContext(eq("a-resource-id"), - any(VenmoInternalCallback.class)); + any(VenmoInternalCallback.class)); } @Test public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( - new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE))) - .build(); + .createNonceFromPaymentContextSuccess(VenmoAccountNonce.fromJSON( + new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE))) + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); @@ -677,13 +713,14 @@ public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONExcepti venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); verify(venmoApi).vaultVenmoAccountNonce(eq("fake-venmo-nonce"), - any(VenmoInternalCallback.class)); + any(VenmoInternalCallback.class)); } @Test @@ -699,27 +736,28 @@ public void tokenize_doesNotPerformRequestIfTokenizationKeyUsed() { venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); verify(venmoApi, never()).vaultVenmoAccountNonce(anyString(), - any(VenmoInternalCallback.class)); + any(VenmoInternalCallback.class)); } @Test public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListener_andSendsAnalytics() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .build(); + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL_WITHOUT_RESOURCE_ID); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = mock(VenmoAccountNonce.class); VenmoApi venmoApi = new MockVenmoApiBuilder() - .vaultVenmoAccountNonceSuccess(venmoAccountNonce) - .build(); + .vaultVenmoAccountNonceSuccess(venmoAccountNonce) + .build(); when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); @@ -729,7 +767,8 @@ public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListe venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -746,20 +785,20 @@ public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListe @Test public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToCallback_andSendsAnalytics() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) - .build(); + .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = VenmoAccountNonce.fromJSON( - new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); + new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextSuccess(venmoAccountNonce) - .vaultVenmoAccountNonceSuccess(venmoAccountNonce) - .build(); + .createNonceFromPaymentContextSuccess(venmoAccountNonce) + .vaultVenmoAccountNonceSuccess(venmoAccountNonce) + .build(); when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); @@ -769,7 +808,8 @@ public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToC venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -793,8 +833,8 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a Exception error = new Exception("error"); VenmoApi venmoApi = new MockVenmoApiBuilder() - .vaultVenmoAccountNonceError(error) - .build(); + .vaultVenmoAccountNonceError(error) + .build(); when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); @@ -804,7 +844,8 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -824,21 +865,21 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a @Test public void tokenize_withPaymentContext_withFailedVaultCall_forwardsErrorToCallback_andSendsAnalytics() - throws JSONException { + throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) - .build(); + .sendGraphQLPOSTSuccessfulResponse(Fixtures.VENMO_GRAPHQL_GET_PAYMENT_CONTEXT_RESPONSE) + .build(); when(browserSwitchResult.getReturnUrl()).thenReturn(SUCCESS_URL); when(merchantRepository.getAuthorization()).thenReturn(clientToken); VenmoAccountNonce venmoAccountNonce = VenmoAccountNonce.fromJSON( - new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); + new JSONObject(Fixtures.PAYMENT_METHODS_VENMO_ACCOUNT_RESPONSE)); Exception error = new Exception("error"); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createNonceFromPaymentContextSuccess(venmoAccountNonce) - .vaultVenmoAccountNonceError(error) - .build(); + .createNonceFromPaymentContextSuccess(venmoAccountNonce) + .vaultVenmoAccountNonceError(error) + .build(); when(sharedPrefsWriter.getVenmoVaultOption(context)).thenReturn(true); @@ -848,7 +889,8 @@ public void tokenize_withPaymentContext_withFailedVaultCall_forwardsErrorToCallb venmoApi, sharedPrefsWriter, analyticsParamRepository, - merchantRepository + merchantRepository, + venmoRepository ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); diff --git a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoLauncherUnitTest.kt b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoLauncherUnitTest.kt index 3835be593d..d0224f9a43 100644 --- a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoLauncherUnitTest.kt +++ b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoLauncherUnitTest.kt @@ -1,14 +1,18 @@ package com.braintreepayments.api.venmo import android.content.Intent +import android.net.Uri import androidx.activity.ComponentActivity import com.braintreepayments.api.BrowserSwitchClient import com.braintreepayments.api.BrowserSwitchException import com.braintreepayments.api.BrowserSwitchFinalResult import com.braintreepayments.api.BrowserSwitchOptions import com.braintreepayments.api.BrowserSwitchStartResult +import com.braintreepayments.api.core.AnalyticsClient +import com.braintreepayments.api.core.AnalyticsEventParams import io.mockk.every import io.mockk.mockk +import io.mockk.verify import junit.framework.Assert import org.junit.Assert.assertEquals import org.junit.Assert.assertSame @@ -23,6 +27,8 @@ import org.robolectric.RobolectricTestRunner @RunWith(RobolectricTestRunner::class) class VenmoLauncherUnitTest { private val browserSwitchClient: BrowserSwitchClient = mockk(relaxed = true) + private val venmoRepository: VenmoRepository = mockk(relaxed = true) + private val analyticsClient: AnalyticsClient = mockk(relaxed = true) private val activity: ComponentActivity = mockk(relaxed = true) private val paymentAuthRequestParams: VenmoPaymentAuthRequestParams = mockk(relaxed = true) private val intent: Intent = mockk(relaxed = true) @@ -31,10 +37,26 @@ class VenmoLauncherUnitTest { private lateinit var sut: VenmoLauncher + private val appSwitchUrl = Uri.parse("http://example.com") + @Before fun setup() { every { paymentAuthRequestParams.browserSwitchOptions } returns options - sut = VenmoLauncher(browserSwitchClient) + every { venmoRepository.venmoUrl } returns appSwitchUrl + + sut = VenmoLauncher(browserSwitchClient, venmoRepository, lazy { analyticsClient }) + } + + @Test + fun `when launch is invoked, app switch started analytics event is sent`() { + sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.APP_SWITCH_STARTED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } } @Test @@ -42,8 +64,7 @@ class VenmoLauncherUnitTest { val startedPendingRequest = BrowserSwitchStartResult.Started(pendingRequestString) every { browserSwitchClient.start(activity, options) } returns startedPendingRequest - val pendingRequest = - sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) + val pendingRequest = sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) assertTrue(pendingRequest is VenmoPendingRequest.Started) assertEquals( @@ -52,6 +73,21 @@ class VenmoLauncherUnitTest { ) } + @Test + fun `when launch is called and Started is returned, app switch succeeded analytics event is sent`() { + val startedPendingRequest = BrowserSwitchStartResult.Started(pendingRequestString) + every { browserSwitchClient.start(activity, options) } returns startedPendingRequest + + sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.APP_SWITCH_SUCCEEDED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + @Test fun `launch on error returns pending request failure`() { every { paymentAuthRequestParams.browserSwitchOptions } returns options @@ -67,7 +103,22 @@ class VenmoLauncherUnitTest { } @Test - @Throws(BrowserSwitchException::class) + fun `when launch is called and Failure is returned, app switch failed analytics event is sent`() { + every { paymentAuthRequestParams.browserSwitchOptions } returns options + every { browserSwitchClient.start(eq(activity), eq(options)) } returns + BrowserSwitchStartResult.Failure(BrowserSwitchException("error")) + + sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.APP_SWITCH_FAILED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + + @Test fun `launch when device cant perform browser switch returns pending request failure`() { every { paymentAuthRequestParams.browserSwitchOptions } returns options val exception = BrowserSwitchException("browser switch error") @@ -92,6 +143,35 @@ class VenmoLauncherUnitTest { ) } + @Test + @Throws(BrowserSwitchException::class) + fun `when launch is called with a manifest error, app switch failed analytics event is sent`() { + every { paymentAuthRequestParams.browserSwitchOptions } returns options + every { browserSwitchClient.assertCanPerformBrowserSwitch(eq(activity), eq(options)) } throws + BrowserSwitchException("browser switch error") + + sut.launch(activity, VenmoPaymentAuthRequest.ReadyToLaunch(paymentAuthRequestParams)) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.APP_SWITCH_FAILED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + + @Test + fun `when handleReturnToApp is invoked, app switch started analytics event is sent`() { + sut.handleReturnToApp(VenmoPendingRequest.Started(pendingRequestString), intent) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.HANDLE_RETURN_STARTED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + @Test fun `handleReturnToApp when result exists returns result`() { val browserSwitchFinalResult = mockk() @@ -113,6 +193,21 @@ class VenmoLauncherUnitTest { ) } + @Test + fun `when handleReturnToApp is called with Success, handle return succeeded analytics event is sent`() { + every { browserSwitchClient.completeRequest(intent, pendingRequestString) } returns + mockk() + + sut.handleReturnToApp(VenmoPendingRequest.Started(pendingRequestString), intent) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.HANDLE_RETURN_SUCCEEDED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + @Test fun `handleReturnToApp when result does not exist returns null`() { every { @@ -130,6 +225,36 @@ class VenmoLauncherUnitTest { assertTrue(paymentAuthResult is VenmoPaymentAuthResult.NoResult) } + @Test + fun `when handleReturnToApp is called without a result, handle return no result analytics event is sent`() { + every { browserSwitchClient.completeRequest(intent, pendingRequestString) } returns + BrowserSwitchFinalResult.NoResult + + sut.handleReturnToApp(VenmoPendingRequest.Started(pendingRequestString), intent) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.HANDLE_RETURN_NO_RESULT, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + + @Test + fun `when handleReturnToApp is called with a failure, handle return failed analytics event is sent`() { + every { browserSwitchClient.completeRequest(intent, pendingRequestString) } returns + mockk(relaxed = true) + + sut.handleReturnToApp(VenmoPendingRequest.Started(pendingRequestString), intent) + + verify { + analyticsClient.sendEvent( + eventName = VenmoAnalytics.HANDLE_RETURN_FAILED, + analyticsEventParams = AnalyticsEventParams(appSwitchUrl = appSwitchUrl.toString()) + ) + } + } + @Test fun showVenmoInGooglePlayStore_opensVenmoAppStoreURL() { val activity = Mockito.mock( From bafeda710b4c65780395ef2f1ca872254d648e9c Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Thu, 21 Nov 2024 14:14:05 -0800 Subject: [PATCH 13/22] Expose paymentId (#1220) * remove RestrictTo library scope * Update CHANGELOG.md Co-authored-by: Sarah Koop --------- Co-authored-by: Sarah Koop --- CHANGELOG.md | 5 +++++ .../com/braintreepayments/demo/LocalPaymentFragment.java | 6 ++++++ .../api/localpayment/LocalPaymentAuthRequestParams.kt | 2 +- 3 files changed, 12 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 53d94d6c93..18b3f5d9b8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,10 @@ # Braintree Android SDK Release Notes +## unreleased + +* LocalPayment + * Make LocalPaymentAuthRequestParams public (fixes #1207) + ## 5.2.0 (2024-10-30) * GooglePay diff --git a/Demo/src/main/java/com/braintreepayments/demo/LocalPaymentFragment.java b/Demo/src/main/java/com/braintreepayments/demo/LocalPaymentFragment.java index 6b3a3dc0e2..d184d0a1ae 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/LocalPaymentFragment.java +++ b/Demo/src/main/java/com/braintreepayments/demo/LocalPaymentFragment.java @@ -1,6 +1,7 @@ package com.braintreepayments.demo; import android.os.Bundle; +import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; @@ -71,6 +72,11 @@ public void launchIdeal(View v) { if (paymentAuthRequest instanceof LocalPaymentAuthRequest.ReadyToLaunch) { LocalPaymentPendingRequest pendingRequest = localPaymentLauncher.launch(requireActivity(), (LocalPaymentAuthRequest.ReadyToLaunch) paymentAuthRequest); + // merchants have to log paymentId to their servers + Log.i("Sample-server", ((LocalPaymentAuthRequest.ReadyToLaunch) paymentAuthRequest) + .getRequestParams() + .getPaymentId() + ); if (pendingRequest instanceof LocalPaymentPendingRequest.Started) { storePendingRequest((LocalPaymentPendingRequest.Started) pendingRequest); } else if (pendingRequest instanceof LocalPaymentPendingRequest.Failure) { diff --git a/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentAuthRequestParams.kt b/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentAuthRequestParams.kt index f4f8434bb4..0a3af2892f 100644 --- a/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentAuthRequestParams.kt +++ b/LocalPayment/src/main/java/com/braintreepayments/api/localpayment/LocalPaymentAuthRequestParams.kt @@ -10,10 +10,10 @@ import com.braintreepayments.api.BrowserSwitchOptions * @property approvalUrl used for payment approval. * @property paymentId of the local payment after creation. */ -@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) data class LocalPaymentAuthRequestParams @JvmOverloads internal constructor( val request: LocalPaymentRequest, val approvalUrl: String, val paymentId: String, + @get:RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) var browserSwitchOptions: BrowserSwitchOptions? = null ) From 0cfbf0c8b21c6d3f5865fd85c636935302d10600 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Wed, 4 Dec 2024 11:10:07 -0600 Subject: [PATCH 14/22] Add deep link support as a fallback to app links (#1223) * Add deep link support as a fallback to app links * Add unit tests and kdoc * Add a null check for both app link and deep link urls * Update changelog for deepLinkFallbackUrlScheme --- .../api/core/BraintreeClient.kt | 8 +- .../api/core/GetReturnLinkUseCase.kt | 48 +++++ .../api/core/MerchantRepository.kt | 2 + .../api/core/BraintreeClientUnitTest.kt | 8 +- .../api/core/GetReturnLinkUseCaseUnitTest.kt | 87 ++++++++ CHANGELOG.md | 2 + .../demo/PayPalFragment.java | 7 +- .../api/paypal/PayPalClient.kt | 54 +++-- .../api/paypal/PayPalInternalClient.kt | 39 +++- .../api/paypal/PayPalClientUnitTest.java | 113 +++++++++-- .../paypal/PayPalInternalClientUnitTest.java | 191 +++++++++++++++--- 11 files changed, 485 insertions(+), 74 deletions(-) create mode 100644 BraintreeCore/src/main/java/com/braintreepayments/api/core/GetReturnLinkUseCase.kt create mode 100644 BraintreeCore/src/test/java/com/braintreepayments/api/core/GetReturnLinkUseCaseUnitTest.kt diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt index efc3d56cab..737e00bbdd 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/BraintreeClient.kt @@ -7,7 +7,6 @@ import androidx.annotation.RestrictTo import com.braintreepayments.api.sharedutils.HttpResponseCallback import com.braintreepayments.api.sharedutils.HttpResponseTiming import com.braintreepayments.api.sharedutils.ManifestValidator -import com.braintreepayments.api.sharedutils.Time import org.json.JSONException import org.json.JSONObject @@ -22,12 +21,12 @@ class BraintreeClient internal constructor( authorization: Authorization, returnUrlScheme: String, appLinkReturnUri: Uri?, + deepLinkFallbackUrlScheme: String? = null, sdkComponent: SdkComponent = SdkComponent.create(applicationContext), private val httpClient: BraintreeHttpClient = BraintreeHttpClient(), private val graphQLClient: BraintreeGraphQLClient = BraintreeGraphQLClient(), private val configurationLoader: ConfigurationLoader = ConfigurationLoader.instance, private val manifestValidator: ManifestValidator = ManifestValidator(), - private val time: Time = Time(), private val merchantRepository: MerchantRepository = MerchantRepository.instance, private val analyticsClient: AnalyticsClient = AnalyticsClient(), ) { @@ -47,6 +46,7 @@ class BraintreeClient internal constructor( returnUrlScheme: String? = null, appLinkReturnUri: Uri? = null, integrationType: IntegrationType? = null, + deepLinkFallbackUrlScheme: String? = null, ) : this( applicationContext = context.applicationContext, authorization = Authorization.fromString(authorization), @@ -54,6 +54,7 @@ class BraintreeClient internal constructor( ?: "${getAppPackageNameWithoutUnderscores(context.applicationContext)}.braintree", appLinkReturnUri = appLinkReturnUri, integrationType = integrationType ?: IntegrationType.CUSTOM, + deepLinkFallbackUrlScheme = deepLinkFallbackUrlScheme ) init { @@ -73,6 +74,9 @@ class BraintreeClient internal constructor( if (appLinkReturnUri != null) { it.appLinkReturnUri = appLinkReturnUri } + if (deepLinkFallbackUrlScheme != null) { + it.deepLinkFallbackUrlScheme = deepLinkFallbackUrlScheme + } } } diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/GetReturnLinkUseCase.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/GetReturnLinkUseCase.kt new file mode 100644 index 0000000000..7fc8d7f3e1 --- /dev/null +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/GetReturnLinkUseCase.kt @@ -0,0 +1,48 @@ +package com.braintreepayments.api.core + +import android.content.Intent +import android.content.pm.PackageManager +import android.net.Uri +import androidx.annotation.RestrictTo +import com.braintreepayments.api.core.GetReturnLinkUseCase.ReturnLinkResult + +/** + * Use case that returns a return link that should be used for navigating from App Switch / CCT back into the merchant + * app. It handles both App Links and Deep Links. + * + * If a user unchecks the "Open supported links" checkbox in the Android OS settings for the merchant's app. If this + * setting is unchecked, this use case will return [ReturnLinkResult.DeepLink], otherwise [ReturnLinkResult.AppLink] + * will be returned. + */ +@RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) +class GetReturnLinkUseCase(private val merchantRepository: MerchantRepository) { + + sealed class ReturnLinkResult { + data class AppLink(val appLinkReturnUri: Uri) : ReturnLinkResult() + + data class DeepLink(val deepLinkFallbackUrlScheme: String) : ReturnLinkResult() + + data class Failure(val exception: Exception) : ReturnLinkResult() + } + + operator fun invoke(): ReturnLinkResult { + val context = merchantRepository.applicationContext + val intent = Intent(Intent.ACTION_VIEW, merchantRepository.appLinkReturnUri).apply { + addCategory(Intent.CATEGORY_BROWSABLE) + } + val resolvedActivity = context.packageManager.resolveActivity(intent, PackageManager.MATCH_DEFAULT_ONLY) + return if (resolvedActivity?.activityInfo?.packageName == context.packageName) { + merchantRepository.appLinkReturnUri?.let { + ReturnLinkResult.AppLink(it) + } ?: run { + ReturnLinkResult.Failure(BraintreeException("App Link Return Uri is null")) + } + } else { + merchantRepository.deepLinkFallbackUrlScheme?.let { + ReturnLinkResult.DeepLink(it) + } ?: run { + ReturnLinkResult.Failure(BraintreeException("Deep Link fallback return url is null")) + } + } + } +} diff --git a/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt b/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt index d8ad972c5c..ce0fccb246 100644 --- a/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt +++ b/BraintreeCore/src/main/java/com/braintreepayments/api/core/MerchantRepository.kt @@ -16,6 +16,8 @@ class MerchantRepository { lateinit var returnUrlScheme: String var appLinkReturnUri: Uri? = null + var deepLinkFallbackUrlScheme: String? = null + companion object { /** diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt index ecba21eace..c7d6d5cbf9 100644 --- a/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/BraintreeClientUnitTest.kt @@ -10,7 +10,6 @@ import com.braintreepayments.api.BrowserSwitchClient import com.braintreepayments.api.sharedutils.HttpResponseCallback import com.braintreepayments.api.sharedutils.ManifestValidator import com.braintreepayments.api.sharedutils.NetworkResponseCallback -import com.braintreepayments.api.sharedutils.Time import com.braintreepayments.api.testutils.Fixtures import io.mockk.* import org.json.JSONException @@ -319,10 +318,7 @@ class BraintreeClientUnitTest { .configuration(configuration) .build() - val time: Time = mockk() - every { time.currentTime } returns 123 - - val sut = createBraintreeClient(configurationLoader, time) + val sut = createBraintreeClient(configurationLoader) sut.sendAnalyticsEvent("event.started") verify { @@ -432,7 +428,6 @@ class BraintreeClientUnitTest { private fun createBraintreeClient( configurationLoader: ConfigurationLoader = mockk(), - time: Time = Time(), appLinkReturnUri: Uri? = Uri.parse("https://example.com"), merchantRepository: MerchantRepository = MerchantRepository.instance ) = BraintreeClient( @@ -446,7 +441,6 @@ class BraintreeClientUnitTest { analyticsClient = analyticsClient, manifestValidator = manifestValidator, configurationLoader = configurationLoader, - time = time, merchantRepository = merchantRepository, ) } diff --git a/BraintreeCore/src/test/java/com/braintreepayments/api/core/GetReturnLinkUseCaseUnitTest.kt b/BraintreeCore/src/test/java/com/braintreepayments/api/core/GetReturnLinkUseCaseUnitTest.kt new file mode 100644 index 0000000000..81ed10d334 --- /dev/null +++ b/BraintreeCore/src/test/java/com/braintreepayments/api/core/GetReturnLinkUseCaseUnitTest.kt @@ -0,0 +1,87 @@ +package com.braintreepayments.api.core + +import android.content.Context +import android.content.Intent +import android.content.pm.ActivityInfo +import android.content.pm.ResolveInfo +import android.net.Uri +import io.mockk.every +import io.mockk.mockk +import org.junit.Before +import org.junit.runner.RunWith +import org.robolectric.RobolectricTestRunner +import kotlin.test.Test +import kotlin.test.assertEquals +import kotlin.test.assertTrue + +@RunWith(RobolectricTestRunner::class) +class GetReturnLinkUseCaseUnitTest { + + private val merchantRepository: MerchantRepository = mockk(relaxed = true) + private val context: Context = mockk(relaxed = true) + private val resolveInfo = ResolveInfo() + private val activityInfo = ActivityInfo() + private val contextPackageName = "context.package.name" + private val appLinkReturnUri = Uri.parse("https://example.com") + private val deepLinkFallbackUrlScheme = "com.braintreepayments.demo" + + lateinit var subject: GetReturnLinkUseCase + + @Before + fun setUp() { + every { merchantRepository.applicationContext } returns context + every { merchantRepository.appLinkReturnUri } returns appLinkReturnUri + every { merchantRepository.deepLinkFallbackUrlScheme } returns deepLinkFallbackUrlScheme + every { context.packageName } returns contextPackageName + resolveInfo.activityInfo = activityInfo + every { context.packageManager.resolveActivity(any(), any()) } returns resolveInfo + + subject = GetReturnLinkUseCase(merchantRepository) + } + + @Test + fun `when invoke is called and app link is available, APP_LINK is returned`() { + activityInfo.packageName = "context.package.name" + + val result = subject() + + assertEquals(GetReturnLinkUseCase.ReturnLinkResult.AppLink(appLinkReturnUri), result) + } + + @Test + fun `when invoke is called and app link is not available, DEEP_LINK is returned`() { + activityInfo.packageName = "different.package.name" + + val result = subject() + + assertEquals(GetReturnLinkUseCase.ReturnLinkResult.DeepLink(deepLinkFallbackUrlScheme), result) + } + + @Test + fun `when invoke is called and deep link is available but null, Failure is returned`() { + activityInfo.packageName = "different.package.name" + every { merchantRepository.deepLinkFallbackUrlScheme } returns null + + val result = subject() + + assertTrue { result is GetReturnLinkUseCase.ReturnLinkResult.Failure } + assertEquals( + "Deep Link fallback return url is null", + (result as GetReturnLinkUseCase.ReturnLinkResult.Failure).exception.message + ) + } + + @Test + fun `when invoke is called and app link is available but null, Failure is returned`() { + activityInfo.packageName = "context.package.name" + every { merchantRepository.appLinkReturnUri } returns null + + val result = subject() + + assertTrue { result is GetReturnLinkUseCase.ReturnLinkResult.Failure } + assertEquals( + "App Link Return Uri is null", + (result as GetReturnLinkUseCase.ReturnLinkResult.Failure).exception.message + ) + } +} diff --git a/CHANGELOG.md b/CHANGELOG.md index 18b3f5d9b8..bc38ca05bb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ ## unreleased +* PayPal + * Add `deepLinkFallbackUrlScheme` to `PayPalClient` constructor params for supporting deep link fallback * LocalPayment * Make LocalPaymentAuthRequestParams public (fixes #1207) diff --git a/Demo/src/main/java/com/braintreepayments/demo/PayPalFragment.java b/Demo/src/main/java/com/braintreepayments/demo/PayPalFragment.java index fa90df0b62..86c067e408 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/PayPalFragment.java +++ b/Demo/src/main/java/com/braintreepayments/demo/PayPalFragment.java @@ -75,9 +75,10 @@ public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup c }); payPalClient = new PayPalClient( - requireContext(), - super.getAuthStringArg(), - Uri.parse("https://mobile-sdk-demo-site-838cead5d3ab.herokuapp.com/braintree-payments") + requireContext(), + super.getAuthStringArg(), + Uri.parse("https://mobile-sdk-demo-site-838cead5d3ab.herokuapp.com/braintree-payments"), + "com.braintreepayments.demo.braintree" ); payPalLauncher = new PayPalLauncher(); diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt index ccdfbd46ad..5d00d97370 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt @@ -9,6 +9,7 @@ import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.BraintreeRequestCodes import com.braintreepayments.api.core.Configuration +import com.braintreepayments.api.core.GetReturnLinkUseCase import com.braintreepayments.api.core.LinkType import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.UserCanceledException @@ -24,6 +25,7 @@ class PayPalClient internal constructor( private val braintreeClient: BraintreeClient, private val internalPayPalClient: PayPalInternalClient = PayPalInternalClient(braintreeClient), private val merchantRepository: MerchantRepository = MerchantRepository.instance, + private val getReturnLinkUseCase: GetReturnLinkUseCase = GetReturnLinkUseCase(merchantRepository) ) { /** @@ -48,14 +50,23 @@ class PayPalClient internal constructor( * @param context an Android Context * @param authorization a Tokenization Key or Client Token used to authenticate * @param appLinkReturnUrl A [Uri] containing the Android App Link website associated with - * your application to be used to return to your app from the PayPal - * payment flows. + * your application to be used to return to your app from the PayPal payment flows. + * @param deepLinkFallbackUrlScheme A return url scheme that will be used as a deep link fallback when returning to + * your app via App Link is not available (buyer unchecks the "Open supported links" setting). */ constructor( context: Context, authorization: String, - appLinkReturnUrl: Uri - ) : this(BraintreeClient(context, authorization, null, appLinkReturnUrl)) + appLinkReturnUrl: Uri, + deepLinkFallbackUrlScheme: String? = null + ) : this( + BraintreeClient( + context = context, + authorization = authorization, + deepLinkFallbackUrlScheme = deepLinkFallbackUrlScheme, + appLinkReturnUri = appLinkReturnUrl + ) + ) /** * Starts the PayPal payment flow by creating a [PayPalPaymentAuthRequestParams] to be @@ -89,6 +100,7 @@ class PayPalClient internal constructor( } } + @Suppress("TooGenericExceptionCaught") private fun sendPayPalRequest( context: Context, payPalRequest: PayPalRequest, @@ -112,14 +124,16 @@ class PayPalClient internal constructor( braintreeClient.sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_STARTED, analyticsParams) } - callback.onPayPalPaymentAuthRequest( - PayPalPaymentAuthRequest.ReadyToLaunch(payPalResponse) - ) - } catch (exception: JSONException) { - callbackCreatePaymentAuthFailure( - callback, - PayPalPaymentAuthRequest.Failure(exception) - ) + callback.onPayPalPaymentAuthRequest(PayPalPaymentAuthRequest.ReadyToLaunch(payPalResponse)) + } catch (exception: Exception) { + when (exception) { + is JSONException, + is BraintreeException -> { + callbackCreatePaymentAuthFailure(callback, PayPalPaymentAuthRequest.Failure(exception)) + } + + else -> throw exception + } } } else { callbackCreatePaymentAuthFailure( @@ -130,7 +144,7 @@ class PayPalClient internal constructor( } } - @Throws(JSONException::class) + @Throws(JSONException::class, BraintreeException::class) private fun buildBrowserSwitchOptions( paymentAuthRequest: PayPalPaymentAuthRequestParams ): BrowserSwitchOptions { @@ -152,10 +166,22 @@ class PayPalClient internal constructor( return BrowserSwitchOptions() .requestCode(BraintreeRequestCodes.PAYPAL.code) - .appLinkUri(merchantRepository.appLinkReturnUri) .url(Uri.parse(paymentAuthRequest.approvalUrl)) .launchAsNewTask(braintreeClient.launchesBrowserSwitchAsNewTask()) .metadata(metadata) + .apply { + when (val returnLinkResult = getReturnLinkUseCase()) { + is GetReturnLinkUseCase.ReturnLinkResult.AppLink -> { + appLinkUri(returnLinkResult.appLinkReturnUri) + } + + is GetReturnLinkUseCase.ReturnLinkResult.DeepLink -> { + returnUrlScheme(returnLinkResult.deepLinkFallbackUrlScheme) + } + + is GetReturnLinkUseCase.ReturnLinkResult.Failure -> throw returnLinkResult.exception + } + } } /** diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt index cfb9427d40..38746419bf 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalInternalClient.kt @@ -7,6 +7,7 @@ import com.braintreepayments.api.core.BraintreeClient import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.Configuration import com.braintreepayments.api.core.DeviceInspector +import com.braintreepayments.api.core.GetReturnLinkUseCase import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.datacollector.DataCollector import com.braintreepayments.api.datacollector.DataCollectorInternalRequest @@ -20,10 +21,8 @@ internal class PayPalInternalClient( private val apiClient: ApiClient = ApiClient(braintreeClient), private val deviceInspector: DeviceInspector = DeviceInspector(), private val merchantRepository: MerchantRepository = MerchantRepository.instance, + private val getReturnLinkUseCase: GetReturnLinkUseCase = GetReturnLinkUseCase(merchantRepository) ) { - private val cancelUrl = "${merchantRepository.appLinkReturnUri}://onetouch/v1/cancel" - private val successUrl = "${merchantRepository.appLinkReturnUri}://onetouch/v1/success" - private val appLink = merchantRepository.appLinkReturnUri?.toString() fun sendRequest( context: Context, @@ -44,18 +43,37 @@ internal class PayPalInternalClient( CREATE_SINGLE_PAYMENT_ENDPOINT } val url = "/v1/$endpoint" - val appLinkReturn = if (isBillingAgreement) appLink else null if (isBillingAgreement && (payPalRequest as PayPalVaultRequest).enablePayPalAppSwitch) { payPalRequest.enablePayPalAppSwitch = isPayPalInstalled(context) } + val returnLinkResult = getReturnLinkUseCase() + val navigationLink: String = when (returnLinkResult) { + is GetReturnLinkUseCase.ReturnLinkResult.AppLink -> returnLinkResult.appLinkReturnUri.toString() + is GetReturnLinkUseCase.ReturnLinkResult.DeepLink -> returnLinkResult.deepLinkFallbackUrlScheme + is GetReturnLinkUseCase.ReturnLinkResult.Failure -> { + callback.onResult(null, returnLinkResult.exception) + return@getConfiguration + } + } + val appLinkParam = if ( + returnLinkResult is GetReturnLinkUseCase.ReturnLinkResult.AppLink && isBillingAgreement + ) { + merchantRepository.appLinkReturnUri?.toString() + } else { + null + } + + val cancelUrl = "$navigationLink://onetouch/v1/cancel" + val successUrl = "$navigationLink://onetouch/v1/success" + val requestBody = payPalRequest.createRequestBody( configuration = configuration, authorization = merchantRepository.authorization, successUrl = successUrl, cancelUrl = cancelUrl, - appLink = appLinkReturn + appLink = appLinkParam ) ?: throw JSONException("Error creating requestBody") sendPost( @@ -123,12 +141,21 @@ internal class PayPalInternalClient( ) } + val returnLink: String = when (val returnLinkResult = getReturnLinkUseCase()) { + is GetReturnLinkUseCase.ReturnLinkResult.AppLink -> returnLinkResult.appLinkReturnUri.toString() + is GetReturnLinkUseCase.ReturnLinkResult.DeepLink -> returnLinkResult.deepLinkFallbackUrlScheme + is GetReturnLinkUseCase.ReturnLinkResult.Failure -> { + callback.onResult(null, returnLinkResult.exception) + return@sendPOST + } + } + val paymentAuthRequest = PayPalPaymentAuthRequestParams( payPalRequest = payPalRequest, browserSwitchOptions = null, clientMetadataId = clientMetadataId, pairingId = pairingId, - successUrl = successUrl + successUrl = "$returnLink://onetouch/v1/success" ) if (isAppSwitchEnabled(payPalRequest) && isPayPalInstalled(context)) { diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java index ea68b5b6ed..3bb81af02a 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java @@ -17,8 +17,10 @@ import com.braintreepayments.api.BrowserSwitchOptions; import com.braintreepayments.api.core.AnalyticsEventParams; import com.braintreepayments.api.core.BraintreeClient; +import com.braintreepayments.api.core.BraintreeException; import com.braintreepayments.api.core.BraintreeRequestCodes; import com.braintreepayments.api.core.Configuration; +import com.braintreepayments.api.core.GetReturnLinkUseCase; import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.testutils.Fixtures; import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; @@ -43,6 +45,7 @@ public class PayPalClientUnitTest { private PayPalPaymentAuthCallback paymentAuthCallback; private MerchantRepository merchantRepository; + private GetReturnLinkUseCase getReturnLinkUseCase; @Before public void beforeEach() throws JSONException { @@ -55,6 +58,12 @@ public void beforeEach() throws JSONException { paymentAuthCallback = mock(PayPalPaymentAuthCallback.class); merchantRepository = mock(MerchantRepository.class); + getReturnLinkUseCase = mock(GetReturnLinkUseCase.class); + + when(merchantRepository.getReturnUrlScheme()).thenReturn("com.braintreepayments.demo"); + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.AppLink( + Uri.parse("www.example.com") + )); } @Test @@ -77,7 +86,7 @@ public void createPaymentAuthRequest_callsBackPayPalResponse_sendsStartedAnalyti BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -131,7 +140,7 @@ public void createPaymentAuthRequest_whenLaunchesBrowserSwitchAsNewTaskEnabled_s new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) .launchesBrowserSwitchAsNewTask(true).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -166,7 +175,7 @@ public void createPaymentAuthRequest_setsAppLinkReturnUrl() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) .build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -179,6 +188,78 @@ public void createPaymentAuthRequest_setsAppLinkReturnUrl() { ((PayPalPaymentAuthRequest.ReadyToLaunch) request).getRequestParams().getBrowserSwitchOptions().getAppLinkUri()); } + @Test + public void createPaymentAuthRequest_setsDeepLinkReturnUrlScheme() { + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.DeepLink( + "com.braintreepayments.demo" + )); + PayPalVaultRequest payPalVaultRequest = new PayPalVaultRequest(true); + payPalVaultRequest.setMerchantAccountId("sample-merchant-account-id"); + + PayPalPaymentAuthRequestParams paymentAuthRequest = new PayPalPaymentAuthRequestParams( + payPalVaultRequest, + null, + "https://example.com/approval/url", + "sample-client-metadata-id", + null, + "https://example.com/success/url" + ); + + PayPalInternalClient payPalInternalClient = + new MockPayPalInternalClientBuilder().sendRequestSuccess(paymentAuthRequest) + .build(); + + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) + .build(); + + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); + sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); + + ArgumentCaptor captor = + ArgumentCaptor.forClass(PayPalPaymentAuthRequest.class); + verify(paymentAuthCallback).onPayPalPaymentAuthRequest(captor.capture()); + + PayPalPaymentAuthRequest request = captor.getValue(); + assertTrue(request instanceof PayPalPaymentAuthRequest.ReadyToLaunch); + assertEquals("com.braintreepayments.demo", + ((PayPalPaymentAuthRequest.ReadyToLaunch) request).getRequestParams().getBrowserSwitchOptions().getReturnUrlScheme()); + } + + @Test + public void createPaymentAuthRequest_returnsAnErrorWhen_getReturnLinkUseCase_returnsAFailure() { + BraintreeException exception = new BraintreeException(); + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.Failure(exception)); + + PayPalVaultRequest payPalVaultRequest = new PayPalVaultRequest(true); + payPalVaultRequest.setMerchantAccountId("sample-merchant-account-id"); + + PayPalPaymentAuthRequestParams paymentAuthRequest = new PayPalPaymentAuthRequestParams( + payPalVaultRequest, + null, + "https://example.com/approval/url", + "sample-client-metadata-id", + null, + "https://example.com/success/url" + ); + + PayPalInternalClient payPalInternalClient = + new MockPayPalInternalClientBuilder().sendRequestSuccess(paymentAuthRequest) + .build(); + + BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig) + .build(); + + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); + sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); + + ArgumentCaptor captor = ArgumentCaptor.forClass(PayPalPaymentAuthRequest.class); + verify(paymentAuthCallback).onPayPalPaymentAuthRequest(captor.capture()); + + PayPalPaymentAuthRequest request = captor.getValue(); + assertTrue(request instanceof PayPalPaymentAuthRequest.Failure); + assertEquals(exception, ((PayPalPaymentAuthRequest.Failure) request).getError()); + } + @Test public void createPaymentAuthRequest_whenPayPalNotEnabled_returnsError() { PayPalInternalClient payPalInternalClient = new MockPayPalInternalClientBuilder().build(); @@ -186,7 +267,7 @@ public void createPaymentAuthRequest_whenPayPalNotEnabled_returnsError() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalDisabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, new PayPalCheckoutRequest("1.00", true), paymentAuthCallback); @@ -215,7 +296,7 @@ public void createPaymentAuthRequest_whenCheckoutRequest_whenConfigError_forward .configurationError(authError) .build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, new PayPalCheckoutRequest("1.00", true), paymentAuthCallback); ArgumentCaptor captor = @@ -240,7 +321,7 @@ public void requestBillingAgreement_whenConfigError_forwardsErrorToListener() { .configurationError(authError) .build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, new PayPalVaultRequest(true), paymentAuthCallback); ArgumentCaptor captor = @@ -266,7 +347,7 @@ public void createPaymentAuthRequest_whenVaultRequest_sendsPayPalRequestViaInter PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalRequest, paymentAuthCallback); verify(payPalInternalClient).sendRequest(same(activity), same(payPalRequest), @@ -282,7 +363,7 @@ public void createPaymentAuthRequest_whenCheckoutRequest_sendsPayPalRequestViaIn PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalRequest, paymentAuthCallback); verify(payPalInternalClient).sendRequest(same(activity), same(payPalRequest), @@ -314,7 +395,7 @@ public void createPaymentAuthRequest_whenVaultRequest_sendsAppSwitchStartedEvent BraintreeClient braintreeClient = new MockBraintreeClientBuilder().configuration(payPalEnabledConfig).build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.createPaymentAuthRequest(activity, payPalVaultRequest, paymentAuthCallback); ArgumentCaptor captor = @@ -359,7 +440,7 @@ public void tokenize_withBillingAgreement_tokenizesResponseOnSuccess() throws JS PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -403,7 +484,7 @@ public void tokenize_withOneTimePayment_tokenizesResponseOnSuccess() throws JSON PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -448,7 +529,7 @@ public void tokenize_whenCancelUriReceived_notifiesCancellationAndSendsAnalytics PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -488,7 +569,7 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_callsBackResult() PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -530,7 +611,7 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_sendsAppSwitchSuccee PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -569,7 +650,7 @@ public void tokenize_whenPayPalNotEnabled_sendsAppSwitchFailedEvents() throws JS PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); @@ -601,7 +682,7 @@ public void tokenize_whenCancelUriReceived_sendsAppSwitchCanceledEvents() PayPalPaymentAuthResult.Success payPalPaymentAuthResult = new PayPalPaymentAuthResult.Success( browserSwitchResult); BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); - PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository); + PayPalClient sut = new PayPalClient(braintreeClient, payPalInternalClient, merchantRepository, getReturnLinkUseCase); sut.tokenize(payPalPaymentAuthResult, payPalTokenizeCallback); diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java index d743584131..0de7604dc5 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalInternalClientUnitTest.java @@ -20,9 +20,11 @@ import com.braintreepayments.api.core.ApiClient; import com.braintreepayments.api.core.BraintreeClient; +import com.braintreepayments.api.core.BraintreeException; import com.braintreepayments.api.core.ClientToken; import com.braintreepayments.api.core.Configuration; import com.braintreepayments.api.core.DeviceInspector; +import com.braintreepayments.api.core.GetReturnLinkUseCase; import com.braintreepayments.api.core.MerchantRepository; import com.braintreepayments.api.core.PostalAddress; import com.braintreepayments.api.core.TokenizationKey; @@ -63,6 +65,7 @@ public class PayPalInternalClientUnitTest { PayPalInternalClientCallback payPalInternalClientCallback; private MerchantRepository merchantRepository = mock(MerchantRepository.class); + private GetReturnLinkUseCase getReturnLinkUseCase = mock(GetReturnLinkUseCase.class); @Before public void beforeEach() throws JSONException { @@ -75,6 +78,10 @@ public void beforeEach() throws JSONException { apiClient = mock(ApiClient.class); deviceInspector = mock(DeviceInspector.class); payPalInternalClientCallback = mock(PayPalInternalClientCallback.class); + + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.AppLink( + Uri.parse("https://example.com") + )); } @Test @@ -92,7 +99,8 @@ public void sendRequest_withPayPalVaultRequest_sendsAllParameters() throws JSONE dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PostalAddress shippingAddressOverride = new PostalAddress(); @@ -153,6 +161,87 @@ public void sendRequest_withPayPalVaultRequest_sendsAllParameters() throws JSONE JSONAssert.assertEquals(expected, actual, true); } + @Test + public void sendRequest_withPayPalVaultRequest_sendsAllParameters_with_deep_link() throws JSONException { + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.DeepLink( + "com.braintreepayments.demo" + )); + + BraintreeClient braintreeClient = new MockBraintreeClientBuilder() + .configuration(configuration) + .build(); + when(clientToken.getBearer()).thenReturn("client-token-bearer"); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(merchantRepository.getReturnUrlScheme()).thenReturn("com.braintreepayments.demo"); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository, + getReturnLinkUseCase + ); + + PostalAddress shippingAddressOverride = new PostalAddress(); + shippingAddressOverride.setRecipientName("Brianna Tree"); + shippingAddressOverride.setStreetAddress("123 Fake St."); + shippingAddressOverride.setExtendedAddress("Apt. v.0"); + shippingAddressOverride.setLocality("Oakland"); + shippingAddressOverride.setRegion("CA"); + shippingAddressOverride.setPostalCode("12345"); + shippingAddressOverride.setCountryCodeAlpha2("US"); + + PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); + payPalRequest.setBillingAgreementDescription("Billing Agreement Description"); + payPalRequest.setMerchantAccountId("sample-merchant-account-id"); + payPalRequest.setLandingPageType(PayPalLandingPageType.LANDING_PAGE_TYPE_BILLING); + payPalRequest.setDisplayName("sample-display-name"); + payPalRequest.setLocaleCode("US"); + payPalRequest.setShippingAddressRequired(true); + payPalRequest.setShippingAddressEditable(true); + payPalRequest.setShouldOfferCredit(true); + payPalRequest.setShippingAddressOverride(shippingAddressOverride); + + sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); + + ArgumentCaptor captor = ArgumentCaptor.forClass(String.class); + verify(braintreeClient).sendPOST( + eq("/v1/paypal_hermes/setup_billing_agreement"), + captor.capture(), + anyMap(), + any(HttpResponseCallback.class) + ); + + String result = captor.getValue(); + JSONObject actual = new JSONObject(result); + + JSONObject expected = new JSONObject() + .put("authorization_fingerprint", "client-token-bearer") + .put("return_url", "com.braintreepayments.demo://onetouch/v1/success") + .put("cancel_url", "com.braintreepayments.demo://onetouch/v1/cancel") + .put("offer_paypal_credit", true) + .put("description", "Billing Agreement Description") + .put("experience_profile", new JSONObject() + .put("no_shipping", false) + .put("landing_page_type", "billing") + .put("brand_name", "sample-display-name") + .put("locale_code", "US") + .put("address_override", false)) + .put("shipping_address", new JSONObject() + .put("line1", "123 Fake St.") + .put("line2", "Apt. v.0") + .put("city", "Oakland") + .put("state", "CA") + .put("postal_code", "12345") + .put("country_code", "US") + .put("recipient_name", "Brianna Tree")) + .put("merchant_account_id", "sample-merchant-account-id"); + + JSONAssert.assertEquals(expected, actual, true); + } + @Test public void sendRequest_withPayPalCheckoutRequest_sendsAllParameters() throws JSONException { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() @@ -161,14 +250,14 @@ public void sendRequest_withPayPalCheckoutRequest_sendsAllParameters() throws JS when(clientToken.getBearer()).thenReturn("client-token-bearer"); when(merchantRepository.getAuthorization()).thenReturn(clientToken); - when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com")); PayPalInternalClient sut = new PayPalInternalClient( braintreeClient, dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PostalAddress shippingAddressOverride = new PostalAddress(); shippingAddressOverride.setRecipientName("Brianna Tree"); @@ -269,7 +358,8 @@ public void sendRequest_withTokenizationKey_sendsClientKeyParam() throws JSONExc dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -304,7 +394,8 @@ public void sendRequest_withEmptyDisplayName_fallsBackToPayPalConfigurationDispl dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(false); @@ -339,7 +430,8 @@ public void sendRequest_withLocaleNotSpecified_omitsLocale() throws JSONExceptio dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -374,7 +466,8 @@ public void sendRequest_withMerchantAccountIdNotSpecified_omitsMerchantAccountId dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -409,7 +502,8 @@ public void sendRequest_withShippingAddressOverrideNotSpecified_sendsAddressOver dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -445,7 +539,8 @@ public void sendRequest_withShippingAddressSpecified_sendsAddressOverrideBasedOn dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -482,7 +577,8 @@ public void sendRequest_withPayPalVaultRequest_omitsEmptyBillingAgreementDescrip dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -517,7 +613,8 @@ public void sendRequest_withPayPalCheckoutRequest_fallsBackToPayPalConfiguration dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -550,7 +647,8 @@ public void sendRequest_withPayPalCheckoutRequest_omitsEmptyLineItems() throws J dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -587,7 +685,8 @@ public void sendRequest_whenRiskCorrelationIdNotNull_setsClientMetadataIdToRiskC dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -619,7 +718,8 @@ public void sendRequest_whenRiskCorrelationIdNull_setsClientMetadataIdFromPayPal dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -649,7 +749,8 @@ public void sendRequest_withPayPalCheckoutRequest_whenRequestBillingAgreementFal dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -689,7 +790,8 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess( dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -728,7 +830,8 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_ dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -770,7 +873,8 @@ public void sendRequest_withPayPalVaultRequest_callsBackPayPalResponseOnSuccess_ dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalVaultRequest payPalRequest = new PayPalVaultRequest(true); @@ -805,7 +909,8 @@ public void sendRequest_withPayPalCheckoutRequest_callsBackPayPalResponseOnSucce dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -847,7 +952,8 @@ public void sendRequest_propagatesHttpErrors() { dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -870,7 +976,8 @@ public void sendRequest_propagatesMalformedJSONResponseErrors() { dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -894,7 +1001,8 @@ public void sendRequest_onConfigurationFailure_forwardsError() { dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); @@ -903,6 +1011,33 @@ public void sendRequest_onConfigurationFailure_forwardsError() { verify(payPalInternalClientCallback).onResult(null, configurationError); } + @Test + public void sendRequest_returnLinkResultFailure_forwardsError() { + BraintreeException exception = new BraintreeException(); + + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.Failure(exception)); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder() + .configuration(configuration) + .sendPOSTSuccessfulResponse("{bad:") + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + + PayPalInternalClient sut = new PayPalInternalClient( + braintreeClient, + dataCollector, + apiClient, + deviceInspector, + merchantRepository, + getReturnLinkUseCase + ); + + PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); + sut.sendRequest(context, payPalRequest, payPalInternalClientCallback); + + verify(payPalInternalClientCallback).onResult(isNull(), eq(exception)); + } + @Test public void tokenize_tokenizesWithApiClient() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder().build(); @@ -914,7 +1049,8 @@ public void tokenize_tokenizesWithApiClient() { dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); sut.tokenize(payPalAccount, callback); @@ -937,7 +1073,8 @@ public void tokenize_onTokenizeResult_returnsAccountNonceToCallback() throws JSO dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); sut.tokenize(payPalAccount, callback); @@ -967,7 +1104,8 @@ public void tokenize_onTokenizeError_returnsErrorToCallback() { dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); sut.tokenize(payPalAccount, callback); @@ -991,7 +1129,8 @@ public void payPalDataCollector_passes_correct_arguments_to_getClientMetadataId( dataCollector, apiClient, deviceInspector, - merchantRepository + merchantRepository, + getReturnLinkUseCase ); PayPalCheckoutRequest payPalRequest = new PayPalCheckoutRequest("1.00", true); From d0e0e6f8248bfeb5441abc4c219f48c79be30ed1 Mon Sep 17 00:00:00 2001 From: Jax DesMarais-Leder Date: Thu, 5 Dec 2024 09:17:45 -0600 Subject: [PATCH 15/22] Add URL to PayPal App Switch Events (#1226) * send analytics with app switch URL * update unit tests * add CHANGELOG entry * PR feedback: update to use copy * PR feedback: update appSwitchUrl to immutable property --- CHANGELOG.md | 2 ++ .../api/paypal/PayPalClient.kt | 16 +++++++++-- .../api/paypal/PayPalClientUnitTest.java | 28 +++++++++++++++++-- 3 files changed, 42 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index bc38ca05bb..adb0ce3dbb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,8 @@ * Add `deepLinkFallbackUrlScheme` to `PayPalClient` constructor params for supporting deep link fallback * LocalPayment * Make LocalPaymentAuthRequestParams public (fixes #1207) +* PayPal + * Send `url` in `event_params` for App Switch events to PayPal's analytics service (FPTI) ## 5.2.0 (2024-10-30) diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt index 5d00d97370..6e0b14072c 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt @@ -44,6 +44,11 @@ class PayPalClient internal constructor( */ private var isVaultRequest = false + /** + * The final URL string used to open the app switch flow + */ + private var appSwitchUrlString: String? = null + /** * Initializes a new [PayPalClient] instance * @@ -213,6 +218,7 @@ class PayPalClient internal constructor( val isAppSwitchFlow = !switchInitiatedTime.isNullOrEmpty() if (isAppSwitchFlow) { + appSwitchUrlString = approvalUrl braintreeClient.sendAnalyticsEvent( PayPalAnalytics.HANDLE_RETURN_STARTED, analyticsParams @@ -330,7 +336,10 @@ class PayPalClient internal constructor( braintreeClient.sendAnalyticsEvent(PayPalAnalytics.TOKENIZATION_FAILED, analyticsParams) if (isAppSwitchFlow) { - braintreeClient.sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_FAILED, analyticsParams) + braintreeClient.sendAnalyticsEvent( + PayPalAnalytics.APP_SWITCH_FAILED, + analyticsParams.copy(appSwitchUrl = appSwitchUrlString) + ) } callback.onPayPalResult(failure) @@ -344,7 +353,10 @@ class PayPalClient internal constructor( braintreeClient.sendAnalyticsEvent(PayPalAnalytics.TOKENIZATION_SUCCEEDED, analyticsParams) if (isAppSwitchFlow) { - braintreeClient.sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_SUCCEEDED, analyticsParams) + braintreeClient.sendAnalyticsEvent( + PayPalAnalytics.APP_SWITCH_SUCCEEDED, + analyticsParams.copy(appSwitchUrl = appSwitchUrlString) + ) } callback.onPayPalResult(success) diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java index 3bb81af02a..9721d1d5fb 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java @@ -9,6 +9,8 @@ import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; +import static java.util.Collections.emptyList; + import android.net.Uri; import androidx.fragment.app.FragmentActivity; @@ -626,7 +628,18 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_sendsAppSwitchSuccee verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.HANDLE_RETURN_STARTED, params); params.setPayPalContextId("EC-HERMES-SANDBOX-EC-TOKEN"); verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.TOKENIZATION_SUCCEEDED, params); - verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_SUCCEEDED, params); + AnalyticsEventParams appSwitchParams = new AnalyticsEventParams( + "EC-HERMES-SANDBOX-EC-TOKEN", + null, + false, + null, + null, + null, + null, + emptyList(), + "sample-scheme://onetouch/v1/success?PayerID=HERMES-SANDBOX-PAYER-ID&paymentId=HERMES-SANDBOX-PAYMENT-ID&token=EC-HERMES-SANDBOX-EC-TOKEN&switch_initiated_time=17166111926211" + ); + verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_SUCCEEDED, appSwitchParams); } @Test @@ -657,7 +670,18 @@ public void tokenize_whenPayPalNotEnabled_sendsAppSwitchFailedEvents() throws JS AnalyticsEventParams params = new AnalyticsEventParams(); params.setPayPalContextId("SOME-BA"); verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.TOKENIZATION_FAILED, params); - verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_FAILED, params); + AnalyticsEventParams appSwitchParams = new AnalyticsEventParams( + "SOME-BA", + null, + false, + null, + null, + null, + null, + emptyList(), + "https://some-scheme/onetouch/v1/cancel?token=SOME-BA&switch_initiated_time=17166111926211" + ); + verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.APP_SWITCH_FAILED, appSwitchParams); } @Test From 15db334147e50291ebffd9d908845fbef5d6dc5d Mon Sep 17 00:00:00 2001 From: scannillo <35243507+scannillo@users.noreply.github.com> Date: Thu, 5 Dec 2024 14:50:15 -0600 Subject: [PATCH 16/22] Venmo - Support App Link Returns (#1190) --- CHANGELOG.md | 3 ++ .../com/braintreepayments/demo/Settings.java | 4 ++ .../braintreepayments/demo/VenmoFragment.java | 15 +++++-- Demo/src/main/res/values/strings.xml | 2 + Demo/src/main/res/xml/settings.xml | 6 +++ .../api/venmo/VenmoClient.kt | 42 +++++++++++++------ .../api/venmo/VenmoClientUnitTest.java | 40 ++++++++++++++++++ 7 files changed, 96 insertions(+), 16 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index adb0ce3dbb..7f4119ef80 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,6 +16,9 @@ * Shopper Insights (BETA) * For analytics, send `experiment` as a parameter to `getRecommendedPaymentMethods` method * For analytics, send `experiment` and `paymentMethodsDisplayed` analytic metrics to FPTI via the button presented event methods +* Venmo + * Add `VenmoClient` constructor with `appLinkReturnUri` argument to use App Links when redirecting back from the Venmo flow + * Deprecate `VenmoClient` constructor with `returnUrlScheme` argument ## 5.1.0 (2024-10-15) diff --git a/Demo/src/main/java/com/braintreepayments/demo/Settings.java b/Demo/src/main/java/com/braintreepayments/demo/Settings.java index 569a954f25..da6bbd3964 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/Settings.java +++ b/Demo/src/main/java/com/braintreepayments/demo/Settings.java @@ -210,6 +210,10 @@ public static boolean vaultVenmo(Context context) { return getPreferences(context).getBoolean("vault_venmo", true); } + public static boolean useAppLinkReturn(Context context) { + return getPreferences(context).getBoolean("use_app_link_return", true); + } + public static boolean isAmexRewardsBalanceEnabled(Context context) { return getPreferences(context).getBoolean("amex_rewards_balance", false); } diff --git a/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java b/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java index b51ec38885..4e89b9c5dc 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java +++ b/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java @@ -1,5 +1,6 @@ package com.braintreepayments.demo; +import android.net.Uri; import android.os.Bundle; import android.text.TextUtils; import android.view.LayoutInflater; @@ -79,13 +80,21 @@ private void handleVenmoAccountNonce(VenmoAccountNonce venmoAccountNonce) { } public void launchVenmo(View v) { + FragmentActivity activity = getActivity(); + getActivity().setProgressBarIndeterminateVisibility(true); if (venmoClient == null) { - venmoClient = new VenmoClient(requireContext(), super.getAuthStringArg(), null); + if (Settings.useAppLinkReturn(activity)) { + venmoClient = new VenmoClient( + requireContext(), + super.getAuthStringArg(), + Uri.parse("https://mobile-sdk-demo-site-838cead5d3ab.herokuapp.com/braintree-payments") + ); + } else { + venmoClient = new VenmoClient(requireContext(), super.getAuthStringArg()); + } } - FragmentActivity activity = getActivity(); - boolean shouldVault = Settings.vaultVenmo(activity) && !TextUtils.isEmpty(Settings.getCustomerId(activity)); diff --git a/Demo/src/main/res/values/strings.xml b/Demo/src/main/res/values/strings.xml index d3272218a6..d8f3251404 100644 --- a/Demo/src/main/res/values/strings.xml +++ b/Demo/src/main/res/values/strings.xml @@ -93,6 +93,8 @@ Venmo Vault Venmo Vault Venmo payment methods on creation. Requires a customer id to be set. + Use App Link + Use merchant App Link, instead of deeplink, when redirecting back from Venmo flow. Amex Get Rewards Balance Fetch Amex Rewards Balance on Card Tokenization. Requires a Client Token and relevant configurations. diff --git a/Demo/src/main/res/xml/settings.xml b/Demo/src/main/res/xml/settings.xml index f15ca91bb2..ea7f9561b2 100644 --- a/Demo/src/main/res/xml/settings.xml +++ b/Demo/src/main/res/xml/settings.xml @@ -192,6 +192,12 @@ android:summary="@string/vault_venmo_summary" android:defaultValue="true" /> + + captor = + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); + VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); + VenmoPaymentAuthRequestParams params = ((VenmoPaymentAuthRequest.ReadyToLaunch) paymentAuthRequest).getRequestParams(); + BrowserSwitchOptions browserSwitchOptions = params.getBrowserSwitchOptions(); + + Uri url = browserSwitchOptions.getUrl(); + assertEquals("https://example.com/payments/success", url.getQueryParameter("x-success")); + assertEquals("https://example.com/payments/error", url.getQueryParameter("x-error")); + assertEquals("https://example.com/payments/cancel", url.getQueryParameter("x-cancel")); + } + @Test public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithProfileIdAndAccessToken() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() From f23e3530a7a8f9be63d984e1ffb976432f028c2d Mon Sep 17 00:00:00 2001 From: Jax DesMarais-Leder Date: Fri, 6 Dec 2024 08:33:13 -0600 Subject: [PATCH 17/22] Add `ThreeDSecureRequest.requestorAppUrl` (#1232) * add ThreeDSecureRequest threeDSRequestorAppUrl * pass in new cardinalConfigurationParameters.threeDSRequestorAppURL * add CHANGELOG entry * PR feedback: update name to requestorAppUrl * update CHANGELOG property name * add unit test --- CHANGELOG.md | 5 +++-- .../api/threedsecure/CardinalClient.kt | 3 +++ .../api/threedsecure/ThreeDSecureRequest.kt | 6 +++++- .../api/threedsecure/CardinalClientUnitTest.kt | 16 ++++++++++++++++ 4 files changed, 27 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7f4119ef80..33c35e3db8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,10 +4,11 @@ * PayPal * Add `deepLinkFallbackUrlScheme` to `PayPalClient` constructor params for supporting deep link fallback + * Send `url` in `event_params` for App Switch events to PayPal's analytics service (FPTI) * LocalPayment * Make LocalPaymentAuthRequestParams public (fixes #1207) -* PayPal - * Send `url` in `event_params` for App Switch events to PayPal's analytics service (FPTI) +* ThreeDSecure + * Add `ThreeDSecureRequest.requestorAppUrl` ## 5.2.0 (2024-10-30) diff --git a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/CardinalClient.kt b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/CardinalClient.kt index 4614d5c691..2c802f4334 100644 --- a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/CardinalClient.kt +++ b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/CardinalClient.kt @@ -109,6 +109,9 @@ internal class CardinalClient { cardinalConfigurationParameters.uiCustomization = it.cardinalUiCustomization } + request.requestorAppUrl?.let { + cardinalConfigurationParameters.threeDSRequestorAppURL = it + } try { Cardinal.getInstance().configure(context, cardinalConfigurationParameters) } catch (e: RuntimeException) { diff --git a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureRequest.kt b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureRequest.kt index 626bbb015b..c7bd016005 100644 --- a/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureRequest.kt +++ b/ThreeDSecure/src/main/java/com/braintreepayments/api/threedsecure/ThreeDSecureRequest.kt @@ -49,6 +49,9 @@ import org.json.JSONObject * @property customFields Optional. Object where each key is the name of a custom field which has * been configured in the Control Panel. In the Control Panel you can configure 3D Secure Rules * which trigger on certain values. + * @property requestorAppUrl Optional. Three DS Requester APP URL Merchant app declaring their + * URL within the CReq message so that the Authentication app can call the Merchant app after + * OOB authentication has occurred. */ @Parcelize data class ThreeDSecureRequest @JvmOverloads constructor( @@ -68,7 +71,8 @@ data class ThreeDSecureRequest @JvmOverloads constructor( var v2UiCustomization: ThreeDSecureV2UiCustomization? = null, var uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, var renderTypes: List? = null, - var customFields: Map? = null + var customFields: Map? = null, + var requestorAppUrl: String? = null ) : Parcelable { /** diff --git a/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/CardinalClientUnitTest.kt b/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/CardinalClientUnitTest.kt index ae23c15e14..c4408afb5e 100644 --- a/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/CardinalClientUnitTest.kt +++ b/ThreeDSecure/src/test/java/com/braintreepayments/api/threedsecure/CardinalClientUnitTest.kt @@ -185,6 +185,22 @@ class CardinalClientUnitTest { assertEquals(exceptionSlot.captured.message, "consumer session id not available") } + @Test + fun `when cardinal configuration is called with a requestorAppUrl, sets threeDSRequestorAppURL`() { + every { Cardinal.getInstance() } returns cardinalInstance + + val sut = CardinalClient() + val request = ThreeDSecureRequest() + request.requestorAppUrl = "www.paypal.com" + sut.initialize(context, configuration, request, cardinalInitializeCallback) + + val parametersSlot = slot() + verify { cardinalInstance.configure(context, capture(parametersSlot)) } + + val parameters = parametersSlot.captured + assertEquals("www.paypal.com", parameters.threeDSRequestorAppURL) + } + @Test fun initialize_onCardinalConfigureRuntimeException_throwsError() { every { Cardinal.getInstance() } returns cardinalInstance From e12b9858980852aa5bafa83d43be68b6dc86c8c3 Mon Sep 17 00:00:00 2001 From: Jax DesMarais-Leder Date: Fri, 6 Dec 2024 10:59:34 -0600 Subject: [PATCH 18/22] move app link under unreleased (#1234) --- CHANGELOG.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 33c35e3db8..6e8db3f936 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,9 @@ * Make LocalPaymentAuthRequestParams public (fixes #1207) * ThreeDSecure * Add `ThreeDSecureRequest.requestorAppUrl` +* Venmo + * Add `VenmoClient` constructor with `appLinkReturnUri` argument to use App Links when redirecting back from the Venmo flow + * Deprecate `VenmoClient` constructor with `returnUrlScheme` argument ## 5.2.0 (2024-10-30) @@ -17,9 +20,6 @@ * Shopper Insights (BETA) * For analytics, send `experiment` as a parameter to `getRecommendedPaymentMethods` method * For analytics, send `experiment` and `paymentMethodsDisplayed` analytic metrics to FPTI via the button presented event methods -* Venmo - * Add `VenmoClient` constructor with `appLinkReturnUri` argument to use App Links when redirecting back from the Venmo flow - * Deprecate `VenmoClient` constructor with `returnUrlScheme` argument ## 5.1.0 (2024-10-15) From caf65bd0b7667d57d7b117cbf2c1db37facf6706 Mon Sep 17 00:00:00 2001 From: saperi22 <104481964+saperi22@users.noreply.github.com> Date: Tue, 10 Dec 2024 11:55:13 -0800 Subject: [PATCH 19/22] Paypal analytics (#1231) * Add constants * Add analytics around app switch return to app * remove analytics captured in the wrong place --- .../api/paypal/PayPalAnalytics.kt | 3 ++ .../api/paypal/PayPalClient.kt | 4 -- .../api/paypal/PayPalLauncher.kt | 37 +++++++++++---- .../api/paypal/PayPalClientUnitTest.java | 1 - .../api/paypal/PayPalLauncherUnitTest.kt | 47 +++++++++++++++++-- 5 files changed, 75 insertions(+), 17 deletions(-) diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalAnalytics.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalAnalytics.kt index d8abc15df8..279d934292 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalAnalytics.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalAnalytics.kt @@ -10,6 +10,9 @@ internal object PayPalAnalytics { // Additional Conversion events const val HANDLE_RETURN_STARTED = "paypal:tokenize:handle-return:started" + const val HANDLE_RETURN_SUCCEEDED = "paypal:tokenize:handle-return:succeeded" + const val HANDLE_RETURN_FAILED = "paypal:tokenize:handle-return:failed" + const val HANDLE_RETURN_NO_RESULT = "paypal:tokenize:handle-return:no-result" // App Switch events const val APP_SWITCH_STARTED = "paypal:tokenize:app-switch:started" diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt index 6e0b14072c..9958c67bbd 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalClient.kt @@ -219,10 +219,6 @@ class PayPalClient internal constructor( if (isAppSwitchFlow) { appSwitchUrlString = approvalUrl - braintreeClient.sendAnalyticsEvent( - PayPalAnalytics.HANDLE_RETURN_STARTED, - analyticsParams - ) } approvalUrl?.let { diff --git a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalLauncher.kt b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalLauncher.kt index a169f12f43..290bf4affc 100644 --- a/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalLauncher.kt +++ b/PayPal/src/main/java/com/braintreepayments/api/paypal/PayPalLauncher.kt @@ -6,16 +6,25 @@ import com.braintreepayments.api.BrowserSwitchClient import com.braintreepayments.api.BrowserSwitchException import com.braintreepayments.api.BrowserSwitchFinalResult import com.braintreepayments.api.BrowserSwitchStartResult +import com.braintreepayments.api.core.AnalyticsClient import com.braintreepayments.api.core.BraintreeException /** * Responsible for launching PayPal user authentication in a web browser */ -class PayPalLauncher internal constructor(private val browserSwitchClient: BrowserSwitchClient) { +class PayPalLauncher internal constructor( + private val browserSwitchClient: BrowserSwitchClient, + lazyAnalyticsClient: Lazy +) { /** * Used to launch the PayPal flow in a web browser and deliver results to your Activity */ - constructor() : this(BrowserSwitchClient()) + constructor() : this( + browserSwitchClient = BrowserSwitchClient(), + lazyAnalyticsClient = AnalyticsClient.lazyInstance + ) + + private val analyticsClient: AnalyticsClient by lazyAnalyticsClient /** * Launches the PayPal flow by switching to a web browser for user authentication @@ -73,17 +82,27 @@ class PayPalLauncher internal constructor(private val browserSwitchClient: Brows pendingRequest: PayPalPendingRequest.Started, intent: Intent ): PayPalPaymentAuthResult { + analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_STARTED) return when (val browserSwitchResult = browserSwitchClient.completeRequest(intent, pendingRequest.pendingRequestString)) { - is BrowserSwitchFinalResult.Success -> PayPalPaymentAuthResult.Success( - browserSwitchResult - ) + is BrowserSwitchFinalResult.Success -> { + analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_SUCCEEDED) + PayPalPaymentAuthResult.Success( + browserSwitchResult + ) + } - is BrowserSwitchFinalResult.Failure -> PayPalPaymentAuthResult.Failure( - browserSwitchResult.error - ) + is BrowserSwitchFinalResult.Failure -> { + analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_FAILED) + PayPalPaymentAuthResult.Failure( + browserSwitchResult.error + ) + } - is BrowserSwitchFinalResult.NoResult -> PayPalPaymentAuthResult.NoResult + is BrowserSwitchFinalResult.NoResult -> { + analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_NO_RESULT) + PayPalPaymentAuthResult.NoResult + } } } diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java index 9721d1d5fb..07f0418064 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalClientUnitTest.java @@ -625,7 +625,6 @@ public void tokenize_whenPayPalInternalClientTokenizeResult_sendsAppSwitchSuccee assertEquals(payPalAccountNonce, ((PayPalResult.Success) result).getNonce()); AnalyticsEventParams params = new AnalyticsEventParams(); - verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.HANDLE_RETURN_STARTED, params); params.setPayPalContextId("EC-HERMES-SANDBOX-EC-TOKEN"); verify(braintreeClient).sendAnalyticsEvent(PayPalAnalytics.TOKENIZATION_SUCCEEDED, params); AnalyticsEventParams appSwitchParams = new AnalyticsEventParams( diff --git a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalLauncherUnitTest.kt b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalLauncherUnitTest.kt index 247627ca3d..57b004db00 100644 --- a/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalLauncherUnitTest.kt +++ b/PayPal/src/test/java/com/braintreepayments/api/paypal/PayPalLauncherUnitTest.kt @@ -7,8 +7,10 @@ import com.braintreepayments.api.BrowserSwitchException import com.braintreepayments.api.BrowserSwitchFinalResult import com.braintreepayments.api.BrowserSwitchOptions import com.braintreepayments.api.BrowserSwitchStartResult +import com.braintreepayments.api.core.AnalyticsClient import io.mockk.every import io.mockk.mockk +import io.mockk.verify import org.json.JSONException import org.junit.Assert.assertEquals import org.junit.Assert.assertSame @@ -26,13 +28,14 @@ class PayPalLauncherUnitTest { private val intent: Intent = mockk(relaxed = true) private val options: BrowserSwitchOptions = mockk(relaxed = true) private val pendingRequestString = "pending_request_string" + private val analyticsClient: AnalyticsClient = mockk(relaxed = true) private lateinit var sut: PayPalLauncher @Before fun setup() { every { paymentAuthRequestParams.browserSwitchOptions } returns options - sut = PayPalLauncher(browserSwitchClient) + sut = PayPalLauncher(browserSwitchClient, lazy { analyticsClient }) } @Test @@ -90,6 +93,16 @@ class PayPalLauncherUnitTest { ) } + @Test + @Throws(JSONException::class) + fun `handleReturnToApp sends started event`() { + sut.handleReturnToApp( + PayPalPendingRequest.Started(pendingRequestString), + intent + ) + verify { analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_STARTED) } + } + @Test @Throws(JSONException::class) fun `handleReturnToApp when result exists returns result`() { @@ -102,7 +115,8 @@ class PayPalLauncherUnitTest { } returns browserSwitchFinalResult val paymentAuthResult = sut.handleReturnToApp( - PayPalPendingRequest.Started(pendingRequestString), intent + PayPalPendingRequest.Started(pendingRequestString), + intent ) assertTrue(paymentAuthResult is PayPalPaymentAuthResult.Success) @@ -110,6 +124,31 @@ class PayPalLauncherUnitTest { browserSwitchFinalResult, (paymentAuthResult as PayPalPaymentAuthResult.Success).browserSwitchSuccess ) + verify { analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_SUCCEEDED) } + } + + @Test + @Throws(JSONException::class) + fun `handleReturnToApp when result fails returns failed result`() { + val browserSwitchFinalResult = mockk() + every { + browserSwitchClient.completeRequest(intent, pendingRequestString) + } returns browserSwitchFinalResult + + val exception = BrowserSwitchException("BrowserSwitchException") + every { browserSwitchFinalResult.error } returns exception + + val paymentAuthResult = sut.handleReturnToApp( + PayPalPendingRequest.Started(pendingRequestString), + intent + ) + + assertTrue(paymentAuthResult is PayPalPaymentAuthResult.Failure) + assertSame( + exception, + (paymentAuthResult as PayPalPaymentAuthResult.Failure).error + ) + verify { analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_FAILED) } } @Test @@ -120,9 +159,11 @@ class PayPalLauncherUnitTest { } returns BrowserSwitchFinalResult.NoResult val paymentAuthResult = sut.handleReturnToApp( - PayPalPendingRequest.Started(pendingRequestString), intent + PayPalPendingRequest.Started(pendingRequestString), + intent ) assertTrue(paymentAuthResult is PayPalPaymentAuthResult.NoResult) + verify { analyticsClient.sendEvent(PayPalAnalytics.HANDLE_RETURN_NO_RESULT) } } } From 7fc4f263a6198ff047c95b5292003ac7ad4c5070 Mon Sep 17 00:00:00 2001 From: Tim Chow Date: Tue, 10 Dec 2024 14:35:00 -0600 Subject: [PATCH 20/22] Venmo - Add deep link fallback (#1237) --- CHANGELOG.md | 1 + Demo/src/main/AndroidManifest.xml | 1 + .../braintreepayments/demo/VenmoFragment.java | 34 ++-- .../api/venmo/VenmoClient.kt | 75 ++++++--- .../api/venmo/VenmoClientUnitTest.java | 154 +++++++++++++----- 5 files changed, 183 insertions(+), 82 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6e8db3f936..0834c20a10 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -11,6 +11,7 @@ * Add `ThreeDSecureRequest.requestorAppUrl` * Venmo * Add `VenmoClient` constructor with `appLinkReturnUri` argument to use App Links when redirecting back from the Venmo flow + * Add `deepLinkFallbackUrlScheme` to `VenmoClient` constructor params for supporting deep link fallback * Deprecate `VenmoClient` constructor with `returnUrlScheme` argument ## 5.2.0 (2024-10-30) diff --git a/Demo/src/main/AndroidManifest.xml b/Demo/src/main/AndroidManifest.xml index 101229fb26..c09b65871d 100644 --- a/Demo/src/main/AndroidManifest.xml +++ b/Demo/src/main/AndroidManifest.xml @@ -37,6 +37,7 @@ + diff --git a/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java b/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java index 4e89b9c5dc..22684c9ce4 100644 --- a/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java +++ b/Demo/src/main/java/com/braintreepayments/demo/VenmoFragment.java @@ -14,6 +14,7 @@ import androidx.navigation.NavDirections; import androidx.navigation.fragment.NavHostFragment; +import com.braintreepayments.api.core.UserCanceledException; import com.braintreepayments.api.venmo.VenmoAccountNonce; import com.braintreepayments.api.venmo.VenmoClient; import com.braintreepayments.api.venmo.VenmoLauncher; @@ -25,7 +26,6 @@ import com.braintreepayments.api.venmo.VenmoPendingRequest; import com.braintreepayments.api.venmo.VenmoRequest; import com.braintreepayments.api.venmo.VenmoResult; -import com.braintreepayments.api.core.UserCanceledException; import java.util.ArrayList; @@ -42,6 +42,18 @@ public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup c venmoButton = view.findViewById(R.id.venmo_button); venmoButton.setOnClickListener(this::launchVenmo); + if (venmoClient == null) { + if (Settings.useAppLinkReturn(requireContext())) { + venmoClient = new VenmoClient( + requireContext(), + super.getAuthStringArg(), + Uri.parse("https://mobile-sdk-demo-site-838cead5d3ab.herokuapp.com/braintree-payments"), + "com.braintreepayments.demo.braintree" + ); + } else { + venmoClient = new VenmoClient(requireContext(), super.getAuthStringArg()); + } + } venmoLauncher = new VenmoLauncher(); return view; @@ -71,11 +83,11 @@ private void handleVenmoResult(VenmoResult result) { handleError(new UserCanceledException("User canceled Venmo")); } } + private void handleVenmoAccountNonce(VenmoAccountNonce venmoAccountNonce) { super.onPaymentMethodNonceCreated(venmoAccountNonce); - NavDirections action = - VenmoFragmentDirections.actionVenmoFragmentToDisplayNonceFragment(venmoAccountNonce); + NavDirections action = VenmoFragmentDirections.actionVenmoFragmentToDisplayNonceFragment(venmoAccountNonce); NavHostFragment.findNavController(this).navigate(action); } @@ -83,23 +95,12 @@ public void launchVenmo(View v) { FragmentActivity activity = getActivity(); getActivity().setProgressBarIndeterminateVisibility(true); - if (venmoClient == null) { - if (Settings.useAppLinkReturn(activity)) { - venmoClient = new VenmoClient( - requireContext(), - super.getAuthStringArg(), - Uri.parse("https://mobile-sdk-demo-site-838cead5d3ab.herokuapp.com/braintree-payments") - ); - } else { - venmoClient = new VenmoClient(requireContext(), super.getAuthStringArg()); - } - } boolean shouldVault = - Settings.vaultVenmo(activity) && !TextUtils.isEmpty(Settings.getCustomerId(activity)); + Settings.vaultVenmo(activity) && !TextUtils.isEmpty(Settings.getCustomerId(activity)); VenmoPaymentMethodUsage venmoPaymentMethodUsage = shouldVault ? - VenmoPaymentMethodUsage.MULTI_USE : VenmoPaymentMethodUsage.SINGLE_USE; + VenmoPaymentMethodUsage.MULTI_USE : VenmoPaymentMethodUsage.SINGLE_USE; VenmoRequest venmoRequest = new VenmoRequest(venmoPaymentMethodUsage); venmoRequest.setProfileId(null); venmoRequest.setShouldVault(shouldVault); @@ -139,6 +140,7 @@ private void completeVenmoFlow(VenmoPaymentAuthResult.Success paymentAuthResult) private void storePendingRequest(VenmoPendingRequest.Started request) { PendingRequestStore.getInstance().putVenmoPendingRequest(requireContext(), request); } + private VenmoPendingRequest.Started getPendingRequest() { return PendingRequestStore.getInstance().getVenmoPendingRequest(requireContext()); } diff --git a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt index e4639e1988..efaef70666 100644 --- a/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt +++ b/Venmo/src/main/java/com/braintreepayments/api/venmo/VenmoClient.kt @@ -16,6 +16,7 @@ import com.braintreepayments.api.core.BraintreeException import com.braintreepayments.api.core.BraintreeRequestCodes import com.braintreepayments.api.core.ClientToken import com.braintreepayments.api.core.Configuration +import com.braintreepayments.api.core.GetReturnLinkUseCase import com.braintreepayments.api.core.MerchantRepository import com.braintreepayments.api.core.MetadataBuilder import org.json.JSONException @@ -32,7 +33,8 @@ class VenmoClient internal constructor( private val sharedPrefsWriter: VenmoSharedPrefsWriter = VenmoSharedPrefsWriter(), private val analyticsParamRepository: AnalyticsParamRepository = AnalyticsParamRepository.instance, private val merchantRepository: MerchantRepository = MerchantRepository.instance, - private val venmoRepository: VenmoRepository = VenmoRepository.instance + private val venmoRepository: VenmoRepository = VenmoRepository.instance, + private val getReturnLinkUseCase: GetReturnLinkUseCase = GetReturnLinkUseCase(merchantRepository) ) { /** * Used for linking events from the client to server side request @@ -52,12 +54,24 @@ class VenmoClient internal constructor( * @param authorization a Tokenization Key or Client Token used to authenticate * @param appLinkReturnUrl A [Uri] containing the Android App Link website associated with * your application to be used to return to your app from the PayPal + * @param deepLinkFallbackUrlScheme A return url scheme that will be used as a deep link fallback when returning to + * your app via App Link is not available (buyer unchecks the "Open supported links" setting). */ + @JvmOverloads constructor( context: Context, authorization: String, appLinkReturnUrl: Uri, - ) : this(BraintreeClient(context, authorization, null, appLinkReturnUrl)) + deepLinkFallbackUrlScheme: String? = null + ) : this( + BraintreeClient( + context = context, + authorization = authorization, + returnUrlScheme = null, + appLinkReturnUri = appLinkReturnUrl, + deepLinkFallbackUrlScheme = deepLinkFallbackUrlScheme + ) + ) /** * Initializes a new [VenmoClient] instance @@ -67,7 +81,8 @@ class VenmoClient internal constructor( * @param returnUrlScheme a custom return url to use for browser and app switching */ @Deprecated("Use the constructor that uses an `appLinkReturnUrl` to redirect back to your application instead.") - @JvmOverloads constructor( + @JvmOverloads + constructor( context: Context, authorization: String, returnUrlScheme: String? = null @@ -82,6 +97,7 @@ class VenmoClient internal constructor( * @param request [VenmoRequest] * @param callback [VenmoPaymentAuthRequestCallback] */ + @Suppress("LongMethod", "CyclomaticComplexMethod", "TooGenericExceptionCaught") fun createPaymentAuthRequest( context: Context, request: VenmoRequest, @@ -138,8 +154,14 @@ class VenmoClient internal constructor( merchantRepository.authorization, finalVenmoProfileId, paymentContextId, callback ) - } catch (e: JSONException) { - callbackPaymentAuthFailure(callback, VenmoPaymentAuthRequest.Failure(e)) + } catch (e: Exception) { + when (e) { + is JSONException, is BraintreeException -> { + callbackPaymentAuthFailure(callback, VenmoPaymentAuthRequest.Failure(e)) + } + + else -> throw e + } } } else { callbackPaymentAuthFailure(callback, VenmoPaymentAuthRequest.Failure(exception)) @@ -171,22 +193,27 @@ class VenmoClient internal constructor( val braintreeData = JSONObject() .put("_meta", metadata) - val applicationName = - context.packageManager.getApplicationLabel(context.applicationInfo) - .toString() + val applicationName = context.packageManager.getApplicationLabel(context.applicationInfo).toString() - val merchantBaseUri = merchantRepository.appLinkReturnUri - ?: Uri.parse("${braintreeClient.getReturnUrlScheme()}://x-callback-url/vzero/auth/venmo") + val returnLinkResult = getReturnLinkUseCase() + val merchantBaseUrl: String = when (returnLinkResult) { + is GetReturnLinkUseCase.ReturnLinkResult.AppLink -> returnLinkResult.appLinkReturnUri.toString() + is GetReturnLinkUseCase.ReturnLinkResult.DeepLink -> { + "${returnLinkResult.deepLinkFallbackUrlScheme}://x-callback-url/vzero/auth/venmo" + } - val successUri = merchantBaseUri.buildUpon().appendPath("success").build() - val cancelUri = merchantBaseUri.buildUpon().appendPath("cancel").build() - val errorUri = merchantBaseUri.buildUpon().appendPath("error").build() + is GetReturnLinkUseCase.ReturnLinkResult.Failure -> throw returnLinkResult.exception + } + + val successUri = "$merchantBaseUrl/success" + val cancelUri = "$merchantBaseUrl/cancel" + val errorUri = "$merchantBaseUrl/error" val venmoBaseURL = Uri.parse("https://venmo.com/go/checkout") .buildUpon() - .appendQueryParameter("x-success", successUri.toString()) - .appendQueryParameter("x-error", errorUri.toString()) - .appendQueryParameter("x-cancel", cancelUri.toString()) + .appendQueryParameter("x-success", successUri) + .appendQueryParameter("x-error", errorUri) + .appendQueryParameter("x-cancel", cancelUri) .appendQueryParameter("x-source", applicationName) .appendQueryParameter("braintree_merchant_id", venmoProfileId) .appendQueryParameter("braintree_access_token", configuration?.venmoAccessToken) @@ -204,11 +231,17 @@ class VenmoClient internal constructor( val browserSwitchOptions = BrowserSwitchOptions() .requestCode(BraintreeRequestCodes.VENMO.code) .url(venmoBaseURL) - .appLinkUri(merchantRepository.appLinkReturnUri) - .returnUrlScheme(braintreeClient.getReturnUrlScheme()) - val params = VenmoPaymentAuthRequestParams( - browserSwitchOptions - ) + .apply { + when (returnLinkResult) { + is GetReturnLinkUseCase.ReturnLinkResult.AppLink -> appLinkUri(returnLinkResult.appLinkReturnUri) + is GetReturnLinkUseCase.ReturnLinkResult.DeepLink -> { + returnUrlScheme(returnLinkResult.deepLinkFallbackUrlScheme) + } + + is GetReturnLinkUseCase.ReturnLinkResult.Failure -> throw returnLinkResult.exception + } + } + val params = VenmoPaymentAuthRequestParams(browserSwitchOptions) callback.onVenmoPaymentAuthRequest(VenmoPaymentAuthRequest.ReadyToLaunch(params)) } diff --git a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java index 70953cb4d5..b0d0925f73 100644 --- a/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java +++ b/Venmo/src/test/java/com/braintreepayments/api/venmo/VenmoClientUnitTest.java @@ -21,15 +21,16 @@ import com.braintreepayments.api.core.AnalyticsEventParams; import com.braintreepayments.api.core.AnalyticsParamRepository; import com.braintreepayments.api.core.ApiClient; -import com.braintreepayments.api.core.IntegrationType; -import com.braintreepayments.api.core.MerchantRepository; -import com.braintreepayments.api.testutils.Fixtures; -import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; import com.braintreepayments.api.core.Authorization; import com.braintreepayments.api.core.BraintreeClient; import com.braintreepayments.api.core.BraintreeException; import com.braintreepayments.api.core.BraintreeRequestCodes; import com.braintreepayments.api.core.Configuration; +import com.braintreepayments.api.core.GetReturnLinkUseCase; +import com.braintreepayments.api.core.IntegrationType; +import com.braintreepayments.api.core.MerchantRepository; +import com.braintreepayments.api.testutils.Fixtures; +import com.braintreepayments.api.testutils.MockBraintreeClientBuilder; import org.json.JSONException; import org.json.JSONObject; @@ -91,6 +92,7 @@ public class VenmoClientUnitTest { private final MerchantRepository merchantRepository = mock(MerchantRepository.class); private final VenmoRepository venmoRepository = mock(VenmoRepository.class); + private final GetReturnLinkUseCase getReturnLinkUseCase = mock(GetReturnLinkUseCase.class); @Before public void beforeEach() throws JSONException { @@ -116,6 +118,7 @@ public void beforeEach() throws JSONException { when(merchantRepository.getIntegrationType()).thenReturn(IntegrationType.CUSTOM); when(merchantRepository.getApplicationContext()).thenReturn(context); when(venmoRepository.getVenmoUrl()).thenReturn(appSwitchUrl); + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.AppLink(appSwitchUrl)); } @Test @@ -144,7 +147,8 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -158,13 +162,14 @@ public void createPaymentAuthRequest_whenCreatePaymentContextFails_collectAddres } @Test - public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVenmoAuthChallenge() { + public void createPaymentAuthRequest_withDeepLink_whenCreatePaymentContextSucceeds_createsVenmoAuthChallenge() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() .configuration(venmoEnabledConfiguration) .returnUrlScheme("com.example") .build(); when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.DeepLink("com.example")); VenmoApi venmoApi = new MockVenmoApiBuilder() .createPaymentContextSuccess("venmo-payment-context-id") @@ -181,7 +186,8 @@ public void createPaymentAuthRequest_whenCreatePaymentContextSucceeds_createsVen sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -231,7 +237,8 @@ public void createPaymentAuthRequest_whenConfigurationException_forwardsExceptio sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -261,7 +268,8 @@ public void createPaymentAuthRequest_whenVenmoNotEnabled_forwardsExceptionToList sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -297,7 +305,8 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -316,41 +325,78 @@ public void createPaymentAuthRequest_whenProfileIdIsNull_appSwitchesWithMerchant @Test public void createPaymentAuthRequest_whenAppLinkUriSet_appSwitchesWithAppLink() { BraintreeClient braintreeClient = new MockBraintreeClientBuilder() - .configuration(venmoEnabledConfiguration) - .build(); + .configuration(venmoEnabledConfiguration) + .build(); VenmoApi venmoApi = new MockVenmoApiBuilder() - .createPaymentContextSuccess("venmo-payment-context-id") - .build(); + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); request.setProfileId(null); request.setShouldVault(false); - when(merchantRepository.getAppLinkReturnUri()).thenReturn(Uri.parse("https://example.com/payments")); - VenmoClient sut = new VenmoClient( - braintreeClient, - apiClient, - venmoApi, - sharedPrefsWriter, - analyticsParamRepository, - merchantRepository, - venmoRepository + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository, + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); ArgumentCaptor captor = - ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); VenmoPaymentAuthRequestParams params = ((VenmoPaymentAuthRequest.ReadyToLaunch) paymentAuthRequest).getRequestParams(); BrowserSwitchOptions browserSwitchOptions = params.getBrowserSwitchOptions(); Uri url = browserSwitchOptions.getUrl(); - assertEquals("https://example.com/payments/success", url.getQueryParameter("x-success")); - assertEquals("https://example.com/payments/error", url.getQueryParameter("x-error")); - assertEquals("https://example.com/payments/cancel", url.getQueryParameter("x-cancel")); + assertEquals("https://example.com/success", url.getQueryParameter("x-success")); + assertEquals("https://example.com/error", url.getQueryParameter("x-error")); + assertEquals("https://example.com/cancel", url.getQueryParameter("x-cancel")); + } + + @Test + public void createPaymentAuthRequest_throws_error_when_getReturnLinkUseCase_returnsFailure() { + BraintreeException exception = new BraintreeException(); + BraintreeClient braintreeClient = new MockBraintreeClientBuilder() + .configuration(venmoEnabledConfiguration) + .build(); + + when(merchantRepository.getAuthorization()).thenReturn(clientToken); + when(getReturnLinkUseCase.invoke()).thenReturn(new GetReturnLinkUseCase.ReturnLinkResult.Failure(exception)); + + VenmoApi venmoApi = new MockVenmoApiBuilder() + .createPaymentContextSuccess("venmo-payment-context-id") + .build(); + + VenmoRequest request = new VenmoRequest(VenmoPaymentMethodUsage.SINGLE_USE); + request.setProfileId("second-pwv-profile-id"); + request.setShouldVault(false); + + VenmoClient sut = new VenmoClient( + braintreeClient, + apiClient, + venmoApi, + sharedPrefsWriter, + analyticsParamRepository, + merchantRepository, + venmoRepository, + getReturnLinkUseCase + ); + sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); + + ArgumentCaptor captor = + ArgumentCaptor.forClass(VenmoPaymentAuthRequest.class); + verify(venmoPaymentAuthRequestCallback).onVenmoPaymentAuthRequest(captor.capture()); + VenmoPaymentAuthRequest paymentAuthRequest = captor.getValue(); + assertTrue(paymentAuthRequest instanceof VenmoPaymentAuthRequest.Failure); + assertEquals(exception, ((VenmoPaymentAuthRequest.Failure) paymentAuthRequest).getError()); } @Test @@ -376,7 +422,8 @@ public void createPaymentAuthRequest_whenProfileIdIsSpecified_appSwitchesWithPro sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -411,7 +458,8 @@ public void createPaymentAuthRequest_sendsAnalyticsEvent() { sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); verify(braintreeClient).sendAnalyticsEvent(VenmoAnalytics.TOKENIZE_STARTED, new AnalyticsEventParams()); @@ -440,7 +488,8 @@ public void createPaymentAuthRequest_whenShouldVaultIsTrue_persistsVenmoVaultTru sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -470,7 +519,8 @@ public void createPaymentAuthRequest_whenShouldVaultIsFalse_persistsVenmoVaultFa sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -500,7 +550,8 @@ public void createPaymentAuthRequest_withTokenizationKey_persistsVenmoVaultFalse sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -529,7 +580,8 @@ public void createPaymentAuthRequest_whenVenmoApiError_forwardsErrorToListener_a sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.createPaymentAuthRequest(context, request, venmoPaymentAuthRequestCallback); @@ -557,7 +609,8 @@ public void tokenize_withPaymentContextId_requestFromVenmoApi() { sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -583,7 +636,8 @@ public void tokenize_withPaymentAuthResult_whenUserCanceled_returnsCancelAndSend sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -618,7 +672,8 @@ public void tokenize_onGraphQLPostSuccess_returnsNonceToListener_andSendsAnalyti sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -656,7 +711,8 @@ public void tokenize_onGraphQLPostFailure_forwardsExceptionToListener_andSendsAn sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -698,7 +754,8 @@ public void tokenize_withPaymentContext_performsVaultRequestIfRequestPersisted() sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -719,7 +776,8 @@ public void tokenize_postsPaymentMethodNonceOnSuccess() { sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -754,7 +812,8 @@ public void tokenize_performsVaultRequestIfRequestPersisted() throws JSONExcepti sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -777,7 +836,8 @@ public void tokenize_doesNotPerformRequestIfTokenizationKeyUsed() { sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -808,7 +868,8 @@ public void tokenize_withSuccessfulVaultCall_forwardsResultToActivityResultListe sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -849,7 +910,8 @@ public void tokenize_withPaymentContext_withSuccessfulVaultCall_forwardsNonceToC sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -885,7 +947,8 @@ public void tokenize_withFailedVaultCall_forwardsErrorToActivityResultListener_a sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); @@ -930,7 +993,8 @@ public void tokenize_withPaymentContext_withFailedVaultCall_forwardsErrorToCallb sharedPrefsWriter, analyticsParamRepository, merchantRepository, - venmoRepository + venmoRepository, + getReturnLinkUseCase ); sut.tokenize(paymentAuthResult, venmoTokenizeCallback); From c51680ebaf5710b782648bfdc2542a66f188187c Mon Sep 17 00:00:00 2001 From: braintreeps Date: Wed, 11 Dec 2024 20:44:04 +0000 Subject: [PATCH 21/22] Release 5.3.0 --- CHANGELOG.md | 2 +- README.md | 2 +- build.gradle | 2 +- .../-american-express-client.html | 2 +- .../-companion/index.html | 2 +- .../get-rewards-balance.html | 2 +- .../-american-express-client/index.html | 2 +- .../index.html | 2 +- .../on-american-express-result.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/index.html | 2 +- .../-success/rewards-balance.html | 2 +- .../-american-express-result/index.html | 2 +- .../-american-express-rewards-balance.html | 2 +- .../-companion/index.html | 2 +- .../conversion-rate.html | 2 +- .../currency-amount.html | 2 +- .../currency-iso-code.html | 2 +- .../error-code.html | 2 +- .../error-message.html | 2 +- .../index.html | 2 +- .../request-id.html | 2 +- .../rewards-amount.html | 2 +- .../rewards-unit.html | 2 +- .../index.html | 2 +- docs/AmericanExpress/index.html | 2 +- docs/AmericanExpress/navigation.html | 126 +++++++---- ...-t_-k-e-y_-a-n-a-l-y-t-i-c-s_-j-s-o-n.html | 76 +++++++ ...u-t_-k-e-y_-a-u-t-h-o-r-i-z-a-t-i-o-n.html | 76 +++++++ ...u-t_-k-e-y_-c-o-n-f-i-g-u-r-a-t-i-o-n.html | 76 +++++++ ...n-p-u-t_-k-e-y_-i-n-t-e-g-r-a-t-i-o-n.html | 76 +++++++ ...-i-n-p-u-t_-k-e-y_-s-e-s-s-i-o-n_-i-d.html | 76 +++++++ ...a-m-e_-a-n-a-l-y-t-i-c-s_-u-p-l-o-a-d.html | 76 +++++++ ...n-a-m-e_-a-n-a-l-y-t-i-c-s_-w-r-i-t-e.html | 76 +++++++ .../-analytics-client/-companion/index.html | 205 +++++++++++++++++ .../-companion/lazy-instance.html | 76 +++++++ .../-analytics-client/index.html | 164 ++++++++++++++ .../perform-analytics-upload.html | 76 +++++++ .../perform-analytics-write.html | 76 +++++++ .../-analytics-client/report-crash.html | 76 +++++++ .../-analytics-client/send-event.html | 76 +++++++ .../-analytics-event-params.html | 6 +- .../app-switch-url.html | 76 +++++++ .../-analytics-event-params/end-time.html | 2 +- .../-analytics-event-params/endpoint.html | 2 +- .../-analytics-event-params/experiment.html | 2 +- .../-analytics-event-params/index.html | 27 ++- .../is-vault-request.html | 2 +- .../-analytics-event-params/link-type.html | 2 +- .../pay-pal-context-id.html | 2 +- .../payment-methods-displayed.html | 2 +- .../-analytics-event-params/start-time.html | 2 +- .../-analytics-param-repository.html | 2 +- .../-companion/index.html | 2 +- .../-companion/instance.html | 2 +- .../-analytics-param-repository/index.html | 2 +- .../reset-session-id.html | 2 +- .../session-id.html | 2 +- .../-app-switch-not-available-exception.html | 2 +- .../index.html | 2 +- .../-braintree-client/-companion/index.html | 80 +++++++ .../-braintree-client/get-configuration.html | 2 +- .../-braintree-client/index.html | 21 +- .../launches-browser-switch-as-new-task.html | 2 +- .../-braintree-error/-companion/index.html | 2 +- .../-braintree-error/code.html | 2 +- .../-braintree-error/error-for.html | 2 +- .../-braintree-error/field-errors.html | 2 +- .../-braintree-error/field.html | 2 +- .../-braintree-error/index.html | 2 +- .../-braintree-error/message.html | 2 +- .../-braintree-error/to-string.html | 2 +- .../-braintree-exception.html | 2 +- .../-braintree-exception/index.html | 2 +- .../-g-o-o-g-l-e_-p-a-y/index.html | 2 +- .../-l-o-c-a-l_-p-a-y-m-e-n-t/index.html | 2 +- .../-p-a-y-p-a-l/index.html | 2 +- .../-s-e-p-a_-d-e-b-i-t/index.html | 2 +- .../-t-h-r-e-e_-d_-s-e-c-u-r-e/index.html | 2 +- .../-v-e-n-m-o/index.html | 2 +- .../-v-i-s-a_-c-h-e-c-k-o-u-t/index.html | 2 +- .../-braintree-request-codes/code.html | 2 +- .../-braintree-request-codes/entries.html | 2 +- .../-braintree-request-codes/index.html | 2 +- .../-braintree-request-codes/value-of.html | 2 +- .../-braintree-request-codes/values.html | 2 +- .../-configuration-callback/index.html | 2 +- .../-configuration-callback/on-result.html | 2 +- .../-configuration-exception.html | 2 +- .../-configuration-exception/index.html | 2 +- .../-configuration/assets-url.html | 2 +- .../cardinal-authentication-jwt.html | 2 +- .../-configuration/client-api-url.html | 2 +- .../-configuration/environment.html | 2 +- .../-configuration/index.html | 2 +- .../is-cvv-challenge-present.html | 2 +- .../-configuration/is-google-pay-enabled.html | 2 +- .../is-local-payment-enabled.html | 2 +- .../-configuration/is-pay-pal-enabled.html | 2 +- .../is-postal-code-challenge-present.html | 2 +- .../is-three-d-secure-enabled.html | 2 +- .../-configuration/is-venmo-enabled.html | 2 +- .../is-visa-checkout-enabled.html | 2 +- .../-configuration/merchant-account-id.html | 2 +- .../-configuration/merchant-id.html | 2 +- .../pay-pal-direct-base-url.html | 2 +- .../-configuration/pay-pal-privacy-url.html | 2 +- .../pay-pal-user-agreement-url.html | 2 +- .../-configuration/supported-card-types.html | 2 +- .../-configuration/to-json.html | 2 +- .../-companion/index.html | 2 +- .../-error-with-response/error-for.html | 2 +- .../-error-with-response/error-response.html | 2 +- .../-error-with-response/field-errors.html | 2 +- .../-error-with-response/index.html | 2 +- .../-error-with-response/message.html | 2 +- .../-error-with-response/status-code.html | 2 +- .../-error-with-response/to-string.html | 2 +- .../-experimental-beta-api/index.html | 2 +- .../-get-return-link-use-case.html | 76 +++++++ .../-app-link/-app-link.html | 76 +++++++ .../-app-link/app-link-return-uri.html | 76 +++++++ .../-return-link-result/-app-link/index.html | 119 ++++++++++ .../-deep-link/-deep-link.html | 76 +++++++ .../deep-link-fallback-url-scheme.html | 76 +++++++ .../-return-link-result/-deep-link/index.html | 119 ++++++++++ .../-failure/-failure.html | 76 +++++++ .../-failure/exception.html | 76 +++++++ .../-return-link-result/-failure/index.html | 119 ++++++++++ .../-return-link-result/index.html | 130 +++++++++++ .../-get-return-link-use-case/index.html | 138 ++++++++++++ .../-get-return-link-use-case/invoke.html | 76 +++++++ .../-invalid-argument-exception.html | 2 +- .../-invalid-argument-exception/index.html | 2 +- .../-link-type/-a-p-p_-l-i-n-k/index.html | 2 +- .../-link-type/-a-p-p_-s-w-i-t-c-h/index.html | 2 +- .../-link-type/entries.html | 2 +- .../-link-type/index.html | 2 +- .../-link-type/string-value.html | 2 +- .../-link-type/value-of.html | 2 +- .../-link-type/values.html | 2 +- .../-companion/index.html | 100 ++++++++ .../-companion/instance.html | 76 +++++++ .../-merchant-repository.html | 76 +++++++ .../app-link-return-uri.html | 76 +++++++ .../application-context.html | 76 +++++++ .../-merchant-repository/authorization.html | 76 +++++++ .../deep-link-fallback-url-scheme.html | 76 +++++++ .../-merchant-repository/index.html | 213 ++++++++++++++++++ .../integration-type.html | 76 +++++++ .../return-url-scheme.html | 76 +++++++ .../-payment-method-nonce.html | 2 +- .../-payment-method-nonce/index.html | 2 +- .../-payment-method-nonce/is-default.html | 2 +- .../-payment-method-nonce/string.html | 2 +- .../-d-e-f-a-u-l-t_-s-o-u-r-c-e.html | 2 +- .../-o-p-e-r-a-t-i-o-n_-n-a-m-e_-k-e-y.html | 2 +- .../-companion/-o-p-t-i-o-n-s_-k-e-y.html | 2 +- .../-companion/-v-a-l-i-d-a-t-e_-k-e-y.html | 2 +- .../-payment-method/-companion/index.html | 2 +- .../-payment-method/api-path.html | 2 +- .../-payment-method/build-j-s-o-n.html | 2 +- .../-payment-method/index.html | 2 +- .../-payment-method/integration.html | 2 +- .../-payment-method/session-id.html | 2 +- .../-payment-method/source.html | 2 +- .../-postal-address/-postal-address.html | 2 +- .../-postal-address/country-code-alpha2.html | 2 +- .../-postal-address/extended-address.html | 2 +- .../-postal-address/index.html | 2 +- .../-postal-address/is-empty.html | 2 +- .../-postal-address/locality.html | 2 +- .../-postal-address/phone-number.html | 2 +- .../-postal-address/postal-code.html | 2 +- .../-postal-address/recipient-name.html | 2 +- .../-postal-address/region.html | 2 +- .../-postal-address/sorting-code.html | 2 +- .../-postal-address/street-address.html | 2 +- .../-postal-address/to-string.html | 2 +- .../-user-canceled-exception.html | 2 +- .../-user-canceled-exception/index.html | 2 +- .../com.braintreepayments.api.core/index.html | 51 ++++- docs/BraintreeCore/index.html | 2 +- docs/BraintreeCore/navigation.html | 126 +++++++---- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../-authentication-insight/index.html | 2 +- .../regulation-environment.html | 2 +- .../-companion/-b-i-n_-d-a-t-a_-k-e-y.html | 2 +- .../-bin-data/-companion/from-json.html | 2 +- .../-bin-data/-companion/index.html | 2 +- .../-bin-data/commercial.html | 2 +- .../-bin-data/country-of-issuance.html | 2 +- .../-bin-data/debit.html | 2 +- .../-bin-data/durbin-regulated.html | 2 +- .../-bin-data/healthcare.html | 2 +- .../-bin-data/index.html | 2 +- .../-bin-data/issuing-bank.html | 2 +- .../-bin-data/payroll.html | 2 +- .../-bin-data/prepaid.html | 2 +- .../-bin-data/product-id.html | 2 +- .../-bin-type/-companion/index.html | 2 +- .../-bin-type/-no/index.html | 2 +- .../-bin-type/-unknown/index.html | 2 +- .../-bin-type/-yes/index.html | 2 +- .../-bin-type/entries.html | 2 +- .../-bin-type/index.html | 2 +- .../-bin-type/value-of.html | 2 +- .../-bin-type/values.html | 2 +- .../-card-client/-card-client.html | 2 +- .../-card-client/index.html | 2 +- .../-card-client/tokenize.html | 2 +- .../-card-nonce/-card-nonce.html | 2 +- .../-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html | 2 +- .../-companion/-d-a-t-a_-k-e-y.html | 2 +- .../-card-nonce/-companion/from-j-s-o-n.html | 2 +- .../-card-nonce/-companion/index.html | 2 +- .../-card-nonce/authentication-insight.html | 2 +- .../-card-nonce/bin-data.html | 2 +- .../-card-nonce/bin.html | 2 +- .../-card-nonce/card-type.html | 2 +- .../-card-nonce/cardholder-name.html | 2 +- .../-card-nonce/expiration-month.html | 2 +- .../-card-nonce/expiration-year.html | 2 +- .../-card-nonce/index.html | 2 +- .../-card-nonce/is-default.html | 2 +- .../-card-nonce/last-four.html | 2 +- .../-card-nonce/last-two.html | 2 +- .../-card-nonce/string.html | 2 +- .../-card-result/-failure/error.html | 2 +- .../-card-result/-failure/index.html | 2 +- .../-card-result/-success/index.html | 2 +- .../-card-result/-success/nonce.html | 2 +- .../-card-result/index.html | 2 +- .../-card-tokenize-callback/index.html | 2 +- .../on-card-result.html | 2 +- .../-card/-card.html | 2 +- .../-card/-companion/index.html | 2 +- .../-card/api-path.html | 2 +- .../-card/build-j-s-o-n-for-graph-q-l.html | 2 +- .../-card/build-j-s-o-n.html | 2 +- .../-card/cardholder-name.html | 2 +- .../-card/company.html | 2 +- .../-card/country-code.html | 2 +- .../-card/cvv.html | 2 +- .../-card/expiration-month.html | 2 +- .../-card/expiration-year.html | 2 +- .../-card/extended-address.html | 2 +- .../-card/first-name.html | 2 +- .../-card/index.html | 2 +- .../-card/integration.html | 2 +- .../is-authentication-insight-requested.html | 2 +- .../-card/last-name.html | 2 +- .../-card/locality.html | 2 +- .../-card/merchant-account-id.html | 2 +- .../-card/number.html | 2 +- .../-card/postal-code.html | 2 +- .../-card/region.html | 2 +- .../-card/session-id.html | 2 +- .../-card/should-validate.html | 2 +- .../-card/source.html | 2 +- .../-card/street-address.html | 2 +- .../com.braintreepayments.api.card/index.html | 2 +- docs/Card/index.html | 2 +- docs/Card/navigation.html | 126 +++++++---- .../-data-collector-callback/index.html | 2 +- .../on-data-collector-result.html | 2 +- .../-companion/index.html | 2 +- .../-data-collector-internal-request.html | 2 +- .../additional-data.html | 2 +- .../application-guid.html | 2 +- .../client-metadata-id.html | 2 +- .../has-user-location-consent.html | 2 +- .../index.html | 2 +- .../is-disable-beacon.html | 2 +- .../-data-collector-request.html | 2 +- .../has-user-location-consent.html | 2 +- .../-data-collector-request/index.html | 2 +- .../risk-correlation-id.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/device-data.html | 2 +- .../-success/index.html | 2 +- .../-data-collector-result/index.html | 2 +- .../-data-collector/-companion/index.html | 2 +- .../-data-collector/-data-collector.html | 2 +- .../-data-collector/collect-device-data.html | 2 +- .../-data-collector/index.html | 2 +- .../-magnes-internal-client.html | 2 +- .../-magnes-internal-client/index.html | 2 +- .../index.html | 2 +- docs/DataCollector/index.html | 2 +- docs/DataCollector/navigation.html | 126 +++++++---- .../-f-u-l-l/index.html | 2 +- .../-m-i-n/index.html | 2 +- .../entries.html | 2 +- .../index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html | 2 +- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../billing-address.html | 2 +- .../-google-pay-card-nonce/bin-data.html | 2 +- .../-google-pay-card-nonce/bin.html | 2 +- .../-google-pay-card-nonce/card-network.html | 2 +- .../-google-pay-card-nonce/card-type.html | 2 +- .../-google-pay-card-nonce/email.html | 2 +- .../-google-pay-card-nonce/index.html | 2 +- .../-google-pay-card-nonce/is-default.html | 2 +- .../is-network-tokenized.html | 2 +- .../-google-pay-card-nonce/last-four.html | 2 +- .../-google-pay-card-nonce/last-two.html | 2 +- .../shipping-address.html | 2 +- .../-google-pay-card-nonce/string.html | 2 +- .../-e-x-t-r-a_-e-n-v-i-r-o-n-m-e-n-t.html | 2 +- ...p-a-y-m-e-n-t_-d-a-t-a_-r-e-q-u-e-s-t.html | 2 +- .../-google-pay-client/-companion/index.html | 2 +- .../-google-pay-client.html | 2 +- .../create-payment-auth-request.html | 2 +- .../get-allowed-card-networks.html | 2 +- .../get-tokenization-parameters.html | 2 +- .../-google-pay-client/index.html | 2 +- .../-google-pay-client/is-ready-to-pay.html | 2 +- .../-google-pay-client/tokenize.html | 2 +- .../index.html | 2 +- .../on-tokenization-parameters-result.html | 2 +- .../index.html | 2 +- .../on-google-pay-readiness-result.html | 2 +- .../-google-pay-launcher-callback/index.html | 2 +- .../on-google-pay-launcher-result.html | 2 +- .../-companion/index.html | 2 +- .../-google-pay-launcher.html | 2 +- .../-google-pay-launcher/index.html | 2 +- .../-google-pay-launcher/launch.html | 2 +- .../index.html | 2 +- .../on-google-pay-payment-auth-request.html | 2 +- .../google-pay-environment.html | 2 +- .../index.html | 2 +- .../payment-data-request.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../-not-ready-to-pay/error.html | 2 +- .../-not-ready-to-pay/index.html | 2 +- .../-ready-to-pay/index.html | 2 +- .../-google-pay-readiness-result/index.html | 2 +- .../-google-pay-request.html | 2 +- .../allow-credit-cards.html | 2 +- .../allow-prepaid-cards.html | 2 +- .../billing-address-format.html | 2 +- .../-google-pay-request/country-code.html | 2 +- .../-google-pay-request/currency-code.html | 2 +- .../-google-pay-request/get-environment.html | 2 +- .../google-merchant-name.html | 2 +- .../-google-pay-request/index.html | 2 +- .../is-billing-address-required.html | 2 +- .../is-email-required.html | 2 +- .../is-pay-pal-enabled.html | 2 +- .../is-phone-number-required.html | 2 +- .../is-shipping-address-required.html | 2 +- .../set-allowed-auth-methods.html | 2 +- .../set-allowed-card-networks.html | 2 +- .../set-allowed-payment-method.html | 2 +- .../-google-pay-request/set-environment.html | 2 +- ...t-tokenization-specification-for-type.html | 2 +- .../shipping-address-parameters.html | 2 +- .../-google-pay-request/to-json.html | 2 +- .../total-price-label.html | 2 +- .../total-price-status.html | 2 +- .../-google-pay-request/total-price.html | 2 +- .../-google-pay-result/-cancel/index.html | 2 +- .../-google-pay-result/-failure/error.html | 2 +- .../-google-pay-result/-failure/index.html | 2 +- .../-google-pay-result/-success/index.html | 2 +- .../-google-pay-result/-success/nonce.html | 2 +- .../-google-pay-result/index.html | 2 +- ...oogle-pay-shipping-address-parameters.html | 2 +- .../allowed-country-codes.html | 2 +- .../index.html | 2 +- .../is-phone-number-required.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/allowed-card-networks.html | 2 +- .../-success/index.html | 2 +- .../-success/parameters.html | 2 +- .../index.html | 2 +- .../-google-pay-tokenize-callback/index.html | 2 +- .../on-google-pay-result.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../entries.html | 2 +- .../-google-pay-total-price-status/index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../-ready-for-google-pay-request.html | 2 +- .../-ready-for-google-pay-request/index.html | 2 +- .../is-existing-payment-method-required.html | 2 +- .../index.html | 2 +- docs/GooglePay/index.html | 2 +- docs/GooglePay/navigation.html | 126 +++++++---- .../-local-payment-auth-callback/index.html | 2 +- .../on-local-payment-auth-request.html | 2 +- .../approval-url.html | 2 +- .../browser-switch-options.html | 4 +- .../index.html | 6 +- .../payment-id.html | 2 +- .../request.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../-local-payment-auth-request/index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-no-result/index.html | 2 +- .../-success/index.html | 2 +- .../-local-payment-auth-result/index.html | 2 +- .../-companion/index.html | 2 +- .../-local-payment-client.html | 2 +- .../build-browser-switch-options.html | 2 +- .../create-payment-auth-request.html | 2 +- .../-local-payment-client/index.html | 2 +- .../-local-payment-client/tokenize.html | 2 +- .../-local-payment-launcher.html | 2 +- .../handle-return-to-app.html | 2 +- .../-local-payment-launcher/index.html | 2 +- .../-local-payment-launcher/launch.html | 2 +- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../-local-payment-nonce/billing-address.html | 2 +- .../client-metadata-id.html | 2 +- .../-local-payment-nonce/email.html | 2 +- .../-local-payment-nonce/given-name.html | 2 +- .../-local-payment-nonce/index.html | 2 +- .../-local-payment-nonce/is-default.html | 2 +- .../-local-payment-nonce/payer-id.html | 2 +- .../-local-payment-nonce/phone.html | 2 +- .../shipping-address.html | 2 +- .../-local-payment-nonce/string.html | 2 +- .../-local-payment-nonce/surname.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-started/-started.html | 2 +- .../-started/index.html | 2 +- .../-started/pending-request-string.html | 2 +- .../-local-payment-pending-request/index.html | 2 +- .../-companion/index.html | 2 +- .../-local-payment-request.html | 2 +- .../-local-payment-request/address.html | 2 +- .../-local-payment-request/amount.html | 2 +- .../bank-identification-code.html | 2 +- .../-local-payment-request/currency-code.html | 2 +- .../-local-payment-request/display-name.html | 2 +- .../-local-payment-request/email.html | 2 +- .../-local-payment-request/given-name.html | 2 +- .../has-user-location-consent.html | 2 +- .../-local-payment-request/index.html | 2 +- .../is-shipping-address-required.html | 2 +- .../merchant-account-id.html | 2 +- .../payment-type-country-code.html | 2 +- .../-local-payment-request/payment-type.html | 2 +- .../-local-payment-request/phone.html | 2 +- .../-local-payment-request/surname.html | 2 +- .../-local-payment-result/-cancel/index.html | 2 +- .../-local-payment-result/-failure/error.html | 2 +- .../-local-payment-result/-failure/index.html | 2 +- .../-local-payment-result/-success/index.html | 2 +- .../-local-payment-result/-success/nonce.html | 2 +- .../-local-payment-result/index.html | 2 +- .../index.html | 2 +- .../on-local-payment-result.html | 2 +- .../index.html | 4 +- docs/LocalPayment/index.html | 2 +- docs/LocalPayment/navigation.html | 126 +++++++---- .../-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html | 2 +- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../authenticate-url.html | 2 +- .../billing-address.html | 2 +- .../client-metadata-id.html | 2 +- .../credit-financing.html | 2 +- .../-pay-pal-account-nonce/email.html | 2 +- .../-pay-pal-account-nonce/first-name.html | 2 +- .../-pay-pal-account-nonce/index.html | 2 +- .../-pay-pal-account-nonce/is-default.html | 2 +- .../-pay-pal-account-nonce/last-name.html | 2 +- .../-pay-pal-account-nonce/payer-id.html | 2 +- .../-pay-pal-account-nonce/phone.html | 2 +- .../shipping-address.html | 2 +- .../-pay-pal-account-nonce/string.html | 2 +- .../-companion/index.html | 2 +- .../-pay-pal-billing-cycle.html | 2 +- .../-pay-pal-billing-cycle/index.html | 2 +- .../interval-count.html | 2 +- .../-pay-pal-billing-cycle/interval.html | 2 +- .../-pay-pal-billing-cycle/is-trial.html | 2 +- .../number-of-executions.html | 2 +- .../-pay-pal-billing-cycle/pricing.html | 2 +- .../-pay-pal-billing-cycle/sequence.html | 2 +- .../-pay-pal-billing-cycle/start-date.html | 2 +- .../-pay-pal-billing-cycle/to-json.html | 2 +- .../-d-a-y/index.html | 2 +- .../-m-o-n-t-h/index.html | 2 +- .../-w-e-e-k/index.html | 2 +- .../-y-e-a-r/index.html | 2 +- .../-pay-pal-billing-interval/entries.html | 2 +- .../-pay-pal-billing-interval/index.html | 2 +- .../-pay-pal-billing-interval/value-of.html | 2 +- .../-pay-pal-billing-interval/values.html | 2 +- .../-companion/index.html | 2 +- .../-pay-pal-billing-pricing.html | 2 +- .../-pay-pal-billing-pricing/amount.html | 2 +- .../-pay-pal-billing-pricing/index.html | 2 +- .../pricing-model.html | 2 +- .../reload-threshold-amount.html | 2 +- .../-pay-pal-billing-pricing/to-json.html | 2 +- .../index.html | 10 +- .../-pay-pal-checkout-request.html | 2 +- .../-pay-pal-checkout-request/amount.html | 2 +- .../billing-agreement-description.html | 2 +- .../create-request-body.html | 2 +- .../currency-code.html | 2 +- .../display-name.html | 2 +- .../has-user-location-consent.html | 2 +- .../-pay-pal-checkout-request/index.html | 2 +- .../-pay-pal-checkout-request/intent.html | 2 +- .../is-shipping-address-editable.html | 2 +- .../is-shipping-address-required.html | 2 +- .../landing-page-type.html | 2 +- .../-pay-pal-checkout-request/line-items.html | 2 +- .../locale-code.html | 2 +- .../merchant-account-id.html | 2 +- .../risk-correlation-id.html | 2 +- .../shipping-address-override.html | 2 +- .../should-offer-pay-later.html | 2 +- .../should-request-billing-agreement.html | 2 +- .../user-action.html | 2 +- .../user-authentication-email.html | 2 +- .../user-phone-number.html | 2 +- .../-pay-pal-client/-companion/index.html | 2 +- .../-pay-pal-client/-pay-pal-client.html | 6 +- .../create-payment-auth-request.html | 2 +- .../-pay-pal-client/index.html | 8 +- .../-pay-pal-client/tokenize.html | 2 +- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../currency.html | 2 +- .../index.html | 2 +- .../value.html | 2 +- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../has-payer-acceptance.html | 2 +- .../-pay-pal-credit-financing/index.html | 2 +- .../is-card-amount-immutable.html | 2 +- .../monthly-payment.html | 2 +- .../-pay-pal-credit-financing/term.html | 2 +- .../-pay-pal-credit-financing/total-cost.html | 2 +- .../total-interest.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../-pay-pal-landing-page-type/entries.html | 2 +- .../-pay-pal-landing-page-type/index.html | 2 +- .../string-value.html | 2 +- .../-pay-pal-landing-page-type/value-of.html | 2 +- .../-pay-pal-landing-page-type/values.html | 2 +- .../-pay-pal-launcher/-companion/index.html | 2 +- .../-pay-pal-launcher/-pay-pal-launcher.html | 2 +- .../handle-return-to-app.html | 2 +- .../-pay-pal-launcher/index.html | 2 +- .../-pay-pal-launcher/launch.html | 2 +- .../-c-r-e-d-i-t/index.html | 2 +- .../-d-e-b-i-t/index.html | 2 +- .../-pay-pal-line-item-kind/entries.html | 2 +- .../-pay-pal-line-item-kind/index.html | 2 +- .../-pay-pal-line-item-kind/value-of.html | 2 +- .../-pay-pal-line-item-kind/values.html | 2 +- .../-u-p-c_-t-y-p-e_-a/index.html | 2 +- .../-u-p-c_-t-y-p-e_-b/index.html | 2 +- .../-u-p-c_-t-y-p-e_-c/index.html | 2 +- .../-u-p-c_-t-y-p-e_-d/index.html | 2 +- .../-u-p-c_-t-y-p-e_-e/index.html | 2 +- .../-u-p-c_-t-y-p-e_2/index.html | 2 +- .../-u-p-c_-t-y-p-e_5/index.html | 2 +- .../-pay-pal-line-item-upc-type/entries.html | 2 +- .../-pay-pal-line-item-upc-type/index.html | 2 +- .../-pay-pal-line-item-upc-type/value-of.html | 2 +- .../-pay-pal-line-item-upc-type/values.html | 2 +- .../-pay-pal-line-item/-companion/index.html | 2 +- .../-pay-pal-line-item.html | 2 +- .../-pay-pal-line-item/description.html | 2 +- .../-pay-pal-line-item/image-url.html | 2 +- .../-pay-pal-line-item/index.html | 2 +- .../-pay-pal-line-item/kind.html | 2 +- .../-pay-pal-line-item/name.html | 2 +- .../-pay-pal-line-item/product-code.html | 2 +- .../-pay-pal-line-item/quantity.html | 2 +- .../-pay-pal-line-item/to-json.html | 2 +- .../-pay-pal-line-item/unit-amount.html | 2 +- .../-pay-pal-line-item/unit-tax-amount.html | 2 +- .../-pay-pal-line-item/upc-code.html | 2 +- .../-pay-pal-line-item/upc-type.html | 2 +- .../-pay-pal-line-item/url.html | 2 +- .../-pay-pal-payment-auth-callback/index.html | 2 +- .../on-pay-pal-payment-auth-request.html | 2 +- .../approval-url.html | 2 +- .../browser-switch-options.html | 2 +- .../client-metadata-id.html | 2 +- .../index.html | 2 +- .../intent.html | 2 +- .../is-billing-agreement.html | 2 +- .../merchant-account-id.html | 2 +- .../pairing-id.html | 2 +- .../success-url.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../-pay-pal-payment-auth-request/index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-no-result/index.html | 2 +- .../-success/index.html | 2 +- .../-pay-pal-payment-auth-result/index.html | 2 +- .../-a-u-t-h-o-r-i-z-e/index.html | 2 +- .../-companion/from-string.html | 2 +- .../-companion/index.html | 2 +- .../-o-r-d-e-r/index.html | 2 +- .../-s-a-l-e/index.html | 2 +- .../-pay-pal-payment-intent/entries.html | 2 +- .../-pay-pal-payment-intent/index.html | 2 +- .../-pay-pal-payment-intent/value-of.html | 2 +- .../-pay-pal-payment-intent/values.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../-pay-pal-payment-user-action/entries.html | 2 +- .../-pay-pal-payment-user-action/index.html | 2 +- .../value-of.html | 2 +- .../-pay-pal-payment-user-action/values.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-started/-started.html | 2 +- .../-started/index.html | 2 +- .../-started/pending-request-string.html | 2 +- .../-pay-pal-pending-request/index.html | 2 +- .../-companion/index.html | 2 +- .../-pay-pal-phone-number.html | 2 +- .../-pay-pal-phone-number/country-code.html | 2 +- .../-pay-pal-phone-number/index.html | 2 +- .../national-number.html | 2 +- .../-a-u-t-o_-r-e-l-o-a-d/index.html | 2 +- .../-f-i-x-e-d/index.html | 2 +- .../-v-a-r-i-a-b-l-e/index.html | 2 +- .../-pay-pal-pricing-model/entries.html | 2 +- .../-pay-pal-pricing-model/index.html | 2 +- .../-pay-pal-pricing-model/value-of.html | 2 +- .../-pay-pal-pricing-model/values.html | 2 +- .../-companion/index.html | 2 +- .../-pay-pal-recurring-billing-details.html | 2 +- .../billing-cycles.html | 2 +- .../currency-i-s-o-code.html | 2 +- .../index.html | 2 +- .../one-time-fee-amount.html | 2 +- .../product-amount.html | 2 +- .../product-description.html | 2 +- .../product-name.html | 2 +- .../product-quantity.html | 2 +- .../shipping-amount.html | 2 +- .../tax-amount.html | 2 +- .../to-json.html | 2 +- .../total-amount.html | 2 +- .../-i-n-s-t-a-l-l-m-e-n-t/index.html | 2 +- .../-r-e-c-u-r-r-i-n-g/index.html | 2 +- .../-s-u-b-s-c-r-i-p-t-i-o-n/index.html | 2 +- .../-u-n-s-c-h-e-d-u-l-e-d/index.html | 2 +- .../entries.html | 2 +- .../index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../-pay-pal-request/-companion/index.html | 2 +- .../billing-agreement-description.html | 2 +- .../-pay-pal-request/create-request-body.html | 2 +- .../-pay-pal-request/display-name.html | 2 +- .../has-user-location-consent.html | 2 +- .../-pay-pal-request/index.html | 2 +- .../is-shipping-address-editable.html | 2 +- .../is-shipping-address-required.html | 2 +- .../-pay-pal-request/landing-page-type.html | 2 +- .../-pay-pal-request/line-items.html | 2 +- .../-pay-pal-request/locale-code.html | 2 +- .../-pay-pal-request/merchant-account-id.html | 2 +- .../-pay-pal-request/risk-correlation-id.html | 2 +- .../shipping-address-override.html | 2 +- .../user-authentication-email.html | 2 +- .../-pay-pal-request/user-phone-number.html | 2 +- .../-pay-pal-result/-cancel/index.html | 2 +- .../-pay-pal-result/-failure/error.html | 2 +- .../-pay-pal-result/-failure/index.html | 2 +- .../-pay-pal-result/-success/index.html | 2 +- .../-pay-pal-result/-success/nonce.html | 2 +- .../-pay-pal-result/index.html | 2 +- .../-pay-pal-tokenize-callback/index.html | 2 +- .../on-pay-pal-result.html | 2 +- .../-pay-pal-vault-request.html | 2 +- .../billing-agreement-description.html | 2 +- .../create-request-body.html | 2 +- .../-pay-pal-vault-request/display-name.html | 2 +- .../enable-pay-pal-app-switch.html | 2 +- .../has-user-location-consent.html | 2 +- .../-pay-pal-vault-request/index.html | 2 +- .../is-shipping-address-editable.html | 2 +- .../is-shipping-address-required.html | 2 +- .../landing-page-type.html | 2 +- .../-pay-pal-vault-request/line-items.html | 2 +- .../-pay-pal-vault-request/locale-code.html | 2 +- .../merchant-account-id.html | 2 +- .../recurring-billing-details.html | 2 +- .../recurring-billing-plan-type.html | 2 +- .../risk-correlation-id.html | 2 +- .../shipping-address-override.html | 2 +- .../should-offer-credit.html | 2 +- .../user-authentication-email.html | 2 +- .../user-phone-number.html | 2 +- .../index.html | 4 +- docs/PayPal/index.html | 2 +- docs/PayPal/navigation.html | 126 +++++++---- .../-create-mandate-result/approval-url.html | 2 +- .../bank-reference-token.html | 2 +- .../-create-mandate-result/customer-id.html | 2 +- .../iban-last-four.html | 2 +- .../-create-mandate-result/index.html | 2 +- .../-create-mandate-result/mandate-type.html | 2 +- .../-companion/index.html | 2 +- .../-s-e-p-a-direct-debit-client.html | 2 +- .../create-payment-auth-request.html | 2 +- .../-s-e-p-a-direct-debit-client/index.html | 2 +- .../tokenize.html | 2 +- .../-s-e-p-a-direct-debit-launcher.html | 2 +- .../handle-return-to-app.html | 2 +- .../-s-e-p-a-direct-debit-launcher/index.html | 2 +- .../launch.html | 2 +- .../-o-n-e_-o-f-f/index.html | 2 +- .../-r-e-c-u-r-r-e-n-t/index.html | 2 +- .../entries.html | 2 +- .../index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../customer-id.html | 2 +- .../iban-last-four.html | 2 +- .../-s-e-p-a-direct-debit-nonce/index.html | 2 +- .../is-default.html | 2 +- .../mandate-type.html | 2 +- .../-s-e-p-a-direct-debit-nonce/string.html | 2 +- .../index.html | 2 +- ...-p-a-direct-debit-payment-auth-result.html | 2 +- .../browser-switch-options.html | 2 +- .../index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-launch-not-required/index.html | 2 +- .../-launch-not-required/nonce.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-no-result/index.html | 2 +- .../-success/index.html | 2 +- .../index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-started/-started.html | 2 +- .../-started/index.html | 2 +- .../-started/pending-request-string.html | 2 +- .../index.html | 2 +- .../-s-e-p-a-direct-debit-request.html | 2 +- .../account-holder-name.html | 2 +- .../billing-address.html | 2 +- .../customer-id.html | 2 +- .../-s-e-p-a-direct-debit-request/iban.html | 2 +- .../-s-e-p-a-direct-debit-request/index.html | 2 +- .../-s-e-p-a-direct-debit-request/locale.html | 2 +- .../mandate-type.html | 2 +- .../merchant-account-id.html | 2 +- .../-cancel/index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/index.html | 2 +- .../-success/nonce.html | 2 +- .../-s-e-p-a-direct-debit-result/index.html | 2 +- .../index.html | 2 +- .../on-s-e-p-a-direct-debit-result.html | 2 +- .../index.html | 2 +- docs/SEPADirectDebit/index.html | 2 +- docs/SEPADirectDebit/navigation.html | 126 +++++++---- .../-shopper-insights-buyer-phone.html | 2 +- .../country-code.html | 2 +- .../-shopper-insights-buyer-phone/index.html | 2 +- .../national-number.html | 2 +- .../-shopper-insights-callback/index.html | 2 +- .../-shopper-insights-callback/on-result.html | 2 +- .../-companion/index.html | 2 +- .../-shopper-insights-client.html | 2 +- .../get-recommended-payment-methods.html | 2 +- .../-shopper-insights-client/index.html | 2 +- .../send-pay-pal-presented-event.html | 2 +- .../send-pay-pal-selected-event.html | 2 +- .../send-venmo-presented-event.html | 2 +- .../send-venmo-selected-event.html | 2 +- .../-shopper-insights-info/index.html | 2 +- .../is-eligible-in-pay-pal-network.html | 2 +- .../is-pay-pal-recommended.html | 2 +- .../is-venmo-recommended.html | 2 +- .../-shopper-insights-request.html | 2 +- .../-shopper-insights-request/email.html | 2 +- .../-shopper-insights-request/index.html | 2 +- .../-shopper-insights-request/phone.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/index.html | 2 +- .../-success/response.html | 2 +- .../-shopper-insights-result/index.html | 2 +- .../index.html | 2 +- docs/ShopperInsights/index.html | 2 +- docs/ShopperInsights/navigation.html | 126 +++++++---- .../-c-r-e-d-i-t/index.html | 2 +- .../-d-e-b-i-t/index.html | 2 +- .../-three-d-secure-account-type/entries.html | 2 +- .../-three-d-secure-account-type/index.html | 2 +- .../value-of.html | 2 +- .../-three-d-secure-account-type/values.html | 2 +- ...three-d-secure-additional-information.html | 2 +- .../account-age-indicator.html | 2 +- .../account-change-date.html | 2 +- .../account-change-indicator.html | 2 +- .../account-create-date.html | 2 +- .../account-id.html | 2 +- .../account-purchases.html | 2 +- .../account-pwd-change-date.html | 2 +- .../account-pwd-change-indicator.html | 2 +- .../add-card-attempts.html | 2 +- .../address-match.html | 2 +- .../authentication-indicator.html | 2 +- .../delivery-email.html | 2 +- .../delivery-timeframe.html | 2 +- .../fraud-activity.html | 2 +- .../gift-card-amount.html | 2 +- .../gift-card-count.html | 2 +- .../gift-card-currency-code.html | 2 +- .../index.html | 2 +- .../installment.html | 2 +- .../ip-address.html | 2 +- .../order-description.html | 2 +- .../payment-account-age.html | 2 +- .../payment-account-indicator.html | 2 +- .../preorder-date.html | 2 +- .../preorder-indicator.html | 2 +- .../product-code.html | 2 +- .../purchase-date.html | 2 +- .../recurring-end.html | 2 +- .../recurring-frequency.html | 2 +- .../reorder-indicator.html | 2 +- .../sdk-max-timeout.html | 2 +- .../shipping-address-usage-date.html | 2 +- .../shipping-address-usage-indicator.html | 2 +- .../shipping-address.html | 2 +- .../shipping-method-indicator.html | 2 +- .../shipping-name-indicator.html | 2 +- .../tax-amount.html | 2 +- .../to-json.html | 2 +- .../transaction-count-day.html | 2 +- .../transaction-count-year.html | 2 +- .../user-agent.html | 2 +- .../work-phone-number.html | 2 +- .../-three-d-secure-client.html | 2 +- .../create-payment-auth-request.html | 2 +- .../-three-d-secure-client/index.html | 2 +- ...ialize-challenge-with-lookup-response.html | 2 +- .../prepare-lookup.html | 2 +- .../send-analytics-and-callback-result.html | 2 +- .../-three-d-secure-client/tokenize.html | 2 +- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../acs-transaction-id.html | 2 +- ...hentication-transaction-status-reason.html | 2 +- .../authentication-transaction-status.html | 2 +- .../-three-d-secure-info/cavv.html | 2 +- .../ds-transaction-id.html | 2 +- .../-three-d-secure-info/eci-flag.html | 2 +- .../-three-d-secure-info/enrolled.html | 2 +- .../-three-d-secure-info/index.html | 2 +- .../liability-shift-possible.html | 2 +- .../liability-shifted.html | 2 +- .../lookup-transaction-status-reason.html | 2 +- .../lookup-transaction-status.html | 2 +- .../-three-d-secure-info/pares-status.html | 2 +- .../-three-d-secure-info/status.html | 2 +- .../three-d-secure-authentication-id.html | 2 +- .../three-d-secure-server-transaction-id.html | 2 +- .../three-d-secure-version.html | 2 +- .../-three-d-secure-info/was-verified.html | 2 +- .../-three-d-secure-info/xid.html | 2 +- .../index.html | 2 +- ...on-three-d-secure-payment-auth-result.html | 2 +- .../-companion/index.html | 2 +- .../-three-d-secure-launcher.html | 2 +- .../activity-launcher.html | 2 +- .../-three-d-secure-launcher/index.html | 2 +- .../-three-d-secure-launcher/launch.html | 2 +- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../-three-d-secure-lookup/acs-url.html | 2 +- .../-three-d-secure-lookup/index.html | 2 +- .../-three-d-secure-lookup/md.html | 2 +- .../-three-d-secure-lookup/pareq.html | 2 +- .../requires-user-authentication.html | 2 +- .../-three-d-secure-lookup/term-url.html | 2 +- .../three-d-secure-version.html | 2 +- .../transaction-id.html | 2 +- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../authentication-insight.html | 2 +- .../-three-d-secure-nonce/bin-data.html | 2 +- .../-three-d-secure-nonce/bin.html | 2 +- .../-three-d-secure-nonce/card-type.html | 2 +- .../cardholder-name.html | 2 +- .../expiration-month.html | 2 +- .../expiration-year.html | 2 +- .../-three-d-secure-nonce/index.html | 2 +- .../-three-d-secure-nonce/is-default.html | 2 +- .../-three-d-secure-nonce/last-four.html | 2 +- .../-three-d-secure-nonce/last-two.html | 2 +- .../-three-d-secure-nonce/string.html | 2 +- .../three-d-secure-info.html | 2 +- .../-companion/from-json.html | 2 +- .../-companion/index.html | 2 +- .../-three-d-secure-params.html | 2 +- .../-three-d-secure-params/error-message.html | 2 +- .../-three-d-secure-params/has-error.html | 2 +- .../-three-d-secure-params/index.html | 2 +- .../-three-d-secure-params/lookup.html | 2 +- .../three-d-secure-nonce.html | 2 +- .../index.html | 2 +- ...n-three-d-secure-payment-auth-request.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-launch-not-required/index.html | 2 +- .../-launch-not-required/nonce.html | 2 +- .../three-d-secure-lookup.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../-companion/index.html | 2 +- .../-three-d-secure-postal-address.html | 2 +- .../country-code-alpha2.html | 2 +- .../extended-address.html | 2 +- .../given-name.html | 2 +- .../-three-d-secure-postal-address/index.html | 2 +- .../-three-d-secure-postal-address/line3.html | 2 +- .../locality.html | 2 +- .../phone-number.html | 2 +- .../postal-code.html | 2 +- .../region.html | 2 +- .../street-address.html | 2 +- .../surname.html | 2 +- .../to-json.html | 2 +- .../index.html | 2 +- .../on-prepare-lookup-result.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-success/client-data.html | 2 +- .../-success/index.html | 2 +- .../-success/request.html | 2 +- .../index.html | 2 +- .../-m-u-l-t-i_-s-e-l-e-c-t/index.html | 2 +- .../-o-o-b/index.html | 2 +- .../-o-t-p/index.html | 2 +- .../-r-e-n-d-e-r_-h-t-m-l/index.html | 2 +- .../-s-i-n-g-l-e_-s-e-l-e-c-t/index.html | 2 +- .../-three-d-secure-render-type/entries.html | 2 +- .../-three-d-secure-render-type/index.html | 2 +- .../-three-d-secure-render-type/value-of.html | 2 +- .../-three-d-secure-render-type/values.html | 2 +- .../-three-d-secure-request.html | 6 +- .../-three-d-secure-request/account-type.html | 2 +- .../additional-information.html | 2 +- .../-three-d-secure-request/amount.html | 2 +- .../billing-address.html | 2 +- .../-three-d-secure-request/build.html | 2 +- .../card-add-challenge-requested.html | 2 +- .../challenge-requested.html | 2 +- .../custom-fields.html | 2 +- .../data-only-requested.html | 2 +- .../-three-d-secure-request/email.html | 2 +- .../exemption-requested.html | 2 +- .../-three-d-secure-request/index.html | 25 +- .../mobile-phone-number.html | 2 +- .../-three-d-secure-request/nonce.html | 2 +- .../-three-d-secure-request/render-types.html | 2 +- .../requested-exemption-type.html | 2 +- .../requestor-app-url.html | 76 +++++++ .../shipping-method.html | 2 +- .../-three-d-secure-request/ui-type.html | 2 +- .../v2-ui-customization.html | 2 +- .../-l-o-w_-v-a-l-u-e/index.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../entries.html | 2 +- .../index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../-three-d-secure-result/-cancel/index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-failure/nonce.html | 2 +- .../-success/index.html | 2 +- .../-success/nonce.html | 2 +- .../-three-d-secure-result/index.html | 2 +- .../index.html | 2 +- .../-e-x-p-e-d-i-t-e-d/index.html | 2 +- .../-g-r-o-u-n-d/index.html | 2 +- .../-p-r-i-o-r-i-t-y/index.html | 2 +- .../-s-a-m-e_-d-a-y/index.html | 2 +- .../-s-h-i-p_-t-o_-s-t-o-r-e/index.html | 2 +- .../entries.html | 2 +- .../index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- .../index.html | 2 +- .../on-three-d-secure-result.html | 2 +- .../-b-o-t-h/index.html | 2 +- .../-h-t-m-l/index.html | 2 +- .../-n-a-t-i-v-e/index.html | 2 +- .../-three-d-secure-ui-type/entries.html | 2 +- .../-three-d-secure-ui-type/index.html | 2 +- .../-three-d-secure-ui-type/value-of.html | 2 +- .../-three-d-secure-ui-type/values.html | 2 +- ...hree-d-secure-v2-button-customization.html | 2 +- .../background-color.html | 2 +- .../cardinal-button-customization.html | 2 +- .../corner-radius.html | 2 +- .../index.html | 2 +- .../text-color.html | 2 +- .../text-font-name.html | 2 +- .../text-font-size.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../-b-u-t-t-o-n_-t-y-p-e_-n-e-x-t/index.html | 2 +- .../index.html | 2 +- .../index.html | 2 +- .../entries.html | 2 +- .../-three-d-secure-v2-button-type/index.html | 2 +- .../value-of.html | 2 +- .../values.html | 2 +- ...three-d-secure-v2-label-customization.html | 2 +- .../cardinal-label-customization.html | 2 +- .../heading-text-color.html | 2 +- .../heading-text-font-name.html | 2 +- .../heading-text-font-size.html | 2 +- .../index.html | 2 +- .../text-color.html | 2 +- .../text-font-name.html | 2 +- .../text-font-size.html | 2 +- ...ee-d-secure-v2-text-box-customization.html | 2 +- .../border-color.html | 2 +- .../border-width.html | 2 +- .../cardinal-text-box-customization.html | 2 +- .../corner-radius.html | 2 +- .../index.html | 2 +- .../text-color.html | 2 +- .../text-font-name.html | 2 +- .../text-font-size.html | 2 +- ...ree-d-secure-v2-toolbar-customization.html | 2 +- .../background-color.html | 2 +- .../button-text.html | 2 +- .../cardinal-toolbar-customization.html | 2 +- .../header-text.html | 2 +- .../index.html | 2 +- .../text-color.html | 2 +- .../text-font-name.html | 2 +- .../text-font-size.html | 2 +- .../-three-d-secure-v2-ui-customization.html | 2 +- .../button-customization.html | 2 +- .../button-type.html | 2 +- .../cardinal-ui-customization.html | 2 +- .../index.html | 2 +- .../label-customization.html | 2 +- .../text-box-customization.html | 2 +- .../toolbar-customization.html | 2 +- .../index.html | 4 +- docs/ThreeDSecure/index.html | 2 +- docs/ThreeDSecure/navigation.html | 126 +++++++---- .../-companion/from-j-s-o-n.html | 2 +- .../-companion/index.html | 2 +- .../-venmo-account-nonce/billing-address.html | 2 +- .../-venmo-account-nonce/email.html | 2 +- .../-venmo-account-nonce/external-id.html | 2 +- .../-venmo-account-nonce/first-name.html | 2 +- .../-venmo-account-nonce/index.html | 2 +- .../-venmo-account-nonce/is-default.html | 2 +- .../-venmo-account-nonce/last-name.html | 2 +- .../-venmo-account-nonce/phone-number.html | 2 +- .../shipping-address.html | 2 +- .../-venmo-account-nonce/string.html | 2 +- .../-venmo-account-nonce/username.html | 2 +- .../-venmo-client/-companion/index.html | 2 +- .../-venmo-client/-venmo-client.html | 6 +- .../create-payment-auth-request.html | 2 +- .../-venmo-client/index.html | 8 +- .../-venmo-client/tokenize.html | 2 +- .../-venmo-launcher/-companion/index.html | 2 +- .../-venmo-launcher/-venmo-launcher.html | 2 +- .../-venmo-launcher/handle-return-to-app.html | 2 +- .../-venmo-launcher/index.html | 2 +- .../-venmo-launcher/launch.html | 2 +- .../show-venmo-in-google-play-store.html | 2 +- .../-c-r-e-d-i-t/index.html | 2 +- .../-d-e-b-i-t/index.html | 2 +- .../-venmo-line-item-kind/entries.html | 2 +- .../-venmo-line-item-kind/index.html | 2 +- .../-venmo-line-item-kind/value-of.html | 2 +- .../-venmo-line-item-kind/values.html | 2 +- .../-venmo-line-item/-companion/index.html | 2 +- .../-venmo-line-item/-venmo-line-item.html | 2 +- .../-venmo-line-item/description.html | 2 +- .../-venmo-line-item/index.html | 2 +- .../-venmo-line-item/kind.html | 2 +- .../-venmo-line-item/name.html | 2 +- .../-venmo-line-item/product-code.html | 2 +- .../-venmo-line-item/quantity.html | 2 +- .../-venmo-line-item/to-json.html | 2 +- .../-venmo-line-item/unit-amount.html | 2 +- .../-venmo-line-item/unit-tax-amount.html | 2 +- .../-venmo-line-item/url.html | 2 +- .../index.html | 2 +- .../on-venmo-payment-auth-request.html | 2 +- .../browser-switch-options.html | 2 +- .../index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-ready-to-launch/index.html | 2 +- .../-ready-to-launch/request-params.html | 2 +- .../-venmo-payment-auth-request/index.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-no-result/index.html | 2 +- .../-success/index.html | 2 +- .../-venmo-payment-auth-result/index.html | 2 +- .../-m-u-l-t-i_-u-s-e/index.html | 2 +- .../-s-i-n-g-l-e_-u-s-e/index.html | 2 +- .../-venmo-payment-method-usage/entries.html | 2 +- .../-venmo-payment-method-usage/index.html | 2 +- .../-venmo-payment-method-usage/value-of.html | 2 +- .../-venmo-payment-method-usage/values.html | 2 +- .../-failure/error.html | 2 +- .../-failure/index.html | 2 +- .../-started/-started.html | 2 +- .../-started/index.html | 2 +- .../-started/pending-request-string.html | 2 +- .../-venmo-pending-request/index.html | 2 +- .../-venmo-request/-venmo-request.html | 2 +- .../collect-customer-billing-address.html | 2 +- .../collect-customer-shipping-address.html | 2 +- .../-venmo-request/discount-amount.html | 2 +- .../-venmo-request/display-name.html | 2 +- .../-venmo-request/index.html | 2 +- .../-venmo-request/is-final-amount.html | 2 +- .../-venmo-request/line-items.html | 2 +- .../-venmo-request/payment-method-usage.html | 2 +- .../-venmo-request/profile-id.html | 2 +- .../-venmo-request/shipping-amount.html | 2 +- .../-venmo-request/should-vault.html | 2 +- .../-venmo-request/sub-total-amount.html | 2 +- .../-venmo-request/tax-amount.html | 2 +- .../-venmo-request/total-amount.html | 2 +- .../-venmo-result/-cancel/index.html | 2 +- .../-venmo-result/-failure/error.html | 2 +- .../-venmo-result/-failure/index.html | 2 +- .../-venmo-result/-success/index.html | 2 +- .../-venmo-result/-success/nonce.html | 2 +- .../-venmo-result/index.html | 2 +- .../-venmo-tokenize-callback/index.html | 2 +- .../on-venmo-result.html | 2 +- .../index.html | 2 +- docs/Venmo/index.html | 2 +- docs/Venmo/navigation.html | 126 +++++++---- docs/index.html | 2 +- docs/navigation.html | 126 +++++++---- docs/scripts/pages.json | 2 +- v5_MIGRATION_GUIDE.md | 2 +- 1198 files changed, 5998 insertions(+), 1637 deletions(-) create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-n-a-l-y-t-i-c-s_-j-s-o-n.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-u-t-h-o-r-i-z-a-t-i-o-n.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-c-o-n-f-i-g-u-r-a-t-i-o-n.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-i-n-t-e-g-r-a-t-i-o-n.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-s-e-s-s-i-o-n_-i-d.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-u-p-l-o-a-d.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-w-r-i-t-e.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/lazy-instance.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-upload.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-write.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/report-crash.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/send-event.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/app-switch-url.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/-companion/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-get-return-link-use-case.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/-app-link.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/app-link-return-uri.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/-deep-link.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/deep-link-fallback-url-scheme.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/-failure.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/exception.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/invoke.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/instance.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-merchant-repository.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/app-link-return-uri.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/application-context.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/authorization.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/deep-link-fallback-url-scheme.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/index.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/integration-type.html create mode 100644 docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/return-url-scheme.html create mode 100644 docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requestor-app-url.html diff --git a/CHANGELOG.md b/CHANGELOG.md index 0834c20a10..4199684611 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,6 @@ # Braintree Android SDK Release Notes -## unreleased +## 5.3.0 (2024-12-11) * PayPal * Add `deepLinkFallbackUrlScheme` to `PayPalClient` constructor params for supporting deep link fallback diff --git a/README.md b/README.md index 1be4eb56ac..8cb85eda50 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ For an integration offering card payments, add the following dependency in your ```groovy dependencies { - implementation 'com.braintreepayments.api:card:5.2.0' + implementation 'com.braintreepayments.api:card:5.3.0' } ``` diff --git a/build.gradle b/build.gradle index 7af8e4689c..8799594480 100644 --- a/build.gradle +++ b/build.gradle @@ -48,7 +48,7 @@ allprojects { } } -version '5.2.1-SNAPSHOT' +version '5.3.0' group 'com.braintreepayments' ext { compileSdkVersion = 35 diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-american-express-client.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-american-express-client.html index fbefe6097b..0a8e9b8dd7 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-american-express-client.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-american-express-client.html @@ -41,7 +41,7 @@ braintree_android -
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-companion/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-companion/index.html index 54cb58851e..e3f94fd21e 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-companion/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/get-rewards-balance.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/get-rewards-balance.html index 609e520f91..7d7f7194d9 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/get-rewards-balance.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/get-rewards-balance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/index.html index e93b3a7593..9b8af23090 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/index.html index a50a329609..31a9a721d8 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/on-american-express-result.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/on-american-express-result.html index 82aa1f434e..b6eb36c98d 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/on-american-express-result.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-get-rewards-balance-callback/on-american-express-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/error.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/error.html index 2da03b4691..24a3f0fe15 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/error.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/index.html index 795d4cd5cf..9c2d2a3850 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/index.html index d73679ddda..895d6a7b99 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/rewards-balance.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/rewards-balance.html index 74a3da4c98..cf2696f7f8 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/rewards-balance.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/-success/rewards-balance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/index.html index 825fa1c9dc..3b8ea23f95 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-american-express-rewards-balance.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-american-express-rewards-balance.html index 6cf21400a2..c729bca46a 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-american-express-rewards-balance.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-american-express-rewards-balance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-companion/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-companion/index.html index bef990a7b6..fa37c00896 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-companion/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/conversion-rate.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/conversion-rate.html index f7f952c0ca..ad77906cf0 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/conversion-rate.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/conversion-rate.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-amount.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-amount.html index e76568d1b5..c5e75ee94b 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-amount.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-iso-code.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-iso-code.html index 49816819d5..f6046d8ebe 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-iso-code.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/currency-iso-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-code.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-code.html index 963e05a04e..30834d855f 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-code.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-message.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-message.html index a5b9ceb15f..4554111538 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-message.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/error-message.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/index.html index a2c3a45a82..1f303b84e4 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/request-id.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/request-id.html index 61d1875ca0..24ff27f9f5 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/request-id.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/request-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-amount.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-amount.html index dc1f01c786..7990bb8a9c 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-amount.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-unit.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-unit.html index f91c4d21b9..0cbc514478 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-unit.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/-american-express-rewards-balance/rewards-unit.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/index.html b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/index.html index a8d243402a..e996fc165b 100644 --- a/docs/AmericanExpress/com.braintreepayments.api.americanexpress/index.html +++ b/docs/AmericanExpress/com.braintreepayments.api.americanexpress/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/index.html b/docs/AmericanExpress/index.html index 175d0e5a49..dd65511028 100644 --- a/docs/AmericanExpress/index.html +++ b/docs/AmericanExpress/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/AmericanExpress/navigation.html b/docs/AmericanExpress/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/AmericanExpress/navigation.html +++ b/docs/AmericanExpress/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-n-a-l-y-t-i-c-s_-j-s-o-n.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-n-a-l-y-t-i-c-s_-j-s-o-n.html new file mode 100644 index 0000000000..0020265d13 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-n-a-l-y-t-i-c-s_-j-s-o-n.html @@ -0,0 +1,76 @@ + + + + + WORK_INPUT_KEY_ANALYTICS_JSON + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_INPUT_KEY_ANALYTICS_JSON

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-u-t-h-o-r-i-z-a-t-i-o-n.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-u-t-h-o-r-i-z-a-t-i-o-n.html new file mode 100644 index 0000000000..dfb15b64dc --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-a-u-t-h-o-r-i-z-a-t-i-o-n.html @@ -0,0 +1,76 @@ + + + + + WORK_INPUT_KEY_AUTHORIZATION + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_INPUT_KEY_AUTHORIZATION

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-c-o-n-f-i-g-u-r-a-t-i-o-n.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-c-o-n-f-i-g-u-r-a-t-i-o-n.html new file mode 100644 index 0000000000..e7ec881992 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-c-o-n-f-i-g-u-r-a-t-i-o-n.html @@ -0,0 +1,76 @@ + + + + + WORK_INPUT_KEY_CONFIGURATION + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_INPUT_KEY_CONFIGURATION

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-i-n-t-e-g-r-a-t-i-o-n.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-i-n-t-e-g-r-a-t-i-o-n.html new file mode 100644 index 0000000000..90cbd9757d --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-i-n-t-e-g-r-a-t-i-o-n.html @@ -0,0 +1,76 @@ + + + + + WORK_INPUT_KEY_INTEGRATION + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_INPUT_KEY_INTEGRATION

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-s-e-s-s-i-o-n_-i-d.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-s-e-s-s-i-o-n_-i-d.html new file mode 100644 index 0000000000..fb03f45b2b --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-i-n-p-u-t_-k-e-y_-s-e-s-s-i-o-n_-i-d.html @@ -0,0 +1,76 @@ + + + + + WORK_INPUT_KEY_SESSION_ID + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_INPUT_KEY_SESSION_ID

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-u-p-l-o-a-d.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-u-p-l-o-a-d.html new file mode 100644 index 0000000000..aeeefe1c5e --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-u-p-l-o-a-d.html @@ -0,0 +1,76 @@ + + + + + WORK_NAME_ANALYTICS_UPLOAD + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_NAME_ANALYTICS_UPLOAD

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-w-r-i-t-e.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-w-r-i-t-e.html new file mode 100644 index 0000000000..254bc331b2 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/-w-o-r-k_-n-a-m-e_-a-n-a-l-y-t-i-c-s_-w-r-i-t-e.html @@ -0,0 +1,76 @@ + + + + + WORK_NAME_ANALYTICS_WRITE + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

WORK_NAME_ANALYTICS_WRITE

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/index.html new file mode 100644 index 0000000000..098f9b1662 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/index.html @@ -0,0 +1,205 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/lazy-instance.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/lazy-instance.html new file mode 100644 index 0000000000..35bd99fd16 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/-companion/lazy-instance.html @@ -0,0 +1,76 @@ + + + + + lazyInstance + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

lazyInstance

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/index.html new file mode 100644 index 0000000000..cef7bdf9e2 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/index.html @@ -0,0 +1,164 @@ + + + + + AnalyticsClient + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

AnalyticsClient

+ +
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun reportCrash(context: Context?, configuration: Configuration?, integration: IntegrationType?, authorization: Authorization?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun sendEvent(eventName: String, analyticsEventParams: AnalyticsEventParams = AnalyticsEventParams())
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-upload.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-upload.html new file mode 100644 index 0000000000..332bfc4402 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-upload.html @@ -0,0 +1,76 @@ + + + + + performAnalyticsUpload + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

performAnalyticsUpload

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-write.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-write.html new file mode 100644 index 0000000000..5d18a55bb3 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/perform-analytics-write.html @@ -0,0 +1,76 @@ + + + + + performAnalyticsWrite + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

performAnalyticsWrite

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/report-crash.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/report-crash.html new file mode 100644 index 0000000000..c28874b766 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/report-crash.html @@ -0,0 +1,76 @@ + + + + + reportCrash + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

reportCrash

+
+
fun reportCrash(context: Context?, configuration: Configuration?, integration: IntegrationType?, authorization: Authorization?)
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/send-event.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/send-event.html new file mode 100644 index 0000000000..9b5250264c --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-client/send-event.html @@ -0,0 +1,76 @@ + + + + + sendEvent + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

sendEvent

+
+
fun sendEvent(eventName: String, analyticsEventParams: AnalyticsEventParams = AnalyticsEventParams())
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/-analytics-event-params.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/-analytics-event-params.html index c8cb5b4a22..02833fec51 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/-analytics-event-params.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/-analytics-event-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -58,12 +58,12 @@
-
+

AnalyticsEventParams

-
constructor(payPalContextId: String? = null, linkType: String? = null, isVaultRequest: Boolean = false, startTime: Long? = null, endTime: Long? = null, endpoint: String? = null, experiment: String? = null, paymentMethodsDisplayed: List<String> = emptyList())
+
constructor(payPalContextId: String? = null, linkType: String? = null, isVaultRequest: Boolean = false, startTime: Long? = null, endTime: Long? = null, endpoint: String? = null, experiment: String? = null, paymentMethodsDisplayed: List<String> = emptyList(), appSwitchUrl: String? = null)
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/endpoint.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/endpoint.html index 70502ec67e..de7ae6d0cf 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/endpoint.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/endpoint.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/experiment.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/experiment.html index b2428333fe..ae670637a9 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/experiment.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/experiment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/index.html index bc0ba4495a..b58de0d99d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -62,24 +62,24 @@

AnalyticsEventParams

-
data class AnalyticsEventParams @JvmOverloads constructor(var payPalContextId: String? = null, var linkType: String? = null, var isVaultRequest: Boolean = false, var startTime: Long? = null, var endTime: Long? = null, var endpoint: String? = null, val experiment: String? = null, val paymentMethodsDisplayed: List<String> = emptyList())

DTO for analytics events. See also: AnalyticsEvent It is a catch-all data class for any parameters any of the modules wants to send. As such, not all parameters are required at each call site.

+
data class AnalyticsEventParams @JvmOverloads constructor(var payPalContextId: String? = null, var linkType: String? = null, var isVaultRequest: Boolean = false, var startTime: Long? = null, var endTime: Long? = null, var endpoint: String? = null, val experiment: String? = null, val paymentMethodsDisplayed: List<String> = emptyList(), val appSwitchUrl: String? = null)

DTO for analytics events. See also: AnalyticsEvent It is a catch-all data class for any parameters any of the modules wants to send. As such, not all parameters are required at each call site.

Constructors

-
+
- +
Link copied to clipboard
-
constructor(payPalContextId: String? = null, linkType: String? = null, isVaultRequest: Boolean = false, startTime: Long? = null, endTime: Long? = null, endpoint: String? = null, experiment: String? = null, paymentMethodsDisplayed: List<String> = emptyList())
+
constructor(payPalContextId: String? = null, linkType: String? = null, isVaultRequest: Boolean = false, startTime: Long? = null, endTime: Long? = null, endpoint: String? = null, experiment: String? = null, paymentMethodsDisplayed: List<String> = emptyList(), appSwitchUrl: String? = null)
@@ -88,7 +88,22 @@

Constructors

Properties

-
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val appSwitchUrl: String? = null
+
+
+
+
+
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/is-vault-request.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/is-vault-request.html index 2c6ade0b47..4c910557d3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/is-vault-request.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/is-vault-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/link-type.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/link-type.html index 48622e986f..dea93dda39 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/link-type.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/link-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/pay-pal-context-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/pay-pal-context-id.html index 1c6901f631..5eea44a12c 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/pay-pal-context-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/pay-pal-context-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/payment-methods-displayed.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/payment-methods-displayed.html index fdccb23495..cd8cda6a9f 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/payment-methods-displayed.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/payment-methods-displayed.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/start-time.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/start-time.html index facd6b7c09..98ab7bf022 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/start-time.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-event-params/start-time.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-analytics-param-repository.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-analytics-param-repository.html index 385659577b..27b4cbcef7 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-analytics-param-repository.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-analytics-param-repository.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/index.html index b0841b0528..0efa2c0bef 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/instance.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/instance.html index 38d5913a19..749c4c0c00 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/instance.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/-companion/instance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/index.html index ee4c42dde2..b96a48f2c3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/reset-session-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/reset-session-id.html index c6093745a6..32dd271111 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/reset-session-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/reset-session-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/session-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/session-id.html index 34b7a21b4a..6ad5890008 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/session-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-analytics-param-repository/session-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/-app-switch-not-available-exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/-app-switch-not-available-exception.html index 92b2ce9e9d..66f2cae982 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/-app-switch-not-available-exception.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/-app-switch-not-available-exception.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/index.html index 209e0c8e01..0bf6e12395 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-app-switch-not-available-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/-companion/index.html new file mode 100644 index 0000000000..e1bd752959 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/-companion/index.html @@ -0,0 +1,80 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/get-configuration.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/get-configuration.html index 01d2080498..2670f5ec47 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/get-configuration.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/get-configuration.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/index.html index 2f2fd1cd93..a802f18fa4 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -67,6 +67,25 @@

BraintreeClient
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+

Functions

diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/launches-browser-switch-as-new-task.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/launches-browser-switch-as-new-task.html index dee3e371f8..66abe35f67 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/launches-browser-switch-as-new-task.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-client/launches-browser-switch-as-new-task.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/-companion/index.html index 8abdb351a1..f688d56ea7 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/-companion/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/code.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/code.html index 0dbdb497c4..c90e7fc2d5 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/code.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/error-for.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/error-for.html index 3a9dcf8900..5f703efe90 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/error-for.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/error-for.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field-errors.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field-errors.html index 82f98eb9f9..db841b627d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field-errors.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field-errors.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field.html index c67082cde6..9d648a478f 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/field.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/index.html index 66476db61c..f8b61369bf 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/message.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/message.html index 448e9b42a0..96274c5444 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/message.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/message.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/to-string.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/to-string.html index b51eb13f44..79aeb7c6f8 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/to-string.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-error/to-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/-braintree-exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/-braintree-exception.html index 54454b5907..263de7794a 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/-braintree-exception.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/-braintree-exception.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/index.html index bbeaf3dacd..bf7459b906 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-g-o-o-g-l-e_-p-a-y/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-g-o-o-g-l-e_-p-a-y/index.html index cc0843b985..230c00c930 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-g-o-o-g-l-e_-p-a-y/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-g-o-o-g-l-e_-p-a-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-l-o-c-a-l_-p-a-y-m-e-n-t/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-l-o-c-a-l_-p-a-y-m-e-n-t/index.html index 0ff8585079..509ac303a3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-l-o-c-a-l_-p-a-y-m-e-n-t/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-l-o-c-a-l_-p-a-y-m-e-n-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-p-a-y-p-a-l/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-p-a-y-p-a-l/index.html index 58b31518cd..10c8a3a8da 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-p-a-y-p-a-l/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-p-a-y-p-a-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-s-e-p-a_-d-e-b-i-t/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-s-e-p-a_-d-e-b-i-t/index.html index 117c6b40f4..05d19f673e 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-s-e-p-a_-d-e-b-i-t/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-s-e-p-a_-d-e-b-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-t-h-r-e-e_-d_-s-e-c-u-r-e/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-t-h-r-e-e_-d_-s-e-c-u-r-e/index.html index b1da4082ad..ef1433f903 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-t-h-r-e-e_-d_-s-e-c-u-r-e/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-t-h-r-e-e_-d_-s-e-c-u-r-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-e-n-m-o/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-e-n-m-o/index.html index e1e0ce62b1..555caeb034 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-e-n-m-o/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-e-n-m-o/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-i-s-a_-c-h-e-c-k-o-u-t/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-i-s-a_-c-h-e-c-k-o-u-t/index.html index 2cdaa8ff88..1764d60217 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-i-s-a_-c-h-e-c-k-o-u-t/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/-v-i-s-a_-c-h-e-c-k-o-u-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/code.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/code.html index ab8df4b389..f4c30c7628 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/code.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/entries.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/entries.html index 93ce18f738..0795866a1b 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/entries.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/index.html index 2d55adeb17..1668359d80 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/value-of.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/value-of.html index 7e83c0ad2b..2f19f1bdc3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/value-of.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/values.html b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/values.html index 0f152624f2..71b6d0fa2e 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/values.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-braintree-request-codes/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/index.html index 687711d76c..7156eb0eb7 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/on-result.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/on-result.html index df6e9a1c05..e5e2b369f1 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/on-result.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-callback/on-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/-configuration-exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/-configuration-exception.html index a24a0000fd..1f88bba46f 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/-configuration-exception.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/-configuration-exception.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/index.html index a9a14e1e00..250e1e105b 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/assets-url.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/assets-url.html index 5ff82c5573..85c4ef4412 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/assets-url.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/assets-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/cardinal-authentication-jwt.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/cardinal-authentication-jwt.html index 407b9d41b3..84a4bb578d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/cardinal-authentication-jwt.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/cardinal-authentication-jwt.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/client-api-url.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/client-api-url.html index e45958b47d..43408d7538 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/client-api-url.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/client-api-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/environment.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/environment.html index edf2fb579d..1d7f0a5ec6 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/environment.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/environment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/index.html index 840777fe2d..2c82f95c1f 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-cvv-challenge-present.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-cvv-challenge-present.html index 9a4772fbf6..e7dee38599 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-cvv-challenge-present.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-cvv-challenge-present.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-google-pay-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-google-pay-enabled.html index f2bff26d53..445e55f067 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-google-pay-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-google-pay-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-local-payment-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-local-payment-enabled.html index dba5f6ff9d..7164ba70b3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-local-payment-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-local-payment-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-pay-pal-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-pay-pal-enabled.html index 354b63eb24..1b6aee762d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-pay-pal-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-pay-pal-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-postal-code-challenge-present.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-postal-code-challenge-present.html index 82a5e819fc..3d8734ed73 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-postal-code-challenge-present.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-postal-code-challenge-present.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-three-d-secure-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-three-d-secure-enabled.html index 6c43921eae..8d15696aa5 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-three-d-secure-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-three-d-secure-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-venmo-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-venmo-enabled.html index ff4fddded9..1c50cc4eef 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-venmo-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-venmo-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-visa-checkout-enabled.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-visa-checkout-enabled.html index 631d7a54a0..f80e5dbddf 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-visa-checkout-enabled.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/is-visa-checkout-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-account-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-account-id.html index 32db09848a..e33036db1f 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-account-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-id.html index e8ef7cbdea..23a2bdc488 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/merchant-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-direct-base-url.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-direct-base-url.html index e95710b3e0..9e2c80197d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-direct-base-url.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-direct-base-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-privacy-url.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-privacy-url.html index afb893f43f..756e398c05 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-privacy-url.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-privacy-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-user-agreement-url.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-user-agreement-url.html index c6b09eecbc..22100097a5 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-user-agreement-url.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/pay-pal-user-agreement-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/supported-card-types.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/supported-card-types.html index cd26ddd9e7..6474075fdf 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/supported-card-types.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/supported-card-types.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/to-json.html b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/to-json.html index 4354e18c22..711f4c6f67 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/to-json.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-configuration/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/-companion/index.html index 30efe579f4..adc39ee1eb 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/-companion/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-for.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-for.html index 4ebcd9fbcf..4114d007e1 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-for.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-for.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-response.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-response.html index 0042bec090..b2d6e4ea51 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-response.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/error-response.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/field-errors.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/field-errors.html index a311648375..a4990a4bc5 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/field-errors.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/field-errors.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/index.html index c503521ef8..42ae69ca94 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/message.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/message.html index 044b279f3d..ea8e7352b6 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/message.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/message.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/status-code.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/status-code.html index 0c613461a1..d176af9791 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/status-code.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/status-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/to-string.html b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/to-string.html index 717ae11191..fe95f4d6a3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/to-string.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-error-with-response/to-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-experimental-beta-api/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-experimental-beta-api/index.html index c3cc1516ff..f05dd2931b 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-experimental-beta-api/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-experimental-beta-api/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-get-return-link-use-case.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-get-return-link-use-case.html new file mode 100644 index 0000000000..deb130ce2d --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-get-return-link-use-case.html @@ -0,0 +1,76 @@ + + + + + GetReturnLinkUseCase + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

GetReturnLinkUseCase

+
+
constructor(merchantRepository: MerchantRepository)
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/-app-link.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/-app-link.html new file mode 100644 index 0000000000..4c39e8119e --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/-app-link.html @@ -0,0 +1,76 @@ + + + + + AppLink + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

AppLink

+
+
constructor(appLinkReturnUri: Uri)
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/app-link-return-uri.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/app-link-return-uri.html new file mode 100644 index 0000000000..8bd8991905 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/app-link-return-uri.html @@ -0,0 +1,76 @@ + + + + + appLinkReturnUri + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

appLinkReturnUri

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/index.html new file mode 100644 index 0000000000..02359266a5 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-app-link/index.html @@ -0,0 +1,119 @@ + + + + + AppLink + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

AppLink

+
data class AppLink(val appLinkReturnUri: Uri) : GetReturnLinkUseCase.ReturnLinkResult
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(appLinkReturnUri: Uri)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/-deep-link.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/-deep-link.html new file mode 100644 index 0000000000..366d00c695 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/-deep-link.html @@ -0,0 +1,76 @@ + + + + + DeepLink + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DeepLink

+
+
constructor(deepLinkFallbackUrlScheme: String)
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/deep-link-fallback-url-scheme.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/deep-link-fallback-url-scheme.html new file mode 100644 index 0000000000..4c99918f86 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/deep-link-fallback-url-scheme.html @@ -0,0 +1,76 @@ + + + + + deepLinkFallbackUrlScheme + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deepLinkFallbackUrlScheme

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/index.html new file mode 100644 index 0000000000..2b0ce3d3a1 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-deep-link/index.html @@ -0,0 +1,119 @@ + + + + + DeepLink + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DeepLink

+
data class DeepLink(val deepLinkFallbackUrlScheme: String) : GetReturnLinkUseCase.ReturnLinkResult
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(deepLinkFallbackUrlScheme: String)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/-failure.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/-failure.html new file mode 100644 index 0000000000..70dde6b14b --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/-failure.html @@ -0,0 +1,76 @@ + + + + + Failure + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Failure

+
+
constructor(exception: Exception)
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/exception.html new file mode 100644 index 0000000000..5adb57bb38 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/exception.html @@ -0,0 +1,76 @@ + + + + + exception + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

exception

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/index.html new file mode 100644 index 0000000000..b1762442bc --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/-failure/index.html @@ -0,0 +1,119 @@ + + + + + Failure + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Failure

+ +
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(exception: Exception)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/index.html new file mode 100644 index 0000000000..36e325a0bc --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/-return-link-result/index.html @@ -0,0 +1,130 @@ + + + + + ReturnLinkResult + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

ReturnLinkResult

+ +
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
data class AppLink(val appLinkReturnUri: Uri) : GetReturnLinkUseCase.ReturnLinkResult
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
data class DeepLink(val deepLinkFallbackUrlScheme: String) : GetReturnLinkUseCase.ReturnLinkResult
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/index.html new file mode 100644 index 0000000000..8af45c1e1f --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/index.html @@ -0,0 +1,138 @@ + + + + + GetReturnLinkUseCase + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

GetReturnLinkUseCase

+

Use case that returns a return link that should be used for navigating from App Switch / CCT back into the merchant app. It handles both App Links and Deep Links.

If a user unchecks the "Open supported links" checkbox in the Android OS settings for the merchant's app. If this setting is unchecked, this use case will return ReturnLinkResult.DeepLink, otherwise ReturnLinkResult.AppLink will be returned.

+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(merchantRepository: MerchantRepository)
+
+
+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
sealed class ReturnLinkResult
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/invoke.html b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/invoke.html new file mode 100644 index 0000000000..ef1b2ee549 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-get-return-link-use-case/invoke.html @@ -0,0 +1,76 @@ + + + + + invoke + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

invoke

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/-invalid-argument-exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/-invalid-argument-exception.html index bdc829a1eb..bef49133af 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/-invalid-argument-exception.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/-invalid-argument-exception.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/index.html index 893058a167..97c6b4b13b 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-invalid-argument-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-l-i-n-k/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-l-i-n-k/index.html index 2256b2ea7f..20c7eace42 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-l-i-n-k/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-l-i-n-k/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-s-w-i-t-c-h/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-s-w-i-t-c-h/index.html index 7c2bc50a94..6f24f975fb 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-s-w-i-t-c-h/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/-a-p-p_-s-w-i-t-c-h/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/entries.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/entries.html index 93e49d8536..5744370fb2 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/entries.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/index.html index 3a896e9a83..5dec7c84f4 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/string-value.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/string-value.html index d67ba2d834..c1f285d73c 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/string-value.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/string-value.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/value-of.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/value-of.html index c81baad314..840df0d845 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/value-of.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/values.html b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/values.html index 42d3c94b92..838c448480 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/values.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-link-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/index.html new file mode 100644 index 0000000000..096dfcdb2c --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/index.html @@ -0,0 +1,100 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Singleton instance of the MerchantRepository.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/instance.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/instance.html new file mode 100644 index 0000000000..c0d67245cd --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-companion/instance.html @@ -0,0 +1,76 @@ + + + + + instance + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

instance

+
+

Singleton instance of the MerchantRepository.

+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-merchant-repository.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-merchant-repository.html new file mode 100644 index 0000000000..4417860e90 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/-merchant-repository.html @@ -0,0 +1,76 @@ + + + + + MerchantRepository + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

MerchantRepository

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/app-link-return-uri.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/app-link-return-uri.html new file mode 100644 index 0000000000..1375017792 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/app-link-return-uri.html @@ -0,0 +1,76 @@ + + + + + appLinkReturnUri + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

appLinkReturnUri

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/application-context.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/application-context.html new file mode 100644 index 0000000000..1ef353135c --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/application-context.html @@ -0,0 +1,76 @@ + + + + + applicationContext + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

applicationContext

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/authorization.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/authorization.html new file mode 100644 index 0000000000..9d0e4ad581 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/authorization.html @@ -0,0 +1,76 @@ + + + + + authorization + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

authorization

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/deep-link-fallback-url-scheme.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/deep-link-fallback-url-scheme.html new file mode 100644 index 0000000000..d882a696ab --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/deep-link-fallback-url-scheme.html @@ -0,0 +1,76 @@ + + + + + deepLinkFallbackUrlScheme + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deepLinkFallbackUrlScheme

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/index.html new file mode 100644 index 0000000000..1e7b263fb4 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/index.html @@ -0,0 +1,213 @@ + + + + + MerchantRepository + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

MerchantRepository

+

An internal repository that holds properties set by the integrating merchant.

+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
lateinit var returnUrlScheme: String
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/integration-type.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/integration-type.html new file mode 100644 index 0000000000..066457bdea --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/integration-type.html @@ -0,0 +1,76 @@ + + + + + integrationType + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

integrationType

+
+ +
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/return-url-scheme.html b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/return-url-scheme.html new file mode 100644 index 0000000000..f64633ce92 --- /dev/null +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-merchant-repository/return-url-scheme.html @@ -0,0 +1,76 @@ + + + + + returnUrlScheme + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

returnUrlScheme

+
+
lateinit var returnUrlScheme: String
+
+ +
+
+
+ + + diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/-payment-method-nonce.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/-payment-method-nonce.html index 8009b17b0a..594b1913e2 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/-payment-method-nonce.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/-payment-method-nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/index.html index 22a0e685f0..93a5027062 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/is-default.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/is-default.html index d7e7d450a4..632dec8b57 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/is-default.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/string.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/string.html index 884b00514c..890d0333ce 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/string.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-d-e-f-a-u-l-t_-s-o-u-r-c-e.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-d-e-f-a-u-l-t_-s-o-u-r-c-e.html index 858702544a..b0ee0edf5d 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-d-e-f-a-u-l-t_-s-o-u-r-c-e.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-d-e-f-a-u-l-t_-s-o-u-r-c-e.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-e-r-a-t-i-o-n_-n-a-m-e_-k-e-y.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-e-r-a-t-i-o-n_-n-a-m-e_-k-e-y.html index 683fb8f401..9c816e49f8 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-e-r-a-t-i-o-n_-n-a-m-e_-k-e-y.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-e-r-a-t-i-o-n_-n-a-m-e_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-t-i-o-n-s_-k-e-y.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-t-i-o-n-s_-k-e-y.html index 63f01d297e..b60582bc91 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-t-i-o-n-s_-k-e-y.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-o-p-t-i-o-n-s_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-v-a-l-i-d-a-t-e_-k-e-y.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-v-a-l-i-d-a-t-e_-k-e-y.html index 87732c9943..d0585e082a 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-v-a-l-i-d-a-t-e_-k-e-y.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/-v-a-l-i-d-a-t-e_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/index.html index aadf9e2001..14fc2f63c8 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/api-path.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/api-path.html index 942c1fe8b1..f79a293a75 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/api-path.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/api-path.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/build-j-s-o-n.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/build-j-s-o-n.html index e4fa420cf4..cc7b79706e 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/build-j-s-o-n.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/build-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/index.html index 9a2a131208..c3083a7c52 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/integration.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/integration.html index a2265e8067..a8847784b1 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/integration.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/integration.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/session-id.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/session-id.html index 2ca8a7354e..e8789c6b53 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/session-id.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/session-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/source.html b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/source.html index f2b42dc5cf..0becbebd7c 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/source.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-payment-method/source.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/-postal-address.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/-postal-address.html index 37830253a6..ab61f54656 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/-postal-address.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/-postal-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/country-code-alpha2.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/country-code-alpha2.html index ae938b8f26..38c02526c3 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/country-code-alpha2.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/country-code-alpha2.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/extended-address.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/extended-address.html index 5a30d9acaa..761c5992a9 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/extended-address.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/extended-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/index.html index 7f88e4a29b..ca2ab4937c 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/is-empty.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/is-empty.html index 8c1ecf5c96..6562847f8e 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/is-empty.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/is-empty.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/locality.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/locality.html index 6a5c367f65..6218515852 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/locality.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/locality.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/phone-number.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/phone-number.html index 9c098ea46b..39cdf2c9f7 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/phone-number.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/postal-code.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/postal-code.html index bd851e7dca..6eca2b6a70 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/postal-code.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/postal-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/recipient-name.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/recipient-name.html index e8fede9a45..ea2fc51735 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/recipient-name.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/recipient-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/region.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/region.html index cc28fb6eb6..a7c556c719 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/region.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/region.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/sorting-code.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/sorting-code.html index 30338b2579..409510f644 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/sorting-code.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/sorting-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/street-address.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/street-address.html index 9bf7cfbd1f..d399e22001 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/street-address.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/street-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/to-string.html b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/to-string.html index cd88803ef1..56d10473db 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/to-string.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-postal-address/to-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/-user-canceled-exception.html b/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/-user-canceled-exception.html index 8493822689..c8f15ff245 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/-user-canceled-exception.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/-user-canceled-exception.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/index.html index 9e0120ba33..939c6a9cf6 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/-user-canceled-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/com.braintreepayments.api.core/index.html b/docs/BraintreeCore/com.braintreepayments.api.core/index.html index 383ac7aceb..f181e5d9e6 100644 --- a/docs/BraintreeCore/com.braintreepayments.api.core/index.html +++ b/docs/BraintreeCore/com.braintreepayments.api.core/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -68,7 +68,22 @@

Package-level declaratio

Types

-
+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+
@@ -78,7 +93,7 @@

Types

-
data class AnalyticsEventParams @JvmOverloads constructor(var payPalContextId: String? = null, var linkType: String? = null, var isVaultRequest: Boolean = false, var startTime: Long? = null, var endTime: Long? = null, var endpoint: String? = null, val experiment: String? = null, val paymentMethodsDisplayed: List<String> = emptyList())

DTO for analytics events. See also: AnalyticsEvent It is a catch-all data class for any parameters any of the modules wants to send. As such, not all parameters are required at each call site.

+
data class AnalyticsEventParams @JvmOverloads constructor(var payPalContextId: String? = null, var linkType: String? = null, var isVaultRequest: Boolean = false, var startTime: Long? = null, var endTime: Long? = null, var endpoint: String? = null, val experiment: String? = null, val paymentMethodsDisplayed: List<String> = emptyList(), val appSwitchUrl: String? = null)

DTO for analytics events. See also: AnalyticsEvent It is a catch-all data class for any parameters any of the modules wants to send. As such, not all parameters are required at each call site.

@@ -248,6 +263,21 @@

Types

+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Use case that returns a return link that should be used for navigating from App Switch / CCT back into the merchant app. It handles both App Links and Deep Links.

+
+
+
+
@@ -278,6 +308,21 @@

Types

+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

An internal repository that holds properties set by the integrating merchant.

+
+
+
+
diff --git a/docs/BraintreeCore/index.html b/docs/BraintreeCore/index.html index 71dbf69cb8..8d4b8fd8e5 100644 --- a/docs/BraintreeCore/index.html +++ b/docs/BraintreeCore/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/BraintreeCore/navigation.html b/docs/BraintreeCore/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/BraintreeCore/navigation.html +++ b/docs/BraintreeCore/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/from-json.html b/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/from-json.html index 24cd2d2e9a..208f1ccae1 100644 --- a/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/from-json.html +++ b/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/index.html b/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/index.html index a5de533203..a7ba537428 100644 --- a/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/index.html +++ b/docs/Card/com.braintreepayments.api.card/-authentication-insight/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-authentication-insight/index.html b/docs/Card/com.braintreepayments.api.card/-authentication-insight/index.html index ba809cdef0..030a9f20ec 100644 --- a/docs/Card/com.braintreepayments.api.card/-authentication-insight/index.html +++ b/docs/Card/com.braintreepayments.api.card/-authentication-insight/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-authentication-insight/regulation-environment.html b/docs/Card/com.braintreepayments.api.card/-authentication-insight/regulation-environment.html index 41d016144b..c1f8f0a459 100644 --- a/docs/Card/com.braintreepayments.api.card/-authentication-insight/regulation-environment.html +++ b/docs/Card/com.braintreepayments.api.card/-authentication-insight/regulation-environment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/-b-i-n_-d-a-t-a_-k-e-y.html b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/-b-i-n_-d-a-t-a_-k-e-y.html index f0dcfc28e0..882271239b 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/-b-i-n_-d-a-t-a_-k-e-y.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/-b-i-n_-d-a-t-a_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/from-json.html b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/from-json.html index 0a10ba05a7..6d2bf2dc7e 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/from-json.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/index.html b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/index.html index bdd13155e1..5be9a501a2 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/commercial.html b/docs/Card/com.braintreepayments.api.card/-bin-data/commercial.html index bbb56b4f03..65c831f4f6 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/commercial.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/commercial.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/country-of-issuance.html b/docs/Card/com.braintreepayments.api.card/-bin-data/country-of-issuance.html index d593551334..e4f77b342c 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/country-of-issuance.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/country-of-issuance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/debit.html b/docs/Card/com.braintreepayments.api.card/-bin-data/debit.html index 9542a53322..a9b9ed723b 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/debit.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/debit.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/durbin-regulated.html b/docs/Card/com.braintreepayments.api.card/-bin-data/durbin-regulated.html index 7e5da6c33b..ede378b5b6 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/durbin-regulated.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/durbin-regulated.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/healthcare.html b/docs/Card/com.braintreepayments.api.card/-bin-data/healthcare.html index 2d5afc3ce1..95e5217a86 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/healthcare.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/healthcare.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/index.html b/docs/Card/com.braintreepayments.api.card/-bin-data/index.html index 43d5aea759..0d2917f8c1 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/issuing-bank.html b/docs/Card/com.braintreepayments.api.card/-bin-data/issuing-bank.html index 0c10753747..49ae69181c 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/issuing-bank.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/issuing-bank.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/payroll.html b/docs/Card/com.braintreepayments.api.card/-bin-data/payroll.html index 4c5ffee9b7..7880f12269 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/payroll.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/payroll.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/prepaid.html b/docs/Card/com.braintreepayments.api.card/-bin-data/prepaid.html index ebaddd62d2..90bf3615b0 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/prepaid.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/prepaid.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-data/product-id.html b/docs/Card/com.braintreepayments.api.card/-bin-data/product-id.html index 902a0ca8a9..0a0ea913ad 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-data/product-id.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-data/product-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/-companion/index.html b/docs/Card/com.braintreepayments.api.card/-bin-type/-companion/index.html index c35eb9c5f4..927b279c12 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/-companion/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/-no/index.html b/docs/Card/com.braintreepayments.api.card/-bin-type/-no/index.html index 75ca591814..daa2ceed24 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/-no/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/-no/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/-unknown/index.html b/docs/Card/com.braintreepayments.api.card/-bin-type/-unknown/index.html index 5c5490e916..0ce0ce51f6 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/-unknown/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/-unknown/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/-yes/index.html b/docs/Card/com.braintreepayments.api.card/-bin-type/-yes/index.html index 5697fb82d5..dccdd30abc 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/-yes/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/-yes/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/entries.html b/docs/Card/com.braintreepayments.api.card/-bin-type/entries.html index ebbd96ac74..19ce810423 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/entries.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/index.html b/docs/Card/com.braintreepayments.api.card/-bin-type/index.html index 582a8a21da..ba6200a3d9 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/index.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/value-of.html b/docs/Card/com.braintreepayments.api.card/-bin-type/value-of.html index 65cd0a28b7..77d40b5ec2 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/value-of.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-bin-type/values.html b/docs/Card/com.braintreepayments.api.card/-bin-type/values.html index 88c8940d80..fec947fabc 100644 --- a/docs/Card/com.braintreepayments.api.card/-bin-type/values.html +++ b/docs/Card/com.braintreepayments.api.card/-bin-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-client/-card-client.html b/docs/Card/com.braintreepayments.api.card/-card-client/-card-client.html index 9a59e157e0..05d6bca8cf 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-client/-card-client.html +++ b/docs/Card/com.braintreepayments.api.card/-card-client/-card-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-client/index.html b/docs/Card/com.braintreepayments.api.card/-card-client/index.html index 2011fbf141..0d15c385be 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-client/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-client/tokenize.html b/docs/Card/com.braintreepayments.api.card/-card-client/tokenize.html index 145fc04f9f..768d836466 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-client/tokenize.html +++ b/docs/Card/com.braintreepayments.api.card/-card-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/-card-nonce.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/-card-nonce.html index a64d4a20e8..4de90c915c 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/-card-nonce.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/-card-nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html index 23b093b912..808aed7c93 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-d-a-t-a_-k-e-y.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-d-a-t-a_-k-e-y.html index c50a5da7ee..6606939b51 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-d-a-t-a_-k-e-y.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/-d-a-t-a_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/from-j-s-o-n.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/from-j-s-o-n.html index 031a753b7e..28d9afdea7 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/from-j-s-o-n.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/index.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/index.html index 10b5467c59..61686b2c0b 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/authentication-insight.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/authentication-insight.html index e5e3bcda97..ce9006c4c6 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/authentication-insight.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/authentication-insight.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/bin-data.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/bin-data.html index 5bc1d4eee3..23466de6d0 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/bin-data.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/bin-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/bin.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/bin.html index 10f2640905..2da134c026 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/bin.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/bin.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/card-type.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/card-type.html index a61ffa7cb6..7ef29c6802 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/card-type.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/card-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/cardholder-name.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/cardholder-name.html index e8e8166cb9..dbbeb87eca 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/cardholder-name.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/cardholder-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-month.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-month.html index 28c4607788..b4ad49e425 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-month.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-month.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-year.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-year.html index 21a0663be7..18ca23551f 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-year.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/expiration-year.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/index.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/index.html index 1681588916..cc1e1e3bf9 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/is-default.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/is-default.html index 278706c2af..aa9ead80a5 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/is-default.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/last-four.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/last-four.html index 08f27e335b..ace6781d77 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/last-four.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/last-four.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/last-two.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/last-two.html index c6ad5880bd..23323b1836 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/last-two.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/last-two.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-nonce/string.html b/docs/Card/com.braintreepayments.api.card/-card-nonce/string.html index 61172381f2..fc1ddac466 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-nonce/string.html +++ b/docs/Card/com.braintreepayments.api.card/-card-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-result/-failure/error.html b/docs/Card/com.braintreepayments.api.card/-card-result/-failure/error.html index 1c51635b60..af3c4aecc0 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-result/-failure/error.html +++ b/docs/Card/com.braintreepayments.api.card/-card-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-result/-failure/index.html b/docs/Card/com.braintreepayments.api.card/-card-result/-failure/index.html index bafdf7e594..5960f3e9ac 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-result/-failure/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-result/-success/index.html b/docs/Card/com.braintreepayments.api.card/-card-result/-success/index.html index 418c696ee2..88299ecff3 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-result/-success/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-result/-success/nonce.html b/docs/Card/com.braintreepayments.api.card/-card-result/-success/nonce.html index 30c9313a22..4ce4ea2c5e 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-result/-success/nonce.html +++ b/docs/Card/com.braintreepayments.api.card/-card-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-result/index.html b/docs/Card/com.braintreepayments.api.card/-card-result/index.html index 521c191e51..19656b3789 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-result/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/index.html b/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/index.html index 06d278dbe2..2082032828 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/on-card-result.html b/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/on-card-result.html index 5b7c72dd1c..0ff76036e5 100644 --- a/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/on-card-result.html +++ b/docs/Card/com.braintreepayments.api.card/-card-tokenize-callback/on-card-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/-card.html b/docs/Card/com.braintreepayments.api.card/-card/-card.html index 04520ff191..b57641ea04 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/-card.html +++ b/docs/Card/com.braintreepayments.api.card/-card/-card.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/-companion/index.html b/docs/Card/com.braintreepayments.api.card/-card/-companion/index.html index 2ae3a06283..0b3e765f15 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/-companion/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/api-path.html b/docs/Card/com.braintreepayments.api.card/-card/api-path.html index 9eb6f12d6d..18c8aed7ff 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/api-path.html +++ b/docs/Card/com.braintreepayments.api.card/-card/api-path.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n-for-graph-q-l.html b/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n-for-graph-q-l.html index 5c11627ec8..d4dba49266 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n-for-graph-q-l.html +++ b/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n-for-graph-q-l.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n.html b/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n.html index a373ffe17b..9d47a543ed 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n.html +++ b/docs/Card/com.braintreepayments.api.card/-card/build-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/cardholder-name.html b/docs/Card/com.braintreepayments.api.card/-card/cardholder-name.html index e87069dd6a..42db2854c5 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/cardholder-name.html +++ b/docs/Card/com.braintreepayments.api.card/-card/cardholder-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/company.html b/docs/Card/com.braintreepayments.api.card/-card/company.html index 6b6349c4dd..bb5f27d681 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/company.html +++ b/docs/Card/com.braintreepayments.api.card/-card/company.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/country-code.html b/docs/Card/com.braintreepayments.api.card/-card/country-code.html index 9557589603..86a48cfaa1 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/country-code.html +++ b/docs/Card/com.braintreepayments.api.card/-card/country-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/cvv.html b/docs/Card/com.braintreepayments.api.card/-card/cvv.html index e78efa22f0..2ed73cef0e 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/cvv.html +++ b/docs/Card/com.braintreepayments.api.card/-card/cvv.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/expiration-month.html b/docs/Card/com.braintreepayments.api.card/-card/expiration-month.html index 9ec02167b7..834ba4a100 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/expiration-month.html +++ b/docs/Card/com.braintreepayments.api.card/-card/expiration-month.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/expiration-year.html b/docs/Card/com.braintreepayments.api.card/-card/expiration-year.html index 5d98b6352b..4b5abdd227 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/expiration-year.html +++ b/docs/Card/com.braintreepayments.api.card/-card/expiration-year.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/extended-address.html b/docs/Card/com.braintreepayments.api.card/-card/extended-address.html index dc54c7b4b0..da8a69c2f6 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/extended-address.html +++ b/docs/Card/com.braintreepayments.api.card/-card/extended-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/first-name.html b/docs/Card/com.braintreepayments.api.card/-card/first-name.html index b393e966ca..af0377ee58 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/first-name.html +++ b/docs/Card/com.braintreepayments.api.card/-card/first-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/index.html b/docs/Card/com.braintreepayments.api.card/-card/index.html index 14a0abe020..47439ee22b 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/index.html +++ b/docs/Card/com.braintreepayments.api.card/-card/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/integration.html b/docs/Card/com.braintreepayments.api.card/-card/integration.html index 889fdb5985..32e64a909b 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/integration.html +++ b/docs/Card/com.braintreepayments.api.card/-card/integration.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/is-authentication-insight-requested.html b/docs/Card/com.braintreepayments.api.card/-card/is-authentication-insight-requested.html index c15ac8aed0..7221825857 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/is-authentication-insight-requested.html +++ b/docs/Card/com.braintreepayments.api.card/-card/is-authentication-insight-requested.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/last-name.html b/docs/Card/com.braintreepayments.api.card/-card/last-name.html index 9136146a71..4b9f9dbbda 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/last-name.html +++ b/docs/Card/com.braintreepayments.api.card/-card/last-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/locality.html b/docs/Card/com.braintreepayments.api.card/-card/locality.html index 814125a2a7..438768c132 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/locality.html +++ b/docs/Card/com.braintreepayments.api.card/-card/locality.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/merchant-account-id.html b/docs/Card/com.braintreepayments.api.card/-card/merchant-account-id.html index f12a729f09..b7e747f166 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/merchant-account-id.html +++ b/docs/Card/com.braintreepayments.api.card/-card/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/number.html b/docs/Card/com.braintreepayments.api.card/-card/number.html index 6be9fbd895..b2698f0eb4 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/number.html +++ b/docs/Card/com.braintreepayments.api.card/-card/number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/postal-code.html b/docs/Card/com.braintreepayments.api.card/-card/postal-code.html index a982c691e2..daecc7a04d 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/postal-code.html +++ b/docs/Card/com.braintreepayments.api.card/-card/postal-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/region.html b/docs/Card/com.braintreepayments.api.card/-card/region.html index 4812947fa8..d6c7af5b25 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/region.html +++ b/docs/Card/com.braintreepayments.api.card/-card/region.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/session-id.html b/docs/Card/com.braintreepayments.api.card/-card/session-id.html index fef942a31a..7f73d0edb6 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/session-id.html +++ b/docs/Card/com.braintreepayments.api.card/-card/session-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/should-validate.html b/docs/Card/com.braintreepayments.api.card/-card/should-validate.html index 60b770882f..6c81702e1b 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/should-validate.html +++ b/docs/Card/com.braintreepayments.api.card/-card/should-validate.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/source.html b/docs/Card/com.braintreepayments.api.card/-card/source.html index eff3c45cc0..30da17afb9 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/source.html +++ b/docs/Card/com.braintreepayments.api.card/-card/source.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/-card/street-address.html b/docs/Card/com.braintreepayments.api.card/-card/street-address.html index 94212bc37e..ffa0fbcfee 100644 --- a/docs/Card/com.braintreepayments.api.card/-card/street-address.html +++ b/docs/Card/com.braintreepayments.api.card/-card/street-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/com.braintreepayments.api.card/index.html b/docs/Card/com.braintreepayments.api.card/index.html index 76fd37cb9d..6f437eb06c 100644 --- a/docs/Card/com.braintreepayments.api.card/index.html +++ b/docs/Card/com.braintreepayments.api.card/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/index.html b/docs/Card/index.html index 1c1ecb1e80..d9cb00bb49 100644 --- a/docs/Card/index.html +++ b/docs/Card/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Card/navigation.html b/docs/Card/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/Card/navigation.html +++ b/docs/Card/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/index.html index d3811bd763..3ebe76d820 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/on-data-collector-result.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/on-data-collector-result.html index 46b4bb33ad..0a4f35256c 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/on-data-collector-result.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-callback/on-data-collector-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-companion/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-companion/index.html index 9829dfb7e8..0d34b35c81 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-companion/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-data-collector-internal-request.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-data-collector-internal-request.html index 8df4f9158d..20e8eab114 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-data-collector-internal-request.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/-data-collector-internal-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/additional-data.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/additional-data.html index cd5a64d960..4c27db9c44 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/additional-data.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/additional-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/application-guid.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/application-guid.html index ef1b7d47ff..80f0bd1813 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/application-guid.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/application-guid.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/client-metadata-id.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/client-metadata-id.html index 4f38753262..3597eb5c10 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/client-metadata-id.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/client-metadata-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/has-user-location-consent.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/has-user-location-consent.html index 7c3f964469..3abaa74b13 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/has-user-location-consent.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/index.html index fbed351fcc..50dc03111d 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/is-disable-beacon.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/is-disable-beacon.html index 31035916bf..7700be0bb2 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/is-disable-beacon.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-internal-request/is-disable-beacon.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/-data-collector-request.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/-data-collector-request.html index 8b9a138df7..3fa99a4069 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/-data-collector-request.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/-data-collector-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/has-user-location-consent.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/has-user-location-consent.html index 4bf759f8de..2aef14dbb7 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/has-user-location-consent.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/index.html index 32d0d2ee38..fb92f4bd7b 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/risk-correlation-id.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/risk-correlation-id.html index 962818118b..237490cba1 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/risk-correlation-id.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-request/risk-correlation-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/error.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/error.html index f8cbf3128e..aba81de76b 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/error.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/index.html index 767ecc7719..1c19132a3d 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/device-data.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/device-data.html index 845e2ab613..b1b51f8abd 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/device-data.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/device-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/index.html index 48667fac2d..abb35f4d9b 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/index.html index 48ec429bb1..ae4825ddc9 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-companion/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-companion/index.html index 84bda2c0c5..141e6bcb2a 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-companion/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-data-collector.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-data-collector.html index 088646ee84..e080d7d7a6 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-data-collector.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/-data-collector.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/collect-device-data.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/collect-device-data.html index a0d10a81b5..79cb1238b4 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/collect-device-data.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/collect-device-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/index.html index 5f2eaaf948..473215fcea 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-data-collector/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/-magnes-internal-client.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/-magnes-internal-client.html index 72c78c2281..96440b96a0 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/-magnes-internal-client.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/-magnes-internal-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/index.html index bb97512848..94d47972ba 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/-magnes-internal-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/com.braintreepayments.api.datacollector/index.html b/docs/DataCollector/com.braintreepayments.api.datacollector/index.html index 1166a96b27..35f7a83ee8 100644 --- a/docs/DataCollector/com.braintreepayments.api.datacollector/index.html +++ b/docs/DataCollector/com.braintreepayments.api.datacollector/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/index.html b/docs/DataCollector/index.html index eba90a0788..28ac995c69 100644 --- a/docs/DataCollector/index.html +++ b/docs/DataCollector/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/DataCollector/navigation.html b/docs/DataCollector/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/DataCollector/navigation.html +++ b/docs/DataCollector/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-f-u-l-l/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-f-u-l-l/index.html index cbf323403c..26440cdc08 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-f-u-l-l/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-f-u-l-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-m-i-n/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-m-i-n/index.html index fff8b28986..a2fcb13a18 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-m-i-n/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/-m-i-n/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/entries.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/entries.html index 3dc1003a57..91de29fd8f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/entries.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/index.html index 287854e2be..328bb13a4f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/value-of.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/value-of.html index b844c545f4..2bcb4d03f0 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/value-of.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/values.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/values.html index 5b6a8235d0..2a212c219c 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/values.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-billing-address-format/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html index 7bdd18d43c..3da3f31945 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/from-j-s-o-n.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/from-j-s-o-n.html index 6b0164bafc..87824a7b04 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/from-j-s-o-n.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/index.html index 689c02824c..d32e848296 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/billing-address.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/billing-address.html index 9f01074c43..c0d33be727 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/billing-address.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin-data.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin-data.html index 1f09a0d7ac..af378fb720 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin-data.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin.html index 0f689bfb91..8c9f373371 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/bin.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-network.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-network.html index 79d2fed058..f7fd8783c8 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-network.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-network.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-type.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-type.html index 23c59cc64f..4663124627 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-type.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/card-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/email.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/email.html index 660c6319ec..714162db1e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/email.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/index.html index 9cd241abb2..89433f54a9 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-default.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-default.html index 79bd39cb43..531d97e48b 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-default.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-network-tokenized.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-network-tokenized.html index 8c9db76ea5..e812b24116 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-network-tokenized.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/is-network-tokenized.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-four.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-four.html index 2c8d596fe1..4b795489b2 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-four.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-four.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-two.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-two.html index 37a0851688..96b50f00f7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-two.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/last-two.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/shipping-address.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/shipping-address.html index 1d9a5f71ed..0868ccffd6 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/shipping-address.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/string.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/string.html index b35a9f22ec..d249ddb2a3 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/string.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-card-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-e-n-v-i-r-o-n-m-e-n-t.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-e-n-v-i-r-o-n-m-e-n-t.html index 896a744871..eb1b3d158c 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-e-n-v-i-r-o-n-m-e-n-t.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-e-n-v-i-r-o-n-m-e-n-t.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-p-a-y-m-e-n-t_-d-a-t-a_-r-e-q-u-e-s-t.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-p-a-y-m-e-n-t_-d-a-t-a_-r-e-q-u-e-s-t.html index 15382044a2..256eb6583e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-p-a-y-m-e-n-t_-d-a-t-a_-r-e-q-u-e-s-t.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/-e-x-t-r-a_-p-a-y-m-e-n-t_-d-a-t-a_-r-e-q-u-e-s-t.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/index.html index f21ac07f0b..6bde112c1f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-google-pay-client.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-google-pay-client.html index 3ab293481b..79819f09f7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-google-pay-client.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/-google-pay-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/create-payment-auth-request.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/create-payment-auth-request.html index 741c0d6409..2634a76e97 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/create-payment-auth-request.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/create-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-allowed-card-networks.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-allowed-card-networks.html index 168171491c..e112e3fac6 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-allowed-card-networks.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-allowed-card-networks.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-tokenization-parameters.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-tokenization-parameters.html index 871a6233fd..5698124075 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-tokenization-parameters.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/get-tokenization-parameters.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/index.html index 6451ccf683..86421051b9 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/is-ready-to-pay.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/is-ready-to-pay.html index c2db516c43..a704db1d6b 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/is-ready-to-pay.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/is-ready-to-pay.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/tokenize.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/tokenize.html index f5dd42a97f..55793a3ee4 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/tokenize.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/index.html index ebe12108f9..77dac12e54 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/on-tokenization-parameters-result.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/on-tokenization-parameters-result.html index b2f96d0c3d..52316a8610 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/on-tokenization-parameters-result.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-get-tokenization-parameters-callback/on-tokenization-parameters-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/index.html index 3ef6c74213..dcdddeed26 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/on-google-pay-readiness-result.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/on-google-pay-readiness-result.html index c83cd796e1..8010ed2015 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/on-google-pay-readiness-result.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-is-ready-to-pay-callback/on-google-pay-readiness-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/index.html index df8de2aa81..02f37d26e1 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/on-google-pay-launcher-result.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/on-google-pay-launcher-result.html index dc1304326a..441003bfd6 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/on-google-pay-launcher-result.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher-callback/on-google-pay-launcher-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-companion/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-companion/index.html index 3523833f70..a6e8a9d77e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-companion/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-google-pay-launcher.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-google-pay-launcher.html index c6db31aec1..829cf4060f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-google-pay-launcher.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/-google-pay-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/index.html index c7d58d0dc5..bd19e3f813 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/launch.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/launch.html index 347cbd7d34..8a90b09f9f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/launch.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/index.html index e44650949f..749373c9b9 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/on-google-pay-payment-auth-request.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/on-google-pay-payment-auth-request.html index f1c7fa630b..aea27b7cb8 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/on-google-pay-payment-auth-request.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-callback/on-google-pay-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/google-pay-environment.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/google-pay-environment.html index 7ecfd531e9..cefe8d1846 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/google-pay-environment.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/google-pay-environment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/index.html index 9dcb948f47..94cecd9a26 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/payment-data-request.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/payment-data-request.html index 02becad031..0c451317b3 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/payment-data-request.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request-params/payment-data-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/error.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/error.html index e60890060c..b059257f42 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/error.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/index.html index 2584ee16d5..2cc18e9eec 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/index.html index 453392631b..6af46d6b0b 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/request-params.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/request-params.html index b9c4c99e04..362a3ffbdc 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/index.html index 5d43d5eaee..17703b41a7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-result/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-result/index.html index 99e97abb5f..542c4e6427 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-result/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/error.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/error.html index 2c8c1f2038..1fcc42cee4 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/error.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/index.html index 3f0490cccf..be987bc39e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-not-ready-to-pay/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-ready-to-pay/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-ready-to-pay/index.html index 34a42153d5..ec6fa2bbfd 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-ready-to-pay/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/-ready-to-pay/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/index.html index ef6555de54..36a983c846 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-readiness-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/-google-pay-request.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/-google-pay-request.html index da23e2b688..e31f9d7df5 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/-google-pay-request.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/-google-pay-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-credit-cards.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-credit-cards.html index 4966dae938..77114b2bd4 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-credit-cards.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-credit-cards.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-prepaid-cards.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-prepaid-cards.html index 17383cb340..f889d916b8 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-prepaid-cards.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/allow-prepaid-cards.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/billing-address-format.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/billing-address-format.html index d383db2552..baf25f0300 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/billing-address-format.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/billing-address-format.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/country-code.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/country-code.html index 18223fd9ef..e475086aa8 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/country-code.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/country-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/currency-code.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/currency-code.html index 25d958ecc5..dac7d90e56 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/currency-code.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/currency-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/get-environment.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/get-environment.html index de7fd72175..659b9cde42 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/get-environment.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/get-environment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/google-merchant-name.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/google-merchant-name.html index ce7a734f85..d0f2458ef7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/google-merchant-name.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/google-merchant-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/index.html index 3114b05656..9c97bafdfe 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-billing-address-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-billing-address-required.html index ae2d082b63..984ebe49ee 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-billing-address-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-billing-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-email-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-email-required.html index 5acf2a911e..7db97c7b62 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-email-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-email-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-pay-pal-enabled.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-pay-pal-enabled.html index 27ddbc87d2..372ccd0d10 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-pay-pal-enabled.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-pay-pal-enabled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-phone-number-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-phone-number-required.html index 3ec2081014..768113897d 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-phone-number-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-phone-number-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-shipping-address-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-shipping-address-required.html index 5c60b256a9..c604f101f5 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-shipping-address-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/is-shipping-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-auth-methods.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-auth-methods.html index 452fba3de0..b7c68cbe69 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-auth-methods.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-auth-methods.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-card-networks.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-card-networks.html index ca2f4bbfdf..fa0f4c5fae 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-card-networks.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-card-networks.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-payment-method.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-payment-method.html index d36c35b3d9..6c10636a64 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-payment-method.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-allowed-payment-method.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-environment.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-environment.html index 802b1a25f5..461a25654f 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-environment.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-environment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-tokenization-specification-for-type.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-tokenization-specification-for-type.html index 1f933e4f18..f6a39a5b5a 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-tokenization-specification-for-type.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/set-tokenization-specification-for-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/shipping-address-parameters.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/shipping-address-parameters.html index e0ece08883..f07979110e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/shipping-address-parameters.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/shipping-address-parameters.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/to-json.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/to-json.html index 064bfc22fe..a5dcff0e98 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/to-json.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-label.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-label.html index 348bb3ebee..c7b46743e6 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-label.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-label.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-status.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-status.html index dc76d0ed31..581d52914a 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-status.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price-status.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price.html index f7350149bf..e0e6fd2306 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-request/total-price.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-cancel/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-cancel/index.html index 22664dc1ce..c2c87100f2 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-cancel/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/error.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/error.html index 2fa76626b3..a647fee94d 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/error.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/index.html index 05189426ce..76178ea82d 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/index.html index 71ce2311fd..289b16c478 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/nonce.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/nonce.html index f8f0cbdfdf..94d417a37a 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/nonce.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/index.html index d472350455..14d8ce007e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/-google-pay-shipping-address-parameters.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/-google-pay-shipping-address-parameters.html index c041658c2b..ad3c8a8c00 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/-google-pay-shipping-address-parameters.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/-google-pay-shipping-address-parameters.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/allowed-country-codes.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/allowed-country-codes.html index 0ab280da6b..334a3596bb 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/allowed-country-codes.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/allowed-country-codes.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/index.html index 377bd3912a..7dc122f0d2 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/is-phone-number-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/is-phone-number-required.html index 80aa07af17..f2f4544e69 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/is-phone-number-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-shipping-address-parameters/is-phone-number-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/error.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/error.html index c7fb8c064f..74b6807b4c 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/error.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/index.html index 90a67251e3..c8dcd7f5f1 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/allowed-card-networks.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/allowed-card-networks.html index 817e05ffb4..e60e43d536 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/allowed-card-networks.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/allowed-card-networks.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/index.html index 9ce7fefecc..0687b48f1a 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/parameters.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/parameters.html index 6a652c20cb..2778b5a065 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/parameters.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/-success/parameters.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/index.html index 1a2e59a26e..705adee931 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenization-parameters/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/index.html index 53d1b9fed5..f524c124a3 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/on-google-pay-result.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/on-google-pay-result.html index 8b56b7aaa2..5f462cb583 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/on-google-pay-result.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-tokenize-callback/on-google-pay-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-e-s-t-i-m-a-t-e-d/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-e-s-t-i-m-a-t-e-d/index.html index 0e23fc2900..91cf7df1f7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-e-s-t-i-m-a-t-e-d/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-e-s-t-i-m-a-t-e-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-f-i-n-a-l/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-f-i-n-a-l/index.html index e21ea418b8..a928333973 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-f-i-n-a-l/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/-t-o-t-a-l_-p-r-i-c-e_-s-t-a-t-u-s_-f-i-n-a-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/entries.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/entries.html index 42f85f945e..2038e79262 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/entries.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/index.html index 32e54efb6f..ea828edc66 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/value-of.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/value-of.html index 76c593607f..53440d27f4 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/value-of.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/values.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/values.html index 9a4fa36a13..502ceef8f7 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/values.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-google-pay-total-price-status/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/-ready-for-google-pay-request.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/-ready-for-google-pay-request.html index 3a739a54ad..a1a3e5d223 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/-ready-for-google-pay-request.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/-ready-for-google-pay-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/index.html index 36d35bffdd..ade154513e 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/is-existing-payment-method-required.html b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/is-existing-payment-method-required.html index 79622b4b7d..020c0dddf6 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/is-existing-payment-method-required.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/-ready-for-google-pay-request/is-existing-payment-method-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/com.braintreepayments.api.googlepay/index.html b/docs/GooglePay/com.braintreepayments.api.googlepay/index.html index 24ede8a17d..d2977cede9 100644 --- a/docs/GooglePay/com.braintreepayments.api.googlepay/index.html +++ b/docs/GooglePay/com.braintreepayments.api.googlepay/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/index.html b/docs/GooglePay/index.html index 1f8174add4..7fe320d9e1 100644 --- a/docs/GooglePay/index.html +++ b/docs/GooglePay/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/GooglePay/navigation.html b/docs/GooglePay/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/GooglePay/navigation.html +++ b/docs/GooglePay/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/index.html index f5bd81b4ef..2c83a6410c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/on-local-payment-auth-request.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/on-local-payment-auth-request.html index 14b7d3dce1..c772dc498d 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/on-local-payment-auth-request.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-callback/on-local-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/approval-url.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/approval-url.html index 075f1be266..4253164d0b 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/approval-url.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/approval-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/browser-switch-options.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/browser-switch-options.html index 36e5cff602..c25893240b 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/browser-switch-options.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/browser-switch-options.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -63,7 +63,7 @@

browserSwitchOptions

-
var browserSwitchOptions: BrowserSwitchOptions?
+
var browserSwitchOptions: BrowserSwitchOptions?
-
5.2.0 +
5.3.0
@@ -62,7 +62,7 @@

LocalPaymentAuthRequestParams

-

Local payment result information.

+

Local payment result information.

@@ -94,7 +94,7 @@

Properties

-
var browserSwitchOptions: BrowserSwitchOptions?
+
var browserSwitchOptions: BrowserSwitchOptions?
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/payment-id.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/payment-id.html index d861bb81d8..b1329b63c0 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/payment-id.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/payment-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/request.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/request.html index ca0447c5c5..dfe1318d94 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/request.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request-params/request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/error.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/error.html index 683dd30138..92da712af0 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/error.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/index.html index 5ab91a77b5..6a394a1f66 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/index.html index fbbcda5ff2..56c639ad89 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/request-params.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/request-params.html index 2df0acf79b..0c193b7fc2 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/index.html index 409d2b1bff..eb7a78f567 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/error.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/error.html index 761c6827fd..da534c3832 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/error.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/index.html index d44c90145d..7e024bf6f1 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-no-result/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-no-result/index.html index ab8678f9a8..8716839283 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-no-result/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-no-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-success/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-success/index.html index c9e28e40f1..b6489a6b6b 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-success/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/index.html index dfde9845ff..8319ba722f 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-companion/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-companion/index.html index b1a1eca4eb..a495b3312f 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-companion/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-local-payment-client.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-local-payment-client.html index 50c6bd4f1d..1068b2e2bf 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-local-payment-client.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/-local-payment-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/build-browser-switch-options.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/build-browser-switch-options.html index 23cb9d080c..11f9b83621 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/build-browser-switch-options.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/build-browser-switch-options.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/create-payment-auth-request.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/create-payment-auth-request.html index 35d6efd42e..8329971ea3 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/create-payment-auth-request.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/create-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/index.html index 556d05fd80..44587b53a5 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/tokenize.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/tokenize.html index 5f25e4909c..adcbc283e2 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/tokenize.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/-local-payment-launcher.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/-local-payment-launcher.html index 209fa0779a..467cdb9aad 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/-local-payment-launcher.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/-local-payment-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/handle-return-to-app.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/handle-return-to-app.html index 0e80f5df51..8b776fea8c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/handle-return-to-app.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/handle-return-to-app.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/index.html index 7bfaf3f2fa..8508a480bc 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/launch.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/launch.html index 46e06c839c..b37aa902c1 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/launch.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/from-j-s-o-n.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/from-j-s-o-n.html index 260fd9b925..c7feb11969 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/from-j-s-o-n.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/index.html index fd98082ead..42ef6766d3 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/billing-address.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/billing-address.html index 1c3cf97f25..9448481d0b 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/billing-address.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/client-metadata-id.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/client-metadata-id.html index a00edea4f8..1cbf6704b9 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/client-metadata-id.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/client-metadata-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/email.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/email.html index 58e5932f7d..d46e838c7c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/email.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/given-name.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/given-name.html index 949b28025b..af588035c4 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/given-name.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/given-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/index.html index 9d533b1bbd..8c2c401acd 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/is-default.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/is-default.html index fb5916b06b..7aa19ffe83 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/is-default.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/payer-id.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/payer-id.html index 4cb27b61af..6d54db0fd9 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/payer-id.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/payer-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/phone.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/phone.html index ca45e8d860..1ea69445f4 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/phone.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/phone.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/shipping-address.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/shipping-address.html index fda62aad63..a49855843d 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/shipping-address.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/string.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/string.html index 704e396c97..e786d1eae8 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/string.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/surname.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/surname.html index a6cf53c0ab..05bf06c57c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/surname.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-nonce/surname.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/error.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/error.html index d870fdb437..c1a75e9c18 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/error.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/index.html index 85f5233354..632ae6551f 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/-started.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/-started.html index f3b238a24c..4367ea6019 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/-started.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/-started.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/index.html index 8c247270ba..3b3958948c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/pending-request-string.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/pending-request-string.html index ebec02f176..05cf4ca185 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/pending-request-string.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/-started/pending-request-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/index.html index e43575d7db..825393a371 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-pending-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-companion/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-companion/index.html index e1d36ee575..ba09838272 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-companion/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-local-payment-request.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-local-payment-request.html index 02eeef8c29..bcbf56e7e9 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-local-payment-request.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/-local-payment-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/address.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/address.html index f73d49d94f..8dce4c93c9 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/address.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/amount.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/amount.html index d30219125f..a31d80261b 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/amount.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/bank-identification-code.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/bank-identification-code.html index d1d2eb9b60..6ae320d3ac 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/bank-identification-code.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/bank-identification-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/currency-code.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/currency-code.html index 81824ddf1c..9754d04119 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/currency-code.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/currency-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/display-name.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/display-name.html index 58b428286b..23bc5b7e85 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/display-name.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/display-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/email.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/email.html index 96defaf86d..b7c5dda6d4 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/email.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/given-name.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/given-name.html index 7efe61fc83..469202f038 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/given-name.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/given-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/has-user-location-consent.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/has-user-location-consent.html index 96aa73cd57..097b4f8166 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/has-user-location-consent.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/index.html index ddf33d53e0..d47ad646cd 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/is-shipping-address-required.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/is-shipping-address-required.html index 3e154b4cd1..4fb80da497 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/is-shipping-address-required.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/is-shipping-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/merchant-account-id.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/merchant-account-id.html index 6ff0c5974e..b1716efc39 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/merchant-account-id.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type-country-code.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type-country-code.html index 9cddf4f254..6ece7f57cc 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type-country-code.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type-country-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type.html index c0eb9e679b..297e4eead6 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/payment-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/phone.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/phone.html index b252a44d5a..e1e35f13ce 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/phone.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/phone.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/surname.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/surname.html index a3f9226fdf..32bf0d7b9c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/surname.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-request/surname.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-cancel/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-cancel/index.html index e3dff558b6..98f7ec9666 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-cancel/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/error.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/error.html index 0388ccccac..5c0c3b31a3 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/error.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/index.html index 1d83227ff9..4306f7448c 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/index.html index 94e8cc0820..ac4cafa752 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/nonce.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/nonce.html index 091b9a02a5..47ddd6e052 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/nonce.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/index.html index 4f19c14f6d..1413c9fc79 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/index.html index c54ccb02ff..01167b4f6f 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/on-local-payment-result.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/on-local-payment-result.html index 39df9846c1..9fde5a0b93 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/on-local-payment-result.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/-local-payment-tokenize-callback/on-local-payment-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/com.braintreepayments.api.localpayment/index.html b/docs/LocalPayment/com.braintreepayments.api.localpayment/index.html index 81ebe4389f..0161ee43b5 100644 --- a/docs/LocalPayment/com.braintreepayments.api.localpayment/index.html +++ b/docs/LocalPayment/com.braintreepayments.api.localpayment/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -108,7 +108,7 @@

Types

-

Local payment result information.

+

Local payment result information.

diff --git a/docs/LocalPayment/index.html b/docs/LocalPayment/index.html index 6043e5f048..9e3ee7a88a 100644 --- a/docs/LocalPayment/index.html +++ b/docs/LocalPayment/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/LocalPayment/navigation.html b/docs/LocalPayment/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/LocalPayment/navigation.html +++ b/docs/LocalPayment/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html index df2a604df5..82f7238fa6 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/-a-p-i_-r-e-s-o-u-r-c-e_-k-e-y.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/from-j-s-o-n.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/from-j-s-o-n.html index 89323e6d3a..4e3b58c8ea 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/from-j-s-o-n.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/index.html index 0f5d252f89..873e994be8 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/authenticate-url.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/authenticate-url.html index 9554565fdd..80c64534e3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/authenticate-url.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/authenticate-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/billing-address.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/billing-address.html index eae7df2519..9dd37a1dd7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/billing-address.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/client-metadata-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/client-metadata-id.html index 2971c733f2..31fc9efb42 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/client-metadata-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/client-metadata-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/credit-financing.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/credit-financing.html index 294e2c065a..a1898e567f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/credit-financing.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/credit-financing.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/email.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/email.html index 11f1a98ed4..73228c9e03 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/email.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/first-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/first-name.html index 41ed1b789b..4b40b98746 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/first-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/first-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/index.html index 041cf64cd3..3cfeedcf1b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/is-default.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/is-default.html index 745f53023a..089d05eab7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/is-default.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/last-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/last-name.html index 34880aeadb..2d449087ea 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/last-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/last-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/payer-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/payer-id.html index 2c9ae7c256..1c1d8244dc 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/payer-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/payer-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/phone.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/phone.html index 998afb1fe1..fead620c54 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/phone.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/phone.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/shipping-address.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/shipping-address.html index d4169602c7..5664918b64 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/shipping-address.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/string.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/string.html index 30ab702281..1ba6cb597f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/string.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-account-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-companion/index.html index 3d17b8dfd4..5fba31b0a0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-pay-pal-billing-cycle.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-pay-pal-billing-cycle.html index 809d65ee1a..fa57e891c0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-pay-pal-billing-cycle.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/-pay-pal-billing-cycle.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/index.html index a7460ac9a2..d4daf40590 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval-count.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval-count.html index f8e680af66..d9475b8d05 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval-count.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval-count.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval.html index 05bdffcb2a..053250ca0b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/interval.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/is-trial.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/is-trial.html index 0c1e13e766..ab1adf1335 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/is-trial.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/is-trial.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/number-of-executions.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/number-of-executions.html index 305adac081..3cf4c99a68 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/number-of-executions.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/number-of-executions.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/pricing.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/pricing.html index 606b0da321..358303cd89 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/pricing.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/pricing.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/sequence.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/sequence.html index c5be4bb752..dc3e392d5a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/sequence.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/sequence.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/start-date.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/start-date.html index 4578ac0505..52066ba52a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/start-date.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/start-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/to-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/to-json.html index f02fb9c00f..ab4b0ab76c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/to-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-cycle/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-d-a-y/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-d-a-y/index.html index bbdc6b94b5..34ce01073a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-d-a-y/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-d-a-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-m-o-n-t-h/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-m-o-n-t-h/index.html index 8a8971424f..f48a70425d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-m-o-n-t-h/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-m-o-n-t-h/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-w-e-e-k/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-w-e-e-k/index.html index df8afba62e..618c07dff6 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-w-e-e-k/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-w-e-e-k/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-y-e-a-r/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-y-e-a-r/index.html index 6282a4ae45..6c76412faf 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-y-e-a-r/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/-y-e-a-r/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/entries.html index fb78573da1..37853032e9 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/index.html index 24a2fe3c6d..bfdd3860a7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/value-of.html index 3fb1cfb3d5..47abbe467d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/values.html index 424d850697..4a63f0129b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-interval/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-companion/index.html index 5a221e77ac..850630edee 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-pay-pal-billing-pricing.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-pay-pal-billing-pricing.html index 5622f35484..0d1616fdef 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-pay-pal-billing-pricing.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/-pay-pal-billing-pricing.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/amount.html index d337f29322..33a28608ee 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/index.html index 2e3465dd23..a9bdc5ebd4 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/pricing-model.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/pricing-model.html index a602350f57..98dbe51752 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/pricing-model.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/pricing-model.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/reload-threshold-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/reload-threshold-amount.html index 05c453a0b3..88305982f8 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/reload-threshold-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/reload-threshold-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/to-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/to-json.html index 5e814f82f2..a142f9a340 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/to-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-billing-pricing/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-browser-switch-exception/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-browser-switch-exception/index.html index b9d53f2061..e6d16c132a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-browser-switch-exception/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-browser-switch-exception/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -62,7 +62,7 @@

PayPalBrowserSwitchException

-

Exception for whenever the browser has returned an 'error' in its response.

+

Exception for whenever the browser has returned an 'error' in its response.

@@ -158,7 +158,7 @@

Functions

@@ -203,7 +203,7 @@

Functions

@@ -218,7 +218,7 @@

Functions

diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/-pay-pal-checkout-request.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/-pay-pal-checkout-request.html index 30af272b76..0df8bb7e30 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/-pay-pal-checkout-request.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/-pay-pal-checkout-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/amount.html index d63fe17101..0612f2eeea 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/billing-agreement-description.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/billing-agreement-description.html index 6eccdcbd26..f6e01fabc9 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/billing-agreement-description.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/billing-agreement-description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/create-request-body.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/create-request-body.html index 4849ec38ea..c3a357cbf4 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/create-request-body.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/create-request-body.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/currency-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/currency-code.html index d4e9c38830..478bf0a315 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/currency-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/currency-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/display-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/display-name.html index 6ff12b15d4..1ddd9e88cd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/display-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/display-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/has-user-location-consent.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/has-user-location-consent.html index bd6b0a2717..4458b7e62e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/has-user-location-consent.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/index.html index ed6586a984..76ea87845b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/intent.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/intent.html index af072f1bf6..4933a75742 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/intent.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/intent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-editable.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-editable.html index e2eae3db56..3e8ccbc18c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-editable.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-editable.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-required.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-required.html index 2784afe4fd..0d7f3de7b2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-required.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/is-shipping-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/landing-page-type.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/landing-page-type.html index 5e9859d75a..6e86ee9910 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/landing-page-type.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/landing-page-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/line-items.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/line-items.html index 98d9065ca8..204e3829c0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/line-items.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/line-items.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/locale-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/locale-code.html index 80090782a2..cdae357eae 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/locale-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/locale-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/merchant-account-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/merchant-account-id.html index 6e935b6253..08874b1320 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/merchant-account-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/risk-correlation-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/risk-correlation-id.html index e2a57c7ac4..6f7a2b539e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/risk-correlation-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/risk-correlation-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/shipping-address-override.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/shipping-address-override.html index 1ae6cff7fd..ea80a05ae8 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/shipping-address-override.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/shipping-address-override.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-offer-pay-later.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-offer-pay-later.html index 57b5aac44b..17249e933b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-offer-pay-later.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-offer-pay-later.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-request-billing-agreement.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-request-billing-agreement.html index bf034a9170..1c68980a94 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-request-billing-agreement.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/should-request-billing-agreement.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-action.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-action.html index 9389807505..23ef11c345 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-action.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-action.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-authentication-email.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-authentication-email.html index 95fdd01d5f..5e0d5de47d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-authentication-email.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-authentication-email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-phone-number.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-phone-number.html index c5acf5205a..b467f0365a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-phone-number.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-checkout-request/user-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-companion/index.html index 16378c697d..8edc43c37b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-pay-pal-client.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-pay-pal-client.html index bd3ba45514..2396f1a5a1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-pay-pal-client.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/-pay-pal-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -58,12 +58,12 @@
-
+

PayPalClient

-
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri)

Initializes a new PayPalClient instance

Parameters

context

an Android Context

authorization

a Tokenization Key or Client Token used to authenticate

appLinkReturnUrl

A Uri containing the Android App Link website associated with your application to be used to return to your app from the PayPal payment flows.

+
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri, deepLinkFallbackUrlScheme: String? = null)

Initializes a new PayPalClient instance

Parameters

context

an Android Context

authorization

a Tokenization Key or Client Token used to authenticate

appLinkReturnUrl

A Uri containing the Android App Link website associated with your application to be used to return to your app from the PayPal payment flows.

deepLinkFallbackUrlScheme

A return url scheme that will be used as a deep link fallback when returning to your app via App Link is not available (buyer unchecks the "Open supported links" setting).

-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/index.html index 44bbf547e3..0bb7feb83b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -69,17 +69,17 @@

PayPalClient

Constructors

-
+
- +
Link copied to clipboard
-
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri)

Initializes a new PayPalClient instance

+
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri, deepLinkFallbackUrlScheme: String? = null)

Initializes a new PayPalClient instance

diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/tokenize.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/tokenize.html index 4195cc85f0..a104b8bf63 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/tokenize.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/from-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/from-json.html index 41e641187f..640eca120a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/from-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/index.html index f05836e68f..2b570c2c5c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/currency.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/currency.html index a2e6e44518..843589e6d0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/currency.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/currency.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/index.html index b93bee939c..e2d67d05b0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/value.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/value.html index 750140fb4a..0c0067263c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/value.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing-amount/value.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/from-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/from-json.html index 814af383fc..f356aa5405 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/from-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/index.html index bae055eba6..1aa41bacca 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/has-payer-acceptance.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/has-payer-acceptance.html index d7ed50465d..da357b64b3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/has-payer-acceptance.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/has-payer-acceptance.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/index.html index 6b30f549c3..8dc3b64bdc 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/is-card-amount-immutable.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/is-card-amount-immutable.html index 1d9a2edd7b..46fc6cf3c6 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/is-card-amount-immutable.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/is-card-amount-immutable.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/monthly-payment.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/monthly-payment.html index 6363bc26ee..9e3b7ef7aa 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/monthly-payment.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/monthly-payment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/term.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/term.html index b69c4bf17f..66a59a2565 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/term.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/term.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-cost.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-cost.html index bfa45d7058..effd9d6ce9 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-cost.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-cost.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-interest.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-interest.html index 140b73e45b..f0026c21c0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-interest.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-credit-financing/total-interest.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-b-i-l-l-i-n-g/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-b-i-l-l-i-n-g/index.html index 4466664a2c..c309058213 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-b-i-l-l-i-n-g/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-b-i-l-l-i-n-g/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-l-o-g-i-n/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-l-o-g-i-n/index.html index bdab8a9b3b..350da0cc89 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-l-o-g-i-n/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/-l-a-n-d-i-n-g_-p-a-g-e_-t-y-p-e_-l-o-g-i-n/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/entries.html index 73b5438f04..0acb2d17e1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/index.html index b5388629e9..273ebdb9be 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/string-value.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/string-value.html index 1e5bc2dc84..e1c0a374fd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/string-value.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/string-value.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/value-of.html index 7b97d711f4..493f904fd3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/values.html index a50c441bb2..1ca88c9058 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-landing-page-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-companion/index.html index 20aa131425..e97a4c5d23 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-pay-pal-launcher.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-pay-pal-launcher.html index e0f6b9f589..5b3ff89683 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-pay-pal-launcher.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/-pay-pal-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/handle-return-to-app.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/handle-return-to-app.html index 8256f4d068..5b1438692a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/handle-return-to-app.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/handle-return-to-app.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/index.html index 2412dd1f62..1d426277a2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/launch.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/launch.html index 1df6bd3519..63026022d5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/launch.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-c-r-e-d-i-t/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-c-r-e-d-i-t/index.html index e3f22d47b2..0e0870472c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-c-r-e-d-i-t/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-c-r-e-d-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-d-e-b-i-t/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-d-e-b-i-t/index.html index be23f88358..2e38f39e17 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-d-e-b-i-t/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/-d-e-b-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/entries.html index 52e3aada9f..70aabf1e5a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/index.html index 740cd30b8b..b1ed3fdc0f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/value-of.html index 79fef51724..3c796ffb22 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/values.html index 26970bc76c..cc74999b20 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-kind/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-a/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-a/index.html index 3beb1adfa8..e0ae8b7ebc 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-a/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-a/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-b/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-b/index.html index 3fc0581599..6a724bd836 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-b/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-b/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-c/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-c/index.html index d11200b3c6..df3ae9fbdd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-c/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-c/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-d/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-d/index.html index c5bd9bcdf2..619d35e470 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-d/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-e/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-e/index.html index dffee5569e..249303cbb5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-e/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_2/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_2/index.html index 6d956ca548..f797acc514 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_2/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_2/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_5/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_5/index.html index 23d0ccc3ba..72471e0e45 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_5/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/-u-p-c_-t-y-p-e_5/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/entries.html index 2622b1c218..f9d2145531 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/index.html index ea4ccff9fc..90d2216708 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/value-of.html index 48bc618632..a2358b5059 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/values.html index 663a05d36b..5007bdbcc4 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item-upc-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-companion/index.html index e57717359f..8d607ea2a1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-pay-pal-line-item.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-pay-pal-line-item.html index 8b71b0f9ca..317889b63f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-pay-pal-line-item.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/-pay-pal-line-item.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/description.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/description.html index 51a2487f0d..185fcc0dc8 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/description.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/image-url.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/image-url.html index 372454eb6c..4af339a3e4 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/image-url.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/image-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/index.html index b035deb0f3..ab5677dddb 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/kind.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/kind.html index 7594960e55..b7f5d50d1b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/kind.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/kind.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/name.html index ba7d4ae209..a0ec339bd1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/product-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/product-code.html index 6ff459b327..681f51957f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/product-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/product-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/quantity.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/quantity.html index d8c7f6b88e..c3b5d9c604 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/quantity.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/quantity.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/to-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/to-json.html index 78467e8569..890a9bb415 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/to-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-amount.html index 81abf6644b..60b4ed2bbf 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-tax-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-tax-amount.html index 74206b8391..458fa6f202 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-tax-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/unit-tax-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-code.html index 7686461cea..bd83696886 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-type.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-type.html index 43719ace09..8034acadcf 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-type.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/upc-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/url.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/url.html index 19c64f08c2..188150a81d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/url.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-line-item/url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/index.html index 981377ab8a..90cd933b19 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/on-pay-pal-payment-auth-request.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/on-pay-pal-payment-auth-request.html index b410ddb717..7a9f2b0f1f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/on-pay-pal-payment-auth-request.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-callback/on-pay-pal-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/approval-url.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/approval-url.html index 4761c09dac..0ee3462dff 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/approval-url.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/approval-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/browser-switch-options.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/browser-switch-options.html index a1b51f0864..2595aaaa52 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/browser-switch-options.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/browser-switch-options.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/client-metadata-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/client-metadata-id.html index f92047fb6b..1ad9eeb88b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/client-metadata-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/client-metadata-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/index.html index 3dc772025c..77d8658713 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/intent.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/intent.html index af7a68cab1..cecc4c22d5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/intent.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/intent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/is-billing-agreement.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/is-billing-agreement.html index 1209fb37b2..d8c80487b8 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/is-billing-agreement.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/is-billing-agreement.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/merchant-account-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/merchant-account-id.html index 94d473cf47..1f21eea406 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/merchant-account-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/pairing-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/pairing-id.html index ad3eab6769..17ed2c4997 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/pairing-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/pairing-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/success-url.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/success-url.html index a3ed2f264c..28106bb04c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/success-url.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request-params/success-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/error.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/error.html index 1b6de6744b..a016894b7a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/error.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/index.html index 48b5412f6a..a09fdd783e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/index.html index 5d0151c0cf..668a8141b1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/request-params.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/request-params.html index 0ef173cc23..472fc37998 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/index.html index b8a3902341..b59ea9940f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/error.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/error.html index fc7de457ab..9e43b7fd64 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/error.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/index.html index b5417a337c..5a1dc7017d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-no-result/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-no-result/index.html index 7816432b74..39a0a00cca 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-no-result/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-no-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-success/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-success/index.html index 67185f6b60..a3389557fd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-success/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/index.html index a01cf41e6c..c38bc00408 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-a-u-t-h-o-r-i-z-e/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-a-u-t-h-o-r-i-z-e/index.html index b3f4c2ff01..4f08603e3c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-a-u-t-h-o-r-i-z-e/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-a-u-t-h-o-r-i-z-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/from-string.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/from-string.html index 220272b461..0668cbebad 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/from-string.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/from-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/index.html index 9e7bad5db2..3e6d0c6187 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-o-r-d-e-r/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-o-r-d-e-r/index.html index cd985d5b6e..74dc7213e0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-o-r-d-e-r/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-o-r-d-e-r/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-s-a-l-e/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-s-a-l-e/index.html index 30da85990e..f83af3b2a2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-s-a-l-e/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/-s-a-l-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/entries.html index 2abc561f4c..3d0097ef0e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/index.html index bc2713adf9..a307d8e9e3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/value-of.html index 16f662096d..d7907a290f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/values.html index 426105c9c4..765183c10b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-intent/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-c-o-m-m-i-t/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-c-o-m-m-i-t/index.html index 060d463392..b759ef07c5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-c-o-m-m-i-t/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-c-o-m-m-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-d-e-f-a-u-l-t/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-d-e-f-a-u-l-t/index.html index 59066d04a4..0e80b38bf5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-d-e-f-a-u-l-t/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/-u-s-e-r_-a-c-t-i-o-n_-d-e-f-a-u-l-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/entries.html index 8485724815..251531f938 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/index.html index 93b0583ba5..3c75e061ba 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/value-of.html index 2f07f2ebc2..d6c3d61b61 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/values.html index 1d54a208b0..cf4e38eaf4 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-payment-user-action/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/error.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/error.html index 9c31742c21..0b96a188a6 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/error.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/index.html index a61ae723b9..c6d88db42e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/-started.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/-started.html index 1296690470..5109067f46 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/-started.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/-started.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/index.html index c828d6f2ee..a24a3140d1 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/pending-request-string.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/pending-request-string.html index dcec635ae0..0c2ee374da 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/pending-request-string.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/-started/pending-request-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/index.html index f29d62e08c..5603d06006 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pending-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-companion/index.html index 0e0db47b43..e27e9869b7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-pay-pal-phone-number.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-pay-pal-phone-number.html index 45408ce7aa..b34c03a8ff 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-pay-pal-phone-number.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/-pay-pal-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/country-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/country-code.html index 6142c71312..01e3bf5842 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/country-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/country-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/index.html index c31860abfb..2aa22d5efb 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/national-number.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/national-number.html index fa408a1758..7c0dc07402 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/national-number.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-phone-number/national-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-a-u-t-o_-r-e-l-o-a-d/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-a-u-t-o_-r-e-l-o-a-d/index.html index 1eeb04468c..d3aecffe90 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-a-u-t-o_-r-e-l-o-a-d/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-a-u-t-o_-r-e-l-o-a-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-f-i-x-e-d/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-f-i-x-e-d/index.html index d39c1db766..8ec2c893ec 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-f-i-x-e-d/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-f-i-x-e-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-v-a-r-i-a-b-l-e/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-v-a-r-i-a-b-l-e/index.html index 700eff1f2b..a241110e16 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-v-a-r-i-a-b-l-e/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/-v-a-r-i-a-b-l-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/entries.html index deed8b18bf..f22532a139 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/index.html index 66bd18ffcb..b658113009 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/value-of.html index 599ef342da..452401f41b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/values.html index a75f560542..2f62e8a367 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-pricing-model/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-companion/index.html index 7ffbf8628f..4ca2101372 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-pay-pal-recurring-billing-details.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-pay-pal-recurring-billing-details.html index 6914a4bbfd..e4d0d5c99e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-pay-pal-recurring-billing-details.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/-pay-pal-recurring-billing-details.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/billing-cycles.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/billing-cycles.html index 785d7de066..92c25610fa 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/billing-cycles.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/billing-cycles.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/currency-i-s-o-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/currency-i-s-o-code.html index 17f5124126..ef4b0c41dd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/currency-i-s-o-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/currency-i-s-o-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/index.html index 946923cc3e..847f897018 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/one-time-fee-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/one-time-fee-amount.html index 09f0235664..9f5b7e000c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/one-time-fee-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/one-time-fee-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-amount.html index 1526399249..0bf8b4a3d3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-description.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-description.html index 0a4d0f2c54..cf8f2f0933 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-description.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-name.html index fc5ee91189..4957f13603 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-quantity.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-quantity.html index 1b327feef9..859b60d34d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-quantity.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/product-quantity.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/shipping-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/shipping-amount.html index 0cef44110c..c97313ed03 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/shipping-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/shipping-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/tax-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/tax-amount.html index 6c94cabdcb..76af16e28b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/tax-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/tax-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/to-json.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/to-json.html index e8b42d2851..2f2ab1725e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/to-json.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/total-amount.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/total-amount.html index 3bbb0e54d0..a979552515 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/total-amount.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-details/total-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-i-n-s-t-a-l-l-m-e-n-t/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-i-n-s-t-a-l-l-m-e-n-t/index.html index ee4df959d6..d45f199372 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-i-n-s-t-a-l-l-m-e-n-t/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-i-n-s-t-a-l-l-m-e-n-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-r-e-c-u-r-r-i-n-g/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-r-e-c-u-r-r-i-n-g/index.html index fd222b3767..e63689cb32 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-r-e-c-u-r-r-i-n-g/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-r-e-c-u-r-r-i-n-g/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-s-u-b-s-c-r-i-p-t-i-o-n/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-s-u-b-s-c-r-i-p-t-i-o-n/index.html index 4b78801819..15943f4831 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-s-u-b-s-c-r-i-p-t-i-o-n/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-s-u-b-s-c-r-i-p-t-i-o-n/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-u-n-s-c-h-e-d-u-l-e-d/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-u-n-s-c-h-e-d-u-l-e-d/index.html index 64794ee6d2..4089b7fea2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-u-n-s-c-h-e-d-u-l-e-d/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/-u-n-s-c-h-e-d-u-l-e-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/entries.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/entries.html index ab3eb95f10..f0253f31e6 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/entries.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/index.html index 695e0f52df..c048cd9bc5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/value-of.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/value-of.html index 01606799cb..8bc288330b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/value-of.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/values.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/values.html index 6bf8ce3763..2a1e98673b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/values.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-recurring-billing-plan-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/-companion/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/-companion/index.html index dc6ff51833..6fc9685fdc 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/-companion/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/billing-agreement-description.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/billing-agreement-description.html index c8f25c58f3..5b9ac227df 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/billing-agreement-description.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/billing-agreement-description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/create-request-body.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/create-request-body.html index 000bafa442..f45fdf5c43 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/create-request-body.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/create-request-body.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/display-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/display-name.html index 47950324e6..01189ba417 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/display-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/display-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/has-user-location-consent.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/has-user-location-consent.html index 49bc161855..48701611aa 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/has-user-location-consent.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/index.html index 289b1a580a..d29e36f8a2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-editable.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-editable.html index a5971b164c..9b4898ebea 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-editable.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-editable.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-required.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-required.html index 9c27253a81..8ef8afa50f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-required.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/is-shipping-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/landing-page-type.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/landing-page-type.html index 9d97a8071d..49ddb7b21c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/landing-page-type.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/landing-page-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/line-items.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/line-items.html index 5b879d5b15..14813adb2e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/line-items.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/line-items.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/locale-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/locale-code.html index 558c9e1e6a..110692ae05 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/locale-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/locale-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/merchant-account-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/merchant-account-id.html index 4579dbd7a7..39b5a23c50 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/merchant-account-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/risk-correlation-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/risk-correlation-id.html index 84bd2e36a6..b7a0fea07b 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/risk-correlation-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/risk-correlation-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/shipping-address-override.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/shipping-address-override.html index 91dad37a49..4e51fe050d 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/shipping-address-override.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/shipping-address-override.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-authentication-email.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-authentication-email.html index f24c6a95df..dbe5bb5bba 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-authentication-email.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-authentication-email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-phone-number.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-phone-number.html index 71c5ec5c2a..615e3c95cd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-phone-number.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-request/user-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-cancel/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-cancel/index.html index 93f762c425..888f5b159a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-cancel/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/error.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/error.html index e6837f18cf..6abb1b0a4a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/error.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/index.html index 823592011d..9e5c443b6e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/index.html index 42d85c262c..d3c2c987b7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/nonce.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/nonce.html index 98e2bae586..be57f59441 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/nonce.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/index.html index 91dc86b292..e749ba62c7 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/index.html index 434c237d23..c373802aa2 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/on-pay-pal-result.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/on-pay-pal-result.html index 79c5ce04f6..60f1572637 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/on-pay-pal-result.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-tokenize-callback/on-pay-pal-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/-pay-pal-vault-request.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/-pay-pal-vault-request.html index a29a01cc05..2a498a6335 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/-pay-pal-vault-request.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/-pay-pal-vault-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/billing-agreement-description.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/billing-agreement-description.html index 98ff048312..7644ca1c23 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/billing-agreement-description.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/billing-agreement-description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/create-request-body.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/create-request-body.html index 523b3c3222..62a29a8b70 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/create-request-body.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/create-request-body.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/display-name.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/display-name.html index cbd1249d68..d8ba6b6bba 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/display-name.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/display-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/enable-pay-pal-app-switch.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/enable-pay-pal-app-switch.html index 6755f21015..102b06e158 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/enable-pay-pal-app-switch.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/enable-pay-pal-app-switch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/has-user-location-consent.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/has-user-location-consent.html index 35aba253c6..134445c26f 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/has-user-location-consent.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/has-user-location-consent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/index.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/index.html index 6bf359c4d6..d93438f7a3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-editable.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-editable.html index 4fc0e9a70c..6c624255a3 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-editable.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-editable.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-required.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-required.html index 3ea3e49cdd..085f134546 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-required.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/is-shipping-address-required.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/landing-page-type.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/landing-page-type.html index cf5d35a4b6..9bd6852afd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/landing-page-type.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/landing-page-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/line-items.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/line-items.html index adcb848a39..49fd8c1f75 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/line-items.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/line-items.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/locale-code.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/locale-code.html index 845f2ea67b..2ca20381b0 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/locale-code.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/locale-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/merchant-account-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/merchant-account-id.html index af00495d34..7255b61737 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/merchant-account-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-details.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-details.html index 1f96df614e..ec69b6fe57 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-details.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-details.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-plan-type.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-plan-type.html index cb20d619ed..e465acaa8c 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-plan-type.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/recurring-billing-plan-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/risk-correlation-id.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/risk-correlation-id.html index 70c42b7557..3e0221f7b5 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/risk-correlation-id.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/risk-correlation-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/shipping-address-override.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/shipping-address-override.html index 1598279d35..6833c9277e 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/shipping-address-override.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/shipping-address-override.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/should-offer-credit.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/should-offer-credit.html index 347c79f332..fcae0b0529 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/should-offer-credit.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/should-offer-credit.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-authentication-email.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-authentication-email.html index fc858e5b4e..f8390f8000 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-authentication-email.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-authentication-email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-phone-number.html b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-phone-number.html index 3a2b7989c8..432352b48a 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-phone-number.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/-pay-pal-vault-request/user-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/com.braintreepayments.api.paypal/index.html b/docs/PayPal/com.braintreepayments.api.paypal/index.html index b3e2d52afa..5c28fa43dd 100644 --- a/docs/PayPal/com.braintreepayments.api.paypal/index.html +++ b/docs/PayPal/com.braintreepayments.api.paypal/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -138,7 +138,7 @@

Types

-

Exception for whenever the browser has returned an 'error' in its response.

+

Exception for whenever the browser has returned an 'error' in its response.

diff --git a/docs/PayPal/index.html b/docs/PayPal/index.html index ba7c2baa38..c6ecac89a6 100644 --- a/docs/PayPal/index.html +++ b/docs/PayPal/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/PayPal/navigation.html b/docs/PayPal/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/PayPal/navigation.html +++ b/docs/PayPal/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/approval-url.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/approval-url.html index ac8ca3dc5c..39c41fdbc3 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/approval-url.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/approval-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/bank-reference-token.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/bank-reference-token.html index a107ea7260..3655692675 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/bank-reference-token.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/bank-reference-token.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/customer-id.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/customer-id.html index 0bc20e85da..0eb356299e 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/customer-id.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/customer-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/iban-last-four.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/iban-last-four.html index 3795e1ec24..01548e8eb8 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/iban-last-four.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/iban-last-four.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/index.html index 9731c7f5ae..2e757cd76a 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/mandate-type.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/mandate-type.html index df17d3808b..02f8de4730 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/mandate-type.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-create-mandate-result/mandate-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-companion/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-companion/index.html index c033e99863..9cba45e224 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-companion/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-s-e-p-a-direct-debit-client.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-s-e-p-a-direct-debit-client.html index 6b4ae38356..2e60077817 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-s-e-p-a-direct-debit-client.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/-s-e-p-a-direct-debit-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/create-payment-auth-request.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/create-payment-auth-request.html index a46505a240..dbd010b4fc 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/create-payment-auth-request.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/create-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/index.html index 29a75e31b3..84ff60e424 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/tokenize.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/tokenize.html index ec1110a381..dc2ad0af39 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/tokenize.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/-s-e-p-a-direct-debit-launcher.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/-s-e-p-a-direct-debit-launcher.html index eb4020706a..f7fffefa98 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/-s-e-p-a-direct-debit-launcher.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/-s-e-p-a-direct-debit-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/handle-return-to-app.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/handle-return-to-app.html index d99856c6c2..6cb63a0a74 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/handle-return-to-app.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/handle-return-to-app.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/index.html index d63cca1e81..532d45feec 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/launch.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/launch.html index b8bfc9e7da..7f3510dfb5 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/launch.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-o-n-e_-o-f-f/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-o-n-e_-o-f-f/index.html index 38609add49..9ccbe4e856 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-o-n-e_-o-f-f/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-o-n-e_-o-f-f/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-r-e-c-u-r-r-e-n-t/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-r-e-c-u-r-r-e-n-t/index.html index a3379a8a3d..81884d629c 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-r-e-c-u-r-r-e-n-t/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/-r-e-c-u-r-r-e-n-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/entries.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/entries.html index c424cc6141..ea13e359d8 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/entries.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/index.html index 9898becaa8..e77d4a5062 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/value-of.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/value-of.html index cd937601a5..f6e51f3093 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/value-of.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/values.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/values.html index 08426b52da..dfd22bea6d 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/values.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-mandate-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/from-j-s-o-n.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/from-j-s-o-n.html index 05be1ba334..c4793fc900 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/from-j-s-o-n.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/index.html index c6a0dbfed4..0856d4e18e 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/customer-id.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/customer-id.html index dccacb3932..80bc2784ff 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/customer-id.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/customer-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/iban-last-four.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/iban-last-four.html index bf90a4752a..ef2af9381a 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/iban-last-four.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/iban-last-four.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/index.html index 9fa00cbc60..e5f68e12aa 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/is-default.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/is-default.html index f147a7e8a3..331d97fd7e 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/is-default.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/mandate-type.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/mandate-type.html index 4f5ffc8392..1fa4f86a9c 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/mandate-type.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/mandate-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/string.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/string.html index 09c7d106f6..7cec13bb61 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/string.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/index.html index b4035db974..e20f343c8d 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/on-s-e-p-a-direct-debit-payment-auth-result.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/on-s-e-p-a-direct-debit-payment-auth-result.html index 4347814d04..5ec97e5faf 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/on-s-e-p-a-direct-debit-payment-auth-result.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-callback/on-s-e-p-a-direct-debit-payment-auth-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/browser-switch-options.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/browser-switch-options.html index 46e604de7e..874ecda509 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/browser-switch-options.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/browser-switch-options.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/index.html index 34efaa6e7e..4c304e2a9b 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/error.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/error.html index 5332870bbf..6b5af5d070 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/error.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/index.html index 4ad126de59..c3b49e1400 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/index.html index b0cf50c64d..f487a2c187 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/nonce.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/nonce.html index 4bcf966e65..9cd08add48 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/nonce.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-launch-not-required/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/index.html index 94a0310045..674fdf0399 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/request-params.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/request-params.html index 4df5770f0e..06a84a20ae 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/index.html index 101f914854..1870c9bb8e 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/error.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/error.html index 43b0df4f61..6a53abc760 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/error.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/index.html index 3f2c0358d6..a5ed8b2bbc 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-no-result/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-no-result/index.html index b56f1e1c43..523100c894 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-no-result/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-no-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-success/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-success/index.html index 7bfa0c8ab4..639de23eec 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-success/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/index.html index b61758415d..f319fbcb53 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/error.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/error.html index 5095308d4e..ae0c9ed330 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/error.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/index.html index d8c70bcabc..87db233823 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/-started.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/-started.html index c89091c477..ce5f27bf90 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/-started.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/-started.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/index.html index 7b4ea06bab..4e28273bb0 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/pending-request-string.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/pending-request-string.html index 504d41472c..45cf8b57a6 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/pending-request-string.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/-started/pending-request-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/index.html index 887a940bb2..7e082cb3f4 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-pending-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/-s-e-p-a-direct-debit-request.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/-s-e-p-a-direct-debit-request.html index 41e0f787bf..f7b1fcece7 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/-s-e-p-a-direct-debit-request.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/-s-e-p-a-direct-debit-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/account-holder-name.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/account-holder-name.html index 9c682ee01f..cfc3ed9988 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/account-holder-name.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/account-holder-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/billing-address.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/billing-address.html index 3b3961d7bb..92a199ebf9 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/billing-address.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/customer-id.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/customer-id.html index 654eefaad0..05210913e3 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/customer-id.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/customer-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/iban.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/iban.html index 14a069bd5e..fe142a1ffe 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/iban.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/iban.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/index.html index 9e9e8c3687..14bb3faab7 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/locale.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/locale.html index 0a49f309c6..9874d3c745 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/locale.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/locale.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/mandate-type.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/mandate-type.html index 41c26c2b32..a526b4cf97 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/mandate-type.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/mandate-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/merchant-account-id.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/merchant-account-id.html index ed87848b3e..b362b55dfc 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/merchant-account-id.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-request/merchant-account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-cancel/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-cancel/index.html index ac07b10412..06b793fab9 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-cancel/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/error.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/error.html index 9ac52ae531..b7b204148f 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/error.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/index.html index 87aa57f6e3..6b20206403 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/index.html index be40faa634..abb0e9c196 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/nonce.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/nonce.html index 08ddea227b..d07e4bd991 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/nonce.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/index.html index 0c9e10b4ec..88bf1d7ae3 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/index.html index 0f1becf026..4736e9a3bd 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/on-s-e-p-a-direct-debit-result.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/on-s-e-p-a-direct-debit-result.html index 900df17816..cf8051b71c 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/on-s-e-p-a-direct-debit-result.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/-s-e-p-a-direct-debit-tokenize-callback/on-s-e-p-a-direct-debit-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/index.html b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/index.html index 061e118988..b6e27c3434 100644 --- a/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/index.html +++ b/docs/SEPADirectDebit/com.braintreepayments.api.sepadirectdebit/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/index.html b/docs/SEPADirectDebit/index.html index bd86a19b5b..fca69a3e6a 100644 --- a/docs/SEPADirectDebit/index.html +++ b/docs/SEPADirectDebit/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/SEPADirectDebit/navigation.html b/docs/SEPADirectDebit/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/SEPADirectDebit/navigation.html +++ b/docs/SEPADirectDebit/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/-shopper-insights-buyer-phone.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/-shopper-insights-buyer-phone.html index 6a52e184f1..a0cfd830f7 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/-shopper-insights-buyer-phone.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/-shopper-insights-buyer-phone.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/country-code.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/country-code.html index 17dce54c63..1b3f7d9fb4 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/country-code.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/country-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/index.html index 2d3aa587c0..7dcf1c14b6 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/national-number.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/national-number.html index ff0bb14891..d83721b04d 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/national-number.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-buyer-phone/national-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/index.html index 7b0d9f3910..9edd4fbe03 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/on-result.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/on-result.html index 6d192059f5..30f2c99969 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/on-result.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-callback/on-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-companion/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-companion/index.html index 2533fedbd2..b153cf7787 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-companion/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-shopper-insights-client.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-shopper-insights-client.html index 000e217aa6..dd0dc3d372 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-shopper-insights-client.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/-shopper-insights-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/get-recommended-payment-methods.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/get-recommended-payment-methods.html index 053068e8df..0e3324ce73 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/get-recommended-payment-methods.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/get-recommended-payment-methods.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/index.html index e496b7b763..012043ee1c 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-presented-event.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-presented-event.html index 8fd4bc9255..630d1e1c60 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-presented-event.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-presented-event.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-selected-event.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-selected-event.html index 98035a5d11..32988d8c74 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-selected-event.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-pay-pal-selected-event.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-presented-event.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-presented-event.html index 38bc221169..17e79ab0b2 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-presented-event.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-presented-event.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-selected-event.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-selected-event.html index 37ac82fef9..d0721980b1 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-selected-event.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-client/send-venmo-selected-event.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/index.html index 3299dd6d29..2fc16d6bc3 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-eligible-in-pay-pal-network.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-eligible-in-pay-pal-network.html index d0696d5b08..db197ee07b 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-eligible-in-pay-pal-network.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-eligible-in-pay-pal-network.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-pay-pal-recommended.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-pay-pal-recommended.html index 4d4704d284..a8609a61c7 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-pay-pal-recommended.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-pay-pal-recommended.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-venmo-recommended.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-venmo-recommended.html index 1e59deb9c0..9dc96fc140 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-venmo-recommended.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-info/is-venmo-recommended.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/-shopper-insights-request.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/-shopper-insights-request.html index 0c39202849..736314ab2b 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/-shopper-insights-request.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/-shopper-insights-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/email.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/email.html index ff43923216..f0808b4267 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/email.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/index.html index 9970a6d518..b86d19baca 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/phone.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/phone.html index caabdae7c9..4f65cb0802 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/phone.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-request/phone.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/error.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/error.html index a79636364d..84b59db1c6 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/error.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/index.html index 223e93f8a6..cbc41d55d7 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/index.html index a164af82c3..f34c8e6a65 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/response.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/response.html index 2b08b34692..0c18da689b 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/response.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/-success/response.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/index.html index 211a67a7b9..22d70e9522 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/-shopper-insights-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/index.html b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/index.html index 8eefab075c..e6b1f6689b 100644 --- a/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/index.html +++ b/docs/ShopperInsights/com.braintreepayments.api.shopperinsights/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/index.html b/docs/ShopperInsights/index.html index 00ce8879bb..a549ad2632 100644 --- a/docs/ShopperInsights/index.html +++ b/docs/ShopperInsights/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ShopperInsights/navigation.html b/docs/ShopperInsights/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/ShopperInsights/navigation.html +++ b/docs/ShopperInsights/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-c-r-e-d-i-t/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-c-r-e-d-i-t/index.html index 7df9abd887..6b7d6a3132 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-c-r-e-d-i-t/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-c-r-e-d-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-d-e-b-i-t/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-d-e-b-i-t/index.html index 08828e5ffe..5e1c5edc3c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-d-e-b-i-t/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/-d-e-b-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/entries.html index ae35e6575e..959adaf043 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/index.html index 26d702cacd..0f20373e73 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/value-of.html index 93c78a42ed..4c3950c0b3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/values.html index 3897a0e901..f6db5dd111 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-account-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/-three-d-secure-additional-information.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/-three-d-secure-additional-information.html index b03f4e4239..c777cab60d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/-three-d-secure-additional-information.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/-three-d-secure-additional-information.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-age-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-age-indicator.html index eca65ccfdb..69f66d2297 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-age-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-age-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-date.html index cbc96d89ec..f53daf34e0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-indicator.html index a93b17031e..0b6b611ed8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-change-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-create-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-create-date.html index 731356c55e..cdecbab1a7 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-create-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-create-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-id.html index a4284f14cd..2f300e8f36 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-purchases.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-purchases.html index 3c4a6819de..5d90b8504b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-purchases.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-purchases.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-date.html index cf299f9630..fae1855c48 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-indicator.html index f7e7f283d3..3de8492d3b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/account-pwd-change-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/add-card-attempts.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/add-card-attempts.html index 8bee87b221..912ba68b54 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/add-card-attempts.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/add-card-attempts.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/address-match.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/address-match.html index d241491aab..5384342a5f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/address-match.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/address-match.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/authentication-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/authentication-indicator.html index b11191babe..6a3fe2e138 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/authentication-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/authentication-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-email.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-email.html index 9b392fb244..2e03989cde 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-email.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-timeframe.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-timeframe.html index cbc639f521..6d775b8c57 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-timeframe.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/delivery-timeframe.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/fraud-activity.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/fraud-activity.html index 836cdc93bc..a21485143d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/fraud-activity.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/fraud-activity.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-amount.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-amount.html index a44021d994..3702595d2d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-amount.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-count.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-count.html index f62f05a57e..69f7c0e108 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-count.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-count.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-currency-code.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-currency-code.html index f833bbb83a..6f7cbdf6a9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-currency-code.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/gift-card-currency-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/index.html index 621bc33aa6..50b66d0010 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/installment.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/installment.html index ce7565feec..fcaab2a019 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/installment.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/installment.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/ip-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/ip-address.html index b226c92509..e6e09f0e7a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/ip-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/ip-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/order-description.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/order-description.html index 2b4f4fa548..d1df5bc7af 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/order-description.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/order-description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-age.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-age.html index c931db6606..f32f8c9ef3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-age.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-age.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-indicator.html index ae6ee0f784..f803302a17 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/payment-account-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-date.html index 38a15de287..aea3d026e9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-indicator.html index 51f0ecfbd9..038ca3c9fd 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/preorder-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/product-code.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/product-code.html index 550fa33a5b..52f5793cce 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/product-code.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/product-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/purchase-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/purchase-date.html index e5a9eba5c8..ccb5cd934d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/purchase-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/purchase-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-end.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-end.html index ca84cfd02d..6ebf235230 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-end.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-end.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-frequency.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-frequency.html index baddb5b514..15a7f4d0cb 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-frequency.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/recurring-frequency.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/reorder-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/reorder-indicator.html index e033c00c7b..35730f9850 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/reorder-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/reorder-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/sdk-max-timeout.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/sdk-max-timeout.html index e85d024f32..201161979b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/sdk-max-timeout.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/sdk-max-timeout.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-date.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-date.html index 9e0a588b39..0133b82f15 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-date.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-date.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-indicator.html index 2693a90f6c..ad58847822 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address-usage-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address.html index 7bd55f54b5..9a7acf8eb3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-method-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-method-indicator.html index c892c68bc7..a32d11c4c3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-method-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-method-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-name-indicator.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-name-indicator.html index 7a63397e21..e100a7b840 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-name-indicator.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/shipping-name-indicator.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/tax-amount.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/tax-amount.html index de1cee9019..f02b937062 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/tax-amount.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/tax-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/to-json.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/to-json.html index 253186c7da..6b42086358 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/to-json.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-day.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-day.html index d04dd93c00..1691d1a8fe 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-day.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-day.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-year.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-year.html index ae836fd405..db1206b9d2 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-year.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/transaction-count-year.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/user-agent.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/user-agent.html index 11ec26baf5..2f12cb8667 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/user-agent.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/user-agent.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/work-phone-number.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/work-phone-number.html index b56c1461d5..6408823720 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/work-phone-number.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-additional-information/work-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/-three-d-secure-client.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/-three-d-secure-client.html index 5ec1befcfd..d1cf3cc465 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/-three-d-secure-client.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/-three-d-secure-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/create-payment-auth-request.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/create-payment-auth-request.html index e6ac5d3988..4ff054c3de 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/create-payment-auth-request.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/create-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/index.html index 3cc5e1b1d2..6f5a84cdf6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/initialize-challenge-with-lookup-response.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/initialize-challenge-with-lookup-response.html index 23667d85ee..4e5c22d1ad 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/initialize-challenge-with-lookup-response.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/initialize-challenge-with-lookup-response.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/prepare-lookup.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/prepare-lookup.html index 17d0a3358d..7260634536 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/prepare-lookup.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/prepare-lookup.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/send-analytics-and-callback-result.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/send-analytics-and-callback-result.html index ed1ce1678d..2628a644dd 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/send-analytics-and-callback-result.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/send-analytics-and-callback-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/tokenize.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/tokenize.html index c632547d0b..ea8048110d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/tokenize.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/from-json.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/from-json.html index 6709d8bfe5..338ae9464f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/from-json.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/index.html index bfdf8a44bb..14eced6e13 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/acs-transaction-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/acs-transaction-id.html index 0c96ae2499..929d9efe4c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/acs-transaction-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/acs-transaction-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status-reason.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status-reason.html index e54523780a..db77a1394f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status-reason.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status-reason.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status.html index 256f3a4537..d40cd017de 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/authentication-transaction-status.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/cavv.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/cavv.html index fd446f2084..1c2238ed40 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/cavv.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/cavv.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/ds-transaction-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/ds-transaction-id.html index 09e1b92914..1b73417a08 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/ds-transaction-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/ds-transaction-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/eci-flag.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/eci-flag.html index d7ab078ce6..7fa0db1258 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/eci-flag.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/eci-flag.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/enrolled.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/enrolled.html index b3023dcf7e..6c64f854ad 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/enrolled.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/enrolled.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/index.html index 418192c934..30fc1be09a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shift-possible.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shift-possible.html index 1d6c221fde..9321eee6dc 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shift-possible.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shift-possible.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shifted.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shifted.html index b47b782b8c..fc472e08a0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shifted.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/liability-shifted.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status-reason.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status-reason.html index 0dc3fee677..6236678043 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status-reason.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status-reason.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status.html index 9a4b7073bd..363bd5704f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/lookup-transaction-status.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/pares-status.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/pares-status.html index 8fc7b33657..7bf30bf41e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/pares-status.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/pares-status.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/status.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/status.html index 8208419117..7283231446 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/status.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/status.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-authentication-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-authentication-id.html index 6fd3696fb2..9fdd13995a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-authentication-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-authentication-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-server-transaction-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-server-transaction-id.html index 1242df2c76..ed158e73a6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-server-transaction-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-server-transaction-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-version.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-version.html index 94ff9ef88e..354696e228 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-version.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/three-d-secure-version.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/was-verified.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/was-verified.html index 1eaf6df98c..0063567a01 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/was-verified.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/was-verified.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/xid.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/xid.html index 2e14968ac8..68a3ba20ec 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/xid.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-info/xid.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/index.html index df6e9628ec..f4779fc9be 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/on-three-d-secure-payment-auth-result.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/on-three-d-secure-payment-auth-result.html index 346c2b4008..fb732c9fe8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/on-three-d-secure-payment-auth-result.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher-callback/on-three-d-secure-payment-auth-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-companion/index.html index d65d343e7a..27c34815c5 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-three-d-secure-launcher.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-three-d-secure-launcher.html index 9d3cbc799e..afeb4db9f4 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-three-d-secure-launcher.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/-three-d-secure-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/activity-launcher.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/activity-launcher.html index 16aa89f868..550a9a8ed9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/activity-launcher.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/activity-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/index.html index 8ff7d2037a..e05894f4e7 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/launch.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/launch.html index 07a8eb8bd2..05d81f5d1a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/launch.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/from-json.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/from-json.html index 10ba091c87..f87c386da8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/from-json.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/index.html index 7a256b16f7..9c768d736e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/acs-url.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/acs-url.html index 3b1bd40093..890719db56 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/acs-url.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/acs-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/index.html index d804f5de14..8d497e6029 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/md.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/md.html index d4213a8f81..d1fb36c80c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/md.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/md.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/pareq.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/pareq.html index aeea98122c..576559549b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/pareq.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/pareq.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/requires-user-authentication.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/requires-user-authentication.html index 45493be982..d3802af693 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/requires-user-authentication.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/requires-user-authentication.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/term-url.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/term-url.html index 1af63bb837..7c9167b01c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/term-url.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/term-url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/three-d-secure-version.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/three-d-secure-version.html index e02934f554..06a09930a9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/three-d-secure-version.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/three-d-secure-version.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/transaction-id.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/transaction-id.html index f8b61b81b8..652664ca1b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/transaction-id.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-lookup/transaction-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/from-j-s-o-n.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/from-j-s-o-n.html index 9bedef7cf9..0520c21bf6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/from-j-s-o-n.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/index.html index 6e2ac552af..beca1b9c19 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/authentication-insight.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/authentication-insight.html index a90c5a6d5c..75e663feb6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/authentication-insight.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/authentication-insight.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin-data.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin-data.html index b68a53b6ce..63c7023b08 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin-data.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin.html index 21ec737fef..085223c23d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/bin.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/card-type.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/card-type.html index fffafdb061..6e757fc082 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/card-type.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/card-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/cardholder-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/cardholder-name.html index 4760f16177..45ea259294 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/cardholder-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/cardholder-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-month.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-month.html index 01e38a8a82..d9770bd9a6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-month.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-month.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-year.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-year.html index bbac2f2ec7..6da1e20e88 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-year.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/expiration-year.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/index.html index 594638f8e4..aac73e2cf1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/is-default.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/is-default.html index e5bd750f72..4a5516af96 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/is-default.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-four.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-four.html index f7ace696fd..f1167fe9e8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-four.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-four.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-two.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-two.html index 13736cb8a4..cce4fe35e9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-two.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/last-two.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/string.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/string.html index f8b008055b..1f04ec0e16 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/string.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/three-d-secure-info.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/three-d-secure-info.html index 1ce61bef9d..e586eec288 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/three-d-secure-info.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-nonce/three-d-secure-info.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/from-json.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/from-json.html index 8654a05475..2ad1efdef2 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/from-json.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/from-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/index.html index abb4ab506d..949bb88424 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-three-d-secure-params.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-three-d-secure-params.html index 36c0b50233..68b93aba5d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-three-d-secure-params.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/-three-d-secure-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/error-message.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/error-message.html index e91a07ac8a..c301ac4f2a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/error-message.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/error-message.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/has-error.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/has-error.html index c39843234e..a9bdd935f0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/has-error.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/has-error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/index.html index 642c0f2377..e8780e0547 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/lookup.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/lookup.html index b280a0d910..235ed1529c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/lookup.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/lookup.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/three-d-secure-nonce.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/three-d-secure-nonce.html index 2d9146c53f..1cd285feac 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/three-d-secure-nonce.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-params/three-d-secure-nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/index.html index a87f5c6e56..797a47b3e1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/on-three-d-secure-payment-auth-request.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/on-three-d-secure-payment-auth-request.html index 7686c1148b..db45262f45 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/on-three-d-secure-payment-auth-request.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request-callback/on-three-d-secure-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/error.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/error.html index 57129490f9..ed912abae7 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/error.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/index.html index 8bcc20d849..a0d82fb66d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/index.html index 93467f1353..70dffe5519 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/nonce.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/nonce.html index 7185a4e1d9..904e044704 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/nonce.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/three-d-secure-lookup.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/three-d-secure-lookup.html index f7878e9a85..61b7a1d023 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/three-d-secure-lookup.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-launch-not-required/three-d-secure-lookup.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/index.html index 3065e4dae6..51c0e65712 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/request-params.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/request-params.html index 3e795231e6..70e5aa4479 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/index.html index 3f481f1079..1cbee418a6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-result/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-result/index.html index 3db372bdda..5e69ab5168 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-result/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-companion/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-companion/index.html index 02c68d7b92..7f46e1f986 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-companion/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-three-d-secure-postal-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-three-d-secure-postal-address.html index fceb8048f8..82e1276118 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-three-d-secure-postal-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/-three-d-secure-postal-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/country-code-alpha2.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/country-code-alpha2.html index 17a1052b7a..9db399a631 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/country-code-alpha2.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/country-code-alpha2.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/extended-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/extended-address.html index dfe4d71a91..19487ed3fe 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/extended-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/extended-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/given-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/given-name.html index 8c0c7c67e0..aca8bd6cb8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/given-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/given-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/index.html index f8f6b7e93a..073ec8cb55 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/line3.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/line3.html index 6975d9f9a0..5ab7ac5282 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/line3.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/line3.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/locality.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/locality.html index bdd0da8228..1fa20db23a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/locality.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/locality.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/phone-number.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/phone-number.html index a21defeb41..61624fa82b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/phone-number.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/postal-code.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/postal-code.html index 0f5fe09f46..23f3d4f2d6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/postal-code.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/postal-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/region.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/region.html index 4118f0a701..d8ea374ef1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/region.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/region.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/street-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/street-address.html index e5a8a96626..49a96f4447 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/street-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/street-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/surname.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/surname.html index f45dcf3ac8..91ba618620 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/surname.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/surname.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/to-json.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/to-json.html index 8c23debe24..13dc89caab 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/to-json.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-postal-address/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/index.html index aa6d26ad40..74bbd3e876 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/on-prepare-lookup-result.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/on-prepare-lookup-result.html index daa7bd6850..21620160ca 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/on-prepare-lookup-result.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-callback/on-prepare-lookup-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/error.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/error.html index 0858d9cc10..37cdd8ab0a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/error.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/index.html index 2535c2eca2..b4799e6206 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/client-data.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/client-data.html index 3f3c8216e7..abd53ba895 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/client-data.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/client-data.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/index.html index c65559fd55..bd79308c12 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/request.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/request.html index 55d4108106..ba080d53ae 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/request.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/-success/request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/index.html index e1de9c2cb4..dd1c22a2f1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-prepare-lookup-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-m-u-l-t-i_-s-e-l-e-c-t/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-m-u-l-t-i_-s-e-l-e-c-t/index.html index a91551ded5..b4f48854d3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-m-u-l-t-i_-s-e-l-e-c-t/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-m-u-l-t-i_-s-e-l-e-c-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-o-b/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-o-b/index.html index f8baf2c952..6be4816d8a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-o-b/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-o-b/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-t-p/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-t-p/index.html index a5a4ae15ea..215f9870b1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-t-p/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-o-t-p/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-r-e-n-d-e-r_-h-t-m-l/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-r-e-n-d-e-r_-h-t-m-l/index.html index 1e03df320a..e67e5f3d4e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-r-e-n-d-e-r_-h-t-m-l/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-r-e-n-d-e-r_-h-t-m-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-s-i-n-g-l-e_-s-e-l-e-c-t/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-s-i-n-g-l-e_-s-e-l-e-c-t/index.html index bbada2022b..a3e8feb1be 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-s-i-n-g-l-e_-s-e-l-e-c-t/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/-s-i-n-g-l-e_-s-e-l-e-c-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/entries.html index f6229eed8d..6a8194f091 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/index.html index f41e90dacf..feb1ccd1c8 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/value-of.html index 0aad2f41ae..31714d296d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/values.html index dbdeba4b87..1eeb7a7793 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-render-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/-three-d-secure-request.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/-three-d-secure-request.html index 71c1293bdd..3026aa36a4 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/-three-d-secure-request.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/-three-d-secure-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -58,12 +58,12 @@
-
+

ThreeDSecureRequest

-
constructor(nonce: String? = null, amount: String? = null, mobilePhoneNumber: String? = null, email: String? = null, shippingMethod: ThreeDSecureShippingMethod? = null, billingAddress: ThreeDSecurePostalAddress? = null, accountType: ThreeDSecureAccountType? = null, additionalInformation: ThreeDSecureAdditionalInformation? = null, challengeRequested: Boolean = false, dataOnlyRequested: Boolean = false, exemptionRequested: Boolean = false, requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, cardAddChallengeRequested: Boolean? = null, v2UiCustomization: ThreeDSecureV2UiCustomization? = null, uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, renderTypes: List<ThreeDSecureRenderType>? = null, customFields: Map<String, String>? = null)
+
constructor(nonce: String? = null, amount: String? = null, mobilePhoneNumber: String? = null, email: String? = null, shippingMethod: ThreeDSecureShippingMethod? = null, billingAddress: ThreeDSecurePostalAddress? = null, accountType: ThreeDSecureAccountType? = null, additionalInformation: ThreeDSecureAdditionalInformation? = null, challengeRequested: Boolean = false, dataOnlyRequested: Boolean = false, exemptionRequested: Boolean = false, requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, cardAddChallengeRequested: Boolean? = null, v2UiCustomization: ThreeDSecureV2UiCustomization? = null, uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, renderTypes: List<ThreeDSecureRenderType>? = null, customFields: Map<String, String>? = null, requestorAppUrl: String? = null)
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/additional-information.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/additional-information.html index 1b239dfdaa..c19aa7c5dd 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/additional-information.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/additional-information.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/amount.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/amount.html index 6168fd9cd3..dc3481ab64 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/amount.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/billing-address.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/billing-address.html index e510c13c43..7eb32a6c99 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/billing-address.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/build.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/build.html index 4ae8a1d214..3b9e2d2124 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/build.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/build.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/card-add-challenge-requested.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/card-add-challenge-requested.html index f222ebc295..a315cb6a1e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/card-add-challenge-requested.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/card-add-challenge-requested.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/challenge-requested.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/challenge-requested.html index 6a610eaec0..7995748408 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/challenge-requested.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/challenge-requested.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/custom-fields.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/custom-fields.html index 41672eecd9..83b223bcbe 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/custom-fields.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/custom-fields.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/data-only-requested.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/data-only-requested.html index 5d8c03b618..db1ba6cc2d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/data-only-requested.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/data-only-requested.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/email.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/email.html index f26eac649e..5a467bd290 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/email.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/exemption-requested.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/exemption-requested.html index 7619287266..c726eefca5 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/exemption-requested.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/exemption-requested.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/index.html index 5c391d19c5..803120af34 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -62,24 +62,24 @@

ThreeDSecureRequest

-
data class ThreeDSecureRequest @JvmOverloads constructor(var nonce: String? = null, var amount: String? = null, var mobilePhoneNumber: String? = null, var email: String? = null, var shippingMethod: ThreeDSecureShippingMethod? = null, var billingAddress: ThreeDSecurePostalAddress? = null, var accountType: ThreeDSecureAccountType? = null, var additionalInformation: ThreeDSecureAdditionalInformation? = null, var challengeRequested: Boolean = false, var dataOnlyRequested: Boolean = false, var exemptionRequested: Boolean = false, var requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, var cardAddChallengeRequested: Boolean? = null, var v2UiCustomization: ThreeDSecureV2UiCustomization? = null, var uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, var renderTypes: List<ThreeDSecureRenderType>? = null, var customFields: Map<String, String>? = null) : Parcelable

A class to contain 3D Secure request information used for authentication

+
data class ThreeDSecureRequest @JvmOverloads constructor(var nonce: String? = null, var amount: String? = null, var mobilePhoneNumber: String? = null, var email: String? = null, var shippingMethod: ThreeDSecureShippingMethod? = null, var billingAddress: ThreeDSecurePostalAddress? = null, var accountType: ThreeDSecureAccountType? = null, var additionalInformation: ThreeDSecureAdditionalInformation? = null, var challengeRequested: Boolean = false, var dataOnlyRequested: Boolean = false, var exemptionRequested: Boolean = false, var requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, var cardAddChallengeRequested: Boolean? = null, var v2UiCustomization: ThreeDSecureV2UiCustomization? = null, var uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, var renderTypes: List<ThreeDSecureRenderType>? = null, var customFields: Map<String, String>? = null, var requestorAppUrl: String? = null) : Parcelable

A class to contain 3D Secure request information used for authentication

Constructors

-
+
- +
Link copied to clipboard
-
constructor(nonce: String? = null, amount: String? = null, mobilePhoneNumber: String? = null, email: String? = null, shippingMethod: ThreeDSecureShippingMethod? = null, billingAddress: ThreeDSecurePostalAddress? = null, accountType: ThreeDSecureAccountType? = null, additionalInformation: ThreeDSecureAdditionalInformation? = null, challengeRequested: Boolean = false, dataOnlyRequested: Boolean = false, exemptionRequested: Boolean = false, requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, cardAddChallengeRequested: Boolean? = null, v2UiCustomization: ThreeDSecureV2UiCustomization? = null, uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, renderTypes: List<ThreeDSecureRenderType>? = null, customFields: Map<String, String>? = null)
+
constructor(nonce: String? = null, amount: String? = null, mobilePhoneNumber: String? = null, email: String? = null, shippingMethod: ThreeDSecureShippingMethod? = null, billingAddress: ThreeDSecurePostalAddress? = null, accountType: ThreeDSecureAccountType? = null, additionalInformation: ThreeDSecureAdditionalInformation? = null, challengeRequested: Boolean = false, dataOnlyRequested: Boolean = false, exemptionRequested: Boolean = false, requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, cardAddChallengeRequested: Boolean? = null, v2UiCustomization: ThreeDSecureV2UiCustomization? = null, uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, renderTypes: List<ThreeDSecureRenderType>? = null, customFields: Map<String, String>? = null, requestorAppUrl: String? = null)
@@ -298,6 +298,21 @@

Properties

+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Optional. Three DS Requester APP URL Merchant app declaring their URL within the CReq message so that the Authentication app can call the Merchant app after OOB authentication has occurred.

+
+
+
+
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/mobile-phone-number.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/mobile-phone-number.html index e0d1ee45fc..0308536e30 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/mobile-phone-number.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/mobile-phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/nonce.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/nonce.html index 056f344b42..812f4c064d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/nonce.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/render-types.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/render-types.html index 8a4423c9f6..3bdd0f0581 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/render-types.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/render-types.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requested-exemption-type.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requested-exemption-type.html index 5882b66a83..6d6245ae7a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requested-exemption-type.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requested-exemption-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requestor-app-url.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requestor-app-url.html new file mode 100644 index 0000000000..0d8c770729 --- /dev/null +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/requestor-app-url.html @@ -0,0 +1,76 @@ + + + + + requestorAppUrl + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

requestorAppUrl

+
+ +
+ +
+
+
+ + + diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/shipping-method.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/shipping-method.html index 737c1c15cc..96f1942ff5 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/shipping-method.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/shipping-method.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/ui-type.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/ui-type.html index b9ddadcaeb..8eac057415 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/ui-type.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/ui-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/v2-ui-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/v2-ui-customization.html index 16ee80928d..b115b65fa2 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/v2-ui-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-request/v2-ui-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-l-o-w_-v-a-l-u-e/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-l-o-w_-v-a-l-u-e/index.html index e26a0fda0f..c0bb345f0f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-l-o-w_-v-a-l-u-e/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-l-o-w_-v-a-l-u-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-s-e-c-u-r-e_-c-o-r-p-o-r-a-t-e/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-s-e-c-u-r-e_-c-o-r-p-o-r-a-t-e/index.html index 07fc70589f..ea08492eab 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-s-e-c-u-r-e_-c-o-r-p-o-r-a-t-e/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-s-e-c-u-r-e_-c-o-r-p-o-r-a-t-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-a-n-s-a-c-t-i-o-n_-r-i-s-k_-a-n-a-l-y-s-i-s/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-a-n-s-a-c-t-i-o-n_-r-i-s-k_-a-n-a-l-y-s-i-s/index.html index 8ce3dd3a48..4e7d054b11 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-a-n-s-a-c-t-i-o-n_-r-i-s-k_-a-n-a-l-y-s-i-s/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-a-n-s-a-c-t-i-o-n_-r-i-s-k_-a-n-a-l-y-s-i-s/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-u-s-t-e-d_-b-e-n-e-f-i-c-i-a-r-y/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-u-s-t-e-d_-b-e-n-e-f-i-c-i-a-r-y/index.html index 6518e3779e..04cb5f2d25 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-u-s-t-e-d_-b-e-n-e-f-i-c-i-a-r-y/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/-t-r-u-s-t-e-d_-b-e-n-e-f-i-c-i-a-r-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/entries.html index 9ffe65fa16..e852de5f48 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/index.html index e6572a3d6d..c638dd4d79 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/value-of.html index a824e430ae..48f42a9c2e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/values.html index ff21650814..03173f0172 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-requested-exemption-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-cancel/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-cancel/index.html index 694f378b9d..cdab2e682b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-cancel/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/error.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/error.html index d72816cac8..e48ca41b4d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/error.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/index.html index 6a12903768..e1e629a6e3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/nonce.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/nonce.html index 98e5e477c5..6819f014f0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/nonce.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-failure/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/index.html index a14d1011ae..c8fb703e1e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/nonce.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/nonce.html index c545a2a32a..59d088c63c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/nonce.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/index.html index 460cfc6836..5a2b847432 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-l-e-c-t-r-o-n-i-c_-d-e-l-i-v-e-r-y/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-l-e-c-t-r-o-n-i-c_-d-e-l-i-v-e-r-y/index.html index c6010a1123..8faf86b815 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-l-e-c-t-r-o-n-i-c_-d-e-l-i-v-e-r-y/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-l-e-c-t-r-o-n-i-c_-d-e-l-i-v-e-r-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-x-p-e-d-i-t-e-d/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-x-p-e-d-i-t-e-d/index.html index 8d27bafd3a..49b512648c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-x-p-e-d-i-t-e-d/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-e-x-p-e-d-i-t-e-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-g-r-o-u-n-d/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-g-r-o-u-n-d/index.html index 84f537895d..143068c45e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-g-r-o-u-n-d/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-g-r-o-u-n-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-p-r-i-o-r-i-t-y/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-p-r-i-o-r-i-t-y/index.html index ae90e4f529..042dd755c3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-p-r-i-o-r-i-t-y/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-p-r-i-o-r-i-t-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-a-m-e_-d-a-y/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-a-m-e_-d-a-y/index.html index a4ae6a5155..be92edcc78 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-a-m-e_-d-a-y/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-a-m-e_-d-a-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-h-i-p_-t-o_-s-t-o-r-e/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-h-i-p_-t-o_-s-t-o-r-e/index.html index c6ac6c1522..779f98dd59 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-h-i-p_-t-o_-s-t-o-r-e/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/-s-h-i-p_-t-o_-s-t-o-r-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/entries.html index e76d70da42..30322ab13c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/index.html index 2003e41bd2..9300bd5521 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/value-of.html index 6aff6fc2c5..2a1d39b061 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/values.html index 00f6b8d0af..0810146b7f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-shipping-method/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/index.html index c0480cc779..618af5f06f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/on-three-d-secure-result.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/on-three-d-secure-result.html index fa0e74e4ef..07b954ae8a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/on-three-d-secure-result.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-tokenize-callback/on-three-d-secure-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-b-o-t-h/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-b-o-t-h/index.html index 310b521e19..6344e65124 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-b-o-t-h/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-b-o-t-h/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-h-t-m-l/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-h-t-m-l/index.html index a31d803dd9..4a59d12a08 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-h-t-m-l/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-h-t-m-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-n-a-t-i-v-e/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-n-a-t-i-v-e/index.html index cc42b22004..0a61048e88 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-n-a-t-i-v-e/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/-n-a-t-i-v-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/entries.html index bf1abefc6e..82c4502ff1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/index.html index 207cabf8b1..72efb22bca 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/value-of.html index 31c685124c..6d9aefe898 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/values.html index 39fb67d298..c35f5684e9 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-ui-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/-three-d-secure-v2-button-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/-three-d-secure-v2-button-customization.html index ef7b4ac259..6f0fcb10b4 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/-three-d-secure-v2-button-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/-three-d-secure-v2-button-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/background-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/background-color.html index 9a339fd966..a03ee874a7 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/background-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/background-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/cardinal-button-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/cardinal-button-customization.html index c98f932b94..901d077f15 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/cardinal-button-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/cardinal-button-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/corner-radius.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/corner-radius.html index c48300ff86..1dbb33aeb3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/corner-radius.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/corner-radius.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/index.html index 0a61b72ea5..3f2d004238 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-color.html index 0e486dfdfc..21f9764618 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-name.html index e66c54b7b0..2d6b736a1c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-size.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-size.html index f4a1883626..734c07c0ec 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-size.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-customization/text-font-size.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-a-n-c-e-l/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-a-n-c-e-l/index.html index 418c153c4d..f63c4edf0a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-a-n-c-e-l/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-a-n-c-e-l/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-o-n-t-i-n-u-e/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-o-n-t-i-n-u-e/index.html index 70d7f51d04..0894fee2a3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-o-n-t-i-n-u-e/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-c-o-n-t-i-n-u-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-n-e-x-t/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-n-e-x-t/index.html index c0c77fd990..80fa0dbb97 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-n-e-x-t/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-n-e-x-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-r-e-s-e-n-d/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-r-e-s-e-n-d/index.html index fa3fd90052..4142e42935 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-r-e-s-e-n-d/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-r-e-s-e-n-d/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-v-e-r-i-f-y/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-v-e-r-i-f-y/index.html index 1cb06f6dca..d6dd8a8483 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-v-e-r-i-f-y/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/-b-u-t-t-o-n_-t-y-p-e_-v-e-r-i-f-y/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/entries.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/entries.html index bb5dfbdad5..d00c6eeb6f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/entries.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/index.html index 2a9c3374d6..0ebd7b5ce3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/value-of.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/value-of.html index ef990a4aa6..edb571c87e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/value-of.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/values.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/values.html index c0a56ff84e..2ee5877ad1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/values.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-button-type/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/-three-d-secure-v2-label-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/-three-d-secure-v2-label-customization.html index 6bada06b4a..099fed7e9b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/-three-d-secure-v2-label-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/-three-d-secure-v2-label-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/cardinal-label-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/cardinal-label-customization.html index 26e0f5a1c1..5732f472db 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/cardinal-label-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/cardinal-label-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-color.html index bca80a45f1..fa54280145 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-name.html index e405ceec55..d2fc4eb2f2 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-size.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-size.html index 7073547820..16db17b47a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-size.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/heading-text-font-size.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/index.html index d3e7e84e57..15e04d52cd 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-color.html index 685632ca09..c406d7d79e 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-name.html index 75fe43d414..b115f54f43 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-size.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-size.html index d3d2002205..2f754082bf 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-size.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-label-customization/text-font-size.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/-three-d-secure-v2-text-box-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/-three-d-secure-v2-text-box-customization.html index 4f85ef7c19..4d1cad132c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/-three-d-secure-v2-text-box-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/-three-d-secure-v2-text-box-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-color.html index 73f58ec827..61f3cffd36 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-width.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-width.html index 2df365e3d5..8a41f511b0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-width.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/border-width.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/cardinal-text-box-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/cardinal-text-box-customization.html index 8656f51075..fd0e3920b1 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/cardinal-text-box-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/cardinal-text-box-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/corner-radius.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/corner-radius.html index c22c58d3a4..48a5968d42 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/corner-radius.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/corner-radius.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/index.html index ebef5f5072..ac5473fa97 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-color.html index fb76071908..ee855e68c0 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-name.html index 31867650a5..c9cbbb4f75 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-size.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-size.html index 966e9628d5..b596e15ea6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-size.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-text-box-customization/text-font-size.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/-three-d-secure-v2-toolbar-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/-three-d-secure-v2-toolbar-customization.html index 9565ad2ede..53fd1dd71f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/-three-d-secure-v2-toolbar-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/-three-d-secure-v2-toolbar-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/background-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/background-color.html index 4238db3725..6e32cdcc0a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/background-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/background-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/button-text.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/button-text.html index bc8d2fa144..0202c529ba 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/button-text.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/button-text.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/cardinal-toolbar-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/cardinal-toolbar-customization.html index 737037160b..cecfc73baf 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/cardinal-toolbar-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/cardinal-toolbar-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/header-text.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/header-text.html index 4c21a54d44..636445756a 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/header-text.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/header-text.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/index.html index 927dd43dcb..a5dc4dd768 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-color.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-color.html index f4797824b7..35e6cee01d 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-color.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-color.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-name.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-name.html index 1b4d6042dd..88b315594c 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-name.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-size.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-size.html index 09c2fca3d0..260db19734 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-size.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-toolbar-customization/text-font-size.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/-three-d-secure-v2-ui-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/-three-d-secure-v2-ui-customization.html index 3f944c5577..8e2440a86b 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/-three-d-secure-v2-ui-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/-three-d-secure-v2-ui-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-customization.html index 9f01873ff8..12f88a79d3 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-type.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-type.html index 9d9dcb1c6f..5636790484 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-type.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/button-type.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/cardinal-ui-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/cardinal-ui-customization.html index 007ce935cc..0fea52e987 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/cardinal-ui-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/cardinal-ui-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/index.html index f4d11d51b7..0b46c02596 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/label-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/label-customization.html index ba0ecb21ed..ed83907583 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/label-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/label-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/text-box-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/text-box-customization.html index 0a132ddb96..f14e3608a6 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/text-box-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/text-box-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/toolbar-customization.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/toolbar-customization.html index e182bc39cc..e494f73738 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/toolbar-customization.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/-three-d-secure-v2-ui-customization/toolbar-customization.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/index.html b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/index.html index 698b684923..522610fa3f 100644 --- a/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/index.html +++ b/docs/ThreeDSecure/com.braintreepayments.api.threedsecure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -318,7 +318,7 @@

Types

-
data class ThreeDSecureRequest @JvmOverloads constructor(var nonce: String? = null, var amount: String? = null, var mobilePhoneNumber: String? = null, var email: String? = null, var shippingMethod: ThreeDSecureShippingMethod? = null, var billingAddress: ThreeDSecurePostalAddress? = null, var accountType: ThreeDSecureAccountType? = null, var additionalInformation: ThreeDSecureAdditionalInformation? = null, var challengeRequested: Boolean = false, var dataOnlyRequested: Boolean = false, var exemptionRequested: Boolean = false, var requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, var cardAddChallengeRequested: Boolean? = null, var v2UiCustomization: ThreeDSecureV2UiCustomization? = null, var uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, var renderTypes: List<ThreeDSecureRenderType>? = null, var customFields: Map<String, String>? = null) : Parcelable

A class to contain 3D Secure request information used for authentication

+
data class ThreeDSecureRequest @JvmOverloads constructor(var nonce: String? = null, var amount: String? = null, var mobilePhoneNumber: String? = null, var email: String? = null, var shippingMethod: ThreeDSecureShippingMethod? = null, var billingAddress: ThreeDSecurePostalAddress? = null, var accountType: ThreeDSecureAccountType? = null, var additionalInformation: ThreeDSecureAdditionalInformation? = null, var challengeRequested: Boolean = false, var dataOnlyRequested: Boolean = false, var exemptionRequested: Boolean = false, var requestedExemptionType: ThreeDSecureRequestedExemptionType? = null, var cardAddChallengeRequested: Boolean? = null, var v2UiCustomization: ThreeDSecureV2UiCustomization? = null, var uiType: ThreeDSecureUiType = ThreeDSecureUiType.BOTH, var renderTypes: List<ThreeDSecureRenderType>? = null, var customFields: Map<String, String>? = null, var requestorAppUrl: String? = null) : Parcelable

A class to contain 3D Secure request information used for authentication

diff --git a/docs/ThreeDSecure/index.html b/docs/ThreeDSecure/index.html index d215613cb6..b15c9ed122 100644 --- a/docs/ThreeDSecure/index.html +++ b/docs/ThreeDSecure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/ThreeDSecure/navigation.html b/docs/ThreeDSecure/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/ThreeDSecure/navigation.html +++ b/docs/ThreeDSecure/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/from-j-s-o-n.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/from-j-s-o-n.html index 0e06a2b7e1..a3ccff69c5 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/from-j-s-o-n.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/from-j-s-o-n.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/index.html index 1fc1cd155e..ddcc2d8e74 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/billing-address.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/billing-address.html index 0e8c5c8102..413b76ecf1 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/billing-address.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/email.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/email.html index 43fae61ec3..f3ce1202c8 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/email.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/email.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/external-id.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/external-id.html index 766154a77e..cb424ca961 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/external-id.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/external-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/first-name.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/first-name.html index 68c409c65b..5ed9ef5b17 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/first-name.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/first-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/index.html index f27ded25d6..b2357a1c63 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/is-default.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/is-default.html index e418f311b2..0b3af48425 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/is-default.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/is-default.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/last-name.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/last-name.html index c92246836e..485e71c500 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/last-name.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/last-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/phone-number.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/phone-number.html index ceb0e82d83..d71b4364a7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/phone-number.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/phone-number.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/shipping-address.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/shipping-address.html index 299ea0dd6e..dfaa8f3f99 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/shipping-address.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/string.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/string.html index f74d59f5b0..9fd86063ef 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/string.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/username.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/username.html index 64cfa79b54..7d4329beb2 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/username.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-account-nonce/username.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-companion/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-companion/index.html index 1df2aa75be..be048b5e5c 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-companion/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-venmo-client.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-venmo-client.html index e763b2fdc6..62c6f6fc7d 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-venmo-client.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/-venmo-client.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -58,12 +58,12 @@
-
+

VenmoClient

-
constructor(context: Context, authorization: String, returnUrlScheme: String?)

Initializes a new VenmoClient instance

Parameters

context

an Android Context

authorization

a Tokenization Key or Client Token used to authenticate

returnUrlScheme

a custom return url to use for browser and app switching

+
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri, deepLinkFallbackUrlScheme: String? = null)

Initializes a new VenmoClient instance

Parameters

context

an Android Context

authorization

a Tokenization Key or Client Token used to authenticate

appLinkReturnUrl

A Uri containing the Android App Link website associated with your application to be used to return to your app from the PayPal

deepLinkFallbackUrlScheme

A return url scheme that will be used as a deep link fallback when returning to your app via App Link is not available (buyer unchecks the "Open supported links" setting).


constructor(context: Context, authorization: String, returnUrlScheme: String? = null)

Deprecated

Use the constructor that uses an `appLinkReturnUrl` to redirect back to your application instead.

Initializes a new VenmoClient instance

Parameters

context

an Android Context

authorization

a Tokenization Key or Client Token used to authenticate

returnUrlScheme

a custom return url to use for browser and app switching

-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/index.html index e858b4f8f5..853bbcd9b4 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
@@ -69,17 +69,17 @@

VenmoClient

Constructors

-
+
- +
Link copied to clipboard
-
constructor(context: Context, authorization: String, returnUrlScheme: String?)

Initializes a new VenmoClient instance

+
constructor(context: Context, authorization: String, appLinkReturnUrl: Uri, deepLinkFallbackUrlScheme: String? = null)

Initializes a new VenmoClient instance

constructor(context: Context, authorization: String, returnUrlScheme: String? = null)

Initializes a new VenmoClient instance

diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/tokenize.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/tokenize.html index 7404727854..df912c0721 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/tokenize.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-client/tokenize.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-companion/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-companion/index.html index 9ccb06e334..0590abdb99 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-companion/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-venmo-launcher.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-venmo-launcher.html index a17953c0ea..472a864df7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-venmo-launcher.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/-venmo-launcher.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/handle-return-to-app.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/handle-return-to-app.html index c2c1adb1e2..9293555809 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/handle-return-to-app.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/handle-return-to-app.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/index.html index 8a21c57632..de341dbc97 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/launch.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/launch.html index 4d3360477c..5b9e84eba6 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/launch.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/launch.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/show-venmo-in-google-play-store.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/show-venmo-in-google-play-store.html index 70570f66a5..abee7014b3 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/show-venmo-in-google-play-store.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-launcher/show-venmo-in-google-play-store.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-c-r-e-d-i-t/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-c-r-e-d-i-t/index.html index 02583e5fc8..08d2312bff 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-c-r-e-d-i-t/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-c-r-e-d-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-d-e-b-i-t/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-d-e-b-i-t/index.html index c06bd4832d..011a2939a7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-d-e-b-i-t/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/-d-e-b-i-t/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/entries.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/entries.html index 677914c71e..7571b87f53 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/entries.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/index.html index 599794d84f..b4de015df8 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/value-of.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/value-of.html index 15d55fa60f..74af76416a 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/value-of.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/values.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/values.html index 0ed5e17556..cda4007610 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/values.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item-kind/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-companion/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-companion/index.html index 9629b8d7e8..0ed121816e 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-companion/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-companion/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-venmo-line-item.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-venmo-line-item.html index cc0053533b..92ed8458a7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-venmo-line-item.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/-venmo-line-item.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/description.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/description.html index 13a4fd90eb..d36fccd166 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/description.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/description.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/index.html index 63131860b0..13839131b6 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/kind.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/kind.html index 73dd946c10..0e2aac8e9b 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/kind.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/kind.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/name.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/name.html index db1a83ae8c..3ab8273b3b 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/name.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/product-code.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/product-code.html index 140532f975..af1d78a28a 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/product-code.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/product-code.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/quantity.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/quantity.html index f39cf86d00..43ce95c0a3 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/quantity.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/quantity.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/to-json.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/to-json.html index a68ed86310..717f029031 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/to-json.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/to-json.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-amount.html index 8591eaed28..08d1505eb5 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-tax-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-tax-amount.html index 65b7925409..1dce3886eb 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-tax-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/unit-tax-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/url.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/url.html index c899b00081..6487eca115 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/url.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-line-item/url.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/index.html index 7f2af12763..c4aee0ee1d 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/on-venmo-payment-auth-request.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/on-venmo-payment-auth-request.html index 32a8a44f8e..e671d46410 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/on-venmo-payment-auth-request.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-callback/on-venmo-payment-auth-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/browser-switch-options.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/browser-switch-options.html index 8b336d429c..ea088d5e7e 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/browser-switch-options.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/browser-switch-options.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/index.html index 650073877e..0362b07fb7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request-params/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/error.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/error.html index 711ebaa8b0..f55999e1d2 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/error.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/index.html index 379a407ac8..1e45c587d7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/index.html index cd570e9576..aadacf0ad6 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/request-params.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/request-params.html index 1922a3c453..61648077fd 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/request-params.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/-ready-to-launch/request-params.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/index.html index dca1c5be34..1ecda7b5f7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/error.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/error.html index a8aa03a1a2..bd81bc1b6c 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/error.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/index.html index 839cb2c87f..f1cca72fdf 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-no-result/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-no-result/index.html index 310d4e3d37..13235bf091 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-no-result/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-no-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-success/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-success/index.html index 203a33f5f8..94edca0c43 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-success/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/index.html index 75326ac27c..ae4e6c109c 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-auth-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-m-u-l-t-i_-u-s-e/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-m-u-l-t-i_-u-s-e/index.html index ae381337c8..75bf500eb3 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-m-u-l-t-i_-u-s-e/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-m-u-l-t-i_-u-s-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-s-i-n-g-l-e_-u-s-e/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-s-i-n-g-l-e_-u-s-e/index.html index 8d017ece84..467c51e3ba 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-s-i-n-g-l-e_-u-s-e/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/-s-i-n-g-l-e_-u-s-e/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/entries.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/entries.html index a0e5db7a97..7f88e69271 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/entries.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/entries.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/index.html index bf431efef1..4d4f0fdd2a 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/value-of.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/value-of.html index d0dcfcc899..73c549a963 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/value-of.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/value-of.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/values.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/values.html index e6213be11b..bf04012bf9 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/values.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-payment-method-usage/values.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/error.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/error.html index 1b60349f3a..13b49e6513 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/error.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/index.html index d972674b8a..8b6a448e1e 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/-started.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/-started.html index 09dc072564..ed15815a46 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/-started.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/-started.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/index.html index 314ed67216..d2e94219c2 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/pending-request-string.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/pending-request-string.html index 1c4d670c5c..994b8916dd 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/pending-request-string.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/-started/pending-request-string.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/index.html index 44616766fe..3a74de9f20 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-pending-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/-venmo-request.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/-venmo-request.html index a5b0ed293d..bada2668b7 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/-venmo-request.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/-venmo-request.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-billing-address.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-billing-address.html index 9f4918d744..4610f10545 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-billing-address.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-billing-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-shipping-address.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-shipping-address.html index ff35d1ef05..7c8480f648 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-shipping-address.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/collect-customer-shipping-address.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/discount-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/discount-amount.html index d8c8ff7cde..8a80b18c2c 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/discount-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/discount-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/display-name.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/display-name.html index c08c042fb1..ff682e163f 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/display-name.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/display-name.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/index.html index e55f80fcde..1d713a216f 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/is-final-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/is-final-amount.html index c429ec3f1c..1fe64c9b67 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/is-final-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/is-final-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/line-items.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/line-items.html index 09804b4069..88d497d0ea 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/line-items.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/line-items.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/payment-method-usage.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/payment-method-usage.html index 6d988d83da..404c6812b5 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/payment-method-usage.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/payment-method-usage.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/profile-id.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/profile-id.html index 8615147687..0d5f292ba8 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/profile-id.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/profile-id.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/shipping-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/shipping-amount.html index 90c589b297..53813976f6 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/shipping-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/shipping-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/should-vault.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/should-vault.html index 7320c5b68f..1b41aacf58 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/should-vault.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/should-vault.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/sub-total-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/sub-total-amount.html index 557c1bb2ea..05b509b4fa 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/sub-total-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/sub-total-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/tax-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/tax-amount.html index f02eff15ac..8bab814ff6 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/tax-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/tax-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/total-amount.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/total-amount.html index c87c1de5b8..ba5182777a 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/total-amount.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-request/total-amount.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-cancel/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-cancel/index.html index 13d154bf89..ed1983c035 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-cancel/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-cancel/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/error.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/error.html index 6a461268f4..5f13798d21 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/error.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/error.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/index.html index 5155a82326..495440ac0f 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-failure/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/index.html index cd4c79c8b1..865974b348 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/nonce.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/nonce.html index 9fe882ca52..e0a4c23dda 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/nonce.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/-success/nonce.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/index.html index df31b7f841..54598ae746 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-result/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/index.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/index.html index a10369a927..5ec30a2924 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/on-venmo-result.html b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/on-venmo-result.html index 437f2d6319..1c01364a18 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/on-venmo-result.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/-venmo-tokenize-callback/on-venmo-result.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/com.braintreepayments.api.venmo/index.html b/docs/Venmo/com.braintreepayments.api.venmo/index.html index 2cb6ad896a..01450a96b5 100644 --- a/docs/Venmo/com.braintreepayments.api.venmo/index.html +++ b/docs/Venmo/com.braintreepayments.api.venmo/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/index.html b/docs/Venmo/index.html index fb0b1a13fd..54c1b31492 100644 --- a/docs/Venmo/index.html +++ b/docs/Venmo/index.html @@ -41,7 +41,7 @@ braintree_android
-
5.2.0 +
5.3.0
diff --git a/docs/Venmo/navigation.html b/docs/Venmo/navigation.html index 12ed47b79c..fbb9759106 100644 --- a/docs/Venmo/navigation.html +++ b/docs/Venmo/navigation.html @@ -57,157 +57,207 @@ -
+
+ +
+
+ Companion +
+
+
+ -
+
- -
+ -
+ -
+
- -
+ -
+
-
+ -
+ -
+ -
+ -
+ -
+ - -
+ -
+ -
+ -
+
- -
+ -
+
+ +
+ +
+
+ AppLink +
+
+
+
+ DeepLink +
+
+
+
+ Failure +
+
+
+
+ -
+
-
+ - -
+
+ +
+
+ Companion +
+
+
+
- -
+ -
+ -
+
diff --git a/docs/index.html b/docs/index.html index 7a1fd2de40..25fd1650f0 100644 --- a/docs/index.html +++ b/docs/index.html @@ -44,7 +44,7 @@
-5.2.0
+5.3.0