Menangani Permintaan Tindakan

Seperti yang dijelaskan dalam Mendeklarasikan Tindakan, saat pengguna berinteraksi dengan Tindakan dalam Aplikasi, Google akan mengirimkan permintaan HTTP ke URL yang dideklarasikan dalam tindakan tersebut.

Contoh berikut menambahkan tombol ConfirmAction ke email tentang laporan pengeluaran:

JSON-LD

<script type="application/ld+json">
{
  "@context": "http://schema.org",
  "@type": "EmailMessage",
  "potentialAction": {
    "@type": "ConfirmAction",
    "name": "Approve Expense",
    "handler": {
      "@type": "HttpActionHandler",
      "url": "https://myexpenses.com/approve?expenseId=abc123"
    }
  },
  "description": "Approval request for John's $10.13 expense for office supplies"
}
</script>

Microdata

<div itemscope itemtype="http://schema.org/EmailMessage">
  <div itemprop="potentialAction" itemscope itemtype="http://schema.org/ConfirmAction">
    <meta itemprop="name" content="Approve Expense"/>
    <div itemprop="handler" itemscope itemtype="http://schema.org/HttpActionHandler">
      <link itemprop="url" href="https://myexpenses.com/approve?expenseId=abc123"/>
    </div>
  </div>
  <meta itemprop="description" content="Approval request for John's $10.13 expense for office supplies"/>
</div>

Saat pengguna mengklik tombol tersebut, permintaan HTTP akan dikeluarkan dari Google ke layanan Anda, yang mencatat konfirmasi. Layanan Anda menerima permintaan HTTP berikut dari Google:

POST /approve?expenseId=abc123 HTTP/1.1
Host: your-domain.com
Authorization: Bearer AbCdEf123456
Content-Type: application/x-www-form-urlencoded
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/1.0 (KHTML, like Gecko; Gmail Actions)

confirmed=Approved

Bagian selanjutnya dari halaman ini menjelaskan hal yang perlu dilakukan layanan di https://your-domain.com/approve?expenseId=abc123 untuk menangani tindakan dengan benar. Hal ini mencakup:

  • Memverifikasi permintaan
  • Memproses payload
  • Menampilkan kode respons

Langkah 1: Verifikasi Permintaan

Layanan di https://your-domain.com/approve?expenseId=abc123 sebaiknya memeriksa:

Agen Pengguna untuk semua permintaan Action adalah Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/1.0 (KHTML, like Gecko; Gmail Actions).

Jika semua pemeriksaan lulus, layanan dapat melanjutkan ke langkah berikutnya.

Langkah 2: Proses Tindakan

Layanan harus memproses tindakan seperti yang ditentukan dalam parameter URL serta informasi tambahan yang dikumpulkan dari pengguna.

Informasi tambahan dari pengguna berada di isi permintaan, dan dienkode menggunakan encoding x-www-form-urlecoded. Informasi ditetapkan dalam properti yang namanya sesuai dengan properti Action. Misalnya, ConfirmAction memiliki properti confirmed.

Langkah 3: Menampilkan Kode Respons

Setelah berhasil memproses dan mencatat tindakan, layanan akan menampilkan kode respons 200 (OK). Kode respons berikut dapat digunakan dalam situasi error:

Kode Respons Perlakuan
400 (Bad Request) Google akan menggagalkan tindakan tersebut.
401 (Tidak sah) Google akan menggagalkan tindakan tersebut.
404 (Tidak Ditemukan) Google akan menggagalkan tindakan tersebut.
408 (Waktu Tunggu Permintaan Habis) Google akan mencoba lagi nanti.

Jika terjadi kegagalan permanen, Google akan memberi tahu pengguna bahwa tindakan telah gagal dan pengguna harus mengikuti petunjuk alternatif di dalam email.

Bacaan Lebih Lanjut