Building a Microsoft Teams Bot
- Fetch Channel List
- Mention User
- Start New 1 on 1 Chat
- Route Message To General
- Fetch Member List
- Send O365 Card
- Fetch Team Info
- Start New Reply Chain
- Mention Channel
- Mention Team
- Notification Feed
- Bot Delete Message
Let’s start to create a bot, the easiest way is create a “Web App Bot” on Azure, this naturally presupposes the possession of a subscription:
data:image/s3,"s3://crabby-images/f3b44/f3b441d9e2f076162a797f5f755bd0ae05c40659" alt="Giuliano De Luca | Blog | delucagiuliano.com"
The next step is to download the package, you can do it by clicking on “Build” under “Bot Management” and then “Download zip file”:
data:image/s3,"s3://crabby-images/05a10/05a109a7337e2f5b89859905e907366861671d7d" alt="Giuliano De Luca | Blog | delucagiuliano.com"
Unzip the content in a folder and open it with Visual Studio Code or other code editors, in my case I’ll use VSCode. In order to debug the bot locally is required ngrok a “secure introspectable tunnels to localhost webhook development tool and debugging tool”, then on VSCode create a folder “.vscode” and a file “launch.json” as follow:
data:image/s3,"s3://crabby-images/aebbc/aebbcf69d039ad01ef179fd5f4669ea96cf6e4d8" alt="Giuliano De Luca | Blog | delucagiuliano.com"
The content of the file “launch.json” is:
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
"version": "0.2.0",
"configurations": [
{
"type": "node",
"request": "launch",
"name": "Launch Program",
"program": "${workspaceFolder}\\app.js",
"env": {
"MicrosoftAppId": "<App ID>",
"MicrosoftAppPassword": "<App Password>",
"AzureWebJobsStorage": "<Connection string available on Azure>"
}
}
]
}
This allows running the VSCode debugger. When you are ready to debug your bot run the console command “ngrok http 3978” and copy the https URL:
data:image/s3,"s3://crabby-images/ccd83/ccd8381c4a355d900edc499511fa514dd93de938" alt="Giuliano De Luca | Blog | delucagiuliano.com"
Open the “Settings” of your bot on Azure and paste the ngrok https URL in the field “Messaging endpoint”, at the end will be something like that https://ngrokurl/api/messages in this way your bot will respond directly from your local machine. The last step is set up the breakpoints and click on play:
data:image/s3,"s3://crabby-images/52cce/52cce1795089c492112432d664af48e351ea948b" alt="Giuliano De Luca | Blog | delucagiuliano.com"
Open Teams and start a new chat, in the field to: write the Microsoft App Id that you can read on Azure in “Application Settings” this allow you to start a one to one conversation with your bot. I developed a sample that you can find on my Github which makes use of Microsoft Teams API check the images below:
data:image/s3,"s3://crabby-images/3db3a/3db3a6d3d1e95a967fb52e5933c79f1b1058d3f1" alt="Giuliano De Luca | Blog | delucagiuliano.com"
data:image/s3,"s3://crabby-images/4d74b/4d74b277a5264191f99b1a28ca58ab0410d4a7ef" alt="Giuliano De Luca | Blog | delucagiuliano.com"
data:image/s3,"s3://crabby-images/f5a48/f5a48141984269e88a3f59e415bb9acce88fc912" alt="Giuliano De Luca | Blog | delucagiuliano.com"
data:image/s3,"s3://crabby-images/f2ed3/f2ed3bd03c9a4c41bcb28978fc069bd3a1b47faa" alt="Giuliano De Luca | Blog | delucagiuliano.com"
data:image/s3,"s3://crabby-images/8f2be/8f2bee778db15d8c64391b5e31f7f7578cb6a0a4" alt="Giuliano De Luca | Blog | delucagiuliano.com"
data:image/s3,"s3://crabby-images/56132/56132910322e5fb7705d7a570996cc7437fb5335" alt="Giuliano De Luca | Blog | delucagiuliano.com"
The solution is available on Github: https://github.com/giuleon/teams-bot-api