Version: 3.1.12
This specification has moved to Agents SDK
The Bot Framework Activity schema is an application-level representation of conversational actions made by humans and automated software. The schema includes provisions for communicating text, multimedia, and non-content actions like social interactions and typing indicators.
This schema is used within the Bot Framework protocol and is implemented by Microsoft chat systems and by interoperable bots and clients from many sources.
- Introduction
- Basic activity structure
- Message activity
- Contact relation update activity
- Conversation update activity
- End of conversation activity
- Event activity
- Invoke activity
- Installation update activity
- Message delete activity
- Message update activity
- Message reaction activity
- Suggestion activity
- Trace activity
- Typing activity
- Handoff activity
- Command activity
- Command result activity
- Complex types
- References
- Appendix I - Changes
- Appendix II - Non-IRI entity types
- Appendix III - Protocols using the Invoke activity
- Appendix IV - Priming format
- Appendix V - Caller ID values
- Appendix VI - Protocols using the Command activity
The Bot Framework Activity schema represents conversational behaviors made by humans and automated software within chat applications, email, and other text interaction programs. Each activity object includes a type field and represents a single action: most commonly, sending text content, but also including multimedia attachments and non-content behaviors like a "like" button or a typing indicator.
This document provides meanings for each type of activity, and describes the required and optional fields that may be included. It also defines the roles of the client and server, and provides guidance on which fields are mastered by each participant, and which may be ignored.
There are three roles of consequence in this specification: clients, which send and receive activities on behalf of users; bots, which send and receive activities and are typically automated; and the channel, which stores and forwards activities between clients and bots.
Although this specification requires activities to be transmitted between roles, the exact nature of that transmission is not described here. This may be found instead in the companion Bot Framework Protocol specification [1].
For compactness, visual interactive cards are not defined in this specification. Instead, these are defined within the Bot Framework Cards [10] and Adaptive Cards [11] specifications. These cards, and other undefined card types, may be included as attachments within Bot Framework activities.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 [2].
An implementation is not compliant if it fails to satisfy one or more of the MUST or REQUIRED level requirements for the protocols it implements. An implementation that satisfies all the MUST or REQUIRED level and all the SHOULD level requirements for its protocols is said to be "unconditionally compliant"; one that satisfies all the MUST level requirements but not all the SHOULD level requirements for its protocols is said to be "conditionally compliant."
Explanatory text describes the intent. Editors are encouraged to omit normative statements from explanatory text. All numbered requirements are normative. All examples are non-normative.
Lines beginning with markers of the form AXXXX
are specific requirements designed to be referenced by number in discussion outside of this document. They do not carry any more or less weight than normative statements made outside of AXXXX
lines.
A1000
: Editors of this specification MAY add new AXXXX
requirements. They SHOULD find numeric AXXXX
values that preserve the document's flow.
A1001
: Editors MUST NOT renumber existing AXXXX
requirements.
A1002
: Editors MAY delete or revise AXXXX
requirements. If revised, editors SHOULD retain the existing AXXXX
value if the topic of the requirement remains largely intact.
A1003
: Editors SHOULD NOT reuse retired AXXXX
values. A list of deleted values MAY be maintained at the end of this document.
activity
An action expressed by a bot, a channel, or a client that conforms to the Activity schema.
channel
Software that sends and receives activities, and transforms them to and from chat or application behaviors. Channels are the authoritative store for activity data.
bot
Software that sends and receives activities, and generates automated, semi-automated, or entirely manual responses. Bots have endpoints that are registered with channels.
client
Software that sends and receives activities, typically on behalf of human users. Clients do not have endpoints.
sender
Software transmitting an activity.
receiver
Software accepting an activity.
endpoint
A programmatically addressable location where a bot or channel can receive activities.
address
An identifier or address where a user or bot can be contacted.
field
A named value within an activity or nested object.
The activity object is a flat list of name/value pairs, some of which are primitive objects, and some of which are complex (nested). The activity object is commonly expressed in the JSON format, but can also be projected into in-memory data structures in .Net or JavaScript.
The activity type
field controls the meaning of the activity and the fields contained within it. Depending on the role that a participant is playing (client, bot, or channel), each field is mandatory, optional, or ignored. For example, the id
field is mastered by the channel, and is mandatory in some circumstances, but ignored if it is sent by a bot.
Fields that describe the identity of the activity and any participants, such as the type
and from
fields, are shared across all activities. In many programming languages, it is convenient to organize these fields on a core base type from which other, more specific, activity types derive.
When storing or transmitting activities, some fields may be duplicated within the transport mechanism. For example, if an activity is transmitted via HTTP POST to a URL that includes the conversation ID, the receiver may infer its value without requiring it to be present within the activity body. This document merely describes the abstract requirements for these fields, and it is up to the controlling protocol to establish whether the values must be explicitly declared or if implicit or inferred values are allowed.
When a bot or client sends an activity to a channel, it is typically a request for the activity to be recorded. When a channel sends an activity to a bot or client, it is typically a notification that the activity has already been recorded.
This section defines the requirements for the basic structure of the activity object.
Activity objects include a flat list of name/value pairs, called fields. Fields may be primitive types. JSON is used as the common interchange format and although not all activities must be serialized to JSON at all times, they must be serializable to it. This allows implementations to rely on a simple set of conventions for handling known and unknown activity fields.
A2001
: Activities MUST be serializable to the JSON format defined in RFC 4627 [15], including adherence to e.g. field uniqueness constraints.
A2002
: Receivers MAY allow improperly-cased field names, although this is not required. Receivers MAY reject activities that do not include fields with the proper casing.
A2004
: Unless otherwise noted, senders SHOULD NOT include empty string values for string fields.
A2005
: Unless otherwise noted, senders MAY include additional fields within the activity or any nested complex objects. Receivers MUST accept fields they do not understand.
A2006
: Receivers SHOULD accept events of types they do not understand.
This document defines data types for fields used within the Activity object. These type definitions include a syntactic type (e.g. string
or complex type
) and in the case of strings, an optional format (e.g. ISO 8601 date time format [3]).
A2007
: Senders MUST adhere to data type definitions contained in this document.
A2003
: Receivers SHOULD reject activities that contain field values whose types do not match the data types described in this specification.
The type
field controls the meaning of each activity, and are by convention short strings (e.g. "message
"). Senders may define their own application-layer types, although they are encouraged to choose values that are unlikely to collide with future well-defined values. If senders use URIs as type values, they SHOULD NOT implement URI ladder comparisons to establish equivalence.
A2010
: Activities MUST include a type
field, with string value type.
A2011
: Two type
values are equivalent only if they are ordinally identical.
A2012
: A sender MAY generate activity type
values not defined in this document.
A2013
: A channel SHOULD reject activities of type it does not understand.
A2014
: A bot or client SHOULD ignore activities of type it does not understand.
The channelId
field establishes the channel and authoritative store for the activity. The value of the channelId
field is of type string.
A2020
: Activities MUST include a channelId
field, with string value type.
A2021
: Two channelId
values are equivalent only if they are ordinally identical.
A2022
: A channel MAY ignore or reject any activity it receives without an expected channelId
value.
The id
field establishes the identity for the activity once it has been recorded in the channel. Activities in-flight that have not yet been recorded do not have identities. Not all activities are assigned identities (for example, a typing activity may never be assigned an id
.) The value of the id
field is of type string.
A2030
: Channels SHOULD include an id
field if it is available for that activity.
A2031
: Clients and bots SHOULD NOT include an id
field in activities they generate.
For ease of implementation, it should be assumed that other participants do not have sophisticated knowledge of activity IDs, and that they will use only ordinal comparison to establish equivalency.
For example, a channel may use hex-encoded GUIDs for each activity ID. Even though GUIDs encoded in uppercase are logically equivalent to GUIDs encoded in lowercase, senders SHOULD NOT use these alternative encodings when possible. The normalized version of each ID is established by the authoritative store, the channel.
A2032
: When generating id
values, senders SHOULD choose values whose equivalency can be established by ordinal comparison. However, senders and receivers MAY allow logical equivalence of two values that are not ordinally equivalent if they have special knowledge of the circumstances.
The id
field is designed to allow de-duplication, but this is prohibitive in most applications.
A2033
: Receivers MAY de-duplicate activities by ID, however senders SHOULD NOT rely on receivers performing this de-duplication.
The timestamp
field records the exact UTC time when the activity occurred. Due to the distributed nature of computing systems, the important time is when the channel (the authoritative store) records the activity. The time when a client or bot initiated an activity may be transmitted separately in the localTimestamp
field. The value of the timestamp
field is an ISO 8601 [3] encoded datetime within a string.
A2040
: Channels SHOULD include a timestamp
field if it is available for that activity.
A2041
: Clients and bots SHOULD NOT include a timestamp
field in activities they generate.
A2042
: Clients and bots SHOULD NOT use timestamp
to reject activities, as they may appear out-of-order. However, they MAY use timestamp
to order activities within a UI or for downstream processing.
A2043
: Senders SHOULD always use encode the value of timestamp
fields as UTC, and they SHOULD always include Z as an explicit UTC mark within the value.
The localTimezone
field expresses the timezone where the activity was generated. The value of the localTimezone
field is a time zone name (zone entry) per the IANA Time Zone database. [15]
A2055
: Clients MAY include the localTimezone
in their activities.
A2056
: Channels SHOULD preserve localTimezone
when forwarding activities from a sender to recipient(s).
A2057
: A receiver MAY ignore localTimezone
values it does not understand.
The localTimestamp
field expresses the datetime and timezone offset where the activity was generated. This may be different from the UTC timestamp
where the activity was recorded. The value of the localTimestamp
field is an ISO 8601 [3] encoded datetime within a string.
When both the localTimezone
and localTimestamp
fields are included in an activity, the interpretation is to first convert the value of the localTimestamp to UTC and then apply a conversion to the local timezone.
A2050
: Clients and bots MAY include the localTimestamp
field in their activities. They SHOULD explicitly list the timezone offset within the encoded value.
A2051
: Channels SHOULD preserve localTimestamp
when forwarding activities from a sender to recipient(s).
The from
field describes which client, bot, or channel generated an activity. The value of the from
field is a complex object of the Channel account type.
The from.id
field identifies who generated an activity. Most commonly, this is another user or bot within the system. In some cases, the from
field identifies the channel itself.
A2060
: Channels MUST include the from
and from.id
fields when generating an activity.
A2061
: Bots and clients SHOULD include the from
and from.id
fields when generating an activity. A channel MAY reject an activity due to missing from
and from.id
fields.
The from.name
field is optional and represents the display name for the account within the channel. Channels SHOULD include this value so clients and bots can populate their UIs and backend systems. Bots and clients SHOULD NOT send this value to channels that have a central record of this store, but they MAY send this value to channels that populate the value on every activity (e.g. an email channel).
A2062
: Channels SHOULD include the from.name
field if the from
field is present and from.name
is available.
A2063
: Bots and clients SHOULD NOT include the from.name
field unless it is semantically valuable within the channel.
The recipient
field describes which client or bot is receiving this activity. This field is only meaningful when an activity is transmitted to exactly one recipient; it is not meaningful when it is broadcast to multiple recipients (as happens when an activity is sent to a channel). The purpose of the field is to allow the recipient to identify themselves. This is helpful when a client or bot has more than one identity within the channel. The value of the recipient
field is a complex object of the Channel account type.
A2070
: Channels MUST include the recipient
and recipient.id
fields when transmitting an activity to a single recipient.
A2071
: Bots and clients SHOULD NOT include the recipient
field when generating an activity. The exception to this is when sending a Suggestion activity, in which case the recipient MUST identify the user that should receive the suggestion.
The recipient.name
field is optional and represents the display name for the account within the channel. Channels SHOULD include this value so clients and bots can populate their UIs and backend systems.
A2072
: Channels SHOULD include the recipient.name
field if the recipient
field is present and recipient.name
is available.
The conversation
field describes the conversation in which the activity exists. The value of the conversation
field is a complex object of the Conversation account type.
A2080
: Channels, bots, and clients MUST include the conversation
and conversation.id
fields when generating an activity.
The conversation.name
field is optional and represents the display name for the conversation if it exists and is available.
A2081
: Channels SHOULD include the conversation.name
and conversation.isGroup
fields if they are available.
A2082
: Bots and clients SHOULD NOT include the conversation.name
field unless it is semantically valuable within the channel.
A2083
: Bots and clients SHOULD NOT include the conversation.isGroup
and conversation.converationType
fields in activities they generate.
A2084
: Channels SHOULD include the conversation.conversationType
field if more than one value is defined for the channel. Channels SHOULD NOT include the field if there is only one possible value.
The replyToId
field identifies the prior activity to which the current activity is a reply. This field allows threaded conversation and comment nesting to be communicated between participants. replyToId
is valid only within the current conversation. (See relatesTo for references to other conversations.) The value of the replyToId
field is a string.
A2090
: Senders SHOULD include replyToId
on an activity when it is a reply to another activity.
A2091
: A channel MAY reject an activity if its replyToId
does not reference a valid activity within the conversation.
A2092
: Bots and clients MAY omit replyToId
if it knows the channel does not make use of the field, even if the activity being sent is a reply to another activity.
The entities
field contains a flat list of metadata objects pertaining to this activity. Unlike attachments (see the attachments field), entities do not necessarily manifest as user-interactable content elements, and are intended to be ignored if not understood. Senders may include entities they think may be useful to a receiver even if they are not certain the receiver can accept them. The value of each entities
list element is a complex object of the Entity type.
A2100
: Senders SHOULD omit the entities
field if it contains no elements.
A2101
: Senders MAY send multiple entities of the same type, provided the entities have distinct meaning.
A2102
: Senders MUST NOT include two or more entities with identical types and contents.
A2103
: Senders and receivers SHOULD NOT rely on specific ordering of the entities included in an activity.
A2104
: Receivers MUST ignore entities whose types they do not understand.
A2105
: Receivers SHOULD ignore entities whose type they understand but are unable to process due to e.g. syntactic errors.
Extensibility data in the activity schema is organized principally within the channelData
field. This simplifies plumbing in SDKs that implement the protocol. The format of the channelData
object is defined by the channel sending or receiving the activity.
A2200
: Channels SHOULD NOT define channelData
formats that are JSON primitives (e.g., strings, ints). Instead, they SHOULD define channelData
as a complex type, or leave it undefined.
A2201
: If the channelData
format is undefined for the current channel, receivers SHOULD ignore the contents of channelData
.
In some cases, it's important to record where an activity was sent. The callerId
field is a string containing an IRI [4] identifying the caller of a bot, described in more detail in Appendix V. This field is not intended to be transmitted over the wire, but is instead populated by bots and clients based on cryptographically verifiable data that asserts the identity of the callers (e.g. tokens).
A2250
: Senders SHOULD NOT populate the callerId
field.
A2251
: Receivers SHOULD discard any data included in the callerId
field on the wire.
A2252
: Bots SHOULD, after receiving an Activity, populate its callerId
field with an identifier described in Appendix V
Activities are frequently sent asynchronously, with separate transport connections for sending and receiving traffic. The serviceUrl
field is used by channels to denote the URL where replies to the current activity may be sent. The value of the serviceUrl
field is of type string.
A2300
: Channels MUST include the serviceUrl
field in all activities they send to bots.
A2301
: Channels SHOULD NOT include the serviceUrl
field to clients who demonstrate they already know the channel's endpoint.
A2302
: Bots and clients SHOULD NOT populate the serviceUrl
field in activities they generate.
A2302
: Channels MUST ignore the value of serviceUrl
in activities sent by bots and clients.
A2304
: Channels SHOULD use stable values for the serviceUrl
field as bots may persist them for long periods.
Message activities represent content intended to be shown within a conversational interface. Message activities may contain text, speech, interactive cards, and binary or unknown attachments; typically channels require at most one of these for the message activity to be well-formed.
Message activities are identified by a type
value of message
.
The text
field contains text content, either in the Markdown format, XML, or as plain text. The format is controlled by the textFormat
field as is plain if unspecified or ambiguous. The value of the text
field is of type string.
A3000
: The text
field MAY contain an empty string to indicate sending text without contents.
A3001
: Channels SHOULD handle markdown
-formatted text in a way that degrades gracefully for that channel.
The textFormat
field denotes whether the text
field should be interpreted as Markdown [5], plain text, or XML. The value of the textFormat
field is of type string, with defined values of markdown
, plain
, and xml
. The default value is plain
. This field is not designed to be extended with arbitrary values.
The textFormat
field controls additional fields within attachments etc. This relationship is described within those fields, elsewhere in this document.
A3010
: If a sender includes the textFormat
field, it SHOULD only send defined values.
A3011
: Senders SHOULD omit textFormat
if the value is plain
.
A3012
: Receivers SHOULD interpret undefined values as plain
.
A3013
: Bots and clients SHOULD NOT send the value xml
unless they have prior knowledge that the channel supports it, and the characteristics of the supported XML dialect.
A3014
: Channels SHOULD NOT send markdown
or xml
contents to bots.
A3015
: Channels SHOULD accept textformat
values of at least plain
and markdown
.
A3016
: Channels MAY reject textformat
of value xml
.
The locale
field communicates the language code of the text
field. The value of the locale
field is an IETF BCP-47 [19] language tag within a string.
A3020
: Receivers SHOULD treat missing and unknown values of the locale
field as unknown.
A3021
: Receivers SHOULD NOT reject activities with unknown locale.
The speak
field indicates how the activity should be spoken via a text-to-speech system. The field is only used to customize speech rendering when the default is deemed inadequate. It replaces speech synthesis for any content within the activity, including text, attachments, and summaries. The value of the speak
field is either plain text or SSML [7] encoded within a string.
A3030
: The speak
field MAY contain an empty string to indicate no speech should be generated.
A3031
: Receivers unable to generate speech SHOULD ignore the speak
field.
A3033
: Receivers SHOULD NOT use XML DTD or schema resolution to include remote resources from outside the communicated XML fragment.
A3034
: Channels SHOULD NOT send the speak
field to bots.
A3035
: Receivers generating speech from an Activity with a missing or null speak
field SHOULD render message contents such as text
and summary
instead.
The inputHint
field indicates whether or not the generator of the activity is anticipating a response. This field is used predominantly within channels that have modal user interfaces, and is typically not used in channels with continuous chat feeds. The value of the inputHint
field is of type string, with defined values of accepting
, expecting
, and ignoring
. The default value is accepting
.
A3040
: If a sender includes the inputHint
field, it SHOULD only send defined values.
A3041
: If sending an activity to a channel where inputHint
is used, bots SHOULD include the field, even when the value is accepting
.
A3042
: Receivers SHOULD interpret undefined values as accepting
.
The attachments
field contains a flat list of objects to be displayed as part of this activity. The value of each attachments
list element is a complex object of the Attachment type.
A3050
: Senders SHOULD omit the attachments
field if it contains no elements.
A3051
: Senders MAY send multiple entities of the same type.
A3052
: Receivers MAY treat attachments of unknown types as downloadable documents.
A3053
: Receivers SHOULD preserve the ordering of attachments when processing content, except when rendering limitations force changes, e.g. grouping of documents after images.
The attachmentLayout
field instructs user interface renderers how to present content included in the attachments
field. The value of the attachmentLayout
field is of type string, with defined values of list
and carousel
. The default value is list
.
A3060
: If a sender includes the attachmentLayout
field, it SHOULD only send defined values.
A3061
: Receivers SHOULD interpret undefined values as list
.
The summary
field contains text used to replace attachments
on channels that do not support them. The value of the summary
field is of type string.
A3070
: Receivers SHOULD consider the summary
field to logically follow the text
field.
A3071
: Channels SHOULD NOT send the summary
field to bots.
A3072
: Channels able to process all attachments within an activity SHOULD ignore the summary
field.
The suggestedActions
field contains a payload of interactive actions that may be displayed to the user. Support for suggestedActions
and their manifestation depends heavily on the channel. The value of the suggestedActions
field is a complex object of the Suggested actions type.
The value
field contains a programmatic payload specific to the activity being sent. Its meaning and format are defined in other sections of this document that describe its use.
A3080
: Senders SHOULD NOT include value
fields of primitive types (e.g. string, int). value
fields SHOULD be complex types or omitted.
The expiration
field contains a time at which the activity should be considered to be "expired" and should not be presented to the recipient. The value of the expiration
field is an ISO 8601 [3] encoded datetime within a string.
A3090
: Senders SHOULD always use encode the value of expiration
fields as UTC, and they SHOULD always include Z as an explicit UTC mark within the value.
The importance
field contains an enumerated set of values to signal to the recipient the relative importance of the activity. It is up to the receiver to map these importance hints to the user experience. The value of the importance
field is of type string, with defined values of low
, normal
and high
. The default value is normal
.
A3100
: If a sender includes the importance
field, it SHOULD only send defined values.
A3101
: Receivers SHOULD interpret undefined values as normal
.
The deliveryMode
field contains any one of an enumerated set of values to signal to the recipient alternate delivery paths for the activity or response. The value of the deliveryMode
field is of type string, with defined values of normal
, notification
and expectReplies
. The default value is normal
.
Activities with a deliveryMode
of expectReplies
differ only in their requirement to return a response payload back to the caller synchronously, as a direct response to the initial request.
A3110
: If a sender includes the deliveryMode
field, it SHOULD only send defined values.
A3111
: Receivers SHOULD interpret undefined values as normal
.
A3112
: Receivers SHOULD reject activities with deliveryMode
of expectReplies
if they do not support synchronous responses.
A3113
: Receivers SHOULD NOT reply with asynchronous responses to activities with deliveryMode
of expectReplies
.
A3114
: Senders MUST NOT include deliveryMode
of expectReplies
on Invoke activities unless the Invoke profile explicitly allows and describes its behavior.
A3115
: Senders MUST establish whether a receiver understands deliveryMode
of expectReplies
prior to sending activities with that value.
A3116
: Bots SHOULD NOT send activities with deliveryMode
of expectReplies
to channels.
The listenFor
field contains a list of terms or references to term sources that speech and language processing systems can listen for. The value of the listenFor
field is an array of strings whose format is defined in Appendix IV.
A missing listenFor
field indicates default priming behavior should be used. The default is defined by the channel and may depend on variables such as the identity of the user and the bot.
A3120
: Channels SHOULD NOT populate the listenFor
field.
A3121
: Bots SHOULD send listenFor
contents that reflect the complete set of utterances expected from users, not just the utterances in response to the content in the message in which the listenFor
is included.
The semanticAction
field contains an optional programmatic action accompanying the user request. The semantic action field is populated by the channel and bot based on some understanding of what the user is trying to accomplish; this understanding may be achieved with natural language processing, additional user interface elements tied specifically to these actions, through a process of conversational refinement, or contextually via other means. The meaning and structure of the semantic action is agreed ahead of time between the channel and the bot.
The value of the semanticAction
field is a complex object of the semantic action type.
A3130
: Channels and bots MAY populate the semanticAction
field. Other senders SHOULD NOT populate the semanticAction
field.
Information within the semantic action field is meant to augment, not replace, existing content within the activity. A well-formed semantic action has a defined name, corresponding well-formed entities, and matches the user's intent in generating the activity.
A3131
: Senders SHOULD NOT remove any content used to generate the semanticAction
field.
A3132
: Receivers MAY ignore parts or all of the semanticAction
field.
A3133
: Receivers MUST ignore semanticAction
fields they cannot parse or do not understand.
Semantic actions are sometimes used to indicate a change in which participant controls the conversation. For example, a channel may use actions during an exchange with a skill. When so defined, skills can relinquish control through the handoff activity after the final semanticAction
state
is done
.
A3135
: Channels MAY define the use of handoff activity in conjunction with semantic actions.
A3136
: Bots MAY use semantic action and handoff activity internally to coordinate conversational focus between components of the bot.
Contact relation update activities signal a change in the relationship between the recipient and a user within the channel. Contact relation update activities generally do not contain user-generated content. The relationship update described by a contact relation update activity exists between the user in the from
field (often, but not always, the user initiating the update) and the user or bot in the recipient
field.
Contact relation update activities are identified by a type
value of contactRelationUpdate
.
The action
field describes the meaning of the contact relation update activity. The value of the action
field is a string. Only values of add
and remove
are defined, which denote a relationship between the users/bots in the from
and recipient
fields.
Conversation update activities describe a change in a conversation's members, description, existence, or otherwise. Conversation update activities generally do not contain user-generated content. The conversation being updated is described in the conversation
field.
Conversation update activities are identified by a type
value of conversationUpdate
.
A4100
: Senders MAY include zero or more of membersAdded
, membersRemoved
, topicName
, and historyDisclosed
fields in a conversation update activity.
A4101
: Each channelAccount
(identified by id
field) SHOULD appear at most once within the membersAdded
and membersRemoved
fields. An ID SHOULD NOT appear in both fields. An ID SHOULD NOT be duplicated within either field.
A4102
: Channels SHOULD NOT use conversation update activities to indicate changes to a channel account's fields (e.g., name
) if the channel account was not added to or removed from the conversation.
A4103
: Channels SHOULD NOT send the topicName
or historyDisclosed
fields if the activity is not signaling a change in value for either field.
The membersAdded
field contains a list of channel participants (bots or users) added to the conversation. The value of the membersAdded
field is an array of type channelAccount
.
The membersRemoved
field contains a list of channel participants (bots or users) removed from the conversation. The value of the membersRemoved
field is an array of type channelAccount
.
The topicName
field contains the text topic or description for the conversation. The value of the topicName
field is of type string.
The historyDisclosed
field is deprecated.
A4110
: Senders SHOULD NOT include the historyDisclosed
field.
End of conversation activities signal the end of a conversation from the recipient's perspective. This may be because the conversation has been completely ended, or because the recipient has been removed from the conversation in a way that is indistinguishable from it ending. The conversation being ended is described in the conversation
field.
End of conversation activities are identified by a type
value of endOfConversation
.
Both the code
and the text
fields are optional.
The code
field contains a programmatic value describing why or how the conversation was ended. The value of the code
field is of type string and its meaning is defined by the channel sending the activity.
The text
field contains optional text content to be communicated to a user. The value of the text
field is of type string, and its format is plain text.
Event activities communicate programmatic information from a client or channel to a bot. The meaning of an event activity is defined by the name
field, which is meaningful within the scope of a channel. Event activities are designed to carry both interactive information (such as button clicks) and non-interactive information (such as a notification of a client automatically updating an embedded speech model).
Event activities are the asynchronous counterpart to invoke activities. Unlike invoke, event is designed to be extended by client application extensions.
Event activities are identified by a type
value of event
and specific values of the name
field.
A5000
: Channels MAY allow application-defined event messages between clients and bots, if the clients allow application customization.
The name
field controls the meaning of the event and the schema of the value
field. The value of the name
field is of type string.
A5001
: Event activities MUST contain a name
field.
A5002
: Receivers MUST ignore event activities with name
fields they do not understand.
The value
field contains parameters specific to this event, as defined by the event name. The value of the value
field is a complex type.
A5100
: The value
field MAY be missing or empty, if defined by the event name.
A5101
: Extensions to the event activity SHOULD NOT require receivers to use any information other than the activity type
and name
fields to understand the schema of the value
field.
The relatesTo
field references another conversation, and optionally a specific activity within that conversation. The value of the relatesTo
field is a complex object of the Conversation reference type.
A5200
: relatesTo
SHOULD NOT reference an activity within the conversation identified by the conversation
field.
Invoke activities communicate programmatic information from a client or channel to a bot, and have a corresponding return payload for use within the channel. The meaning of an invoke activity is defined by the name
field, which is meaningful within the scope of a channel.
Invoke activities are the synchronous counterpart to event activities. Event activities are designed to be extensible. Invoke activities differ only in their ability to return response payloads back to the channel; because the channel must decide where and how to process these response payloads, Invoke is useful only in cases where explicit support for each invoke name has been added to the channel. Thus, Invoke is not designed to be a generic application extensibility mechanism.
Invoke activities are identified by a type
value of invoke
and specific values of the name
field.
The list of defined Invoke activities is included in Appendix III.
A5301
: Channels SHOULD NOT allow application-defined invoke messages between clients and bots.
The name
field controls the meaning of the invocation and the schema of the value
field. The value of the name
field is of type string.
A5401
: Invoke activities MUST contain a name
field.
A5402
: Receivers MUST ignore event activities with name
fields they do not understand.
The value
field contains parameters specific to this event, as defined by the event name. The value of the value
field is a complex type.
A5500
: The value
field MAY be missing or empty, if defined by the event name.
A5501
: Extensions to the event activity SHOULD NOT require receivers to use any information other than the activity type
and name
fields to understand the schema of the value
field.
The relatesTo
field references another conversation, and optionally a specific activity within that conversation. The value of the relatesTo
field is a complex object of the Conversation reference type.
A5600
: relatesTo
SHOULD NOT reference an activity within the conversation identified by the conversation
field.
Installation update activities represent an installation or uninstallation of a bot within an organizational unit (such as a customer tenant or "team") of a channel. Installation update activities generally do not represent adding or removing a channel.
Installation update activities are identified by a type
value of installationUpdate
.
A5700
: Channels MAY send installation activities when a bot is added to or removed from a tenant, team, or other organization unit within the channel.
A5701
: Channels SHOULD NOT send installation activities when the bot is installed into or removed from a channel.
The action
field describes the meaning of the installation update activity. The value of the action
field is a string. Only values of add
and remove
are defined.
Message delete activities represent a deletion of an existing message activity within a conversation. The deleted activity is referred to by the id
and conversation
fields within the activity.
Message delete activities are identified by a type
value of messageDelete
.
A5800
: Channels MAY elect to send message delete activities for all deletions within a conversation, a subset of deletions within a conversation (e.g. only deletions by certain users), or no activities within the conversation.
A5801
: Channels SHOULD NOT send message delete activities for conversations or activities that the bot did not observe.
A5802
: If a bot triggers a delete, the channel SHOULD NOT send a message delete activity back to that bot.
A5803
: Channels SHOULD NOT send message delete activities corresponding to activities whose type is not message
.
Message update activities represent an update of an existing message activity within a conversation. The updated activity is referred to by the id
and conversation
fields within the activity, and the message update activity contains all fields in the revised message activity.
Message update activities are identified by a type
value of messageUpdate
.
A5900
: Channels MAY elect to send messageUpdate activities for all updates within a conversation, a subset of updates within a conversation (e.g. only updates by certain users), or no activities within the conversation.
A5901
: If a bot triggers an update, the channel SHOULD NOT send a message update activity back to that bot.
A5902
: Channels SHOULD NOT send message update activities corresponding to activities whose type is not message
.
Message reaction activities represent a social interaction on an existing message activity within a conversation. The original activity is referred to by the id
and conversation
fields within the activity. The from
field represents the source of the reaction (i.e., the user that reacted to the message).
Message reaction activities are identified by a type
value of messageReaction
.
The reactionsAdded
field contains a list of reactions added to this activity. The value of the reactionsAdded
field is an array of type messageReaction
.
The reactionsRemoved
field contains a list of reactions removed from this activity. The value of the reactionsRemoved
field is an array of type messageReaction
.
Suggestion activities allow a bot to send content targeting a single user in the conversation which refers to a previous activity and suggests content that augments it. The suggested content is a superset of the message activity, and fields present on the message activity are schematically valid on the suggestion activity. The channel in which the suggestion activity is sent defines limitations on text or attachment content, and these limitations may differ from the channel's limitations on message activities. The suggestion activity includes the textHighlights
property so that the suggestions can be surfaced as annotations to the original content in the source activity.
For example: an message activity with the text "...we should meet on Monday to review this plan..." could cause a bot to send a suggestion activity which refers to that section of text and offers the user an affordance to create a meeting on their calendar. Some channels use this information to highlight and turn into a hot link the snippet of text to show the suggestion in context.
Suggestion activities are identified by a type
value of suggestion
. Suggestion activities refer to another activity by using the replyToId
property.
A6100
: If there is no replyToId
then the suggested content should be shown to the recipient as a normal message activity.
Suggestion activity uses the recipient
field to signal which user the suggestion is for.
All textHighlight
objects are relative to the activity specified by the replyToId
property. There can be multiple textHighlight
provided, allowing a client the option to turn different sections of the text into links which would show the suggestion content.
A6101
: Bots MAY use replyToId
and textHighlights
to associate the suggestion with an activity.
A6102
: Channels MAY use replyToId
and textHighlights
to show the suggestion activity contextually to the recipient.
A6103
: Channels MUST only show the suggestion activity to the recipient. If unable to identify the intended recipient or show the content only to them, the channel MUST drop the activity.
A6104
: Channels SHOULD NOT send suggestion activities to bots.
The textHighlights
field contains a list of text to highlight in the text
field of the activity referred to by replyToId
. The value of the textHighlights
field is an array of type textHighlight
.
The Trace activity is an activity which the developer inserts in to the stream of activities to represent a point in the developers bot logic. The trace activity typically is logged by transcript history components to become part of a Transcript-format history file. In remote debugging scenarios the Trace activity can be sent to the client so that the activity can be inspected as part of the debug flow.
Trace activities are normally not shown to the user, and are internal to transcript logging and developer debugging.
Trace activities are identified by a type
value of trace
.
A6150
: channels SHOULD NOT display trace activities to the user, unless the user has identified itself as the developer in a secure manner.
The name
field controls the name of the trace operation. The value of the name
field is of type string.
A6151
: Trace activities MAY contain a name
field.
A6152
: Receivers MUST ignore event activities with name
fields they do not understand.
The label
field contains optional a label which can provide contextual information about the trace. The value of the label
field is of type string.
A6153
: Trace activities MAY contain a label
field.
The valueType
field is a string type which contains a unique value which identifies the shape of the value
object for this trace.
A6154
: The valueType
field MAY be missing or empty, if the name
property is sufficient to understand the shape of the value
property.
The value
field contains an object for this trace, as defined by the valueType
or name
property if there is no valueType
. The value of the value
field is a complex type.
A6155
: The value
field MAY be missing or empty.
A6156
: Extensions to the trace activity SHOULD NOT require receivers to use any information other than the activity type
and name
or valueType
field to understand the schema of the value
field.
The relatesTo
field references another conversation, and optionally a specific activity within that conversation. The value of the relatesTo
field is a complex object of the Conversation reference type.
A6157
: relatesTo
MAY reference an activity within the conversation identified by the conversation
field.
Typing activities represent ongoing input from a user or a bot. This activity is often sent when keystrokes are being entered by a user, although it's also used by bots to indicate they're "thinking," and could also be used to indicate e.g. collecting audio from users.
Typing activities are intended to persist within UIs for three seconds.
Typing activities are identified by a type
value of typing
.
A6000
: If able, clients SHOULD display typing indicators for three seconds upon receiving a typing activity.
A6001
: Unless otherwise known for the channel, senders SHOULD NOT send typing activities more frequently than one every three seconds. (Senders MAY send typing activities every two seconds to prevent gaps from appearing.)
A6002
: If a channel assigns an id
to a typing activity, it MAY allow bots and clients to delete the typing activity before its expiration.
A6003
: If able, channels SHOULD send typing activities to bots.
Handoff activities are used to request or signal a change in focus between elements inside a bot. They are not intended to be used in wire communication (besides internal communication that occurs between services in a distributed bot).
Handoff activities are identified by a type
value of handoff
.
A6200
: Channels SHOULD drop handoff activities if they are not supported.
Command activities communicate a request to perform a specific action. They are identified by a type
value of command
and specific values of the name
field.
Commands look similar in structure to events but have different semantics. Commands are requests to perform an action and receivers typically respond with one or more commandResult activities. Receivers are also expected to explicitly reject unsupported command activities.
A6300
: Channels MAY allow application-defined command activities between clients and bots, if the clients allow application customization.
A6301
: Application-defined command activities MUST be declared in the application/*
namespace.
A6302
: Command activities outside the application/*
are considered reserved for Bot Framework Protocols.
The list of all Bot Framework protocols using command activities is included in Appendix VI.
The name
field defines the meaning of the command activity. The value of the name
field is of type string.
A6310
: Command activities MUST contain a name
field.
A6311
: The name
of a command activity MUST use a MIME media type [9] format.
A6312
: Receivers MUST ignore command activities with missing or invalid name
field.
The recommended patterns for rejecting command activities are included in Appendix VI.
The value
field contains the command metadata and parameters specific to a command, as defined by the command name
. The value
field is a complex object of the command value type.
A6321
: Command activities MUST contain a value
field.
A6322
: Receivers MUST ignore command activities with missing or invalid value
field.
Command result activities communicate the result of a command activity.
Command result activities are identified by a type
value of commandResult
and specific values of the name
field. The name
field of a command result is always set to the name
of the original command activity.
A6400
: Senders MAY send one or more command result activities to communicate the result of the command.
The name
field defines the meaning of the command result activity. The value of the name
field is of type string.
A6411
: Command result activities MUST contain a name
field.
A6412
: Receivers MUST ignore command activities with missing or invalid name
field.
A6413
: The name
of a command result activity MUST be the same as the name
of the original command activity.
The value
field contains the command metadata and additional information specific to a command result, as defined by the command result name
. The value of the value
field is a complex object of type command result value type.
A6421
: Command result activities MUST contain a value
field.
A6422
: Receivers MUST reject command result activities with missing or invalid value
field.
This section defines complex types used within the activity schema, described above.
Attachments are content included within a message activity: cards, binary documents, and other interactive content. They're intended to be displayed in conjunction with text content. Content may be sent via URL data URI within the contentUrl
field, or inline in the content
field.
A7100
: Senders SHOULD NOT include both content
and contentUrl
fields in a single attachment.
The contentType
field describes the MIME media type [9] of the content of the attachment. The value of the contentType
field is of type string.
When present, the content
field contains a structured JSON object attachment. The value of the content
field is a complex type defined by the contentType
field.
A7110
: Senders SHOULD NOT include JSON primitives in the content
field of an attachment.
When present, the contentUrl
field contains a URL to the content in the attachment. Data URIs, as defined in RFC 2397 [10] are typically supported by channels. The value of the contentUrl
field is of type string.
A7120
: Receivers SHOULD accept HTTPS URLs.
A7121
: Receivers MAY accept HTTP URLs.
A7122
: Channels SHOULD accept data URIs.
A7123
: Channels SHOULD NOT send data URIs to clients or bots.
The name
field contains an optional name or filename for the attachment. The value of the name
field is of type string.
Some clients have the ability to display custom thumbnails for non-interactive attachments or as placeholders for interactive attachments. The thumbnailUrl
field identifies the source for this thumbnail. Data URIs, as defined in RFC 2397 [10] are typically also allowed.
A7140
: Receivers SHOULD accept HTTPS URLs.
A7141
: Receivers MAY accept HTTP URLs.
A7142
: Channels SHOULD accept data URIs.
A7143
: Channels SHOULD NOT send thumbnailUrl
fields to bots.
A card action represents a clickable or interactive button for use within cards or as suggested actions. They are used to solicit input from users. Despite their name, card actions are not limited to use solely on cards.
Card actions are meaningful only when sent to channels.
Channels decide how each action manifests in their user experience. In most cases, the cards are clickable. In others, they may be selected by speech input. In cases where the channel does not offer an interactive activation experience (e.g., when interacting over SMS), the channel may not support activation whatsoever. The decision about how to render actions is controlled by normative requirements elsewhere in this document (e.g. within the card format, or within the suggested actions definition).
The type
field describes the meaning of the button and behavior when the button is activated. Values of the type
field are by convention short strings (e.g. "openUrl
"). See subsequent sections for requirements specific to each action type.
- An action of type
messageBack
represents a text response to be sent via the chat system. - An action of type
imBack
represents a text response that is added to the chat feed. - An action of type
postBack
represents a text response that is not added to the chat feed. - An action of type
openUrl
represents a hyperlink to be handled by the client. - An action of type
downloadFile
represents a hyperlink to be downloaded. - An action of type
showImage
represents an image that may be displayed. - An action of type
signin
represents a hyperlink to be handled by the client's signin system. - An action of type
playAudio
represents audio media that may be played. - An action of type
playVideo
represents video media that may be played. - An action of type
call
represents a telephone number that may be called.
The title
field includes text to be displayed on the button's face. The value of the title
field is of type string, and does not contain markup.
This field applies to actions of all types.
A7210
: Channels SHOULD NOT process markup within the title
field (e.g. Markdown).
The image
field contains a URL referencing an image to be displayed on the button's face. Data URIs, as defined in RFC 2397 [10] are typically supported by channels. The value of the image
field is of type string.
This field applies to actions of all types.
A7220
: Channels SHOULD accept HTTPS URLs.
A7221
: Channels MAY accept HTTP URLs.
A7222
: Channels SHOULD accept data URIs.
The imageAltText
field contains alternate image text to be used in place of the image
field. This field should only be used when the text
field is inadequate as alt text. The value of the imageAltText
field is of type string.
A7225
: Senders SHOULD NOT populate the imageAltText
field if its value is identical to the text
field.
A7226
: Receivers SHOULD use the value of the imageAltText
field if it is present in the enclosing card action. If the imageAltText
field is missing, receivers SHOULD use the text
field as the alt text.
The text
field contains text content to be sent to a bot and included in the chat feed when the button is clicked. The contents of the text
field may or may not be displayed, depending on the button type. The text
field may contain markup, controlled by the textFormat
field in the activity root. The value of the text
field is of type string.
This field is only used on actions of select types. Details on each type of action are included later in this document.
A7230
: The text
field MAY contain an empty string to indicate sending text without contents.
A7231
: Channels SHOULD process the contents of the text
field in accordance with the textFormat
field in the activity root.
The displayText
field contains text content to be included in the chat feed when the button is clicked. The contents of the displayText
field SHOULD always be displayed, when technically possible within the channel. The displayText
field may contain markup, controlled by the textFormat
field in the activity root. The value of the displayText
field is of type string.
This field is only used on actions of select types. Details on each type of action are included later in this document.
A7240
: The displayText
field MAY contain an empty string to indicate sending text without contents.
A7241
: Channels SHOULD process the contents of the displayText
field in accordance with the textFormat
field in the activity root.
The value
field contains programmatic content to be sent to a bot when the button is clicked. The contents of the value
field are of any primitive or complex type, although certain activity types constrain this field.
This field is only used on actions of select types. Details on each type of action are included later in this document.
A messageBack
action represents a text response to be sent via the chat system. Message Back uses the following fields:
type
("messageBack
")title
image
text
displayText
value
(of any type)
A7350
: Senders SHOULD NOT include value
fields of primitive types (e.g. string, int). value
fields SHOULD be complex types or omitted.
A7351
: Channels MAY reject or drop value
fields not of complex type.
A7352
: When activated, channels MUST send an activity of type message
to all relevant recipients.
A7353
: If the channel supports storing and transmitting text, the contents of the text
field of the action MUST be preserved and transmitted in the text
field of the generated message activity.
A7355
: If the channel supports storing and transmitting additional programmatic values, the contents of the value
field MUST be preserved and transmitted in the value
field of the generated message activity.
A7356
: If the channel supports preserving a different value in the chat feed than is sent to bots, it MUST include the displayText
field in the chat history.
A7354
: If the channel does not support A7353
but does support recording text within the chat feed, it MUST include the text
field in the chat history.
A7357
: If the channel supports presenting an image on the action, the contents of the image
field of the action MUST be shown on or in connection with the action.
A7358
: The contents of the title
field of the action MUST be shown on or in connection with the action.
A7359
: Senders SHOULD include an image
field, a title
field, or both. Channels MAY reject or drop messageBack
actions which have neither an image
field nor a title
field.
An imBack
action represents a text response that is added to the chat feed. IM Back uses the following fields:
type
("imBack
")title
image
value
(of type string)
A7360
: When activated, channels MUST send an activity of the type message
to all relevant recipients.
A7361
: If the channel supports storing and transmitting text, the contents of the title
field MUST be preserved and transmitted in the text
field of the generated message activity.
A7362
: If the title
field on an action is missing and the value
field is of type string, the channel MAY transmit the contents of the value
field in the text
field of the generated message activity.
A7363
: If the channel supports recording text within the chat feed, it MUST include the contents of the title
field in the chat history.
A postBack
action represents a text response that is not added to the chat feed. Post Back uses the following fields:
type
("postBack
")title
image
value
(of type string)
A7370
: When activated, channels MUST send an activity of the type message
to all relevant recipients.
A7371
: Channels SHOULD NOT include text within the chat history when a Post Back action is activated.
A7372
: Channels MUST reject or drop value
fields not of string type.
A7373
: If the channel supports storing and transmitting text, the contents of the value
field MUST be preserved and transmitted in the text
field of the generated message activity.
A7374
: If the channel is unable to support transmitting to the bot without including history in the chat feed, it SHOULD use the title
field as the display text.
An openUrl
action represents a hyperlink to be handled by the client. Open URL uses the following fields:
type
("openUrl
")title
image
value
(of type string)
A7380
: Senders MUST include a URL in the value
field of an openUrl
action.
A7381
: Receivers MAY reject openUrl
action whose value
field is missing or not a string.
A7382
: Receivers SHOULD reject or drop openUrl
actions whose value
field contains a data URI, as defined in RFC 2397 [10].
A7383
: Receivers SHOULD NOT reject openUrl
actions whose value
URI is of an otherwise unexpected URI scheme or value.
A7384
: Clients with knowledge of particular URI schemes (e.g. HTTP) MAY handle openUrl
actions within an embedded renderer (e.g., a browser control).
A7385
: When available, clients SHOULD delegate handling of openUrl
actions not handled by A7354
to the operating-system- or shell-level URI handler.
An downloadFile
action represents a hyperlink to be downloaded. Download File uses the following fields:
type
("downloadFile
")title
image
value
(of type string)
A7390
: Senders MUST include a URL in the value
field of an downloadFile
action.
A7391
: Receivers MAY reject downloadFile
action whose value
field is missing or not a string.
A7392
: Receivers SHOULD reject or drop downloadFile
actions whose value
field contains a data URI, as defined in RFC 2397 [10].
An showImage
action represents an image that may be displayed. Show Image uses the following fields:
type
("showImage
")title
image
value
(of type string)
A7400
: Senders MUST include a URL in the value
field of an showImage
action.
A7401
: Receivers MAY reject showImage
action whose value
field is missing or not a string.
A7402
: Receivers MAY reject showImage
actions whole value
field is a Data URI, as defined in RFC 2397 [10].
A signin
action represents a hyperlink to be handled by the client's signin system. Signin uses the following fields:
type
("signin
")title
image
value
(of type string)
A7410
: Senders MUST include a URL in the value
field of an signin
action.
A7411
: Receivers MAY reject signin
action whose value
field is missing or not a string.
A7412
: Receivers MUST reject or drop signin
actions whose value
field contains a data URI, as defined in RFC 2397 [10].
A playAudio
action represents audio media that may be played. Play Audio uses the following fields:
type
("playAudio
")title
image
value
(of type string)
A7420
: When activated, channels MAY play the audio referenced by URI in the value
field.
A7421
: Channels MUST reject or drop value
fields not of string type.
A7422
: Senders SHOULD NOT send data URIs, as defined in RFC 2397 [10], without prior knowledge that the channel supports them.
A playVideo
action represents video media that may be played. Play Video uses the following fields:
type
("playVideo
")title
image
value
(of type string)
A7430
: When activated, channels MAY play the video referenced by URI in the value
field.
A7431
: Channels MUST reject or drop value
fields not of string type.
A7432
: Senders SHOULD NOT send data URIs, as defined in RFC 2397 [10], without prior knowledge that the channel supports them.
A call
action represents a telephone number that may be called. Call uses the following fields:
type
("call
")title
image
value
(of type string)
A7440
: Senders MUST include a URL of scheme tel
in the value
field of an signin
action.
A7441
: Receivers MUST reject signin
action whose value
field is missing or not a string URI of the tel
scheme.
Channel accounts represent identities within a channel. The channel account includes an ID that can be used to identify and contact the account within that channel. Sometimes these IDs exist within a single namespace (e.g. Skype IDs); sometimes, they are federated across many servers (e.g. email addresses). In addition to the ID, channel accounts include display names and Azure Active Directory (AAD) object IDs.
The id
field is the identifier and address within the channel. The value of the id
field is a string. An example id
within a channel that uses email addresses is "[email protected]"
A7510
: Channels SHOULD use the same values and conventions for account IDs regardless of their position within the schema (from.id
, recipient.id
, membersAdded
, etc.). This allows bots and clients to use ordinal string comparisons to know when e.g. they are described in the membersAdded
field of a conversationUpdate
activity.
The name
field is an optional, friendly name within the channel. The value of the name
field is a string. An example name
within a channel is "John Doe"
The aadObjectId
field is an optional ID corresponding to the account's object ID within Azure Active Directory (AAD). The value of the aadObjectId
field is a string.
The role
field indicates whether entity behind the account is a user or bot. This field is intended for use in the Transcript format [16] to distinguish between activities sent by users and activities sent by bots. The value of the role
field is a string.
A7511
: Senders SHOULD NOT include this field. Receivers SHOULD ignore this field.
Conversation accounts represent the identity of conversations within a channel. In channels that support only a single conversation between two accounts (e.g. SMS), the conversation account is persistent and does not have a predetermined start or end. In channels that support multiple parallel conversations (e.g. email), each conversation will likely have a unique ID.
The id
field is the identifier within the channel. The format of this ID is defined by the channel and is used as an opaque string throughout the protocol.
Channels SHOULD choose id
values that are stable for all participants within a conversation. (For example, a poor example for the id
field for a 1:1 conversation is to use the other participant's ID as the id
value. This would result in a different id
from each participant's perspective. A better choice is to sort the IDs of both participants and concatenate them together, which would be the same for both parties.)
The name
field is an optional, friendly name for the conversation within the channel. The value of the name
field is a string.
The aadObjectId
field is an optional ID corresponding to the conversation's object ID within Azure Active Directory (AAD). The value of the aadObjectId
field is a string.
The isGroup
field indicates whether the conversation contains more than two participants at the time the activity was generated. The value of the isGroup
field is a boolean; if omitted, the default value is false
. This field typically controls the at-mention behavior for participants in the channel, and SHOULD be set to true
if and only if more than two participants have the ability to both send and receive activities within the conversation.
If the channel distinguishes between types of conversations (e.g. group vs. personal), the conversationType
field indicates the type of the conversation. This field augments the lower-fidelity isGroup
field. The value of the conversationType
field is a string and its meaning is defined by the channel in which the type occurs.
The role
field indicates whether entity behind the account is a user or bot. This field is intended for use in the Transcript format [16] to distinguish between activities sent by users and activities sent by bots. The value of the role
field is a string.
A7512
:Senders SHOULD NOT include this field. Receivers SHOULD ignore this field.
The tenantId
field is an optional ID corresponding to the conversation's tenant ID within the channel. The value of the tenantId
field is a string.
The conversationReference
type contains a reference into another conversation. In its most minimal form, this reference may only contain the IDs of the target conversation. Implementers may wish to carry additional information in the conversationReference
, such as the identity and roles of participants, and the ID of a specific activity
within the conversation. Consumers of the conversationReference
type are not provided any de facto guarantees about the validity or consistency of the IDs within the object; this is instead conferred by the sender who created the object.
The conversationReference
type is frequently used to store a reference to a conversation so it can be later retrieved and used to continue a conversation.
A7550
: Senders MUST include the channelId
and the conversation.id
properties within a conversation reference, even if they contain the same values as the parent Activity.
The channelId
field contains the channel ID of the conversation referenced by the conversationReference object. The value of the channelId
field is of type string.
The activityId
field contains an optional ID of an activity to refer to within the conversation. The value of the activityId
field is of type string.
The conversation
field contains the Conversation account representing the conversation's identity. The value of the conversation
field is a complex object of type Conversation account.
The user
field contains an optional reference to the user's identity within the conversation. The value of the user
field is of type Channel account.
The bot
field contains an optional reference to the bot's identity within the conversation. The value of the bot
field is of type Channel account.
The serviceUrl
field contains an optional copy of the serviceUrl
that applies to the referenced conversation. The value of the serviceUrl
field is of type string.
A7560
: Receivers SHOULD ensure the serviceUrl
property in conversation references is accompanied by either a corresponding security endorsement (in the case of transmitted Conversation references), or a flag indicating the serviceUrl
and its security endorsement was verified before storage (in the case of a stored Conversation reference).
The locale
field contains an optional copy of the locale
that applies to the referenced conversation. The value of the locale
field is an IETF BCP-47 [19] language tag within a string.
Entities carry metadata about an activity or conversation. Each entity's meaning and shape is defined by the type
field. Additional type-specific fields sit as peers to the type
field.
Some non-Bot-Framework entities may have a preexisting field called type
. Parties integrating these entities into the activity entity format are advised to define field-level mapping to resolve conflicts with the type
field name and other incompatibilities with serialization requirement A2001
as part of the IRI defining the entity type.
Frequently, entities used within Bot Framework are also expressed elsewhere using JSON-LD [18]. The entity format is designed to be compatible with JSON-LD contexts, but does not require senders or receivers to implement JSON-LD to successfully process an entity.
A7603
: Senders MAY include JSON-LD [18] fields within entities.
A7604
: Senders MUST NOT expect or require JSON-LD [18] processing to parse an entity.
The type
field is required, and defines the meaning and shape of the entity. type
is intended to contain IRIs [4] although there are a small number on non-IRI entity types defined in Appendix II. The value of the type
field is a string.
A7610
: Senders SHOULD use non-IRI types names only for types described in Appendix II.
A7611
: Senders MAY send IRI types for types described in Appendix II if they have knowledge that the receiver understands them.
A7612
: Senders SHOULD use or establish IRIs for entity types not defined in Appendix II.
A7613
: Senders MUST NOT use relative IRIs within the type
field, nor require JSON-LD IRI resolution to understand a type identifier.
Suggested actions may be sent within message content to create interactive action elements within a client UI.
A7700
: Clients that do not support UI capable of rendering suggested actions SHOULD ignore the suggestedActions
field.
A7701
: Senders SHOULD omit the suggestedActions
field if the actions
field is empty.
The to
field contains channel account IDs to whom the suggested actions should be displayed. This field may be used to filter actions to a subset of participants within the conversation.
A7710
: If the to
field is missing or empty, the client SHOULD display the suggested actions to all conversation participants.
A7711
: If the to
field contains invalid IDs, those values SHOULD be ignored.
The actions
field contains a flat list of actions to be displayed. The value of each actions
list element is a complex object of type cardAction
.
Message reactions represent a social interaction ("like", "+1", etc.). Message reactions currently only carry a single field: the type
field.
The type
field describes the type of social interaction. The value of the type
field is a string, and its meaning is defined by the channel in which the interaction occurs. Some common values such as like
and +1
although these are uniform by convention and not by rule.
A text highlight refers to a substring of content within another field. This type is used within suggestion activities to annotate text within another activity.
A7720
: Receivers MUST ignore a text highlight if the text
field is missing or empty, if it contains with a occurrence
value less than 0, or if the occurrence
field greater than the number of occurrences of the text
field within the referenced text.
The text
field is required, and defines the snippet of text to highlight. The contents of the text
field MUST be ordinally identical to the content of the referenced text. The value of the text
field is of type string.
A7721
: Senders MUST NOT send missing or empty strings for text
. Receivers MUST ignore text higlights with missing or empty text
fields.
The occurrence
field is optional. It gives the sender the ability to specify which occurrence of the text
to highlight. If it is not specified or is 0 then clients should highlight the first occurrence. The value of the occurrence
field is of type integer.
A7722
: Senders SHOULD NOT include the occurrence
field if its value is 0
or 1
.
The semantic action type represents a programmatic reference. It is used within the semanticAction
field in message activities. Actions are defined and registered externally to this protocol, typically as part of the Bot Framework Manifest [14]. The action definition declares the ID for the action and associates it with named entities, each of which has a corresponding type. Senders are receivers of actions use these names and types to create and parse actions that conform to the action definition.
Actions proceed through a lifecycle, described by the state
and id
fields.
At the beginning of the lifecycle, the channel indicates the id
of the action it wishes to invoke, and sends a state
of start
.
The bot then sends and receives subsequent activities. During this time, both the bot and the channel may send additional metadata in the form of actions with state
of continue
. If the bot detects the user changing topic, it reflects this in a revised value of id
.
When complete, the bot may send state
of done
. Just like earlier steps, the bot can update the id
field to reflect what was actually in the conversation.
Example data flow for semanticAction
. (Note that entities are abbreviated).
User: Book a flight from SeaTac to NYC
Semantic action: state="start", id="bookFlight", entities="SeaTac", "NYC"
Bot: Would you like to arrive at LaGuardia Airport or JFK International Airport?
Semantic action: state="continue", id="bookFlight", entities="KLGA", "KJFK"
User: Hold on a second
Semantic action empty
Bot: No problem, please reply when you'd like to continue.
Semantic action empty
User: LaGuardia
Semantic action: state="continue", id="bookFlight", entities="KLGA"
Bot: OK, would you like to book your flight?
Semantic action: state="continue", id="bookFlight"
User: Yes
Semantic action empty
Bot: OK, your flight has been booked for November 10 at 8:05am.
Semantic action: state="done", id="flightBooked", entities="Flight 81, KSEA to KLGA"
The state
field describes whether the action is beginning, continuing, or ending. The value of the state
field is of type string with defined values of start
, continue
, and done
. This field is not extensible.
Note: the state
field is not a mechanism to control a bot's state machine. Instead, it may be used to request that an action be started, or it may be used by bots to inform that the current action has changed or completed.
Because semanticAction
is optional and the topic of a conversation may drift over time, receivers are cautioned to be flexible in accepting semanticAction
contents, especially with states of continue
and done
. Specifically, channels and bots are cautioned not to create a state machine requiring specific values of semanticAction
fields state
and id
. Instead, treat semanticAction
as additional metadata that can be used to optionally enrich data sharing between actors. Receivers may always discard unexpected semanticAction
values in accordance with A3133
.
The start
state indicates an action is being started. Subsequent start
actions indicate the sender wishes to start this action or another action (depending on the value of the id
field).
A7760
: Channels MUST only send state
of start
on the first message of an exchange invoking an action. Others senders MUST NOT send state
of start
.
The continue
state indicates processing of an action is ongoing, and this activity contains new information within the semanticAction
field.
A7761
: Channels and bots MAY send state
of continue
when they populate the semanticAction
field. Other senders MUST NOT send state
of continue
.
The done
state indicates an action was successfully completed.
A7762
: Bots SHOULD send state
of done
when an action has been completed, even if semanticAction
contains no entities. Other senders MUST NOT send state
of done
.
Channels are expected to provide continuity when issuing actions to bots, but should expect changes in the state
or id
values received from bots.
A7763
: Channels SHOULD NOT send state
of continue
without a preceding state
of start
.
A7764
: Receivers MUST NOT require senders to include semanticAction
fields with state
of continue
or done
, nor a specific id
value during a conversation.
The id
field establishes the identity for the action, and is associated with a definition for the meaning and structure of the action (typically communicated via a registration system). The value of the id
field is of type string.
A7730
: Senders MUST NOT generate semantic actions with missing or empty id
fields.
A7731
: Two id
values are equivalent only if they are ordinally identical.
A7732
: Channels SHOULD only change the value of the id
field within a conversation when a new action with state
of start
is sent, or when the bot sends a state
of continue
with a new id
value.
A7733
: Bots SHOULD make best-effort attempts to update the id
field to reflect the topic of the conversation. Channels SHOULD make best-effort attempts to honor the bot's stated id
values.
The entities
field contains entities associated with this action. The value of the entities
field is a complex object; the keys of this object are entity names and the values of each key is the corresponding entity values of type entity. The meaning of each entity is defined by the enclosing action and the entity name. An additional field named $instance
occurs after the named entities. The value of the $instance
field is of type entityInstance
.
A7740
: Unless otherwise specified, senders MAY omit some or all entities associated with an action definition.
A7742
: Senders MAY add entities with unknown keys if they have special knowledge that the bot supports them.
Actions support dynamic typing. An implementer of an action expresses a list of types it prefers, and callers of that action can match the desired types with known entities of varying fidelity. For example, assume an action prefers to receive a destination in the form of a city entity. The caller may not have a city available, but is able to supply either a string or geocoordinates based on what it was able to extract from the conversation. The caller can examine the action's preferred types and send the string or geocoordinates if the action can handle it.
A7744
: Senders MAY send downgraded entities in accordance with the rules outlined in the action definition.
Entities sent within the semantic action have a specific meaning, defined by their name. For example, an action may be named findRoute
with entities named source
and destination
. Sometimes, additional entities are available that do not fit a specific meaning within the action. The root entities
array is a suitable location to transmit these entities.
A7745
: Senders MAY send entities not listed in the action definition in the entities
array in the activity root. Senders SHOULD NOT send these entities in the semantic action.
The $instance
field carries metadata about the source of each entity. The keys of this object are identical to the entity names as peers. The values of each key is the corresponding instance metadata of type semanticEntityInstance
.
A7746
: Senders SHOULD include properties within $instance
for any entities bearing instance metadata.
A7747
: Senders SHOULD NOT include empty fields within $instance
or an empty $instance
object.
A7748
: Senders MUST NOT include a $instance
field within the $instance
object.
Example of semantic action entities
"entities": {
"sourceAirport": {
"type": "http://icao.org/airport/code"
"code": "KSEA",
"name": "Seattle-Tacoma International Airport",
},
"destinationAirport": {
"type": "http://schema.org/City",
"name": "New York",
"geo": {
"type": "http://schema.org/GeoCoordinates",
"latitude": 40.7127,
"longitude": -74.0059
}
},
"$instance": {
"sourceAirport": {
"text": "SeaTac",
"startIndex": 19,
"endIndex": 25
},
"destinationAirport": {
"text": "New York",
"startIndex": 29,
"endIndex": 37
}
}
}
The semanticEntityInstance
type references to source information about where the entity was mentioned. This specification includes source data to refer to the text
field although others may be added in the future. The value of the $instance
field is a complex object with fields text
, startIndex
, and endIndex
. The text
field is a string containing a copy of the text within the text
field in the activity root; startIndex
is a number containing the index of the first character where text
is found (inclusive); endIndex
is a number containing the index after the last character where text
is found (exclusive).
A7750
: Senders MUST NOT include the $instance
field if its text
field is empty or null or the contents of its text
field cannot be found within the text
field in the activity root.
A7751
: The startIndex
field MUST be an integer greater than or equal to zero and less than the length of the text
field in the activity root.
A7752
: The endIndex
field MUST be an integer greater than zero and less than or equal to the length of the text
field in the activity root. Its value MUST be greater than the startIndex
value.
A7753
: The contents of the text
field within $instance
MUST contain characters ordinally identical to the value of the text
field in the activity root starting at startIndex
characters from the beginning and ending immediately before endIndex
characters from the beginning.
The value
field of a command activity contains metadata related to a command. An optional extensible data
payload may be included if defined by the command activity name
.
A10100
: A command value MAY include the commandId
field with the unique ID that the sender assigns to this command.
The data
field contains optional parameters specific to this command activity, as defined by the name
. The value of the data
field is a complex type.
A10200
: The data
field MAY be missing or empty, if defined by the command activity name
.
A10201
: Extensions to the command activity SHOULD NOT require receivers to use any information other than the activity type
and name
fields to understand the schema of the data
field.
The value
field of a command result activity contains metadata related to a command. An optional extensible data
payload may be included if defined by the command result activity name
. The presence of an error
field indicates that the original command failed to complete.
A11100
: If the original command includes a valid commandId
, then the command result value MUST include the same value in commandId
to allow the result to be correlated to the original command instance.
The data
field contains optional additional information specific to this command result activity, as defined by the name
. The value of the data
field is a complex type.
A11200
: The data
field MAY be missing or empty, if defined by the command result activity name.
A11201
: Extensions to the command result activity SHOULD NOT require receivers to use any information other than the activity type
and name
fields to understand the schema of the data
field.
The error
field contains the reason the original command activity failed to complete.
A11300
: Senders MUST include the error
field when the command was not successful. The value of the error
field is of type Error Object
A11301
: Senders MUST NOT include the error
field when the command was successful.
- Bot Framework Protocol -- Bot Framework Protocol swagger definition
- RFC 2119 -- Key words for use in RFCs to Indicate Requirement Levels
- ISO 8601 -- Date and time format
- RFC 3987 -- Internationalized Resource Identifiers (IRIs)
- Markdown
- ISO 639 -- Language codes
- SSML -- Speech Synthesis Markup Language
- XML -- Extensible Markup Language
- MIME media types
- RFC 2397 -- The "data" URL scheme
- ISO 3166-1 -- Country codes
- Bot Framework Cards
- Adaptive Cards
- Bot Framework Manifest
- RFC 4627 -- The application/json Media Type for JavaScript Object Notation (JSON)
- Transcript
- RFC 6557
- JSON-LD -- A JSON-based serialization for Linked Data
- IETF BCP-47 -- Language tag
2020-07-07 - [email protected]
- Fix the broken link to the Bot Framework Manifest Spec in the References section
2020-06-19 - [email protected]
- Fix
A7420
andA7430
text to reflect original intent ofplayAudio
andplayVideo
actions - Add conversation reference type definition
2020-06-16 - [email protected]
- Integrate typo and casing fixes
- Fix internal anchor links and relative file links
2020-03-02 - [email protected]
- Added
imageAltText
2019-07-15 - [email protected]
- Added
A3035
to clarify behavior in the absence of aspeak
field.
2019-05-09 - [email protected]
- Removed A3032. Speak takes either plain text or valid SSML
2019-01-31 - [email protected]
- Revised specification of [locale] to reference BCP-47.
2019-05-02 - [email protected]
- Added
callerId
and Appendix V
2019-01-31 - [email protected]
- Revised specification of [locale] to reference BCP-47.
2019-01-31 - [email protected]
- Add
tenantId
to conversation account type
2019-01-11 - [email protected]
- Add
A7357
,A7358
, andA7359
to profileimage
andtitle
fields of themessageBack
action
2019-01-04 - [email protected]
- Resolved collision in Trace activity numbering:
A610x
->A615x
2018-12-06 - [email protected]
- Resolved restriction number collision by renaming duplicate
A7352
andA7353
toA7355
andA7356
, respectively - Fixed broken links
2018-10-23 - [email protected]
- Added action
state
2018-09-27 - [email protected]
- Revised reference descriptions and links
- Clarified syntactic rules, revised
A2003
, addedA2007
- Removed
A7743
as redundant - Removed ordering requirement for semantic action entities (
A7741
) - Added
$instance
to semantic action entities - Added action type downgrading
- Move
A7600
andA7601
and re-introduce asA2104
andA2105
2018-09-18 - [email protected]
- Added localTimezone property
2018-08-27 - [email protected]
- Added Channel account role property
- Added Conversation account role property
2018-07-17 - [email protected]
- Added
semanticAction
- Added handoff activity
2018-07-05 - [email protected]
- Changed
RXXXX
(Requiment) toAXXXX
(Activity) to match other Bot Framework specifications.
2018-04-11 - [email protected]
- Added Listen for field and Appendix IV
2018-04-08 - [email protected]
- Added Suggestion activity and
textHighlight
complex type. - Amended
A2071
to allow suggestion activities to specify receipients
2018-03-07 - [email protected]
- Added
conversationAccount.conversationType
andA2084
.
2018-02-07 - [email protected]
- Initial draft
Activity entities communicate extra metadata about the activity, such as a user's location or the version of the messaging app they're using. Activity types are intended to be IRIs, but a small list of non-IRI names are in common use. This appendix is an exhaustive list of the supported non-IRI entity types.
Type | IRI equivalent | Description |
---|---|---|
GeoCoordinates | http://schema.org/GeoCoordinates/ | Schema.org GeoCoordinates |
Mention | https://botframework.com/schema/mention | @-mention |
Place | http://schema.org/Place | Schema.org Place |
Thing | http://schema.org/Thing | Schema.org Thing |
string | N/A | String |
number | N/A | Number |
clientInfo | N/A | Skype client info |
The string
and number
primitive entity types contains simple values within the value
field. The value
field is a string or number, respectively.
Example:
{
"type": "string",
"value": "This is the string value"
}
The clientInfo
entity type contains extended information about the client software used to send a user's message. It contains three properties, all of which are optional.
A9201
: Bots SHOULD NOT send the clientInfo
entity.
A9202
: Senders SHOULD include the clientInfo
entity only when one or more fields are populated.
The locale
field contains the user's locale. This field duplicates the locale
field in the Activity root. The value of the locale
field is an ISO 639 [6] code within a string.
The locale
field within clientInfo
is deprecated.
A9211
: Receivers SHOULD NOT use the locale
field within the clientInfo
object.
A9212
: Senders MAY populate the locale
field within clientInfo
for compatibility reasons. If compatibility with older receivers is not required, senders SHOULD NOT send the locale
property.
The country
field contains the user's detected location. This value may differ from any locale
data as the country
is detected whereas locale
is typically a user or application setting. The value of the country
field is an ISO 3166-1 [11] 2- or 3-letter country code.
A9220
: Channels SHOULD NOT allow clients to specify arbitrary values for the country
field. Channels SHOULD use a mechanism like GPS, location API, or IP address detection to establish the country generating a request.
The platform
field describes the messaging client platform used to generate the activity. The value of the platform
field is a string and the list of possible values and their meaning is defined by the channel sending them.
Note that on channels with a persistent chat feed, platform
is typically useful only in deciding which content to include, not the format of that content. For instance, if a user on a mobile device asks for product support help, a bot could generate help specific to their mobile device. However, the user may then re-open the chat feed on their PC so they can read it on that screen while making changes to their mobile device. In this situation, the platform
field is intended to inform the content, but the content should be viewable on other devices.
A9230
: Bots SHOULD NOT use the platform
field to control how response data is formatted unless they have specific knowledge that the content they are sending may only ever be seen on the device in question.
The invoke activity is designed for use only within protocols supported by Bot Framework channels (i.e., it is not a generic extensibility mechanism). This appendix contains a list of all Bot Framework protocols using this activity.
The Microsoft Teams channel uses Invoke for compose extensions. This use of Invoke is specific to Microsoft Teams.
The listenFor
field within the Bot Framework activity schema contains a list of terms and references to hint to a speech or language processor which terms to prefer when processing input. This format is referred to within this appendix as the priming format.
The format allows:
- Phrases, including single-term phrases (e.g. "house", "open the doors")
- Sources of phrases (e.g., a LUIS model)
All contents appear within a flat array of strings.
Phrases are specified directly without markup. Sources are enclosed by {
and }
and their contents may be either a full URI or a shortened URI adhering to one of the conventions below.
A9300
: Senders SHOULD NOT include punctuation that does not affect language processing, such as enclosing parentheses or trailing periods. Senders MUST NOT enclose plain phrases with leading {
and trailing }
.
A9301
: Senders MAY include phrase sources by URI or short form. Phrase source URIs and short forms MUST be enclosed by leading {
and trailing }
. Senders SHOULD NOT include whitespace before or after {
and }
characters.
A9302
: Senders MUST URI-encode any {
, }
, and "
characters that occur within a phrase source.
A9303
: Processors SHOULD ignore phrase sources they do not understand.
Phrase source URIs may be symbolic or may be URLs. For example, https://example.com/language/models/1234#intent0001
could identify intent0001
within the example.com
language model with ID 1234
. The format of these URIs and relationship to the backing phrase source data is bounded by the example.com
hostname and is established entirely by the service supporting that name. Processors must have specific knowledge of each phrase source to determine the method of extraction. In some cases, an HTTP GET directly to the URL is adequate, in others, an entire language model may be retrieved and parsed to select individual phrases. A processor knows how to retrieve the data by inspecting the hostname.
A9304
: Processors MAY upgrade phrase source URIs to URLs when they have knowledge that the source supports phrase retrieval.
A9305
: Processors SHOULD use plain ordinal hostname comparisons when determining whether they recognize a source URI.
A9306
: Processors MAY ignore any resolved URLs that are not HTTPS.
Phrase sources specified in complete URIs (e.g. https://luis.ai/apps/12345#intent0001
) can be verbose and this spec establishes a format for shortening these URIs, and one known format specifically for LUIS apps.
A9307
: If a processor supports a phrase source, and that source has a compact representation, processors SHOULD support both the compact and the expanded format.
A9308
: Phrase sources SHOULD establish a well-defined mapping between compact and expanded forms of phrase source references.
This section provides a definition for the LUIS phrase source URI and compact form.
LUIS.ai models can be referenced with the following format:
https://luis.ai/apps/<appId>[/intents/<intentId>]
The short form for these IDs is:
luis:<appId>[#intentId]
The Activity schema includes a 'callerId' field that identifies the caller sending an activity. The field is not populated on the wire but is used for internal routing within a bot, and for tracking this data when an Activity is committed to storage (in e.g. the Transcript [#16] format).
This specification defines three IRI schemes for caller IDs.
It is important that implementers follow the verification rules in this appendix to ensure a caller ID is set only when the caller is successfully authenticated.
Bot Framework services call registered bots to transmit messages sent over Bot Framework channels. The caller ID for any Bot Framework channel service is urn:botframework:azure
.
The authenticity of a call from Bot Framework can be established by inspecting its JSON Web Token and ensuring it is both correctly formed and is signed with a key listed in the Bot Framework Open ID Metadata Document.
Bot Framework services running in the US Government Cloud are in a distinct security domain from traditional Bot Framework serivces. The caller ID for any Bot Framework channel service is urn:botframework:azureusgov
.
The authenticity of a call from Bot Framework US Government Cloud can be established by inspecting its JSON Web Token and ensuring it is both correctly formed and is signed with a key listed in the Bot Framework US Government Cloud Open ID Metadata Document.
The Activity schema can be used when a bot initiates a request to another bot acting as a skill. The caller ID for these calls is the prefix urn:botframework:aadappid:
followed by the Azure Active Directory App ID used by the bot initiating the call.
The authenticity of a call from a bot can be established by inspecting its JSON Web Token and ensuring it is both correctly formed and is signed with a key listed in the Azure Active Directory Open ID Metadata Document.
Command activities communicate a request to perform a specific action. Command activities outside the application
are considered reserved for Bot Framework Protocols. This appendix contains a list of command activities used in Bot Framework protocols and recommended patterns for defining and using command activities.
The Microsoft Telephony channel defines channel command activities in the namespace channel/vnd.microsoft.telephony.<action>
.
The general pattern for rejecting commands is to send an asynchronous commands result with an error. This is used in most cases when the receiver needs to process the command before rejecting it.
Here is an example of a command result indicating that the command was not supported by the receiver:
{
'type': 'commandResult'
'name': 'channel/vnd.microsoft.telephony.<action>'
'value': {
'error' : {
'code': 'NotSupported',
'message' : 'Command channel/vnd.microsoft.telephony.<action> is not supported'
}
}
}
Some channels may may not support the command protocol or not allow for application customization of commands. In this case, the channel can reject commands with a transport-level response codes to allow a sender to detect the command activity was rejected. Example: When the transport is HTTP, 200 indicates acceptance and 400 indicates that the Activity name is not supported.