Chatbot實作工作坊
真理大學110學年度第2學期 微課程
Outline
- Chatbot簡介
- 認識Dialogflow
- Chatbot建置指引
Chatbot聊天機器人分類
General Purpose
data:image/s3,"s3://crabby-images/81417/81417d2a9cfc1b90901c1e30d0afbf47041f0947" alt=""
data:image/s3,"s3://crabby-images/eb00d/eb00d4a20d616aff9b083496fa6376300f059a23" alt=""
task-oriented
中文版 Eliza (心理醫師)
(Artificial Linguistic Internet Computer Entity)
負責特定工作
Chatbot聊天機器人技術
Rule-based
樣式比對(pattern matching)
Corpus-based
採用大量詞庫進行訓練
詞庫來源: crowdsourcing, wikipedia
Chatbot聊天機器人架構
data:image/s3,"s3://crabby-images/ea69e/ea69ecda17d32d71d44bd34567c2eaed3a864a06" alt=""
語音辨識
自然語言理解
狀態追蹤
自然語言產生
文字轉語音
對話策略
Dialogflow
Dialogflow
自然語言理解 (Natural Language Understanding) 平台
data:image/s3,"s3://crabby-images/26d9d/26d9daaf5f1f7fd2e700e4df70cb286d0918c491" alt=""
使用者的語句
代理人程式
預測意圖
擷取字句當中的資訊
預測 + 資訊擷取
Dialogflow
使用者的語句
代理人程式
可以預測的意圖
「意圖」包含:
data:image/s3,"s3://crabby-images/b1c68/b1c68d824e82823cd31cbb4f2878522bb9af4fb5" alt=""
訓練用片語
引發的動作
附帶的參數
回覆的語句
預測的機制?如何運用擷取的資訊?
Dialogflow
自然語言理解 (Natural Language Understanding) 平台
自然語言處理 NLP
命名實體辨識
Name Entity Recognition
詞類標記
Port-Of-Speech tagging
文字分類
Text Categorization
機器翻譯
Machine Translation
自然語言理解 NLU
自然語言推理
Natural language Inference
語意解析
Semantic Parsing
文字摘要
Text Summarization
情感分析
Sentiment Analysis
問答系統
Question-Answering System
對話代理
Dialogue Agent
Dialogflow
Dialogflow Essentials (ES)
- 試用版、基本版
- 試用版免費:小於 每分鐘180次text requests
超過則 ➪ 每個request $0.002美元
(請參考配額與限制)
Dialogflow Customer Experience (CX)
- 進階版
- 視覺化介面(如對話流程設定)
data:image/s3,"s3://crabby-images/40f64/40f64ae72583c9cbd0162cd0f46a2bff22eb20f4" alt=""
Prebuilt Agents
步驟1: 新建代理人 Create Agent (optional) (1/2)
data:image/s3,"s3://crabby-images/c2c83/c2c830f3eb7a135860a318344372275efffcf5b0" alt=""
如果左側選單無Prebuilt Agents,則先Create Agent
data:image/s3,"s3://crabby-images/f162f/f162f2760975d210623ceca7f4b3524f3db9c3c3" alt=""
步驟1: 新建代理人 Create Agent (optional) (2/2)
輸入代理人名稱
設定預設語言別
綁定Google專案
步驟2: 套用Prebuilt代理人 (Prebuilt Agents) (1/4)
data:image/s3,"s3://crabby-images/67a37/67a3701321cddd7e19bb5d13fec5d1a94e68252b" alt=""
步驟2: 套用Prebuilt代理人 (Prebuilt Agents) (2/4)
data:image/s3,"s3://crabby-images/ddbe8/ddbe855d50d5ebba04fd6e7be11cf4d112ea6021" alt=""
任選一個agent
步驟2: 套用Prebuilt代理人 (Prebuilt Agents) (3/4)
data:image/s3,"s3://crabby-images/81621/81621a6f3b6ea7c82255143bf699b6a98b521ad2" alt=""
Agent名稱
建立新的Google專案
步驟2: 套用Prebuilt代理人 (Prebuilt Agents) (4/4)
data:image/s3,"s3://crabby-images/44301/44301bcee003158e4bb6be416a8af5da7c97f43e" alt=""
步驟3: 與其他平台整合以Line為例
1. 前往LINE Developers Console建立Channel
(使用Messaging API)
2. 從Dialogflow ES控制台取得Line webhook URL
3. 完成Line webhook設定(Line 平台端)
4. 完成Dialogflow integrations端的設定
步驟3-1: 建立Line Channel使用Line Messaging API
3-1 前往LINE Developers Console建立Channel
data:image/s3,"s3://crabby-images/76e2a/76e2adea293348b26a8d8596b052b39803e4cab2" alt=""
你的系統(如Dialogflow)
Channel是LINE平台與你的系統之間的「溝通路徑」
(HTTP協定、採用「訂閱」機制)
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-1. 登入LINE Developers Console
data:image/s3,"s3://crabby-images/dc0b7/dc0b74d609b2b3ee2d363ff2f996ef76ab66ba01" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-2. 以開發者身份註冊(僅需設定一次)
data:image/s3,"s3://crabby-images/7c4d6/7c4d60abc74ef79fb4c2c12c95c461a6f75c1416" alt=""
輸入姓名、Email
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-3. 建立新的Provider
輸入Provider名稱
data:image/s3,"s3://crabby-images/f7fb5/f7fb5ed1d153279ced2f04aec1ec4b54ab9f85cc" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-4. 建立Messaging API channel (1/3)
data:image/s3,"s3://crabby-images/b8b74/b8b74e487acb6bdd6503bca60e83f2da4758bf71" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-4. 建立Messaging API channel (2/3)
data:image/s3,"s3://crabby-images/d82fc/d82fcaace2b2e53b96ff6132f683c7da60c8892e" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-4. 建立Messaging API channel (3/3)
data:image/s3,"s3://crabby-images/9a3c4/9a3c4c449295799e426d540f66907460a27b926b" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-1: 建立Line Channel使用Line Messaging API
3-1-5. 確認Channel已成功建立
data:image/s3,"s3://crabby-images/083ab/083abeac619e0932d8da00233af3ba337e1857cb" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-2: 取得LINE webhook URL從Dialogflow控制台
Prebuilt agent不要更改Webhook版本設定
❶
❷ prebuilt agent使用v1, 勿改
data:image/s3,"s3://crabby-images/504c4/504c4d429fcf506bce603cafde16b1cb89cb7683" alt=""
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
步驟3-2: 取得LINE webhook URL從Dialogflow控制台
data:image/s3,"s3://crabby-images/ea063/ea06380f74429876ab1f285cc51111026871c6ac" alt=""
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
步驟3-2: 取得LINE webhook URL從Dialogflow控制台
data:image/s3,"s3://crabby-images/5ea8e/5ea8e0e1feebaa521625906d43a502dd761f2e0f" alt=""
複製Webhook URL, 準備到LINE Developers Console進行設定
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
步驟3-3: 在LINE Developers Console設定Webhook URL
Webhook URL: 你的系統網址
data:image/s3,"s3://crabby-images/76e2a/76e2adea293348b26a8d8596b052b39803e4cab2" alt=""
你的系統(如Dialogflow)
所以,Webhook是什麼?
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
步驟3-3: 在LINE Developers Console設定Webhook URL
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
data:image/s3,"s3://crabby-images/64510/645100944abdd89469de0a5119a9dfe575f9e48f" alt=""
❶ 選擇3-1建立的Provider
❶ 選擇3-1建立的Provider
❷ 點選此分頁
3-3-1 前往LINE Developers Console 啟用Webhook
步驟3-3: 在LINE Developers Console設定Webhook URL
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
3-3-1 前往LINE Developers Console 啟用Webhook
data:image/s3,"s3://crabby-images/686b7/686b705af53e7f01b9f205bafd3cdd489dfdbf10" alt=""
❶ 貼上Webhook URL
❷ 打開啟用開關
步驟3-3: 在LINE Developers Console設定Webhook URL
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
3-3-2 關閉「自動回覆訊息」(重要!)
❶ 點選Edit, 關閉自動回覆訊息
data:image/s3,"s3://crabby-images/1af83/1af8328a37217f5579732acbd4a4b42a79cbef9b" alt=""
步驟3-4: 將Channel ID, Channel secret, Channel access token貼至Dialogflow
data:image/s3,"s3://crabby-images/ea063/ea06380f74429876ab1f285cc51111026871c6ac" alt=""
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
回Dialogflow agent
步驟3-4: 將Channel ID, Channel secret, Channel access token貼至Dialogflow
❶ 準備從Line Provider處複製Channel ID, Channel secret, Channel access token貼至此處
data:image/s3,"s3://crabby-images/5ea8e/5ea8e0e1feebaa521625906d43a502dd761f2e0f" alt=""
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
❷ 啟動agent,作為Line平台的bot server
步驟3-4: 將Channel ID, Channel secret, Channel access token貼至Dialogflow
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
data:image/s3,"s3://crabby-images/527b3/527b318b6a07b54d45fec6c4d7e58ae161391869" alt=""
❶ Channel ID在Basic information段落的最前面
步驟3-4: 將Channel ID, Channel secret, Channel access token貼至Dialogflow
❷ Channel secret在Basic information段落的最後面
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
data:image/s3,"s3://crabby-images/3dee5/3dee54aafcc4d77073316c7c9671ed7ed1caa58c" alt=""
步驟3-4: 將Channel ID, Channel secret, Channel access token貼至Dialogflow
❸ Channel access token在Basic information段落的最後面
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
data:image/s3,"s3://crabby-images/9c455/9c4552a38592fe4a19ea229d07d9b78fbc58c18a" alt=""
步驟3-5: 掃描QR-Code, 加入好友
打開手機,掃描QR-Code,加入好友
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
data:image/s3,"s3://crabby-images/f2f04/f2f04f49876b9034c7d98c9688ae6be703ab433f" alt=""
data:image/s3,"s3://crabby-images/eb41f/eb41f7f1a9543c4e0c72bb772f8e5af8c228b271" alt=""
步驟3-6: 建立回應訊息
打開手機,掃描QR-Code,加入好友
data:image/s3,"s3://crabby-images/15b69/15b69f66a0064cfb586914ca673eb44b31a7acbf" alt=""
步驟3-7: 測試聊天機器人
打開手機,掃描QR-Code,加入好友
data:image/s3,"s3://crabby-images/eb41f/eb41f7f1a9543c4e0c72bb772f8e5af8c228b271" alt=""
data:image/s3,"s3://crabby-images/9d96d/9d96d941dc882658d637f92a5379495c57e054dd" alt=""
Create Agents
你的chatbot能提供什麼服務?
荷蘭皇家航空提供「訂位」與「打包清單」服務
data:image/s3,"s3://crabby-images/c8406/c84066f43d599630aea3b55dbd650666e609025e" alt=""
data:image/s3,"s3://crabby-images/3d842/3d842b4bfec9ef454b1d5a0682ef21aec589d55f" alt=""
訂位
打包清單提醒
data:image/s3,"s3://crabby-images/2be57/2be57ab1e257d07971395c6bab9eda7225d8dcb7" alt=""
達美樂提供「點餐」與「訂單追蹤」服務
點餐
訂單追蹤
data:image/s3,"s3://crabby-images/f21a4/f21a40d37f6c41d74ec54d073e071515d9dfcbe1" alt=""
data:image/s3,"s3://crabby-images/1f109/1f109bbd9d27a3ee0ae0563d1749a8bf9d9bd939" alt=""
data:image/s3,"s3://crabby-images/d8c63/d8c6396ab5fb3eba7893eb9356b8fbb838e09634" alt=""
線上售票公司提供「查詢」與「訂票」服務
查詢
訂票
data:image/s3,"s3://crabby-images/216dd/216dde2f2a2e3625c96af0de09c1ffc7a3b807a1" alt=""
data:image/s3,"s3://crabby-images/196fa/196fa2a4c618ef3a0f07d417ba69f3a6c0963138" alt=""
data:image/s3,"s3://crabby-images/7209f/7209f5943a4fd462b6558751f3f57bb94d2b2d8f" alt=""
你的chatbot想提供什麼服務?
- 庫存:「請問{某個商品}還有貨嗎?」
- 營業時間:「請問門市營業{時間}為何?」
- 推薦:「有沒有可以{解決某種問題}的東西?」
- 推薦:「哪個{牌子}的電視比較好?」
- 關聯推薦
...
電商服務:除了訂購之外,可能還可提供...
- 推薦:「哪裡有好吃/玩的{target}?」
- 推薦:「我想找{某地}{天數}的自由行行程
- 預約:「我要預約這個行程」
- 路線規劃:「{target}怎麼去?」
...
觀光旅遊業:可能可提供...
你的chatbot想提供什麼服務?
{target}: 小吃、景點、餐廳...
單車店/ 理髮店
1.「我想預約{服務}」
2.「請問你們明天有營業嗎?」
{服務}: 洗頭、剪頭髮、買車、保養
你的chatbot想提供什麼服務?
Chatbot 以單車店為例
data:image/s3,"s3://crabby-images/c6a18/c6a1841835ccc9ee25ec51caa4f3f6ae0240b94f" alt=""
步驟1: 新建代理人 Create Agent (optional) (1/2)
data:image/s3,"s3://crabby-images/c2c83/c2c830f3eb7a135860a318344372275efffcf5b0" alt=""
Create Agent
data:image/s3,"s3://crabby-images/f162f/f162f2760975d210623ceca7f4b3524f3db9c3c3" alt=""
步驟1: 新建代理人 Create Agent (optional) (2/2)
輸入代理人名稱
設定預設語言別
綁定Google專案
步驟2: 建立意圖 (Create Intent)
測試主控台
建立新的意圖
預設Intents
data:image/s3,"s3://crabby-images/067dd/067dd32690baafb60dc7f072fb3f3d58dd4b6d41" alt=""
已產生兩個Intents: Fallback, Welcome
輸入測試語句
何時觸發Welcome? 偵測到「開始對話」的語句
何時觸發Fallback? 偵測到agent不了解的語句
data:image/s3,"s3://crabby-images/b1c68/b1c68d824e82823cd31cbb4f2878522bb9af4fb5" alt=""
Intent指的是某句子中的意圖(intention)
我要預約
明天天氣預報
你們店怎麼去?
使用者字句
可能的意圖
預約
查詢天氣
查詢地址
Intent指的是某句子中的意圖(intention)
我要預約
明天天氣預報
你們店怎麼去?
使用者字句
可能的意圖
預約
查詢天氣
查詢地址
data:image/s3,"s3://crabby-images/b1c68/b1c68d824e82823cd31cbb4f2878522bb9af4fb5" alt=""
訓練用片語
執行動作與參數
回應
步驟2-1: 制定Welcome意圖 (Create Intent)
2-1-1 客製化Welcome意圖:需符合系統目標、Bot的人設
data:image/s3,"s3://crabby-images/42deb/42deb252f855f4d6d3a71e4fa6040aa0f481f469" alt=""
❸存檔
❶ 刪除預設回應訊息
❷ 新增回應訊息如上
歡迎光臨!你想知道本店營業時間,還是想要預約來店?
步驟2-1: 制定Welcome意圖 (Create Intent)
❸訓練用片語都可用來測試看看
❶ 輸入測試的句子
❷ 查看是否出現回應訊息
data:image/s3,"s3://crabby-images/e8192/e81929ef5cc51bf3f8f14c0e5bc0366c0d715683" alt=""
2-1-1 客製化Welcome意圖:需符合系統目標、Bot的人設
步驟2-1: 制定Welcome意圖 (Create Intent)
❶ 多加幾種不同的歡迎詞
2-1-2 建立回應訊息的變形
data:image/s3,"s3://crabby-images/ec759/ec75960c951bb383a372db4d69abc5bea71d2b33" alt=""
❷ 存檔後測試
你好!我可以告訴你本店營業時間,也可以幫你預約,你需要什麼服務呢?
嗨!有什麼需要幫忙的嗎?我可以告訴你本店營業時間,也能幫你預約來店。
步驟2-2: 建立自訂意圖 (Custom Intent)
❶ 建立新的意圖
2-2-1 兩個工作: 告知營業時間、預約 ➔ 自訂意圖
data:image/s3,"s3://crabby-images/6e8c7/6e8c7220f71db1f0c9f940740f065d7f6b19462d" alt=""
步驟2-2: 建立自訂意圖 (Custom Intent)
❶ 輸入意圖名稱
2-2-1 兩個工作: 告知營業時間、預約 ➔ 自訂意圖
data:image/s3,"s3://crabby-images/2cf24/2cf242a64a3cb416fbd01419d83cd0eefa77543e" alt=""
❷ 存檔
❸ 新增訓練用片語
步驟2-2: 建立自訂意圖 (Custom Intent)
❶ 輸入多個訓練用片語
2-2-2 新增訓練用片語
❷ 存檔
data:image/s3,"s3://crabby-images/5d7e2/5d7e2c648b4262764d76b1e86b88e155a80853d9" alt=""
步驟2-2: 建立自訂意圖 (Custom Intent)
❶ 輸入多個回應訊息
2-2-3 建立回應訊息
❷ 存檔
data:image/s3,"s3://crabby-images/571e1/571e1edef8a13d3b06367f86618cb19b6eba7aea" alt=""
步驟2-3: 制定Fallback意圖 (Fallback Intent)
2-3 不了解使用者字句時,觸發Fallback意圖
❸存檔
❶ 刪除預設回應訊息
❷ 新增回應訊息如上
抱歉,請問你是要詢問營業時間?還是要預約來店呢?
data:image/s3,"s3://crabby-images/a0941/a094181347f516321e7c4913fab85ac6e74c76bb" alt=""
不好意思,請問你是想知道營業時間?還是要預約呢?
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
「預約」意圖必須能夠處理更複雜的句子
data:image/s3,"s3://crabby-images/59823/598236961e86220b4fe6cee96e283ef340efda29" alt=""
❶ 辨識出3 PM, today為重要資訊
❷ 回應訊息附上剛提及的日期、時間資訊
Dialogflow要能辨識重要資訊、並將之儲存
參數(parameters), 每個辨識出來的參數都有自己的實體型別(entity type)
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-1 新增「預約」意圖
❶ 輸入我要預約今天下午三點
data:image/s3,"s3://crabby-images/8ee7a/8ee7a021c66b0f2052843316f004752f0df47931" alt=""
❷ 系統自動偵測出兩個參數
或
手動標示兩個參數並選擇正確的entity type
❸存檔
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-1 新增「預約」意圖(續)
❶ 回應訊息輸入上列文字
❷存檔
data:image/s3,"s3://crabby-images/175bd/175bde228f67333092109f7a754e3eb50fb19cb6" alt=""
收到!為你預約 $date 時間是 $time 來店賞車,期待你的光臨。
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-2 加入更多的訓練用片語
❶ 加入更多訓練用片語
❷存檔
data:image/s3,"s3://crabby-images/a38fa/a38fafd9319d19be22f19534796b6d6b2d0a4683" alt=""
我想看看最新款的單車
包含一些不含日期時間的句子
我的車壞了
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-3 設定「參數」為必要資訊 (slot filling)
❶ 勾選為「必要」REQUIRED參數
我想看看最新款的單車
❷ 打開Define prompts,輸入後續提示字句
我的車壞了
data:image/s3,"s3://crabby-images/57d00/57d00cfe6007c2f3ddab2ae0dd80642444b128d1" alt=""
使用者輸入的句子經常不包含日期、時間,要如何預約
❸存檔
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-4 填入「參數」缺少時的提示訊息 (slot filling)
❶ 加入後續提示字句
data:image/s3,"s3://crabby-images/603c5/603c5cbdb0ece4af5203a165e8473ad9748e5dca" alt=""
以缺少日期為例,輸入後續Bot應該回應的問句
data:image/s3,"s3://crabby-images/4731a/4731a9f9be916812fd8cfb01f4c1f2b9afb605a2" alt=""
❷存檔
步驟2-4: 建立「預約」自訂意圖 (Intent with parameters)
2-4-4 填入「參數」缺少時的提示訊息 (slot filling)
data:image/s3,"s3://crabby-images/07db1/07db1100607072930403f160349657cde0e7409b" alt=""
❶ 加入後續提示字句
缺少「時間」時,後續Bot應該回應的問句
❷存檔
步驟2-5: 呼叫「預約」程式 (fulfillment using webhook)
預約若要記錄下來,需要外部程式(透過webhook)協助完成
data:image/s3,"s3://crabby-images/0a1b7/0a1b7971d6cf36f832582d981ad4f85bfd2c3694" alt=""
Fulfillment運作示意圖
Fulfillment: 用來解決使用者要求的「外部服務」
(用量超過一定數量需付費)
步驟2-5: 呼叫「預約」程式 (fulfillment using webhook)
目標:Dialogflow收到「日期」、「時間」,記錄到Google日曆
data:image/s3,"s3://crabby-images/57536/5753652e71277995f7853fd3907b7f961881444a" alt=""
data:image/s3,"s3://crabby-images/a38fa/a38fafd9319d19be22f19534796b6d6b2d0a4683" alt=""
❶ 開啟wehook call選項
❷存檔
前往「預約」intent
webhook外部服務:使用內建編輯器inline editor, 支援node.js程式
步驟2-5: 呼叫「預約」程式 (fulfillment using webhook)
❶ 開啟inline editor選項
fulfillments
data:image/s3,"s3://crabby-images/72ed0/72ed0e408a7e9b882d8595c732439a11d72b7bdd" alt=""
❷ 在此處寫程式
❸ 部署
步驟2-5: 呼叫「預約」程式 (fulfillment using webhook)
{
"name": "DialogflowFirebaseWebhook",
"description": "Firebase Webhook dependencies for a Dialogflow agent.",
"version": "0.0.1",
"private": true,
"license": "Apache Version 2.0",
"author": "Google Inc.",
"engines": {
"node": "6"
},
"scripts": {
"lint": "semistandard --fix \"**/*.js\"",
"start": "firebase deploy --only functions",
"deploy": "firebase deploy --only functions"
},
"dependencies": {
"firebase-functions": "^2.0.2",
"firebase-admin": "^5.13.1",
"googleapis": "^27.0.0",
"actions-on-google": "2.2.0",
"dialogflow-fulfillment": "0.5.0"
}
}
data:image/s3,"s3://crabby-images/c214a/c214ad8dca82408d3cbdbc805023e191b350badf" alt=""
貼至package.json的內容
刪除原package.json的內容
步驟2-5: 呼叫「預約」程式 (fulfillment using webhook)
/**
* Copyright 2017 Google Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
'use strict';
const functions = require('firebase-functions');
const {google} = require('googleapis');
const {WebhookClient} = require('dialogflow-fulfillment');
// 需輸入Google Calander API裡的 calendar ID and service account JSON
const calendarId = '此處換成CALENDAR ID'; // Example: 6ujc6j6rgfk02cp02vg6h38cs0@group.calendar.google.com
const serviceAccount = {}; // 貼上JSON物件,The JSON object looks like: { "type": "service_account", ... }
// 設定 Google Calendar service account credentials
const serviceAccountAuth = new google.auth.JWT({
email: serviceAccount.client_email,
key: serviceAccount.private_key,
scopes: 'https://www.googleapis.com/auth/calendar'
});
const calendar = google.calendar('v3');
process.env.DEBUG = 'dialogflow:*'; // It enables lib debugging statements
const timeZone = 'America/Los_Angeles'; // Change it to your time zone
const timeZoneOffset = '-07:00'; // Change it to your time zone offset
exports.dialogflowFirebaseFulfillment = functions.https.onRequest((request, response) => {
const agent = new WebhookClient({ request, response });
function makeAppointment (agent) {
// Use the Dialogflow's date and time parameters to create Javascript Date instances, 'dateTimeStart' and 'dateTimeEnd',
// which are used to specify the appointment's time.
const appointmentDuration = 1;// Define the length of the appointment to be one hour.
const dateTimeStart = convertParametersDate(agent.parameters.date, agent.parameters.time);
const dateTimeEnd = addHours(dateTimeStart, appointmentDuration);
const appointmentTimeString = getLocaleTimeString(dateTimeStart);
const appointmentDateString = getLocaleDateString(dateTimeStart);
// Check the availability of the time slot and set up an appointment if the time slot is available on the calendar
return createCalendarEvent(dateTimeStart, dateTimeEnd).then(() => {
agent.add(`Got it. I have your appointment scheduled on ${appointmentDateString} at ${appointmentTimeString}. See you soon. Good-bye.`);
}).catch(() => {
agent.add(`Sorry, we're booked on ${appointmentDateString} at ${appointmentTimeString}. Is there anything else I can do for you?`);
});
}
let intentMap = new Map();
intentMap.set('Make Appointment', makeAppointment); // It maps the intent 'Make Appointment' to the function 'makeAppointment()'
agent.handleRequest(intentMap);
});
function createCalendarEvent (dateTimeStart, dateTimeEnd) {
return new Promise((resolve, reject) => {
calendar.events.list({ // List all events in the specified time period
auth: serviceAccountAuth,
calendarId: calendarId,
timeMin: dateTimeStart.toISOString(),
timeMax: dateTimeEnd.toISOString()
}, (err, calendarResponse) => {
// Check if there exists any event on the calendar given the specified the time period
if (err || calendarResponse.data.items.length > 0) {
reject(err || new Error('Requested time conflicts with another appointment'));
} else {
// Create an event for the requested time period
calendar.events.insert({ auth: serviceAccountAuth,
calendarId: calendarId,
resource: {summary: 'Bike Appointment',
start: {dateTime: dateTimeStart},
end: {dateTime: dateTimeEnd}}
}, (err, event) => {
err ? reject(err) : resolve(event);
}
);
}
});
});
}
// A helper function that receives Dialogflow's 'date' and 'time' parameters and creates a Date instance.
function convertParametersDate(date, time){
return new Date(Date.parse(date.split('T')[0] + 'T' + time.split('T')[1].split('-')[0] + timeZoneOffset));
}
// A helper function that adds the integer value of 'hoursToAdd' to the Date instance 'dateObj' and returns a new Data instance.
function addHours(dateObj, hoursToAdd){
return new Date(new Date(dateObj).setHours(dateObj.getHours() + hoursToAdd));
}
// A helper function that converts the Date instance 'dateObj' into a string that represents this time in English.
function getLocaleTimeString(dateObj){
return dateObj.toLocaleTimeString('en-US', { hour: 'numeric', hour12: true, timeZone: timeZone });
}
// A helper function that converts the Date instance 'dateObj' into a string that represents this date in English.
function getLocaleDateString(dateObj){
return dateObj.toLocaleDateString('en-US', { weekday: 'long', month: 'long', day: 'numeric', timeZone: timeZone });
}
貼至index.js的內容
data:image/s3,"s3://crabby-images/869c4/869c47c8600d397c2ac94d960cfdebff7857b91e" alt=""
刪除原index.js的內容
需要Google Calendar API的金鑰☟
data:image/s3,"s3://crabby-images/7ee1a/7ee1ab87481a2c1e3033c2be1ae18c211e1c99ff" alt=""
取得金鑰的方式
data:image/s3,"s3://crabby-images/3ee28/3ee28a76c55fde3f5fa2720b249781a73d0fa6a4" alt=""
data:image/s3,"s3://crabby-images/937fb/937fb9dea9663f4aec306cdeaf07b05d9f66484a" alt=""
data:image/s3,"s3://crabby-images/64886/6488689cc173205774479299887e5d80a767f57b" alt=""
data:image/s3,"s3://crabby-images/d6f68/d6f68d82bd9fd09aa022c4a1d95b59b2b5886f49" alt=""
❸
❶
❷
找到Google Calendar API的卡片,啟動
取得金鑰的方式
❶
❷
data:image/s3,"s3://crabby-images/ba794/ba7945de8d89ee1eeddfbafb7bf9a81ec08bcd5f" alt=""
data:image/s3,"s3://crabby-images/648ab/648ab3ad96b4a9c35279f8f5f1bd40da8cf7fd5c" alt=""
❸
取得金鑰的方式
❶ 填入名稱與ID,值可相同
❷
data:image/s3,"s3://crabby-images/73515/73515ba7a422ed641a3750c68dd631ab4ffdf88e" alt=""
取得金鑰的方式
❶ 點入服務帳戶
❷
data:image/s3,"s3://crabby-images/770ba/770ba6178b18d03c06423599584aa9e55fcef111" alt=""
❸
按下建立,會提示下載檔案,存檔
練習時間
設計Chatbot就是在設計軟體系統
軟體工程的方法論都可派上用場
軟體工具
data:image/s3,"s3://crabby-images/9b207/9b2074deae251d2c5e62439d154c72bdc87c22a7" alt=""
心智圖
data:image/s3,"s3://crabby-images/f51c9/f51c9d2655b9a09748c3acada35f462adf19fe0d" alt=""
試算表
需求發想:User Story
客戶需求
- 要有淡水的交通資訊
捷運、客運、自行車、開車、搭船 - 淡水景點介紹
根據GPS位置顯示景點、呼叫google導航... - 美食介紹與評論
呼叫google導航、評論店家...
- 淡水天氣資訊
串接氣象資料 - 好康折價券
根據GPS位置顯示景點...
data:image/s3,"s3://crabby-images/76c51/76c51e67e470e0b43a253ac7cc43a7b8c1947ad5" alt=""
功能發想:功能性需求
資料盤點
需求發想
Persona
需求發想
資料搜尋四種樣態
循序漸進...
Chatbot實作工作坊
By Leuo-Hong Wang
Chatbot實作工作坊
- 466