GetReader
GetReader
একটি প্রকাশককে যাচাই করার অনুমতি দেয় যদি একটি পরিচিত PPID সহ তাদের পাঠকদের মধ্যে একজন তাদের সাবস্ক্রিপশন Google-এর সাথে লিঙ্ক করে থাকে। একটি GET
অনুরোধ ব্যবহার করে, প্রকাশক একটি নির্দিষ্ট প্রকাশনা আইডির অন্তর্গত একটি PPID-এর জন্য প্রশ্ন করে।
অনুরোধ
REST API: অনুরোধ GET
https://readerrevenuesubscriptionlinking.googleapis.com/v1/publications/publicationId/readers/ppid
ক্লায়েন্ট লাইব্রেরি (Node.js)
async function getReader(ppid) {
const publicationId = process.env.PUBLICATION_ID;
return await client.publications.readers.get({
name: `publications/${publicationId}/readers/${ppid}`,
});
};
প্রতিক্রিয়া
এন্ডপয়েন্ট হয় একটি JSON বডি সহ একটি 200 প্রদান করবে যার মধ্যে লিঙ্ক করা সাবস্ক্রিপশনের created_time
আছে, অথবা যদি প্রকাশনার জন্য কোনো PPID পাওয়া না যায় তাহলে একটি ত্রুটি। আরো তথ্যের জন্য ত্রুটি বিভাগ দেখুন.
{
"name": "publications/CAowqfCKCw/readers/22553",
"createTime": "2025-07-30T18:26:58.050224Z",
"publicationId": "CAowqfCKCw",
"ppid": "22553",
"originatingPublicationId": "CAowqfCKCw"
}
GetReaderEntitlements
GetReaderEntitlements
একজন প্রকাশককে একটি PPID এর জন্য এনটাইটেলমেন্টের জন্য জিজ্ঞাসা করার অনুমতি দেয় যা প্রকাশক পূর্বে প্রদান করেছিলেন। একটি GET অনুরোধ ব্যবহার করে, প্রকাশক একটি PPID এবং প্রকাশনা আইডি প্রদান করে এনটাইটেলমেন্টের জন্য অনুরোধ করেন।
অনুরোধ
REST API: অনুরোধ GET
https://readerrevenuesubscriptionlinking.googleapis.com/v1/publications/publicationId/readers/ppid/entitlements
ক্লায়েন্ট লাইব্রেরি (Node.js)
async function getReaderEntitlements(ppid) {
const publicationId = process.env.PUBLICATION_ID;
return await client.publications.readers.getEntitlements({
name: `publications/${publicationId}/readers/${ppid}/entitlements`
});
};
প্রতিক্রিয়া
একটি সফল অনুরোধের জন্য, রিটার্ন ফরম্যাটটি UpdateReaderEntitlements
PATCH
অনুরোধের সাথে এনটাইটেলমেন্টগুলি সঞ্চয় করতে ব্যবহৃত বিন্যাসের অনুরূপ।
{
"name": "publications/dailybugle.com/readers/6789/entitlements",
"entitlements": [
{
"product_id": "dailybugle.com:basic",
"subscription_token": "dnabhdufbwinkjanvejskenfw",
"detail": "This is our basic plan",
"expire_time": "2022-08-19T04:53:40+00:00"
},
{
"product_id": "dailybugle.com:premium",
"subscription_token": "wfwhddgdgnkhngfw",
"detail": "This is our premium plan",
"expire_time": "2022-07-19T04:53:40+00:00"
},
{
"product_id": "dailybugle.com:deluxe",
"subscription_token": "fefcbwinkjanvejfefw",
"detail": "This is our deluxe plan",
"expire_time": "2022-08-20T04:53:40+00:00"
}
]
}
ব্যবহারকারীদের জন্য যাদের এনটাইটেলমেন্ট নেই, কিন্তু একটি লিঙ্কযুক্ত PPID আছে (উদাহরণস্বরূপ, একটি এনটাইটেলমেন্ট যার মেয়াদ শেষ হয়ে গেছে এবং পরিস্কার করা হয়েছে), একটি এনটাইটেলমেন্ট অনুরোধ স্ট্যান্ডার্ড এনটাইটেলমেন্ট অবজেক্টের অংশ হিসাবে একটি খালি এনটাইটেলমেন্ট অ্যারে ফিরিয়ে দেবে।
{
"name": "publications/dailybugle.com/readers/6789/entitlements"
}
আপডেট রিডার এনটাইটেলমেন্ট
UpdateReaderEntitlements
একটি পাঠকের জন্য তাদের PPID এর উপর ভিত্তি করে এনটাইটেলমেন্ট তৈরি এবং আপডেট করার জন্য ব্যবহার করা হয়।
এই নমুনা পেলোডটি PPID 6789
সহ পাঠককে The Daily Bugle-এর জন্য তিনটি পণ্য আইডিতে এনটাইটেলমেন্ট দেয়: dailybugle.com:basic
, dailybugle.com:premium
, এবং dailybugle.com:deluxe
৷ যখন রিডার 6789
পরবর্তীতে অনুসন্ধান এবং আবিষ্কারের জন্য Google সারফেস ব্যবহার করে, তখন "আপনার সদস্যতা থেকে" তালিকায় এই পণ্য আইডিগুলির যেকোনো একটির সাথে ট্যাগ করা dailybugle.com নিবন্ধগুলির যেকোনো প্রাসঙ্গিক ফলাফল দেখাবে৷
অনুরোধ
REST API: PATCH
অনুরোধ
https://readerrevenuesubscriptionlinking.googleapis.com/v1/publications/publicationId/readers/ppid/entitlements
অনুরোধের অংশ: entitlements
অবজেক্ট সম্পর্কে আরও তথ্যের জন্য, শব্দকোষ পৃষ্ঠাটি পড়ুন।
{
entitlements : [{
product_id: `${publicationId}:basic`,
subscription_token: 'abc1234',
detail: 'This is our basic plan',
expire_time: '2025-10-21T03:05:08.200564Z'
}]
}
ক্লায়েন্ট লাইব্রেরি (Node.js)
async function updateReaderEntitlements(ppid) {
const publicationId = process.env.PUBLICATION_ID;
const requestBody = {
entitlements : [{
product_id: `${publicationId}:basic`,
subscription_token: 'abc1234',
detail: 'This is our basic plan',
expire_time: '2025-10-21T03:05:08.200564Z'
}]
};
return await client.publications.readers.updateEntitlements({
name: `publications/${publicationId}/readers/${ppid}/entitlements`,
requestBody
});
};
প্রতিক্রিয়া
একটি সফল প্যাচ অপারেশনের পরে, সংরক্ষিত entitlements
অবজেক্টটি GetReaderEntitlements
মতো একই বিন্যাসে ফেরত দেওয়া হবে।
ডিলিট রিডার
DeleteReader
একজন প্রকাশককে ম্যানুয়ালি একটি লিঙ্ক করা সদস্যতা মুছে ফেলার অনুমতি দেয়। একটি DELETE
অনুরোধ ব্যবহার করে, প্রকাশক একটি প্রকাশনা আইডি মুছে ফেলার জন্য একটি PPID জমা দেন।
DeleteReader
কল করার আগে, আপনাকে অবশ্যই একটি খালি অ্যারে ( { "entitlements": [] }
) সহ UpdateReaderEntitlements
ব্যবহার করে প্রথমে এনটাইটেলমেন্টগুলি মুছে ফেলতে হবে, অথবা যদি আপনি এনটাইটেলমেন্ট আছে এমন একটি পাঠক মুছে ফেলতে চান তাহলে ঐচ্ছিক force
পরামিতিটিকে true
হিসাবে সেট করুন৷ force
পরামিতি ডিফল্ট করে false
।
অনুরোধ
REST API: অনুরোধ DELETE
https://readerrevenuesubscriptionlinking.googleapis.com/v1/publications/publicationId/readers/ppid?force={boolean}
ক্লায়েন্ট লাইব্রেরি (Node.js)
async function deleteReader(ppid, forceDelete = false) {
const publicationId = process.env.PUBLICATION_ID;
return await client.publications.readers.delete({
name: `publications/${publicationId}/readers/${ppid}`
force: forceDelete
});
};
প্রতিক্রিয়া
একটি সফল মুছে ফেলা একটি খালি JSON বস্তু {}
সহ একটি 200 প্রদান করে।
{}