ms:rtc:saas:messagingInvitation
- JSON
Represents an invitation to a ms:rtc:saas:conversation for the ms:rtc:saas:messaging modality.
Web link
For more on web links, see Web Links.
Name | Description |
---|---|
rel | The resource that this link points to. In JSON, this is the outer container. |
href | The location of this resource on the server, and the target of an HTTP operation. |
Resource description
This resource can be incoming or outgoing. If outgoing, the messagingInvitation can be created in one of two ways. First, startMessaging will create a messagingInvitation that also creates a ms:rtc:saas:conversation. Second, ms:rtc:saas:addMessaging will attempt to add the ms:rtc:saas:messaging modality to an existing ms:rtc:saas:conversation. This resource helps keep track of the invitation status; for example, the invitation could be accepted, declined, or ignored. An outgoing messagingInvitation will be in the 'Connecting' state while waiting for the recipient to accept or decline it; during this time, the messagingInvitation can be terminated using ms:rtc:saas:cancel. Note that if the recipient does not respond in approximately thirty seconds, the messagingInvitation will complete with failure. Ultimately, the messagingInvitation will complete with success or failure (in which case a reason is supplied). If the messagingInvitation succeeds, the participant that accepts will be provided (ms:rtc:saas:acceptedByParticipant). If incoming, the messagingInvitation may either create a brand new ms:rtc:saas:conversation or attempt to add the ms:rtc:saas:messaging modality to an existing ms:rtc:saas:conversation.
Properties
Name | Description |
---|---|
customContent | Custom Content. |
direction | Gets the direction of the invitation. |
importance | Gets the importance. |
Gets the first message represented in this invitation. | |
operationId |
Gets the operation id as supplied by the client.
The maximum length is 50 characters. |
state | Gets the invitation state. |
subject |
Gets the subject.
The maximum length is 250 characters. |
threadId | Gets the thread id of the conversation. |
to | Gets the target of this invitation. |
Links
This resource can have the following relationships.
Link | Description |
---|---|
self | The link to the current resource. |
ms:rtc:saas:acceptAndBridge | accept an incoming invitation and bridge with conference |
ms:rtc:saas:accept | Accepts an incoming invitation. |
ms:rtc:saas:cancel | Cancels the corresponding invitation. |
ms:rtc:saas:conversation | Represents the local participant's perspective on a multi-modal, multi-party communication. |
ms:rtc:saas:decline | Declines an incoming invitation. |
ms:rtc:saas:from | Represents the ms:rtc:saas:participant that sent an invitation. |
ms:rtc:saas:messaging | Represents the instant messaging modality in a ms:rtc:saas:conversation. |
ms:rtc:saas:startAdhocMeeting | Represents an link to a resource that, if this invitation succeeded, will be replaced |
ms:rtc:saas:acceptedByParticipant | Represents the remote participant who accepted the invitation of the user. |
ms:rtc:saas:application | Represents your real-time communication application. |
ms:rtc:saas:from | Represents the ms:rtc:saas:participant that sent an invitation. |
Events
- started
- updated
- completed
Resource | Priority | Sender | Reason |
---|---|---|---|
ms:rtc:saas:messagingInvitation | High | ms:rtc:saas:communication | Delivered when a messaging invitation is started. This occurs when the application starts a messaging modality. |
Sample of returned event data.
This sample is given only as an illustration of event syntax. The semantic content is not guaranteed to correspond to a valid scenario.
{ "_links" : { "self" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=63" }, "next" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=63" } }, "sender" : [ { "rel" : "ms:rtc:saas:communication", "href" : "communication", "events" : [ { "link" : { "rel" : "ms:rtc:saas:messagingInvitation", "href" : "communication/invitations/928" }, "type" : "started" } ] } ] }
Resource | Priority | Sender | Reason |
---|---|---|---|
ms:rtc:saas:messagingInvitation | High | ms:rtc:saas:communication | Delivered when the messaging invitiation is updated. |
Sample of returned event data.
This sample is given only as an illustration of event syntax. The semantic content is not guaranteed to correspond to a valid scenario.
{ "_links" : { "self" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=53" }, "next" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=53" } }, "sender" : [ { "rel" : "ms:rtc:saas:communication", "href" : "communication", "events" : [ { "link" : { "rel" : "ms:rtc:saas:messagingInvitation", "href" : "communication/invitations/928" }, "type" : "updated" } ] } ] }
Resource | Priority | Sender | Reason |
---|---|---|---|
ms:rtc:saas:messagingInvitation | High | ms:rtc:saas:communication | Delivered when the messaging invitation completes. |
Sample of returned event data.
This sample is given only as an illustration of event syntax. The semantic content is not guaranteed to correspond to a valid scenario.
{ "_links" : { "self" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=22" }, "next" : { "href" : "http://sample:80/ucwa/v1/applications/appId/events?ack=22" } }, "sender" : [ { "rel" : "ms:rtc:saas:communication", "href" : "communication", "events" : [ { "link" : { "rel" : "ms:rtc:saas:messagingInvitation", "href" : "communication/invitations/928" }, "type" : "completed" } ] } ] }
Asynchronous reason codes
The completed event is sent on the event channel when the operation is finished. A status value of "success" indicates that the operation completed successfully.A status value of "failure" indicates that the operation failed. In case of failure, the error code and subcode are sent on the event channel.The following table shows the errors that are possible for this resource.
It is recommended that applications handle the error codes shown here. Applications can optionally display subcodes and messages in their user interface.
- Conflict
- EntityTooLarge
- Forbidden
- Gone
- Informational
- LocalFailure
- NotFound
- RemoteFailure
- ServiceFailure
- Timeout
Subcode | Reason |
---|---|
AlreadyExists | There was a problem joining the conference focus. |
AlreadyExists | |
None | There was a problem joining the conference focus. |
None | |
None | The resource is being deleted. |
TooManyGroups |
Subcode | Reason |
---|---|
None | The request was too large. |
Subcode | Reason |
---|---|
AnonymousNotAllowed | This meeting does not allow dial-out by attendees. |
DialoutNotAllowed | This meeting does not allow dial-out by attendees. |
FederationRequired | Federation required. |
InviteesOnly | User not allowed in closed meeting. |
ModalityNotSupported | The remote client does not support the requested modality. |
ModalityNotSupported | The requested modality is not allowed in the conference. |
None | Participant is not connected to meeting. |
Unreachable | The destination is not reachable. |
Subcode | Reason |
---|---|
CannotRedirect |
Subcode | Reason |
---|---|
Canceled | Request was canceled. |
ConnectedElsewhere | The invitation was accepted at another location. |
DerivedConversation | A derived conversation was created. |
MediaFallback | The invitation was cancelled by the media fallback logic. |
Missed | The invitation was missed. |
Subcode | Reason |
---|---|
Canceled | Invitation was canceled by local user. |
Declined | Invitation was declined by local user. |
None | Local Failure. |
Timeout | The invitation timed out locally. |
Subcode | Reason |
---|---|
DestinationNotFound | The destination identity could not be found. |
Subcode | Reason |
---|---|
AnotherOperationPending | Remote Failure with another operation pending. |
Busy | The remote side indicated that it is too busy at this time to accept the invitation. |
Canceled | Invitation canceled by remote user. |
Declined | Outgoing invitation declined. |
DoNotDisturb | The remote party does not want to be disturbed at this time. |
None | Remote Failure. |
NotAcceptable | The remote client is unable to accept the call at this time or context. |
NotAllowed | The remote party is not allowed to process this request due to policy. |
RepliedWithOtherModality | Replied with other modality. |
TemporarilyUnavailable | Some service is temporarily unavailable. |
TemporarilyUnavailable | Remote is temporarily unavailable. |
ThreadIdAlreadyExists | The invitation was not accepted as the remote is already in a conversation with the same thread id. |
Timeout | The operation has timed out on the callee's end. |
UnsupportedMediaType | Unsupported media. |
Subcode | Reason |
---|---|
CallbackChannelError | |
Forwarded | Forward request failed. |
InvalidExchangeServerVersion | |
MediaNegotiationFailure | Media negotation failed. |
MediaNegotiationTimeOut | Media negotation timed out. |
None | Internal Server Error. |
Timeout | The operation timed out. |
Unavailable | There is no suitable service available for this modality in this conference. |
Subcode | Reason |
---|---|
None | The operation has timed out. |
Operations
Returns a representation of an invitation to a ms:rtc:saas:conversation for the ms:rtc:saas:messaging modality.
Request body
None
Response body
The response from a GET request contains the properties and links shown in the Properties and Links sections at the top of this page.
Synchronous errors
The errors below (if any) are specific to this resource. Generic errors that can apply to any resource are covered in Generic synchronous errors.
Error | Code | Subcode | Description |
---|---|---|---|
BadRequest | 400 | None | Something is wrong with the entire request (malformed XML/JSON, for example). |
BadRequest | 400 | ParameterValidationFailure | Wrong Parameters provided for the request (for example, the requested conference subject exceeds the maximum length). |
Gone | 410 | None | The content-type is not supported. |
NotFound | 404 | None | The resource does not exist. |
ServiceFailure | 500 | InvalidExchangeServerVersion | |
Conflict | 409 | AlreadyExists | |
Conflict | 409 | TooManyGroups | |
Conflict | 409 | None | |
Gone | 410 | CannotRedirect |
Examples
Request
JSON Response
This sample is given only as an illustration of response syntax. The semantic content is not guaranteed to correspond to a valid scenario.