data:image/s3,"s3://crabby-images/091d5/091d5ad0aea3f94568e4cacf8c693b7cba871e3f" alt="Microsoft Teams"
Microsoft Teams
Microsoft has released Teams from one year, the utility of this product is indisputable, a strength is definitely the possibility to extend it with bots, connectors and tabs.
In this article, I’ll talk about how to build a bot and how to leverage the Microsoft Teams API capabilities, which are the following:
- 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/7dea2/7dea2c2ddf6bdf34b8a02675cee39f403cb52f7a" alt="Create a Bot via Azure"
Create a Bot via Azure
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/6eca8/6eca8a8afcf5f46627751a128166f498ded9e339" alt="Download Bot package"
Download Bot package
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/74382/74382921d81d2ebb35530eb491790e9b4d7d4c62" alt="launch.json"
launch.json
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>" } } ] }
data:image/s3,"s3://crabby-images/49592/495920efb42baa53878182b56004cbc1cb334c6d" alt="ngrok"
ngrok
The last step is set up the breakpoints and click on play:
data:image/s3,"s3://crabby-images/98108/981081ae6a82e1b100152fa2a936f9e1689d5d0b" alt="vscode-play"
vscode-play
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/b636c/b636c1cb14a931075cfd80a33891a85fbdbc6c9a" alt="Microsoft Teams API Example"
Microsoft Teams API Example
data:image/s3,"s3://crabby-images/f0b67/f0b67505f13aef1085218974b2cb31cdfdd477b9" alt="Microsoft Teams API Example"
Microsoft Teams API Example
data:image/s3,"s3://crabby-images/b6956/b6956d989b2b03a08ba32e66b99b1f394770ab45" alt="Microsoft Teams API Example"
Microsoft Teams API Example
data:image/s3,"s3://crabby-images/3f21f/3f21fc9bdf1768a2d608da52cf8eaab37acfd453" alt="Microsoft Teams API Example"
Microsoft Teams API Example
data:image/s3,"s3://crabby-images/005b1/005b1fed7eba943d0a48aff71be0288f79bcbdbe" alt="Microsoft Teams API Example"
Microsoft Teams API Example
The solution is available on Github:
https://github.com/giuleon/teams-bot-api
Reference:
De Luca, G. (2018). Building a Microsoft Teams Bot. Available at: https://delucagiuliano.com/building-a-microsoft-teams-bot/#.Wr3yGYjwaUk [Accessed 30 Mar. 2018].