PWA sebagai Pengendali URL

Izinkan PWA yang diinstal menangani URL untuk pengalaman yang lebih terintegrasi.

Apa yang dimaksud dengan PWA sebagai Pengendali URL?

Bayangkan Anda sedang melakukan chat dengan teman menggunakan aplikasi pesan instan seperti Message di macOS dan Anda sedang membicarakan musik. Selanjutnya, bayangkan Anda berdua telah menginstal PWA music.example.com di perangkat Anda. Jika ingin membagikan lagu favorit kepada teman untuk dinikmati, Anda dapat mengirim deep link seperti https://music.example.com/rick-astley/never-gonna-give-you-up kepada mereka. Karena link ini cukup panjang, developer music.example.com mungkin telah memutuskan untuk menambahkan link singkat tambahan ke setiap jalur, seperti, misalnya, https://🎵.example.com/r-a/n-g-g-y-u.

PWA sebagai Pengendali URL memungkinkan aplikasi seperti music.example.com mendaftarkan dirinya sebagai pengendali URL untuk URL yang cocok dengan pola seperti https://music.example.com, https://*.music.example.com, atau https://🎵.example.com, sehingga link dari luar PWA, misalnya, dari aplikasi pesan instan atau klien email, terbuka di PWA yang diinstal, bukan di tab browser.

PWA sebagai Pengendali URL terdiri dari dua tambahan:

  1. Anggota manifes aplikasi web "url_handlers".
  2. Format file web-app-origin-association untuk memvalidasi pengaitan URL dalam dan di luar cakupan.

Kasus penggunaan yang disarankan untuk PWA sebagai Pengendali URL

Contoh situs yang dapat menggunakan API ini meliputi:

  • Situs streaming musik atau video sehingga link lagu atau link playlist terbuka di pengalaman pemutar aplikasi.
  • Pembaca berita atau RSS sehingga situs yang diikuti atau di-subscribe akan terbuka dalam mode pembaca aplikasi.

Cara menggunakan PWA sebagai Pengendali URL

Mengaktifkan melalui about://flags

Untuk bereksperimen dengan PWA sebagai Pengendali URL secara lokal, tanpa token uji coba origin, aktifkan tanda #enable-desktop-pwas-url-handling di about://flags.

Anggota manifes aplikasi web "url_handlers"

Untuk mengaitkan PWA yang diinstal dengan pola URL, pola ini harus ditentukan dalam manifes aplikasi web. Hal ini terjadi melalui anggota "url_handlers". Fungsi ini menerima array objek dengan properti origin, yang merupakan string wajib yang merupakan pola untuk mencocokkan asal. Pola ini diizinkan untuk memiliki awalan karakter pengganti (*) guna menyertakan beberapa subdomain (seperti https://*.example.com). URL yang cocok dengan origin ini dapat ditangani oleh aplikasi web ini. Skema ini selalu diasumsikan sebagai https://, tetapi perlu disebutkan secara eksplisit.

Cuplikan manifes aplikasi web di bawah menunjukkan cara contoh PWA musik dari paragraf pengantar dapat menyiapkannya. Entri kedua dengan karakter pengganti ("https://*.music.example.com") memastikan aplikasi juga diaktifkan untuk https://www.music.example.com atau potensi contoh lain seperti https://marketing-activity.music.example.com.

{
  "url_handlers": [
    {
      "origin": "https://music.example.com"
    },
    {
      "origin": "https://*.music.example.com"
    },
    {
      "origin": "https://🎵.example.com"
    }
  ]
}

File web-app-origin-association

Karena PWA berada di origin (music.example.com) yang berbeda dengan beberapa URL yang perlu ditangani (misalnya, https://🎵.example.com), aplikasi harus memverifikasi kepemilikan asal lain ini. Hal ini terjadi dalam file web-app-origin-association yang dihosting di origin lain.

File ini harus berisi JSON yang valid. Struktur tingkat teratas adalah objek, dengan anggota bernama "web_apps". Anggota ini adalah array objek dan setiap objek mewakili entri untuk aplikasi web unik. Setiap objek berisi:

Kolom Deskripsi Jenis Default
"manifest" (Wajib diisi) String URL manifes aplikasi web PWA terkait string T/A
"details" (Opsional) Objek yang berisi array pola URL yang disertakan dan dikecualikan object T/A

Setiap objek "details" berisi:

Kolom Deskripsi Jenis Default
"paths" (Opsional) Array string jalur yang diizinkan string[] []
"exclude_paths" (Opsional) Array string jalur yang tidak diizinkan string[] []

Contoh file web-app-origin-association untuk contoh PWA musik dari atas diberikan di bawah. URL ini akan dihosting di origin 🎵.example.com dan membuat pengaitan dengan PWA music.example.com, yang diidentifikasi oleh URL manifes aplikasi web-nya.

{
  "web_apps": [
    {
      "manifest": "https://music.example.com/manifest.json",
      "details": {
        "paths": ["/*"],
        "exclude_paths": ["/internal/*"]
      }
    }
  ]
}

Kapan URL cocok?

PWA cocok dengan URL untuk penanganan jika kedua kondisi berikut terpenuhi:

  • URL cocok dengan salah satu string asal di "url_handlers".
  • Browser dapat memvalidasi melalui file web-app-origin-association masing-masing bahwa setiap asal setuju untuk mengizinkan aplikasi ini menangani URL tersebut.

Terkait penemuan file web-app-origin-association

Agar browser dapat menemukan file web-app-origin-association, developer harus menempatkan file web-app-origin-association di folder /.well-known/ di root aplikasi. Agar berfungsi, nama file harus persis web-app-origin-association.

Demo

Untuk menguji PWA sebagai Pengendali URL, pastikan untuk menetapkan flag browser seperti yang diuraikan di atas, lalu instal PWA di https://mandymsft.github.io/pwa/. Dengan melihat manifes aplikasi web, Anda dapat melihat bahwa aplikasi tersebut menangani URL dengan pola URL berikut: https://mandymsft.github.io dan https://luhuangmsft.github.io. Karena yang terakhir berada di origin yang berbeda (luhuangmsft.github.io) dari PWA, PWA di mandymsft.github.io perlu membuktikan kepemilikan, yang dilakukan melalui file web-app-origin-association yang dihosting di https://luhuangmsft.github.io/.well-known/web-app-origin-association.

Untuk menguji apakah fitur ini benar-benar berfungsi, kirim pesan pengujian kepada diri Anda sendiri menggunakan aplikasi pesan instan pilihan Anda atau email yang dilihat di program email yang tidak berbasis web seperti Mail di macOS. Email atau pesan teks harus berisi salah satu link https://mandymsft.github.io atau https://luhuangmsft.github.io. Keduanya akan terbuka di PWA yang diinstal.

Aplikasi pesan instan Skype Windows di samping PWA demo yang diinstal, yang dibuka dalam mode mandiri setelah mengklik link yang ditanganinya dalam pesan chat Skype.

Keamanan dan izin

Tim Chromium mendesain dan menerapkan PWA sebagai Pengendali URL menggunakan prinsip inti yang ditentukan dalam Mengontrol Akses ke Fitur Platform Web yang Efisien, termasuk kontrol pengguna, transparansi, dan ergonomi.

Kontrol pengguna

Jika lebih dari satu PWA terdaftar sebagai pengendali URL untuk pola URL tertentu, pengguna akan diminta untuk memilih PWA yang ingin mereka gunakan untuk menangani pola tersebut—jika ada. Navigasi yang dimulai di tab browser tidak ditangani oleh proposal ini, yang secara eksplisit ditujukan untuk navigasi yang dimulai di luar browser.

Transparansi

Jika validasi pengaitan yang diperlukan tidak dapat berhasil diselesaikan selama penginstalan PWA karena alasan apa pun, browser tidak akan mendaftarkan aplikasi sebagai pengendali URL aktif untuk URL yang terpengaruh. Pengendali URL, jika tidak diterapkan dengan benar, dapat digunakan untuk membajak traffic untuk situs. Itulah sebabnya mekanisme pengaitan aplikasi adalah bagian penting dari skema ini.

Aplikasi khusus platform sudah dapat menggunakan API sistem operasi untuk menghitung aplikasi yang diinstal di sistem pengguna. Misalnya, aplikasi di Windows dapat menggunakan FindAppUriHandlersAsync API untuk menghitung pengendali URL. Jika PWA terdaftar sebagai pengendali URL tingkat OS di Windows, kehadirannya akan terlihat oleh aplikasi lain.

Persistensi izin

Origin dapat mengubah pengaitan dengan PWA kapan saja. Browser akan secara rutin mencoba memvalidasi ulang pengaitan aplikasi web yang diinstal. Jika pendaftaran pengendali URL gagal memvalidasi ulang karena data pengaitan telah berubah atau tidak lagi tersedia, browser akan menghapus pendaftaran.

Masukan

Tim Chromium ingin mengetahui pengalaman Anda dengan PWA sebagai Pengendali URL.

Ceritakan kepada kami tentang desain API

Apakah ada sesuatu tentang API yang tidak berfungsi seperti yang Anda harapkan? Atau apakah ada metode atau properti yang tidak ada yang Anda perlukan untuk menerapkan ide Anda? Ada pertanyaan atau komentar tentang model keamanan? Ajukan masalah spesifikasi di repo GitHub yang sesuai, atau tambahkan pendapat Anda ke masalah yang ada.

Melaporkan masalah terkait penerapan

Apakah Anda menemukan bug pada penerapan Chromium? Atau apakah implementasinya berbeda dengan spesifikasi? Laporkan bug di new.crbug.com. Pastikan untuk menyertakan detail sebanyak mungkin, petunjuk sederhana untuk mereproduksi, dan masukkan UI>Browser>WebAppInstalls di kotak Components. Glitch sangat cocok untuk membagikan rekaman ulang yang cepat dan mudah.

Menampilkan dukungan untuk API

Apakah Anda berencana menggunakan PWA sebagai Pengendali URL? Dukungan publik Anda membantu tim Chromium memprioritaskan fitur dan menunjukkan kepada vendor browser lain betapa pentingnya mendukungnya.

Kirim tweet ke @ChromiumDev menggunakan hashtag #URLHandlers dan beri tahu kami tempat dan cara Anda menggunakannya.

Link bermanfaat

Ucapan terima kasih

PWA sebagai Pengendali URL ditentukan dan diimplementasikan oleh Lu Huang dan Mandy Chen dari tim Microsoft Edge. Artikel ini ditinjau oleh Joe Medley. Gambar hero oleh Bryson Hammer di Unsplash.