Answer Generation API¶
This API allows you to fetch answers to a query from SearchAI corresponding to the input query and the meta filters sent in the request body. Additionally, this API also returns debug information about the qualified chunks used to generate answers.
Method | POST |
---|---|
Endpoint | https://{{host}}/api/public/stream/{{AppID}}/advancedSearch |
Content Type | application/json |
Authorization | auth: {{JWT}} See How to generate the JWT Token |
API Scope | Answer Generation |
Query Parameters¶
PARAMETER | REQUIRED | DESCRIPTION |
host | Required | The environment URL. For example, https://platform.kore.ai
|
App ID | Required | Unique Identifier of your application. To view your App ID, go to the Dev Tools under App Settings. You can view the AppID under the API scopes. |
Sample Request¶
curl --location 'https://platform.kore.ai/api/public/stream/st-3beea617-cfd5-5224-b70b-656c4eef768e/advancedSearch' \
--header 'auth: eyJhbGciOiJnR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwiYXBwSWQiOiJjcy05Yzg5MGMwOS1kMzQ5LTUzZjctYmIwZC1jYWEwZGIwOGNmMTkifQ.K2DWFPthcsTlltPTcR1irzjlxr4LYUzknxeTRfANolo' \
--header 'Content-Type: application/json' \
--data '{
"query": "Info on Conversational AI",
"metaFilters": [{
"condition": "AND",
"rules": [
{
"fieldName": "sourceType",
"fieldValue": [
"file"
],
"operator": "contains"
}
]
}]
}'
Body Parameters¶
PARAMETER | REQUIRED | DESCRIPTION |
query | Yes | Query string for search |
metaFilters | No | This parameter can be used to define rules to filter out the results from the Answer Index before using them for generating the answer. This parameter takes an array of rules with conditions. For instance, to use only web pages to answer a query, set the filters as shown below.
|
answerSearch | No | This can be set to true or false. When set to ‘true’, the response will include answers. Conversely, when set to ‘false’, the response will omit the answer to the query. However, you can still use the includeChunksInResponse field to see the qualified chunks in the response. By default, it is set to true. |
includeChunksInResponse | No | This can be set to true or false. When set to true, the response will also include a list of qualified chunks along with other parameters. The chunk information is stored in the response's chunk_result field. |
IncludeMetaDataAnswers | No | This field can fetch specific chunk metadata fields in the response along with the default fields.The requested fields are returned as part of the graph_answer field in the response. If a metadata field listed in this object does not exist, the field is returned in the response with a null value.
For instance, to fetch the author name(a metadata field) and subtitle(a custom field) additionally from the chunks, include the following in the request payload.
"IncludeMetaDataAnswers": ["chunkMeta.author", “subtitle”].Note that for metadata fields, use the field name along with the root name, such as chunkMeta.x, as shown in the above example. |
raclEntityIds | No | Array of RACL values
This field specifies the RACL (Role-Based Access Control List) values to be used to determine accessible content. It can include both user identities (e.g., email addresses) and permission entity IDs (e.g., user groups).
When raclEntityIds is passed in the API request, Search AI exclusively uses the provided values in raclEntityIds to identify accessible content. No additional mapping between user identities and permission entities is performed to resolve content accessibility. For each value in raclEntityIds, only the content where the sys_racl field contains a matching value will be accessible in the response.
For instance,
raclEntityIds: [ “123234”, // Permission Entity ID “[user@example.com](mailto:user@example.com)” // User Identity ]
|
customData | No | Custom data to be sent in the request. This data can be used to further process or filter the search results in the application. This can also be used to pass previous conversations as context or to set user context like user identity, location, etc. Refer to [the following section](#example-of-using-custom-data-request-parameter) for examples on how to use custom data. |
dynamicPromptSelection | No | Specifies the prompt and model to be used to generate the answer in this API call. If not provided, the API will use the default model and prompt configured at the application level. This field accepts the following three parameters:
Example: "dynamicPromptSelection" : { "integrationName" : "openai", "model" : "GPT-3.5 "promptName" : "testprompt" } Note:
|
Example of Using Custom Data Request parameter¶
Example 1. To pass user information
"customData": {
"userContext": {
"userName": "John",
"userId": "john.smith@example.com",
"emailId": "john.smith@example.com"
}
}
Example 2. To pass user location
Example 3. To pass the previous conversation as context to the Query Rephrasing Agent.
"customData": {
"previousConversation": [
{
"query": "What is the leave policy for America?",
"answer": "The leave policy in the U.S. varies by employer, but the Family and Medical Leave Act (FMLA) allows eligible employees to take up to 12 weeks of unpaid leave for certain family and medical reasons. Paid leave policies depend on the employer."
},
{
"query": "How do I reset my company email password?",
"answer": "You can reset your company email password by visiting the IT support portal and selecting 'Forgot Password.' Follow the instructions to reset your password. If you need further assistance, contact the IT helpdesk."
}]
}