-
Notifications
You must be signed in to change notification settings - Fork 35
Solution Overview
The follwoing commands are supported:
Bot Command | Bot Response |
---|---|
Book room | Presents list of favorite rooms which can be booked for a meeting |
Manage favorites | Responds with an adaptive card with action button to invoke the task module for managing user favorites |
Help | Presents a list of commands that the bot supports |
The bot is built using the Bot Framework SDK v4 for .NET and ASP.NET Core 2.1 . The bot has a conversational interface with personal scope. The app majorly performs below actions -
- Provides user sign in flow using bot service Azure Active Directory v2 connection settings to get favorite rooms based on user ID and check availability and book room using Microsoft Graph APIs.
- Create meeting with user selections.
Features such as manage user favorites and book other rooms (non-favorite) are implemented using ReactJs and .Net Core 2.1. A task module in Microsoft Teams uses Microsoft Teams Javascript SDK to get current Teams context.
Recurring operation of room sync from Microsoft Exchange to Azure table storage created using .Net Core 2.1. It follows following steps for sync:
- Get list of buildings from Microsoft Graph API.
- Create batch of 10 buildings. (Useful for parallel execution)
- For every building in batch:
- Get records from table storage matching building email ID.
- Get rooms from Microsoft Graph API associated with building email ID.
- Delete existing records from table storage matching building email ID.
- Add records fetched from Microsoft Graph API to table storage.
- Find out deleted rooms from exchange and remove them from user favorites.
Azure bot service is developed using Microsoft Bot Framework .Net SDK v4.
- Azure Active Directory v2 service provider is used for authentication and registered in OAuth connection string settings in bot registration portal.
- Meetings web app endpoint is registered as messaging end point in bot registration portal.
- The bot follows the waterfall dialog concept to combine sequential steps and allow passing state to next steps.
The MainDialog component dialog have below steps –
- PromptStepAsync
- CommandStepAsync
- ProcessStepAsync
- Each step checks user token using WaterfallStepContext and OAuth card is provided in case of no token found by following the sequence starting from PromptStepAsync.
- Logout interruption is handled in LogoutDialog (base class of MainDialog) and can be extended to handle other interruptions. In case of any other interruption, user will be provided with the message to complete the current process.
In order to allow application to support various data sources, all methods are implemented by using below interfaces. All dependencies are registered in Startup file -
- IMeetingProvider: provides methods to process meeting location information.
- ISearchService: provides methods to perform room and building search operations.
- IActivityStorageProvider: provides methods to process CRUD operations on ActivityEntities table.
- IFavoriteStorageProvider: provides methods to process CRUD operations on FavoriteRooms table.
- IRoomCollectionStorageProvider: provides methods to process CRUD operations on RoomCollection table.
- IUserConfigurationStorageProvider: provides methods to process CRUD operations on UserConfiguration table.
- IUserConfigurationProvider: provides method to get user specific details from Microsoft Graph.
Azure table storage saves buildings and rooms information along with favorite rooms of users.
Application performs rooms and buildings data sync operation from Microsoft Exchange to table storage which requires application level permission and requires tenant admin to provide consent.
Use Case | API | Delegated Permission | Application Permission |
---|---|---|---|
Get schedules for rooms | https://graph.microsoft.com/v1.0/me/calendar/getSchedule | Calendars.ReadWrite | NA |
Create event | https://graph.microsoft.com/v1.0/me/calendar/events | Calendars.ReadWrite | NA |
Cancel event | https://graph.microsoft.com/beta/me/events/{id}/cancel | Calendars.ReadWrite | NA |
List places (buildings) | https://graph.microsoft.com/beta/places/microsoft.graph.roomlist | NA | Place.Read.All |
List places (rooms) | https://graph.microsoft.com/beta/places/{BuildingAlias}/microsoft.graph.roomlist/rooms | NA | Place.Read.All |