Menangani Permintaan Tindakan

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

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, 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 apa 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 dianjurkan untuk memeriksa:

Agen Pengguna untuk semua permintaan Tindakan 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 Tindakan. Misalnya, ConfirmAction memiliki properti confirmed.

Langkah 3: Mengembalikan Kode Respons

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

Kode Respons Perlakuan
400 (Permintaan Buruk) Google akan gagal melakukan tindakan tersebut.
401 (Tidak Sah) Google akan gagal melakukan tindakan tersebut.
404 (Tidak Ditemukan) Google akan gagal melakukan tindakan tersebut.
408 (Waktu 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