1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167package io.hyperswitch.payments.googlepaylauncher
import android.os.Parcelable
import androidx.annotation.IntDef
import io.hyperswitch.payments.GooglePayEnvironment
import kotlinx.parcelize.Parcelize
import java.util.Locale
class GooglePayPaymentMethodLauncher {
@Parcelize
data class Config @JvmOverloads constructor(
val environment: GooglePayEnvironment,
val merchantCountryCode: String,
val merchantName: String,
/**
* Flag to indicate whether Google Pay collect the customer's email address.
*
* Default to `false`.
*/
var isEmailRequired: Boolean = false,
/**
* Billing address collection configuration.
*/
var billingAddressConfig: BillingAddressConfig = BillingAddressConfig(),
/**
* If `true`, Google Pay is considered ready if the customer's Google Pay wallet
* has existing payment methods.
*
* Default to `true`.
*/
var existingPaymentMethodRequired: Boolean = true,
/**
* Set to false if you don't support credit cards.
*
* Default: The credit card class is supported for the card networks specified.
*/
var allowCreditCards: Boolean = true
) : Parcelable {
internal val isJcbEnabled: Boolean
get() = merchantCountryCode.equals(Locale.JAPAN.country, ignoreCase = true)
}
@Parcelize
data class BillingAddressConfig @JvmOverloads constructor(
val isRequired: Boolean = false,
/**
* Billing address format required to complete the transaction.
*/
val format: Format = Format.Min,
/**
* Set to true if a phone number is required to process the transaction.
*/
val isPhoneNumberRequired: Boolean = false
) : Parcelable {
/**
* Billing address format required to complete the transaction.
*/
enum class Format(internal val code: String) {
/**
* Name, country code, and postal code (default).
*/
Min("MIN"),
/**
* Name, street address, locality, region, country code, and postal code.
*/
Full("FULL")
}
}
sealed class Result : Parcelable {
/**
* Represents a successful transaction.
*
* @param paymentMethod The resulting payment method.
*/
@Parcelize
data class Completed(
val paymentMethod: PaymentMethod
) : Result()
/**
* Represents a failed transaction.
*
* @param error The failure reason.
* @param errorCode The failure [ErrorCode].
*/
@Parcelize
data class Failed(
val error: Throwable,
@ErrorCode val errorCode: Int
) : Result()
/**
* Represents a transaction that was canceled by the user.
*/
@Parcelize
data class Canceled(
val data: String
) : Result()
}
fun interface ReadyCallback {
fun onReady(isReady: Boolean)
}
fun interface ResultCallback {
fun onResult(result: Result)
}
/**
* Error codes representing the possible error types for [Result.Failed].
* See the corresponding [Result.Failed.error] message for more details.
*/
@Target(AnnotationTarget.PROPERTY, AnnotationTarget.VALUE_PARAMETER, AnnotationTarget.TYPE)
@IntDef(INTERNAL_ERROR, DEVELOPER_ERROR, NETWORK_ERROR)
annotation class ErrorCode
companion object {
internal const val PRODUCT_USAGE_TOKEN = "GooglePayPaymentMethodLauncher"
// Generic internal error
const val INTERNAL_ERROR = 1
// The application is misconfigured
const val DEVELOPER_ERROR = 2
// Error executing a network call
const val NETWORK_ERROR = 3
}
}
@Parcelize
data class PaymentMethod
constructor(
/**
* Unique identifier for the object.
*
* [id](https://docs.hyperswitch.io/api/payment_methods/object#payment_method_object-id)
*/
@JvmField val id: String?,
/**
* Time at which the object was created. Measured in seconds since the Unix epoch.
*
* [created](https://docs.hyperswitch.io/api/payment_methods/object#payment_method_object-created)
*/
@JvmField val created: Long?,
/**
* Has the value `true` if the object exists in live mode or the value `false` if the object exists in test mode.
*
* [livemode](https://docs.hyperswitch.io/api/payment_methods/object#payment_method_object-livemode)
*/
@JvmField val liveMode: Boolean,
) : Parcelable