Data store handlers are a special type of state handler that can provide LLM generated agent responses based on your website content and uploaded data.
To create this handler, you provide data stores when creating the agent.
Using these data store handlers, your agent can have conversations about the content with your end-users.
Limitations
The following limitations apply:
- This feature currently only supports select languages in GA. See the data store column in the language reference.
- Only the following regions
are supported:
global
,us
multi-region, andeu
multi-region. - The only structured data store type supported is FAQ.
- Apps with both chunked and non-chunked data stores are not supported.
Access control
If you are the project owner, you have all the permissions needed to create a data store handler. If you are not the project owner, you must have the following roles:
- Dialogflow Admin
- Discovery Engine Admin
For more information, see the access control guide.
Create an agent
To create an agent that uses data store handlers:
- If you have not already, follow the setup instructions.
Go to the Agent Builder console:
Select your project from the console drop-down.
If you have not already activated the API, read and agree to the Terms of Service, then click Continue and activate the API.
Click Create a New App or New App.
Select Chat.
Provide your company name in the Agent configurations section.
Expand the time zone and language settings section.
Select a time zone.
Select a default language.
Provide an agent name in the Your agent name section.
Select a region or multi-region in the Location of your agent section.
Click Continue.
Connect a data store to your agent by doing one of the following:
- Select an existing data store that you previously created.
- Create a new data store:
- Click Create New Data Store.
- Choose a data source.
- Provide data and configuration for the data store source you selected. Your data store location should correspond to the agent location.
- Click Create to create the data store.
- Select your new data store.
Click Create.
Your agent is now created, and you are automatically redirected to the Available data stores page, where you can add more data stores as needed.
If you have created a new data store for a website, you must verify your domain.
To open your agent with the Dialogflow CX console, click Preview in the left panel. In the console, you can edit or add data store handlers, deploy your agent, and optionally add flows that will handle scenarios not covered by the data stores.
Test your agent
You can use the simulator to test your agent.
Deploy your agent
There are many ways to deploy your agent:
The simplest option is to use an integration, which provides a user interface for your agent. Each integration provides instructions for deployment.
The Dialogflow CX Messenger integration is a particularly good option for data store handlers. It has built-in options for generative features.
You can create your own user interface and use the Conversational Agents (Dialogflow CX) API for interactions. Your user interface implementation is in control of deployment.
Special intents
In addition to handling questions about the content you provide, the agent can handle the following types of questions:
- Agent identification: Handles questions like "Who are you?" or "Are you human?".
- Escalate to a human agent: Handles questions like "I want to talk to a human" or "I want to talk to a real person".
This is accomplished by automatically generated intents and intent routes.
Add or edit data store handlers for an existing agent
Data store handlers are a special type of state handler. This means that you can apply them to flows or pages, and that they are evaluated using the same scope rules.
To add or edit a data store handler:
- Go to the Dialogflow CX console.
- Select your project.
- Select the agent.
- Select the flow associated with the data store handler. This is commonly the default start flow.
- Select the page associated with the data store handler. This is commonly the start page.
- Click Add state handler in the page data, then select data store.
- If you need to create a data store, you will be taken to the Vertex AI Agent Builder user interface. See the data store information to help you make selections.
- If you already have a data store, click Edit data store.
- Make updates as needed and save when you are complete. See information below about data store specific settings.
Agent responses
In the Agent responses section,
you can provide custom responses that reference generative answers.
Use $request.knowledge.answers[0]
in the Agent says section
to provide the generative answer.
Advanced response customization
Additional information may be available in $request.knowledge.*
that could be used to customize the response.
Such information includes:
- The identified sources of the answer with the following fields: snippet, title, uri.
- The grounding confidence for the answer.
- In case of an FAQ data store, the question corresponding to the answer that was selected.
See the table below for examples how to access this information.
Information | How to access |
---|---|
Snippet of the top identified source of the top answer | $sys.func.GET_FIELD($sys.func.GET($sys.func.IDENTITY($request.knowledge.sources[0]), 0), "snippet") |
Title of the top identified source of the top answer | $sys.func.GET_FIELD($sys.func.GET($sys.func.IDENTITY($request.knowledge.sources[0]), 0), "title") |
Link of the top identified source of the top answer | $sys.func.GET_FIELD($sys.func.GET($sys.func.IDENTITY($request.knowledge.sources[0]), 0), "uri") |
Number of identified sources for the top answer | $sys.func.COUNT($sys.func.IDENTITY($request.knowledge.sources[0])) |
Number of knowledge answers | $sys.func.COUNT($request.knowledge.answers) |
Question corresponding to the top answer (for FAQ data store answers only) | $request.knowledge.questions[0] |
Grounding confidence for the top answer | $request.knowledge.grounding_confidences[0] |
Data store response options
You can update the Link maximum field to indicate the maximum number of supplemental links that should be provided by the generative answers.