পণ্য স্থানান্তর

মার্চেন্ট এপিআই আপনার পণ্যের ডেটা পরিচালনা করার জন্য একটি আরও শক্তিশালী এবং সহজবোধ্য উপায় নিয়ে এসেছে। প্রধান পরিবর্তনটি হলো পণ্যের ডেটাকে দুটি স্বতন্ত্র রিসোর্সে বিভক্ত করা: আপনার ডেটা জমা দেওয়ার জন্য ProductInput এবং পণ্যের স্ট্যাটাস ও সমস্যাসহ চূড়ান্ত, প্রক্রিয়াকৃত সংস্করণটি দেখার জন্য Product । এই নতুন কাঠামোটি আরও অনুমানযোগ্য এবং স্বচ্ছ অভিজ্ঞতা প্রদান করে।

এই নির্দেশিকাটি আপনাকে মূল পার্থক্যগুলো বুঝিয়ে দেবে, যা আপনাকে Content API for Shopping থেকে আপনার ইন্টিগ্রেশন মাইগ্রেট করতে সাহায্য করবে। নতুন ফিচারগুলো ব্যবহারের বিস্তারিত নির্দেশিকার জন্য, Manage your products দেখুন।

মূল পার্থক্য

শপিং-এর জন্য কন্টেন্ট এপিআই-এর তুলনায় মার্চেন্ট এপিআই-তে পণ্য ব্যবস্থাপনার সবচেয়ে উল্লেখযোগ্য পরিবর্তনগুলো নিচে দেওয়া হলো:

  • ইনপুট এবং প্রক্রিয়াকৃত ডেটার জন্য নির্দিষ্ট রিসোর্স : মার্চেন্ট এপিআই প্রোডাক্ট ম্যানেজমেন্টকে দুটি রিসোর্সে বিভক্ত করে। আপনি আপনার প্রোডাক্ট ডেটা ইনসার্ট, আপডেট এবং ডিলিট করার জন্য ProductInput রিসোর্সটি ব্যবহার করতে পারেন। গুগল আপনার ইনপুটগুলো প্রসেস করার পর, নিয়ম প্রয়োগ করে এবং সম্পূরক উৎস থেকে ডেটা একত্রিত করার পরে চূড়ান্ত প্রোডাক্টটি দেখার জন্য আপনি রিড-অনলি Product রিসোর্সটি ব্যবহার করতে পারেন।

  • পণ্যের নামের জন্য এনকোডিং : আপনি ProductInput.name এবং Product.name উভয় ফিল্ডের জন্য আনপ্যাডেড base64url (RFC 4648 সেকশন 5) এনকোডিং ব্যবহার করতে পারেন। যদি পণ্যের নামে মার্চেন্ট এপিআই (Merchant API) দ্বারা ব্যবহৃত অক্ষর বা ইউআরএল-সংরক্ষিত অক্ষর থাকে, তবে এনকোডিং বাধ্যতামূলক । উদাহরণস্বরূপ, পণ্যের নামে নিম্নলিখিত অক্ষরগুলির কোনোটি থাকলে আপনাকে অবশ্যই তা এনকোড করতে হবে:

    % . + / : ~ , ( * ! ) & ? = @ # $
    
  • সমন্বিত পণ্যের অবস্থা : productstatuses সার্ভিসটি সরিয়ে ফেলা হয়েছে। পণ্যের যাচাইকরণ সংক্রান্ত সমস্যা এবং গন্তব্যের অবস্থা এখন সরাসরি Product রিসোর্সের productStatus ফিল্ডের মধ্যে অন্তর্ভুক্ত করা হয়েছে, যা ডেটা পুনরুদ্ধারকে সহজ করে তুলেছে।

  • Predictable product updates : The new productInputs.patch method modifies a specific product input directly. This is a significant improvement over the Content API for Shopping, where updates could be unexpectedly overwritten by other feed uploads. In Merchant API, an update remains until that specific product input is updated again or deleted. Product updates are applied on ProductInput resource instead of processed Product resource.

  • আরও স্বচ্ছ ডেটা ব্যবস্থাপনার জন্য আপনার ডেটা উৎস বেছে নিন : এখন থেকে সমস্ত productInputs রাইট অপারেশনের জন্য একটি dataSource কোয়েরি প্যারামিটার প্রয়োজন হবে, যার ফলে আপনি কোন ডেটা উৎসটি পরিবর্তন করছেন তা সুস্পষ্টভাবে বোঝা যায়। আপনার যদি একাধিক উৎস থেকে ডেটা আসে, তবে এটি বিশেষভাবে কার্যকর।

  • নতুন রিসোর্স আইডেন্টিফায়ার : প্রোডাক্টগুলো এখন id ফিল্ডের পরিবর্তে একটি RESTful রিসোর্স name দ্বারা চিহ্নিত করা হয়। এর ফরম্যাটটি হলো accounts/{account}/products/{product}

  • কাস্টম ব্যাচ নেই : custombatch মেথডটি এখন আর উপলব্ধ নেই। আপনি একটিমাত্র HTTP কলে একাধিক অনুরোধ পাঠাতে অ্যাসিঙ্ক্রোনাস রিকোয়েস্ট অথবা HTTP ব্যাচিং ব্যবহার করতে পারেন।

  • যেকোনো ফিড লেবেল এবং ভাষার জন্য ডেটা সোর্স : মার্চেন্ট এপিআই ফিড লেবেল এবং ভাষা নির্দিষ্ট না করেই ডেটা সোর্স তৈরি করা সম্ভব করে, এবং এর ফলে যেকোনো ফিড লেবেল ও ভাষার পণ্য অন্তর্ভুক্ত করা যায়।

অনুরোধ

এই বিভাগে কন্টেন্ট এপিআই ফর শপিং এবং মার্চেন্ট এপিআই-এর রিকোয়েস্ট ফরম্যাটগুলোর তুলনা করা হয়েছে।

অনুরোধের বিবরণ কেনাকাটার জন্য কন্টেন্ট এপিআই মার্চেন্ট এপিআই
একটি পণ্য নিন GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products/{product}
পণ্যের তালিকা GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products
একটি পণ্য প্রবেশ করান POST https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products POST https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs:insert
একটি পণ্য আপডেট করুন PATCH https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} PATCH https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs/{productinput}
একটি পণ্য মুছে ফেলুন DELETE https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/products/{productId} DELETE https://merchantapi.googleapis.com/products/v1/accounts/{account}/productInputs/{productinput}
পণ্যের অবস্থা জানুন GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/productstatuses/{productId} GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products/{product}
পণ্যের অবস্থা তালিকাভুক্ত করুন GET https://shoppingcontent.googleapis.com/content/v2.1/{merchantId}/productstatuses GET https://merchantapi.googleapis.com/products/v1/accounts/{account}/products
ব্যাচ একাধিক অনুরোধ POST https://shoppingcontent.googleapis.com/content/v2.1/products/custombatch অ্যাসিঙ্ক্রোনাস অনুরোধ বা HTTP ব্যাচিং ব্যবহার করুন

শনাক্তকারী

মার্চেন্ট এপিআই-তে প্রোডাক্ট আইডেন্টিফায়ারের ফরম্যাট পরিবর্তন করে একটি স্ট্যান্ডার্ড REST রিসোর্স নেম করা হয়েছে।

শনাক্তকারী বিবরণ কেনাকাটার জন্য কন্টেন্ট এপিআই মার্চেন্ট এপিআই
পণ্যের আইডি কোলন : :) দ্বারা পৃথক করা খণ্ডাংশ দিয়ে গঠিত একটি স্ট্রিং।
ফর্ম্যাট: channel:contentLanguage:targetCountry:offerId অথবা channel:contentLanguage:feedLabel:offerId
উদাহরণ: online:en:US:sku123
একটি REST রিসোর্স name স্ট্রিং।
ফর্ম্যাট: accounts/{account}/products/{product} যেখানে {product} হল contentLanguage~feedLabel~offerId
উদাহরণ: accounts/12345/products/en~US~sku123 .
Encoding: Unpadded base64url encoding recommended and mandatory in case of product ids that contain characters used by Merchant API or URL-reserved characters.

পদ্ধতি

এই সারণিতে কন্টেন্ট এপিআই-এর শপিং মেথডগুলো এবং মার্চেন্ট এপিআই-তে সেগুলোর সমতুল্য মেথডগুলো দেখানো হয়েছে।

শপিং পদ্ধতির জন্য কন্টেন্ট এপিআই মার্চেন্ট এপিআই পদ্ধতি প্রাপ্যতা ও নোট
products.get products.get চূড়ান্ত, প্রক্রিয়াজাত পণ্যটি সংগ্রহ করে।
products.list products.list চূড়ান্ত ও প্রক্রিয়াজাত পণ্যগুলোর তালিকা।
products.insert productInputs.insert পণ্যের তথ্য প্রবেশ করানোর জন্য একটি dataSource প্রয়োজন।
products.update productInputs.patch এর আচরণটি উল্লেখযোগ্যভাবে ভিন্ন। এটি একটি নির্দিষ্ট পণ্যের ইনপুট আপডেট করে এবং এটি স্থায়ী।
products.delete productInputs.delete একটি নির্দিষ্ট পণ্যের ইনপুট মুছে ফেলে। এর জন্য একটি dataSource প্রয়োজন।
products.custombatch উপলব্ধ নয় অ্যাসিঙ্ক্রোনাস রিকোয়েস্ট অথবা HTTP ব্যাচিং ব্যবহার করুন।
productstatuses.get products.get productstatuses সার্ভিসটি সরিয়ে ফেলা হয়েছে। স্ট্যাটাস সংক্রান্ত তথ্য এখন Product রিসোর্সের অংশ।
productstatuses.list products.list productstatuses সার্ভিসটি সরিয়ে ফেলা হয়েছে। স্ট্যাটাস সংক্রান্ত তথ্য এখন Product রিসোর্সের অংশ।
productstatuses.custombatch উপলব্ধ নয় অ্যাসিঙ্ক্রোনাস রিকোয়েস্ট অথবা এইচটিটিপি ব্যাচিং ব্যবহার করুন।

বিস্তারিত ক্ষেত্রের পরিবর্তন

এই সারণিতে মার্চেন্ট এপিআই-তে পরিবর্তন করা, যোগ করা বা সরিয়ে দেওয়া গুরুত্বপূর্ণ ফিল্ডগুলো তুলে ধরা হয়েছে।

কেনাকাটার জন্য কন্টেন্ট এপিআই মার্চেন্ট এপিআই বর্ণনা
id name এখন একটি পণ্যের প্রাথমিক শনাক্তকারী হলো REST রিসোর্সের name । পণ্যের নামে মার্চেন্ট এপিআই (Merchant API) দ্বারা ব্যবহৃত অক্ষর বা ইউআরএল-সংরক্ষিত অক্ষর থাকলে, আনপ্যাডেড বেস৬৪ইউআরএল (unpadded base64url) এনকোডিং ব্যবহার করার পরামর্শ দেওয়া হয় এবং এটি বাধ্যতামূলক।
শীর্ষ-স্তরের পণ্য ডেটা নির্দিষ্টকরণ বৈশিষ্ট্যসমূহ (যেমন, title , price , link ) productAttributes object পণ্যের অ্যাট্রিবিউট যেমন title , price এবং link এখন আর টপ-লেভেল ফিল্ড নয়। এগুলো এখন Product এবং ProductInput উভয় রিসোর্সের productAttributes ) অবজেক্টের মধ্যে গ্রুপ করা হয়েছে। এটি একটি পরিচ্ছন্ন এবং আরও সুসংগঠিত রিসোর্স কাঠামো প্রদান করে।
targetCountry feedLabel মার্চেন্ট সেন্টারের কার্যকারিতার সাথে সামঞ্জস্য রাখতে রিসোর্সের নামে এখন targetCountry পরিবর্তে feedLabel ব্যবহার করা হয়।
feedId dataSource (কোয়েরি প্যারামিটার) এখন থেকে productInputs সকল রাইট মেথডের ( insert , update , delete ) জন্য dataSource নাম একটি আবশ্যিক কোয়েরি প্যারামিটার।
channel উপলব্ধ নয়। শুধুমাত্র স্থানীয় পণ্যের জন্য legacy_local ব্যবহার করুন। মার্চেন্ট এপিআই-তে channel ফিল্ডটি আর নেই। শপিং-এর জন্য কন্টেন্ট এপিআই-তে যেসব প্রোডাক্টের LOCAL চ্যানেল রয়েছে, সেগুলোর ক্ষেত্রে এর পরিবর্তে legacy_local ফিল্ডটির মান true সেট করতে হবে।
উপলব্ধ নয় versionNumber ProductInput এ একটি নতুন ঐচ্ছিক ফিল্ড যা প্রাথমিক ডেটা উৎসগুলিতে ভুল ক্রমে ডেটা সন্নিবেশ রোধ করতে ব্যবহার করা যেতে পারে।
নির্দিষ্ট মান সেট সহ string টাইপের ফিল্ড নির্দিষ্ট মান সেট সহ enum টাইপের ফিল্ড প্রোডাক্ট অ্যাট্রিবিউটের অন্তর্গত যেসব ফিল্ডের নির্দিষ্ট মান সেট রয়েছে (যেমন excluded_destinations , availability ), সেগুলো এখন enum টাইপের।