購入者として B&A と統合する

入札およびオークション(B&A)サービスは、広告の購入者と販売者向けのサービス群で、高信頼実行環境(TEE)で実行され、Protected Audience(PA)オークションを促進します。このデベロッパー ガイドでは、購入者が Chrome 向け B&A PA オークションと統合する方法について説明します。

概要

B&A サービスで Protected Audience オークションに参加するには、バイヤーがインタレスト グループ(IG)を更新して、オークションのレイテンシを改善するためにペイロードを最適化します。

購入者は次のペイロード最適化タスクを必要とします。

B&A のインタレスト グループ

ペイロード最適化が適用された B&A PA オークションのインタレスト グループ構成の例を次に示します。

navigator.joinAdInterestGroup({
  name: 'example-ig',
  owner: 'https://dsp.example',

  // An ID is mapped to each render URL
  ads: [
    {
      renderURL: 'https://dsp.example/ad.html',
      adRenderId: '12345678' // 12 characters max,
      buyerReportingId: 'brid123', // Optional
      buyerAndSellerReportingId: 'bsrid123', // Optional
      selectableBuyerAndSellerReportingId: ['sbsrid123', 'sbsrid456'], // Optional
    },
  ],
  adComponents: [
    {
      renderURL: 'https://dsp.example/ad-component.html',
      adRenderId: 'abcdefgh'
    },
  ],

  // Flags are set to omit data in the B&A auction payload
  auctionServerRequestFlags: ['omit-ads', 'omit-user-bidding-signals'],

  // Data not included in the B&A auction payload can be fetched as trusted signals
  // The following is an example of how the keys could look, but the actual
  // implementation is up to the ad tech
  trustedBiddingSignalsKeys: [
    'exampleUserBiddingSignalsKey',
    'exampleAdRenderIdKey',
    'exampleAdMetadataKey',
    'exampleAdReportingIdKey',
  ],

  // Optionally, interest groups can be prioritized
  priority: 0.0,
});

B&A とオンデバイスのインタレスト グループ設定の違いは次のとおりです。

フィールド B&A IG オンデバイス IG B&A オークションのペイロードに含まれる
auctionServerRequestFlags 使用済み 不使用 いいえ
userBiddingSignals 非推奨 使用済み いいえ(omit-user-bidding-signals フラグが設定されている場合)
adsadComponentsadRenderId 使用済み 不使用 omit-ads フラグが設定されている場合、adsadRenderId はペイロードの browserSignals.prevWins でのみ使用できます。adComponents で定義された adRenderId がペイロードに含まれていません。

omit-ads フラグが設定されていない場合、browserSignals.prevWinsinterestGroup.adRenderIdsinterestGroup.adComponentRenderIds で利用できます。

adsadComponentsrenderURL 使用済み 使用済み いいえ
adsadComponentsmetadata 不使用 使用済み いいえ
ads のレポート用識別子 使用済み 使用済み いいえ
  • auctionServerRequestFlags フィールドでは、ブラウザに B&A オークション ペイロードの一部のデータを省略するよう指示するフラグを設定できます。
  • userBiddingSignals 値はインタレスト グループで定義できますが、omit-user-bidding-signals フラグを使用して省略することをおすすめします。省略されたシグナルは、K/V サービスを使用して提供できます。
  • adRenderId フィールドは関連する renderURL とともに設定されますが、B&A オークション ペイロードの一部になるのは adRenderId のみです。オークション時に generateBid() から返されるレンダリング URL は、IG で定義されたレンダリング URL と一致する必要があります。
  • レポート ID は B&A IG で定義されていますが、B&A オークション ペイロードには含まれていません。オークション時に generateBid() から返されるレポート ID は、IG で定義されたレンダリング URL と一致する必要があります。
  • ad.metadata とレポート ID は B&A オークション ペイロードに含まれていません。代わりに、これらのデータは Trusted Key/Value Service の使用を通じて利用可能になります。

renderURLads のレポート ID はインタレスト グループ構成で定義されていますが、オークション リクエスト ペイロードには含まれません。これは、ブラウザが、入札サービスの generateBid() 関数から返されたレンダリング URL とレポート ID が、インタレスト グループで定義された値と一致することを確認するためです。

joinAdInterestGroup() 件のタスク

joinAdInterestGroup() 呼び出しでは、次のタスクを実行する必要があります。

サーバー リクエスト フラグを設定する

joinAdInterestGroup() 構成の auctionServerRequestFlags フィールドには、次のフラグを指定できます。

フラグ 説明
omit-user-bidding-signals omit-user-bidding-signals フラグを指定すると、オークション ペイロードで userBiddingSignals オブジェクトが省略されます。

フラグが設定されていない場合、インタレスト グループで定義された userBiddingSignals の値は、入札サービスの generateBid() 内で利用可能になります。

omit-ads omit-ads フラグは、オークション ペイロードで ads オブジェクトと adComponents オブジェクトを省略するようブラウザに指示します。

adRenderIdbrowserSignalsprevWins プロパティで使用できます。

フラグが設定されていない場合、generateBid()interestGroup 引数の adRenderIds フィールドと adComponentRenderIds フィールドには、対応する広告レンダリング ID が含まれます。

購入者は omit-ads フラグを選択することを強くおすすめします。将来的に、ペイロードの最適化をさらに進めるため、クライアントからレンダリング ID と広告コンポーネントのレンダリング ID を渡すことが非推奨になる可能性があります。

省略されたデータは、関連情報を trustedBiddingSignals で利用できるようにすることで処理されます。フラグは個別に使用でき、一緒に使用する必要はありません。

使用例:

navigator.joinAdInterestGroup({
  auctionServerRequestFlags: ['omit-user-bidding-signals', 'omit-ads'],
});

広告レンダリング ID を設定する

B&A オークション ペイロードのサイズを縮小するため、インタレスト グループの ads オブジェクトと adComponents オブジェクトは省略されます。そのため、これらのオブジェクトは Bidding Service で実行される generateBid() 関数内では使用できません。

広告情報の欠落に対処するため、購入者はインタレスト グループ設定の各広告に関連付けられた識別子(adRenderIdadComponentRenderId)を保持します。識別子は 12 バイト以下の DOMString である必要があります。識別子が Base64 エンコードされている場合、その長さは 12 バイト以下にする必要があります。

広告レンダリング ID を含むインタレスト グループの例:

navigator.joinAdInterestGroup({
  ads: [
    {
      renderURL: 'https://dsp.example/ad.html',
      adRenderId: '12345678' // 12 characters max
    },
  ],
  adComponents: [
    {
      renderURL: 'https://dsp.example/ad-component.html',
      adComponentRenderId: 'abcdefgh'
    },
  ],
});

広告に関連付けられている adRenderId は、generateBid()prevWins.browserSignals で使用できるようになります。

renderURL はリクエスト ペイロードに含まれていませんが、generateBid() から返されるレンダリング URL は、インタレスト グループ構成で定義されたレンダリング URL と一致する必要があります。広告テクノロジーは trustedBiddingSignals で広告メタデータなどの情報を返送できるため、generateBid() の実行中に、入札の広告レンダリング URL と広告コンポーネントのレンダリング URL を生成できます。

インタレスト グループの優先度を設定する

Chrome では、購入者がインタレスト グループの優先度を設定できます。販売者が設定した購入者ごとのペイロード サイズの上限に達すると、インタレスト グループの優先度の値を使用して、販売者の B&A オークション ペイロードが生成されるときに、優先度の低いインタレスト グループが単一の購入者に対して削除されます。異なる購入者間のインタレスト グループを選択する場合、ブラウザはシリアル化されたペイロードのサイズに基づいて決定します。デフォルトでは、各購入者に同じサイズが割り当てられます。実際の優先順位付けは、リクエスト ペイロードの生成時ではなく、B&A サーバーで行われます。

優先度は、購入者の優先度ベクトル(priorityVector)と販売者の優先度シグナル(prioritySignals)を使用してオークション時に計算されます。購入者は販売者の優先度シグナルをオーバーライドできます。

プロパティ 説明
優先度ベクトル 購入者は、K/V サービスの priorityVector キーの値としてベクトルを提供します
優先シグナル 販売者は、オークション構成の priority_signals を設定してシグナルを提供します。
優先シグナルのオーバーライド 購入者は、オークション構成の PerBuyerConfigpriority_signals_overrides フィールドでオーバーライドを指定します。

オークション中、ブラウザは優先度を計算するために、priorityVectorprioritySignals の一致するキーのスパース ドット積を計算します。次の図では、優先度は (4 * 2) + (3 * -1) で計算され、8 + -3 に減らされるため、オークション時のこのインタレスト グループの優先度は 5 になります。

優先度ベクトルと優先度シグナル オブジェクトの各キーが互いに乗算され、その結果が合計されて優先度が計算されます。
図 1: 購入者のベクトルと販売者のシグナルを使用した優先度の計算

B&A で優先順位付けに使用できる追加シグナルは次のとおりです。

シグナル 説明
deviceSignals.one 値は常に 1 で、内積に定数を追加する場合に便利です。
deviceSignals.ageInMinutes この値は、インタレスト グループの年齢(最新のインタレスト グループへの参加からの経過時間)を分単位で表したもので、0 ~ 43,200 の整数です。
deviceSignals.ageInMinutesMax60 値は ageInMinutes シグナルと同じですが、最大値は 60 です。グループが 1 時間以上経過している場合は、60 が返されます。
deviceSignals.ageInHoursMax24 値はインタレスト グループの存続期間を時間単位で表します。最大値は 24 時間です。グループが 1 日以上経過している場合は、24 が返されます。
deviceSignals.ageInDaysMax30 この値は、インタレスト グループの経過日数を表します(最大 30 日)。グループの作成から 30 日以上経過している場合は、30 が返されます。

詳しくは、GitHub の説明をご覧ください。

信頼できる入札シグナルを設定する

B&A オークション ペイロードから一部のデータが除外されるため、Key-Value サービスを使用して、除外されたデータを信頼できる入札シグナルとして generateBid() 関数に提供できます。

次の省略されたデータは、K/V サービスによって提供できます。

  • 購入者が使用している場合は userBiddingSignals
  • 各広告に関連付けられた metadata
  • 各広告に関連付けられた adRenderId
  • レポート ID
インタレスト グループから除外されたデータは、購入者の収集サーバーに送信できます。収集サーバーがデータを Key-Value サービスにプッシュし、後でブラウザが Key-Value サービスからデータを読み込みます。
図 2: 信頼できるシグナルの設定例

1 つの方法として、信頼できる入札シグナルのキーに一意の ID を含め、関連するデータをサーバーに送信して、Key/Value サービスに読み込めるようにする方法があります。ただし、実際の実装は広告テクノロジーに委ねられており、API は規定されていません。

次の例では、実装可能なアプローチの 1 つについて説明します。

const ad1RenderURL = 'https://dsp.example/ad-1.html';
const ad2RenderURL = 'https://dsp.example/ad-2.html';
const ad1RenderId = 'render-id-1';
const ad2RenderId = 'render-id-2';
const ad1ReportingId = 'reporting-id-1';
const ad2ReportingId = 'reporting-id-2';

// Generate a unique identifier
const id = crypto.randomUUID();

// Define the keys with the unique ID
const trustedSignalsKeyForIG = `interest-group-${id}`

// Set the keys in the interest group
navigator.joinAdInterestGroup({
  // …
  ads: [
    {
      renderURL: ad1RenderURL,
      adRenderId: ad1RenderId,
      buyerReportingId: ad1ReportingId
    },
    {
      renderURL: ad2RenderURL,
      adRenderId: ad2RenderId,
      buyerReportingId: ad2ReportingId
    },
  ],
  trustedBiddingSignalsKeys: [
    trustedSignalsKeyForIG
  ]
});

// Send the associated data to your server to be loaded into the Key/Value Service
fetch('https://dsp.example/kv/load', {
  method: 'POST',
  body: JSON.stringify({
    id,
    [trustedSignalsKeyForIG]: {
      userBiddingSignals: {
        favoriteColor: 'blue'
      },
      ads: [
        {
          renderURL: ad1RenderURL,
          adRenderId: ad1RenderId,
          buyerReportingId: ad1ReportingId,
          metadata: {
            color: 'red'
          }   
        },
        {
          renderURL: ad2RenderURL,
          adRenderId: ad2RenderId,
          buyerReportingId: ad2ReportingId,
          metadata: {
            color: 'blue'
          }   
        },
      ]
    }
  })
});

この例では、IG に一意の識別子が定義され、信頼できるシグナルのキーの一部になります。IG のキーと関連する値がサーバーに送信され、Key-Value サービスに読み込まれます。オークションの後半で、ブラウザは信頼できるシグナルを取得し、購入者の generateBid() 関数で使用できるようにします。

必要に応じて K/V からインタレスト グループの更新シグナルを返す

信頼できるシグナルの updateIfOlderThanMs キーは、通常の日次間隔よりも早くインタレスト グループを更新するために使用されます。updateIfOlderThanMs キーで返されたミリ秒値を超える期間、インタレスト グループに参加または更新されていない場合、インタレスト グループは updateURL メカニズムで更新されます。Chrome は、インタレスト グループを 10 分に 1 回を超える頻度で更新することはありません。

B&A オークションで、ブラウザに保存されているインタレスト グループで定義された広告のいずれにも一致しない落札広告が返された場合、ブラウザはオークションを失敗させます。updateIfOlderThanMs メカニズムは、ブラウザと B&A オークションがインタレスト グループ内の広告セットについて合意していることを確認するうえで役立ちます。

詳しくは、説明をご覧ください。

generateBid() 件のタスク

generateBid() 呼び出しでは、次のタスクを実行する必要があります。

ブラウザ シグナルを読み取る

B&A の generateBid() 呼び出しに渡される browserSignals オブジェクトは次のようになります。

{
  topWindowHostname: 'advertiser.example',
  seller: 'https://ssp.example',
  topLevelSeller: 'https://ssp-top.example',
  joinCount: 5,
  bidCount: 24,
  recency: 1684134092,

  // prevWins is [timeInSeconds, adRenderId]
  prevWins: [
    [9342, 'render-id-1'],
    [1314521, 'render-id-2']
  ],

  // Compiled WebAssembly code
  wasmHelper: WebAssembly.Module

  // Data-Version value from K/V response, if available
  dataVersion: 1,
}

browserSignals では、次の変更または新しいプロパティを使用できます。

プロパティ 説明
prevWins prevWins は、時間と広告のタプルの配列です。この時間は、関連付けられた広告が過去 30 日間に最後に落札してから経過した秒数を表します。

ad オブジェクトではなく adRenderId を提供するように変更されました。

wasmHelper biddingWasmHelperURL から提供されたコードのコンパイル済みオブジェクト。
dataVersion 信頼できるサーバーは、必要に応じて、generateBid() で使用可能になる数値の Data-Version レスポンス ヘッダーを含めることができます。

詳しくは、GitHub の説明をご覧ください。

generateBid() からレンダリング URL を返す

B&A オークション ペイロードでは ads オブジェクトが省略されているため、generateBid() から返されたレンダリング URL を再作成する必要があります。レンダリング URL の再作成方法は実装によって決まります。返される URL は、インタレスト グループで定義されたレンダリング URL と一致している必要があります。

1 つの方法として、ベース URL を維持し、interestGrouptrustedBiddingSignals の情報でテンプレートを入力することが考えられます。

この例では、色と商品に基づいて 4 つの広告を定義しています。

await navigator.joinAdInterestGroup({
  ads: [
    { renderURL: 'https://dsp.example/red-shirt-ad.html', adRenderId: 'arid1'},
    { renderURL: 'https://dsp.example/blue-shirt-ad.html', adRenderId: 'arid2'},
    { renderURL: 'https://dsp.example/red-pants-ad.html', adRenderId: 'arid3'},
    { renderURL: 'https://dsp.example/blue-pants-ad.html', adRenderId: 'arid4'},
  ],
  trustedBiddingSignalKeys: [
    'userBiddingSignals-someUniqueId',
    // ...and more
  ]
})

次に、ユーザーのお気に入りの色と商品情報を送信して、Key/Value サービスに読み込みます。

fetch('https://dsp.example/kv/load', {
  body: JSON.stringify({
    'userBiddingSignals-someUniqueId': {
      favoriteColor: 'blue',
      favoriteProduct: 'shirt'
    }
  })
})

オークションが実行されると、信頼できる入札シグナルが generateBid() で利用可能になり、その情報を使用して URL を再構築できます。

function generateBid(..., trustedBiddingSignals, browserSignals) {
  const { userBiddingSignals } = trustedBiddingSignals
  const { favoriteColor, favoriteProduct } = userBiddingSignals

  return {
    bid: 1,
    render: `https://dsp.example/${favoriteColor}-${favoriteProduct}-ad.html`
  }
}

generateBid() からレポート ID を返す

レポート ID は B&A オークション ペイロードに含まれていないため、信頼できる入札シグナルを通じて generateBid() で ID を利用できるようになります。使用するレポート ID が決定されると、選択されたレポート ID が generateBid() から返されます。返される ID は、インタレスト グループで定義された ID と一致している必要があります。

この例では、広告 1 が選択され、関連付けられたレンダリング ID が generateBid() から返されます。

generateBid(..., trustedBiddingSignals, ) {
  const { ad1ReportingId, ad2reportingId } = trustedBiddingSignals;
  // ...
  return {
    bid: 1,
    render: 'https://dsp.example/ad-1.html'
    buyerReportingId: ad1reportingId
  }
}

返されたレポート ID は、buyerReportingSignals を介して reportWin() で使用できるようになります。

reportWin(..., buyerReportingSignals) {
  const { buyerReportingId } = buyerReportingSignals;
}

generateBid() から buyerReportingId が返されない場合、interestGroupName 値は buyerReportingId ではなく buyerReportingSignals で使用できます。

詳しくは、レポート ID に関するガイドをご覧ください。

次のステップ

次のリソースをご利用いただけます

その他の情報

ご不明な点がある場合