關(guān)鍵詞 Parlay API 呼叫禁止業(yè)務 下一代業(yè)務
一、引言
Parlay API(Application Programming Interface)是一種基于分布式技術(shù)的、開放的、面向?qū)ο蟮南乱淮鷺I(yè)務開發(fā)技術(shù),它通過協(xié)議映射技術(shù)把底層網(wǎng)絡(luò)的通信細節(jié)抽象成標準的API形式供業(yè)務開發(fā)者開發(fā)業(yè)務邏輯程序。它帶來的好處是降低了業(yè)務開發(fā)的技術(shù)門檻,能使業(yè)務開發(fā)者更快捷地滿足用戶的個性化需要,提供豐富多彩的業(yè)務,為下一代網(wǎng)絡(luò)的應用和發(fā)展提供最有效的驅(qū)動力。
框架服務器接口和業(yè)務能力接口是Parlay API定義的兩類主要接口。業(yè)務邏輯程序通過Parlay網(wǎng)關(guān)中框架服務器接口鑒權(quán)后,被授權(quán)接入規(guī)定的業(yè)務,然后使用框架服務器接口提供的業(yè)務能力發(fā)現(xiàn)和業(yè)務能力選擇功能,通過簽訂在線業(yè)務能力使用協(xié)議,獲得在框架服務器中注冊的、滿足業(yè)務需求的業(yè)務能力管理類接口引用。業(yè)務邏輯通過獲得業(yè)務能力管理類接口引用就可以和其對應的業(yè)務能力接口進行通信,實現(xiàn)特定業(yè)務邏輯的呼叫控制、用戶交互、計費等功能。文本主要在結(jié)合實踐的基礎(chǔ)上,說明如何實現(xiàn)基于Parlay API技術(shù)的呼叫禁止業(yè)務的基本功能。
二、業(yè)務功能結(jié)構(gòu)
當主叫用戶呼叫申請了呼叫禁止業(yè)務的用戶時,要求主叫用戶輸入被叫的設(shè)定的PIN(Personal Identification Number)碼,如果呼叫禁止業(yè)務邏輯發(fā)現(xiàn)輸入的PIN碼正確,則允許把該呼叫接續(xù)到被叫用戶目的地址,否則提示主叫用戶并禁止該呼叫。
呼叫禁止業(yè)務功能結(jié)構(gòu)由框架接入模塊、業(yè)務消息通知接口、業(yè)務話音管理模塊、業(yè)務處理模塊、后臺數(shù)據(jù)庫和業(yè)務支撐接口六部分組成。
框架接入模塊通過Parlay網(wǎng)關(guān)框架服務器接口提供的接入鑒權(quán)、授權(quán)、業(yè)務能力發(fā)現(xiàn)、業(yè)務能力選擇等功能獲得呼叫禁止業(yè)務邏輯所需的一般呼叫控制能力管理類接口對象引用和用戶交互能力管理類接口對象引用。業(yè)務邏輯使用一般呼叫控制能力管理類接口對象的方法要求Parlay網(wǎng)關(guān)上報定制的呼叫禁止業(yè)務事件,使用用戶交互能力管理類接口對象方法創(chuàng)建用戶信息交互對象,向用戶發(fā)送系統(tǒng)提示音收集用戶輸入的交互信息。
呼叫禁止業(yè)務邏輯通過業(yè)務消息接口收集Parlay網(wǎng)關(guān)的呼叫消息和用戶交互信息,它們也是標準的Parlay API接口,由Parlay網(wǎng)關(guān)使用對象回調(diào)的方式調(diào)用呼叫禁止業(yè)務邏輯提供的這些接口對象中的方法,實現(xiàn)消息的傳遞。業(yè)務消息接口根據(jù)消息類型和業(yè)務邏輯當前狀態(tài)把接收到的消息傳遞給業(yè)務話音管理模塊和業(yè)務處理模塊。
業(yè)務話音管理模塊的功能主要是允許用戶在系統(tǒng)語音提示下在線設(shè)置、修改和刪除PIN碼;而業(yè)務處理模塊的功能主要是判斷主叫用戶輸入的PIN碼是否和被叫設(shè)置的PIN碼一致,以決定是否允許接續(xù)本次呼叫到被叫用戶。它們都涉及到對后臺數(shù)據(jù)庫的操作,主要是讀寫用戶設(shè)置的PIN碼信息。
業(yè)務支撐接口主要是接收和響應系統(tǒng)管理操作、業(yè)務管理操作、用戶管理操作和用戶業(yè)務定制操作,它在呼叫禁止業(yè)務邏輯產(chǎn)品化過程中占有重要的地位。
1. 框架接入消息交互
框架接入消息交互依照接入流程的先后次序由初始接入、業(yè)務能力發(fā)現(xiàn)和業(yè)務能力選擇三組交互序列組成。
在初始接入時業(yè)務邏輯框架接入模塊調(diào)用Parlay網(wǎng)關(guān)框架服務器通過名字服務方式向外公布的初始接入對象IpInitial的認證初始化方法InitialAuthentication,然后使用selectEncryptionMethod選擇和框架服務的鑒權(quán)機制。業(yè)務邏輯和框架服務需相互認證,只有當相互認證成功后,業(yè)務邏輯才可以調(diào)用requestAccess方法獲得一個IpAccess對象引用,業(yè)務邏輯通過調(diào)用該對象的selectSigningAlgorithm方法和框架服務器協(xié)商交易簽署算法。
業(yè)務邏輯在完成初始接入后,使用obtainInterface方法獲得框架服務器提供的業(yè)務發(fā)現(xiàn)接口對象,然后調(diào)用該對象的listServiceTypes方法列出在網(wǎng)絡(luò)中哪些業(yè)務能力類型被支持。業(yè)務邏輯在其獲得的業(yè)務能力類型列表中,使用describeServiceType方法獲得它所感興趣的一個確定業(yè)務類型的屬性,然后使用discoverService方法獲得跟它需要的業(yè)務屬性相匹配的已注冊的、包含業(yè)務能力標識符和特征描述的列表。
在業(yè)務能力發(fā)現(xiàn)過程中獲得的包含業(yè)務能力標識符和特征描述的列表中,包含有多個業(yè)務能力版本,它們通過serviceID來標識,在進行業(yè)務能力選擇時,業(yè)務邏輯從中確定其最終使用的業(yè)務能力,通過調(diào)用selectService方法獲得一個針對該業(yè)務能力的私有標識符,它被用在簽署業(yè)務能力使用條約的過程中。業(yè)務邏輯和框架服務器間相互簽署業(yè)務使用條約,如果簽署成功,則業(yè)務邏輯就獲得了一個指向該業(yè)務能力管理接口的引用。
在呼叫禁止業(yè)務邏輯使用上述流程獲得一般呼叫控制能力管理接口引用后,還需充分業(yè)務能力發(fā)現(xiàn)和業(yè)務能力選擇流程,以獲得用戶交互能力管理接口的引用。
2. 業(yè)務消息交互
呼叫禁止業(yè)務通過Parlay網(wǎng)關(guān)提供的一般呼叫控制對象和用戶交互對象下網(wǎng)絡(luò)發(fā)送消息,通過在業(yè)務消息接口中實現(xiàn)的一般呼叫控制應用對象和用戶交互應用對象接收Paraly網(wǎng)關(guān)的傳遞給業(yè)務邏輯的消息。
呼叫禁止業(yè)務邏輯在完成框架接入消息流程后。首先業(yè)務邏輯使用enableCallNotification方法要求Parlay網(wǎng)關(guān)通知底層網(wǎng)絡(luò)上報跟呼叫禁止業(yè)務相關(guān)的業(yè)務觸發(fā)事件,如上報對申請了呼叫禁止業(yè)務用戶的呼叫觸發(fā)事件,上報呼叫禁止業(yè)務話音管理觸發(fā)事件。Parlay網(wǎng)關(guān)通過一般呼叫控制應用對象的callEventNotifify方式上報業(yè)務觸發(fā)事件,根據(jù)事件類型,把消息傳遞給業(yè)務處理模塊或業(yè)務話音管理模塊。隨后業(yè)務模塊通過用戶交互對象向用戶發(fā)送提示音收集用戶信息,一般根據(jù)需要這樣的語音提示信息收集過程要進行多次。業(yè)務邏輯根據(jù)用戶信息決定業(yè)務邏輯后續(xù)執(zhí)行動作,如在業(yè)務處理模塊中,當獲得的主叫用戶輸入PIN碼和被叫用戶設(shè)定的PIN碼相同時,則使用Parlay網(wǎng)關(guān)的routeReq方法允許底層網(wǎng)絡(luò)接續(xù)本次呼叫。呼叫結(jié)束后需使用callEnded方法通知業(yè)務邏輯,業(yè)務邏輯使用deassignCall方法釋放Parlay網(wǎng)關(guān)中的呼叫對象和底層網(wǎng)絡(luò)中的相關(guān)呼叫資源。
四、業(yè)務模塊
業(yè)務模塊可分為業(yè)務處理模塊和業(yè)務話音管理模塊,它們是呼叫禁止業(yè)務邏輯的核心部分,在后臺數(shù)據(jù)庫的配合下,由它們實現(xiàn)呼叫禁止業(yè)務的業(yè)務處理和業(yè)務話音管理功能。
1. 業(yè)務處理模塊
當主叫用戶呼叫申請了呼叫禁止業(yè)務的用戶時,底層網(wǎng)絡(luò)交換設(shè)備把該初始呼叫事件通過Parlay網(wǎng)關(guān)上報給呼叫禁止業(yè)務邏輯,業(yè)務邏輯在其IpAppCallControlManager對象的callEventNotify方法中接收到該事件后,業(yè)務邏輯程序進入業(yè)務處理模塊,創(chuàng)建一個線程處理該呼叫,隨后使用Parlay網(wǎng)關(guān)IpUICall對象的sendInfoAndCollectReq方法向用戶發(fā)送系統(tǒng)提示音要求主叫用戶輸入被叫設(shè)定的PIN碼,業(yè)務邏輯邏輯通過其的IpAppUICall對象的sendInfoAndCollectRes收集到主叫輸入的PIN碼。
業(yè)務邏輯從后臺數(shù)據(jù)庫中讀出被叫用戶設(shè)定的PIN碼,并和收集到的主叫用戶輸入的PIN碼相比較,當不一致時,如果主叫用戶輸入錯誤PIN的次數(shù)沒有超過規(guī)定的最大次數(shù),則發(fā)送系統(tǒng)提示音告知用戶輸入PIN碼不正確,需重新輸入,如果主叫用戶輸入錯誤PIN的次數(shù)超過規(guī)定的最大次數(shù),則告訴用戶呼叫失敗,隨后釋放本次呼叫。
當主叫輸入的PIN碼和被叫設(shè)定的相一致時,終止和主叫用戶的信息交互,然后使用Parlay網(wǎng)關(guān)IpCall對象的routeReq方法運行底層網(wǎng)絡(luò)交換設(shè)備繼續(xù)本次呼叫,當呼叫結(jié)束時,Parlay網(wǎng)關(guān)上報呼叫結(jié)束事件,業(yè)務邏輯釋放本次呼叫對象和資源。
2. 業(yè)務話音管理模塊
呼叫禁止業(yè)務話音管理功能對應著一個特服號,當用戶撥打該特服號號時,Parlay網(wǎng)關(guān)通過調(diào)用業(yè)務邏輯的callEventNotify方法把來自底層網(wǎng)絡(luò)交換設(shè)備的該事件上報給業(yè)務邏輯,業(yè)務邏輯程序進入業(yè)務話音管理模塊,創(chuàng)建一個線程處理該業(yè)務話音管理呼叫,實現(xiàn)用戶PIN碼設(shè)定、刪除和修改功能。
業(yè)務邏輯查詢后臺數(shù)據(jù)庫該用戶是否已申請了呼叫禁止業(yè)務,如果沒有申請,則提示用戶是否要設(shè)定被叫時的PIN碼,如果用戶要求設(shè)定,則業(yè)務邏輯同樣通過Parlay網(wǎng)關(guān)的sendInfoAndCollectReq和業(yè)務邏輯的sendInfoAndCollectRes方法收集用戶設(shè)定的PIN碼,如果兩次輸入的PIN碼相同,則把該用戶和PIN碼對應的信息寫到后臺數(shù)據(jù)庫中,并提示用戶設(shè)定成功。
如果用戶已設(shè)定了被叫時的PIN碼,則提示用戶是否刪除或修改PIN碼。如果用戶選擇刪除PIN碼,則業(yè)務邏輯從后臺數(shù)據(jù)庫中清除該用戶設(shè)定的PIN碼,本次會話結(jié)束。如果用戶選擇修改PIN碼,則只有當用戶現(xiàn)正確輸入原PIN碼后,才可設(shè)定新的PIN碼。
五、結(jié)束語
Parlay API是進行下一代業(yè)務開發(fā)的重要技術(shù),作者通過對基于Parlay API的呼叫禁止業(yè)務的開發(fā),熟悉了Parlay API的基本原理,掌握了一定的業(yè)務邏輯工程實現(xiàn)技術(shù),為開發(fā)其他各種基于Parlay API技術(shù)的下一代業(yè)務奠定了技術(shù)基礎(chǔ)。
通信世界網(wǎng)(www.cww.net.cn)