Android ডিজাইন প্রস্তাবের জন্য বিডিং এবং নিলাম পরিষেবাগুলি বিশ্বস্ত বিডিং এবং নিলাম সার্ভার ব্যবহার করে Android এ চলমান নিলামগুলির সম্পাদন এবং ডেটা প্রবাহের বিবরণ দেয়৷ ট্রানজিটের ডেটা শুধুমাত্র গোপনীয়তা-সংরক্ষণকারী API এবং বিশ্বস্ত সার্ভার দ্বারা পরিচালিত হয় তা নিশ্চিত করতে, দ্বিমুখী হাইব্রিড পাবলিক কী এনক্রিপশন ব্যবহার করে ক্লায়েন্ট এবং সার্ভারের মধ্যে ডেটা এনক্রিপ্ট করা হয়।
আগে বিশদভাবে নিলাম চালানোর জন্য, ডিভাইসে বিক্রেতার বিজ্ঞাপন প্রযুক্তিকে অবশ্যই নিম্নলিখিত পদক্ষেপগুলি সম্পাদন করতে হবে:
- সার্ভার নিলামের জন্য ডেটা সংগ্রহ এবং এনক্রিপ্ট করুন
- একটি অবিশ্বস্ত বিক্রেতা পরিষেবা একটি অনুরোধ পাঠান
- একটি অবিশ্বস্ত বিক্রেতা পরিষেবা থেকে একটি প্রতিক্রিয়া পান
- সুরক্ষিত দর্শকের নিলাম প্রতিক্রিয়া ডিক্রিপ্ট করুন এবং নিলামের ফলাফল পান
চলমান সার্ভার নিলাম সমর্থন করার জন্য সুরক্ষিত শ্রোতা দুটি নতুন API প্রবর্তন করছে:
-
getAdSelectionDataAPI সার্ভার নিলামের জন্য ডেটা সংগ্রহ করে এবং নিলামের ডেটা ধারণকারী একটি এনক্রিপ্ট করা পেলোড তৈরি করে। বিডিং এবং নিলাম সার্ভার একটি নিলাম চালাতে, নিলামের ফলাফল তৈরি করতে এবং নিলামের ফলাফল ফেরত দিতে এই পেলোড ব্যবহার করে। - অন-ডিভাইস বিজ্ঞাপন প্রযুক্তি ক্লায়েন্টরা সার্ভার নিলামের মাধ্যমে তৈরি ফলাফল ডিক্রিপ্ট করতে এবং বিজয়ী বিজ্ঞাপন রেন্ডার URL পেতে
persistAdSelectionResultAPI-কে কল করতে পারে।
ডিভাইসে বিক্রেতার বিজ্ঞাপন প্রযুক্তিকে একটি নিলাম চালানোর জন্য নিম্নলিখিতগুলিকে একীভূত করতে হবে এবং তৈরি করতে হবে:
- সার্ভার নিলাম বিক্রেতার জন্য ডেটা সংগ্রহ এবং এনক্রিপ্ট করুন : এনক্রিপ্ট করা পেলোড পেতে বিজ্ঞাপন প্রযুক্তির
getAdSelectionDataAPI কল করা উচিত। - অবিশ্বস্ত বিক্রেতা পরিষেবার কাছে অনুরোধ পাঠান পাঠান : একটি
HTTP POSTবাPUTঅনুরোধ যাতেgetAdSelectionDataAPI দ্বারা তাদের অবিশ্বস্ত বিক্রেতা পরিষেবাতে তৈরি করা এনক্রিপ্ট করা পেলোড এবং প্রাসঙ্গিক ফলাফল তৈরি করতে অবিশ্বস্ত বিক্রেতা পরিষেবার প্রয়োজনীয় ডেটা রয়েছে৷ - অবিশ্বস্ত বিক্রেতা পরিষেবা থেকে প্রতিক্রিয়া পান : অবিশ্বস্ত বিক্রেতা পরিষেবা থেকে প্রতিক্রিয়া এনক্রিপ্ট করা সুরক্ষিত দর্শক নিলাম ফলাফল এবং প্রাসঙ্গিক নিলাম ফলাফল ধারণ করবে৷
- সুরক্ষিত শ্রোতা নিলাম প্রতিক্রিয়া ডিক্রিপ্ট করুন এবং নিলামের ফলাফল পান: সুরক্ষিত দর্শক নিলাম ফলাফল ডিক্রিপ্ট করতে, বিক্রেতা বিজ্ঞাপন প্রযুক্তিকে
persistAdSelectionResultAPI কল করা উচিত।persistAdSelectionResultদ্বারা উত্পন্ন ফলাফল প্রযোজ্য হলে প্রাসঙ্গিক বিজ্ঞাপন বা সুরক্ষিত দর্শক বিজ্ঞাপন নিলাম এবং বিজয়ী সুরক্ষিত দর্শক বিজ্ঞাপনের URI জিতেছে কিনা তা নির্ধারণ করতে বিজ্ঞাপন প্রযুক্তিকে সাহায্য করবে৷
সার্ভার নিলামের জন্য সমর্থিত বৈশিষ্ট্য
আমরা ডিভাইসের নিলামের জন্য উপলব্ধ সমস্ত বৈশিষ্ট্য সমর্থন করার লক্ষ্য রাখি। সার্ভার নিলামে এই বৈশিষ্ট্যগুলিকে সমর্থন করার সময়সীমা নিম্নরূপ:
অন-ডিভাইস নিলাম | সার্ভার নিলাম | |||
বিকাশকারী পূর্বরূপ | বেটা | বিকাশকারী পূর্বরূপ | বেটা | |
ইভেন্ট-স্তরের জয়ের প্রতিবেদন | Q1 '23 | Q3 '23 | N/A | Q4 '23 |
Q1 '23 | Q4 '23 | N/A | প্রশ্ন 1 24 | |
Q2 '23 | Q3 '23 | N/A | Q4 '23 | |
ফিল্টারিংয়ের জন্য বিজ্ঞাপন নির্বাচন কর্মপ্রবাহে প্রাসঙ্গিক বিজ্ঞাপনগুলি পাস করুন | Q2 '23 | Q1 '24 | N/A | N/A |
Q2 '23 | Q3 '23 | N/A | Q4 '23 | |
Q3 '23 | Q4 '23 | N/A | Q4 '23 | |
নন-সিপিএম বিলিং | Q3 '23 | Q4 '23 | ||
ডিবাগ | Q3 '23 | Q4 '23 | Q3 '23 | Q4 '23 |
ওপেন বিডিং মধ্যস্থতা | N/A | N/A | N/A | Q1 '24 |
Q2 '23 | Q1 '24 | N/A | Q1 '24 | |
মুদ্রা ব্যবস্থাপনা | N/A | N/A | N/A | Q1 '24 |
কে-অ্যানন ইন্টিগ্রেশন | N/A | Q1 '24 | N/A | Q1 '24 |
প্রাইভেট অ্যাগ্রিগেশন ইন্টিগ্রেশন | N/A | N/A | N/A | Q3 '24 |
সুরক্ষিত দর্শক API ব্যবহার করে সার্ভার নিলাম চালান
ডেভেলপার প্রিভিউ ট্র্যাকে, AdSelectionManager দুটি নতুন API প্রকাশ করে: getAdSelectionData এবং persistAdSelectionResult । এই APIগুলি বিজ্ঞাপন প্রযুক্তি SDK গুলিকে বিডিং এবং নিলাম সার্ভারগুলির সাথে একীভূত করার অনুমতি দেয়৷
একটি সার্ভার নিলামের জন্য ডেটা সংগ্রহ এবং এনক্রিপ্ট করুন
getAdSelectionData API বিডিং এবং নিলামের উপাদানগুলির জন্য প্রয়োজনীয় ইনপুট তৈরি করে যেমন BuyerInput এবং ProtectedAudienceInput , এবং ফলাফলটি কলারের কাছে উপলব্ধ করার আগে ডেটা এনক্রিপ্ট করে৷ অ্যাপ জুড়ে ডেটা ফাঁস প্রতিরোধ করতে, এই ডেটাতে ডিভাইসে উপস্থিত সমস্ত ক্রেতার তথ্য রয়েছে৷ গোপনীয়তা বিবেচনা বিভাগে এই সিদ্ধান্ত সম্পর্কে আরও পড়ুন এবং আকার বিবেচনা বিভাগে এটি অপ্টিমাইজ করার কৌশলগুলি।
API অ্যাক্সেস করতে, সুরক্ষিত শ্রোতা API-তে অ্যাক্সেস সক্ষম করতে হবে এবং ACCESS_ADSERVICES_CUSTOM_AUDIENCE অনুমতি অবশ্যই কলারের ম্যানিফেস্টে সংজ্ঞায়িত করতে হবে।
public class AdSelectionManager {
public void getAdSelectionData(
GetAdSelectionDataRequest getAdSelectionDataRequest,
Executor executor,
OutcomeReceiver<GetAdSelectionDataOutcome, Exception> receiver) {}
}
GetAdSelectionDataRequest
- কলকারীকে অবশ্যই অনুরোধে
sellerক্ষেত্রটি সেট করতে হবে কারণ এটি অনুরোধটি পরিবেশন করার আগে তালিকাভুক্তি চেক চালানোর জন্য ব্যবহৃত হয়। -
coordinatorOriginUriক্ষেত্রটি ঐচ্ছিক।- সেট করা থাকলে, এটি বিক্রেতার B&A সার্ভার স্থাপন করার সময় কনফিগার করা সমন্বয়কারী URL-এর স্কিম, হোস্টনাম এবং পোর্টের সমান হওয়া উচিত।
- সমন্বয়কারীকে অবশ্যই অনুমোদিত সমন্বয়কারীদের তালিকার অন্তর্ভুক্ত হতে হবে:
প্রদানকারী ইউআরআই URI অরিজিন ডিফল্ট গুগল ক্লাউড https://publickeyservice.pa.gcp.privacysandboxservices.com/.well-known/protected-auction/v1/public-keys https://publickeyservice.pa.gcp.privacysandboxservices.com হ্যাঁ আমাজন ওয়েব সার্ভিসেস https://publickeyservice.pa.aws.privacysandboxservices.com/.well-known/protected-auction/v1/public-keys https://publickeyservice.pa.aws.privacysandboxservices.com না - যদি কোন সমন্বয়কারীর উৎস প্রদান করা না হয়, ডিফল্ট সমন্বয়কারী ব্যবহার করা হয়।
- যদিও কোঅর্ডিনেটর ইউআরএলের পরিবর্তন হওয়ার সম্ভাবনা খুবই কম, তবে এই ইউআরএলটি গতিশীলভাবে পরিচালনা করার জন্য একটি পদ্ধতি প্রয়োগ করার জন্য দৃঢ়ভাবে সুপারিশ করা হয়। এটি নিশ্চিত করে যে ইউআরএলে ভবিষ্যতের যেকোনো পরিবর্তন একটি নতুন SDK প্রকাশের প্রয়োজন ছাড়াই সামঞ্জস্য করা যেতে পারে।
public class GetAdSelectionDataRequest {
public setSeller(AdTechIdentifier seller);
public setCoordinatorOriginUri(Uri coordinatorOriginUri)
}
অনুরোধটি বৈধ হওয়ার পর, ডিভাইসের ক্রেতার ডেটা BuyerInput এবং ProtectedAudienceInput এ তৈরি করা হয়। চূড়ান্ত পেলোড অবজেক্ট তারপর দ্বিমুখী হাইব্রিড পাবলিক কী এনক্রিপশন ব্যবহার করে এনক্রিপ্ট করা হয়।
GetAdSelectionDataOutcome
GetAdSelectionDataOutcome getAdSelectionData API এর ফলাফল হিসাবে তৈরি হয়। এতে নিম্নলিখিতগুলি রয়েছে:
-
adSelectionId:getAdSelectionDataএর এই আহ্বান সনাক্ত করতে একটি অস্বচ্ছ পূর্ণসংখ্যা। বিজ্ঞাপন প্রযুক্তি ক্লায়েন্টের এইadSelectionIdমান বজায় রাখা উচিত কারণ এটিgetAdSelectionDataকলের পয়েন্টার হিসাবে কাজ করে। বিডিং এবং নিলাম সার্ভার থেকে নিলামের ফলাফল ডিক্রিপ্ট করতেpersistAdSelectionResultAPI-এর দ্বারা এই শনাক্তকারীর প্রয়োজন হয় এবংreportImpressionএবংreportEventAPI-এর জন্যও এটি প্রয়োজনীয়। -
adSelectionData: এটি হল এনক্রিপ্ট করা নিলাম ডেটা যা নিলাম চালানোর জন্য বিডিং এবং নিলাম সার্ভারের প্রয়োজন হবে। এই পদ্ধতিতে রয়েছে:- ফ্রিকোয়েন্সি ক্যাপিং, অ্যাপ ইনস্টল ফিল্টার এবং কাস্টম অডিয়েন্সের জন্য সার্ভার নিলামের প্রয়োজনীয়তার উপর ভিত্তি করে ফিল্টার করা কাস্টম অডিয়েন্স ডেটা।
- ভবিষ্যতের সংস্করণে, এতে অ্যাপ ইনস্টল ডেটা থাকবে।
public class GetAdSelectionDataOutcome {
Public getAdSelectionId(long adSelectionId);
public byte[] getAdSelectionData();
}
ত্রুটি, ব্যতিক্রম এবং ব্যর্থতা পরিচালনা
যদি অবৈধ আর্গুমেন্ট, টাইমআউট বা অত্যধিক রিসোর্স খরচের কারণে বিজ্ঞাপন নির্বাচন ডেটা জেনারেশন সফলভাবে সম্পন্ন না করা যায়, তাহলে OutcomeReceiver.onError() কলব্যাক নিম্নলিখিত আচরণগুলির সাথে একটি AdServicesException প্রদান করে:
- যদি
getAdSelectionDataঅবৈধ আর্গুমেন্ট দিয়ে শুরু করা হয়, তাহলেAdServicesException` কারণ হিসেবে একটি IllegalArgumentException নির্দেশ করে। - অন্যান্য সমস্ত ত্রুটি কারণ হিসাবে একটি
IllegalStateExceptionসহ একটিAdServicesExceptionপায়।
একটি অবিশ্বস্ত বিক্রেতা সেবা একটি অনুরোধ পাঠান
AdSelectionData ব্যবহার করে, ডিভাইসে থাকা SDK একটি POST বা PUT অনুরোধে ডেটা অন্তর্ভুক্ত করে তাদের বিক্রেতার বিজ্ঞাপন পরিষেবায় একটি অনুরোধ পাঠাতে পারে:
fetch('https://www.example-ssp.com/auction', {
method: "PUT",
body: data,
...
})
ডিভাইসে থাকা SDK এই ডেটা এনকোড করার জন্য দায়ী৷ মাল্টিপার্ট/ফর্ম-ডেটা হিসাবে বিক্রেতার বিজ্ঞাপন পরিষেবাতে অনুরোধ পাঠানোর মতো একটি স্থান দক্ষ সমাধান ব্যবহার করার পরামর্শ দেওয়া হয়।
অবিশ্বস্ত বিক্রেতার পরিষেবা থেকে একটি প্রতিক্রিয়া পান৷
বিডিং এবং নিলাম সার্ভার ব্যাখ্যাকারীতে বিশদভাবে বলা হয়েছে, যখন অবিশ্বস্ত বিক্রেতা পরিষেবা অনুরোধটি গ্রহণ করে, তখন এটি প্রাসঙ্গিক বিজ্ঞাপনের জন্য অংশীদার ক্রেতাদের কল করে।
অবিশ্বস্ত বিক্রেতা পরিষেবা এনক্রিপ্ট করা adSelectionData এবং AuctionConfig একটি TEE তে চলমান বিডিং এবং নিলাম সার্ভারের সেলারফ্রন্টএন্ড পরিষেবাতে ফরোয়ার্ড করে৷
সুরক্ষিত শ্রোতা নিলাম সম্পূর্ণ হলে, SellerFrontEnd পরিষেবা নিলামের ফলাফল এনক্রিপ্ট করে এবং অবিশ্বস্ত বিক্রেতা পরিষেবার প্রতিক্রিয়া হিসাবে এটি ফেরত দেয়।
অবিশ্বস্ত বিক্রেতা পরিষেবা প্রাসঙ্গিক বিজ্ঞাপন এবং/অথবা এনক্রিপ্ট করা সুরক্ষিত দর্শক নিলামের ফলাফল ধারণকারী ডিভাইসে একটি প্রতিক্রিয়া পাঠায়।
প্রতিক্রিয়া পাওয়ার পরে, ডিভাইসে বিক্রেতার বিজ্ঞাপন প্রযুক্তি কোড শুধুমাত্র প্রতিক্রিয়াতে প্রাসঙ্গিক বিজ্ঞাপন ব্যবহার করা বেছে নিতে পারে বা যদি মনে করে যে সুরক্ষিত দর্শক ফলাফল পাওয়ার ক্ষেত্রে ক্রমবর্ধমান মূল্য রয়েছে, তাহলে এটি PersistAdSelectionResult API এ কল করে সুরক্ষিত দর্শক ফলাফল ডিক্রিপ্ট করতে বেছে নিতে পারে।
PersistAdSelectionResult API
সুরক্ষিত দর্শক ফলাফল ডিক্রিপ্ট করতে, বিক্রেতা বিজ্ঞাপন প্রযুক্তি দ্বিতীয় সুরক্ষিত দর্শক API persistAdSelectionResult কল করতে পারে। API ফলাফলটিকে ডিক্রিপ্ট করে এবং একটি AdSelectionOutcome প্রদান করে, একই বস্তু যা আজ একটি অন-ডিভাইস নিলাম থেকে ফেরত দেওয়া হয়।
API অ্যাক্সেস করতে, কলারকে অবশ্যই সুরক্ষিত দর্শক API-এ অ্যাক্সেস সক্ষম করতে হবে এবং তাদের ম্যানিফেস্টে ACCESS_ADSERVICES_CUSTOM_AUDIENCE অনুমতিটি সংজ্ঞায়িত করতে হবে ৷
public void persistAdSelectionResult(
PersistAdSelectionResultRequest persistAdSelectionResultRequest,
Executor executor,
OutcomeReceiver<AdSelectionOutcome, Exception> receiver) {}
অবিরত বিজ্ঞাপন নির্বাচন ফলাফল অনুরোধ
কলকারীকে অনুরোধে নিম্নলিখিতগুলি সেট করতে হবে:
public final class PersistAdSelectionResultRequest {
Public setAdSelectionId(long adSelectionId);
public setSeller(AdTechIdentifier seller);
public setAdSelectionResult(byte[] adSelectionResult);
}
-
adSelectionId:getAdSelectionDataকল দ্বারা উত্পন্ন অস্বচ্ছ শনাক্তকারী যার ফলাফল কলকারী ডিক্রিপ্ট করতে চায়৷ -
seller: বিক্রেতার বিজ্ঞাপন প্রযুক্তি শনাক্তকারীকে অনুরোধটি পরিবেশন করার আগে তালিকাভুক্তি চেক চালানোর অনুরোধে সেট করতে হবে। -
adSelectionResult: বিডিং এবং নিলাম সার্ভার দ্বারা উত্পন্ন এনক্রিপ্ট করা নিলাম ফলাফল যা কলকারী ডিক্রিপ্ট করতে চায়৷
AdSelectionOutcome প্রতিক্রিয়া
যদি একজন সুরক্ষিত দর্শক বিজয়ী হয়, তাহলে AdSelectionOutcome বিজয়ী বিজ্ঞাপন রেন্ডার URI ফেরত দেয়। একবার adSelectionResult ডিক্রিপ্ট হয়ে গেলে, রিপোর্টিং ডেটা অভ্যন্তরীণভাবে বজায় থাকে। OutcomeReceiver.onResult() কলব্যাক একটি AdSelectionOutcome প্রদান করে যাতে রয়েছে:
-
URI: যদি একটি বিজয়ী সুরক্ষিত দর্শক বিজ্ঞাপন থাকে, তাহলে বিজয়ী বিজ্ঞাপনের জন্য একটি বিজ্ঞাপন রেন্ডার URL ফেরত দেওয়া হয়। যদি কোন সুরক্ষিত দর্শক বিজয়ী না হয়, তাহলে `Uri.EMPTY ফেরত দেওয়া হবে। -
adSelectionId: এই সার্ভার নিলামের সাথে যুক্তadSelectionId।
ত্রুটি, ব্যতিক্রম এবং ব্যর্থতা পরিচালনা
যদি অবৈধ আর্গুমেন্ট, টাইমআউট বা অত্যধিক রিসোর্স খরচের কারণে বিজ্ঞাপন নির্বাচন ডেটা জেনারেশন সফলভাবে সম্পন্ন না করা যায়, তাহলে OutcomeReceiver.onError() কলব্যাক নিম্নলিখিত আচরণগুলির সাথে একটি AdServicesException প্রদান করে:
- যদি
getAdSelectionDataঅবৈধ আর্গুমেন্ট দিয়ে শুরু করা হয়, তাহলেAdServicesExceptionকারণ হিসেবে একটিIllegalArgumentExceptionনির্দেশ করে। - অন্যান্য সমস্ত ত্রুটি কারণ হিসাবে একটি
IllegalStateExceptionসহ একটিAdServicesExceptionপায়।
গোপনীয়তা বিবেচনা
ট্রানজিটের ডেটা শুধুমাত্র PPAPI এবং বিশ্বস্ত সার্ভারগুলিতে অ্যাক্সেসযোগ্য তা নিশ্চিত করার জন্য adSelectionData এনক্রিপ্ট করা হয়েছে।
এনক্রিপশন সত্ত্বেও, adSelectionData আকারের কারণে ডেটা ফাঁস হতে পারে। adSelectionData আকার এর কারণে পরিবর্তিত হতে পারে:
- ডিভাইসে উপস্থিত
CustomAudienceডেটাতে পরিবর্তন। -
CustomAudienceফিল্টারিং যুক্তিতে পরিবর্তন -
getAdSelectionDataকলে ইনপুটে পরিবর্তন।
1-বিট লিক আলোচনায় উল্লিখিত হিসাবে একটি ক্রস-অ্যাপ শনাক্তকারী তৈরি করতে adSelectionData ডেটা আকারে পরিবর্তন ব্যবহার করা যেতে পারে। 1-বিট ফাঁসের জন্য প্রযোজ্য অনেক প্রশমন এখানেও প্রযোজ্য।
এই ফাঁসগুলি পরিচালনা করার জন্য, আমরা getAdSelectionData API এ সমস্ত কলের জন্য একই adSelectionData তৈরি করার পরিকল্পনা করছি৷ প্রাথমিক রিলিজে, ডিভাইসের সমস্ত CustomAudiences adSelectionData তৈরি করার জন্য ব্যবহার করা হয় এবং এনক্রিপ্ট করা পেলোড মাস্ক আকারের বৈচিত্রের জন্য প্যাড করা হবে। আমরা জেনারেট করা adSelectionData এ GetAdSelectionData ইনপুট প্যারামিটারের প্রভাবও সীমাবদ্ধ করব।
যাইহোক, সমস্ত অন-ডিভাইস নিলাম ডেটা ব্যবহার করে সমস্ত বিজ্ঞাপন প্রযুক্তির জন্য একই adSelectionData তৈরি করা একটি বড় পেলোড তৈরি করে যা এখন প্রতিটি কলে বিজ্ঞাপন প্রযুক্তি সার্ভারে স্থানান্তর করতে হবে। নিলাম পেলোড তৈরি করতে সমস্ত অন-ডিভাইস কাস্টম শ্রোতাদের ব্যবহার করে ক্ষতিকারক সত্তা থেকে অপব্যবহারের জন্য ইকোসিস্টেমও খুলে যায়। আমরা আকার অপ্টিমাইজেশান এবং অপব্যবহার প্রশমন বিভাগে এই উদ্বেগগুলি কভার করেছি৷
আকার অপ্টিমাইজেশান
বিজ্ঞাপন প্রযুক্তির ক্লায়েন্ট SDK বিজ্ঞাপন প্রযুক্তি সার্ভারে করা HTTP PUT/POST প্রাসঙ্গিক কলে adSelectionData এর এনক্রিপ্ট করা বাইট প্যাকেজ করবে বলে আশা করা হচ্ছে। কম রাউন্ড-ট্রিপ টাইম লেটেন্সি এবং খরচের জন্য, ইউটিলিটি প্রভাবিত না করে যতটা সম্ভব adSelectionData সাইজ কমাতে হবে।
আমরা adSelectionData ডেটার আকার কমাতে আসন্ন রিলিজে নিম্নলিখিত অপ্টিমাইজেশনগুলি অন্বেষণ এবং সম্ভাব্যভাবে চালু করার পরিকল্পনা করছি:
প্যাডিং সহ বালতি আকারের একটি নির্দিষ্ট সেটে তৈরি করা পেলোড : নিম্ন পেলোডের জন্য অনুমতি দেওয়ার সময় আকারের তারতম্য থেকে ফুটো কমাতে, আমরা জেনারেট করা পেলোডের জন্য নির্দিষ্ট আকারের বালতি ব্যবহার করার পরামর্শ দিই। বাকেটের সংখ্যা ছোট রাখলে, উদাহরণস্বরূপ, 7
getAdSelectionDataএ প্রতি কলে 3 বিটের কম এনট্রপি ফাঁস হবে।যদি ডিভাইসে থাকা ডেটা সর্বাধিক বালতির আকারকে অতিক্রম করে, তাহলে কোন ডেটা বাদ দেওয়া হবে তা নির্ধারণ করতে অগ্রাধিকার মানগুলির মতো কৌশলগুলি ব্যবহার করা হবে৷
ক্রেতা কনফিগারেশন : আমরা ক্রেতাদের প্রতি-ক্রেতা পেলোড কনফিগারেশন সেট আপ করতে দেওয়ার সম্ভাব্যতা মূল্যায়ন করছি। কোন ক্রেতা কোন নিলামে যোগ দিতে আগ্রহী তা সনাক্ত করার জন্য এই কনফিগারেশনটি কার্যকর হবে। যদি সম্ভব হয়, তালিকাভুক্তির সময়, একজন ক্রেতা বিজ্ঞাপন প্রযুক্তি একটি শেষ পয়েন্ট নিবন্ধন করতে পারে যেখান থেকে সুরক্ষিত দর্শক একটি দৈনিক নিয়মিত ক্যাডেন্সে পেলোড কনফিগারেশন আনবে। বিকল্পভাবে, গোপনীয়তা-সংরক্ষণকারী APIগুলি একটি API প্রকাশ করবে যাতে ক্রেতা বিজ্ঞাপন প্রযুক্তিগুলিকে এই এন্ডপয়েন্ট নিবন্ধন করার অনুমতি দেয়৷
এই কনফিগারেশনটি প্রতিটি
getAdSelectionDataঅনুরোধের জন্য তৈরি করাadSelectionDataএ ক্রেতার অবদান মূল্যায়ন করতে ব্যবহার করা হবে।ক্রেতা পেলোড কনফিগারেশন ক্রেতাদের নির্দিষ্ট করার অনুমতি দেবে:
- মঞ্জুরিপ্রাপ্ত বিক্রেতাদের তালিকা : ক্রেতার কাস্টম অডিয়েন্স পেলোডে যোগ করা হবে শুধুমাত্র যদি
getAdSelectionDataকলটি অনুমোদিত তালিকার একজন বিক্রেতার দ্বারা শুরু হয়। অনুমোদিত তালিকা আপ টু ডেট রাখতে আমরা প্রতিদিনের ক্যাডেন্সে পেলোড কনফিগারেশন আনব। - প্রতি-বিক্রেতার আকারের সীমা : একজন নির্দিষ্ট বিক্রেতার দ্বারা নিলাম শুরু হলে পেলোডে পাঠানো ডেটা আকার নির্ধারণ করতে ক্রেতা প্রতি-বিক্রেতার আকারের সীমা নির্দিষ্ট করতে পারে। এটি উপযোগী হবে যদি একজন ক্রেতা নির্দিষ্ট বিক্রেতাদের কাছ থেকে নিলাম ডেটা প্রক্রিয়াকরণের জন্য আরও সংস্থান উৎসর্গ করতে চান। SellerFrontendService প্রতিটি BuyerFrontendService-এ শুধুমাত্র ক্রেতা-নির্দিষ্ট ডেটা ফরোয়ার্ড করে। সুতরাং, প্রতি-বিক্রেতার আকারের সীমা সংজ্ঞায়িত করে, একজন ক্রেতা স্পষ্টভাবে একজন বিক্রেতার দ্বারা পরিচালিত নিলামের জন্য তাদের বিডিং এবং নিলাম সার্ভারের BuyerFrontendService দ্বারা প্রবেশ করা এবং প্রক্রিয়াকৃত ডেটার পরিমাণ নিয়ন্ত্রণ করতে পারে।
- মঞ্জুরিপ্রাপ্ত বিক্রেতাদের তালিকা : ক্রেতার কাস্টম অডিয়েন্স পেলোডে যোগ করা হবে শুধুমাত্র যদি
বিক্রেতা কনফিগারেশন : আমরা প্রতি-বিক্রেতা নিলাম কনফিগারেশনের সম্ভাব্যতা মূল্যায়ন করছি যা বিক্রেতাদের পেলোডের আকার এবং নিলাম অংশগ্রহণকারীদের নিয়ন্ত্রণ করতে নিলামের পরামিতিগুলি সংজ্ঞায়িত করার অনুমতি দেবে। যদি সম্ভব হয়, তালিকাভুক্তির সময়, বিক্রেতা বিজ্ঞাপন প্রযুক্তি শেষ পয়েন্টটি নির্দিষ্ট করতে সক্ষম হবে যেখান থেকে সুরক্ষিত দর্শক একটি নিয়মিত ক্যাডেন্সে প্রতি-বিক্রেতার নিলাম কনফিগারেশন আনতে পারে। এই কনফিগারেশনটি তারপর প্রতিটি
getAdSelectionDataঅনুরোধের জন্য তৈরি করাadSelectionDataএর রচনা এবং সীমা নির্ধারণ করতে ব্যবহার করা হবে।ক্রেতা কনফিগারেশনের অনুরূপ, একটি প্রতি-বিক্রেতা কনফিগারেশন বিক্রেতাদের একটি নিলামে ক্রেতাদের কোন সেট দেখতে পাবে তা নির্দিষ্ট করতে এবং পেলোড আকারে প্রতি ক্রেতা অবদানের সীমা নির্দিষ্ট করার অনুমতি দেবে।
বিক্রেতা নিলাম কনফিগারেশন বিক্রেতাদের নির্দিষ্ট করার অনুমতি দেবে:
- অনুমোদিত ক্রেতা তালিকা : প্রদত্ত বিক্রেতার দ্বারা শুরু করা নিলামের জন্য, শুধুমাত্র অনুমোদিত তালিকার ক্রেতারাই নিলামের জন্য কাস্টম দর্শকদের অবদান রাখতে সক্ষম হবে। নিলামের কনফিগারেশন প্রতিদিন আপডেট করতে হবে যাতে সার্ভার-সাইড ক্রেতা অনুমোদন তালিকার সাথে মঞ্জুরি তালিকা আপ টু ডেট থাকে।
- প্রতি-ক্রেতার আকারের সীমা : বিক্রেতারা SellerFrontendService-এ পাঠানো পেলোডে প্রতিটি ক্রেতার দ্বারা আপলোড করা ডেটা আকার নিয়ন্ত্রণ করতে প্রতি-ক্রেতার সীমা নির্দিষ্ট করতে পারে। ক্রেতা প্রতি-ক্রেতার আকারের সীমা অতিক্রম করলে, ক্রেতা পেলোড কনফিগারেশনে সেট করা কাস্টম অডিয়েন্স অগ্রাধিকারটি প্রত্যাশিত সীমাতে ডেটা পেতে ব্যবহার করা হবে।
- প্রতি-ক্রেতা অগ্রাধিকার : বিক্রেতাদের প্রতি-ক্রেতার অগ্রাধিকার সেট করার অনুমতি দিন। পেলোডের আকার পেলোড আকারের সীমা ছাড়িয়ে গেলে কোন ক্রেতার ডেটা পেলোডে রাখা উচিত তা শনাক্ত করতে ক্রেতার অগ্রাধিকার ব্যবহার করা হবে।
- পেলোডের জন্য সর্বোচ্চ আকারের সীমা : বিভিন্ন বিক্রেতার বিভিন্ন সংস্থান বরাদ্দ থাকতে পারে এবং প্রতি-অনুরোধের নিলাম পেলোডের জন্য সর্বোচ্চ আকারের সীমা সেট করতে চাইতে পারে। সর্বাধিক আকারের সীমা সুরক্ষিত শ্রোতা API দ্বারা সেট করা নির্দিষ্ট আকারের বালতিকে সম্মান করবে।
কাস্টম শ্রোতা পরিবর্তন
- কাস্টম অডিয়েন্সের অগ্রাধিকার নির্দিষ্ট করুন : ক্রেতাদের একটি কাস্টম অডিয়েন্সে একটি অগ্রাধিকার মান নির্দিষ্ট করার অনুমতি দিন।
priorityক্ষেত্রটি কাস্টম শ্রোতাদের সনাক্ত করতে ব্যবহার করা হবে যা একটি নিলামে অন্তর্ভুক্ত করা উচিত যদি ক্রেতা কাস্টম দর্শকদের সেট প্রতি-বিক্রেতা বা প্রতি-ক্রেতার আকারের সীমা অতিক্রম করে। একটি কাস্টম অডিয়েন্সে একটি অনির্দিষ্ট অগ্রাধিকার মান ডিফল্ট হবে0.0।
- কাস্টম অডিয়েন্সের অগ্রাধিকার নির্দিষ্ট করুন : ক্রেতাদের একটি কাস্টম অডিয়েন্সে একটি অগ্রাধিকার মান নির্দিষ্ট করার অনুমতি দিন।
পেলোড ডেটা পরিবর্তন
- পেলোডে পাঠানো ডেটা হ্রাস করুন : বিডিং এবং নিলাম পরিষেবা পেলোড অপ্টিমাইজেশানে বিশদ হিসাবে, উচ্চতর পেলোড কাস্টম দর্শক
adsডেটা, ব্যবহারকারীর বিডিং সংকেত, অ্যান্ড্রয়েড সংকেত দ্বারা চালিত হয়৷ উচ্চতর পেলোডগুলি এর দ্বারা কমানো যেতে পারে:- পেলোডে ক্লায়েন্টকে অ্যাড রেন্ডার আইডি পাঠাতে (বিজ্ঞাপন বস্তুর পরিবর্তে)।
- ক্লায়েন্টকে পেলোডে কোনো বিজ্ঞাপনের ডেটা পাঠাতে হবে না।
- ক্লায়েন্ট পেলোডে ব্যবহারকারীর বিডিং সংকেত পাঠানো হচ্ছে না।
- পেলোডে পাঠানো ডেটা হ্রাস করুন : বিডিং এবং নিলাম পরিষেবা পেলোড অপ্টিমাইজেশানে বিশদ হিসাবে, উচ্চতর পেলোড কাস্টম দর্শক
যদিও এই কৌশলগুলি বিজ্ঞাপন প্রযুক্তিগুলিকে adSelectionData ডেটা পেলোড রচনা এবং সীমাগুলি পরিচালনা করার জন্য কনফিগারেশনগুলিকে সংজ্ঞায়িত করার অনুমতি দেয়, তারা কনফিগারেশন প্যারামিটারগুলি পরিবর্তন করে adSelectionData আকার পরিবর্তন করার জন্য একটি ফ্যাক্টরও হতে পারে৷ এটি এড়াতে, কনফিগারেশনটি কনফিগার করা শেষ পয়েন্ট থেকে সুরক্ষিত দর্শকদের দ্বারা প্রতিদিন আনা হবে।
লেটেন্সি অপ্টিমাইজেশান
সার্ভারের নিলামে একটি আকাঙ্খিত ইউটিলিটি স্তরের জন্য, আমাদের নিশ্চিত হতে হবে যে getAdSelectionData API এবং persistAdSelectionResult API-এর প্রতি কলে কম লেটেন্সি আছে। যদিও আমরা 2023 সালে API-এর জন্য বৈশিষ্ট্য সমর্থন প্রদানের লক্ষ্য রাখি, আমাদের পরবর্তী রিলিজটি API-গুলির জন্য লেটেন্সি বেঞ্চমার্ক এবং অপ্টিমাইজেশনের উপর ফোকাস করবে।
গ্রহণযোগ্য সীমার মধ্যে বিলম্ব বজায় রাখার জন্য আমরা নিম্নলিখিত কৌশলগুলি অন্বেষণ করছি:
বিক্রেতা প্রতি সুরক্ষিত শ্রোতাদের ডেটার প্রাক-প্রজন্ম : যেহেতু বিক্রেতার নিলাম কনফিগারেশন এবং ক্রেতার পেলোড কনফিগারেশন যথেষ্ট সময়কালের জন্য স্থিতিশীল থাকবে (প্রতিদিন), প্ল্যাটফর্মটি প্রাক-গণনা করতে পারে এবং যোগ্য সুরক্ষিত দর্শক ডেটা সংরক্ষণ করতে পারে।
এর জন্য প্ল্যাটফর্মটিকে কাস্টম শ্রোতা আপডেটগুলি নিরীক্ষণ করার জন্য একটি প্রক্রিয়া তৈরি করতে এবং আপডেটগুলির উপর ভিত্তি করে পূর্ব-উত্পাদিত সুরক্ষিত শ্রোতা ডেটা সংশোধন করতে হবে। প্ল্যাটফর্মটিকে রেস বিলম্বের বিজ্ঞাপন প্রযুক্তিতেও SLO ঘোষণা করতে হবে কাস্টম শ্রোতা আপডেট এবং সার্ভার নিলামের জন্য তৈরি
adSelectionDataপরিবর্তন দেখার মধ্যে আশা করতে পারে৷যেহেতু একটি ডিভাইস বিভিন্ন প্রক্রিয়ার অগ্রাধিকার সহ একটি সীমিত সম্পদ গণনা মডেল সরবরাহ করে, তাই আমরা স্বীকার করি যে এই প্রাক-প্রজন্ম সুবিধা প্রদানের ক্ষেত্রে অবশ্যই উচ্চ নির্ভরযোগ্যতা এবং SLO-এর নিশ্চয়তা থাকতে হবে।
প্রোটেক্টেড অডিয়েন্স ডেটা প্রাক-জেনারেট করা তারপরের উপর ভিত্তি করে করা হবে
- বিক্রেতা সুরক্ষিত শ্রোতা ডেটা প্রাক-জেনারেট করতে অপ্ট-ইন করুন৷
- একটি নির্দিষ্ট বিক্রেতার দ্বারা শুরু করা একটি নিলামে অংশগ্রহণের যোগ্য ক্রেতারা৷
- ক্রেতা প্রতি কাস্টম শ্রোতা সনাক্ত করা যা এর উপর ভিত্তি করে পেলোডের অংশ হবে:
- প্রতি-ক্রেতার আকারের সীমা, প্রতি-ক্রেতার অগ্রাধিকার এবং সর্বাধিক আকারের সীমা বিক্রেতার কনফিগারেশনে সংজ্ঞায়িত করা হয়েছে,
- প্রতি-বিক্রেতার আকার সীমা, ক্রেতা কনফিগারেশনে সংজ্ঞায়িত কাস্টম দর্শক অগ্রাধিকার।
নেতিবাচক ফিল্টারিংয়ের আগ্রহী প্রয়োগ : যদি একজন বিক্রেতা পছন্দ করেন, তাহলে প্ল্যাটফর্মটি প্রটেক্টেড অডিয়েন্স ডেটা প্রাক-জেনারেট করে এবং গুরুত্বপূর্ণ
getAdSelectionDataকল বন্ধ করে নেতিবাচক ফিল্টারিং প্রয়োগ করে বিজ্ঞাপনadSelectionDataপ্রাক-গণনা করতে পারে। এটি বিক্রেতাদের নেতিবাচক ফিল্টারিং-এ স্থবিরতা গ্রহণ করার সময় কম লেটেন্সি ভারসাম্য করতে অনুমতি দেবে।প্ল্যাটফর্মটি বিক্রেতা কনফিগারেশনে একটি স্থিরতা সীমা সহ একটি ডিফল্ট বিকল্প এবং
getAdSelectionDataএ একটি ওভাররাইড বিকল্প প্রদান করে এই সমর্থনটি প্রদান করতে পারে যাতে প্রয়োজনে নতুনতম গণনার অনুমতি দেওয়া যায়। বিকল্পভাবে, প্ল্যাটফর্মটি নিলামকে উষ্ণ করার জন্যgetAdSelectionDataএর আগে কল করার জন্য একটি অতিরিক্ত ইনিশিয়ালাইজেশন API প্রদান করতে পারে।একাধিক নিলামের জন্য পেলোড গণনা : নির্দিষ্ট পরিস্থিতিতে, ডেটা অচলতার বর্ধিত খরচে একটি লেটেন্সি-পারফরম্যান্ট API থাকা পছন্দনীয় হতে পারে। এটি প্রদান করার জন্য, প্ল্যাটফর্মটি সম্পূর্ণ পেলোড গণনা করার জন্য একটি প্রাথমিক এপিআই প্রবর্তন করতে পারে এবং কলকারীকে গণনা করা পেলোডের একটি রেফারেন্স প্রদান করতে পারে।
getAdSelectionDataএর পরবর্তী কলগুলির জন্য, কলারadSelectionDataজেনারেশনের জন্য ব্যবহার করা প্রাক-গণনা করা পেলোডের রেফারেন্স প্রদান করতে পারে।
এই তিনটি কৌশল প্রাথমিক অন্বেষণ পর্যায়ে রয়েছে এবং প্ল্যাটফর্মটি লেটেন্সির জন্য অপ্টিমাইজ করার জন্য যে দিকটি গ্রহণ করতে পারে তা বর্ণনা করার জন্য। যেহেতু আমরা API এবং বিজ্ঞাপন প্রযুক্তির প্রয়োজনীয়তাগুলির আরও বিস্তারিত লেটেন্সি প্রোফাইলগুলি অন্বেষণ করি, আমরা অতিরিক্ত কৌশলগুলি প্রস্তাব করা চালিয়ে যাব৷
অপব্যবহার প্রশমন এবং সনাক্তকরণ
গোপনীয়তা বিবেচনায় উল্লিখিত হিসাবে, ডিভাইসে সমস্ত ক্রেতার ডেটা ব্যবহার করে adSelectionData তৈরি করা হয়।
যাইহোক, যদি ডিভাইসে সমস্ত ক্রেতার ডেটা ব্যবহার করা হয় adSelectionData আউটপুট জেনারেট করতে, তাহলে একটি দূষিত সত্তা একজন ক্রেতা হিসাবে জাহির করতে পারে এবং Android কার্যক্ষমতা হ্রাস করতে প্রতারণামূলক ক্রেতা ডেটা তৈরি করতে পারে, নিলাম চালানো বা বিডিং চালানোর জন্য একটি বিজ্ঞাপন প্রযুক্তির খরচ বাড়াতে ব্লোট পেলোড করতে পারে এবং আরও অনেক কিছু।
প্রশমন
আকার বিবেচনার বিভাগে উল্লিখিত কিছু ব্যবস্থা যেমন অনুমোদিত বিক্রেতা সমন্বিত ক্রেতা পেলোড কনফিগারেশন এবং অনুমোদিত ক্রেতা সমন্বিত বিক্রেতার নিলাম কনফিগারেশন পেলোডে অপ্রত্যাশিত ডেটা বাদ দিতে সাহায্য করবে।
অন্যান্য আকার বিবেচনার ব্যবস্থা যেমন SSP-কে ক্রেতার অগ্রাধিকার নির্দিষ্ট করার অনুমতি দেওয়া, জেনারেট করা পেলোডে প্রতি-ক্রেতা কোটা স্থাপন করা এবং প্রতি নিলাম পেলোডের জন্য সর্বোচ্চ আকার নির্ধারণ করাও ক্ষতিকারক পেলোড ব্লটিং এর প্রভাব কমাতে সাহায্য করতে পারে। এই ব্যবস্থাগুলির উদ্দেশ্য হল বিজ্ঞাপন প্রযুক্তিগুলিকে তারা কোন বিজ্ঞাপন প্রযুক্তির সাথে সহযোগিতা করবে তা নির্ধারণ করতে এবং তাদের প্রক্রিয়া করার জন্য পেলোডের গ্রহণযোগ্য সীমা সেট করার জন্য।
পূর্বে উল্লিখিত হিসাবে, অপব্যবহার বিরোধী এবং আকারের সীমাবদ্ধতার জন্য প্রবর্তিত সমস্ত প্রশমন অবশ্যই গোপনীয়তার বিবেচনার সাথে মেনে চলতে হবে।
দূষিত সত্তা সনাক্তকরণ
যদিও এই প্রশমনগুলি সার্ভার নিলামের জন্য adSelectionData জেনারেশনকে রক্ষা করে, তারা ক্ষতিকারক সত্তা সনাক্ত করতে বা প্ল্যাটফর্মটিকে অপব্যবহার থেকে রক্ষা করতে সাহায্য করে না যেমন একজন ক্রেতার কাছ থেকে অভূতপূর্ব সংখ্যক কাস্টম দর্শক তৈরি করা।
প্ল্যাটফর্মের স্থিতিশীলতা এবং স্বাস্থ্য যাচাই করার জন্য, আমাদের দূষিত সত্তা চিহ্নিত করার জন্য, অপব্যবহারের ভেক্টর সনাক্ত করতে এবং নির্দিষ্ট আক্রমণের জন্য প্রেরণা সনাক্ত করার জন্য একটি পদ্ধতি খুঁজে বের করতে হবে। পরবর্তী রিলিজে, আমরা সম্ভাব্য অপব্যবহারের ভেক্টর এবং তাদের মোকাবেলা করার জন্য জায়গায় সুরক্ষার বিস্তারিত ব্যাখ্যাকারীদের পরিচয় করিয়ে দেব।