ConversationBot class
Provide utilities for bot conversation, including:
- handle command and response.
- send notification to varies targets (e.g., member, group, channel).
Example
For command and response, you can register your commands through the constructor, or use the registerCommand
and registerCommands
API to add commands later.
import { BotBuilderCloudAdapter } from "@microsoft/teamsfx";
import ConversationBot = BotBuilderCloudAdapter.ConversationBot;
// register through constructor
const conversationBot = new ConversationBot({
command: {
enabled: true,
commands: [ new HelloWorldCommandHandler() ],
},
});
// register through `register*` API
conversationBot.command.registerCommand(new HelpCommandHandler());
For notification, you can enable notification at initialization, then send notifications at any time.
import { BotBuilderCloudAdapter } from "@microsoft/teamsfx";
import ConversationBot = BotBuilderCloudAdapter.ConversationBot;
// enable through constructor
const conversationBot = new ConversationBot({
notification: {
enabled: true,
},
});
// get all bot installations and send message
for (const target of await conversationBot.notification.installations()) {
await target.sendMessage("Hello Notification");
}
// alternative - send message to all members
for (const target of await conversationBot.notification.installations()) {
for (const member of await target.members()) {
await member.sendMessage("Hello Notification");
}
}
Remarks
Set adapter
in ConversationOptions to use your own bot adapter.
For command and response, ensure each command should ONLY be registered with the command once, otherwise it'll cause unexpected behavior if you register the same command more than once.
For notification, set notification.storage
in ConversationOptions to use your own storage implementation.
Constructors
Conversation |
Create new instance of the |
Properties
adapter | The bot adapter. |
card |
The action handler used for adaptive card universal actions. |
command | The entrypoint of command and response. |
notification | The entrypoint of notification. |
Methods
request |
The request handler to integrate with web request. Example For example, to use with Express:
|
Constructor Details
ConversationBot(ConversationOptions)
Create new instance of the ConversationBot
.
new ConversationBot(options: ConversationOptions)
Parameters
- options
- ConversationOptions
The initialize options.
Remarks
It's recommended to create your own adapter and storage for production environment instead of the default one.
Property Details
adapter
The bot adapter.
adapter: CloudAdapter
Property Value
CloudAdapter
cardAction
The action handler used for adaptive card universal actions.
cardAction?: CardActionBot
Property Value
command
notification
Method Details
requestHandler(Request<Record<string, unknown>, Record<string, undefined | string | string[]>>, Response, (context: TurnContext) => Promise<any>)
The request handler to integrate with web request.
Example
For example, to use with Express:
// The default/empty behavior
const expressApp = express();
expressApp.use(express.json());
expressApp.post("/api/notification", conversationBot.requestHandler);
// Or, add your own logic
const expressApp = express();
expressApp.use(express.json());
expressApp.post("/api/notification", async (req, res) => {
await conversationBot.requestHandler(req, res, async (context) => {
// your-own-context-logic
});
});
function requestHandler(req: Request<Record<string, unknown>, Record<string, undefined | string | string[]>>, res: Response, logic?: (context: TurnContext) => Promise<any>): Promise<void>
Parameters
- req
-
Request<Record<string, unknown>, Record<string, undefined | string | string[]>>
An incoming HTTP Request.
- res
-
Response
The corresponding HTTP Response.
- logic
-
(context: TurnContext) => Promise<any>
The additional function to handle bot context.
Returns
Promise<void>