Using the BotBuilder Plugin
Adapters
A BotBuilder CloudAdapter is responsible for managing communication between a bot and its users.
It serves as the entry point for incoming activities and forwards them to the registered ActivityHandler for processing.
You can customize the adapter to add middleware for logging, authentication, and define error handling.
The BotBuilderPlugin provided within the Teams SDK, connects the SDK with the BotBuilder framework.
It can either use an existing CloudAdapter or create a new default one, allowing activities to be processed through BotBuilder
while still handling events via the Teams SDK App framework.
Activity Handlers
The BotBuilder ActivityHandler contains the actual bot logic for processing messages or events
similar to how the Teams SDK App routes messages and events. You can override any number of methods,
such as OnMembersAdded
or onMessage
,
to handle different activity types.
Turn Context
Each incoming activity is wrapped in a TurnContext, which represents the context of a single turn in the conversation.
TurnContext provides access to:
- The incoming activity (message, event).
- Services for sending responses back to the user.
- Conversation, user, and channel metadata.
Teams SDK has IActivityContext
for the same purpose.
How it all comes together
The CloudAdapter creates the TurnContext, and the ActivityHandler uses it to read the activity and send responses.
With the BotBuilderPlugin, when a message or activity is received:
- The BotBuilder ActivityHandler runs first, handling the activity according to standard Bot Framework logic.
- The Teams SDK app based activity handlers execute afterward, allowing Teams SDK logic to execute.
This snippet shows how to use the BotBuilderPlugin to send and receive activities using botbuilder instead of the default Teams SDK http plugin.
- index.ts
- adapter.ts
- activity-handler.ts
import { App } from '@microsoft/teams.apps';
import { BotBuilderPlugin } from '@microsoft/teams.botbuilder';
import adapter from './adapter';
import handler from './activity-handler';
const app = new App({
plugins: [new BotBuilderPlugin({ adapter, handler })],
});
app.on('message', async ({ send }) => {
await send('hi from teams...');
});
(async () => {
await app.start();
})();
import { CloudAdapter } from 'botbuilder';
// replace with your BotAdapter
const adapter = new CloudAdapter(
new ConfigurationBotFrameworkAuthentication(
{},
new ConfigurationServiceClientCredentialFactory({
MicrosoftAppType: tenantId ? 'SingleTenant' : 'MultiTenant',
MicrosoftAppId: clientId,
MicrosoftAppPassword: clientSecret,
MicrosoftAppTenantId: tenantId,
})
)
);
export default adapter;
import { TeamsActivityHandler } from 'botbuilder';
// replace with your TeamsActivityHandler
export class ActivityHandler extends TeamsActivityHandler {
constructor() {
super();
this.onMessage(async (ctx, next) => {
await ctx.sendActivity('hi from botbuilder...');
await next();
});
}
}
const handler = new ActivityHandler();
export default handler;
In this example:
adapter.tsdefines aCloudAdapterto handle incoming activities, and can include middleware support or error handling.activity-handler.tsdefines theActivityHandlerand contains the core bot logic, handling incoming messages and sending responses via theTurnContext.index.tssets up a Teams SDKappand registers theBotBuilderPluginwith your adapter and activity handler. It also defines a native Teams SDK activity handler that responds to messages.
In the ouptut below, The first line comes from the BotBuilder ActivityHandler. The second line comes from the Teams SDK message activity handler. This shows that both handlers can process the same message sequentially when using the BotBuilder Plugin. This strategy can now be used to incrementally migrate from BotBuilder to the Teams SDK.
hi from botbuilder...
hi from teams...