Business Messages 服務專員支援與
整合 Business Messages 服務專員與其他 Dialogflow 功能 ES 或 Dialogflow CX 請參閱每項產品的說明文件
當使用者傳送訊息至具備 Dialogflow 整合服務的代理程式時,
Business Messages 會將使用者訊息傳送至 Dialogflow,並將 Dialogflow 的
回覆訊息
dialogflowResponse 物件。您可以將代理程式設為
不必對應用程式執行任何動作,系統就會自動將 Dialogflow 的回應傳送給使用者
部分。請參閱「自動回覆」
。
Dialogflow 整合
透過 Business Messages 使用以 Dialogflow 為基礎的自動化功能前, 您必須啟用 Dialogflow 整合
必要條件
如要開始使用,請準備
- Business Messages 代理程式
- 「全球」區域的 Dialogflow 代理程式,根語言為英文 (zh-TW)
如果您沒有 Dialogflow 虛擬服務專員,請建立一個。
Dialogflow ES
如要啟用 Dialogflow ES 整合功能,您需要先備妥以下項目: Dialogflow 代理程式的專案 ID。如要找出專案 ID,
- 前往 Dialogflow 主控台。
- 選取要與 Business Messages 連結的 Dialogflow 虛擬服務專員。
按一下齒輪圖示
 。 。
- 在「Google Project」下方,記下「Project ID」的值。
Dialogflow CX
如要啟用 Dialogflow CX 整合功能,您必須具備以下資料: Dialogflow 虛擬服務專員的專案 ID 和服務專員 ID。如要找出這些 ID,
- 前往 Dialogflow CX 主控台。
- 選取 Dialogflow 專案。
- 在代理程式選取器中,按一下溢位選單
  。 。
- 按一下「複製名稱」。這麼做會將代理程式的全名
 格式如下:
 projects/PROJECT_ID/locations/REGION_ID/agents/AGENT_ID。
- 記下專案 ID 和代理程式 ID 值。
建立整合
- 透過以下網址取得合作夥伴的 Dialogflow 服務帳戶電子郵件 - dialogflowServiceAccountEmail。將 將 PARTNER_ID 替換為您的合作夥伴 ID。- cURL- # This code gets the partner. # Read more: https://developers.google.com/business-communications/business-messages/reference/business-communications/rest/v1/partners/get # Replace the __PARTNER_ID__ # Make sure a service account key file exists at ./service_account_key.json curl -X GET \ "https://businesscommunications.googleapis.com/v1/partners/__PARTNER_ID__" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)" - Node.js- /** * This code snippet gets a partner. * Read more: https://developers.google.com/business-communications/business-messages/reference/business-communications/rest/v1/partners/get * * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js * Business Communications client library. */ /** * Edit the values below: */ const PARTNER_ID = 'EDIT_HERE'; const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json'; const businesscommunications = require('businesscommunications'); const {google} = require('googleapis'); // Initialize the Business Communications API const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({}); // Set the scope that we need for the Business Communications API const scopes = [ 'https://www.googleapis.com/auth/businesscommunications', ]; // Set the private key to the service account file const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY); async function main() { const authClient = await initCredentials(); const partnerName = 'partners/' + PARTNER_ID; if (authClient) { // Setup the parameters for the API call const apiParams = { auth: authClient, name: partnerName, }; bcApi.partners.get(apiParams, {}, (err, response) => { if (err !== undefined && err !== null) { console.dir(err); } else { // Agent found console.log(response.data); } }); } else { console.log('Authentication failure.'); } } /** * Initializes the Google credentials for calling the * Business Messages API. */ async function initCredentials() { // Configure a JWT auth client const authClient = new google.auth.JWT( privatekey.client_email, null, privatekey.private_key, scopes, ); return new Promise(function(resolve, reject) { // Authenticate request authClient.authorize(function(err, tokens) { if (err) { reject(false); } else { resolve(authClient); } }); }); } main();- Python- """This code gets a partner. Read more: https://developers.google.com/business-communications/business-messages/reference/business-communications/rest/v1/partners/get This code is based on the https://github.com/google-business-communications/python-businessmessages Python Business Messages client library. """ from oauth2client.service_account import ServiceAccountCredentials from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1 from businesscommunications.businesscommunications_v1_messages import ( Agent, BusinesscommunicationsPartnersGetRequest, ) # Edit the values below: PARTNER_ID = 'EDIT_HERE' SCOPES = ['https://www.googleapis.com/auth/businesscommunications'] SERVICE_ACCOUNT_FILE = './service_account_key.json' credentials = ServiceAccountCredentials.from_json_keyfile_name( SERVICE_ACCOUNT_FILE, scopes=SCOPES) client = BusinesscommunicationsV1(credentials=credentials) partners_service = BusinesscommunicationsV1.PartnersService(client) partner_name = 'partners/' + PARTNER_ID partner = partners_service.Get(BusinesscommunicationsPartnersGetRequest( name=partner_name )) print(partner)
- 複製服務帳戶的電子郵件地址。這個帳戶可連結你的 Business Messages 以及 Dialogflow 代理程式 
- 在 Google Cloud 控制台 選取 Dialogflow 專案。 
- 前往 IAM 權限。 
- 按一下「新增」,然後輸入「新成員」的服務帳戶電子郵件地址。 
- 在「請選擇角色」部分,選取「Dialogflow 主控台代理程式編輯者」。 
- 按一下「新增其他角色」,然後選取「Dialogflow API 用戶端」。 
- 按一下 [儲存]。 
- 將 Dialogflow 專案與 Business Messages 服務專員整合。 - 將 AUTO_RESPONSE_STATUS 替換為「已啟用」或「已停用」,視實際情況而定 您是否希望 Business Messages 自動回覆 向 Dialogflow 使用者提交回應。 - Dialogflow ES- cURL- # This code creates a Dialogflow ES integration. # Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_es # Replace the __BRAND_ID__, __AGENT_ID__, __DIALOGFLOW_ES_PROJECT_ID__ and __AUTO_RESPONSE_STATUS__ # Make sure a service account key file exists at ./service_account_key.json curl -X POST \ "https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -d '{ "dialogflowEsIntegration": { "dialogflowProjectId": "__DIALOGFLOW_ES_PROJECT_ID__", "autoResponseStatus": "__AUTO_RESPONSE_STATUS__" } }'- Node.js- /** * This code snippet creates a Dialogflow ES integration. * Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_es * * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js * Business Communications client library. */ /** * Edit the values below: */ const BRAND_ID = 'EDIT_HERE'; const AGENT_ID = 'EDIT_HERE'; const DIALOGFLOW_ES_PROJECT_ID = 'EDIT_HERE' const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json'; const businesscommunications = require('businesscommunications'); const {google} = require('googleapis'); const uuidv4 = require('uuid').v4; // Initialize the Business Communications API const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({}); // Set the scope that we need for the Business Communications API const scopes = [ 'https://www.googleapis.com/auth/businesscommunications', ]; // Set the private key to the service account file const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY); async function main() { const authClient = await initCredentials(); const agentName = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID; if (authClient) { const integrationObject = { dialogflowEsIntegration: { dialogflowProjectId: DIALOGFLOW_ES_PROJECT_ID, autoResponseStatus: 'ENABLED' } }; // Setup the parameters for the API call const apiParams = { auth: authClient, parent: agentName, resource: integrationObject }; bcApi.brands.agents.integrations.create(apiParams, {}, (err, response) => { if (err !== undefined && err !== null) { console.dir(err); } else { // Agent created console.log(response.data); } }); } else { console.log('Authentication failure.'); } } /** * Initializes the Google credentials for calling the * Business Messages API. */ async function initCredentials() { // Configure a JWT auth client const authClient = new google.auth.JWT( privatekey.client_email, null, privatekey.private_key, scopes, ); return new Promise(function(resolve, reject) { // Authenticate request authClient.authorize(function(err, tokens) { if (err) { reject(false); } else { resolve(authClient); } }); }); } main();- Python- """This code snippet creates a Dialogflow ES integration. Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_es This code is based on the https://github.com/google-business-communications/python-businessmessages Python Business Messages client library. """ from oauth2client.service_account import ServiceAccountCredentials from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1 from businesscommunications.businesscommunications_v1_messages import ( BusinesscommunicationsBrandsAgentsIntegrationsCreateRequest, DialogflowEsIntegration ) # Edit the values below: BRAND_ID = 'EDIT_HERE' AGENT_ID = 'EDIT_HERE' DIALOGFLOW_ES_PROJECT_ID = 'EDIT_HERE' SCOPES = ['https://www.googleapis.com/auth/businesscommunications'] SERVICE_ACCOUNT_FILE = './service_account_key.json' credentials = ServiceAccountCredentials.from_json_keyfile_name( SERVICE_ACCOUNT_FILE, scopes=SCOPES) client = BusinesscommunicationsV1(credentials=credentials) integrations_service = BusinesscommunicationsV1.BrandsAgentsIntegrationsService(client) agent_name = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID integration = integrations_service.Create(BusinesscommunicationsBrandsAgentsIntegrationsCreateRequest( integration=DialogflowEsIntegration( autoResponseStatus=DialogflowEsIntegration.AutoResponseStatusValueValuesEnum.ENABLED, dialogflowProjectId=DIALOGFLOW_ES_PROJECT_ID ), parent=agent_name )) print(integration)- Dialogflow CX- cURL- # This code creates a Dialogflow CX integration. # Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_cx # Replace the __BRAND_ID__, __AGENT_ID__, __DIALOGFLOW_CX_PROJECT_ID__, __DIALOGFLOW_CX_AGENT_ID__ and __AUTO_RESPONSE_STATUS__ # Make sure a service account key file exists at ./service_account_key.json curl -X POST \ "https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -d '{ "dialogflowCxIntegration": { "dialogflowProjectId": "__DIALOGFLOW_CX_PROJECT_ID__", "dialogflowAgentId": "__DIALOGFLOW_CX_AGENT_ID__", "autoResponseStatus": "__AUTO_RESPONSE_STATUS__" } }'- Node.js- /** * This code snippet creates a Dialogflow CX integration. * Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_cx * * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js * Business Communications client library. */ /** * Edit the values below: */ const BRAND_ID = 'EDIT_HERE'; const AGENT_ID = 'EDIT_HERE'; const DIALOGFLOW_CX_AGENT_ID = 'EDIT_HERE' const DIALOGFLOW_CX_PROJECT_ID = 'EDIT_HERE' const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json'; const businesscommunications = require('businesscommunications'); const {google} = require('googleapis'); const uuidv4 = require('uuid').v4; // Initialize the Business Communications API const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({}); // Set the scope that we need for the Business Communications API const scopes = [ 'https://www.googleapis.com/auth/businesscommunications', ]; // Set the private key to the service account file const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY); async function main() { const authClient = await initCredentials(); const agentName = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID; if (authClient) { const integrationObject = { dialogflowCxIntegration: { dialogflowProjectId: DIALOGFLOW_CX_PROJECT_ID, dialogflowAgentId: DIALOGFLOW_CX_AGENT_ID, autoResponseStatus: 'ENABLED' } }; // Setup the parameters for the API call const apiParams = { auth: authClient, parent: agentName, resource: integrationObject }; bcApi.brands.agents.integrations.create(apiParams, {}, (err, response) => { if (err !== undefined && err !== null) { console.dir(err); } else { // Agent created console.log(response.data); } }); } else { console.log('Authentication failure.'); } } /** * Initializes the Google credentials for calling the * Business Messages API. */ async function initCredentials() { // Configure a JWT auth client const authClient = new google.auth.JWT( privatekey.client_email, null, privatekey.private_key, scopes, ); return new Promise(function(resolve, reject) { // Authenticate request authClient.authorize(function(err, tokens) { if (err) { reject(false); } else { resolve(authClient); } }); }); } main();- Python- """This code snippet creates a Dialogflow CX integration. Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#dialogflow_cx This code is based on the https://github.com/google-business-communications/python-businessmessages Python Business Messages client library. """ from oauth2client.service_account import ServiceAccountCredentials from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1 from businesscommunications.businesscommunications_v1_messages import ( BusinesscommunicationsBrandsAgentsIntegrationsCreateRequest, DialogflowCxIntegration ) # Edit the values below: BRAND_ID = 'EDIT_HERE' AGENT_ID = 'EDIT_HERE' DIALOGFLOW_CX_AGENT_ID = 'EDIT_HERE' DIALOGFLOW_CX_PROJECT_ID = 'EDIT_HERE' SCOPES = ['https://www.googleapis.com/auth/businesscommunications'] SERVICE_ACCOUNT_FILE = './service_account_key.json' credentials = ServiceAccountCredentials.from_json_keyfile_name( SERVICE_ACCOUNT_FILE, scopes=SCOPES) client = BusinesscommunicationsV1(credentials=credentials) integrations_service = BusinesscommunicationsV1.BrandsAgentsIntegrationsService(client) agent_name = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID integration = integrations_service.Create(BusinesscommunicationsBrandsAgentsIntegrationsCreateRequest( integration=DialogflowCxIntegration( autoResponseStatus=DialogflowCxIntegration.AutoResponseStatusValueValuesEnum.ENABLED, dialogflowAgentId=DIALOGFLOW_CX_AGENT_ID, dialogflowProjectId=DIALOGFLOW_CX_PROJECT_ID ), parent=agent_name )) print(integration)- 如需格式設定和值選項,請參閱: - Integration。
連結 Business Messages 和 Dialogflow 大約需要兩分鐘。目的地:
檢查整合狀態,取得整合作業的
OperationInfo。
更新整合作業
如要更新代理程式的自動回應設定,請執行下列指令, 將 AUTO_RESPONSE_STATUS 替換為「已啟用」或 視是否要自動啟用 Business Messages 而定 透過 Dialogflow 回應回應使用者。
Dialogflow ES
cURL
# This code updates the Dialogflow association.
# Read more: https://developers.google.com/business-communications/business-messages/reference/business-communications/rest/v1/brands.agents/updateDialogflowAssociation
# Replace the __BRAND_ID__ and __AGENT_ID__
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/dialogflowAssociation?updateMask=enableAutoResponse" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "enableAutoResponse": true
}'
Dialogflow CX
cURL
# This code updates the Dialogflow association.
# Read more: https://developers.google.com/business-communications/business-messages/reference/business-communications/rest/v1/brands.agents/updateDialogflowAssociation
# Replace the __BRAND_ID__ and __AGENT_ID__
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/dialogflowAssociation?updateMask=enableAutoResponse" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "enableAutoResponse": true
}'
如需格式設定和值選項,請參閱:
Integration。
切換不同的 Dialogflow 版本
Business Messages 服務專員一次只能支援一個 Dialogflow 整合。 如要從某個 Dialogflow 版本切換至其他版本,請先移除 進行新的整合
刪除整合項目
如要從 Business Messages 服務專員中移除 Dialogflow,請刪除 與下列指令進行整合
cURL
# This code deletes an integration. # Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#delete_the_integration # Replace the __BRAND_ID__, __AGENT_ID__ and __INTEGRATION_ID__ # Make sure a service account key file exists at ./service_account_key.json curl -X DELETE \ "https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)"
Node.js
/**
 * This code snippet deletes an integration.
 * Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#delete_the_integration
 *
 * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js
 * Business Communications client library.
 */
/**
 * Edit the values below:
 */
 const BRAND_ID = 'EDIT_HERE';
 const AGENT_ID = 'EDIT_HERE';
 const INTEGRATION_ID = 'EDIT_HERE';
 const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json';
 const businesscommunications = require('businesscommunications');
 const {google} = require('googleapis');
 const uuidv4 = require('uuid').v4;
 // Initialize the Business Communications API
 const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({});
 // Set the scope that we need for the Business Communications API
 const scopes = [
   'https://www.googleapis.com/auth/businesscommunications',
 ];
 // Set the private key to the service account file
 const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY);
 async function main() {
   const authClient = await initCredentials();
   const integrationName = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID + '/integrations/' + INTEGRATION_ID;
   if (authClient) {
     // Setup the parameters for the API call
     const apiParams = {
       auth: authClient,
       name: integrationName,
     };
     bcApi.brands.agents.integrations.delete(apiParams, {}, (err, response) => {
       if (err !== undefined && err !== null) {
         console.dir(err);
       } else {
         // Agent created
         console.log(response.data);
       }
     });
   }
   else {
     console.log('Authentication failure.');
   }
 }
 /**
  * Initializes the Google credentials for calling the
  * Business Messages API.
  */
  async function initCredentials() {
   // Configure a JWT auth client
   const authClient = new google.auth.JWT(
     privatekey.client_email,
     null,
     privatekey.private_key,
     scopes,
   );
   return new Promise(function(resolve, reject) {
     // Authenticate request
     authClient.authorize(function(err, tokens) {
       if (err) {
         reject(false);
       } else {
         resolve(authClient);
       }
     });
   });
 }
 main();
Python
"""This code snippet deletes an integration.
Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#delete_the_integration
This code is based on the https://github.com/google-business-communications/python-businessmessages
Python Business Messages client library.
"""
from oauth2client.service_account import ServiceAccountCredentials
from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1
from businesscommunications.businesscommunications_v1_messages import (
    BusinesscommunicationsBrandsAgentsIntegrationsDeleteRequest
)
# Edit the values below:
BRAND_ID = 'EDIT_HERE'
AGENT_ID = 'EDIT_HERE'
INTEGRATION_ID = 'EDIT_HERE'
SCOPES = ['https://www.googleapis.com/auth/businesscommunications']
SERVICE_ACCOUNT_FILE = './service_account_key.json'
credentials = ServiceAccountCredentials.from_json_keyfile_name(
    SERVICE_ACCOUNT_FILE, scopes=SCOPES)
client = BusinesscommunicationsV1(credentials=credentials)
integrations_service = BusinesscommunicationsV1.BrandsAgentsIntegrationsService(client)
integration_name = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID + '/integrations/' + INTEGRATION_ID
integration = integrations_service.Delete(BusinesscommunicationsBrandsAgentsIntegrationsDeleteRequest(
  name=integration_name
))
print(integration)
如需格式設定和值選項,請參閱:
Integration。
取得整合資訊
如需整合項目資訊,可以使用 Business Communications
API (只要有整合功能的 name 值)。
取得單一整合項目的資訊
如要取得整合資訊,請執行下列指令。
cURL
# This code gets information about an integration. # Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#get_info_for_a_single_integration # Replace the __BRAND_ID__, __AGENT_ID__ and __INTEGRATION_ID__ # Make sure a service account key file exists at ./service_account_key.json curl -X GET \ "https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)"
Node.js
/**
 * This code snippet gets information about an integration.
 * Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#get_info_for_a_single_integration
 *
 * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js
 * Business Communications client library.
 */
/**
 * Edit the values below:
 */
 const BRAND_ID = 'EDIT_HERE';
 const AGENT_ID = 'EDIT_HERE';
 const INTEGRATION_ID = 'EDIT_HERE';
 const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json';
 const businesscommunications = require('businesscommunications');
 const {google} = require('googleapis');
 const uuidv4 = require('uuid').v4;
 // Initialize the Business Communications API
 const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({});
 // Set the scope that we need for the Business Communications API
 const scopes = [
   'https://www.googleapis.com/auth/businesscommunications',
 ];
 // Set the private key to the service account file
 const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY);
 async function main() {
   const authClient = await initCredentials();
   const integrationName = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID + '/integrations/' + INTEGRATION_ID;
   if (authClient) {
     // Setup the parameters for the API call
     const apiParams = {
       auth: authClient,
       name: integrationName,
     };
     bcApi.brands.agents.integrations.get(apiParams, {}, (err, response) => {
       if (err !== undefined && err !== null) {
         console.dir(err);
       } else {
         // Agent created
         console.log(response.data);
       }
     });
   }
   else {
     console.log('Authentication failure.');
   }
 }
 /**
  * Initializes the Google credentials for calling the
  * Business Messages API.
  */
  async function initCredentials() {
   // Configure a JWT auth client
   const authClient = new google.auth.JWT(
     privatekey.client_email,
     null,
     privatekey.private_key,
     scopes,
   );
   return new Promise(function(resolve, reject) {
     // Authenticate request
     authClient.authorize(function(err, tokens) {
       if (err) {
         reject(false);
       } else {
         resolve(authClient);
       }
     });
   });
 }
 main();
Python
"""This code snippet gets information about an integration.
Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#get_info_for_a_single_integration
This code is based on the https://github.com/google-business-communications/python-businessmessages
Python Business Messages client library.
"""
from oauth2client.service_account import ServiceAccountCredentials
from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1
from businesscommunications.businesscommunications_v1_messages import (
    BusinesscommunicationsBrandsAgentsIntegrationsDeleteRequest
)
# Edit the values below:
BRAND_ID = 'EDIT_HERE'
AGENT_ID = 'EDIT_HERE'
INTEGRATION_ID = 'EDIT_HERE'
SCOPES = ['https://www.googleapis.com/auth/businesscommunications']
SERVICE_ACCOUNT_FILE = './service_account_key.json'
credentials = ServiceAccountCredentials.from_json_keyfile_name(
    SERVICE_ACCOUNT_FILE, scopes=SCOPES)
client = BusinesscommunicationsV1(credentials=credentials)
integrations_service = BusinesscommunicationsV1.BrandsAgentsIntegrationsService(client)
integration_name = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID + '/integrations/' + INTEGRATION_ID
integration = integrations_service.Get(BusinesscommunicationsBrandsAgentsIntegrationsDeleteRequest(
  name=integration_name
))
print(integration)
如需格式設定和值選項,請參閱:
Integration。
列出代理程式的所有整合作業
如果不知道整合項目名稱,可以取得 省略 INTEGRATION_ID,即可與代理程式進行整合 值。
cURL
# This code lists all integrations for an agent. # Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#list_all_integrations_for_an_agent # Replace the __BRAND_ID__ and __AGENT_ID__ # Make sure a service account key file exists at ./service_account_key.json curl -X GET \ "https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations" \ -H "Content-Type: application/json" \ -H "User-Agent: curl/business-communications" \ -H "$(oauth2l header --json ./service_account_key.json businesscommunications)"
Node.js
/**
 * This code snippet lists all integrations for an agent.
 * Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#list_all_integrations_for_an_agent
 *
 * This code is based on the https://github.com/google-business-communications/nodejs-businesscommunications Node.js
 * Business Communications client library.
 */
/**
 * Edit the values below:
 */
 const BRAND_ID = 'EDIT_HERE';
 const AGENT_ID = 'EDIT_HERE';
 const PATH_TO_SERVICE_ACCOUNT_KEY = './service_account_key.json';
 const businesscommunications = require('businesscommunications');
 const {google} = require('googleapis');
 const uuidv4 = require('uuid').v4;
 // Initialize the Business Communications API
 const bcApi = new businesscommunications.businesscommunications_v1.Businesscommunications({});
 // Set the scope that we need for the Business Communications API
 const scopes = [
   'https://www.googleapis.com/auth/businesscommunications',
 ];
 // Set the private key to the service account file
 const privatekey = require(PATH_TO_SERVICE_ACCOUNT_KEY);
 async function main() {
   const authClient = await initCredentials();
   if (authClient) {
     // Setup the parameters for the API call
     const apiParams = {
       auth: authClient,
       parent: 'brands/' + BRAND_ID + '/agents/' + AGENT_ID,
     };
     bcApi.brands.agents.integrations.list(apiParams, {}, (err, response) => {
       if (err !== undefined && err !== null) {
         console.dir(err);
       } else {
         // Agent created
         console.log(response.data);
       }
     });
   }
   else {
     console.log('Authentication failure.');
   }
 }
 /**
  * Initializes the Google credentials for calling the
  * Business Messages API.
  */
  async function initCredentials() {
   // Configure a JWT auth client
   const authClient = new google.auth.JWT(
     privatekey.client_email,
     null,
     privatekey.private_key,
     scopes,
   );
   return new Promise(function(resolve, reject) {
     // Authenticate request
     authClient.authorize(function(err, tokens) {
       if (err) {
         reject(false);
       } else {
         resolve(authClient);
       }
     });
   });
 }
 main();
Python
"""This code snippet lists all integrations for an agent.
Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#list_all_integrations_for_an_agent
This code is based on the https://github.com/google-business-communications/python-businessmessages
Python Business Messages client library.
"""
from oauth2client.service_account import ServiceAccountCredentials
from businesscommunications.businesscommunications_v1_client import BusinesscommunicationsV1
from businesscommunications.businesscommunications_v1_messages import (
    BusinesscommunicationsBrandsAgentsIntegrationsListRequest
)
# Edit the values below:
BRAND_ID = 'EDIT_HERE'
AGENT_ID = 'EDIT_HERE'
SCOPES = ['https://www.googleapis.com/auth/businesscommunications']
SERVICE_ACCOUNT_FILE = './service_account_key.json'
credentials = ServiceAccountCredentials.from_json_keyfile_name(
    SERVICE_ACCOUNT_FILE, scopes=SCOPES)
client = BusinesscommunicationsV1(credentials=credentials)
integrations_service = BusinesscommunicationsV1.BrandsAgentsIntegrationsService(client)
agent_name = 'brands/' + BRAND_ID + '/agents/' + AGENT_ID
integration = integrations_service.List(
  BusinesscommunicationsBrandsAgentsIntegrationsListRequest(parent=agent_name)
)
print(integration)
如需格式設定和值選項,請參閱:
Integration。
意圖比對
為 Business Messages 服務專員啟用 Dialogflow 整合功能後, 代理程式就能使用 Dialogflow 專案設定的意圖來瞭解 您完全不需要撰寫程式碼,也能回覆使用者的問題。如要進一步瞭解 意圖,請參閱 Dialogflow ES 說明文件 和 Dialogflow CX。
為您要取得的每個對話選項設定 Dialogflow 意圖 支援以自動化技術提供支援Business Messages 服務專員仰賴 Dialogflow 來 掌握使用者訊息
呼叫 Dialogflow API 時,Business Messages 會傳遞
使用者訊息酬載
和執行要求 Webhook當使用者訊息相符時
有了意圖,您就能以 Struct 格式存取這個酬載,
QueryParameters 中的 business_messages_payload 欄位。
酬載包含使用者訊息的所有欄位,但 DialogflowResponse 除外。
如果是 Dialogflow CX,Business Messages 也會將名為 channel 的工作階段參數 (值為 google_business_messages) 傳遞至意圖,因此您可以在代理程式中以下列格式參照該參數:$session.params.channel。
這個參數可用來為 Dialogflow 執行要求新增條件式,以支援同一個 Dialogflow 代理程式中的多個管道。
如要進一步瞭解查詢參數,請參閱 Dialogflow ES 和 Dialogflow CX 參考資料。
必要條件
在 Dialogflow 中建立 NLU 模型時,您可以設定 意圖的回應類型Business Messages 支援預設回應, 可包含下列項目:
- 文字
- 自訂酬載
- 即時服務專員轉接 (僅限 Dialogflow CX)
自訂酬載必須與有效的 Business Messages JSON 訊息回應 物件。 為意圖設定自訂酬載回應時,Business Messages 會忽略下列欄位:
- name
- messageId
- representative
請參閱下列回應範例。
含建議的文字
{
  "text": "Hello World!",
  "fallback": "Hello World!\n\nReply with \"Hello\" or \"Hi!\"",
  "suggestions": [
    {
      "reply": {
        "text": "Hello",
        "postbackData": "hello-formal"
      }
    },
    {
      "reply": {
        "text": "Hi!",
        "postbackData": "hello-informal"
      }
    }
  ]
}
複合式資訊卡
{
  "fallback": "Hello, world!\nSent with Business Messages\n\nReply with \"Suggestion #1\" or \"Suggestion #2\"",
  "richCard": {
    "standaloneCard": {
      "cardContent": {
        "title": "Hello, world!",
        "description": "Sent with Business Messages.",
        "media": {
          "height": "TALL",
          "contentInfo":{
            "altText": "Google logo",
            "fileUrl": "https://www.google.com/images/branding/googlelogo/2x/googlelogo_color_272x92dp.png",
            "forceRefresh": "false"
          }
        },
        "suggestions": [
          {
            "reply": {
              "text": "Suggestion #1",
              "postbackData": "suggestion_1"
            }
          },
          {
            "reply": {
              "text": "Suggestion #2",
              "postbackData": "suggestion_2"
            }
          }
        ]
      }
    }
  }
}
複合式資訊卡輪轉介面
{
  "fallback": "Card #1\nThe description for card #1\n\nCard #2\nThe description for card #2\n\nReply with \"Card #1\" or \"Card #2\"",
  "richCard": {
    "carouselCard": {
      "cardWidth": "MEDIUM",
      "cardContents": [
        {
          "title": "Card #1",
          "description": "The description for card #1",
          "suggestions": [
            {
              "reply": {
                "text": "Card #1",
                "postbackData": "card_1"
              }
            }
          ],
          "media": {
            "height": "MEDIUM",
            "contentInfo": {
              "fileUrl": "https://my.files/cute-dog.jpg",
              "forceRefresh": false
            }
          }
        },
        {
          "title": "Card #2",
          "description": "The description for card #2",
          "suggestions": [
            {
              "reply": {
                "text": "Card #2",
                "postbackData": "card_2"
              }
            }
          ],
          "media": {
            "height": "MEDIUM",
            "contentInfo": {
              "fileUrl": "https://my.files/elephant.jpg",
              "forceRefresh": false
            }
          }
        }
      ]
    }
  }
}
真人服務專員轉接
{
  "metadata": {}
}
常見問題機器人
為 Business Messages 服務專員啟用 Dialogflow ES 整合功能後, 可以建立常見問題機器人當您以 支援的知識文件,Business Messages 和 Dialogflow 會建立 瞭解及回應使用者問題所需的基礎架構 讓您不必編寫程式碼
如要查看常見問題機器人的實際運作情形,請與 Business Messages 常見問題進行即時通訊 機器人。
必要條件
建立常見問題機器人前,您必須備妥下列問題和答案: 知識文件 (最大 50 MB):可公開取得的 HTML 檔案或 CSV 檔案。
一般而言,知識文件
- 可在答案中加入有限的 Markdown,如豐富內容所示 文字。
- 大小上限為 50 MB。
- 不得超過 2000 個問題/答案組合。
- 請勿針對含有不同答案的重複問題提供支援服務。
如果是 HTML 檔案
- 來自公開網址的檔案必須先已由 Google 搜尋索引器檢索, 以納入搜尋索引您可以使用 Google Search Console。 請注意,索引器不會讓您的內容保持最新狀態。你必須明確進行 並且會在來源內容變更時更新您的文件。
- Dialogflow 在建立回應時會從內容中移除 HTML 標記。由於 最好避免使用 HTML 標記,並盡可能使用純文字。
- 系統不支援含有單一問題/答案組合的檔案。
如果是 CSV 檔案,
- 檔案中第一欄應包含問題,並在第二欄中回答問題。 ,
- 檔案必須使用半形逗號做為分隔符號。
建立常見問題機器人
如要建立常見問題機器人,請先建立知識庫來儲存 然後將一或多份內含問題/答案組合的文件新增至 知識庫
建立知識庫
如要建立知識庫,請執行下列指令。將
「BRAND_ID」、「AGENT_ID」和「INTEGRATION_ID」
以文件 name 中的不重複值取代。將
將 KNOWLEDGE_BASE_DISPLAY_NAME 替換為您的識別字串
就是用哪一種烤箱或刀子都可以
那麼預先建構的容器或許是最佳選擇
建立知識庫後,您可以建立文件 在其中建立目錄
cURL
# This code creates a knowledge base.
# Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#create-knowledge-base
# Replace the __BRAND_ID__, __AGENT_ID__, __INTEGRATION_ID__ and __KNOWLEDGE_BASE_DISPLAY_NAME__
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__?updateMask=dialogflowEsIntegration.dialogflowKnowledgeBases" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "dialogflowEsIntegration": {
    "dialogflowKnowledgeBases": [
      {
        "displayName": "__KNOWLEDGE_BASE_DISPLAY_NAME__"
      }
    ]
  }
}'
如需格式設定和值選項,請參閱:
DialogflowKnowledgebase。
建立知識文件
如要建立知識文件,請執行下列指令。
將文件加入現有文件清單;如果沒有文件,請建立新的清單
。現有文件的清單應包含文件的 name
值。
公開 HTML 檔案
替換下列變數:
- 「BRAND_ID」、「AGENT_ID」和「INTEGRATION_ID」
與整合項目 name中的不重複值進行配對
- 「KNOWLEDGE_BASE_DISPLAY_NAME」和 DOCUMENT_DISPLAY_NAME 搭配 識別所選字串
- PUBLIC_URL具備專業知識 文件的公開網址 
cURL
# This code creates a knowledge base document from an HTML document and adds it to the knowledge base.
# Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#create-document
# Replace the __BRAND_ID__, __AGENT_ID__, __INTEGRATION_ID__, __KNOWLEDGE_BASE_DISPLAY_NAME__, __DOCUMENT_DISPLAY_NAME__ and __PUBLIC_URL__
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__?updateMask=dialogflowEsIntegration.dialogflowKnowledgeBases" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "dialogflowEsIntegration": {
    "dialogflowKnowledgeBases": [
      {
        "displayName": "__KNOWLEDGE_BASE_DISPLAY_NAME__",
        "documents": [
          {
            "displayName": "__DOCUMENT_DISPLAY_NAME__",
            "faqUrl": "__PUBLIC_URL__"
          }
        ]
      }
    ]
  }
}'
本機 CSV 檔案
替換下列變數:
- 「BRAND_ID」、「AGENT_ID」和「INTEGRATION_ID」
與整合項目 name中的不重複值進行配對
- 「KNOWLEDGE_BASE_DISPLAY_NAME」和 DOCUMENT_DISPLAY_NAME 搭配 識別所選字串
- 將 CSV 設為 CSV_RAW_BYTES 檔案轉換成 Base64 編碼字串 
cURL
# This code creates a knowledge base document from a CSV document and adds it to the knowledge base.
# Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#create-document
# Replace the __BRAND_ID__, __AGENT_ID__, __INTEGRATION_ID__, __KNOWLEDGE_BASE_DISPLAY_NAME__, __DOCUMENT_DISPLAY_NAME__ and __CSV_RAW_BYTES__
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__?updateMask=dialogflowEsIntegration.dialogflowKnowledgeBases" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "dialogflowEsIntegration": {
    "dialogflowKnowledgeBases": [
      {
        "displayName": "__KNOWLEDGE_BASE_DISPLAY_NAME__",
        "documents": [
          {
            "displayName": "__DOCUMENT_DISPLAY_NAME__",
            "rawContent": "__CSV_RAW_BYTES__"
          }
        ]
      }
    ]
  }
}'
如需格式設定和值選項,請參閱:
DialogflowKnowledgebase。
將文件新增到知識庫大約需要兩分鐘。若要查看
請先取得文件的
OperationInfo。
刪除知識文件
如需從 Business Messages 服務專員移除問題/答案組合, 使用下列指令,刪除包含這些模組的知識文件。
執行下列指令,刪除單一現有文件。將
「BRAND_ID」、「AGENT_ID」和「INTEGRATION_ID」
以文件 name 中的不重複值取代。將
KNOWLEDGE_BASE_DISPLAY_NAME 替換為適當字串。
cURL
# This code deletes a knowledge base document.
# Read more: https://developers.google.com/business-communications/business-messages/guides/how-to/integrate/dialogflow?method=api#delete_a_knowledge_document
# Replace the __BRAND_ID__, __AGENT_ID__, __INTEGRATION_ID__ and __KNOWLEDGE_BASE_DISPLAY_NAME__
# To delete all knowledge bases, set dialogflowKnowledgeBases to an empty list. Otherwise, the list should contain all existing knowledgebases except the one you would like to remove.
# Make sure a service account key file exists at ./service_account_key.json
curl -X PATCH \
"https://businesscommunications.googleapis.com/v1/brands/__BRAND_ID__/agents/__AGENT_ID__/integrations/__INTEGRATION_ID__?updateMask=dialogflowEsIntegration.dialogflowKnowledgeBases" \
-H "Content-Type: application/json" \
-H "User-Agent: curl/business-communications" \
-H "$(oauth2l header --json ./service_account_key.json businesscommunications)" \
-d '{
  "dialogflowEsIntegration": {
    "dialogflowKnowledgeBases": [
      {
        "displayName": "__KNOWLEDGE_BASE_DISPLAY_NAME__"
      }
    ]
  }
}'
如需格式設定和值選項,請參閱:
DialogflowKnowledgebase。
自動回覆
如果您在 Dialogflow 整合期間啟用自動回覆,Business 訊息會透過 Dialogflow 自動回覆使用者。您的商家 訊息代理程式會回應相符的可信度最高。內建 如果常見問題和答案都與 Dialogflow ES 整合, Business Messages 回覆了 信賴水準
Business Messages 會將所有自動回覆訊息標示為來自 BOT
客服代表。如果你的虛擬服務專員支援線上服務專員,
Business Messages 將在 REPRESENTATIVE_JOINED後暫停自動回覆
事件
並在 REPRESENTATIVE_LEFT 事件發生後恢復自動回覆。請參閱 Handoff
從機器人到真人服務專員
自動回覆常見問題解答
與 Dialogflow ES 整合時,如果常見問題的答案的可信度最高, Business Messages 會將回覆對應到簡訊如果有 相關的解答還有不同的答案 接聽」建議。如果沒有,訊息會包含問題和建議 詢問訊息是否滿足使用者的要求。
使用意圖回應自動回覆
意圖回應可包含以下一或多個回應。
如果意圖回應的可信度等級最高,則:
- 如果回覆中至少有一個文字值,Business Messages 就會對應該值 輸入到文字訊息中
- 如果回應中至少有一個自訂酬載,其中包含有效的企業 訊息 JSON 物件結構,Business Messages 會使用 提供的 JSON 物件
- 如果回覆中至少有一個真人服務專員遞交回應,請參閱 透過真人服務專員要求自動回覆。
Dialogflow 可以在單一意圖比對中納入多個回應, Business Messages 會傳送各項文字、自訂酬載或即時服務專員轉接 視為個別訊息回應如果意圖中有多則訊息 但部分格式錯誤,Business Messages 只會傳送有效的 自動回覆訊息。
透過真人服務專員要求自動回覆
Dialogflow CX 支援即時服務專員轉接 回應。表示應將對話轉接給真人 可以傳遞自訂中繼資料 程序。如果意圖回應的可信度等級最高,且 包含真人服務專員轉接、Business Messages 真人服務專員要求活動 附加至 Webhook如要處理這個事件,請參閱 從機器人到真人服務專員。
使用備用訊息自動回覆
如果 Dialogflow 沒有高度相符的信賴水準,Business Messages 會傳送 做為備用回應Dialogflow ES 和 Dialogflow 中的備用處理方式不同 Dialogflow CX。
Dialogflow ES
如果常見問題解答找不到相符的常見問題解答,Business Messages 就會傳送 找不到解答的備用訊息。
在已設定的意圖中,如果找不到相符的意圖回應, 訊息會傳送備用意圖回應。 您可以使用 Dialogflow 提供的備用文字,或設定 具備額外的文字和自訂酬載的備用方案
以下是 Webhook 的備用意圖回應範例 可接收:
{
  "intentResponses": [
    {
      "intentName": "projects/df-integration/agent/intents/12345",
      "intentDisplayName": "Default Fallback Intent",
      "intentDetectionConfidence": "1.0",
      "fulfillmentMessages": [
        {
          "text": "One more time?"
        }
      ]
    }
  ]
}
Dialogflow 會預先填入 intent_name 和 intent_display_name。
Dialogflow CX
Dialogflow CX 會將備用意圖回應 內建事件。 如果沒有與意圖回應相符的結果,Business Messages 會傳送 來自 Dialogflow「No-match」(不相符) 預設事件的備用訊息。你可以 請使用 Dialogflow 提供的備用文字,或設定備用文字 提供額外的文字、自訂酬載和真人服務專員轉接選項
這個備用意圖回應的範例如下 Webhook 可接收:
{
  "intentResponses": [
    {
      "intentName": "sys.no-match-default",
      "intentDisplayName": "Default Fallback Intent",
      "intentDetectionConfidence": "0.3",
      "fulfillmentMessages": [
        {
          "text": "I missed that, say that again?"
        }
      ]
    }
  ]
}
Business Messages 硬式編碼為 intent_name 和 intent_display_name。
Dialogflow 專屬欄位
啟用 Dialogflow 整合後,使用者會針對代理程式傳送訊息
接收
加入
dialogflowResponse敬上
物件。不論
Business Messages 是否會自動回覆
如要查看自動回覆,請參閱
autoResponded敬上
欄位,然後決定是否需要回覆使用者。
Dialogflow ES
...
"dialogflowResponse": {
  "queryText": "TEXT",
  "intentResponse": {
    "intentName": "INTENT_ID",
    "intentDisplayName": "INTENT_NAME",
    "intentDetectionConfidence": "CONFIDENCE_NUMERIC",
    "fulfillmentMessages": [{
      "text": "FULFILLMENT_TEXT",
      "jsonPayload": "JSON",
      "error": "ERROR_STATUS",
    }],
  "faqResponse": {
    "userQuestion": "USER_QUESTION",
    "answers": [{
      "faqQuestion": "FAQ_QUESTION",
      "faqAnswer": "FAQ_ANSWER",
      "matchConfidenceLevel": "CONFIDENCE_LEVEL",
      "matchConfidence": "CONFIDENCE_NUMERIC",
    }],
  },
  "autoResponded": "BOOLEAN",
  "autoRespondedMessages": [{
    "message": "MESSAGE_JSON",
    "responseSource": "SOURCE",
  }],
},
...
| 欄位 | 說明 | 
|---|---|
| queryText | 原始對話型查詢文字。如果自動拼字
已為 Dialogflow 模型「 queryText」啟用修正功能
包含更正後的使用者輸入內容。 | 
| intentName | 相符意圖的專屬 ID。 | 
| intentDisplayName | 相符意圖的名稱。 | 
| intentDetectionConfidence | 比對中的可信度評分數值
介於 queryText至intentName之間。 | 
| text | 文字回應。 | 
| jsonPayload | 自訂酬載回應。
這個字串與
酬載
如果酬載缺少有效的 Business Messages JSON
物件結構 error說明瞭問題。 | 
| error | 含有意圖執行要求訊息的錯誤說明。 | 
| userQuestion | 使用者提出的問題,由 Dialogflow 剖析。 | 
| faqQuestion | Dialogflow 中的問題與使用者的問題相符。 | 
| faqAnswer | Dialogflow 中的答案與使用者的問題相符。 | 
| matchConfidenceLevel | 比對相符程度:
《 userQuestion》和《faqQuestion》。 | 
| matchConfidence | 比對相符結果中的可信度評分
《 userQuestion》和《faqQuestion》。 | 
| autoResponded | Business Messages 是否會自動回應 向 Dialogflow 提供答案的使用者。 | 
| message | 自動回應的酬載。 | 
| responseSource | 自動回應的來源。詳情請見 ResponseSource。 | 
Dialogflow CX
...
"dialogflowResponse": {
  "queryText": "TEXT",
  "intentResponse": {
    "intentName": "INTENT_ID",
    "intentDisplayName": "INTENT_NAME",
    "intentDetectionConfidence": "CONFIDENCE_NUMERIC",
    "fulfillmentMessages": [{
      "text": "FULFILLMENT_TEXT",
      "jsonPayload": "JSON",
      "error": "ERROR_STATUS",
      "liveAgentHandoff": {
        "metadata": {}
      }
    }],
  "autoResponded": "BOOLEAN",
  "autoRespondedMessages": [{
    "message": "MESSAGE_JSON",
    "responseSource": "SOURCE",
  }],
},
...
| 欄位 | 說明 | 
|---|---|
| queryText | 原始對話型查詢文字。如果自動拼字
已為 Dialogflow 模型「 queryText」啟用修正功能
包含更正後的使用者輸入內容。 | 
| intentName | 相符意圖的專屬 ID。 | 
| intentDisplayName | 相符意圖的名稱。 | 
| intentDetectionConfidence | 比對中的可信度評分數值
介於 queryText至intentName之間。 | 
| text | 文字回應。 | 
| jsonPayload | 自訂酬載回應。
這個字串與
酬載
如果酬載缺少有效的 Business Messages JSON
物件結構 error說明瞭問題。 | 
| error | 含有意圖執行要求訊息的錯誤說明。 | 
| liveAgentHandoff | 真人服務專員轉接程序的自訂中繼資料。 | 
| autoResponded | Business Messages 是否會自動回應 向 Dialogflow 提供答案的使用者。 | 
| message | 自動回應的酬載。 | 
| responseSource | 自動回應的來源。詳情請見 ResponseSource。 |