Home

New Concepts

 

The call flows described earlier use some new communication concepts, on top of the familiar UCWA 2.0 concepts.  The following concepts are new to the Trusted Application API:

 

Do note that the concept and call flows are similar to UCWA 2.0, but the namespace for the tokens have ms:rtc:saas prefix, for all the Trusted Applications API tokens.

 

1.       Discovery for SaaS Applications

 

The discovery process that the SaaS applications use is different from the UCWA autodiscover flow. There is a standard url that the SaaS applications use for discovery - https://noammeetings.resources.lync.com/platformservice/discover

 

A GET on this url, will return a ms:rtc:saas:applications resource, which is the starting point for the SaaS application scenarios.

 

More info here: Discovery for SaaS applications

 

2.       Discovery for anonymous clients

 

The anonymous clients follow a separate discovery process. The SaaS hands them a discover url and the anonymous clients GET on that url, to get an anonApplications resource, which is the starting point for the anonymous clients scenarios.

More info here: Discovery by chat client

 

 

3.       Anonymous Application Tokens:

 

When a SaaS application wants to allow anonymous clients to send chat invitations, we now require that the SA acquire an Anonymous Applications Token, and a discover link(ms:rtc:saas:discover), which can be shared with the anonymous client, in order to send messages.

The anonymous client would follow the discover link, find the Anonymous Applications link (anonApplications)and use it along with the anonymous applications token, to talk to the API to send messages

 

3.       Adhoc Meeting:

 

An Adhoc Meeting (or On demand Meeting) is a temporarily generated meeting with a limited expiration.  Default expiration time: 8 hours.  See http://trustedapplicationapi.azurewebsites.net/Resources/ms_rtc_saas_adhocMeetings.html

 

 

4.       Start Adhoc Meeting:

 

When a SaaS application wants to create an adhoc (aka on demand) meeting and join it as a trusted participant who has full access to all info pertaining to the meeting, it can POST on this resource (ms:rtc:saas:startAdhocMeeting). This avoids a two-step process of creating and then joining a meeting.

 

This link is available on the ms:rtc:saas:messagingInvitation event to allow creating and joining an adhoc meeting, and later bridging the messaging leg into a conference.

 

 

 

3.       Conversation Bridge:

 

When the API has to bridge communications between a peer to peer call and a conference, the SA creates a conversation bridge entity to connect the conference with the peer to peer call using this bridge.  In order to allow SfB Online users to send messages to the peer to peer call leg, your SA must add the users as bridged participants to the conversation bridge (if users are not bridged, the peer to peer call leg will not be able to see messages from those users. 

 

Eg. In a contact center supervisor scenario, your app may not bridge the supervisor, so a customer would not see their messages

 

Conceptually, an Conversation Bridge is similar Back-to-back Agent in UCMA, with some key differences:

 

-a Conversation Bridge can only connect a P2P call leg to a conference, unlike a Back-to-back agent which can connect two P2P call legs

 

-An Conversation Bridge (current release IM only) in the future can include multiple conversation modalities, and both Audio/Video and IM.

 

-A UCMA B2B User Agent can only connect 1 modality and only supports audio/video

 

 

4.       Message Filter:

 

Within a conversation bridge, the SA sometimes does not want to allow sending messages from a conversation bridge participant, who is an SFB online user, to the peer to peer leg, which has an anonymous user. To do this, the SA has to set a message filter state when adding the bridge participants to the conversation bridge. Message Filter State enabled means that the messages from the bridge participant SFB online user cannot be sent messages to the peer to peer client, and vice versa.

 

5.       Accept and Bridge:

 

In order to create a Conversation Bridge (when the SaaS wants to bridge an incoming invitation with an existing conference) it can use this Accept and Bridge link (this release includes IM only). This link is available on the incoming invitation and takes in a conference id as a request parameter.

 

6.       Callback Url:

 

See here for more details: The POST to callback url