Web Payments API के ज़रिए शिपिंग पता और पैसे चुकाने वाले की संपर्क जानकारी देने के लिए, Android पेमेंट ऐप्लिकेशन को अपडेट करने का तरीका.
वेब फ़ॉर्म के ज़रिए शिपिंग पता और संपर्क जानकारी डालना, ग्राहकों के लिए एक मुश्किल अनुभव हो सकता है. इससे गड़बड़ियां हो सकती हैं और कन्वर्ज़न रेट में गिरावट आ सकती है.
यही वजह है कि Payment Request API, शिपिंग पते और संपर्क जानकारी के लिए अनुरोध करने की सुविधा के साथ काम करती है. इससे कई फ़ायदे मिलते हैं:
- उपयोगकर्ता बस कुछ ही टैप करके सही पता चुन सकते हैं.
- पता हमेशा स्टैंडर्ड फ़ॉर्मैट में दिखाया जाता है.
- गलत पता सबमिट करने की संभावना कम होती है.
ब्राउज़र, पेमेंट ऐप्लिकेशन में शिपिंग पते और संपर्क जानकारी इकट्ठा करने की प्रोसेस को टाल सकते हैं, ताकि सभी को एक ही तरह से पेमेंट किया जा सके. इस सुविधा को डेलिगेशन कहा जाता है.
जब भी मुमकिन होता है, Chrome, खरीदार के शिपिंग पते और संपर्क जानकारी को उस Android पेमेंट ऐप्लिकेशन को उपलब्ध कराता है जिसे इस्तेमाल किया जा रहा है. इस तरह के काम करने से, चेकआउट के दौरान होने वाली समस्याएं कम हो जाती हैं.
खरीदार के चुने गए शिपिंग पते और शिपिंग के विकल्प के आधार पर, कारोबारी या कंपनी की वेबसाइट पर, शिपिंग के विकल्पों और कुल कीमत को डाइनैमिक तौर पर अपडेट किया जा सकता है.
पहले से मौजूद Android पेमेंट ऐप्लिकेशन में, काम का ऐक्सेस देने की सुविधा जोड़ने के लिए, यह तरीका अपनाएं:
- इस्तेमाल किए जा सकने वाले ऐक्सेस का एलान करना.
- पेमेंट के ज़रूरी विकल्पों के लिए,
PAY
इंटेंट के अतिरिक्त को पार्स करें. - पेमेंट के जवाब में ज़रूरी जानकारी दें.
- [ज़रूरी नहीं] डाइनैमिक फ़्लो के साथ काम करता है:
उन लोगों के बारे में बताएं जिनका इस्तेमाल किया जा सकता है
ब्राउज़र को अतिरिक्त जानकारी की उस सूची की जानकारी होनी चाहिए जो आपका पेमेंट ऐप्लिकेशन दे सकता है, ताकि वह उस जानकारी को आपके ऐप्लिकेशन को सौंप सके. अपने ऐप्लिकेशन के AndroidManifest.xml में, काम करने वाले ऐक्सेस का एलान <meta-data>
के तौर पर करें.
<activity
android:name=".PaymentActivity"
…
<meta-data
android:name="org.chromium.payment_supported_delegations"
android:resource="@array/supported_delegations" />
</activity>
<resource>
, स्ट्रिंग की ऐसी सूची होनी चाहिए जिसे इन मान्य वैल्यू में से चुना गया हो:
[ "payerName", "payerEmail", "payerPhone", "shippingAddress" ]
यहां दिए गए उदाहरण में, सिर्फ़ शिपिंग का पता और पेमेंट करने वाले का ईमेल पता दिया जा सकता है.
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string-array name="supported_delegations">
<item>payerEmail</item>
<item>shippingAddress</item>
</string-array>
</resources>
पेमेंट के ज़रूरी विकल्पों के लिए, PAY
इंटेंट के अतिरिक्त को पार्स करें
कारोबारी, paymentOptions
डिक्शनरी का इस्तेमाल करके, ज़रूरी जानकारी दे सकता है. Chrome उन ज़रूरी विकल्पों की सूची उपलब्ध कराएगा जो आपके ऐप्लिकेशन में उपलब्ध हो सकते हैं. इसके लिए, आपको PAY
गतिविधि में इन पैरामीटर को इंटेंट एक्सटेंशन के तौर पर पास करना होगा.
paymentOptions
paymentOptions
, व्यापारी/कंपनी/कारोबारी के बताए गए पेमेंट के विकल्पों का सबसेट है. आपके ऐप्लिकेशन ने इन विकल्पों के लिए सहायता देने का एलान किया है.
val paymentOptions: Bundle? = extras.getBundle("paymentOptions")
val requestPayerName: Boolean? = paymentOptions?.getBoolean("requestPayerName")
val requestPayerPhone: Boolean? = paymentOptions?.getBoolean("requestPayerPhone")
val requestPayerEmail: Boolean? = paymentOptions?.getBoolean("requestPayerEmail")
val requestShipping: Boolean? = paymentOptions?.getBoolean("requestShipping")
val shippingType: String? = paymentOptions?.getString("shippingType")
इसमें ये पैरामीटर शामिल हो सकते हैं:
requestPayerName
- बूलियन से पता चलता है कि पैसे चुकाने वाले का नाम डालना ज़रूरी है या नहीं.requestPayerPhone
- बूलियन से पता चलता है कि पैसे चुकाने वाले के फ़ोन की ज़रूरत है या नहीं.requestPayerEmail
- बूलियन से पता चलता है कि पैसे चुकाने वाले के ईमेल पते की ज़रूरत है या नहीं.requestShipping
- बूलियन से पता चलता है कि शिपिंग की जानकारी देना ज़रूरी है या नहीं.shippingType
- शिपिंग का टाइप दिखाने वाली स्ट्रिंग. शिपिंग का टाइप"shipping"
,"delivery"
या"pickup"
हो सकता है. लोगों का पता या शिपिंग के विकल्प चुनते समय, आपका ऐप्लिकेशन अपने यूज़र इंटरफ़ेस (यूआई) में इस संकेत का इस्तेमाल कर सकता है.
shippingOptions
shippingOptions
, व्यापारी/कंपनी/कारोबारी के बताए गए शिपिंग विकल्पों का पार्स किया जा सकने वाला कलेक्शन है. यह पैरामीटर सिर्फ़ तब दिखेगा, जब paymentOptions.requestShipping ==
true
.
val shippingOptions: List<ShippingOption>? =
extras.getParcelableArray("shippingOptions")?.mapNotNull {
p -> from(p as Bundle)
}
शिपिंग का हर विकल्प एक Bundle
है. इसमें ये कुंजियां भी शामिल हैं.
id
- शिपिंग के विकल्प का आइडेंटिफ़ायर.label
- उपयोगकर्ता को दिखाया गया शिपिंग के विकल्प का लेबल.amount
- शिपिंग के लिए खरीदार से लिए जाने वाले शुल्क के बंडल में, स्ट्रिंग वैल्यू वालीcurrency
औरvalue
कुंजियां हैं.currency
, शिपिंग के लिए खरीदार से लिए जाने वाले शुल्क की मुद्रा दिखाता है. यह वैल्यू ISO4217 फ़ॉर्मैट में, तीन अक्षरों वाले ऐल्फ़ा कोड के तौर पर मौजूद हैvalue
, शिपिंग के लिए खरीदार से लिए जाने वाले शुल्क की वैल्यू को दशमलव की मान्य मॉनेटरी वैल्यू के तौर पर दिखाता है
selected
- जब पेमेंट ऐप्लिकेशन में शिपिंग के विकल्प दिखाए जाते हैं, तब शिपिंग का विकल्प चुना जाना चाहिए या नहीं.
selected
के अलावा, सभी कुंजियों में स्ट्रिंग वैल्यू होती हैं. selected
की बूलियन वैल्यू है.
val id: String = bundle.getString("id")
val label: String = bundle.getString("label")
val amount: Bundle = bundle.getBundle("amount")
val selected: Boolean = bundle.getBoolean("selected", false)
पेमेंट के जवाब में ज़रूरी जानकारी देना
PAY
पर की गई गतिविधि के जवाब में, आपके ऐप्लिकेशन को ज़रूरी अतिरिक्त जानकारी शामिल करनी चाहिए.
ऐसा करने के लिए, नीचे दिए गए पैरामीटर को इंटेंट एक्स्ट्रा के तौर पर बताना ज़रूरी है:
payerName
- पैसे चुकाने वाले का पूरा नाम.paymentOptions.requestPayerName
के सही होने पर, यह स्ट्रिंग खाली नहीं होनी चाहिए.payerPhone
- पैसे चुकाने वाले का फ़ोन नंबर.paymentOptions.requestPayerPhone
के सही होने पर, यह स्ट्रिंग खाली नहीं होनी चाहिए.payerEmail
- पैसे चुकाने वाले का ईमेल पता.paymentOptions.requestPayerEmail
के सही होने पर, यह एक ऐसी स्ट्रिंग होनी चाहिए जो खाली न हो.shippingAddress
- उपयोगकर्ता की ओर से दिया गया शिपिंग पता. अगरpaymentOptions.requestShipping
सही है, तो यह एक ऐसा बंडल होना चाहिए जो खाली न हो. बंडल में ये कुंजियां होनी चाहिए, जो घर या ऑफ़िस के पते में अलग-अलग हिस्सों को दिखाती हैं.city
countryCode
dependentLocality
organization
phone
postalCode
recipient
region
sortingCode
addressLine
addressLine
के अलावा, सभी कुंजियों में स्ट्रिंग वैल्यू होती हैं.addressLine
, स्ट्रिंग का कलेक्शन होता है.
shippingOptionId
- उपयोगकर्ता के चुने गए शिपिंग विकल्प का आइडेंटिफ़ायर.paymentOptions.requestShipping
के सही होने पर, यह स्ट्रिंग खाली नहीं होनी चाहिए.
पेमेंट के जवाब की पुष्टि करें
अगर शुरू किए गए पेमेंट ऐप्लिकेशन से मिले पेमेंट के जवाब की गतिविधि का नतीजा, RESULT_OK
पर सेट किया गया है, तो Chrome अपनी अन्य चीज़ों में ज़रूरी अतिरिक्त जानकारी की जांच करेगा. अगर पुष्टि नहीं हो पाती है, तो Chrome request.show()
से, डेवलपर को भेजे जाने वाले इन गड़बड़ियों के मैसेज में से किसी एक के साथ अस्वीकार किया गया प्रॉमिस दिखाएगा:
'Payment app returned invalid response. Missing field "payerEmail".'
'Payment app returned invalid response. Missing field "payerName".'
'Payment app returned invalid response. Missing field "payerPhone".'
'Payment app returned invalid shipping address in response.'
'... is not a valid CLDR country code, should be 2 upper case letters [A-Z]'
'Payment app returned invalid response. Missing field "shipping option".'
नीचे दिया गया कोड सैंपल, एक मान्य जवाब का उदाहरण है:
fun Intent.populateRequestedPaymentOptions() {
if (requestPayerName) {
putExtra("payerName", "John Smith")
}
if (requestPayerPhone) {
putExtra("payerPhone", "4169158200")
}
if (requestPayerEmail) {
putExtra("payerEmail", "john.smith@gmail.com")
}
if(requestShipping) {
val address: Bundle = Bundle()
address.putString("countryCode", "CA")
val addressLines: Array<String> =
arrayOf<String>("111 Richmond st. West")
address.putStringArray("addressLines", addressLines)
address.putString("region", "Ontario")
address.putString("city", "Toronto")
address.putString("postalCode", "M5H2G4")
address.putString("recipient", "John Smith")
address.putString("phone", "4169158200")
putExtra("shippingAddress", address)
putExtra("shippingOptionId", "standard")
}
}
ज़रूरी नहीं: डाइनैमिक फ़्लो के साथ काम करता है
कभी-कभी लेन-देन की कुल लागत बढ़ जाती है. उदाहरण के लिए, जब कोई व्यक्ति एक्सप्रेस शिपिंग का विकल्प चुनता है या जब उपयोगकर्ता अंतरराष्ट्रीय शिपिंग पता चुनता है, तो शिपिंग के उपलब्ध विकल्पों की सूची या उनकी कीमतें बदल जाती हैं. जब आपका ऐप्लिकेशन, उपयोगकर्ता का चुना गया शिपिंग पता या विकल्प उपलब्ध कराता है, तो वह व्यापारी/कंपनी/कारोबारी को शिपिंग पते या विकल्प में होने वाले बदलावों के बारे में बता सकता है. साथ ही, उसे पेमेंट के तरीके की अपडेट की गई जानकारी (व्यापारी/कंपनी की ओर से उपलब्ध कराई गई) दिखानी चाहिए.
एआईडीएल
व्यापारी/कंपनी को नए बदलावों की सूचना देने के लिए, Chrome की AndroidManifest.xml में बताई गई PaymentDetailsUpdateService
सेवा का इस्तेमाल करें. इस सेवा का इस्तेमाल करने के लिए, नीचे दिए गए कॉन्टेंट वाली दो एआईडीएल फ़ाइलें बनाएं:
app/src/main/aidl/org/chromium/components/payments/IPaymentDetailsUpdateService
package org.chromium.components.payments;
import android.os.Bundle;
interface IPaymentDetailsUpdateServiceCallback {
oneway void updateWith(in Bundle updatedPaymentDetails);
oneway void paymentDetailsNotUpdated();
}
app/src/main/aidl/org/chromium/components/payments/IPaymentDetailsUpdateServiceCallback
package org.chromium.components.payments;
import android.os.Bundle;
import org.chromium.components.payments.IPaymentDetailsUpdateServiceCallback;
interface IPaymentDetailsUpdateService {
oneway void changePaymentMethod(in Bundle paymentHandlerMethodData,
IPaymentDetailsUpdateServiceCallback callback);
oneway void changeShippingOption(in String shippingOptionId,
IPaymentDetailsUpdateServiceCallback callback);
oneway void changeShippingAddress(in Bundle shippingAddress,
IPaymentDetailsUpdateServiceCallback callback);
}
उपयोगकर्ता के चुने गए पेमेंट के तरीके, शिपिंग पते या शिपिंग के विकल्प में हुए बदलावों के बारे में कारोबारी को सूचना दें
private fun bind() {
// The action is introduced in Chrome version 92, which supports the service in Chrome
// and other browsers (e.g., WebLayer).
val newIntent = Intent("org.chromium.intent.action.UPDATE_PAYMENT_DETAILS")
.setPackage(callingBrowserPackage)
if (packageManager.resolveService(newIntent, PackageManager.GET_RESOLVED_FILTER) == null) {
// Fallback to Chrome-only approach.
newIntent.setClassName(
callingBrowserPackage,
"org.chromium.components.payments.PaymentDetailsUpdateService")
newIntent.action = IPaymentDetailsUpdateService::class.java.name
}
isBound = bindService(newIntent, connection, Context.BIND_AUTO_CREATE)
}
private val connection = object : ServiceConnection {
override fun onServiceConnected(className: ComponentName, service: IBinder) {
val service = IPaymentDetailsUpdateService.Stub.asInterface(service)
try {
if (isOptionChange) {
service?.changeShippingOption(selectedOptionId, callback)
} else (isAddressChange) {
service?.changeShippingAddress(selectedAddress, callback)
} else {
service?.changePaymentMethod(methodData, callback)
}
} catch (e: RemoteException) {
// Handle the remote exception
}
}
}
सेवा शुरू करने के इंटेंट के लिए इस्तेमाल किए जाने वाले callingPackageName
में, इनमें से कोई एक वैल्यू हो सकती है. यह इस बात पर निर्भर करता है कि पेमेंट का अनुरोध किस ब्राउज़र ने किया है.
Chrome चैनल | पैकेज का नाम |
---|---|
स्थिर दिखाना |
"com.android.chrome"
|
बीटा वर्शन |
"com.chrome.beta"
|
डेव |
"com.chrome.dev"
|
कैनेरी |
"com.chrome.canary"
|
Chromium |
"org.chromium.chrome"
|
Google क्विक सर्च बॉक्स (Weblayer एम्बेडर) |
"com.google.android.googlequicksearchbox"
|
changePaymentMethod
उपयोगकर्ता के चुने गए पेमेंट के तरीके में हुए बदलावों के बारे में व्यापारी/कंपनी को सूचना देता है. paymentHandlerMethodData
बंडल में methodName
और वैकल्पिक details
कुंजियां शामिल हैं. इन दोनों की वैल्यू में स्ट्रिंग की वैल्यू दी गई हैं. Chrome एक ऐसे बंडल की जांच करेगा जो खाली नहीं है methodName
और अगर पुष्टि नहीं हो पाती है, तो callback.updateWith
के ज़रिए नीचे दिए गए गड़बड़ी के मैसेज में से किसी एक के साथ updatePaymentDetails
भेजा जाएगा.
'Method data required.'
'Method name required.'
changeShippingOption
व्यापारी/कंपनी को, उपयोगकर्ता के चुने गए शिपिंग विकल्प में हुए बदलावों के बारे में सूचना देता है.
shippingOptionId
, व्यापारी/कंपनी/कारोबारी की ओर से बताए गए शिपिंग विकल्पों में से किसी एक का आइडेंटिफ़ायर होना चाहिए. अगर पुष्टि नहीं हो पाती है, तो Chrome ऐसे shippingOptionId
की जांच करेगा जो खाली नहीं है और callback.updateWith
के ज़रिए इस गड़बड़ी के मैसेज के साथ updatePaymentDetails
भेजेगा.
'Shipping option identifier required.'
changeShippingAddress
उपयोगकर्ता के दिए गए शिपिंग पते में हुए बदलाव के बारे में, व्यापारी/कंपनी को सूचना देता है. Chrome, मान्य countryCode
के साथ ऐसे shippingAddress
बंडल की जांच करेगा जो खाली नहीं है और अगर पुष्टि नहीं हो पाती है, तो गड़बड़ी के इस मैसेज के साथ updatePaymentDetails
भेजेगा.callback.updateWith
'Payment app returned invalid shipping address in response.'
अमान्य स्थिति की गड़बड़ी का मैसेज
अगर बदलाव करने का कोई भी अनुरोध मिलने पर, Chrome को कोई अमान्य स्थिति दिखती है, तो वह छिपाने के लिए बदलाव किए गए updatePaymentDetails
बंडल के साथ callback.updateWith
को कॉल करेगा. बंडल में "Invalid state"
वाली सिर्फ़ error
कुंजी होगी.
अमान्य स्थिति के उदाहरण यहां दिए गए हैं:
- जब Chrome पिछले बदलाव (जैसे कि किसी चल रहे बदलाव इवेंट) के लिए अब भी व्यापारी के जवाब का इंतज़ार कर रहा हो.
- पेमेंट ऐप्लिकेशन से मिलने वाला शिपिंग के विकल्प का आइडेंटिफ़ायर, व्यापारी/कंपनी/कारोबारी के तय किए गए शिपिंग विकल्पों में से किसी से भी जुड़ा नहीं है.
कारोबारी से पेमेंट के तरीके की अपडेट की गई जानकारी पाना
private fun unbind() {
if (isBound) {
unbindService(connection)
isBound = false
}
}
private val callback: IPaymentDetailsUpdateServiceCallback =
object : IPaymentDetailsUpdateServiceCallback.Stub() {
override fun paymentDetailsNotUpdated() {
// Payment request details have not changed.
unbind()
}
override fun updateWith(updatedPaymentDetails: Bundle) {
newPaymentDetails = updatedPaymentDetails
unbind()
}
}
updatePaymentDetails
बंडल, PaymentRequestDetailsUpdate
WebIDL डिक्शनरी के जैसा है (modifiers
फ़ील्ड को छिपाने के लिए बदलाव करने के बाद) और इसमें ये वैकल्पिक कुंजियां होती हैं:
total
-currency
औरvalue
कुंजियों वाला बंडल. दोनों कुंजियों में स्ट्रिंग की वैल्यू हैंshippingOptions
- शिपिंग के विकल्पों का पार्स किया जा सकने वाला कलेक्शनerror
- ऐसी स्ट्रिंग जिसमें गड़बड़ी का सामान्य मैसेज होता है. उदाहरण के लिए, जबchangeShippingOption
शिपिंग के विकल्प का मान्य आइडेंटिफ़ायर नहीं देता हैstringifiedPaymentMethodErrors
- पेमेंट के तरीके की पुष्टि से जुड़ी गड़बड़ियां दिखाने वाली JSON स्ट्रिंगaddressErrors
- शिपिंग पते और स्ट्रिंग की वैल्यू से मिलती-जुलती वैकल्पिक कुंजियों वाला बंडल. हर कुंजी, शिपिंग पते से जुड़ी गड़बड़ी की पुष्टि करती है.
कुंजी मौजूद न होने का मतलब है कि उसकी वैल्यू में बदलाव नहीं हुआ है.