इस दस्तावेज़ में, Google Play Billing Library के लिए रिलीज़ नोट दिए गए हैं.
Google Play Billing Library 8.2.0 रिलीज़ (09-12-2025)
Google Play Billing Library का वर्शन 8.2.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
बाहरी कॉन्टेंट के लिंक और बाहरी ऑफ़र के लिए नए एपीआई:
- इन प्रोग्राम के लिए
BillingClientसेट अप करने के लिए,enableBillingProgramजोड़ा गया. - उपयोगकर्ता की ज़रूरी शर्तें पूरी होने की स्थिति का पता लगाने के लिए,
isBillingProgramAvailableAsyncजोड़ा गया. - रिपोर्टिंग के लिए इस्तेमाल किए जाने वाले बाहरी लेन-देन के टोकन को बनाने के लिए,
createBillingProgramReportingDetailsAsyncजोड़ा गया. - डिजिटल कॉन्टेंट के ऑफ़र या ऐप्लिकेशन डाउनलोड करने के लिए, बाहरी लिंक शुरू करने की सुविधा
launchExternalLinkजोड़ी गई है.
- इन प्रोग्राम के लिए
ऐप्लिकेशन के बाहर ऑफ़र वगैरह प्रमोट करने के प्रोग्राम में हुए बदलाव:
- ऐप्लिकेशन के बाहर ऑफ़र वगैरह प्रमोट करने के प्रोग्राम की नीतियों में बदलाव हुए हैं. ज़्यादा जानकारी के लिए, प्रोग्राम में हुए बदलाव देखें. नए एपीआई की मदद से, बाहरी ऑफ़र के फ़्लो लॉन्च करने का तरीका जानने के लिए, इंटिग्रेशन गाइड देखें.
BillingClient.Builder.enableExternalOfferएपीआई को बंद कर दिया गया है.isExternalOfferAvailableAsyncएपीआई को बंद कर दिया गया है.createExternalOfferReportingDetailsAsyncएपीआई को बंद कर दिया गया है.showExternalOfferInformationDialogएपीआई को बंद कर दिया गया है.
Google Play Billing Library 8.1.0 रिलीज़ (06-11-2025)
Google Play Billing Library का वर्शन 8.1.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
निलंबित की गई सदस्यताएं
सदस्यताओं के लिए क्वेरी करते समय निलंबित की गई सदस्यताओं को शामिल करने के लिए,
BillingClient.queryPurchasesAsync()तरीके में एक नया पैरामीटर जोड़ा गया है. निलंबित की गई सदस्यताएं अब भी उपयोगकर्ता के खाते से जुड़ी रहती हैं, लेकिन वे चालू नहीं होतीं. ऐसा इसलिए होता है, क्योंकि उपयोगकर्ता ने सदस्यता रोकी होती है या सदस्यता के नवीनीकरण के लिए इस्तेमाल किए गए पेमेंट के तरीके को अस्वीकार कर दिया गया होता है.लिसनर में वापस भेजा गया
Purchaseऑब्जेक्ट, निलंबित की गई सभी सदस्यताओं के लिएisSuspended() = trueदिखाएगा. ऐसे में, आपको खरीदी गई सदस्यता का ऐक्सेस नहीं देना चाहिए. इसके बजाय, उपयोगकर्ता को सदस्यता केंद्र पर जाने के लिए कहें. यहां उपयोगकर्ता, पेमेंट के तरीकों को मैनेज कर सकता है या सदस्यता को फिर से चालू करने के लिए, उसे रोके जाने की स्थिति से हटा सकता है.सदस्यताओं से जुड़े अपडेट:
BillingFlowParams.ProductDetailsParamsऑब्जेक्ट में अबsetSubscriptionProductReplacementParams()तरीका उपलब्ध है. इसमें प्रॉडक्ट लेवल पर, बदलने के लिए जानकारी दी जा सकती है.SubscriptionProductReplacementParamsऑब्जेक्ट में दो सेटर तरीके होते हैं:setOldProductId: वह पुराना प्रॉडक्ट जिसे मौजूदाProductDetailsमें मौजूद प्रॉडक्ट से बदलना है.setReplacementMode: यह आइटम लेवल पर सामान बदलने का तरीका है. ये मोड, SubscriptionUpdateParams के जैसे ही होते हैं. हालांकि, वैल्यू मैपिंग को अपडेट कर दिया गया है. बदलाव करने का नया मोडKEEP_EXISTINGपेश किया गया है. इसकी मदद से, किसी आइटम के लिए पेमेंट के मौजूदा शेड्यूल में बदलाव नहीं किया जा सकता.
SubscriptionUpdateParams setSubscriptionReplacementMode को बंद कर दिया जाएगा. इसके बजाय, आपको
SubscriptionProductReplacementParams.setReplacementModeका इस्तेमाल करना चाहिए.
minSdkVersionको 23 पर अपडेट किया गया.वन-टाइम प्रॉडक्ट के लिए, पहले से ऑर्डर करने की सुविधा देने वाले एपीआई चालू किए गए
ProductDetails.oneTimePurchaseOfferDetails.getPreorderDetails()एपीआई, पहले से किए गए ऑर्डर की जानकारी पाने के लिए अब इस्तेमाल किया जा सकता है.Google Play Billing Library अब Kotlin वर्शन 2.2.0 के साथ काम करती है.
Google Play Billing Library 8.0.0 रिलीज़ (30-06-2025)
Google Play Billing Library और Kotlin एक्सटेंशन का 8.0.0 वर्शन अब उपलब्ध है.
परिवर्तनों का सारांश
ऐप्लिकेशन में खरीदे जा सकने वाले आइटम को अब वन-टाइम प्रॉडक्ट कहा जाएगा.
वन-टाइम प्रॉडक्ट के लिए, खरीदारी के कई विकल्प और ऑफ़र.
अब वन-टाइम प्रॉडक्ट के लिए, खरीदारी के कई विकल्प और ऑफ़र उपलब्ध कराए जा सकते हैं. इससे आपको अपने प्रॉडक्ट बेचने के तरीके में ज़्यादा सहूलियत मिलती है और उन्हें मैनेज करते समय आने वाली समस्याएं कम होती हैं.
queryProductDetailsAsync()तरीके को बेहतर बनाया गया है.PBL 8.0.0 से पहले,
queryProductDetailsAsync()तरीके से ऐसे प्रॉडक्ट नहीं मिलते थे जिन्हें फ़ेच नहीं किया जा सकता. ऐसा इन वजहों से हो सकता है: प्रॉडक्ट नहीं मिला या उपयोगकर्ता के लिए कोई ऑफ़र उपलब्ध नहीं है. PBL 8.0.0 के साथ, फ़ेच नहीं किए गए प्रॉडक्ट को प्रॉडक्ट-लेवल के नए स्टेटस कोड के साथ दिखाया जाता है. इससे फ़ेच नहीं किए गए प्रॉडक्ट के बारे में जानकारी मिलती है. ध्यान दें किProductDetailsResponseListener.onProductDetailsResponse()के हस्ताक्षर में बदलाव हुआ है. इसलिए, आपको अपने ऐप्लिकेशन में बदलाव करने होंगे. ज़्यादा जानकारी के लिए, नतीजे को प्रोसेस करना लेख पढ़ें.सेवा से अपने-आप फिर से कनेक्ट होने की सुविधा.
BillingClient.Builder.enableAutoServiceReconnection()builder पैरामीटर की मदद से, डेवलपर सेवा से अपने-आप फिर से कनेक्ट होने की सुविधा के लिए ऑप्ट-इन कर सकते हैं. इससे कनेक्शन को मैनेज करना आसान हो जाता है. ऐसा इसलिए, क्योंकि यह Play Billing Service से अपने-आप फिर से कनेक्ट हो जाता है. साथ ही, सेवा के डिसकनेक्ट होने पर, मैन्युअल तरीके सेstartConnection()को कॉल करने की ज़रूरत नहीं होती. ज़्यादा जानकारी के लिए, कनेक्शन अपने-आप फिर से चालू होने की सुविधा लेख पढ़ें.launchBillingFlow()तरीके के लिए सब-रिस्पॉन्स कोड.launchBillingFlow()से मिले BillingResult में अब सब-रिस्पॉन्स कोड फ़ील्ड शामिल होगा. यह फ़ील्ड सिर्फ़ कुछ मामलों में भरा जाएगा, ताकि फ़ेल होने की वजह के बारे में ज़्यादा जानकारी दी जा सके. PBL 8.0.0 में, PAYMENT_DECLINED_DUE_TO_INSUFFICIENT_FUNDS सब-कोड तब दिखता है, जब उपयोगकर्ता के खाते में मौजूद रकम, खरीदे जाने वाले आइटम की कीमत से कम होती है.queryPurchaseHistory()तरीका हटा दिया गया है.queryPurchaseHistory()तरीके को पहले सेवा से बाहर के तौर पर मार्क किया गया था. अब इसे हटा दिया गया है. इसके बजाय, कौनसे एपीआई इस्तेमाल किए जा सकते हैं, इस बारे में जानने के लिए खरीदारी के इतिहास के बारे में क्वेरी करना लेख पढ़ें.querySkuDetailsAsync()तरीका हटा दिया गया है.querySkuDetailsAsync()तरीके को पहले सेवा से बाहर के तौर पर मार्क किया गया था. अब इसे हटा दिया गया है. इसके बजाय, आपको queryProductDetailsAsync का इस्तेमाल करना चाहिए.BillingClient.Builder.enablePendingPurchases()तरीका हटा दिया गया है.enablePendingPurchases()पैरामीटर के बिना इस्तेमाल किए जाने वालेenablePendingPurchases()तरीके को पहले सेवा से बाहर के तौर पर मार्क किया गया था. अब इसे हटा दिया गया है. इसके बजाय, आपकोenablePendingPurchases(PendingPurchaseParams params)का इस्तेमाल करना चाहिए. ध्यान दें कि अब इस्तेमाल नहीं किया जा सकने वालाenablePendingPurchases(),enablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())के बराबर काम करता है.queryPurchasesAsync()के उस ओवरलोड किए गए तरीके को हटा दिया गया है जो skuType लेता है.queryPurchasesAsync(String skuType, PurchasesResponseListener listener)तरीके को पहले सेवा से बाहर के तौर पर मार्क किया गया था. अब इसे हटा दिया गया है. इसके अलावा,queryPurchasesAsync(QueryPurchasesParams queryPurchasesParams, PurchasesResponseListener listener)का इस्तेमाल करें.
Google Play Billing Library 7.1.1 रिलीज़ (03-10-2024)
Google Play Billing Library का वर्शन 7.1.1 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
गड़बड़ियां ठीक की गईं
- Play Billing Library 7.1.0 में, टेस्टिंग
BillingResultरिस्पॉन्स कोड से जुड़ी गड़बड़ी को ठीक किया गया है.
Google Play Billing Library 7.1.0 रिलीज़ (19-09-2024)
Google Play Billing Library का वर्शन 7.1.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
- कनेक्शन की स्थिति और मैनेजमेंट से जुड़ी थ्रेड की सुरक्षा को बेहतर बनाया गया है.
- जांच के लिए, [
BillingResult][billing-result] रिस्पॉन्स कोड में कुछ बदलाव किए गए हैं. ये बदलाव, Play Billing Library 7.1.1 में पूरी तरह से रिलीज़ किए गए हैं. इस सुविधा का इस्तेमाल करके, अपने इंटिग्रेशन को टेस्ट करने के लिए, आपको Play Billing Library 7.1.1 पर अपग्रेड करना होगा. एक बग मौजूद है. इसका असर सिर्फ़ उन ऐप्लिकेशन पर पड़ेगा जिनमें [बिलिंग ओवरराइड की टेस्टिंग चालू है][enable-billing-overrides-testing]. हालांकि, इससे ऐप्लिकेशन के सामान्य इस्तेमाल पर कोई असर नहीं पड़ेगा. ज़्यादा जानकारी के लिए,BillingResultरिस्पॉन्स कोड की जांच करना लेख पढ़ें. [billing-result]: /reference/com/android/billingclient/api/BillingResult [enable-billing-overrides-testing]: /google/play/billing/test-response-codes#enable-billing-overrides-testing
Google Play Billing Library 7.0.0 रिलीज़ (14-05-2024)
Google Play Billing Library का वर्शन 7.0.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
किस्तों में सदस्यता लेने की सुविधा के लिए, एपीआई जोड़े गए हैं.
- उन बुनियादी प्लान के लिए [
ProductDetails.InstallmentPlanDetails][installment-details] एट्रिब्यूट जोड़ा गया है जिन्हें उपयोगकर्ता किस्तों में खरीद सकते हैं. इस एपीआई की मदद से, आपका ऐप्लिकेशन इंस्टॉलमेंट प्लान और उसके कमिटमेंट सेटअप की पहचान कर पाता है. इससे वह उपयोगकर्ता को इससे जुड़ी जानकारी दे पाता है. ज़्यादा जानने के लिए, [सदस्यता की किस्तों से जुड़ी गाइड][installments] देखें. [installment-details]: /reference/com/android/billingclient/api/ProductDetails.InstallmentPlanDetails [installments]: /google/play/billing/subscriptions#installments
- उन बुनियादी प्लान के लिए [
PendingPurchasesParamsऔरBillingClient.Builder.enablePendingPurchases(PendingPurchaseParams)कोBillingClient.Builder.enablePendingPurchases()की जगह इस्तेमाल करने के लिए जोड़ा गया है. इस रिलीज़ में,BillingClient.Builder.enablePendingPurchases()को बंद कर दिया गया है.- बंद किए गए
enablePendingPurchases()फ़ंक्शन का काम,enablePendingPurchases(PendingPurchasesParams.newBuilder().enableOneTimeProducts().build())फ़ंक्शन के जैसा ही है.
- बंद किए गए
सदस्यता के प्रीपेड प्लान के लिए, ऐसे पेमेंट को मैनेज करने के लिए एपीआई जोड़े गए हैं जिन्हें मंज़ूरी नहीं मिली है:
- सदस्यता के प्रीपेड प्लान के लिए, लंबित लेन-देन की सुविधा चालू करने के लिए,
PendingPurchasesParams.Builder.enablePrepaidPlans()के साथBillingClient.Builder.enablePendingPurchases(PendingPurchaseParams)का इस्तेमाल करें. सहायता जोड़ने के दौरान, पक्का करें कि आपका ऐप्लिकेशन सदस्यता के लाइफ़साइकल को भी सही तरीके से मैनेज करता हो. ज़्यादा जानने के लिए, खरीदारी के लंबित रहने की स्थिति से जुड़ी हमारी गाइड देखें. Purchase.PendingPurchaseUpdateऔरPurchase.getPendingPurchaseUpdate()को जोड़ा गया है. इनकी मदद से, टॉप-अप या अपग्रेड या डाउनग्रेड करने के लिए, मौजूदा सदस्यता से जुड़ी जानकारी को वापस पाया जा सकता है.
- सदस्यता के प्रीपेड प्लान के लिए, लंबित लेन-देन की सुविधा चालू करने के लिए,
BillingClient.Builder.enableAlternativeBilling(),AlternativeBillingListener, औरAlternativeChoiceDetailsको हटा दिया गया है .- डेवलपर को इसके बजाय, लिसनर कॉलबैक में
UserChoiceBillingListenerऔरUserChoiceDetailsके साथBillingClient.Builder.enableUserChoiceBilling()का इस्तेमाल करना चाहिए.
- डेवलपर को इसके बजाय, लिसनर कॉलबैक में
BillingFlowParams.ProrationMode,BillingFlowParams.SubscriptionUpdateParams.Builder.setReplaceProrationMode(), औरBillingFlowParams.SubscriptionUpdateParams.Builder.setReplaceSkusProrationMode()को हटा दिया गया है. - डेवलपर को इसके बजाय,BillingFlowParams.SubscriptionUpdateParams.Builder#setSubscriptionReplacementMode(int)के साथBillingFlowParams.SubscriptionUpdateParams.ReplacementModeका इस्तेमाल करना चाहिए. -BillingFlowParams.SubscriptionUpdateParams.Builder.setReplaceProrationMode(). -BillingFlowParams.SubscriptionUpdateParams.Builder.setReplaceSkusProrationMode().BillingFlowParams.SubscriptionUpdateParams.Builder#setOldSkuPurchaseToken()को हटाया गया. - डेवलपर को इसके बजाय,BillingFlowParams.SubscriptionUpdateParams.Builder#setOldPurchaseToken(java.lang.String)का इस्तेमाल करना चाहिए.BillingClient.queryPurchaseHistoryAsync()अब सेवा में नहीं है. इसे आने वाले वर्शन से हटा दिया जाएगा. डेवलपर को इसके बजाय, इन विकल्पों का इस्तेमाल करना चाहिए:- स्वीकार की गई और लंबित खरीदारी: चालू खरीदारी की जानकारी पाने के लिए,
BillingClient.queryPurchasesAsync()का इस्तेमाल करें. - इस्तेमाल की गई खरीदारी: डेवलपर को अपने सर्वर पर, इस्तेमाल की गई खरीदारी का ट्रैक रखना चाहिए.
- रद्द की गई खरीदारी: voided-purchases डेवलपर एपीआई का इस्तेमाल करें.
- ज़्यादा जानकारी के लिए, खरीदारी के इतिहास के बारे में क्वेरी करना लेख पढ़ें
- स्वीकार की गई और लंबित खरीदारी: चालू खरीदारी की जानकारी पाने के लिए,
BillingFlowParams.ProductDetailsParams.setOfferToken()अब डेवलपर के खालीofferTokenतय करने पर, अपवाद दिखाता है.minSdkVersionको 21 औरtargetSdkVersionको 34 पर अपडेट किया गया.
Google Play Billing Library 6.2.1 रिलीज़ (16-04-2024)
Google Play Billing Library का वर्शन 6.2.1 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
BillingClient.showAlternativeBillingOnlyInformationDialog()में मौजूद गड़बड़ी को ठीक किया गया है. इस गड़बड़ी की वजह से, डायलॉग पूरा होने पर कुछ मामलों मेंAlternativeBillingOnlyInformationDialogListenerको कॉल नहीं किया जा सकता था.
Google Play Billing Library 6.2.0 रिलीज़ (06-03-2024)
Google Play Billing Library का वर्शन 6.2.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
- बाहरी ऑफ़र के लिए एपीआई जोड़े गए
- बाहरी ऑफ़र दिखाने की सुविधा चालू करने के लिए,
BillingClient.Builder.enableExternalOffer()को जोड़ा गया है. - बाहरी ऑफ़र दिखाने की सुविधा उपलब्ध है या नहीं, यह देखने के लिए
BillingClient.isExternalOfferAvailableAsync()को जोड़ा गया है. - जोड़ा गया
BillingClient.showExternalOfferInformationDialog()ताकि लोगों को ऐप्लिकेशन से बाहर ले जाने से पहले, उन्हें सूचना वाला डायलॉग दिखाया जा सके. - जोड़ा गया
BillingClient.createExternalOfferReportingDetailsAsync()बाहरी ऑफ़र के ज़रिए किए गए लेन-देन की रिपोर्ट करने के लिए ज़रूरी पेलोड बनाने के लिए.
- बाहरी ऑफ़र दिखाने की सुविधा चालू करने के लिए,
Google Play Billing Library 6.1.0 रिलीज़ (14-11-2023)
Google Play Billing Library का वर्शन 6.1.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
- सिर्फ़ अन्य बिलिंग सिस्टम (बिना उपयोगकर्ता की पसंद के)
- की सुविधा देने वाले एपीआई जोड़े गए
- सिर्फ़ अन्य बिलिंग सिस्टम की सुविधा देने के लिए,
BillingClient.Builder.enableAlternativeBillingOnly()जोड़ा गया है. - जोड़ा गया
BillingClient.isAlternativeBillingOnlyAvailableAsync()सिर्फ़ अन्य बिलिंग सिस्टम उपलब्ध कराने की सुविधा की उपलब्धता की जांच करने के लिए. - इस कुकी को तब जोड़ा जाता है, जब सिर्फ़ बिलिंग के दूसरे तरीके का इस्तेमाल किया जा रहा हो.
BillingClient.showAlternativeBillingOnlyInformationDialog()इसका इस्तेमाल, लोगों को जानकारी देने वाला डायलॉग दिखाने के लिए किया जाता है. - जोड़ा गया
BillingClient.createAlternativeBillingOnlyReportingDetailsAsync()सिर्फ़ अन्य बिलिंग सिस्टम से किए गए लेन-देन की रिपोर्ट करने के लिए ज़रूरी पेलोड बनाने के लिए.
- सिर्फ़ अन्य बिलिंग सिस्टम की सुविधा देने के लिए,
- उपयोगकर्ता की पसंद के बिलिंग सिस्टम वाले एपीआई अपडेट किए गए
UserChoiceBillingListenerजोड़ा गया है. यह AlternativeBillingListener की जगह इस्तेमाल किया जाएगा. AlternativeBillingListener को डेप्रिकेट किया जा चुका है.AlternativeChoiceDetailsकी जगहUserChoiceDetailsजोड़ा गया है.AlternativeChoiceDetailsको अब इस्तेमाल नहीं किया जा सकता.BillingClient.Builder.enableAlternativeBilling()को बदलकरBillingClient.Builder.enableUserChoiceBilling()जोड़ा गया है.BillingClient.Builder.enableAlternativeBilling()को अब इस्तेमाल नहीं किया जा सकता.
- Google Play खाते में देश का नाम पाने के लिए,
BillingClient.getBillingConfigAsync()को जोड़ा गया.
Google Play Billing Library 6.0.1 रिलीज़ (22-06-2023)
Google Play Billing Library का वर्शन 6.0.1 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
Play Billing Library को Android 14 के साथ काम करने वाले वर्शन में अपडेट करें.
Google Play Billing Library 6.0 रिलीज़ (10-05-2023)
Google Play Billing Library का वर्शन 6.0.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
ProrationModeको बदलने के लिए, नयाReplacementModeenum जोड़ा गया.ध्यान दें कि
ProrationModeअब भी पुराने सिस्टम के साथ काम करने की सुविधा के लिए उपलब्ध है.PENDINGखरीदारी के लिए ऑर्डर आईडी हटा दिया गया है.पहले, खरीदारी लंबित होने पर भी ऑर्डर आईडी हमेशा बन जाता था. वर्शन 6.0.0 से, जिन खरीदारी को मंज़ूरी नहीं मिली है उनके लिए ऑर्डर आईडी नहीं बनाया जाएगा. साथ ही, इन खरीदारी के लिए ऑर्डर आईडी तब दिखेगा, जब खरीदारी को
PURCHASEDस्थिति में ले जाया जाएगा.queryPurchasesऔरlaunchPriceConfirmationFlowतरीके हटाए गए.queryPurchasesऔरlaunchPriceConfirmationFlowतरीकों को पहले ही सेवा से बाहर के तौर पर मार्क कर दिया गया था. अब इन्हें Play Billing Library 6.0.0 से हटा दिया गया है. डेवलपर कोqueryPurchasesके बजाय,queryPurchasesAsyncका इस्तेमाल करना चाहिए.launchPriceConfirmationFlowके विकल्पों के बारे में जानने के लिए, कीमत में बदलाव लेख पढ़ें.नेटवर्क से जुड़ी गड़बड़ी के लिए नया रिस्पॉन्स कोड जोड़ा गया.
Play Billing Library के 6.0.0 वर्शन से, नेटवर्क की गड़बड़ी के लिए एक नया रिस्पॉन्स कोड,
NETWORK_ERROR, जोड़ा गया है. यह कोड तब दिखता है, जब नेटवर्क कनेक्शन की समस्या की वजह से कोई गड़बड़ी होती है. नेटवर्क कनेक्शन से जुड़ी इन गड़बड़ियों को पहलेSERVICE_UNAVAILABLEके तौर पर रिपोर्ट किया गया था.SERVICE_UNAVAILABLEऔरSERVICE_TIMEOUTको अपडेट किया गया.PBL के 6.0.0 वर्शन से, प्रोसेसिंग में टाइम आउट होने की वजह से होने वाली गड़बड़ियों को मौजूदा
SERVICE_TIMEOUTके बजायSERVICE_UNAVAILABLEके तौर पर दिखाया जाएगा.PBL के पुराने वर्शन में, यह सुविधा पहले की तरह ही काम करती है.
SERVICE_TIMEOUTको हटाया गया.PBL 6.0.0 वर्शन से,
SERVICE_TIMEOUTनहीं दिखेगा. PBL के पिछले वर्शन अब भी यह कोड दिखाएंगे.ज़्यादा लॉगिंग की सुविधा जोड़ी गई.
Play Billing Library 6 की रिलीज़ में, अतिरिक्त लॉगिंग शामिल है. इससे एपीआई के इस्तेमाल (जैसे, अनुरोध पूरा होना और अनुरोध पूरा न होना) और सेवा कनेक्शन से जुड़ी समस्याओं के बारे में जानकारी मिलती है. इस जानकारी का इस्तेमाल, Play Billing Library की परफ़ॉर्मेंस को बेहतर बनाने के लिए किया जाएगा. साथ ही, इससे गड़बड़ियों को ठीक करने में बेहतर तरीके से मदद मिलेगी.
Google Play Billing Library 5.2.1 रिलीज़ (22-06-2023)
Google Play Billing Library का वर्शन 5.2.1 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
Play Billing Library को Android 14 के साथ काम करने वाले वर्शन में अपडेट करें.
Google Play Billing Library 5.2 रिलीज़ (06-04-2023)
Google Play Billing Library का वर्शन 5.2.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
- दक्षिण कोरिया में रहने वाले लोगों के लिए, मोबाइल/टैबलेट पर अन्य बिलिंग सिस्टम के फ़्लो को सपोर्ट करने वाली क्लास जोड़ी गई हैं:
- शुरू की गई सदस्यता का बाहरी ट्रांज़ैक्शन आईडी तय करने के लिए,
BillingFlowParams.SubscriptionUpdateParams.Builder.setOriginalExternalTransactionId()तरीका जोड़ा गया. - दक्षिण कोरिया में रहने वाले उपयोगकर्ताओं को अन्य बिलिंग सिस्टम चुनने की अनुमति देने का तरीका
BillingClient.Builder.enableAlternativeBilling()जोड़ा गया.
Google Play Billing Library 5.1 रिलीज़ (31-10-2022)
Google Play Billing Library का वर्शन 5.1.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
- ऑफ़र आईडी वापस पाने का तरीका जोड़ा गया
ProductDetails.SubscriptionOfferDetails.getOfferId(). - बुनियादी प्लान का आईडी वापस पाने का तरीका जोड़ा गया
ProductDetails.SubscriptionOfferDetails.getBasePlanId(). targetSdkVersionको 31 पर अपडेट किया गया.
Google Play Billing Library 5.0 रिलीज़ (11-05-2022)
Google Play Billing Library का वर्शन 5.0.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
- सदस्यताओं के लिए एक नया मॉडल लॉन्च किया गया है. इसमें नई इकाइयां भी शामिल हैं. इनकी मदद से, सदस्यता वाले किसी एक प्रॉडक्ट के लिए कई ऑफ़र बनाए जा सकते हैं. ज़्यादा जानकारी के लिए, डेटा को दूसरी जगह भेजने से जुड़ी गाइड देखें.
BillingClient.querySkuDetailsAsync()को बदलने के लिए,BillingClient.queryProductDetailsAsync()जोड़ा गया.- ईयू में, लोगों की दिलचस्पी के हिसाब से तय की गई कीमत के बारे में जानकारी देने की ज़रूरी शर्तों के लिए,
setIsOfferPersonalized()तरीका जोड़ा गया है. इस तरीके का इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, व्यक्तिगत ज़रूरत के हिसाब से तय की गई कीमत दिखाएं लेख पढ़ें. queryPurchases()को हटा दिया गया है. यह पहले उपलब्ध नहीं था और इसे Google Play Billing Library 4.0.0 में पेश किए गए queryPurchasesAsync से बदल दिया गया था.launchPriceChangeFlowअब सेवा में नहीं है. इसे आने वाले वर्शन से हटा दिया जाएगा. अन्य विकल्पों के बारे में ज़्यादा जानने के लिए, कीमत में बदलाव की पुष्टि करने वाला फ़्लो लॉन्च करें लेख पढ़ें.- हटाया गया
setVrPurchaseFlow(), जिसका इस्तेमाल पहले खरीदारी का फ़्लो शुरू करते समय किया जाता था. पिछले वर्शन में, इस तरीके से उपयोगकर्ता को Android डिवाइस पर खरीदारी पूरी करने के लिए रीडायरेक्ट किया जाता था. इस तरीके को हटाने के बाद, उपयोगकर्ता खरीदारी की सामान्य प्रोसेस के ज़रिए खरीदारी पूरी करेंगे.
Google Play Billing Library 4.1 रिलीज़ (23-02-2022)
Google Play Billing Library का वर्शन 4.1.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
- जोड़ा गया
BillingClient.showInAppMessages()ताकि सदस्यता के पेमेंट अस्वीकार होने की समस्या को ठीक किया जा सके. सदस्यताओं के पेमेंट अस्वीकार होने की समस्या को हल करने के लिए, ऐप्लिकेशन में मैसेज भेजने की सुविधा का इस्तेमाल करने के तरीके के बारे में ज़्यादा जानने के लिए, पेमेंट अस्वीकार होने की समस्या हल करना लेख पढ़ें.
Google Play Billing Library 4.0 रिलीज़ (18-05-2021)
Google Play Billing Library का वर्शन 4.0.0 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
परिवर्तनों का सारांश
BillingClient.queryPurchases()को बदलने के लिए,BillingClient.queryPurchasesAsync()जोड़ा गया है.BillingClient.queryPurchases()को आने वाले समय में हटा दिया जाएगा.सदस्यता बदलने का नया मोड जोड़ा गया
IMMEDIATE_AND_CHARGE_FULL_PRICE.Play Billing Library की कनेक्शन की स्थिति को वापस पाने के लिए,
BillingClient.getConnectionState()तरीका जोड़ा गया है.अपडेट किया गया Javadoc और लागू करने का तरीका, ताकि यह पता चल सके कि किसी तरीके को किस थ्रेड पर कॉल किया जा सकता है और नतीजे किस थ्रेड पर पोस्ट किए जाते हैं.
सदस्यता अपडेट करने का नया तरीका जोड़ा गया
BillingFlowParams.Builder.setSubscriptionUpdateParams(). यहBillingFlowParams#getReplaceSkusProrationMode,BillingFlowParams#getOldSkuPurchaseToken,BillingFlowParams#getOldSku,BillingFlowParams.Builder#setReplaceSkusProrationMode,BillingFlowParams.Builder#setOldSkuकी जगह लेता है. इन सभी को हटा दिया गया है.Purchase.getQuantity()औरPurchaseHistoryRecord.getQuantity()को जोड़ा गया.Purchase#getSkus()औरPurchaseHistoryRecord#getSkus()को जोड़ा गया. येPurchase#getSkuऔरPurchaseHistoryRecord#getSkuकी जगह इस्तेमाल किए जाते हैं. इन्हें हटा दिया गया है.BillingFlowParams#getSku,BillingFlowParams#getSkuDetails, औरBillingFlowParams#getSkuTypeको हटाया गया.
Google Play Billing Library 3.0.3 रिलीज़ (12-03-2021)
Google Play Billing Library, Kotlin एक्सटेंशन, और Unity प्लगिन का वर्शन 3.0.3 अब उपलब्ध है.
Java और Kotlin से जुड़ी गड़बड़ियाँ ठीक की गईं
endConnection()को कॉल किए जाने पर मेमोरी लीक की समस्या ठीक की गई.- Google Play Billing Library का इस्तेमाल करने वाले ऐसे ऐप्लिकेशन से जुड़ी समस्या ठीक की गई है जो सिंगल टास्क लॉन्च मोड का इस्तेमाल करते हैं. जब Android लॉन्चर से किसी ऐप्लिकेशन को फिर से शुरू किया जाता है और निलंबित किए जाने से पहले बिलिंग डायलॉग दिख रहा था, तब
onPurchasesUpdated()कॉलबैक ट्रिगर होगा.
Unity की गड़बड़ियां ठीक की गईं
- मेमोरी लीक की समस्या को ठीक करने के लिए, Java के वर्शन 3.0.3 पर अपडेट करें. साथ ही, इस समस्या को हल करें. इस समस्या की वजह से, Android लॉन्चर से ऐप्लिकेशन को फिर से शुरू करने पर खरीदारी नहीं हो पाती है. इसके अलावा, निलंबन से पहले बिलिंग डायलॉग दिखता था.
Google Play Billing Library 3.0.2 रिलीज़ (24-11-2020)
Google Play Billing Library और Kotlin एक्सटेंशन का वर्शन 3.0.2 अब उपलब्ध है.
गड़बड़ियां ठीक की गईं
- Kotlin एक्सटेंशन में मौजूद एक गड़बड़ी को ठीक किया गया है. इस गड़बड़ी की वजह से, कोराउटीन "Already resumed" गड़बड़ी के साथ फ़ेल हो जाता था.
- Kotlin एक्सटेंशन का इस्तेमाल kotlinx.coroutines लाइब्रेरी के 1.4 या इससे ऊपर के वर्शन के साथ करने पर, अनसुलझे रेफ़रंस की समस्या ठीक की गई.
Google Play Billing Library 3.0.1 रिलीज़ (30-09-2020)
Google Play Billing Library का वर्शन 3.0.1 और Kotlin एक्सटेंशन अब उपलब्ध हैं.
गड़बड़ियां ठीक की गईं
- एक बग को ठीक किया गया है. इस बग में, बिलिंग फ़्लो के दौरान ऐप्लिकेशन बंद होने और फिर से चालू होने पर, खरीदारी के नतीजे के साथ
PurchasesUpdatedListenerको कॉल नहीं किया जा सकता था.
Google Play Billing Library 3.0 रिलीज़ (08-06-2020)
Google Play Billing Library, Kotlin एक्सटेंशन, और Unity प्लगिन का वर्शन 3.0.0 अब उपलब्ध है.
परिवर्तनों का सारांश
- इनाम वाले एसकेयू के लिए सहायता पाने की सुविधा हटा दी गई है.
ChildDirectedऔरUnderAgeOfConsentपैरामीटर हटा दिए गए हैं.- डेवलपर पेलोड के पुराने तरीके हटा दिए गए हैं.
- डेप्रिकेट किए गए तरीके
BillingFlowParams.setAccountId()औरBillingFlowParams.setDeveloperId()हटा दिए गए हैं. - डेप्रिकेट किए गए
BillingFlowParams.setOldSkus(String oldSku)औरBillingFlowParams.addOldSku(String oldSku)तरीकों को हटा दिया गया है. - शून्य होने की अनुमति से जुड़े एनोटेशन जोड़े गए.
गड़बड़ियां ठीक की गईं
SkuDetails.getIntroductoryPriceCycles()अबStringके बजायintदिखाता है.- उस गड़बड़ी को ठीक किया गया है जिसमें बिलिंग फ़्लो को अतिरिक्त पैरामीटर के तौर पर माना जाता था. ऐसा तब होता था, जब कोई अतिरिक्त पैरामीटर सेट नहीं किया गया होता था.
Google Play Billing Library 2.2.1 रिलीज़ (20-05-2020)
Google Play Billing Library का वर्शन 2.2.1 अब उपलब्ध है.
गड़बड़ियां ठीक की गईं
- Java Play Billing Library के डिफ़ॉल्ट वर्शन को अपडेट किया गया है. Kotlin एक्सटेंशन इसी पर निर्भर करता है.
Google Play Billing Library 2.2.0 रिलीज़ और Unity के साथ काम करने की सुविधा (23-03-2020)
Google Play Billing के वर्शन 2.2.0 में एक ऐसा फ़ंक्शन उपलब्ध है जिससे डेवलपर यह पक्का कर पाते हैं कि खरीदारी का क्रेडिट सही उपयोगकर्ता को मिले. इन बदलावों से, डेवलपर पेलोड के आधार पर कस्टम समाधान बनाने की ज़रूरत नहीं पड़ती. इस अपडेट के तहत, डेवलपर पेलोड की सुविधा अब काम नहीं करती. इसे आने वाले समय में हटा दिया जाएगा. सुझाए गए विकल्पों के साथ-साथ ज़्यादा जानकारी के लिए, डेवलपर पेलोड देखें.
Google Play Billing Billing Library 2 for Unity
हमने Google Play Billing Library 2 के मौजूदा Java और Kotlin वर्शन के अलावा, Unity के साथ इस्तेमाल करने के लिए लाइब्रेरी का एक वर्शन भी रिलीज़ किया है. Unity in-app purchase API का इस्तेमाल करने वाले गेम डेवलपर, अब Google Play Billing Library 2 की सभी सुविधाओं का फ़ायदा पाने के लिए अपग्रेड कर सकते हैं. साथ ही, Google Play Billing Library के आने वाले वर्शन में अपग्रेड करना आसान बना सकते हैं.
ज़्यादा जानने के लिए, Unity के साथ Google Play Billing का इस्तेमाल करना लेख पढ़ें.
परिवर्तनों का सारांश
- Java Google Play Billing Library
AcknowledgePurchaseParams,setDeveloperPayload(), औरgetDeveloperPayload()तरीकों में.ConsumeParams,setDeveloperPayload(), औरgetDeveloperPayload()तरीकों में.BillingFlowParamsमें, इसका नाम बदलकरsetAccountId()कर दिया गया है. साथ ही, इसमेंsetObfuscatedAccountId()के तौर पर 64 वर्णों की सीमा और इस फ़ील्ड में व्यक्तिगत पहचान से जुड़ी जानकारी (पीआईआई) शामिल करने पर पाबंदी के बारे में बताया गया है.setAccountId()को सेवा से बाहर के तौर पर मार्क किया गया है. इसे आने वाले समय में लाइब्रेरी के वर्शन से हटा दिया जाएगा.BillingFlowParamsमें,setObfuscatedProfileId()जोड़ा गया है. यहsetObfuscatedAccountId()की तरह ही काम करता है. ज़्यादा जानकारी के लिए, डेवलपर पेलोड के अपडेट और विकल्प देखें.Purchaseमें,BillingFlowParamsमें सेट किए गए, पहचान छिपाकर रखे गए खाते के आइडेंटिफ़ायर को वापस पाने के लिए,getAccountIdentifiers()तरीका जोड़ा गया है.BillingClientमें,loadRewardedSku()तरीके को, इनाम वाले एसकेयू को बंद करने के तहत बंद कर दिया गया है. इस सुविधा के बंद होने के बारे में ज़्यादा जानकारी के लिए, Play Console के सहायता केंद्र पर जाएं.
Google Play Billing Library 2.1.0 और Kotlin एक्सटेंशन 2.1.0 रिलीज़ किया गया (10-12-2019)
Google Play Billing Library का वर्शन 2.1.0 और नया Kotlin एक्सटेंशन अब उपलब्ध है. Play Billing Library का Kotlin एक्सटेंशन, Kotlin के इस्तेमाल के लिए इडियोमैटिक एपीआई के विकल्प उपलब्ध कराता है. इसमें बेहतर नल-सेफ़्टी और कोरुटीन शामिल हैं. कोड के उदाहरणों के लिए, Google Play Billing Library का इस्तेमाल करना लेख पढ़ें.
इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
BillingFlowParamsमें,setOldSku(String oldSku)को बंद कर दिया गया है और उसकी जगहsetOldSku(String oldSku, String purchaseToken)को चालू कर दिया गया है. ऐसा इसलिए किया गया है, ताकि यह पता चल सके कि डिवाइस पर मौजूद एक से ज़्यादा खातों के पास एक ही एसकेयू है.
Google Play Billing Library 2.0.3 रिलीज़ (05-08-2019)
Google Play Billing Library का वर्शन 2.0.3 अब उपलब्ध है.
गड़बड़ियां ठीक की गईं
- एक गड़बड़ी को ठीक किया गया है. इस गड़बड़ी की वजह से,
querySkuDetailsAsync()कभी-कभी सही नतीजे के बजायDEVELOPER_ERRORकोड के साथ काम नहीं करता था.
Google Play Billing Library 2.0.2 रिलीज़ (08-07-2019)
Google Play Billing Library का वर्शन 2.0.2 अब उपलब्ध है. इस रिलीज़ में, रेफ़रंस दस्तावेज़ से जुड़े अपडेट शामिल हैं. इससे लाइब्रेरी के काम करने के तरीके में कोई बदलाव नहीं होगा.
Google Play Billing Library 2.0.1 रिलीज़ (06-06-2019)
Google Play Billing Library का वर्शन 2.0.1 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
गड़बड़ियां ठीक की गईं
- डीबग मैसेज के कुछ मामलों में
nullके तौर पर वापस आने वाली गड़बड़ी को ठीक किया गया है. - मेमोरी लीक की समस्या को ठीक किया गया है.
Google Play Billing Library 2.0 रिलीज़ (07-05-2019)
Google Play Billing Library का वर्शन 2.0 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
खरीदारी की पुष्टि तीन दिनों के अंदर करनी होगी
Google Play पर, ऐप्लिकेशन के अंदर (इन-ऐप्लिकेशन) या ऐप्लिकेशन के बाहर (आउट-ऑफ़-ऐप्लिकेशन) से प्रॉडक्ट खरीदे जा सकते हैं. Google Play यह पक्का करता है कि उपयोगकर्ता को खरीदारी का एक जैसा अनुभव मिले. भले ही, वह आपके प्रॉडक्ट को कहीं से भी खरीदे. इसके लिए, आपको Google Play Billing Library से मिली सभी खरीदारी की पुष्टि करनी होगी. यह पुष्टि, उपयोगकर्ता को एनटाइटलमेंट देने के तुरंत बाद करनी होगी. अगर आपने तीन दिनों के अंदर खरीदारी की पुष्टि नहीं की, तो उपयोगकर्ता को अपने-आप रिफ़ंड मिल जाएगा. साथ ही, Google Play खरीदारी को रद्द कर देगा. लंबित लेन-देन (वर्शन 2.0 में नया) के लिए, तीन दिन की विंडो तब शुरू होती है, जब खरीदारी PURCHASED स्थिति में पहुंच जाती है. यह तब लागू नहीं होती, जब खरीदारी PENDING स्थिति में हो.
सदस्यताओं के लिए, आपको ऐसी हर खरीदारी की पुष्टि करनी होगी जिसके लिए नया खरीदारी टोकन मिला है. इसका मतलब है कि शुरुआती खरीदारी, प्लान में बदलाव, और फिर से साइन अप करने की पुष्टि करना ज़रूरी है. हालांकि, आपको बाद में होने वाले रिन्यूअल की पुष्टि करने की ज़रूरत नहीं है. यह पता लगाने के लिए कि किसी खरीदारी के लिए सूचना भेजना ज़रूरी है या नहीं, खरीदारी में सूचना फ़ील्ड की जांच करें.
Purchase ऑब्जेक्ट में अब isAcknowledged() तरीका शामिल है. इससे यह पता चलता है कि खरीदारी स्वीकार की गई है या नहीं. इसके अलावा, Google Play Developer API में Purchases.products और Purchases.subscriptions, दोनों के लिए बूलियन वैल्यू शामिल होती हैं.
खरीदारी की पुष्टि करने से पहले, इन तरीकों का इस्तेमाल करके यह पता लगाएं कि खरीदारी की पुष्टि पहले ही हो चुकी है या नहीं.
खरीदारी की पुष्टि करने के लिए, इनमें से किसी एक तरीके का इस्तेमाल किया जा सकता है:
- इस्तेमाल किए जा सकने वाले प्रॉडक्ट के लिए, क्लाइंट एपीआई में मौजूद
consumeAsync()का इस्तेमाल करें. - ऐसे प्रॉडक्ट के लिए
acknowledgePurchase()का इस्तेमाल करें जिनका इस्तेमाल नहीं किया जाता. यह क्लाइंट एपीआई में मौजूद होता है. - सर्वर एपीआई में,
acknowledge()का नया तरीका भी उपलब्ध है.
BillingFlowParams.setSku() को हटा दिया गया है
इस रिलीज़ में, पहले से बंद किए गए BillingFlowParams#setSku() तरीके को हटा दिया गया है. खरीदारी के फ़्लो में प्रॉडक्ट रेंडर करने से पहले, अब आपको BillingClient.querySkuDetailsAsync() को कॉल करना होगा. साथ ही, SkuDetails ऑब्जेक्ट को BillingFlowParams.Builder.setSkuDetails() में पास करना होगा.
कोड के उदाहरणों के लिए, Google Play Billing Library का इस्तेमाल करना लेख पढ़ें.
डेवलपर पेलोड की सुविधा काम करती है
Google Play Billing Library के वर्शन 2.0 में, डेवलपर पेलोड के लिए सहायता जोड़ी गई है. यह ऐसी स्ट्रिंग होती हैं जिन्हें खरीदारी से जोड़ा जा सकता है. किसी खरीदारी में डेवलपर पेलोड पैरामीटर अटैच किया जा सकता है. हालांकि, ऐसा सिर्फ़ तब किया जा सकता है, जब खरीदारी की पुष्टि हो गई हो या उसे इस्तेमाल कर लिया गया हो. यह AIDL में डेवलपर पेलोड से अलग है. इसमें खरीदारी का फ़्लो शुरू करते समय पेलोड तय किया जा सकता है. अब आपके ऐप्लिकेशन के बाहर से खरीदारी शुरू की जा सकती है. इसलिए, इस बदलाव से यह पक्का होता है कि आपके पास हमेशा खरीदारी में पेलोड जोड़ने का विकल्प मौजूद रहे.
नई लाइब्रेरी में पेलोड ऐक्सेस करने के लिए, Purchase ऑब्जेक्ट में अब getDeveloperPayload() तरीका शामिल है.
एक जैसे ऑफ़र
छूट वाली एसकेयू ऑफ़र करने पर, Google Play अब एसकेयू की मूल कीमत दिखाता है. इससे लोगों को यह दिखाया जा सकता है कि उन्हें छूट मिल रही है.
SkuDetails में, ओरिजनल एसकेयू की कीमत पाने के लिए दो नए तरीके शामिल हैं:
getOriginalPriceAmountMicros()- इस फ़ंक्शन से, छूट से पहले एसकेयू की बिना फ़ॉर्मैट वाली मूल कीमत मिलती है.
getOriginalPrice()- यह फ़ंक्शन, मुद्रा के अतिरिक्त फ़ॉर्मैटिंग के साथ मूल कीमत दिखाता है.
बाकी लेन-देन
Google Play Billing Library के वर्शन 2.0 के साथ, आपको ऐसी खरीदारी की सुविधा देनी होगी जिनके लिए एनटाइटलमेंट देने से पहले, अतिरिक्त कार्रवाई की ज़रूरत होती है. ऐसा करना ज़रूरी है. उदाहरण के लिए, कोई व्यक्ति नकद पैसे देकर किसी स्टोर से, आपके ऐप्लिकेशन में मौजूद प्रॉडक्ट खरीद सकता है. इसका मतलब है कि लेन-देन आपके ऐप्लिकेशन से बाहर पूरा किया गया है. इस स्थिति में, आपको उपयोगकर्ता को एनटाइटलमेंट सिर्फ़ तब देना चाहिए, जब उसने लेन-देन पूरा कर लिया हो.
खरीदारी के अनुरोध को पूरा होने में समय लगने की सुविधा चालू करने के लिए, अपने ऐप्लिकेशन को शुरू करते समय enablePendingPurchases() को कॉल करें.
Purchase.getPurchaseState() का इस्तेमाल करके यह तय करें कि खरीदारी की स्थिति PURCHASED है या PENDING. ध्यान दें कि आपको एनटाइटलमेंट सिर्फ़ तब देना चाहिए, जब स्थिति PURCHASED हो. आपको Purchase के स्टेटस अपडेट देखने चाहिए. इसके लिए, यह तरीका अपनाएं:
- ऐप्लिकेशन शुरू करते समय,
BillingClient.queryPurchases()को कॉल करें, ताकि उपयोगकर्ता से जुड़े उन प्रॉडक्ट की सूची वापस पाई जा सके जिनका इस्तेमाल नहीं किया गया है. - हर लौटाए गए
Purchaseऑब्जेक्ट परPurchase.getPurchaseState()को कॉल करें. Purchaseऑब्जेक्ट में हुए बदलावों का जवाब देने के लिए,onPurchasesUpdated()तरीके का इस्तेमाल करें.
इसके अलावा, Google Play Developer API में Purchases.products के लिए PENDING स्थिति शामिल है.
सदस्यताओं के लिए, ऐसे लेन-देन की सुविधा उपलब्ध नहीं है जिनका पेमेंट नहीं किया गया है.
इस रिलीज़ में, डेवलपर से जुड़ी रीयल-टाइम सूचनाओं का एक नया टाइप भी पेश किया गया है. यह टाइप OneTimeProductNotification है. इस तरह की सूचना में एक मैसेज होता है. इसकी वैल्यू ONE_TIME_PRODUCT_PURCHASED या ONE_TIME_PRODUCT_CANCELED होती है. इस तरह की सूचना सिर्फ़ उन खरीदारी के लिए भेजी जाती है जिनमें पेमेंट के तरीके के तौर पर, नकद जैसे विकल्पों का इस्तेमाल किया जाता है.
लंबित खरीदारी की पुष्टि करते समय, पक्का करें कि खरीदारी की स्थिति PURCHASED हो, न कि PENDING.
एपीआई में बदलाव
Google Play Billing Library के वर्शन 2.0 में, एपीआई से जुड़े कई बदलाव किए गए हैं. इससे नई सुविधाओं को सपोर्ट करने और मौजूदा सुविधाओं के बारे में ज़्यादा जानकारी देने में मदद मिलती है.
consumeAsync
consumeAsync() अब purchaseToken के बजाय ConsumeParams ऑब्जेक्ट लेता है. ConsumeParams में purchaseToken के साथ-साथ, डेवलपर का वैकल्पिक पेलोड भी शामिल होता है.
इस रिलीज़ में, consumeAsync() के पिछले वर्शन को हटा दिया गया है.
queryPurchaseHistoryAsync
भ्रम को कम करने के लिए, queryPurchaseHistoryAsync() अब Purchase ऑब्जेक्ट के बजाय PurchaseHistoryRecord ऑब्जेक्ट दिखाता है. PurchaseHistoryRecord ऑब्जेक्ट, Purchase ऑब्जेक्ट जैसा ही होता है. हालांकि, इसमें सिर्फ़ queryPurchaseHistoryAsync() से मिली वैल्यू दिखती हैं. साथ ही, इसमें autoRenewing, orderId, और packageName फ़ील्ड शामिल नहीं होते. ध्यान दें कि दिखाए गए डेटा में कोई बदलाव नहीं हुआ है. queryPurchaseHistoryAsync() पहले की तरह ही डेटा दिखाता है.
BillingResult की रिटर्न वैल्यू
पहले जिन एपीआई से BillingResponse पूर्णांक वैल्यू मिलती थी उनसे अब BillingResult ऑब्जेक्ट मिलता है. BillingResult में BillingResponse पूर्णांक के साथ-साथ एक डीबग स्ट्रिंग भी शामिल होती है. इसका इस्तेमाल गड़बड़ियों का पता लगाने के लिए किया जा सकता है. डीबग स्ट्रिंग में en-US
लोकल का इस्तेमाल किया जाता है. इसे असली उपयोगकर्ताओं को नहीं दिखाया जाता.
गड़बड़ियां ठीक की गईं
SkuDetails.getIntroductoryPriceAmountMicros()अबStringके बजायlongदिखाता है.
Google Play Billing Library 1.2.2 रिलीज़ (07-03-2019)
Google Play Billing Library का वर्शन 1.2.2 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
गड़बड़ियां ठीक की गईं
- v1.2.1 में शुरू हुई थ्रेडिंग की समस्या को ठीक किया गया है. बैकग्राउंड कॉल अब मुख्य थ्रेड को ब्लॉक नहीं करते.
अन्य बदलाव
- हालांकि, अब भी मुख्य थ्रेड का इस्तेमाल करने का सुझाव दिया जाता है. हालांकि, अब बैकग्राउंड थ्रेड से Google Play Billing Library को इंस्टैंशिएट किया जा सकता है.
- इंस्टैंटिएशन को पूरी तरह से बैकग्राउंड थ्रेड पर माइग्रेट कर दिया गया है, ताकि ANR की समस्या कम हो.
Play Billing Library 1.2.1 रिलीज़ (04-03-2019)
Google Play Billing Library का वर्शन 1.2.1 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
मुख्य परिवर्तन
- इनाम वाले प्रॉडक्ट के लिए सहायता जोड़ी गई. कमाई करने के विकल्पों के बारे में ज़्यादा जानने के लिए, इनाम वाले प्रॉडक्ट के लिए खास सुविधाएं जोड़ना लेख पढ़ें.
अन्य बदलाव
PurchasesResultऔरSkuDetailsResultके लिए, सार्वजनिक कंस्ट्रक्टर जोड़े गए हैं, ताकि टेस्टिंग को आसान बनाया जा सके.SkuDetailsऑब्जेक्ट,getOriginalJson()नाम के नए तरीके का इस्तेमाल कर सकते हैं.- अब सभी AIDL सेवा कॉल, बैकग्राउंड थ्रेड मैनेज करती हैं.
गड़बड़ियां ठीक की गईं
- अब शून्य कॉलबैक लिसनर को सार्वजनिक एपीआई में पास नहीं किया जाता है.
Google Play Billing Library 1.2 रिलीज़ (18-10-2018)
Google Play Billing Library का वर्शन 1.2 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
- Google Play Billing Library को अब Android सॉफ़्टवेयर डेवलपमेंट किट के लाइसेंस एग्रीमेंट के तहत लाइसेंस दिया गया है.
launchPriceChangeConfirmationFlowएपीआई जोड़ा गया है. इससे लोगों को सदस्यता की कीमत में होने वाले बदलाव की समीक्षा करने के लिए कहा जाता है.- किसी उपयोगकर्ता की सदस्यता को अपग्रेड या डाउनग्रेड करते समय,
DEFERREDनाम के नए प्रोरेशन मोड के लिए सहायता जोड़ी गई है. BillingFlowParamsक्लास में,setSku()कोsetSkuDetails()से बदल दिया गया है.- मामूली गड़बड़ियां ठीक की गई हैं और कोड को ऑप्टिमाइज़ किया गया है.
कीमत में बदलाव की पुष्टि
अब Google Play Console में जाकर, किसी सदस्यता की कीमत बदली जा सकती है. साथ ही, लोगों को आपका ऐप्लिकेशन खोलने पर, नई कीमत की समीक्षा करने और उसे स्वीकार करने के लिए कहा जा सकता है.
इस एपीआई का इस्तेमाल करने के लिए, सदस्यता वाले प्रॉडक्ट के skuDetails का इस्तेमाल करके PriceChangeFlowParams ऑब्जेक्ट बनाएं. इसके बाद, launchPriceChangeConfirmationFlow() को कॉल करें. कीमत में बदलाव की पुष्टि करने वाला फ़्लो पूरा होने पर, नतीजे को मैनेज करने के लिए PriceChangeConfirmationListener लागू करें. इसे यहां दिए गए कोड स्निपेट में दिखाया गया है:
Kotlin
val priceChangeFlowParams = PriceChangeFlowParams.newBuilder() .setSkuDetails(skuDetailsOfThePriceChangedSubscription) .build() billingClient.launchPriceChangeConfirmationFlow(activity, priceChangeFlowParams, object : PriceChangeConfirmationListener() { override fun onPriceChangeConfirmationResult(responseCode: Int) { // Handle the result. } })
Java
PriceChangeFlowParams priceChangeFlowParams = PriceChangeFlowParams.newBuilder() .setSkuDetails(skuDetailsOfThePriceChangedSubscription) .build(); billingClient.launchPriceChangeConfirmationFlow(activity, priceChangeFlowParams, new PriceChangeConfirmationListener() { @Override public void onPriceChangeConfirmationResult(int responseCode) { // Handle the result. } });
कीमत में बदलाव की पुष्टि करने वाले फ़्लो में, एक डायलॉग बॉक्स दिखता है. इसमें नई कीमत की जानकारी होती है. इसमें लोगों से नई कीमत स्वीकार करने के लिए कहा जाता है. इस फ़्लो से BillingClient.BillingResponse टाइप का रिस्पॉन्स कोड मिलता है.
किराया कम करने का नया मोड
किसी उपयोगकर्ता की सदस्यता को अपग्रेड या डाउनग्रेड करते समय, आपके पास नए प्रोरेशन मोड DEFERRED का इस्तेमाल करने का विकल्प होता है. इस मोड में, उपयोगकर्ता की सदस्यता को अगली बार रिन्यू होने पर अपडेट किया जाता है.
इस प्रोरेशन मोड को सेट करने के बारे में ज़्यादा जानने के लिए, प्रोरेशन मोड सेट करना लेख पढ़ें.
SKU की जानकारी सेट करने का नया तरीका
BillingFlowParams क्लास में, setSku() तरीके का इस्तेमाल अब नहीं किया जा सकता.
इस बदलाव का मकसद, Google Play Billing के फ़्लो को ऑप्टिमाइज़ करना है.
हमारा सुझाव है कि ऐप्लिकेशन में मौजूद बिलिंग सिस्टम के क्लाइंट में BillingFlowParams का नया इंस्टेंस बनाते समय, setSkuDetails() का इस्तेमाल करके सीधे JSON ऑब्जेक्ट के साथ काम करें. जैसा कि कोड के इस स्निपेट में दिखाया गया है:
BillingFlowParams Builder क्लास में, setSku() तरीके को बंद कर दिया गया है. इसके बजाय, setSkuDetails() तरीके का इस्तेमाल करें. यह तरीका, यहां दिए गए कोड स्निपेट में दिखाया गया है. setSkuDetails() ऑब्जेक्ट में पास किया गया ऑब्जेक्ट, querySkuDetailsAsync() तरीके से मिलता है.
Kotlin
private lateinit var mBillingClient: BillingClient private val mSkuDetailsMap = HashMap<String, SkuDetails>() private fun querySkuDetails() { val skuDetailsParamsBuilder = SkuDetailsParams.newBuilder() mBillingClient.querySkuDetailsAsync(skuDetailsParamsBuilder.build() ) { responseCode, skuDetailsList -> if (responseCode == 0) { for (skuDetails in skuDetailsList) { mSkuDetailsMap[skuDetails.sku] = skuDetails } } } } private fun startPurchase(skuId: String) { val billingFlowParams = BillingFlowParams.newBuilder() .setSkuDetails(mSkuDetailsMap[skuId]) .build() }
Java
private BillingClient mBillingClient; private Map<String, SkuDetails> mSkuDetailsMap = new HashMap<>(); private void querySkuDetails() { SkuDetailsParams.Builder skuDetailsParamsBuilder = SkuDetailsParams.newBuilder(); mBillingClient.querySkuDetailsAsync(skuDetailsParamsBuilder.build(), new SkuDetailsResponseListener() { @Override public void onSkuDetailsResponse(int responseCode, List<SkuDetails> skuDetailsList) { if (responseCode == 0) { for (SkuDetails skuDetails : skuDetailsList) { mSkuDetailsMap.put(skuDetails.getSku(), skuDetails); } } } }); } private void startPurchase(String skuId) { BillingFlowParams billingFlowParams = BillingFlowParams.newBuilder() .setSkuDetails(mSkuDetailsMap.get(skuId)) .build(); }
Play Billing Library 1.1 रिलीज़ (07-05-2018)
Google Play Billing Library का वर्शन 1.1 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
परिवर्तनों का सारांश
- मौजूदा सदस्यता को अपग्रेड/डाउनग्रेड करते समय,
BillingFlowParamsमें प्रोरैटेड मोड तय करने की सुविधा जोड़ी गई है. BillingFlowParamsमेंreplaceSkusProrationबूलियन फ़्लैग अब काम नहीं करता. इसके बजाय,replaceSkusProrationModeका इस्तेमाल करें.launchBillingFlow()अब जवाब नहीं मिलने पर, कॉलबैक को ट्रिगर करता है.
व्यवहार में बदलाव
Google Play Billing Library के वर्शन 1.1 में, ये बदलाव किए गए हैं.
डेवलपर, BillingFlowParams क्लास में replaceSkusProrationMode सेट कर सकते हैं
ProrationMode में, किसी उपयोगकर्ता की सदस्यता को अपग्रेड या डाउनग्रेड करते समय, प्रोरैटिंग के टाइप के बारे में ज़्यादा जानकारी दी गई है.
Kotlin
BillingFlowParams.newBuilder() .setSku(skuId) .setType(billingType) .setOldSku(oldSku) .setReplaceSkusProrationMode(replaceSkusProrationMode) .build()
Java
BillingFlowParams.newBuilder() .setSku(skuId) .setType(billingType) .setOldSku(oldSku) .setReplaceSkusProrationMode(replaceSkusProrationMode) .build();
Google Play पर, किराये में छूट देने के ये मोड काम करते हैं:
IMMEDIATE_WITH_TIME_PRORATION |
बदलाव तुरंत लागू हो जाता है. साथ ही, सदस्यता खत्म होने का नया समय, उपयोगकर्ता को क्रेडिट या शुल्क के तौर पर दिया जाता है. यह डिफ़ॉल्ट रूप से काम करने का मौजूदा तरीका है. |
IMMEDIATE_AND_CHARGE_PRORATED_PRICE |
बदलाव तुरंत लागू हो जाता है. साथ ही, बिलिंग साइकल में कोई बदलाव नहीं होता. बची हुई अवधि के लिए, आपसे शुल्क लिया जाएगा.
ध्यान दें: यह विकल्प सिर्फ़ सदस्यता अपग्रेड करने के लिए उपलब्ध है. |
IMMEDIATE_WITHOUT_PRORATION |
बदलाव तुरंत लागू हो जाता है. साथ ही, अगली बार सदस्यता रिन्यू करने पर, आपसे नई कीमत ली जाएगी. बिलिंग साइकल में कोई बदलाव नहीं होता. |
BillingFlowParams क्लास में अब replaceSkusProration का इस्तेमाल नहीं किया जा सकता
डेवलपर के पास, सदस्यता अपग्रेड करने के अनुरोध के लिए, समय के हिसाब से तय की गई कीमत लेने के लिए, बूलियन फ़्लैग सेट करने का विकल्प होता था. हम ProrationMode का इस्तेमाल कर रहे हैं. इसमें, प्रो-रेटिंग के बारे में ज़्यादा जानकारी दी गई है. इसलिए, अब इस बूलियन फ़्लैग का इस्तेमाल नहीं किया जा सकता.
launchBillingFlow() अब उन जवाबों के लिए कॉलबैक ट्रिगर करता है जो नहीं दिए जा सके
Billing Library हमेशा PurhcasesUpdatedListener कॉलबैक को ट्रिगर करेगी और BillingResponse को एसिंक्रोनस तरीके से दिखाएगी. BillingResponse की सिंक्रोनस रिटर्न वैल्यू भी सेव की जाती है.
गड़बड़ियां ठीक की गईं
- सेवा के डिसकनेक्ट होने पर, एसिंक तरीकों में जल्दी से सही तरीके से बंद हो जाता है.
Builderपैराम ऑब्जेक्ट अब बिल्ट ऑब्जेक्ट में बदलाव नहीं करते.- समस्या 68087141:
launchBillingFlow()अब फ़ेल हो चुकी प्रतिक्रियाओं के लिए कॉलबैक को ट्रिगर करता है.
Google Play Billing Library 1.0 रिलीज़ (19-09-2017, सूचना)
Google Play Billing Library का वर्शन 1.0 अब उपलब्ध है. इस वर्शन में ये बदलाव किए गए हैं.
अहम बदलाव
- लाइब्रेरी के मेनिफ़ेस्ट में, बिलिंग की अनुमति एम्बेड की गई है. अब Android मेनिफ़ेस्ट में
com.android.vending.BILLINGअनुमति जोड़ने की ज़रूरत नहीं है. BillingClient.Builderक्लास में नया बिल्डर जोड़ा गया.- SKU के बारे में क्वेरी करने के लिए इस्तेमाल किए जाने वाले तरीकों के लिए,
SkuDetailsParamsक्लास के लिए बिल्डर पैटर्न पेश किया गया. - एपीआई के कई तरीकों को अपडेट किया गया है, ताकि वे एक जैसे दिखें. जैसे, एक ही तरह के आर्ग्युमेंट के नाम और क्रम.
व्यवहार में बदलाव
Google Play Billing Library के वर्शन 1.0 में, ये बदलाव किए गए हैं.
BillingClient.Builder क्लास
BillingClient.Builder
को अब newBuilder पैटर्न के ज़रिए शुरू किया गया है:
Kotlin
billingClient = BillingClient.newBuilder(context).setListener(this).build()
Java
billingClient = BillingClient.newBuilder(context).setListener(this).build();
launchBillingFlow तरीके को अब BillingFlowParams क्लास का इस्तेमाल करके कॉल किया जाता है
किसी खरीदारी या सदस्यता के लिए बिलिंग फ़्लो शुरू करने के लिए, launchBillingFlow() तरीके को BillingFlowParams इंस्टेंस मिलता है. यह इंस्टेंस, अनुरोध के हिसाब से तय किए गए पैरामीटर के साथ शुरू किया जाता है:
Kotlin
BillingFlowParams.newBuilder().setSku(skuId) .setType(billingType) .setOldSku(oldSku) .build() // Then, use the BillingFlowParams to start the purchase flow val responseCode = billingClient.launchBillingFlow(builder.build())
Java
BillingFlowParams.newBuilder().setSku(skuId) .setType(billingType) .setOldSku(oldSku) .build(); // Then, use the BillingFlowParams to start the purchase flow int responseCode = billingClient.launchBillingFlow(builder.build());
उपलब्ध प्रॉडक्ट के बारे में क्वेरी करने का नया तरीका
queryPurchaseHistoryAsync() और querySkuDetailsAsync() तरीकों के लिए आर्ग्युमेंट को बिल्डर पैटर्न में रैप किया गया था:
Kotlin
val params = SkuDetailsParams.newBuilder() params.setSkusList(skuList) .setType(itemType) billingClient.querySkuDetailsAsync(params.build(), object : SkuDetailsResponseListener() { ... })
Java
SkuDetailsParams.Builder params = SkuDetailsParams.newBuilder(); params.setSkusList(skuList) .setType(itemType); billingClient.querySkuDetailsAsync(params.build(), new SkuDetailsResponseListener() {...})
अब नतीजे, नतीजे के कोड और SkuDetails ऑब्जेक्ट की सूची के ज़रिए दिखाए जाते हैं. इससे पहले, रैपर क्लास का इस्तेमाल किया जाता था. ऐसा आपकी सुविधा के लिए किया गया है, ताकि हमारे सभी एपीआई में एक जैसा तरीका इस्तेमाल किया जा सके:
Kotlin
fun onSkuDetailsResponse(@BillingResponse responseCode: Int, skuDetailsList: List<SkuDetails>)
Java
public void onSkuDetailsResponse(@BillingResponse int responseCode, List<SkuDetails> skuDetailsList)
onConsumeResponse() तरीके के पैरामीटर का क्रम बदला गया
हमारे एपीआई में एक जैसा अनुभव देने के लिए, ConsumeResponseListener इंटरफ़ेस से onConsumeResponse के लिए आर्ग्युमेंट का क्रम बदल गया है:
Kotlin
fun onConsumeResponse(@BillingResponse responseCode: Int, outToken: String)
Java
public void onConsumeResponse(@BillingResponse int responseCode, String outToken)
Unwrapped PurchaseResult ऑब्जेक्ट
PurchaseResult को अनरैप कर दिया गया है, ताकि हमारे एपीआई में एक जैसा डेटा दिखे:
Kotlin
fun onPurchaseHistoryResponse(@BillingResponse responseCode: Int, purchasesList: List<Purchase>)
Java
void onPurchaseHistoryResponse(@BillingResponse int responseCode, List<Purchase> purchasesList)
गड़बड़ियां ठीक की गईं
- PURCHASES_UPDATED बंडल में कोई रिस्पॉन्स कोड नहीं है
- डिवाइस रोटेट करने के दौरान, ProxyBillingActivity और PurchasesUpdatedListener से जुड़ी समस्याओं को ठीक करना
डेवलपर के लिए झलक 1 रिलीज़ (12-06-2017, सूचना)
डेवलपर प्रीव्यू लॉन्च किया गया. इसका मकसद, बिलिंग की प्रोसेस को आसान बनाना है, ताकि डेवलपर Android ऐप्लिकेशन से जुड़े लॉजिक को लागू करने पर ध्यान दे सकें. जैसे, ऐप्लिकेशन का आर्किटेक्चर और नेविगेशन स्ट्रक्चर.
इस लाइब्रेरी में कई काम के क्लास और सुविधाएं शामिल हैं. इनका इस्तेमाल, Google Play Billing API के साथ अपने Android ऐप्लिकेशन इंटिग्रेट करते समय किया जा सकता है. यह लाइब्रेरी, Android इंटरफ़ेस डेफ़िनिशन लैंग्वेज (एआईडीएल) सेवा के ऊपर एक ऐब्स्ट्रैक्शन लेयर भी उपलब्ध कराती है. इससे डेवलपर के लिए, ऐप्लिकेशन और Google Play Billing API के बीच इंटरफ़ेस को तय करना आसान हो जाता है.