Bots and SDKs
You can create a bot that works in Microsoft Teams with one of the following tools or capabilities:
- Microsoft Bot Framework SDK
- Microsoft Entra ID
- Developer Portal
- Power Virtual Agents
- Virtual Assistant
- Webhooks and connectors
- Bot Framework Composer
Bots with the Microsoft Bot Framework
Your Teams bot consists of the following:
- A publicly accessible web service hosted by you.
- A Bot Framework registration for your web service.
- Your Teams app package, which connects the Teams client to your web service.
Tip
Use the Developer Portal to register your web service with the Bot Framework and specify your app configurations. For more information, see manage your apps with the Developer Portal for Teams.
The Bot Framework is a rich SDK used to create bots using C#, Java, Python, and JavaScript. If you already have a bot that is based on the Bot Framework, you can easily modify it to work in Teams. Use either C# or Node.js to take advantage of our SDKs. These packages extend the basic Bot Builder SDK classes and methods as follows:
- Use specialized card types like the connector card for Microsoft 365 Groups.
- Set Teams-specific channel data on activities.
- Process message extension requests.
You can develop Teams apps in any web programming technology and call the Bot Framework REST APIs directly. You must perform token handling in all cases.
Bots with Power Virtual Agents
Power Virtual Agents is a chatbot service built on the Microsoft Power platform and Bot Framework. The Power Virtual Agent development process uses a guided, no-code, and graphical interface approach that empowers your team members to easily create and maintain an intelligent virtual agent. After creating your chatbot in the Power Virtual Agents portal, you can easily integrate it with Teams. For more information on getting started, see Power Virtual Agents documentation.
Note
You must not use Microsoft Power Platform to create apps that are to be published to the Microsoft Teams Store. Microsoft Power Platform apps can be published to an organization’s app store only.
Bots with webhooks and connectors
Webhooks and connectors connect your bot to your web services. Using webhooks and connectors, you can create a bot for basic interaction, such as creating a workflow or other simple commands. They're available only in the team where you create them and are intended for simple processes specific to your company's workflow. For more information, see what are webhooks and connectors.
Advantages of bots
Bots in Microsoft Teams can be part of a one-to-one conversation, a group chat, or a channel in a team. Each scope provides unique opportunities and challenges for your conversational bot.
In a channel | In a group chat | In a one-to-one chat |
---|---|---|
Massive reach | Fewer members | Traditional way |
Concise individual interactions | @mention to bot | Q&A bots |
@mention to bot | Similar to channel | Bots that tell jokes and take notes |
In a channel
Channels contain threaded conversations between multiple people even up to 2000. This potentially gives your bot massive reach, but individual interactions must be concise. Traditional multi-turn interactions don't work. Instead, you must look to use interactive cards or dialogs (referred as task modules in TeamsJS v1.x), or move the conversation to a one-to-one conversation to collect lots of information. Your bot only has access to messages where it's @mentioned
. You can retrieve additional messages from the conversation using Microsoft Graph and organization-level permissions.
Bots work better in a channel in the following cases:
- Notifications, where you provide an interactive card for users to take additional information.
- Feedback scenarios, such as polls and surveys.
- Single request or response cycle resolves interactions and the results are useful for multiple members of the conversation.
- Social or fun bots, where you get an awesome cat image, randomly pick a winner, and so on.
In a group chat
Group chats are non-threaded conversations between three or more people. They tend to have fewer members than a channel and are more transient. Similar to a channel, your bot only has access to messages where it's @mentioned
directly.
Bots that work better in a channel also work better in a group chat.
In a one-to-one chat
One-to-one chat is a traditional way for a conversational bot to interact with a user. A few examples of one-to-one conversational bots are:
- Q&A bots
- bots that initiate workflows in other systems.
- bots that tell jokes.
- bots that take notes. Before creating one-to-one chatbots, consider whether a conversation-based interface is the best way to present your functionality.
Disadvantages of bots
An extensive dialog between your bot and the user is a slow and complex way to get a task completed. A bot that supports excessive commands, especially a broad range of commands, isn't successful or viewed positively by users.
Have multi-turn experiences in chat
An extensive dialog requires the developer to maintain state. To exit this state, a user must either time out or select Cancel. Also, the process is tedious. For example, see the following conversation scenario:
USER: Schedule a meeting with Megan.
BOT: I’ve found 200 results, include a first and last name.
USER: Schedule a meeting with Megan Bowen.
BOT: OK, what time would you like to meet with Megan Bowen?
USER: 1:00 pm.
BOT: On which day?
Support too many commands
As there are only six visible commands in the current bot menu, anything more is unlikely to be used with any frequency. Bots that go deep into a specific area rather than trying to be a broad assistant work and fare better.
Maintain a large knowledge base
One of the disadvantages of bots is that it's difficult to maintain a large retrieval knowledge base with unranked responses. Bots are best suited for short, quick interactions, and not sifting through long lists looking for an answer.
Limitations and known issues
If you're unable to create a bot in Developer Portal, ensure the following:
App registration is enabled for users: When an app registration is disabled org-wide, users (other than users with Microsoft Entra admin access) can't register new apps. To allow users to register apps, admins must toggle Users can register applications to Yes in the Microsoft Entra admin center.
Give permissions to specific users to register new apps:
For Microsoft 365 licenses where app registration limit is 250 apps per user, ensure that the admin adds Microsoft Entra ID to a user with the following roles:
For information about how to assign roles, see Assign Microsoft Entra roles to users.
For Microsoft 365 (P1, P2, E3, or E5 plan) license where app registration limit is default to tenant limit (more than 300,000) per user, ensure that the admin adds Microsoft Entra ID to a user and assigns a Custom role to the user with the following permissions:
microsoft.directory/applications/create
microsoft.directory/applications/createAsOwner
Code snippets
The following code provides an example of a bot activity for a channel team scope:
protected override async Task OnMessageActivityAsync(ITurnContext<IMessageActivity> turnContext, CancellationToken cancellationToken)
{
var mention = new Mention
{
Mentioned = turnContext.Activity.From,
// EncodeName: Converts the name to a valid XML name.
Text = $"<at>{XmlConvert.EncodeName(turnContext.Activity.From.Name)}</at>",
};
// MessageFactory.Text(): Specifies the type of text data in a message attachment.
var replyActivity = MessageFactory.Text($"Hello {mention.Text}.");
replyActivity.Entities = new List<Entity> { mention };
// Sends a message activity to the sender of the incoming activity.
await turnContext.SendActivityAsync(replyActivity, cancellationToken);
}
The following code provides an example of bot activity for a one-to-one chat:
// Handle message activity
protected override async Task OnMessageActivityAsync(ITurnContext<IMessageActivity> turnContext, CancellationToken cancellationToken)
{
// Remove recipient mention text from Text property.
// Use with caution because this function is altering the text on the Activity.
turnContext.Activity.RemoveRecipientMention();
var text = turnContext.Activity.Text.Trim().ToLower();
// Sends a message activity to the sender of the incoming activity.
await turnContext.SendActivityAsync(MessageFactory.Text($"Your message is {text}."), cancellationToken);
}
Code sample
Sample name | Description | .NETCore | Node.js | Python | Manifest |
---|---|---|---|---|---|
Teams conversation bot | This sample app shows how to use different bot conversation events available in bot framework v4. | View | View | View | View |
Bot samples | Set of bot framework v4 samples. | View | View | View |