Untuk menggunakan pemenuhan di sistem produksi, Anda harus menerapkan dan men-deploy layanan webhook. Untuk menangani pemenuhan, layanan webhook Anda harus menerima permintaan JSON dan menampilkan respons JSON seperti yang ditentukan dalam panduan ini. Alur pemrosesan mendetail untuk pemenuhan dan webhook dijelaskan dalam dokumen ringkasan pemenuhan.
Persyaratan layanan webhook
Persyaratan berikut harus dipenuhi oleh layanan webhook Anda:
- Server harus menangani permintaan HTTPS. HTTP tidak didukung. Jika Anda menghosting layanan webhook di Google Cloud Platform menggunakan solusi Compute atau Serverless Computing, lihat dokumentasi produk untuk penayangan dengan HTTPS. Untuk opsi hosting lainnya, lihat Mendapatkan sertifikat SSL untuk domain Anda.
- URL-nya untuk permintaan harus dapat diakses secara publik.
- Aplikasi harus menangani permintaan POST dengan isi
WebhookRequest
JSON. - Aplikasi harus merespons permintaan
WebhookRequest
dengan isiWebhookResponse
JSON.
Autentikasi
Penting untuk mengamankan layanan webhook Anda, sehingga hanya Anda atau agen Dialogflow Anda yang diberi otorisasi untuk membuat permintaan. Dialogflow mendukung mekanisme berikut untuk autentikasi:
Istilah | Definisi |
---|---|
Nama pengguna dan sandi login | Untuk setelan webhook, Anda dapat menentukan nilai nama pengguna dan sandi login opsional. Jika disediakan, Dialogflow akan menambahkan header HTTP otorisasi ke permintaan webhook. Header ini memiliki bentuk: "authorization: Basic <base 64 encoding of the string username:password>" . |
Header autentikasi | Untuk setelan webhook, Anda dapat menentukan pasangan nilai kunci header HTTP opsional. Jika disediakan, Dialogflow akan menambahkan header HTTP ini ke permintaan webhook. Umumnya, satu pasangan disediakan dengan kunci authorization . |
Autentikasi bawaan Cloud Functions | Anda dapat menggunakan autentikasi bawaan saat menggunakan Cloud Functions. Untuk menggunakan jenis autentikasi ini, jangan berikan nama pengguna login, sandi login, atau header otorisasi. Jika Anda memberikan salah satu kolom ini, kolom tersebut akan digunakan untuk autentikasi, bukan autentikasi bawaan. |
Token identitas layanan | Anda dapat menggunakan token identitas layanan untuk autentikasi. Jika Anda tidak memberikan nama pengguna login, sandi login, atau header dengan kunci authorization , Dialogflow akan otomatis mengasumsikan bahwa token identitas layanan harus digunakan dan menambahkan header HTTP otorisasi ke permintaan webhook. Header ini memiliki bentuk: "authorization: Bearer <identity token>" . |
Autentikasi TLS bersama | Lihat dokumentasi Autentikasi TLS bersama. |
Permintaan webhook
Saat maksud yang dikonfigurasi untuk pemenuhan cocok, Dialogflow mengirim permintaan webhook POST HTTPS ke layanan webhook Anda. Isi permintaan ini adalah objek JSON dengan informasi tentang maksud yang cocok.
Selain kueri pengguna akhir, banyak integrasi juga mengirimkan beberapa informasi tentang pengguna akhir. Misalnya, ID untuk mengidentifikasi pengguna secara unik. Informasi ini dapat diakses melalui kolom originalDetectIntentRequest
dalam permintaan webhook, yang akan berisi informasi yang dikirim dari
platform integrasi.
Lihat dokumentasi referensi
WebhookRequest
untuk mengetahui detailnya.
Berikut adalah contoh permintaan:
{ "responseId": "response-id", "session": "projects/project-id/agent/sessions/session-id", "queryResult": { "queryText": "End-user expression", "parameters": { "param-name": "param-value" }, "allRequiredParamsPresent": true, "fulfillmentText": "Response configured for matched intent", "fulfillmentMessages": [ { "text": { "text": [ "Response configured for matched intent" ] } } ], "outputContexts": [ { "name": "projects/project-id/agent/sessions/session-id/contexts/context-name", "lifespanCount": 5, "parameters": { "param-name": "param-value" } } ], "intent": { "name": "projects/project-id/agent/intents/intent-id", "displayName": "matched-intent-name" }, "intentDetectionConfidence": 1, "diagnosticInfo": {}, "languageCode": "en" }, "originalDetectIntentRequest": {} }
Respons webhook
Setelah menerima permintaan webhook, webhook Anda harus mengirim respons webhook. Isi respons ini adalah objek JSON dengan informasi berikut:
- Respons yang ditampilkan Dialogflow kepada pengguna akhir.
- Pembaruan pada konteks yang aktif untuk percakapan.
- Acara tindak lanjut untuk memicu kecocokan intent.
- Payload kustom yang akan dikirim ke integrasi atau klien deteksi maksud
Batasan berikut berlaku untuk respons Anda:
- Respons harus terjadi dalam waktu 10 detik untuk aplikasi Asisten Google atau 5 detik untuk semua aplikasi lainnya, jika tidak, permintaan akan kehabisan waktu.
- Ukuran respons harus kurang dari atau sama dengan 64 KiB.
Lihat dokumentasi referensi
WebhookResponse
untuk mengetahui detailnya.
Respons teks
Contoh untuk respons teks:
{ "fulfillmentMessages": [ { "text": { "text": [ "Text response from webhook" ] } } ] }
Respons kartu
Contoh untuk respons kartu:
{ "fulfillmentMessages": [ { "card": { "title": "card title", "subtitle": "card text", "imageUri": "https://example.com/images/example.png", "buttons": [ { "text": "button text", "postback": "https://example.com/path/for/end-user/to/follow" } ] } } ] }
Respons Asisten Google
Contoh untuk respons Asisten Google:
{ "payload": { "google": { "expectUserResponse": true, "richResponse": { "items": [ { "simpleResponse": { "textToSpeech": "this is a Google Assistant response" } } ] } } } }
Konteks
Contoh yang menetapkan konteks output:
{ "fulfillmentMessages": [ { "text": { "text": [ "Text response from webhook" ] } } ], "outputContexts": [ { "name": "projects/project-id/agent/sessions/session-id/contexts/context-name", "lifespanCount": 5, "parameters": { "param-name": "param-value" } } ] }
Acara
Contoh yang memanggil peristiwa kustom:
{ "followupEventInput": { "name": "event-name", "languageCode": "en-US", "parameters": { "param-name": "param-value" } } }
Entitas sesi
Contoh yang menetapkan entity sesi:
{ "fulfillmentMessages": [ { "text": { "text": [ "Choose apple or orange" ] } } ], "sessionEntityTypes":[ { "name":"projects/project-id/agent/sessions/session-id/entityTypes/fruit", "entities":[ { "value":"APPLE_KEY", "synonyms":[ "apple", "green apple", "crabapple" ] }, { "value":"ORANGE_KEY", "synonyms":[ "orange" ] } ], "entityOverrideMode":"ENTITY_OVERRIDE_MODE_OVERRIDE" } ] }
Payload kustom
Contoh yang menyediakan payload kustom:
{ "fulfillmentMessages": [ { "payload": { "facebook": { // for Facebook Messenger integration "attachment": { "type": "", "payload": {} } }, "slack": { // for Slack integration "text": "", "attachments": [] }, "richContent": [ // for Dialogflow Messenger integration [ { "type": "image", "rawUrl": "https://example.com/images/logo.png", "accessibilityText": "Example logo" } ] ], // custom integration payload here } } ] }
Mengaktifkan dan mengelola pemenuhan
Untuk mengaktifkan dan mengelola pemenuhan untuk agen Anda dengan konsol:
- Buka konsol Dialogflow ES.
- Pilih agen.
- Pilih Pemenuhan di menu sidebar kiri.
- Alihkan kolom Webhook ke Enabled.
- Berikan detail untuk layanan webhook Anda dalam formulir. Jika webhook Anda tidak memerlukan autentikasi, biarkan kolom autentikasi kosong.
- Klik Simpan di bagian bawah halaman.
Untuk mengaktifkan dan mengelola pemenuhan untuk agen Anda dengan API, lihat referensi agen.
Metode getFulfillment
dan updateFulfillment
dapat digunakan untuk mengelola setelan pemenuhan.
Untuk mengaktifkan pemenuhan intent dengan konsol:
- Pilih Maksud di menu sidebar kiri.
- Pilih maksud.
- Scroll ke bawah ke bagian Pemenuhan.
- Aktifkan Enable webhook call for this intent.
- Klik Simpan.
Untuk mengaktifkan pemenuhan maksud dengan API, lihat referensi maksud.
Tetapkan kolom webhookState
ke WEBHOOK_STATE_ENABLED
.
Error webhook
Jika layanan webhook Anda mengalami error, layanan tersebut harus menampilkan salah satu kode status HTTP berikut:
400
Bad Request401
Unauthorized403
Terlarang404
Tidak ditemukan500
Kesalahan server503
Service Unavailable
Dalam situasi error berikut, Dialogflow merespons pengguna akhir dengan respons bawaan yang dikonfigurasi untuk intent yang saat ini cocok:
- Waktu tunggu respons terlampaui.
- Kode status error diterima.
- Respons tidak valid.
- Layanan webhook tidak tersedia.
Selain itu, jika kecocokan maksud dipicu oleh
panggilan API deteksi maksud,
kolom status
dalam respons deteksi maksud berisi informasi error webhook. Contoh:
"status": {
"code": 206,
"message": "Webhook call failed. <details of the error...>"
}
Percobaan ulang otomatis
Dialogflow ES mencakup mekanisme internal yang otomatis mencoba lagi jika terjadi error webhook tertentu untuk meningkatkan keandalan. Hanya error non-terminal yang dicoba lagi (misalnya, error waktu tunggu atau koneksi).
Untuk mengurangi kemungkinan panggilan duplikat:
- Tetapkan nilai minimum waktu tunggu webhook yang lebih lama.
- Mendukung idempotensi dalam logika webhook atau menghapus duplikat.
Menggunakan Cloud Functions
Ada beberapa cara untuk menggunakan Cloud Functions untuk fulfillment. Editor inline Dialogflow terintegrasi dengan Cloud Functions. Saat Anda menggunakan editor inline untuk membuat dan mengedit kode webhook, Dialogflow membuat koneksi yang aman ke Cloud Function Anda.
Anda juga memiliki opsi untuk menggunakan Cloud Function yang tidak dibuat oleh editor inline (mungkin karena Anda ingin menggunakan bahasa selain Node.js). Jika Cloud Function berada dalam project yang sama dengan agen Anda, agen Anda dapat memanggil webhook tanpa memerlukan konfigurasi khusus.
Namun, ada dua situasi di mana Anda harus menyiapkan integrasi ini secara manual:
- Akun layanan agen layanan Dialogflow dengan alamat berikut harus ada untuk project agen Anda:
Akun layanan khusus ini dan kunci terkait biasanya dibuat secara otomatis saat Anda membuat agen pertama untuk project. Jika agen Anda dibuat sebelum 10 Mei 2021, Anda mungkin perlu memicu pembuatan akun layanan khusus ini dengan perintah berikut:service-agent-project-number@gcp-sa-dialogflow.iam.gserviceaccount.com
- Buat agen baru untuk project.
- Jalankan perintah berikut:
gcloud beta services identity create --service=dialogflow.googleapis.com --project=agent-project-id
- Jika fungsi webhook Anda berada di project yang berbeda dengan agen, Anda harus memberikan peran IAM Cloud Functions Invoker ke akun layanan Agen Layanan Dialogflow di project fungsi Anda.
Token identitas layanan
Saat memanggil webhook, Dialogflow memberikan
token identitas Google
dengan permintaan.
Webhook apa pun dapat secara opsional memvalidasi token
menggunakan library klien Google atau library open source seperti
github.com/googleapis/google-auth-library-nodejs.
Misalnya, Anda dapat memverifikasi email
token ID sebagai:
service-agent-project-number@gcp-sa-dialogflow.iam.gserviceaccount.com
Sampel
Contoh berikut menunjukkan cara menerima WebhookRequest
dan mengirim WebhookResponse
.
Contoh ini mereferensikan intent yang dibuat di
panduan memulai.
Go
Untuk melakukan autentikasi ke Dialogflow, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
import ( "encoding/json" "fmt" "log" "net/http" ) type intent struct { DisplayName string `json:"displayName"` } type queryResult struct { Intent intent `json:"intent"` } type text struct { Text []string `json:"text"` } type message struct { Text text `json:"text"` } // webhookRequest is used to unmarshal a WebhookRequest JSON object. Note that // not all members need to be defined--just those that you need to process. // As an alternative, you could use the types provided by // the Dialogflow protocol buffers: // https://godoc.org/google.golang.org/genproto/googleapis/cloud/dialogflow/v2#WebhookRequest type webhookRequest struct { Session string `json:"session"` ResponseID string `json:"responseId"` QueryResult queryResult `json:"queryResult"` } // webhookResponse is used to marshal a WebhookResponse JSON object. Note that // not all members need to be defined--just those that you need to process. // As an alternative, you could use the types provided by // the Dialogflow protocol buffers: // https://godoc.org/google.golang.org/genproto/googleapis/cloud/dialogflow/v2#WebhookResponse type webhookResponse struct { FulfillmentMessages []message `json:"fulfillmentMessages"` } // welcome creates a response for the welcome intent. func welcome(request webhookRequest) (webhookResponse, error) { response := webhookResponse{ FulfillmentMessages: []message{ { Text: text{ Text: []string{"Welcome from Dialogflow Go Webhook"}, }, }, }, } return response, nil } // getAgentName creates a response for the get-agent-name intent. func getAgentName(request webhookRequest) (webhookResponse, error) { response := webhookResponse{ FulfillmentMessages: []message{ { Text: text{ Text: []string{"My name is Dialogflow Go Webhook"}, }, }, }, } return response, nil } // handleError handles internal errors. func handleError(w http.ResponseWriter, err error) { w.WriteHeader(http.StatusInternalServerError) fmt.Fprintf(w, "ERROR: %v", err) } // HandleWebhookRequest handles WebhookRequest and sends the WebhookResponse. func HandleWebhookRequest(w http.ResponseWriter, r *http.Request) { var request webhookRequest var response webhookResponse var err error // Read input JSON if err = json.NewDecoder(r.Body).Decode(&request); err != nil { handleError(w, err) return } log.Printf("Request: %+v", request) // Call intent handler switch intent := request.QueryResult.Intent.DisplayName; intent { case "Default Welcome Intent": response, err = welcome(request) case "get-agent-name": response, err = getAgentName(request) default: err = fmt.Errorf("Unknown intent: %s", intent) } if err != nil { handleError(w, err) return } log.Printf("Response: %+v", response) // Send response if err = json.NewEncoder(w).Encode(&response); err != nil { handleError(w, err) return } }
Java
Untuk melakukan autentikasi ke Dialogflow, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Node.js
Untuk melakukan autentikasi ke Dialogflow, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.
Python
Untuk melakukan autentikasi ke Dialogflow, siapkan Kredensial Default Aplikasi. Untuk mengetahui informasi selengkapnya, lihat Menyiapkan autentikasi untuk lingkungan pengembangan lokal.