Private एग्रीगेशन एपीआई की खास जानकारी

Protected Audience से मिले डेटा और शेयर किए गए स्टोरेज से मिले क्रॉस-साइट डेटा का इस्तेमाल करके, एग्रीगेट डेटा रिपोर्ट जनरेट करें.

वेब पर काम करने वाली अहम सुविधाएं उपलब्ध कराने के लिए, प्राइवेट एग्रीगेशन एपीआई का इस्तेमाल, क्रॉस-साइट डेटा के एग्रीगेट और रिपोर्टिंग के लिए निजता बनाए रखने का तरीका बताया गया है.

लागू करने की स्थिति

प्रस्ताव स्थिति
शेयर किए गए स्टोरेज के लिए, अमान्य Private एग्रीगेशन एपीआई रिपोर्ट की पुष्टि करना
एक्सप्लेनर
Chrome में उपलब्ध
निजी एग्रीगेशन डीबग मोड की उपलब्धता, 3PC की ज़रूरी शर्तों पर निर्भर करती है
GitHub की समस्या
Chrome M119 में उपलब्ध है
रिपोर्ट में देरी कम हो रही है
पूरी जानकारी देने वाला वीडियो
Chrome M119 में उपलब्ध है
Google Cloud के लिए Private एग्रीगेशन एपीआई और एग्रीगेशन सेवा के लिए सहायता
पूरी जानकारी देने वाला वीडियो
Chrome M121 में उपलब्ध है
इकट्ठा किए जा सकने वाले रिपोर्ट पेलोड के लिए पैडिंग (जगह)
पूरी जानकारी देने वाला वीडियो
Chrome M119 में उपलब्ध है
नीलामी इसकी जानकारी देने वाली रिपोर्ट के लिए, निजी एग्रीगेशन डीबग मोड उपलब्ध है
पूरी जानकारी देने वाला वीडियो
Chrome M123 में होने की उम्मीद है
फ़िल्टर आईडी से जुड़ी सहायता
पूरी जानकारी देने वाला वीडियो
Chrome M128 में होना ज़रूरी है

Private एग्रीगेशन API क्या है

Private एग्रीगेशन API की मदद से डेवलपर, एग्रीगेट डेटा रिपोर्ट जनरेट कर सकते हैं Protected Audience API से मिला डेटा और शेयर किए गए स्टोरेज से मिला क्रॉस-साइट डेटा.

फ़िलहाल, यह एपीआई एक कार्रवाई उपलब्ध कराता है, contributeToHistogram(). हालांकि, कुछ और कार्रवाइयां की जा सकती हैं आने वाले समय में मदद मिल सकेगी. हिस्टोग्राम ऑपरेशन की मदद से आप डेटा इकट्ठा कर सकते हैं जिसे एपीआई में एग्रीगेशन कुंजी के तौर पर जाना जाता है. आपका हिस्टोग्राम कॉल, वैल्यू इकट्ठा करता है और नॉइज़ के तौर पर एग्रीगेट किया गया नतीजा देता है सारांश रिपोर्ट का फ़ॉर्म होता है. उदाहरण के लिए, रिपोर्ट ऐसी साइटें जिन पर हर उपयोगकर्ता ने आपका कॉन्टेंट देखा हो या जिन्हें आपके तीसरे पक्ष की स्क्रिप्ट में कोई गड़बड़ी मिली हो. यह कार्रवाई किसी दूसरे एपीआई के वर्कलेट में की जाती है.

उदाहरण के लिए, अगर आपने पहले से शेयर किए गए स्टोरेज में डेमोग्राफ़िक और भौगोलिक डेटा रिकॉर्ड किया है, तो Private एग्रीगेशन API का इस्तेमाल करके एक हिस्टोग्राम बनाया जा सकता है. इससे आपको पता चलेगा कि न्यूयॉर्क शहर में कितने लोगों ने आपके कॉन्टेंट को क्रॉस-साइट से देखा है. इस मेज़रमेंट के लिए, भौगोलिक डाइमेंशन को एग्रीगेशन कुंजी में बदला जा सकता है. साथ ही, एग्रीगेट की जा सकने वाली वैल्यू में उपयोगकर्ताओं की गिनती की जा सकती है.

मुख्य सिद्धांत

जब निजी एग्रीगेशन एपीआई को एग्रीगेशन कुंजी और एग्रीगेट की जा सकने वाली वैल्यू के साथ कॉल किया जाता है, तो ब्राउज़र एग्रीगेट की जा सकने वाली रिपोर्ट जनरेट करता है.

इकट्ठा करने और बैच बनाने के लिए, इकट्ठा की जा सकने वाली रिपोर्ट आपके सर्वर पर भेजी जाती हैं. बैच में बनाई गई रिपोर्ट को एग्रीगेशन सेवा बाद में प्रोसेस करती है और इसके बाद खास जानकारी वाली रिपोर्ट जनरेट होती है.

Private एग्रीगेशन API के मुख्य सिद्धांतों के बारे में ज़्यादा जानने के लिए, Private एग्रीगेशन एपीआई की बुनियादी बातें दस्तावेज़ देखें.

एट्रिब्यूशन रिपोर्टिंग से अंतर

Private एग्रीगेशन API और Attribution Reporting API के बीच कई समानताएं. एट्रिब्यूशन रिपोर्टिंग एक स्टैंडअलोन एपीआई है जिसे कन्वर्ज़न मेज़र करने के लिए डिज़ाइन किया गया है. वहीं, प्राइवेट एग्रीगेशन को Protected Audience API और Shared Storage जैसे एपीआई के साथ मिलकर, क्रॉस-साइट मेज़रमेंट के लिए बनाया गया है. दोनों एपीआई, ऐसी एग्रीगेट करने लायक रिपोर्ट बनाते हैं जिनका इस्तेमाल एग्रीगेशन सेवा के बैक-एंड में, खास जानकारी वाली रिपोर्ट जनरेट करने के लिए किया जाता है.

एट्रिब्यूशन रिपोर्टिंग, अलग-अलग समय पर होने वाले कन्वर्ज़न इवेंट और इंप्रेशन इवेंट से इकट्ठा किए गए डेटा को जोड़ती है. प्राइवेट एग्रीगेशन किसी एक क्रॉस-साइट इवेंट को मेज़र करता है.

इस एपीआई की जांच करें

Private एग्रीगेशन एपीआई को स्थानीय तौर पर टेस्ट करने के लिए, chrome://settings/adPrivacy में मौजूद सभी Ad Privacy API को चालू करें.

एक्सपेरिमेंट में टेस्ट करने और इसमें हिस्सा लेने के बारे में ज़्यादा जानें.

डेमो का इस्तेमाल करें

शेयर किए गए स्टोरेज के लिए Private एग्रीगेशन एपीआई का डेमो, goo.gle/shared-storage-demo पर जाकर ऐक्सेस किया जा सकता है. कोड, GitHub पर उपलब्ध है. डेमो लेने पर, क्लाइंट-साइड की कार्रवाइयां लागू होती हैं और आपके सर्वर पर भेजी जाने वाली एक एग्रीगेट की जा सकने वाली रिपोर्ट तैयार होती है.

Protected Audience API के लिए, Private एग्रीगेशन API का डेमो आने वाले समय में पब्लिश किया जाएगा.

उपयोग के उदाहरण

Private एग्रीगेशन, क्रॉस-साइट मेज़रमेंट के लिए इस्तेमाल किया जाने वाला एक सामान्य एपीआई है. यह Shared Storage और Protected Audience API वर्कलेट में इस्तेमाल के लिए उपलब्ध है. सबसे पहले, यह तय करें कि आपको किस तरह की जानकारी इकट्ठा करनी है. ये डेटा पॉइंट आपकी एग्रीगेशन कुंजियों का आधार होते हैं.

शेयर किए गए स्टोरेज के साथ

शेयर किया गया स्टोरेज की मदद से, क्रॉस-साइट डेटा को किसी सुरक्षित जगह पर पढ़ा और लिखा जा सकता है, ताकि लीक होने से बचा जा सके. साथ ही, Private एग्रीगेशन API का इस्तेमाल करके, शेयर किए गए स्टोरेज में सेव किए गए क्रॉस-साइट डेटा को मेज़र किया जा सके.

यूनीक रीच का मेज़रमेंट

शायद आप यह आकलन करना चाहें कि कितने यूनीक उपयोगकर्ताओं ने उनका कॉन्टेंट देखा है. Private एग्रीगेशन एपीआई जवाब दे सकता है. जैसे, "करीब 317 यूनीक उपयोगकर्ताओं ने Content ID 861 देखा है."

आप शेयर किए गए स्टोरेज में फ़्लैग सेट करके यह बता सकते हैं कि उपयोगकर्ता ने कॉन्टेंट को पहले ही देख लिया है या नहीं. पहली विज़िट पर जहां फ़्लैग मौजूद नहीं है, वहां प्राइवेट एग्रीगेशन को कॉल किया जाता है और फिर फ़्लैग सेट कर दिया जाता है. क्रॉस-साइट विज़िट और उपयोगकर्ता के बाद की विज़िट पर, शेयर किए गए स्टोरेज की जांच की जा सकती है. अगर फ़्लैग सेट किया गया है, तो निजी एग्रीगेशन के लिए रिपोर्ट सबमिट करना स्किप किया जा सकता है. इन मापों को लागू करने के तरीकों के बारे में ज़्यादा जानने के लिए, हमारा पहुंच से जुड़ा व्हाइट पेपर देखें.

डेमोग्राफ़िक्स (उम्र, लिंग, आय, शिक्षा वगैरह) मेज़रमेंट

शायद आप उन उपयोगकर्ताओं की डेमोग्राफ़िक्स (उम्र, लिंग, आय, शिक्षा वगैरह) का आकलन करना चाहें जिन्होंने अलग-अलग साइटों पर आपका कॉन्टेंट देखा है.

निजी एग्रीगेशन जवाब दे सकता है, जैसे कि "करीब 317 यूनीक उपयोगकर्ता 18 से 45 साल के हैं और जर्मनी से हैं." तीसरे पक्ष से मिले डेमोग्राफ़िक्स (उम्र, लिंग, आय, शिक्षा वगैरह) का डेटा ऐक्सेस करने के लिए, शेयर किए गए स्टोरेज का इस्तेमाल करें. बाद में, एग्रीगेशन कुंजी में उम्र समूह और देश के डाइमेंशन को कोड में बदलकर निजी एग्रीगेशन की मदद से रिपोर्ट जनरेट की जा सकती है.

K+ फ़्रीक्वेंसी मेज़रमेंट

आप उन उपयोगकर्ताओं की संख्या को मेज़र करना चाहेंगे जिन्होंने किसी ब्राउज़र पर, किसी कॉन्टेंट या विज्ञापन को कम से कम K बार देखा है. इसका मतलब है कि पहले से चुनी गई वैल्यू K के तौर पर सेट है.

निजी एग्रीगेशन जवाब दे सकता है. जैसे, "करीब 89 उपयोगकर्ताओं ने Content ID 581 को कम से कम तीन बार देखा है." शेयर किए गए स्टोरेज में, अलग-अलग साइटों से काउंटर को बढ़ाया जा सकता है. साथ ही, उसे वर्कलेट में भी पढ़ा जा सकता है. जब संख्या K तक पहुंच जाएगी, तब प्राइवेट एग्रीगेशन की मदद से रिपोर्ट सबमिट की जा सकती है.

Protected Audience API की मदद से

Protected Audience API, फिर से टारगेट करने और ज़रूरत के मुताबिक ऑडियंस इस्तेमाल करने के उदाहरणों को चालू करता है. वहीं, Private एग्रीगेशन की मदद से, खरीदार और सेलर के वर्कलेट से इवेंट की रिपोर्ट की जा सकती है. एपीआई का इस्तेमाल कई कामों के लिए किया जा सकता है, जैसे कि नीलामी के लिए लगाई गई बिड के डिस्ट्रिब्यूशन को मेज़र करना.

Protected Audience API वर्कलेट से, सीधे contributeToHistogram() का इस्तेमाल करके डेटा इकट्ठा किया जा सकता है. साथ ही, contributeToHistogramOnEvent() का इस्तेमाल करके, ट्रिगर के आधार पर डेटा की रिपोर्ट की जा सकती है. यह Protected Audience API का खास एक्सटेंशन है.

उपलब्ध फ़ंक्शन

शेयर किए गए स्टोरेज और Protected Audience API के वर्कलेट में, privateAggregation ऑब्जेक्ट में ये फ़ंक्शन उपलब्ध हैं.

contributeToHistogram()

आपके पास privateAggregation.contributeToHistogram({ bucket: <bucket>, value: <value> }) को कॉल करने का विकल्प है. यहां एग्रीगेशन कुंजी bucket है और एग्रीगेट की जा सकने वाली वैल्यू value है. bucket पैरामीटर के लिए, BigInt ज़रूरी है. value पैरामीटर के लिए, पूर्णांक संख्या ज़रूरी है.

पहुंच के मेज़रमेंट के लिए, शेयर किए गए स्टोरेज में इसे कैसे कहा जा सकता है, इसका एक उदाहरण यहां दिया गया है:

iframe.js

// Cross-site iframe code

async function measureReach() {
 // Register worklet
 await window.sharedStorage.worklet.addModule('worklet.js');

 // Run reach measurement operation
 await window.sharedStorage.run('reach-measurement', { 
  data: { contentId: '1234' } 
 });
}

measureReach();

worklet.js

// Shared storage worklet code

function convertContentIdToBucket(campaignId){ 
  // Generate aggregation key
}

// The scale factor is multiplied by the aggregatable value to
// maximize the signal-to-noise ratio. See "Noise and scaling" 
// section in the Aggregation Fundamentals document to learn more.
const SCALE_FACTOR = 65536;

class ReachMeasurementOperation {
  async run(data) {
    const key = 'has-reported-content';
    // Read the flag from Shared Storage
    const hasReportedContent = await this.sharedStorage.get(key) === 'true';

    // Do not send report if the flag is set
    if (hasReportedContent) {
      return;
    }

    // Send histogram report
    // Set the aggregation key in `bucket`
    // Bucket examples: 54153254n or BigInt(54153254)
    // Set the scaled aggregatable value in `value`
    privateAggregation.contributeToHistogram({
      bucket: convertContentIdToBucket(data.contentId), 
      value: 1 * SCALE_FACTOR 
    });

    // Set the flag in Shared Storage
    await this.sharedStorage.set(key, true);
  }
}

register('reach-measurement', ReachMeasurementOperation);

ऊपर दिए गए कोड के उदाहरण में, क्रॉस-साइट iframe कॉन्टेंट लोड होने पर प्राइवेट एग्रीगेशन को कॉल किया जाएगा. iframe कोड वर्कलेट को लोड करता है और वर्कलेट, एग्रीगेशन कुंजी (बकेट) में बदले कॉन्टेंट आईडी के साथ Private एग्रीगेशन API को कॉल करता है.

contributeToHistogramOnEvent()

सिर्फ़ Protected Audience API वर्कलेट में, हम किसी खास इवेंट के होने पर ही रिपोर्ट भेजने के लिए, ट्रिगर-आधारित तरीका उपलब्ध कराते हैं. इस फ़ंक्शन की मदद से, बकेट और वैल्यू को उन सिग्नल पर भी निर्भर रहने की अनुमति मिलती है जो नीलामी के उस समय तक उपलब्ध नहीं हैं.

privateAggregation.contributeToHistogramOnEvent(eventType, contribution) तरीके में, ट्रिगर करने वाले इवेंट की जानकारी देने वाले eventType और इवेंट के ट्रिगर होने पर सबमिट किए जाने वाले contribution की जानकारी होती है. ट्रिगर करने वाला इवेंट, नीलामी खत्म होने के बाद भी हो सकता है. जैसे, नीलामी में जीतने या हारने का इवेंट. इसके अलावा, यह विज्ञापन को रेंडर करने वाले फ़्रेम के अंदर से भी ट्रिगर हो सकता है. नीलामी वाले इवेंट की रिपोर्ट भेजने के लिए, दो रिज़र्व कीवर्ड reserved.win, reserved.loss, और reserved.always का इस्तेमाल किया जा सकता है. फ़ेंस किए गए फ़्रेम से, किसी इवेंट से ट्रिगर हुई रिपोर्ट सबमिट करने के लिए, कस्टम इवेंट टाइप तय करें. फ़ेंस किए गए फ़्रेम से इवेंट को ट्रिगर करने के लिए, fence.reportEvent() तरीके का इस्तेमाल करें. यह तरीका, Fenced Frames Ads Reporting API में उपलब्ध है.

यहां दिए गए उदाहरण में, नीलामी के जीतने वाले इवेंट के ट्रिगर होने पर, इंप्रेशन की रिपोर्ट भेजी जाती है. साथ ही, अगर विज्ञापन रेंडर करने वाले फ़ेंस किए गए फ़्रेम से click इवेंट ट्रिगर होता है, तो क्लिक रिपोर्ट भेजता है. क्लिक मिलने की दर (सीटीआर) का हिसाब लगाने के लिए, इन दोनों वैल्यू का इस्तेमाल किया जा सकता है.

function generateBid(interestGroup, auctionSignals, perBuyerSignals, trustedBiddingSignals, browserSignals) {
  // …
  privateAggregation.contributeToHistogramOnEvent("reserved.win", {
      bucket: getImpressionReportBucket(),
      value: 1
  });
  privateAggregation.contributeToHistogramOnEvent("click", {
      bucket: getClickReportBuckets(), // 128-bit integer as BigInt
      value: 1
  });

ज़्यादा जानने के लिए, एक्सटेंडेड प्राइवेट एग्रीगेशन रिपोर्टिंग की जानकारी देखें.

enableDebugMode()

तीसरे पक्ष की कुकी अब भी उपलब्ध हैं. हालांकि, हम कुछ समय के लिए ऐसा तरीका उपलब्ध कराएंगे जिससे डीबग मोड को चालू करके, डीबग करने और टेस्ट करने में आसानी होगी. डीबग रिपोर्ट की मदद से, कुकी पर आधारित मेज़रमेंट और निजी एग्रीगेशन मेज़रमेंट की तुलना की जा सकती है. साथ ही, इससे एपीआई इंटिग्रेशन की तेज़ी से पुष्टि की जा सकती है.

वर्कलेट में privateAggregation.enableDebugMode() को कॉल करने से, डीबग मोड चालू हो जाता है. इस वजह से, एग्रीगेट की जा सकने वाली रिपोर्ट में, एन्क्रिप्ट (सुरक्षित) नहीं किए गए (क्लियरटेक्स्ट) पेलोड को शामिल किया जाता है. इसके बाद, इन पेलोड को एग्रीगेशन सेवा के लोकल टेस्टिंग टूल की मदद से प्रोसेस किया जा सकता है.

डीबग मोड सिर्फ़ ऐसे कॉलर के लिए उपलब्ध है जिन्हें ऐक्सेस करने की अनुमति है तीसरे पक्ष की कुकी. अगर कॉलर के पास तीसरे पक्ष की कुकी का ऐक्सेस नहीं है, तो enableDebugMode() कोई कार्रवाई नहीं कर पाएगा. इसका मतलब है कि जब तीसरा पक्ष, कुकी का इस्तेमाल नहीं किया जा रहा है. इसलिए, अब डीबग मोड उपलब्ध नहीं रहेगा.

डीबग पासकोड सेट करने के लिए, privateAggregation.enableDebugMode({ <debugKey: debugKey> }) को कॉल करें. यहां BigInt का इस्तेमाल डीबग पासकोड के तौर पर किया जा सकता है. कुकी पर आधारित मेज़रमेंट के डेटा और प्राइवेट एग्रीगेशन मेज़रमेंट के डेटा को जोड़ने के लिए, डीबग कुंजी का इस्तेमाल किया जा सकता है.

हर कॉन्टेक्स्ट के लिए, इनका इस्तेमाल सिर्फ़ एक बार किया जा सकता है. बाद के किसी भी कॉल में अपवाद होगा.

// Enables debug mode
privateAggregation.enableDebugMode();

// Enables debug mode and sets a debug key
privateAggregation.enableDebugMode({ debugKey: BigInt(1234) });

पुष्टि की रिपोर्ट करें

शेयर किए गए स्टोरेज के लिए, शेयर किए गए स्टोरेज ऑपरेशन कॉल में कॉन्टेक्स्ट आईडी जोड़कर यह पुष्टि की जा सकती है कि आपको मिली सभी रिपोर्ट सही हैं या नहीं. आईडी को भेजी गई रिपोर्ट से अटैच कर दिया जाएगा और बाद में, उस आईडी का इस्तेमाल करके यह पुष्टि की जा सकती है कि रिपोर्ट, आपके शेयर किए गए स्टोरेज ऑपरेशन से भेजी गई थी या नहीं.

इस सुविधा को Chrome M114 और इसके बाद के वर्शन में टेस्ट किया जा सकता है. Protected Audience API के लिए, रिपोर्ट की पुष्टि करने की सुविधा फ़िलहाल टेस्टिंग के लिए उपलब्ध नहीं है.

ज़्यादा जानने के लिए, पुष्टि करने की शिकायत के बारे में जानकारी वाला लेख पढ़ें.

दिलचस्पी बढ़ाएं और सुझाव दें

Private एग्रीगेशन एपीआई पर अभी चर्चा की जा रही है. आने वाले समय में इसमें बदलाव हो सकता है. अगर आपने इस एपीआई को आज़माया है और आपके पास कोई सुझाव है, तो हमें ज़रूर बताएं.