Skip to content

Latest commit

 

History

History

msgext-doc-search-csharp

page_type description products languages
sample
This sample demonstrates how to integrate Azure AI Search in a Teams message extension to enable Hybrid Search (Vector + Semantic) using Teams Toolkit for Visual Studio and .NET and use the message extension as a plugin in Microsoft 365 Copilot.
office-teams
copilot-m365
dotnet
csharp

EcoGroceries Call Center message extension with Azure AI Search sample

License.

This sample implements Azure AI Search (Formerly known as "Cognitive Search") with a Teams message extension that enables Hybrid Search (Vector + Semantic) and can be used as a plugin for Microsoft 365 Copilot. Architecture below demonstrates how developers can use Microsoft 365 Copilot in Bring Your Own Data scenarios instead of building a custom GPT powered bot.

GIF of the architecture of the sample extension

The message extension allows users to query data inside the EcoGroceries Call Center records and returns the most accurate results with the power of Hybrid Search (Vector + Semantic).

the EcoGroceries Call Center message extension on Copilot

Prerequisites

Setup and use the sample

This sample requires a manual step to upload documents to Azure AI Search in embeddings format before running the app locally and testing the Hybrid Search (Vector + Semantic) capability with Microsoft 365 Copilot.

Step 1 - Upload documents to Azure AI Search

In this step, you will use Azure OpenAI Studio, Add Your Data capability to upload documents to Azure AI Search in embeddings format.

  1. Open the Azure OpenAI resource you created earlier, select Go to Azure OpenAI Studio.
  2. In Azure OpenAI Studio, select Deployments, create two new deployment models, select gpt-35-turbo-16k as a model type in the first model and text-embedding-ada-002 for the second model.
  3. Select Chat from the menu and select Add your data (preview) under the Assistant setup section, then Add a data source.
  4. Select Upload files from the drop-down menu:
    • Select your subscription.
    • Select the Blob Storage and Azure AI Search resources you created in the pre-requisites.
    • Provide an index name.
    • Check the box for Add vector search to this search resource.
    • Select the text-embedding-ada-002 model you created earlier.
    • Check the box for the acknowledgement, then select Next. Screenshot of the upload your data setup
    • Drag and drop the files from the documents folder to the Upload files section, then select Upload files. Screenshot of the upload your files.

Once the documents are successfully uploaded to Azure AI Search index as embeddings, you can test your data in the Chat section by using the following questions:

  • "Any customer complaints recently?"
  • "Find refund orders"

Step 2 - Run the application locally

Clone or Download the sample repository: https://github.com/OfficeDev/Microsoft-365-Copilot-Samples/.

Navigate to the samples/msgext-doc-search-csharp folder and open with Visual Studio.

Navigate to the samples/msgext-doc-search-csharp/env folder, rename .env.local.sample file to .env.local and .env.local.user.sample file to .env.local.user. In .env.local.user file, provide the following variables:

   AZURE_OPENAI_SERVICE_NAME= the endpoint url of the Azure OpenAI resource 
   AZURE_OPENAI_DEPLOYMENT_NAME= the deployment name of the `text-embedding-ada-002` model
   AZURE_OPENAI_API_KEY= the key available under Keys and endpoints on Azure OpenAI resource
   AZURE_SEARCH_ENDPOINT= the endpoint url of Azure AI Search
   AZURE_SEARCH_ADMIN_KEY= the admin key available under Keys on Azure AI Search resource
   AZURE_SEARCH_INDEX_NAME= the index name created when uploading documents

Select the dropdown button right next to the debugging button Microsoft Teams (Browser) and select Dev Tunnels > Create a Tunnel. Choose the Microsoft 365 account you would like to create the dev tunnel on, give a name to the dev tunnel, select tunnel type and access level, select OK. Make sure to select the newly created dev tunnel under the Dev Tunnels.

Right click to the project, select Teams Toolkit > Prepare Teams app dependencies. Select F5 to start debugging, or click Microsoft Teams (Browser) button.

A browser window will open and invite you to log in. Once you're in, Microsoft Teams should open up and display a dialog offering to install your application. Select Add to add EcoGroceries Call Center as a personal application.

Add application to Teams

Test the message extension on Teams chat first before testing it on Microsoft 365 Copilot.

Test application on Teams chat

Step 3 - Test the app in Microsoft 365 Copilot

Navigate to the Microsoft 365 Copilot chat. Check the lower left of the chat user interface, below the compose box. You should see a plugin icon. Click this and enable the EcoGroceries Call Center plugin.

Plugin panel

For best results, start a new chat by typing "New chat" before each prompt or set of related prompts.

Here are some prompts to try that use only a single parameter of the message extension:

  • "Find refund orders in EcoGroceries"

  • "Any customer complaints in EcoGroceries?"

  • "Find any info about the order no 345678 in EcoGroceries"

  • "How was the call between customer agent and Sarah Ramirez in EcoGroceries?"

As you're testing, watch the log messages within your application. You should be able to see when Copilot calls your plugin.

demo-30seconds.mp4

Samples Gallery