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