相對比較新的一個(gè)模塊mod_httapi 可以支持用戶更加動(dòng)態(tài)控制IVR和其他的應(yīng)用程序。配合這個(gè)模塊,通過用戶輸入的不同可以生成自定義的IVR。FreeSWITCH的mod_httapi采用了一個(gè)簡單的HTTP POST操作對頁面應(yīng)用程序發(fā)送各種信息,通過RESTful的實(shí)現(xiàn)方式來控制FreeSWITCH 呼叫流程。在中國章節(jié),我們將討論以下內(nèi)容:
· HTTAPI 標(biāo)記語法
· HTTAPI 配置
· 基本HTTAPI 操作,包括httapi 撥號規(guī)則應(yīng)用
· 一個(gè)PHP樣本庫,使得HTTAPI 應(yīng)用開發(fā)更加簡單
當(dāng)用戶閱讀這個(gè)章節(jié)時(shí),必須牢記mod_httapi 使用了一個(gè)循環(huán)呼叫處理的流程;一個(gè)單個(gè)的呼叫,對于web服務(wù)器來說,有多個(gè)重復(fù)的HTTP POST請求。
這樣給了應(yīng)用開發(fā)人員更大的靈活性來設(shè)計(jì)他們的應(yīng)用模塊。沒有必要在單個(gè)響應(yīng)中生成所有可能的呼叫邏輯。一個(gè)被httapi應(yīng)用控制的呼叫將執(zhí)行在HTTP中指定的響應(yīng)命令,然后對web服務(wù)器發(fā)送另外一個(gè)HTTP POST請求。實(shí)際上,這個(gè)httapi 應(yīng)用獲得從web 服務(wù)器端來的指令,處理這些指令,然后對web 服務(wù)器端說,"我已經(jīng)完成了那些指令,下一個(gè)指令是什么?"。這個(gè)循環(huán)會(huì)一直進(jìn)行,直到呼叫結(jié)束或這個(gè)呼叫被轉(zhuǎn)接到其他流程,超出了httapi 撥號規(guī)則應(yīng)用的控制。
HTTAPI語法
HTTAPI標(biāo)志符和原始的XML語法沒有什么不同。大部分情況下,HTTAPI的語法構(gòu)成類似于這樣的:
<document type="text/freeswitch-httapi">
<variables/>
<params/>
<work/>
</document>
Document是從web 服務(wù)器HTTP POST請求響應(yīng)中返回的。
一個(gè)HTTAPI 響應(yīng)必須有text/xml的content type。所有HTTAPI 響應(yīng)必須包括document 標(biāo)簽,這個(gè)標(biāo)簽的類型屬性是text/freeswitch-httapi。在響應(yīng)的對端,指定的響應(yīng)中,用戶可以使用任意一個(gè)或者所有的子標(biāo)簽。支持的子標(biāo)簽如下:
· params: FreeSWITCH對每個(gè)web服務(wù)器請求發(fā)送的POST params(那是,"parameters") 。用戶可以使用<params> 標(biāo)簽通知FreeSWITCH傳遞自定義的POST params。
· variables: 這些變量是正在呼叫 httapi撥號規(guī)則應(yīng)用的通道變量。<variables> 標(biāo)簽支持用戶通道變量,這些變量可以在FreeSWITCH 撥號規(guī)則中使用或讀回到httapi 下一個(gè)請求中。(本章后續(xù)將詳細(xì)討論。)
· work: 很多有興趣的事情在這里發(fā)生。有很多不同的action標(biāo)簽可以作為<work>標(biāo)簽的子標(biāo)簽使用,通過這些標(biāo)簽來控制FreeSWITCH正在進(jìn)行的呼叫:在后臺進(jìn)行發(fā)送日志信息,播放語音文件,啟動(dòng)自動(dòng)語音識別,采集用戶輸入的DTMF按鍵數(shù)據(jù),和其他的控制。支持的action標(biāo)簽和屬性響應(yīng)的每一個(gè)action將在下一個(gè)部分進(jìn)行詳細(xì)討論。
以下許多的actions 可以對用戶的程序添加綁定,通過這樣的方式來獲得FreeSWITCH采集的信息,然后傳遞這些信息到用戶的應(yīng)用程序中。這樣的處理方式非常類似于頁面的HTML格式。每一個(gè)元素都有一個(gè)名稱,任何相對這個(gè)元素采集的數(shù)據(jù)將作為同名稱的POST param 返回到用戶的頁面程序中。這個(gè)綁定將支持一個(gè)正則表達(dá)式來匹配返回的結(jié)果,然后通過可選的數(shù)據(jù)前綴從輸入的值中來提取出最后的結(jié)果。
Work actions
HTTAPI work actions 在這個(gè)部分進(jìn)行了描述。在以下的定義中,*DATA* 是標(biāo)簽tag 的content (格式為, <tag>*DATA*</tag>)。
所有的work actions 至少支持兩個(gè)two標(biāo)簽:
· action: 修改新默認(rèn)目標(biāo)URL。
· temp-action: 修改URL提交下一個(gè)請求。后續(xù)的請求將使用默認(rèn)的URL或者使用在action標(biāo)簽指定的URL。
以下是一個(gè)work actions列表和他們的描述:
playback
Playback 播放一個(gè)文件,標(biāo)簽支持可選采集用戶輸入。它具有以下屬性:
· file: 播放語音文件的路徑
· name: 指定的Param名稱來保存結(jié)果
· error-file: 無效輸入時(shí),播放錯(cuò)誤提示文件
· digit-timeout: 播放文件完成后的等待輸入的時(shí)間 (輸入綁定時(shí))
· input-timeout: 多數(shù)字輸入時(shí),等待更多數(shù)字時(shí)間設(shè)置
· loops: 播放語音文件的最多次數(shù) (輸入綁定時(shí))
· asr-engine: 啟用自動(dòng)語音識別(ASR)引擎
· asr-grammar: 使用的自動(dòng)語音識別語法(ASR)
· terminators: 輸入結(jié)束鍵,一旦系統(tǒng)收到這個(gè)按鍵消息,立即停止采集,馬上處理采集的結(jié)果數(shù)據(jù)。
未完待續(xù)······