Skip to content
This repository has been archived by the owner on Oct 17, 2024. It is now read-only.

Solution Overview

Shraddha Sarda edited this page Dec 15, 2021 · 5 revisions

architecture-overview

The FAQ Plus application has the following main components:

  • QnA Maker: Resources that comprise the QnAMaker service, which implements the "FAQ" part of the application. The installer creates a knowledge base using the tools provided by QnAMaker.

  • FAQ Plus Expert Bot: The bot serves experts team

    • The experts team receives notifications from the bot when end-users ask questions to expert or create feedback items. The bot tracks questions in a simple "ticketing system", with a basic life cycle of Unassigned -> Assigned to expert -> Closed. The bot notifies both the end-user and the experts team as the request changes states.
    • Using the bot, members of the experts team can add QnA to the existing knowledge base.
    • The bot also implements a messaging extension that lets members of the expert team search for tickets or questions in the knowledge base.
  • FAQ Plus User Bot: The bot serves both end-users and experts team

    • The knowledge base (KB) in QnA Maker is presented to end-user in a 1:1 conversational bot interface. Through the bot, end-user can ask the question to bot, escalate to a designated experts team, send feedback about the app, or give feedback on specific answers.
  • Blob Storage : The knowledge base with QnA and associated metadata is stored in blob storage by Azure function. The same is shown by messaging extension for respective section and search categories using Azure search service.

  • Azure Function: QnA changes in QnA Maker are published every fifteen minutes to knowledge base by time triggered Azure functions.

  • Configuration Application: An Azure App Service lets app admins configure the application to provide team and knowledge base details. These values are necessary to map the expert team and the associated knowledge base. Currently app supports only one knowledge base per tenant(deployment).

QnA Maker

FAQ Plus uses QnA Maker to respond to user questions; in fact, you can have a blank knowledge base to start using FAQ Plus. The precision and recall of the bot responses to end-user questions are directly tied to the quality of the knowledge base, so it's important to follow QnA Maker's recommended best practices. Please keep in mind that a good knowledge base requires curation and feedback: see Development lifecycle of a knowledge base.

For more details about QnA Maker, please refer to the QnAMaker documentation.

Bot and Messaging Extension

The bot is built using the Bot Framework SDK v4 for .NET and ASP.NET Core 2.1. The bot has a conversational interface in personal (1:1) scope for end-users and in team scope for the experts team. It also implements a messaging extension with query commands, which the experts team can use to search for and share requests or knowledge base questions.

Azure Function

Azure function ASP.NET Core 2.1 is used in building the bot. It publishes the QnA pair in the QnAMaker and stores the QnA in the blob storage. It creates a search index to search questions in the knowledge base tab on messaging extension.

Blob Storage

Blob Storage stores the QnA pair in JSON format. QnA can be searched from the search tab in the messaging extension.

Configuration App

The configuration app is a standard ASP.NET MVC 5 web app. The configuration app will be used infrequently, so the included ARM template puts it in the same App Service Plan as the bot and QnAMaker.

From this simple web interface, app administrators can:

  • designate the experts team
  • set the knowledge base to query
  • set the welcome message that's sent to all end-users
  • set the content of the Help tab
Clone this wiki locally