Setup Bot Framework Development Environment Using .Net (C#) - Part Two

In the previous article, I have explained how to build FAQ based bot application using QnA maker for questions and answers. In this article, we will discuss how to set up the Bot Framework development environment and we are going to consume QnA maker Service.

This article will walk you through “How to set up a Bot Framework development environment using .NET (C#)” and test the bot application using Bot Framework Emulator.

Prerequisites

Navigate and place the Bot Application.zip template to the below path.

%USERPROFILE%\Documents\Visual Studio 2017\Templates\ProjectTemplates\Visual C#\

Navigate and place the Bot Controller.zip and Bot Dialog.zip template to the below path.

%USERPROFILE%\Documents\Visual Studio 2017\Templates\ItemTemplates\Visual C#\

Launch the Visual Studio

Once you launch the Visual Studio 2017 and navigate to File -> New Project,  you can get the Bot Framework Template under Visual C# Template.

Visual Studio Launch Screen 

You can create a bot application using Visual Studio Bot Application template or download the Bot Application Solution created by Azure Portal using Bot Framework SDK. In the previous article, I have created the bot application in the Azure portal. I am going to download and update the solution. 

Steps to get the Microsoft Azure Bot Application Solution

  1. Log in to Azure Portal, i.e., https://portal.azure.com and search for the created bot name (my bot name is bot2018).
  2. Select "Web App Bot" and you will be redirected to the "Web App Bot details" page.



  3. Select Build under Bot Management. You get two options there.

    • In the Online Code Editor Option, open the codebase into Visual Studio online.
    • Download the source code using "Download Zip file" option.

    Select the second option i.e. Download Zip file.

  4. Once you download the solution, unzip the source code. 

  5. Launch the Visual Studio 2017 and go to File -> Open Project -> Select the solution.

  6. Expand the Reference Section. The All DLL or Packages link will be in broken mode. So, we need to update this with the latest version and packages.

     

  7. Right-click the project and select "Manage NuGet Packages". Then, wait for a couple of seconds. The NuGet Package Manager will show the available updates. Select all packages and click "Update".

  8. Update Microsoft.Net.Compliers V2.6.1 to V1.2.1 

  9. Add Key and Value under App Settings in the Web.Config file.

    AzureWebJobsStorage,  QnASubscriptionKey, QnAKnowledgebaseId. These values can be get from Azure Bot Application App Service Settings.
    1. <add key="AzureWebJobsStorage" value="DefaultEndpointsProtocol=https;AccountName=bot2018019ada;AccountKey=TPainlj4hGSND3IjYuyP5234m5;"/>  
    2.    <add key="QnASubscriptionKey" value="2b523241d6b4a5c105a6e0ad7e"/>  
    3. <add key="QnAKnowledgebaseId" value="453c2a2d-b423-4816-8544-130edf0f593"/>  
  10. Navigate to Project -> Dialog folder -> Basic QnADialog.cs file. Replace below section two places using find and replace.

    1. Replace -> Utils.GetAppSetting("QnAKnowledgebaseId") with ConfigurationManager.AppSettings["QnAKnowledgebaseId"];
    2. Replace -> Utils.GetAppSetting("QnASubscriptionKey") with ConfigurationManager.AppSettings["QnASubscriptionKey"]; 

  11. Press F5 or Run the solution. VS solution executes on the localhost with port number.

Test your Bot Framework locally

Download Bot Framework Emulator and install the executable.



Open installed Bot Emulator. Select the Ellipses menu and click "App Settings".


 
Download ngrok and add a reference to the app settings in Bot Framework Emulator and click "Save".

 

Response by Emulator 

You can start asking the question as crawled by QnA Maker and you will get the response like below.

 

Publish and test Visual Studio solution on the Azure platform  
  1. Navigate to Azure Bot App Services and click "Get Publish Profile".



  2. Select Visual Studio Project -> Right Click -> Publish option.



  3. Select “Create new profile”.



  4. Select "Import file" and click "Publish".



  5. Solution is successful and published at the Azure Bot website.



  6. Test the bot framework in the Azure portal.

    Navigate to Azure Web App Bot and select "Test in Web Client" under Bot Management section. You can start asking the question as crawled by QnA Maker and you will be prompted with the following response.

Note

I recorded the comlete article and made it available on my YouTube channel also.


Similar Articles