19
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

First-Party Setsでドメインを超えてCookieを共有する

Last updated at Posted at 2021-06-28

以下はGoogleが勧めているプライバシーサンドボックス技術のひとつ、First-Party Setsの紹介です。
細かい部分とかはよくわからないので端折ってたり想像で補ったりしている場合があります。
きっと誰かが正確な訳をプルリクしてくれるはず。

First-Party Sets

本文書は、関連するドメインをまとめてひとつのファーストパーティであると宣言するための、新しいWebプラットフォームメカニズムの提案です。

Introduction

ブラウザは様々なトラッキングポリシーやプライバシーモデルを提案しており( Chromium / Edge / Mozilla / WebKit )、個人情報にアクセスできる範囲をファーストパーティに限定しています。
ファーストパーティの範囲を定義する際には、2つの目標のバランスをとる必要があります。
すなわち、ユーザのプライバシーを守るのに十分な小さな範囲であり、かつユーザが望む機能を提供するのに十分な大きさであることです。

ファーストパーティの自然な範囲としては、ドメイン名があります。
しかし、ユーザのアクセスするWebサイトが複数のドメインにまたがっている場合もあります。
たとえばhttps://google.comhttps://google.co.ukhttps://youtube.comはひとつの組織によって運営されています。
あるいはhttps://apple.comhttps://icloud.comhttps://amazon.comhttps://amazon.deなども同様です。

プライバシー要求と矛盾しない範囲で、ユーザ情報を関連するオリジンに共有することを許可したい場合があります。
たとえばFirefoxには、同じ組織に属するドメインのリストが同梱されています。
このドキュメントでは、組織がそれぞれ独自のドメインリストを宣言し、そのセットがブラウザのポリシーに適合する場合にブラウザがそれを取り入れることを許可するメカニズムについて解説します。

Goals

・関連するドメインが同じファーストパーティであることを宣言できるようにする。
・宣言されたドメインを同じサイトとして扱うか否か、プライバシーポリシーの枠組みを定義する。

Non-goals

・無関係なサイト間でのサードパーティーログイン。
・ターゲティング広告やコンバージョン測定のための無関係なサイト間での情報共有。

これらのユースケースの一部については、プライバシーポリシーの他の領域でサポートされています。

Declaring a First Party Set

First-Party Setsは、ひとつのオーナードメインと、二次登録ドメインのリストによって構成されます。

以下の条件を満たすオリジンは、ファーストパーティセットを構成します。

・httpsである。
・登録ドメインがオーナーであるか、二次登録ドメインのひとつである。

ドメインがオプトインされていて、UAポリシーユーザとサイトのニーズに適合する場合、ブラウザはそのドメインをファーストパーティセットのメンバーであるとみなします。

ファーストパーティセットに参加するには、JSONのマニフェストファイルhttps://<domain>/.well-known/first-party-setを設置します。
二次登録ドメインではオーナードメインを指定し、オーナードメインでは所有する二次登録ドメイン、バージョン番号、UAポリシーの署名の一覧を記述します。

例として、a.exampleb.examplec.exampleがファーストパーティセットであり、オーナードメインがa.exampleである場合は、以下のようになります。

https://a.example/.well-known/first-party-set
{
  "owner": "a.example",
  "version": 1,
  "members": ["b.example", "c.example"],
  "assertions": { 
    "chrome-fps-v1" : "<base64 contents...>",
    "firefox-fps-v1" : "<base64 contents...>",
    "safari-fps-v1": "<base64 contents...>"
  }
}

https://b.example/.well-known/first-party-set
{ "owner": "a.example" }

https://c.example/.well-known/first-party-set
{ "owner": "a.example" }

ブラウザはオーナードメインのマニフェストに以下の制約を追加します。

members記載の登録可能ドメインのうち、登録可能でない場合は無視する。
members記載の二次登録ドメインのうち、UAポリシーに合致する場合のみ受け入れる。合致しない二次登録ドメインは無視する。
・オーナードメイン自体がUAポリシーに合致しない場合、全てが無視される。

Discovering First Party Sets

デフォルトでは、全ての登録可能なドメインは、自分自身がオーナードメインです。
WebサイトはSec-First-Party-Setレスポンスヘッダを送信し、ファーストパーティセットのオーナードメインをブラウザに知らせることができます。
たとえば、https://b.example/some/pageは以下のようなレスポンスヘッダを出力することができます。

  Sec-First-Party-Set: owner="a.example", minVersion=1

ブラウザが所有しているb.exampleの情報がこのヘッダと一致しない場合、ブラウザはナビゲーションを一時停止して2ドメインのマニフェスト、すなわちhttps://a.example/.well-known/first-party-sethttps://b.example/.well-known/first-party-setを取得します。
このリクエストは認証情報を用いず、またクロスサイトでリクエストしているという情報を漏洩しないように注意しなければなりません。
特にa.exampleにおいてはキャッシュを使ってはいけません。

マニフェストファイルの両方にドメインが含まれていることを確認したら、ブラウザはa.exampleb.exampleのオーナーとしてファーストパーティストレージに登録します。
c.exampleは入りません。
またこのときに、a.exampleがオーナーであるとファーストパーティストレージに記録されているドメインのうち、新しいマニフェストファイルからなくなったものを削除します。

次に、オーナーが変更されたドメインについて、Clear-Site-Dataと同じ動作で全てのキャッシュを削除し、アクティブなドキュメントを再読み込みします。
これはオーナーから外れたサイトへの関連付けを解除するために必要な動作です。
オーナーが変更になった際に、既存の実行コンテキスト(worker等)は破棄されます。

その後、ブラウザはリクエストを再試行し、ナビゲーションを完了します。
POSTの再試行は望ましくないため、POSTリクエストにおいてブラウザはSec-First-Party-Setレスポンスヘッダは無視すべきです。
POSTでファーストパーティセットを更新したいサイトは、POST後にリダイレクトを行い、リダイレクト先でSec-First-Party-Setレスポンスヘッダを返すようにします。

サブリソースやサブフレームのナビゲーションにおいては、新たなファーストパーティセットを登録することはできません。

Applications

様々なブラウザのプライバシーモデルをサポートするために、Webプラットフォームはファーストパーティセットを通じて、埋め込みコンテンツが自身のステータスにアクセスしてもよいか決定することができます。
たとえばCookieのSameParty属性を利用して、クロスドメインで送信するCookieアノテートすることができます。また、厳格なオリジンベースの分離が高コストになる場合に、ファーストパーティセットを使用してネットワークキャッシュを分散することでコストを抑えられるかもしれません。

Webプラットフォームは、あるオリジンの中身に別のオリジンが直接アクセスすることを目的としてファーストパーティセットを使用するべきではありません。
ファーストパーティセットは、埋め込みコンテンツが自身の状態にアクセスする場合にのみ限定すべきです。
たとえばa.exampleb.exampleがひとつのファーストパーティセットにあるとして、a.exampleのコンテンツがb.exampleのIndexedDBにアクセスすることはできないようにすべきです。
ただし、a.example内にフレームで表示されているb.exampleのコンテンツが、b.exampleのデータベースにアクセスすることは妥当かもしれません。

Design details

UA Policy

Defining acceptable sets

どのようなセットを許可するか、あるいは受け入れられないかについて、ある程度制限を持っておく必要があります。
たとえばWeb全体を含むセットや、全く関係ないサイトの集まりは明らかに受け入れられないと思われます。
逆にhttps://acme-corp-landing-page.examplehttps://acme-corp-online-store.exampleを含むセットは妥当だと思われます。
この両者の間には幅広いスペースがあり、どこで線を引くのかを定義しなければなりません。

ファーストパーティセットを実装するブラウザは、どのドメインがどのセットに含まれるかについてUAポリシーを定義します。
必須ではありませんが、UAポリシー間である程度の一貫性があることが望ましいでしょう。
UAポリシーを定義する際の指針としては、各ブラウザがファーストパーティをどのように考えているかを参考にすることができます。

A Potential Privacy Model for the Web (Chromium Privacy Sandbox)

ファーストパーティの概念は、eTLD+1を超えて拡張される可能性があります。
結果の範囲が広すぎず、ユーザの理解があることを前提に、ファーストパーティの制限を緩和することは合理的です。

Edge Tracking Protection Preview

全ての組織がひとつのドメイン名だけを使ってインターネットビジネスを展開しているわけではありません。
サイトの円滑な運用のため、ひとつの組織が所有・運営する複数のドメインをまとめています。

Mozilla Anti-Tracking Policy

ファーストパーティとは、同一組織が運営するウェブ上のリソースもしくはリソース群のことで、ユーザが容易に発見でき、リンクをクリックしたリフォームを送信するなど相互作用を行うものです。

WebKit Tracking Prevention Policy

ファーストパーティとは、ブラウザのURLフィールドに表示される、ユーザが意図的かつ承認したうえで訪問しているWebサイト、および同じ組織が運営するウェブ上のリソースの集合です。

UAポリシーは、ユースケースや不正使用などの対策に応じて、時間をかけて進化していくものと考えています。
たとえば無関係なサイトがファーストパーティの範囲を広げるためにコンソーシアムを形成することは悪用とみなされます。

UAポリシーはユーザのブラウザに配信されなければなりません。
これは静的なリスト、もしくは署名されたアサーションのいずれかを使用できます。

ファーストパーティセットのメンバーになるには、UAポリシーを満たすことと、マニフェストファイルによる記載の両方が必要となります。
これによって、Webサイトはファーストパーティセットから無関係なドメインを迅速に排除できます。

Static lists

ブラウザベンダは、自社のUAポリシーを満たすドメインリストをそれぞれで管理し、ブラウザに搭載することができます。
これはEdgeやFirefoxがクロスサイトトラッキングを制御するために使っている同一オーナーのドメインリストと同じようなものです。

このリストを使う場合は、ファーストパーティセットのマニフェストと合体して使います。

静的リストは制御や検査が簡単です。
その一方でスケーラビリティや即応性に問題が生じます。
リストの変更を、何らかのメカニズムで各ブラウザに送り付ける必要があります。
特にネットワーク接続性に困難のある地域では、新しいドメインリストを展開することが難しくなります。
またリストが大きくなりすぎるとスケーラビリティにも問題が起こります。

Signed assertions

ブラウザベンダー、およびベンダーが指定したオーナーは、秘密鍵を用いてドメインのアサーションに署名することができます。
署名されたアサーションは静的リストと同格の意味を持ちます。

Administrative controls

エンタープライズユースでは、Webプラットフォームの動作を制御するためにブラウザは管理者用オプションを提供します。
UPポリシーをプライベートドメインに適用するとは考えにくいので、ブラウザはローカル向けのファーストパーティセットを取り込むオプションを提供するかもしれません。

Cross-site tracking vectors

この設計では、ブラウザがファーストパーティセットの状態を記憶し、その状態を使ってサイトの動作を管理する必要があります。
この状態を、ファーストパーティが異なる2つのサイトにクロスサイトで渡さないようにしなければなりません。
たとえば、あるサイトがユーザ識別子をファーストパーティセットに登録し、その識別子を別のサイトから読めるようにすることができるかもしれません。
また、ファーストパーティセットはオンデマンドで発見・検証されるため、どのサイトを訪問したかの情報が漏洩する可能性があります。

これらの攻撃への対策は、ファーストパーティセットはファーストパーティに限定することです。
現在のセット以外のファーストパーティセット情報を読み書きすることはできません。

また認証を使用せずにマニフェストを取得するため、検証時の漏洩も防ぐことができます。

最後に、ユーザがCookieをクリアした場合など、あるファーストパーティの他の状態がクリアされたときにはファーストパーティセットの情報も必ずクリアします。

Service workers

ServiceWorkerはファーストパーティセットを複雑にします。
ServiceWorkerからのネットワークリクエスト、サブリソースの取得など、ServiceWorkerにおいてファーストパーティセットをどのように取り扱うか決める必要があります。

ファーストパーティのオーナーが変更になると、ServiceWorkerはすべてクリアされます。
すなわち、ServiceWorkerはドキュメント同様、特定のファーストパーティセットに限定されます。
ServiceWorkerからのネットワークリクエストは、サブリソースとして動作します。

UI Treatment

ファーストパーティセットの透明性をユーザに提供するため、ブラウザはファーストパーティセットのオーナーとメンバーの情報をUIに表示することができます。
ChromeであればOrigin/Page Info Bubbleが考えられます。
この位置は調べたいユーザには必要な情報を与える一方、情報を必要としないユーザに対しては邪魔になりません。
しかし、各ブラウザはそれぞれのUIパターンに基づいて異なる位置に表示することができます。

ファーストパーティセットは、サイトごとのコントロールをeTLD+1単位ではなく、ファーストパーティセット単位でグループ化する機会をブラウザに与えます。

Alternative designs

Origins instead of registrable domains

ファーストパーティセットはオリジンの集合ですが、Registrable Domain(ドメインから.comや.co.jpなどを除いた部分)で指定されており、Public Suffix Listに依存しています。
これは提案されている様々なプライバシーモデルやCookieの取り扱いと一致していますが、Web上のセキュリティ境界は、Registrable Domainではなくオリジンです。

代替として、かわりにオリジンによってファーストパーティセットの直接指定が考えられます。
このモデルでは、全てのhttpsオリジンがファーストパーティセットのオーナーになる可能性があります。

既存の動作と互換性を保つために、Registrable Domainを各オリジンのデフォルトのファーストパーティセットとして扱います。
たとえばデフォルトではhttps://foo.example.comhttps://bar.example.comhttps://example.com:444は全てhttps://example.comの所有するセットです。
ファーストパーティセットを明示的に指定することで、このデフォルトのセットを上書きすることができます。

これにより、Public Suffix Listへの依存を減らすことができ、様々な問題が緩和されます。
たとえば大学が学生に任意のサブドメインhttps://foo.university.exampleを作ることを許可しておきながら、Public Suffix Listにuniversity.exampleを登録していなかった場合などです。
オリジン指定のファーストパーティセットがあれば、個々のオリジンをデフォルトのセットから切り離すことができ、Cookieのようなオリジンに基づかない機能のセキュリティ問題を回避することができます。
なお、Cookieの__Host-プレフィックスでもこの問題に対処することは可能です。

Prior Art

・Firefoxのentity list
draft-sullivan-dbound-problem-statement-02
・John WilanderによるSingle Trust and Same-Origin Policy v2およびaffiliated domains

感想

広告屋「このファイルを/.well-known/first-party-setに置けばこれまでどおりトラッキング広告出せるよ!」
クライアント「おk設置した!」

サードパーティーCookieでは?

悪用されたら対策するとか言ってるけど、悪用されたら対策するってことは対策されるまでは悪用できるってことですよ。

そしてUAポリシーを固めすぎると誰も使えない役立たずな機能になるし、緩めたら悪用の温床です。
しかも最初は使えたとしても、Googleの気分次第でいつ境界を禁じられたりするかわかったものじゃありませんからね。
ブラウザベンダと直接コンタクトできる大手以外はFirst-Party Setsをまともに制御して運用することは難しいでしょう。

ちなみにMozillaはFirst-Party Setsをharmfulであると評価しており、現在の仕様でFirefoxに実装される可能性はまずありません。
Firefoxですら導入しないということはSafariやVivaldiやBraveには余計に導入されないということであり、First-Party SetsはいつものようにChrome(+もしかしたらEdge)の独自仕様になることでしょう。

19
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
19
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?