Home

Call Flow

 

The call flow is as follows -

 

1.       The SaaS Application (SA) discovers the location of the Trusted Application API (API)

2.       The SA gets the capabilities,

3.       SA uses anonApplicationTokens resource to get a token and a ms:rtc:saas:discover link that can be shared with the anonymous chat client

4.       The chat client uses the ms:rtc:saas:discover link to get the anonApplications resource, which can be used to establish a ucwa session with the Trusted Application API

5.       The chat client establishes a ucwa session with the API and uses the token got from step 3, to authenticate itself.

6.       The chat client sends a messaging invitation to the helpdesk uri: sip:helpdesk@contoso.com

7.       The API sends a callback to the SA on receiving this messaging invitation, along with a resource called  ms:rtc:saas:startAdhocMeeting, another called ms:rtc:saas:acceptAndBridge and another called ms:rtc:saas:inviteUserToMeeting

 

8.       SA sees that it received a support request and spins up an on demand meeting, using the link in the resource ms:rtc:saas:startAdhocMeeting

9.       SA then uses the ms:rtc:saas:acceptAndBridge capability to bridge the incoming messaging invitation into the on demand meeting that it just created.

10.   SA receives a callback  - ms:rtc:saas:conversationBridge added event, meaning a new conversation bridge has been created. Calling a GET on this resource shows you another resource, which can be used to get or add bridge participants - ms:rtc:saas:bridgedParticipants.

11.   SA POSTs on the ms:rtc:saas:bridgedParticipants link to add the SFB online users who are handling the chat support requests to the conversation bridge. This request includes a messageFilterState parameter set to disabled. If enabled, it means that the messages sent by the participant are not sent to the chat client, and vice versa

 

12.   The SA does a POST on the ms:rtc:saas:sendMessage token link with a welcome text and gets callbacks informing that the message has been successfully sent.

13.   The chat client receives the message in its event channel

14.   SA then proceeds to add one or more participants to the meeting, using POST on the link of the resource - ms:rtc:saas:inviteUserToMeeting, got in step 7. These participants are the customer service representatives that will answer the chat support request, and are SFB online users.

15.   The SA gets a callback when the SFB Online user joined the IM meeting.

16.   If the SFB Online user is sending an "Is Typing" notification, it will be conveyed to the chat client on its event channel

17.   SFB online user sends a message, it will be conveyed to the chat client on its event channel

18.   The chat client now closes the conversation

19.   API sends a callback to the SA, indicating the conversation has been deleted.

20.   The SA then sends a request to terminate the conversation with the Trusted Application API

 

 

The way the API informs the SA of any event is via the callback url. In order for the SA to keep context when starting a new invitation or message, an operation id can be passed in. This id will be sent back in the callback event.

 

The general principles, capabilities, API style, API concepts are modeled to closely follow the already released UCWA API. Please see this link for detailed info - UCWA API reference

 

Being familiar with the UCWA concepts greatly simplifies understanding the Trusted Application APIs

 

 

The detailed call flow is shown in the diagram below. Each of the capability related APIs, related callbacks are modeled on the UCWA capabilities and callback structure. Please refer to the UCWA API reference to get detailed description about these  calls.

 

 

 

 

Machine generated alternative text:
Application 
"hrs": heyd4@Lcgytananttt-irdpatv.conl' 
on ink to the 'tckan" a-d " Inks 
Pcst ha ps//ext vdanSn.com:44S/4atfcrmzv 1/43p W 16272595 E4/ancrAp 4 
— — — — — — — — — — — — •uærætsStvpi-g— 
Trusted Application 
API 
— •rotfvchacléngated- — 
dScuer requ& 
GET ätps//ncemma i-gs reszurces 
Lin k to T Ap 4tatiorE API 
NO OK, " "Yr tc:zæ4pkaOrS' https//rhg2noamnæingsrsouces Vnccom/4atfcrn-Serv 
c i litis 
G ET Lrcs S,' rc.com/43fanfervice/vl/gyø Caions 
— 41 Lhauthorizø• — 
cap*ilitis with oa_lth tcken 
s curces /pÉtformSe-v I/gyplica 
AuthoriaOn: æara>XXX 
a-cnvnwus On to ka-s c*EbiItv : 
Anonymous chat 
client running on 
contoso.com 
SFB Online user 
"kWk", "SIcw±OrigirS': 
NO OK with to •n a-d rk 
"3prvTme: "2016-æ-27T014213.0342, 
three: 
url a-rd tck 
cebæk toSæS44Caion tatn a-rd w th opticns to an orderna-d mairg a-rd a wav to •e rwtaticn wth neetiæ. 
t cuÄmn cont&t frcm t cliant 
https//cléntvdo com txk 
'tv*": "ÄdtaI" 
" msrtcsæsÄatAdh:xMZingh f03S 
/cmn nwniGticn 'or' ætirgIrrvitaticnskart4d a-an ttt-irdpat•/ com"} 
e" { 'href": " /p*fcr 77cCS5eSzg22bcC737SI fcOS 7259584 
/cmn re Irwitatior4bG270 S-fcg2-43c5-b.3æ-CdEcOf2aI S *'acc *tars rd; e ? erd p: he 4JtenTItthi@dtv.com") 
"astonfonent' : "href": " &tafooffoo, ThSNRar&mCustm-ContelT" 
creae a-yd join t on &ma-pd 
rs'1627259584 
Subject": " "dbackIJrt' "https//cIÉlT.vdm-SncomSæg/&ItÄk", "*e' 
— El Crstø- — 
i-öcati-g a rew a rd a rew conver•icn hasbæn creas for the mains. 
https//cléntvdo nen.com txk 
"tvpe": 'Äat±" 
cebæk toSæSgypICaion rew anlinemæti-g hæ bean ad&d tot h?corwzsaOn, 
a-rd reszurce w trin thecomer•ion has n to alk:w mesæirg to the converstion 
https//cléntvdo com txk 
"re": " 'tspé': '%cEd' 
"re": " 'tv " up&tal" - urce- "msrtc 
by PoÄon " 
h a-a-ttt-ird patv.com&zo n.' asaOn d=1765 3" 
El &8tø- — 
ardgi-g m On into the new* c r*ed confaance: 
'p fdos 
/cmn nun c5-b.3æ-CdEcOf2aI SS/scc*tAncE rd-e ? erd phS$sk@LC4Jte r«ltthiccatv.com 
"cnireMZirglJrth 
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ 200 
caltxk with a resouce u the 
"msrtcsæs hrs": "/ c465eS:g22bc07S7e31 fdOS,KvI /g•pltaior$1627259584 
/cmnmunCaticn/conver•zticrs/64fe0722-8cß-4S47-851 n; asatn 
"re": " 'tv*' 
Add SFS anlineuær asa &dge 
rs'1627259584 
/cmn nun etim/corfver •ions/64fe3722-8254-447- *51- 'tk:tp TIE? 
"d$l*ané' : "jchn", " paticjHItUrt' "DiS31aI" 
— El Crstø- — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — 
ærpd v,' eome toc ha 
Ccnten-Tvpe: text/4*l; c raræt=Ltf-8, Lergth 15, Wetomc_stoner 
*bæk indtatiæ outgoirg 
https//cléntvdo com txk 
{"ret': , " tyef" "/ 77c465eScg22bc07S7SI f03S 
/comnw ne / erdpoi-td=sg 
'ÄZLS' : "convetg" 
SF 8 an ine to tte or-line meetiæ (ældiæ cha æe 
/pÉtformærvice,M Caior$1627259584/commLn Snghvt com 
"bozSJærDis;Ä Nare" : "ccntcsohSpd4", " tcSlJzlJrih "so k@ucgyte rantttntdpatv can" , "or' ætirglJrr' •p: UcaÄJæ gaucgyt 
"opa " "to": 
cebæk indtatiæ pa tici*nt to the metiæ 
https//cIÉntvdo rencomsæg/& txk 
"re" : " åtici , "href': " /p*forn-se-vt stgt-c397ß 177c465eS:g22b17S7e31633 627259584 
"Lk4JLE35"_ 'tv*": " æEaI" 
cebæk indtatiæ a pa tici*nt jciredthemæ.æi-g mcdaltv 
https//cléntvdo com txk 
"re:" "href': 
/comnw net im/corfver•ions/24gge2 8-8390-455 -BE 6-240±0129 æ/pa-ttipa-ts/uz 5@LK4Jte r«lt. can ?erd COM' 
'type" " 
muti4eceæcks to to Maeth& evens 
multi4ecebacks g•pIiGtOn to Odiae the de—e 
https//cIÉntvdo net-Lcom txk 
re:" "tvpe": "updaed', " Äæ": 
'tvpe": "d *ed' 
"re": " NT rtc:ææparticipa-dvl , 'tsp g': "dS3ed' 
"re": " 'tv*' : "dBeted' 
tam can vastOn 
Dee / 737201 fdos 
/cmn nun etion/a mer •icn$24gge29-839-4055- b2_56-2480831889 ?a-dpd IT 
— — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — — -u Noconent— — 
c*ltxk *4tation to ird 
https//cléntvdo net-Lcom txk 
"re": " NT " "cEı" 
GET an msltc url to find " token 
— Ga htqs•/ vcbman.cmn:444S/ rnservice/cf•ova? LECO 
Oren : hag//conosacom 
2000K 
arrcrApøt*cnS' : hrs' : 
Creae Llcua 'irk 
— ha ps//dtvdananco r/vl /gypltaia-& — 
"a-yo Nane": "Janadhan") 
231 
'Ädtfv18*irg" : : 
to uri custom cont&lt can be ha e 
POST 4'pæncn/vI/appIiGtOrs/1014S537532S/commuriaior/m8*i-gIrwtaOÆ 
" NO ed': " ,"to" : 'Sg rcbarvco M' ," 
201 
ms*e LKwaevetT 
use to ne2tiæ 
t requ& 
t ærdsa 
—LIZ ærdsa 
— -SFaor•neuær istvpiæ 
— —SF serdsa — 
— — — —l_ær dBetest —