PWA の URL プロトコル ハンドラ登録

インストール済みの PWA に特定のプロトコルを使用するリンクを処理させ、より統合されたエクスペリエンスを実現します。

Uniform Resource Identifier(URI)は、抽象リソースまたは物理リソースを識別するコンパクトな文字列です。各 URI は、そのスキーム内で識別子を割り当てる仕様を参照するスキーム名で始まります。したがって、URI 構文は、各スキームの仕様でそのスキームを使用する識別子の構文とセマンティクスをさらに制限できる、連携型の拡張可能な命名システムです。スキームはプロトコルとも呼ばれます。スキームの例を以下に示します。

tel:+1-816-555-1212
mailto:Jane.Doe@example.com
news:comp.infosystems.www.servers.unix
https://web.dev/

Uniform Resource Locator(URL)という用語は、リソースを識別するだけでなく、その主要なアクセス メカニズム(ネットワーク ロケーションなど)を記述してリソースを特定する手段を提供する URI のサブセットを指します。

registerProtocolHandler() メソッドの背景

セキュア コンテンツ専用の Navigator メソッド registerProtocolHandler() を使用すると、サイトは特定の URL スキームを開く機能や処理機能を登録できます。したがって、サイトは navigator.registerProtocolHandler(scheme, url) のようにメソッドを呼び出す必要があります。2 つのパラメータは次のように定義されています。

  • scheme: サイトが処理するプロトコルを含む文字列。
  • url: ハンドラの URL を含む文字列。この URL には、処理されるエスケープされた URL に置き換えられるプレースホルダとして %s を含める必要があります。

スキームは、セーフリストに登録されているスキームmailtobitcoinmagnet など)のいずれかであるか、web+ で始まり、web+ 接頭辞の後に 1 つ以上の小文字の ASCII 文字が続く必要があります(例: web+coffee)。

これを明確にするために、フローの実例を次に示します。

  1. ユーザーが https://coffeeshop.example.com/ のサイトにアクセスすると、navigator.registerProtocolHandler('web+coffee', 'coffee?type=%s') という呼び出しが行われます。
  2. 後日、ユーザーが https://randomsite.example.com/ にアクセス中に、<a href="web+coffee:latte-macchiato">All about latte macchiato</a> などのリンクをクリックします。
  3. これにより、ブラウザが次の URL(https://coffeeshop.example.com/coffee?type=web%2Bcoffee%3A%2F%2Flatte-macchiato)に移動します。検索文字列を URL デコードすると、?type=web+coffee://latte-macchiato と読み取られます。

プロトコル処理の概要

現在の PWA の URL プロトコル ハンドラの登録メカニズムは、マニフェストを通じて PWA のインストールの一部としてプロトコル ハンドラの登録を提供することを目的としています。PWA をプロトコル ハンドラとして登録すると、ユーザーがブラウザまたはプラットフォーム固有のアプリから mailtobitcoinweb+music などの特定のスキーマを含むハイパーリンクをクリックすると、登録された PWA が開き、URL を受信します。提案されているマニフェストベースの登録と従来の registerProtocolHandler() は、実質的には非常に類似した役割を果たしますが、補完的なユーザー エクスペリエンスの可能性も残されています。

  • 類似点には、登録が許可されるスキームのリスト、パラメータの名前と形式に関する要件などがあります。
  • マニフェストベースの登録の違いは微妙ですが、PWA ユーザーのエクスペリエンスを向上させるのに役立つ場合があります。たとえば、マニフェストベースの PWA 登録では、ユーザーが開始した PWA のインストール以外に、追加のユーザー操作が必要ない場合もあります。

ユースケース

  • ワード プロセッシング PWA で、ドキュメント内のユーザーが web+presentations://deck2378465 のようなプレゼンテーションへのリンクを見つけます。ユーザーがリンクをクリックすると、プレゼンテーション PWA が正しいスコープで自動的に開き、スライド デッキが表示されます。
  • プラットフォーム固有のチャットアプリでは、チャット メッセージ内のユーザーに magnet URL へのリンクが送信されます。リンクをクリックすると、インストールされているトレント PWA が起動してダウンロードが開始されます。
  • ユーザーが音楽ストリーミング PWA をインストールしている。web+music://songid=1234&time=0:13 などの曲へのリンクを友人と共有し、ユーザーがそのリンクをクリックすると、音楽ストリーミング PWA がスタンドアロン ウィンドウで自動的に起動します。

PWA の URL プロトコル ハンドラの登録を使用する方法

URL プロトコル ハンドラの登録用の API は、navigator.registerProtocolHandler() をモデルにしています。ただし、今回は、ウェブアプリ マニフェスト内の "protocol_handlers" という新しいプロパティで、宣言的に渡されます。このプロパティは、2 つの必須キー "protocol""url" を含むオブジェクトの配列を受け取ります。次のコード スニペットは、web+teaweb+coffee を登録する方法を示しています。値は、エスケープされた URL に必要な %s プレースホルダを含むハンドラの URL を含む文字列です。

{
  "protocol_handlers": [
    {
      "protocol": "web+tea",
      "url": "/tea?type=%s"
    },
    {
      "protocol": "web+coffee",
      "url": "/coffee?type=%s"
    }
  ]
}

同じプロトコルに登録する複数のアプリ

複数のアプリが同じスキーム(mailto プロトコルなど)のハンドラとして登録されている場合、オペレーティング システムはユーザーに選択ツールを表示し、登録されているハンドラの中から使用するハンドラを選択できるようにします。

同じアプリが複数のプロトコルに登録されている

上のサンプルコードに示すように、同じアプリを複数のプロトコルに登録できます。

アプリの更新とハンドラの登録

ハンドラの登録は、アプリが提供する最新のマニフェスト バージョンと同期されます。2 つのケースがあります。

  • 新しいハンドラを追加するアップデートは、ハンドラの登録をトリガーします(アプリのインストールとは別)。
  • ハンドラを削除するアップデートは、ハンドラの登録解除をトリガーします(アプリのアンインストールとは別)。

DevTools でのプロトコル ハンドラのデバッグ

[Application] > [Manifest] ペインで [Protocol Handlers] セクションに移動します。使用可能なすべてのプロトコルを表示してテストできます。

たとえば、こちらのデモ PWA をインストールします。[プロトコル ハンドラ] セクションで「americano」と入力し、[プロトコルをテスト] をクリックして PWA でコーヒー ページを開きます。

[マニフェスト] ペインのプロトコル ハンドラ

デモ

PWA の URL プロトコル ハンドラの登録のデモは Glitch でご覧いただけます。

  1. https://protocol-handler.glitch.me/ にアクセスして PWA をインストールし、インストール後にアプリを再読み込みします。これで、ブラウザはオペレーティング システムに web+coffee プロトコルのハンドラとして PWA を登録しました。
  2. インストールされた PWA ウィンドウで、リンク https://protocol-handler-link.glitch.me/ をクリックします。3 つのリンクを含む新しいブラウザタブが開きます。1 つ目または 2 つ目(ラテ マキアートまたはアメリカーノ)をクリックします。ブラウザにプロンプトが表示され、アプリを web+coffee プロトコルのプロトコル ハンドラとして使用してもよいかどうかを尋ねられます。同意すると、PWA が開き、選択したコーヒーが表示されます。
  3. navigator.registerProtocolHandler() を使用する従来のフローと比較するには、PWA の [プロトコル ハンドラを登録] ボタンをクリックします。次に、ブラウザのタブで 3 番目のリンク(chai)をクリックします。同様にプロンプトが表示されますが、ブラウザ ウィンドウではなくタブで PWA が開きます。
  4. <a href="web+coffee://americano">Americano</a> などのリンクを使用して、Windows の Skype などのプラットフォーム固有のアプリで自分にメッセージを送信し、クリックします。同様に、インストールされている PWA が開きます。

左側にリンクを含むブラウザタブ、右側にスタンドアロンの PWA ウィンドウがある URL プロトコル ハンドラのデモ。

セキュリティ上の考慮事項

PWA のインストールではコンテキストの安全性が求められるため、プロトコル処理はこの制約を継承します。登録されたプロトコル ハンドラのリストは、ウェブに公開されないため、フィンガープリント ベクトルとして使用できません。

ユーザーが開始していないナビゲーションの試行

ユーザーが開始したのではなく、プログラムによって開始されたナビゲーションの試行では、アプリが開かない場合があります。カスタム プロトコル URL は、最上位のブラウジング コンテキストでのみ使用できます。iframe の URL として使用することはできません。

プロトコルの許可リスト

registerProtocolHandler() と同様に、アプリが登録して処理できるプロトコルの許可リストがあります。

プロトコルが呼び出されたために PWA を初めて起動すると、ユーザーに権限ダイアログが表示されます。このダイアログには、アプリの名前とアプリの提供元が表示され、プロトコルからのリンクをアプリが処理できるかどうかをユーザーに尋ねます。ユーザーが権限ダイアログを拒否すると、登録されたプロトコル ハンドラはオペレーティング システムによって無視されます。プロトコル ハンドラの登録を解除するには、ユーザーがそのハンドラを登録した PWA をアンインストールする必要があります。また、ユーザーが [選択内容を記憶] を選択し、[許可しない] を選択した場合も、ブラウザはプロトコル ハンドラを登録解除します。

フィードバック

Chromium チームは、PWA の URL プロトコル ハンドラの登録に関するご意見をお聞かせいただきたいと考えています。

API 設計について

API が想定どおりに動作しない点はありますか?または、アイデアを実装するために必要なメソッドやプロパティが不足している場合はどうすればよいですか?セキュリティ モデルに関するご質問やご意見がございましたら、対応する GitHub リポジトリで仕様に関する問題を報告するか、既存の問題にコメントを追加します。

実装に関する問題を報告する

Chromium の実装にバグが見つかりましたか?それとも、実装が仕様と異なるのでしょうか?new.crbug.com でバグを報告します。できるだけ詳細な情報を含め、再現手順を簡単に説明してください。[コンポーネント] ボックスに UI>Browser>WebAppInstalls を入力します。Glitch は、簡単な再現手順をすばやく共有するのに適しています。

API のサポートを表示する

PWA の URL プロトコル ハンドラの登録を使用する予定はありますか?一般公開でサポートすると、Chromium チームが機能の優先順位を決めるのに役立ち、他のブラウザ ベンダーにその機能のサポートがどれほど重要であるかを示します。

WICG Discourse スレッドで、どのように使用する予定かをお知らせください。ハッシュタグ #ProtocolHandler を使用して @ChromiumDev にツイートを送信し、どこでどのように使用しているかをお知らせください。

謝辞

PWA の URL プロトコル ハンドラの登録は、Microsoft Edge チームの Fabio RochaDiego GonzálezConnor MoodySamuel Tang によって実装および指定されました。この記事は、Joe Medley と Fabio Rocha が確認しました。UnsplashJJ Ying によるヒーロー画像。