মে 2022 সদস্যতা পরিবর্তনের নির্দেশিকা

Google Play এর বিলিং সিস্টেম হল একটি পরিষেবা যা আপনাকে আপনার Android অ্যাপে ডিজিটাল পণ্য এবং সামগ্রী বিক্রি করতে দেয়৷ মে 2022-এর রিলিজের সাথে, আমরা সাবস্ক্রিপশন পণ্যগুলিকে কীভাবে সংজ্ঞায়িত করা হয় তা পরিবর্তন করেছি এবং এটি কীভাবে অ্যাপ-মধ্যস্থ বিক্রি এবং আপনার ব্যাকএন্ডে পরিচালনা করা হয় তা প্রভাবিত করে। আপনি যদি প্রথমবার Google Play বিলিং-এর সাথে একীভূত হয়ে থাকেন, তাহলে আপনি Getting ready পড়ে আপনার ইন্টিগ্রেশন শুরু করতে পারেন।

আপনি যদি মে 2022-এর আগে Google Play বিলিং-এর মাধ্যমে সাবস্ক্রিপশন বিক্রি করে থাকেন, তাহলে আপনার বিদ্যমান সাবস্ক্রিপশন বজায় রেখে নতুন বৈশিষ্ট্যগুলি কীভাবে গ্রহণ করবেন তা বোঝা গুরুত্বপূর্ণ।

প্রথম যে জিনিসটি জানতে হবে তা হল আপনার সমস্ত বিদ্যমান সাবস্ক্রিপশন, অ্যাপ এবং ব্যাকএন্ড ইন্টিগ্রেশন মে 2022-এর রিলিজের আগে যেমন কাজ করে । আপনাকে কোনো তাৎক্ষণিক পরিবর্তন করতে হবে না, এবং আপনি সময়ের সাথে সাথে এই নতুন বৈশিষ্ট্যগুলি গ্রহণ করতে পারেন। Google Play বিলিং লাইব্রেরির প্রতিটি বড় রিলিজ রিলিজের পর দুই বছরের জন্য সমর্থিত। Google Play Developer API-এর সাথে বিদ্যমান ইন্টিগ্রেশনগুলি আগের মতোই কাজ করে চলেছে৷

এখানে মে 2022 আপডেটগুলির একটি ওভারভিউ রয়েছে:

  • নতুন Google Play Console আপনাকে সদস্যতা, বেস প্ল্যান এবং অফার তৈরি এবং পরিচালনা করতে দেয়। এর মধ্যে নতুন এবং স্থানান্তরিত সাবস্ক্রিপশন উভয়ই অন্তর্ভুক্ত রয়েছে।
  • Play Developer API-এ API ফর্মে নতুন Google Play Console UI কার্যকারিতা সমর্থন করার জন্য আপডেট রয়েছে। উল্লেখযোগ্যভাবে, সাবস্ক্রিপশন ক্রয় API- এর একটি নতুন সংস্করণ রয়েছে। সদস্যতা স্থিতি পরীক্ষা করতে এবং সদস্যতা কেনাকাটা পরিচালনা করতে এই API ব্যবহার করুন।
  • নতুন প্লে বিলিং লাইব্রেরি সংস্করণ 5 আপনার অ্যাপটিকে সমস্ত নতুন সদস্যতা বৈশিষ্ট্য থেকে উপকৃত হতে দেয়৷ আপনি যখন 5 সংস্করণে আপগ্রেড করতে প্রস্তুত হন, তখন মাইগ্রেশন গাইডের নির্দেশিকা অনুসরণ করুন৷

সদস্যতা কনফিগারেশন

Google Play Console-এর মাধ্যমে সদস্যতা পরিচালনা করা

2022 সালের মে পর্যন্ত, আপনি Google Play Console-এ কিছু পার্থক্য লক্ষ্য করবেন।

একটি সাবস্ক্রিপশনে এখন একাধিক বেস প্ল্যান এবং অফার থাকতে পারে। পূর্বে তৈরি করা সাবস্ক্রিপশন SKUগুলি এখন এই নতুন সাবস্ক্রিপশন, বেস প্ল্যান এবং অফার অবজেক্ট হিসাবে প্লে কনসোলে উপস্থিত হয়। If you haven't already, see Recent changes to subscriptions in Play Console for descriptions of the new objects, including their functionality and configuration. আপনার সমস্ত পূর্বনির্ধারিত সাবস্ক্রিপশন পণ্য এই নতুন ফর্ম্যাটে গুগল প্লে কনসোলে উপস্থিত হয়। প্রতিটি এসকিউ এখন একটি সাবস্ক্রিপশন অবজেক্ট দ্বারা প্রতিনিধিত্ব করা হয় যা প্রযোজ্য ক্ষেত্রে একটি একক বেস পরিকল্পনা এবং পশ্চাদপদ-সামঞ্জস্যপূর্ণ অফার ধারণ করে।

যেহেতু পুরোনো ইন্টিগ্রেশন আশা করে যে প্রতিটি সাবস্ক্রিপশন একটি একক অফার অন্তর্ভুক্ত করবে, একটি SkuDetails অবজেক্ট দ্বারা উপস্থাপিত হবে, তাই প্রতিটি সাবস্ক্রিপশনে একটি একক পশ্চাদপদ-সামঞ্জস্যপূর্ণ বেস প্ল্যান বা অফার থাকতে পারে। The backward-compatible base plan or offer is returned as part of a SKU for apps that are using the now-deprecated querySkuDetailsAsync() method. ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ অফারগুলি কনফিগার এবং পরিচালনার বিষয়ে আরও তথ্যের জন্য, সাবস্ক্রিপশন বুঝতে দেখুন একবার আপনার অ্যাপটি শুধুমাত্র queryProductDetailsAsync() ব্যবহার করে এবং একবার আপনার অ্যাপের কোনও পুরানো সংস্করণ এখনও কেনাকাটা না করলে, আপনাকে আর একটি ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ অফার ব্যবহার করতে হবে না .

সাবস্ক্রিপশনগুলি এপিআই প্রকাশের মাধ্যমে সাবস্ক্রিপশন পরিচালনা করা

প্লে ডেভেলপার এপিআইতে সাবস্ক্রিপশন ক্রয়ের জন্য নতুন কার্যকারিতা রয়েছে। SKU ম্যানেজমেন্টের জন্য inappproducts API আগের মতই কাজ করে চলেছে, যার মধ্যে এককালীন ক্রয় পণ্য এবং সদস্যতাগুলি পরিচালনা করা সহ, তাই আপনার ইন্টিগ্রেশন বজায় রাখার জন্য আপনাকে কোনো তাৎক্ষণিক পরিবর্তন করতে হবে না।

তবে এটি লক্ষ করা গুরুত্বপূর্ণ যে গুগল প্লে কনসোলটি কেবলমাত্র নতুন সাবস্ক্রিপশন সত্তা ব্যবহার করে। একবার আপনি কনসোলে আপনার সাবস্ক্রিপশনগুলি সম্পাদনা শুরু করার পরে, inappproducts এপিআই আর সাবস্ক্রিপশনের জন্য আর ব্যবহার করা যাবে না

আপনি যদি মে 2022-এর আগে Publishing API ব্যবহার করে থাকেন, তাহলে যেকোনও সমস্যা এড়াতে, যেকোনও বিদ্যমান সাবস্ক্রিপশন এখন Google Play Console-এ শুধুমাত্র পঠনযোগ্য হিসেবে দেখা যাবে। আপনি যদি পরিবর্তনগুলি করার চেষ্টা করেন তবে আপনি এই সীমাবদ্ধতার ব্যাখ্যা দেওয়ার জন্য একটি সতর্কতা পেতে পারেন। কনসোলে আরও সাবস্ক্রিপশন সম্পাদনা করার আগে, নতুন সাবস্ক্রিপশন পাবলিশিং এন্ডপয়েন্ট ব্যবহার করতে আপনার ব্যাকএন্ড ইন্টিগ্রেশন আপডেট করা উচিত। নতুন monetization.subscriptions , monetization.subscriptions.baseplans , এবং monetization.subscriptions.offers এন্ডপয়েন্টগুলি আপনাকে সমস্ত উপলব্ধ বেস প্ল্যান এবং অফারগুলি পরিচালনা করতে দেয়৷ আপনি নিম্নলিখিত সারণীতে monetization.subscriptions অধীনে InAppProduct সত্তা থেকে নতুন অবজেক্টে কীভাবে বিভিন্ন ক্ষেত্র ম্যাপ করে তা দেখতে পারেন:

InAppProduct সাবস্ক্রিপশন
packageName packageName
sku productId
status basePlans[0].state
prices basePlans[0].regionalConfigs.price
listings তালিকা
defaultPrice সমতা নেই
subscriptionPeriod বেসপ্ল্যানস [0] .আউটোরনিউইংব্যাসপ্ল্যান্টাইপ.বিলিংপিরিয়ডডারেশন
trialPeriod বেসপ্ল্যানস [0] .অফার্স [0]। ফ্যাসেস [0]
gracePeriod basePlans[0].autoRenewingBasePlanType.gracePeriodDuration
subscriptionTaxesAndComplianceSettings ট্যাক্স এবং কমপ্লায়েন্স সেটিংস

এই প্রয়োজনীয় এপিআই আপডেট কেবল প্রকাশনা এপিআই (এসকেইউ ম্যানেজমেন্ট) এর জন্য প্রযোজ্য।

প্লে বিলিং লাইব্রেরি পরিবর্তন

ধীরে ধীরে স্থানান্তরকে সমর্থন করার জন্য, প্লে বিলিং লাইব্রেরিতে পূর্ববর্তী সংস্করণগুলিতে উপলব্ধ সমস্ত পদ্ধতি এবং বস্তু অন্তর্ভুক্ত রয়েছে৷ SkuDetails অবজেক্ট এবং querySkuDetailsAsync() মতো ফাংশন এখনও বিদ্যমান তাই আপনি অবিলম্বে বিদ্যমান সদস্যতা কোড আপডেট না করে নতুন কার্যকারিতা ব্যবহার করতে আপগ্রেড করতে পারেন। এছাড়াও আপনি পশ্চাদপদ-সামঞ্জস্যপূর্ণ হিসাবে চিহ্নিত করে এই পদ্ধতিগুলির মাধ্যমে কোন অফারগুলি উপলব্ধ তা নিয়ন্ত্রণ করতে পারেন৷

লিগ্যাসি পদ্ধতিগুলি রাখার পাশাপাশি, প্লে বিলিং লাইব্রেরি 5-এ এখন একটি নতুন ProductDetails অবজেক্ট এবং একটি সংশ্লিষ্ট queryProductDetailsAsync() পদ্ধতি রয়েছে যাতে নতুন সত্তা এবং কার্যকারিতা পরিচালনা করা যায়। বিদ্যমান ইন-অ্যাপ্লিকেশন পণ্যগুলি (এককালীন ক্রয় এবং গ্রাহকযোগ্য) এখন ProductDetails দ্বারা সমর্থিত।

সাবস্ক্রিপশনের জন্য, ProductDetails.getSubscriptionOfferDetails() সমস্ত বেস প্ল্যানের একটি তালিকা প্রদান করে এবং অফার করে যে ব্যবহারকারী কেনার যোগ্য। এর মানে হল যে আপনি ব্যবহারকারীর জন্য যোগ্য সমস্ত বেস প্ল্যান এবং অফারগুলি অ্যাক্সেস করতে পারবেন, পশ্চাদপদ-সামঞ্জস্যতা নির্বিশেষে। getSubscriptionOfferDetails() নন-সাবস্ক্রিপশন পণ্যের জন্য null প্রদান করে। এককালীন কেনাকাটার জন্য, আপনি getOneTimePurchaseOfferDetails() ব্যবহার করতে পারেন।

প্লে বিলিং লাইব্রেরি 5-এ ক্রয় প্রবাহ চালু করার জন্য নতুন এবং উত্তরাধিকার উভয় পদ্ধতিও অন্তর্ভুক্ত রয়েছে। BillingFlowParams অবজেক্টটি BillingClient.launchBillingFlow() এ পাস করা হলে একটি SkuDetails অবজেক্ট ব্যবহার করে কনফিগার করা হলে, সিস্টেম ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ বেস প্ল্যান বা অফার থেকে বিক্রি করার জন্য অফার তথ্য বের করে যা SKU-এর সাথে মিলে যায়। BillingClient.launchBillingFlow() এ পাস করা BillingFlowParams অবজেক্টটি যদি ProductDetailsParams অবজেক্ট ব্যবহার করে কনফিগার করা হয়, যার মধ্যে ProductDetails এবং একটি String রয়েছে যা অফার কেনার জন্য নির্দিষ্ট অফার টোকেনের প্রতিনিধিত্ব করে, তাহলে সিস্টেম ব্যবহারকারীর দ্বারা অর্জিত পণ্য সনাক্ত করতে সেই তথ্য ব্যবহার করে।

queryPurchasesAsync() ব্যবহারকারীর মালিকানাধীন সমস্ত কেনাকাটা ফেরত দেয়। অনুরোধ করা পণ্যের ধরন নির্দেশ করতে, আপনি একটি BillingClient.SkuType মান পাস করতে পারেন, পুরানো সংস্করণগুলির মতো, অথবা একটি QueryPurchasesParams অবজেক্ট যাতে একটি BillingClient.ProductType মান রয়েছে যা নতুন সদস্যতা সত্তার প্রতিনিধিত্ব করে৷

আমরা আপনার অ্যাপগুলিকে লাইব্রেরির 5 সংস্করণে শীঘ্রই আপডেট করার সুপারিশ করছি যাতে আপনি এই নতুন সদস্যতা বৈশিষ্ট্যগুলির সুবিধা নেওয়া শুরু করতে পারেন৷

সাবস্ক্রিপশন স্ট্যাটাস পরিচালনা

এই বিভাগটি Google Play বিলিং সিস্টেম ইন্টিগ্রেশনের ব্যাকএন্ড উপাদানগুলির প্রাথমিক পরিবর্তনগুলি বর্ণনা করে যা 5 সংস্করণে স্থানান্তরের জন্য প্রয়োগ করা প্রয়োজন৷

রিয়েল টাইম ডেভেলপার বিজ্ঞপ্তি

শীঘ্রই SubscriptionNotification অবজেক্টে আর subscriptionId থাকবে না। আপনি যদি সাবস্ক্রিপশন পণ্য শনাক্ত করার জন্য এই ক্ষেত্রের উপর নির্ভর করে থাকেন, তাহলে আপনাকে সাবস্ক্রিপশন স্ট্যাটাস থেকে এই তথ্যটি প্রাপ্ত করার জন্য আপডেট করা উচিত purchases.subscriptionv2:get ব্যবহার করে নোটিফিকেশন পাওয়ার পর। লাইন আইটেম সংগ্রহের প্রতিটি SubscriptionPurchaseLineItem উপাদান যা ক্রয়ের স্থিতির অংশ হিসাবে ফেরত দেওয়া হয় তাতে সংশ্লিষ্ট পণ্য আইডি অন্তর্ভুক্ত থাকবে।

সাবস্ক্রিপশন পারচেস এপিআই: সাবস্ক্রিপশন স্ট্যাটাস পাওয়া

সাবস্ক্রিপশন ক্রয় API এর পূর্ববর্তী সংস্করণগুলিতে, আপনি purchases.subscriptions:get ব্যবহার করে সদস্যতার স্থিতি জিজ্ঞাসা করতে পারেন। এই এন্ডপয়েন্ট অপরিবর্তিত এবং পশ্চাদপদ-সামঞ্জস্যপূর্ণ সাবস্ক্রিপশন ক্রয়ের জন্য কাজ করে চলেছে। এই এন্ডপয়েন্ট 2022 সালের মে মাসে প্রকাশিত কোনো নতুন কার্যকারিতা সমর্থন করে না

Subscriptions Purchases API-এর নতুন সংস্করণে, purchases.subscriptionsv2:get । এই API স্থানান্তরিত সাবস্ক্রিপশন, নতুন সাবস্ক্রিপশন (প্রিপেইড এবং স্বয়ংক্রিয়-পুনর্নবীকরণ উভয়ই) এবং সব ধরনের কেনাকাটার সাথে সামঞ্জস্যপূর্ণ। বিজ্ঞপ্তিগুলি পাওয়ার সময় আপনি সদস্যতার স্থিতি পরীক্ষা করতে এই শেষ পয়েন্টটি ব্যবহার করতে পারেন৷ প্রত্যাবর্তিত বস্তু, SubscriptionPurchaseV2 , নতুন ক্ষেত্র ধারণ করে, কিন্তু এটি এখনও লিগ্যাসি ডেটা অন্তর্ভুক্ত করে যা বিদ্যমান সাবস্ক্রিপশনগুলিকে সমর্থন করা চালিয়ে যাওয়ার জন্য প্রয়োজন৷

প্রিপেইড প্ল্যানের জন্য সাবস্ক্রিপশনPurchaseV2 ক্ষেত্র

প্রিপেইড প্ল্যানগুলিকে সমর্থন করার জন্য নতুন ক্ষেত্রগুলি যুক্ত করা হয়েছে, যা স্বয়ংক্রিয়ভাবে পুনর্নবীকরণের পরিবর্তে ব্যবহারকারী দ্বারা প্রসারিত হয়। সমস্ত ক্ষেত্র প্রিপেইড প্ল্যানগুলিতে প্রযোজ্য যেমন তারা স্বয়ংক্রিয় পুনর্নবীকরণ সাবস্ক্রিপশনের জন্য করে, নিম্নলিখিত ব্যতিক্রমগুলি সহ:

  • [নতুন ক্ষেত্র] লাইনআইটেম[0].prepaid_plan.allowExtendAfterTime : বোঝায় যখন একজন ব্যবহারকারীকে তাদের প্রিপেইড প্ল্যান প্রসারিত করার জন্য আরেকটি টপ-আপ কেনার অনুমতি দেওয়া হবে, কারণ একজন ব্যবহারকারীকে একবারে শুধুমাত্র একটি অব্যবহৃত টপ-আপ রাখার অনুমতি দেওয়া হয়।
  • [নতুন ক্ষেত্র] SubscriptionState : সাবস্ক্রিপশন অবজেক্টের অবস্থা নির্দিষ্ট করে। প্রিপেইড প্ল্যানের জন্য, এই মান সর্বদা হয় ACTIVE , PENDING বা CANCELED
  • lineItems[0].expiryTime : এই ক্ষেত্রটি সর্বদা প্রিপেইড প্ল্যানের জন্য উপস্থিত থাকে।
  • paused_state_context : এই ক্ষেত্রটি কখনই উপস্থিত থাকে না, কারণ প্রিপেইড প্ল্যানগুলি বিরতি দিতে পারে না।
  • lineItems[0].auto_renewing_plan : প্রিপেইড প্ল্যানের জন্য উপস্থিত নয়।
  • canceled_state_context : প্রিপেইড প্ল্যানের জন্য উপস্থিত নয়, কারণ এই ক্ষেত্রটি শুধুমাত্র সেই ব্যবহারকারীদের জন্য প্রযোজ্য যারা সক্রিয়ভাবে একটি সদস্যতা বাতিল করে।
  • lineItems[0].productId : এই ক্ষেত্রটি আগের সংস্করণ থেকে subscriptionId প্রতিস্থাপন করে।

পুনরাবৃত্ত সাবস্ক্রিপশনের জন্য SubscriptionPurchaseV2 ক্ষেত্র

purchases.subscriptionv2 নতুন ক্ষেত্র রয়েছে যা নতুন সাবস্ক্রিপশন অবজেক্ট সম্পর্কে আরও বিশদ প্রদান করে। নিম্নলিখিত সারণীটি দেখায় কিভাবে লিগ্যাসি সাবস্ক্রিপশন এন্ডপয়েন্ট ম্যাপ থেকে ক্ষেত্রগুলি purchases.subscriptionv2 এর সংশ্লিষ্ট ক্ষেত্রগুলিতে যায়৷

সাবস্ক্রিপশন ক্রয় সদস্যতা ক্রয়V2
countryCode regionCode
orderId latestOrderId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems ( সাবস্ক্রিপশনPurchaseLineItem এর তালিকা) যা ক্রয়ের সাথে অর্জিত পণ্যগুলিকে প্রতিনিধিত্ব করে
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.basePlanId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.offerId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.offerTags
startTimeMillis startTime
expiryTimeMillis lineItems.expiryTime (ক্রয়ে অর্জিত প্রতিটি সাবস্ক্রিপশনের নিজস্ব expiryTime আছে)
(কোন সমতুল্য ক্ষেত্র নেই) subscriptionState ( সাবস্ক্রিপশনের অবস্থা নির্দেশ করে)
(কোন সমতুল্য ক্ষেত্র নেই) pausedStateContext (যদি সাবস্ক্রিপশন স্থিতি SUBSCRIPTION_STATE_PAUSED হয় তবেই উপস্থিত)
autoResumeTimeMillis pausedStateContext.autoResumeTime
(কোন সমতুল্য ক্ষেত্র নেই) canceledStateContext (সাবস্ক্রিপশন স্ট্যাটাস SUBSCRIPTION_STATE_CANCELED হলেই কেবল উপস্থিত)
(কোন সমতুল্য ক্ষেত্র নেই) testPurchase (শুধুমাত্র লাইসেন্সপ্রাপ্ত পরীক্ষকের কেনাকাটায় উপস্থিত)
autoRenewing lineItems.autoRenewingPlan.autoRenewEnabled
priceCurrenceCode , priceAmountMicros lineItems.autoRenewingPlan.recurringPrice
introductoryPriceInfo (কোন সমতুল্য ক্ষেত্র নেই)
This information can be found in the offer for each of the subscriptions purchased.
বিকাশকারী পেলোড (কোন সমতুল্য ক্ষেত্র নেই) ডেভেলপার পেলোড অবমুক্ত করা হয়েছে
পেমেন্ট স্টেট (কোন সমতুল্য ক্ষেত্র নেই)
আপনি subscriptionState থেকে অর্থপ্রদানের অবস্থা অনুমান করতে পারেন:
  • পেমেন্ট মুলতুবি আছে:
    • SUBSCRIPTION_STATE_PENDING (মুলতুবি লেনদেনের সাথে নতুন কেনাকাটা)
    • SUBSCRIPTION_STATE_IN_GRACE_PERIOD
    • SUBSCRIPTION_STATE_ON_HOLD
  • পেমেন্ট গৃহীত হয়েছে:
    • SUBSCRIPTION_STATE_ACTIVE
  • বিনামূল্যে ট্রায়াল:
    • (কোন সমতুল্য ক্ষেত্র নেই)
  • বিলম্বিত আপগ্রেড/ডাউনগ্রেড:
    • SUBSCRIPTION_STATE_PENDING
cancelReason , userCancellationTimeMillis , cancelSurveyResult canceledStateContext
linkedPurchaseToken linkedPurchaseToken (কোন পরিবর্তন নেই)
purchaseType পরীক্ষা: testPurchase মাধ্যমে
প্রচার: signupPromotion
priceChange lineItems.autoRenewingPlan.priceChangeDetails
profileName , emailAddress , givenName , familyName , profileId subscribeWithGoogleInfo
acknowledgementState acknowledgementState (no change)
promotionType , promotionCode signupPromotion
externalAccountId , obfuscatedExternalAccountId , obfuscatedExteranlProfileId externalAccountIdentifiers

অন্যান্য সদস্যতা ব্যবস্থাপনা ফাংশন

যদিও purchases.subscriptions:get purchases.subscriptionsv2:get এ আপগ্রেড করা হয়েছে, বাকি ডেভেলপার সাবস্ক্রিপশন ম্যানেজমেন্ট ফাংশনগুলি এখন পর্যন্ত purchases.subscriptions এন্ডপয়েন্টে অপরিবর্তিত রয়েছে, যাতে আপনি purchases.subscriptions:acknowledge , purchases.subscriptions:cancel , purchases.subscriptions:defer , purchases.subscriptions:refund , এবং purchases.subscriptions:revoke

মূল্য নির্ধারণ API

Use the monetization.convertRegionPrices endpoint to calculate regional prices as you would through the Play Console. এই পদ্ধতিটি যেকোনও প্লে-সমর্থিত মুদ্রায় একক মূল্য গ্রহণ করে এবং Google Play কেনাকাটা সমর্থন করে এমন সমস্ত অঞ্চলের জন্য রূপান্তরিত মূল্য (যেখানে প্রযোজ্য করের ডিফল্ট হার সহ) ফেরত দেয়।

,

Google Play এর বিলিং সিস্টেম হল একটি পরিষেবা যা আপনাকে আপনার Android অ্যাপে ডিজিটাল পণ্য এবং সামগ্রী বিক্রি করতে দেয়৷ মে 2022-এর রিলিজের সাথে, আমরা সাবস্ক্রিপশন পণ্যগুলিকে কীভাবে সংজ্ঞায়িত করা হয় তা পরিবর্তন করেছি এবং এটি কীভাবে অ্যাপ-মধ্যস্থ বিক্রি এবং আপনার ব্যাকএন্ডে পরিচালনা করা হয় তা প্রভাবিত করে। আপনি যদি প্রথমবার Google Play বিলিং-এর সাথে একীভূত হয়ে থাকেন, তাহলে আপনি Getting ready পড়ে আপনার ইন্টিগ্রেশন শুরু করতে পারেন।

আপনি যদি মে 2022-এর আগে Google Play বিলিং-এর মাধ্যমে সাবস্ক্রিপশন বিক্রি করে থাকেন, তাহলে আপনার বিদ্যমান সাবস্ক্রিপশন বজায় রেখে নতুন বৈশিষ্ট্যগুলি কীভাবে গ্রহণ করবেন তা বোঝা গুরুত্বপূর্ণ।

প্রথম যে জিনিসটি জানতে হবে তা হল আপনার সমস্ত বিদ্যমান সাবস্ক্রিপশন, অ্যাপ এবং ব্যাকএন্ড ইন্টিগ্রেশন মে 2022-এর রিলিজের আগে যেমন কাজ করে । আপনাকে কোনো তাৎক্ষণিক পরিবর্তন করতে হবে না, এবং আপনি সময়ের সাথে সাথে এই নতুন বৈশিষ্ট্যগুলি গ্রহণ করতে পারেন। Google Play বিলিং লাইব্রেরির প্রতিটি বড় রিলিজ রিলিজের পর দুই বছরের জন্য সমর্থিত। Google Play Developer API-এর সাথে বিদ্যমান ইন্টিগ্রেশনগুলি আগের মতোই কাজ করে চলেছে৷

এখানে মে 2022 আপডেটগুলির একটি ওভারভিউ রয়েছে:

  • নতুন Google Play Console আপনাকে সদস্যতা, বেস প্ল্যান এবং অফার তৈরি এবং পরিচালনা করতে দেয়। এর মধ্যে নতুন এবং স্থানান্তরিত সাবস্ক্রিপশন উভয়ই অন্তর্ভুক্ত রয়েছে।
  • Play Developer API-এ API ফর্মে নতুন Google Play Console UI কার্যকারিতা সমর্থন করার জন্য আপডেট রয়েছে। উল্লেখযোগ্যভাবে, সাবস্ক্রিপশন ক্রয় API- এর একটি নতুন সংস্করণ রয়েছে। সদস্যতা স্থিতি পরীক্ষা করতে এবং সদস্যতা কেনাকাটা পরিচালনা করতে এই API ব্যবহার করুন।
  • নতুন প্লে বিলিং লাইব্রেরি সংস্করণ 5 আপনার অ্যাপটিকে সমস্ত নতুন সদস্যতা বৈশিষ্ট্য থেকে উপকৃত হতে দেয়৷ আপনি যখন 5 সংস্করণে আপগ্রেড করতে প্রস্তুত হন, তখন মাইগ্রেশন গাইডের নির্দেশিকা অনুসরণ করুন৷

সদস্যতা কনফিগারেশন

Google Play Console-এর মাধ্যমে সদস্যতা পরিচালনা করা

2022 সালের মে পর্যন্ত, আপনি Google Play Console-এ কিছু পার্থক্য লক্ষ্য করবেন।

একটি সাবস্ক্রিপশনে এখন একাধিক বেস প্ল্যান এবং অফার থাকতে পারে। পূর্বে তৈরি করা সাবস্ক্রিপশন SKUগুলি এখন এই নতুন সাবস্ক্রিপশন, বেস প্ল্যান এবং অফার অবজেক্ট হিসাবে প্লে কনসোলে উপস্থিত হয়। If you haven't already, see Recent changes to subscriptions in Play Console for descriptions of the new objects, including their functionality and configuration. এই নতুন ফর্ম্যাটে Google Play Console-এ আপনার আগে থেকে থাকা সমস্ত সদস্যতা পণ্য প্রদর্শিত হবে। প্রতিটি SKU এখন একটি সাবস্ক্রিপশন অবজেক্ট দ্বারা প্রতিনিধিত্ব করা হয় যাতে প্রযোজ্য হলে একটি একক বেস প্ল্যান এবং ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ অফার থাকে।

যেহেতু পুরোনো ইন্টিগ্রেশন আশা করে যে প্রতিটি সাবস্ক্রিপশন একটি একক অফার অন্তর্ভুক্ত করবে, একটি SkuDetails অবজেক্ট দ্বারা উপস্থাপিত হবে, তাই প্রতিটি সাবস্ক্রিপশনে একটি একক পশ্চাদপদ-সামঞ্জস্যপূর্ণ বেস প্ল্যান বা অফার থাকতে পারে। ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ বেস প্ল্যান বা অফারটি এমন অ্যাপগুলির জন্য একটি SKU-এর অংশ হিসাবে ফেরত দেওয়া হয় যেগুলি এখন-অপ্রচলিত querySkuDetailsAsync() পদ্ধতি ব্যবহার করছে৷ ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ অফারগুলি কনফিগার এবং পরিচালনার বিষয়ে আরও তথ্যের জন্য, সাবস্ক্রিপশন বুঝতে দেখুন একবার আপনার অ্যাপটি শুধুমাত্র queryProductDetailsAsync() ব্যবহার করে এবং একবার আপনার অ্যাপের কোনও পুরানো সংস্করণ এখনও কেনাকাটা না করলে, আপনাকে আর একটি ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ অফার ব্যবহার করতে হবে না .

সাবস্ক্রিপশন পাবলিশিং API এর মাধ্যমে সদস্যতা পরিচালনা করা

প্লে ডেভেলপার API-এ সদস্যতা কেনার জন্য নতুন কার্যকারিতা রয়েছে। SKU ম্যানেজমেন্টের জন্য inappproducts API আগের মতই কাজ করে চলেছে, যার মধ্যে এককালীন ক্রয় পণ্য এবং সদস্যতাগুলি পরিচালনা করা সহ, তাই আপনার ইন্টিগ্রেশন বজায় রাখার জন্য আপনাকে কোনো তাৎক্ষণিক পরিবর্তন করতে হবে না।

যাইহোক, এটা মনে রাখা গুরুত্বপূর্ণ যে Google Play Console শুধুমাত্র নতুন সাবস্ক্রিপশন সত্তা ব্যবহার করে। একবার আপনি কনসোলে আপনার সদস্যতা সম্পাদনা করা শুরু করলে, সাবস্ক্রিপশনের জন্য inappproducts API আর ব্যবহার করা যাবে না

আপনি যদি মে 2022-এর আগে Publishing API ব্যবহার করে থাকেন, তাহলে যেকোনও সমস্যা এড়াতে, যেকোনও বিদ্যমান সাবস্ক্রিপশন এখন Google Play Console-এ শুধুমাত্র পঠনযোগ্য হিসেবে দেখা যাবে। আপনি পরিবর্তন করার চেষ্টা করলে, আপনি এই সীমাবদ্ধতা ব্যাখ্যা করে একটি সতর্কতা পেতে পারেন। কনসোলে আরও সাবস্ক্রিপশন সম্পাদনা করার আগে, নতুন সাবস্ক্রিপশন পাবলিশিং এন্ডপয়েন্ট ব্যবহার করতে আপনার ব্যাকএন্ড ইন্টিগ্রেশন আপডেট করা উচিত। নতুন monetization.subscriptions , monetization.subscriptions.baseplans , এবং monetization.subscriptions.offers এন্ডপয়েন্টগুলি আপনাকে সমস্ত উপলব্ধ বেস প্ল্যান এবং অফারগুলি পরিচালনা করতে দেয়৷ আপনি নিম্নলিখিত সারণীতে monetization.subscriptions অধীনে InAppProduct সত্তা থেকে নতুন অবজেক্টে কীভাবে বিভিন্ন ক্ষেত্র ম্যাপ করে তা দেখতে পারেন:

InAppProduct সাবস্ক্রিপশন
packageName packageName
sku productId
status basePlans[0].state
prices basePlans[0].regionalConfigs.price
listings তালিকা
defaultPrice সমতা নেই
subscriptionPeriod basePlans[0].autoRenewingBasePlanType.billingPeriodDuration
trialPeriod basePlans[0].offers[0].phases[0].Regional Configs[0].free
gracePeriod basePlans[0].autoRenewingBasePlanType.gracePeriodDuration
subscriptionTaxesAndComplianceSettings ট্যাক্স এবং কমপ্লায়েন্স সেটিংস

এই প্রয়োজনীয় API আপডেট শুধুমাত্র পাবলিশিং API (SKU ম্যানেজমেন্ট) এ প্রযোজ্য।

প্লে বিলিং লাইব্রেরি পরিবর্তন

ধীরে ধীরে স্থানান্তরকে সমর্থন করার জন্য, প্লে বিলিং লাইব্রেরিতে পূর্ববর্তী সংস্করণগুলিতে উপলব্ধ সমস্ত পদ্ধতি এবং বস্তু অন্তর্ভুক্ত রয়েছে৷ SkuDetails অবজেক্ট এবং querySkuDetailsAsync() মতো ফাংশন এখনও বিদ্যমান তাই আপনি অবিলম্বে বিদ্যমান সদস্যতা কোড আপডেট না করে নতুন কার্যকারিতা ব্যবহার করতে আপগ্রেড করতে পারেন। এছাড়াও আপনি পশ্চাদপদ-সামঞ্জস্যপূর্ণ হিসাবে চিহ্নিত করে এই পদ্ধতিগুলির মাধ্যমে কোন অফারগুলি উপলব্ধ তা নিয়ন্ত্রণ করতে পারেন৷

লিগ্যাসি পদ্ধতিগুলি রাখার পাশাপাশি, প্লে বিলিং লাইব্রেরি 5-এ এখন একটি নতুন ProductDetails অবজেক্ট এবং একটি সংশ্লিষ্ট queryProductDetailsAsync() পদ্ধতি রয়েছে যাতে নতুন সত্তা এবং কার্যকারিতা পরিচালনা করা যায়। বিদ্যমান অ্যাপ-মধ্যস্থ পণ্য (এককালীন কেনাকাটা এবং ভোগ্য সামগ্রী) এখন ProductDetails দ্বারা সমর্থিত।

সাবস্ক্রিপশনের জন্য, ProductDetails.getSubscriptionOfferDetails() সমস্ত বেস প্ল্যানের একটি তালিকা প্রদান করে এবং অফার করে যে ব্যবহারকারী কেনার যোগ্য। এর মানে হল যে আপনি ব্যবহারকারীর জন্য যোগ্য সমস্ত বেস প্ল্যান এবং অফারগুলি অ্যাক্সেস করতে পারবেন, পশ্চাদপদ-সামঞ্জস্যতা নির্বিশেষে। getSubscriptionOfferDetails() নন-সাবস্ক্রিপশন পণ্যের জন্য null প্রদান করে। এককালীন কেনাকাটার জন্য, আপনি getOneTimePurchaseOfferDetails() ব্যবহার করতে পারেন।

প্লে বিলিং লাইব্রেরি 5-এ ক্রয় প্রবাহ চালু করার জন্য নতুন এবং উত্তরাধিকার উভয় পদ্ধতিও অন্তর্ভুক্ত রয়েছে। BillingFlowParams অবজেক্টটি BillingClient.launchBillingFlow() এ পাস করা হলে একটি SkuDetails অবজেক্ট ব্যবহার করে কনফিগার করা হলে, সিস্টেম ব্যাকওয়ার্ড-সামঞ্জস্যপূর্ণ বেস প্ল্যান বা অফার থেকে বিক্রি করার জন্য অফার তথ্য বের করে যা SKU-এর সাথে মিলে যায়। BillingClient.launchBillingFlow() এ পাস করা BillingFlowParams অবজেক্টটি যদি ProductDetailsParams অবজেক্ট ব্যবহার করে কনফিগার করা হয়, যার মধ্যে ProductDetails এবং একটি String রয়েছে যা অফার কেনার জন্য নির্দিষ্ট অফার টোকেনের প্রতিনিধিত্ব করে, তাহলে সিস্টেম ব্যবহারকারীর দ্বারা অর্জিত পণ্য সনাক্ত করতে সেই তথ্য ব্যবহার করে।

queryPurchasesAsync() ব্যবহারকারীর মালিকানাধীন সমস্ত কেনাকাটা ফেরত দেয়। To indicate the requested product type, you can pass in a BillingClient.SkuType value, as in older versions, or a QueryPurchasesParams object that contains a BillingClient.ProductType value that represents the new subscription entities.

আমরা আপনার অ্যাপগুলিকে লাইব্রেরির 5 সংস্করণে শীঘ্রই আপডেট করার সুপারিশ করছি যাতে আপনি এই নতুন সদস্যতা বৈশিষ্ট্যগুলির সুবিধা নেওয়া শুরু করতে পারেন৷

সাবস্ক্রিপশন স্ট্যাটাস পরিচালনা

এই বিভাগটি Google Play বিলিং সিস্টেম ইন্টিগ্রেশনের ব্যাকএন্ড উপাদানগুলির প্রাথমিক পরিবর্তনগুলি বর্ণনা করে যা 5 সংস্করণে স্থানান্তরের জন্য প্রয়োগ করা প্রয়োজন৷

রিয়েল টাইম ডেভেলপার বিজ্ঞপ্তি

শীঘ্রই SubscriptionNotification অবজেক্টে আর subscriptionId থাকবে না। আপনি যদি সাবস্ক্রিপশন পণ্য শনাক্ত করার জন্য এই ক্ষেত্রের উপর নির্ভর করে থাকেন, তাহলে আপনাকে সাবস্ক্রিপশন স্ট্যাটাস থেকে এই তথ্যটি প্রাপ্ত করার জন্য আপডেট করা উচিত purchases.subscriptionv2:get ব্যবহার করে নোটিফিকেশন পাওয়ার পর। লাইন আইটেম সংগ্রহের প্রতিটি SubscriptionPurchaseLineItem উপাদান যা ক্রয়ের স্থিতির অংশ হিসাবে ফেরত দেওয়া হয় তাতে সংশ্লিষ্ট পণ্য আইডি অন্তর্ভুক্ত থাকবে।

সাবস্ক্রিপশন পারচেস এপিআই: সাবস্ক্রিপশন স্ট্যাটাস পাওয়া

সাবস্ক্রিপশন ক্রয় API এর পূর্ববর্তী সংস্করণগুলিতে, আপনি purchases.subscriptions:get ব্যবহার করে সদস্যতার স্থিতি জিজ্ঞাসা করতে পারেন। এই এন্ডপয়েন্ট অপরিবর্তিত এবং পশ্চাদপদ-সামঞ্জস্যপূর্ণ সাবস্ক্রিপশন ক্রয়ের জন্য কাজ করে চলেছে। এই এন্ডপয়েন্ট 2022 সালের মে মাসে প্রকাশিত কোনো নতুন কার্যকারিতা সমর্থন করে না

Subscriptions Purchases API-এর নতুন সংস্করণে, purchases.subscriptionsv2:get । এই API স্থানান্তরিত সাবস্ক্রিপশন, নতুন সাবস্ক্রিপশন (প্রিপেইড এবং স্বয়ংক্রিয়-পুনর্নবীকরণ উভয়ই) এবং সব ধরনের কেনাকাটার সাথে সামঞ্জস্যপূর্ণ। বিজ্ঞপ্তিগুলি পাওয়ার সময় আপনি সদস্যতার স্থিতি পরীক্ষা করতে এই শেষ পয়েন্টটি ব্যবহার করতে পারেন৷ প্রত্যাবর্তিত বস্তু, SubscriptionPurchaseV2 , নতুন ক্ষেত্র ধারণ করে, কিন্তু এটি এখনও লিগ্যাসি ডেটা অন্তর্ভুক্ত করে যা বিদ্যমান সাবস্ক্রিপশনগুলিকে সমর্থন করা চালিয়ে যাওয়ার জন্য প্রয়োজন৷

প্রিপেইড প্ল্যানের জন্য সাবস্ক্রিপশনPurchaseV2 ক্ষেত্র

প্রিপেইড প্ল্যানগুলিকে সমর্থন করার জন্য নতুন ক্ষেত্রগুলি যুক্ত করা হয়েছে, যা স্বয়ংক্রিয়ভাবে পুনর্নবীকরণের পরিবর্তে ব্যবহারকারী দ্বারা প্রসারিত হয়। সমস্ত ক্ষেত্র প্রিপেইড প্ল্যানগুলিতে প্রযোজ্য যেমন তারা স্বয়ংক্রিয় পুনর্নবীকরণ সাবস্ক্রিপশনের জন্য করে, নিম্নলিখিত ব্যতিক্রমগুলি সহ:

  • [নতুন ক্ষেত্র] লাইনআইটেম[0].prepaid_plan.allowExtendAfterTime : বোঝায় যখন একজন ব্যবহারকারীকে তাদের প্রিপেইড প্ল্যান প্রসারিত করার জন্য আরেকটি টপ-আপ কেনার অনুমতি দেওয়া হবে, কারণ একজন ব্যবহারকারীকে একবারে শুধুমাত্র একটি অব্যবহৃত টপ-আপ রাখার অনুমতি দেওয়া হয়।
  • [নতুন ক্ষেত্র] SubscriptionState : সাবস্ক্রিপশন অবজেক্টের অবস্থা নির্দিষ্ট করে। প্রিপেইড প্ল্যানের জন্য, এই মান সর্বদা হয় ACTIVE , PENDING বা CANCELED
  • lineItems[0].expiryTime : এই ক্ষেত্রটি সর্বদা প্রিপেইড প্ল্যানের জন্য উপস্থিত থাকে।
  • paused_state_context : এই ক্ষেত্রটি কখনই উপস্থিত থাকে না, কারণ প্রিপেইড প্ল্যানগুলি বিরতি দিতে পারে না।
  • lineItems[0].auto_renewing_plan : প্রিপেইড প্ল্যানের জন্য উপস্থিত নয়।
  • canceled_state_context : প্রিপেইড প্ল্যানের জন্য উপস্থিত নয়, কারণ এই ক্ষেত্রটি শুধুমাত্র সেই ব্যবহারকারীদের জন্য প্রযোজ্য যারা সক্রিয়ভাবে একটি সদস্যতা বাতিল করে।
  • lineItems[0].productId : এই ক্ষেত্রটি আগের সংস্করণ থেকে subscriptionId প্রতিস্থাপন করে।

পুনরাবৃত্ত সাবস্ক্রিপশনের জন্য SubscriptionPurchaseV2 ক্ষেত্র

purchases.subscriptionv2 নতুন ক্ষেত্র রয়েছে যা নতুন সাবস্ক্রিপশন অবজেক্ট সম্পর্কে আরও বিশদ প্রদান করে। নিম্নলিখিত সারণীটি দেখায় কিভাবে লিগ্যাসি সাবস্ক্রিপশন এন্ডপয়েন্ট ম্যাপ থেকে ক্ষেত্রগুলি purchases.subscriptionv2 এর সংশ্লিষ্ট ক্ষেত্রগুলিতে যায়৷

সাবস্ক্রিপশন ক্রয় সদস্যতা ক্রয়V2
countryCode regionCode
orderId latestOrderId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems ( সাবস্ক্রিপশনPurchaseLineItem এর তালিকা) যা ক্রয়ের সাথে অর্জিত পণ্যগুলিকে প্রতিনিধিত্ব করে
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.basePlanId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.offerId
(কোন সমতুল্য ক্ষেত্র নেই) lineItems.offerDetails.offerTags
startTimeMillis startTime
expiryTimeMillis lineItems.expiryTime (ক্রয়ে অর্জিত প্রতিটি সাবস্ক্রিপশনের নিজস্ব expiryTime আছে)
(কোন সমতুল্য ক্ষেত্র নেই) subscriptionState ( সাবস্ক্রিপশনের অবস্থা নির্দেশ করে)
(কোন সমতুল্য ক্ষেত্র নেই) pausedStateContext (যদি সাবস্ক্রিপশন স্থিতি SUBSCRIPTION_STATE_PAUSED হয় তবেই উপস্থিত)
autoResumeTimeMillis pausedStateContext.autoResumeTime
(কোন সমতুল্য ক্ষেত্র নেই) canceledStateContext (সাবস্ক্রিপশন স্ট্যাটাস SUBSCRIPTION_STATE_CANCELED হলেই কেবল উপস্থিত)
(কোন সমতুল্য ক্ষেত্র নেই) testPurchase (শুধুমাত্র লাইসেন্সপ্রাপ্ত পরীক্ষকের কেনাকাটায় উপস্থিত)
autoRenewing lineItems.autoRenewingPlan.autoRenewEnabled
priceCurrenceCode , priceAmountMicros lineItems.autoRenewingPlan.recurringPrice
introductoryPriceInfo (কোন সমতুল্য ক্ষেত্র নেই)
কেনা প্রতিটি সাবস্ক্রিপশনের offer এই তথ্য পাওয়া যাবে।
বিকাশকারী পেলোড (কোন সমতুল্য ক্ষেত্র নেই) ডেভেলপার পেলোড অবমুক্ত করা হয়েছে
পেমেন্ট স্টেট (কোন সমতুল্য ক্ষেত্র নেই)
আপনি subscriptionState থেকে অর্থপ্রদানের অবস্থা অনুমান করতে পারেন:
  • পেমেন্ট মুলতুবি আছে:
    • SUBSCRIPTION_STATE_PENDING (new purchases with pending transaction)
    • SUBSCRIPTION_STATE_IN_GRACE_PERIOD
    • SUBSCRIPTION_STATE_ON_HOLD
  • পেমেন্ট গৃহীত হয়েছে:
    • SUBSCRIPTION_STATE_ACTIVE
  • বিনামূল্যে ট্রায়াল:
    • (কোন সমতুল্য ক্ষেত্র নেই)
  • বিলম্বিত আপগ্রেড/ডাউনগ্রেড:
    • SUBSCRIPTION_STATE_PENDING
cancelReason , userCancellationTimeMillis , cancelSurveyResult canceledStateContext
linkedPurchaseToken linkedPurchaseToken (কোন পরিবর্তন নেই)
purchaseType পরীক্ষা: testPurchase মাধ্যমে
প্রচার: signupPromotion
priceChange lineItems.autoRenewingPlan.priceChangeDetails
profileName , emailAddress , givenName , familyName , profileId subscribeWithGoogleInfo
acknowledgementState acknowledgementState (no change)
promotionType , promotionCode signupPromotion
externalAccountId , obfuscatedExternalAccountId , obfuscatedExteranlProfileId externalAccountIdentifiers

অন্যান্য সদস্যতা ব্যবস্থাপনা ফাংশন

যদিও purchases.subscriptions:get কে purchases.subscriptionsv2:get এ আপগ্রেড করা হয়েছে, বাকি ডেভেলপার সাবস্ক্রিপশন ম্যানেজমেন্ট ফাংশনগুলি এখন পর্যন্ত purchases.subscriptions এন্ডপয়েন্টে অপরিবর্তিত রয়েছে, যাতে আপনি purchases.subscriptions:acknowledge , purchases.subscriptions:cancel , purchases.subscriptions:defer , purchases.subscriptions:refund , এবং purchases.subscriptions:revoke

মূল্য নির্ধারণ API

আপনি প্লে কনসোলের মাধ্যমে আঞ্চলিক মূল্য গণনা করতে monetization.convertRegionPrices এন্ডপয়েন্ট ব্যবহার করুন। এই পদ্ধতিটি যেকোনও প্লে-সমর্থিত মুদ্রায় একক মূল্য গ্রহণ করে এবং Google Play কেনাকাটা সমর্থন করে এমন সমস্ত অঞ্চলের জন্য রূপান্তরিত মূল্য (যেখানে প্রযোজ্য করের ডিফল্ট হার সহ) ফেরত দেয়।