কলব্যাক যোগ করুন এবং মুছুন

এই নির্দেশিকাটি ব্যাখ্যা করে কিভাবে Google Wallet API এর সাথে কলব্যাক ব্যবহার করতে হয়৷ যখন একটি মূল্যবান তৈরি বা মুছে ফেলা হয়, তখন Google আপনার পছন্দের একটি HTTPS এন্ডপয়েন্টে কলব্যাক করতে পারে। এই কলব্যাকটি ক্লাস-নির্দিষ্ট, এবং এতে ক্লাস, অবজেক্ট এবং ইভেন্টের প্রকারের মতো ইভেন্ট সম্পর্কিত ডেটা অন্তর্ভুক্ত থাকে। ব্যবহারকারীর যোগ এবং মুছে ফেলার সংখ্যার সাথে সিঙ্কে থাকার জন্য এটি ব্যবহার করা যেতে পারে। উদাহরণস্বরূপ, প্রচারমূলক ইভেন্টের সময় গ্রাহকের ব্যস্ততা ট্র্যাক করতে একটি বিশ্লেষণ অ্যাপ্লিকেশনে ইভেন্টগুলি পাঠানোর জন্য কলব্যাকগুলি কনফিগার করা যেতে পারে।

পূর্বশর্ত

আপনি শুরু করার আগে, নিম্নলিখিত পূর্বশর্তগুলি পর্যালোচনা করুন:

  • একটি HTTPS এন্ডপয়েন্ট দাঁড় করান যা POST অনুরোধ পরিচালনা করে। এই শেষ বিন্দু সর্বজনীনভাবে উপলব্ধ করা প্রয়োজন.
  • প্রতিটি ক্লাসের জন্য প্রোগ্রাম্যাটিকভাবে কলব্যাক এন্ডপয়েন্ট আপডেট করুন। REST API-এ শ্রেণী অনুসারে callbackOptions বৈশিষ্ট্য দেখুন।
  • প্রস্তাবিত: স্বাক্ষর যাচাই করতে টিঙ্ক লাইব্রেরি ব্যবহার করুন।

কলব্যাক বাস্তবায়ন করুন

কোনো বস্তুতে ব্যবহারকারীর দ্বারা সম্পাদিত প্রতিটি যোগ বা মুছে ফেলার জন্য, Google প্রতি-শ্রেণির URL-এ যোগ বা মুছে ফেলার বিবরণ সহ ব্যবসায়ীদের কলব্যাক করে। বার্তাটির সত্যতা যাচাই করতে ব্যবসায়ীদের প্রথমে পাবলিক কী ব্যবহার করতে হবে। কলব্যাকগুলি বার্তাটি যাচাই করার পরে, কলব্যাকগুলি ডাউনস্ট্রিম অপারেশনগুলির জন্য ব্যবহার করা যেতে পারে৷

স্বাক্ষর যাচাই করুন

আমরা সুপারিশ করি যে আপনি যখন আপনার HTTPS এন্ডপয়েন্ট বাস্তবায়ন করবেন তখন বার্তা স্বাক্ষর যাচাই করতে আপনি Tink লাইব্রেরি ব্যবহার করুন। Tink লাইব্রেরি PaymentMethodTokenRecipient প্রদান করে, একটি ইউটিলিটি যা স্বয়ংক্রিয়ভাবে স্বাক্ষর যাচাই করে এবং সফল যাচাইয়ের পর প্রকৃত বার্তা ফেরত দেয়।

নিম্নলিখিত উদাহরণটি দেখায় কিভাবে Tink লাইব্রেরি ব্যবহার করে PaymentMethodTokenRecipient বাস্তবায়ন করতে হয়:

import java.io.IOException;
import javax.servlet.http.*;
import com.google.common.io.CharStreams;
import com.google.crypto.tink.apps.paymentmethodtoken.*;

// Replace ISSUER_ID with your issuer id
private static final String RECIPIENT_ID = "ISSUER_ID";

private static final String PUBLIC_KEY_URL = "https://pay.google.com/gp/m/issuer/keys";
private static final String SENDER_ID = "GooglePayPasses";
private static final String PROTOCOL = "ECv2SigningOnly";

private static final GooglePaymentsPublicKeysManager keysManager = new GooglePaymentsPublicKeysManager.Builder()
        .setKeysUrl(PUBLIC_KEY_URL)
        .build();

public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {
  try {
    // Extract signed message with signature from POST request body.
    String signedMessage = CharStreams.toString(request.getReader());
    PaymentMethodTokenRecipient recipient =
            new PaymentMethodTokenRecipient.Builder()
                    .protocolVersion(PROTOCOL)
                    .fetchSenderVerifyingKeysWith(keysManager)
                    .senderId(SENDER_ID)
                    .recipientId(RECIPIENT_ID)
                    .build();

    String serializedJsonMessage = recipient.unseal(signedMessage);

    // Use serializedJsonMessage to extract the details
  } catch (Exception e) {
    // Handle the error
  }
}

Expected message format

The message format is JSON that's serialized into a string with the following properties:

Identifier Description
classId

Fully qualified class ID. Uses the following format:

<issuer_id.class_id>
objectId

সম্পূর্ণ যোগ্য অবজেক্ট আইডি। নিম্নলিখিত বিন্যাস ব্যবহার করে:

<issuer_id.object_id>
expTimeMillis EPOCH থেকে মিলিসেকেন্ডে মেয়াদ শেষ হওয়ার সময়। মেয়াদ শেষ হওয়ার পরে, বার্তাটি অবৈধ বলে গণ্য করা দরকার।
eventType DELETE এবং SAVE এর জন্য del বা save করা যেতে পারে।
nonce কোনো ডুপ্লিকেট ডেলিভারি ট্র্যাক না.

একটি Google সার্ভার থেকে অনুরোধ পরিচালনা করুন

নিম্নলিখিতটি আপনার কলব্যাক এন্ডপয়েন্টে পাঠানো অনুরোধের শিরোনামের মূল ক্ষেত্রগুলির একটি তালিকা:

  • ব্যবহারকারী-এজেন্ট: Googlebot
  • বিষয়বস্তুর প্রকার: application/json

আপনার সার্ভার কনফিগার করুন যাতে এটি অনুরোধ প্রত্যাখ্যান না করে। এটি করার জন্য, আপনি robots.txt এ নিম্নলিখিত সেট করতে পারেন:

User-agent: Googlebot
Disallow:

পুনরায় চেষ্টা করে

কলব্যাকগুলি সর্বোত্তম প্রচেষ্টার ভিত্তিতে হয়৷ Google ক্ষণস্থায়ী ব্যর্থতার জন্য অ্যাকাউন্টে দুবার চেষ্টা করে। দুবার চেষ্টা করার পরে, Google বার্তাটি মুছে দেয় এবং এটি আবার পাঠানোর চেষ্টা করে না।

ডুপ্লিকেট ডেলিভারি

কিছু ক্ষেত্রে ডুপ্লিকেট ডেলিভারি হতে পারে। আমরা সুপারিশ করি যে আপনি তাদের অনুমান করার জন্য nonce ব্যবহার করুন।