From 6172ea285780b9451dd81b99b4740ad613ffab7d Mon Sep 17 00:00:00 2001
From: Fern Support <126544928+fern-support@users.noreply.github.com>
Date: Wed, 18 Dec 2024 11:27:04 -0500
Subject: [PATCH] chore: update `base_client.py`
---
src/vectara/base_client.py | 361 ++++++++++++-------------------------
1 file changed, 119 insertions(+), 242 deletions(-)
diff --git a/src/vectara/base_client.py b/src/vectara/base_client.py
index a606e87..bbe33ba 100644
--- a/src/vectara/base_client.py
+++ b/src/vectara/base_client.py
@@ -10,6 +10,7 @@
from .corpora.client import CorporaClient
from .upload.client import UploadClient
from .documents.client import DocumentsClient
+from .index.client import IndexClient
from .chats.client import ChatsClient
from .llms.client import LlmsClient
from .generation_presets.client import GenerationPresetsClient
@@ -19,12 +20,14 @@
from .users.client import UsersClient
from .api_keys.client import ApiKeysClient
from .app_clients.client import AppClientsClient
+from .query_history.client import QueryHistoryClient
from .auth.client import AuthClient
from .types.search_corpora_parameters import SearchCorporaParameters
from .types.generation_parameters import GenerationParameters
from .core.request_options import RequestOptions
from .types.query_streamed_response import QueryStreamedResponse
from .core.serialization import convert_and_respect_annotation_metadata
+import httpx_sse
from .core.pydantic_utilities import parse_obj_as
import json
from .errors.bad_request_error import BadRequestError
@@ -42,6 +45,7 @@
from .corpora.client import AsyncCorporaClient
from .upload.client import AsyncUploadClient
from .documents.client import AsyncDocumentsClient
+from .index.client import AsyncIndexClient
from .chats.client import AsyncChatsClient
from .llms.client import AsyncLlmsClient
from .generation_presets.client import AsyncGenerationPresetsClient
@@ -51,6 +55,7 @@
from .users.client import AsyncUsersClient
from .api_keys.client import AsyncApiKeysClient
from .app_clients.client import AsyncAppClientsClient
+from .query_history.client import AsyncQueryHistoryClient
from .auth.client import AsyncAuthClient
# this is used as the default value for optional parameters
@@ -151,6 +156,7 @@ def __init__(
self.corpora = CorporaClient(client_wrapper=self._client_wrapper)
self.upload = UploadClient(client_wrapper=self._client_wrapper)
self.documents = DocumentsClient(client_wrapper=self._client_wrapper)
+ self.index = IndexClient(client_wrapper=self._client_wrapper)
self.chats = ChatsClient(client_wrapper=self._client_wrapper)
self.llms = LlmsClient(client_wrapper=self._client_wrapper)
self.generation_presets = GenerationPresetsClient(client_wrapper=self._client_wrapper)
@@ -160,6 +166,7 @@ def __init__(
self.users = UsersClient(client_wrapper=self._client_wrapper)
self.api_keys = ApiKeysClient(client_wrapper=self._client_wrapper)
self.app_clients = AppClientsClient(client_wrapper=self._client_wrapper)
+ self.query_history = QueryHistoryClient(client_wrapper=self._client_wrapper)
self.auth = AuthClient(client_wrapper=self._client_wrapper)
def query_stream(
@@ -170,17 +177,19 @@ def query_stream(
request_timeout: typing.Optional[int] = None,
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> typing.Iterator[QueryStreamedResponse]:
"""
- Perform a multi-purpose query to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
+ Perform a multipurpose query across to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
- - Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
- - Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
- will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
- - Specify a RAG-specific LLM like Mockingbird (`mockingbird-1.0-2024-07-16`) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
- - Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
- - Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
+ * Specify the unique `corpus_key` identifying the corpus to query. The `corpus_key` is [created in the Vectara Console UI](https://docs.vectara.com/docs/console-ui/creating-a-corpus) or the [Create Corpus API definition](https://docs.vectara.com/docs/api-reference/admin-apis/create-corpus). When creating a new corpus, you have the option to assign a custom `corpus_key` following your preferred naming convention. This key serves as a unique identifier for the corpus, allowing it to be referenced in search requests. For more information, see [Corpus Key Definition](https://docs.vectara.com/docs/api-reference/search-apis/search#corpus-key-definition).
+ * Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
+ * Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
+ will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
+ * Specify Vectara's RAG-focused LLM (Mockingbird) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
+ * Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
+ * Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
For more detailed information, see this [Query API guide](https://docs.vectara.com/docs/api-reference/search-apis/search).
@@ -199,6 +208,9 @@ def query_stream(
generation : typing.Optional[GenerationParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the query in the query history.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -212,10 +224,8 @@ def query_stream(
from vectara import (
CitationParameters,
ContextConfiguration,
- CustomerSpecificReranker,
GenerationParameters,
KeyedSearchCorpus,
- ModelParameters,
SearchCorporaParameters,
Vectara,
)
@@ -226,53 +236,28 @@ def query_stream(
client_secret="YOUR_CLIENT_SECRET",
)
response = client.query_stream(
- request_timeout=1,
- request_timeout_millis=1,
- query="string",
+ query="hello, world?",
search=SearchCorporaParameters(
corpora=[
KeyedSearchCorpus(
- custom_dimensions={"string": 1.1},
- metadata_filter="string",
- lexical_interpolation=1.1,
- semantics="default",
+ lexical_interpolation=0.005,
)
],
- offset=1,
- limit=1,
+ offset=0,
+ limit=10,
context_configuration=ContextConfiguration(
- characters_before=1,
- characters_after=1,
- sentences_before=1,
- sentences_after=1,
- start_tag="string",
- end_tag="string",
- ),
- reranker=CustomerSpecificReranker(
- reranker_id="string",
- reranker_name="string",
+ sentences_before=2,
+ sentences_after=2,
+ start_tag="",
+ end_tag="",
),
),
generation=GenerationParameters(
- generation_preset_name="string",
- prompt_name="string",
- max_used_search_results=1,
- prompt_template="string",
- prompt_text="string",
- max_response_characters=1,
- response_language="auto",
- model_parameters=ModelParameters(
- max_tokens=1,
- temperature=1.1,
- frequency_penalty=1.1,
- presence_penalty=1.1,
- ),
+ max_used_search_results=5,
citations=CitationParameters(
style="none",
- url_pattern="string",
- text_pattern="string",
),
- enable_factual_consistency_score=True,
+ response_language="auto",
),
)
for chunk in response:
@@ -290,6 +275,7 @@ def query_stream(
"generation": convert_and_respect_annotation_metadata(
object_=generation, annotation=GenerationParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": True,
},
headers={
@@ -301,15 +287,14 @@ def query_stream(
) as _response:
try:
if 200 <= _response.status_code < 300:
- for _text in _response.iter_lines():
+ _event_source = httpx_sse.EventSource(_response)
+ for _sse in _event_source.iter_sse():
try:
- if len(_text) == 0:
- continue
yield typing.cast(
QueryStreamedResponse,
parse_obj_as(
type_=QueryStreamedResponse, # type: ignore
- object_=json.loads(_text),
+ object_=json.loads(_sse.data),
),
)
except:
@@ -359,17 +344,19 @@ def query(
request_timeout: typing.Optional[int] = None,
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> QueryFullResponse:
"""
- Perform a multi-purpose query to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
+ Perform a multipurpose query across to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
- - Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
- - Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
- will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
- - Specify a RAG-specific LLM like Mockingbird (`mockingbird-1.0-2024-07-16`) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
- - Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
- - Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
+ * Specify the unique `corpus_key` identifying the corpus to query. The `corpus_key` is [created in the Vectara Console UI](https://docs.vectara.com/docs/console-ui/creating-a-corpus) or the [Create Corpus API definition](https://docs.vectara.com/docs/api-reference/admin-apis/create-corpus). When creating a new corpus, you have the option to assign a custom `corpus_key` following your preferred naming convention. This key serves as a unique identifier for the corpus, allowing it to be referenced in search requests. For more information, see [Corpus Key Definition](https://docs.vectara.com/docs/api-reference/search-apis/search#corpus-key-definition).
+ * Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
+ * Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
+ will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
+ * Specify Vectara's RAG-focused LLM (Mockingbird) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
+ * Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
+ * Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
For more detailed information, see this [Query API guide](https://docs.vectara.com/docs/api-reference/search-apis/search).
@@ -388,6 +375,9 @@ def query(
generation : typing.Optional[GenerationParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the query in the query history.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -422,6 +412,7 @@ def query(
"generation": convert_and_respect_annotation_metadata(
object_=generation, annotation=GenerationParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": False,
},
headers={
@@ -484,6 +475,7 @@ def chat_stream(
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
chat: typing.Optional[ChatParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> typing.Iterator[ChatStreamedResponse]:
"""
@@ -506,6 +498,9 @@ def chat_stream(
chat : typing.Optional[ChatParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the chat in both the chat and query history. This overrides `chat.store`.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -516,17 +511,7 @@ def chat_stream(
Examples
--------
- from vectara import (
- ChatParameters,
- CitationParameters,
- ContextConfiguration,
- CustomerSpecificReranker,
- GenerationParameters,
- KeyedSearchCorpus,
- ModelParameters,
- SearchCorporaParameters,
- Vectara,
- )
+ from vectara import SearchCorporaParameters, Vectara
client = Vectara(
api_key="YOUR_API_KEY",
@@ -534,57 +519,8 @@ def chat_stream(
client_secret="YOUR_CLIENT_SECRET",
)
response = client.chat_stream(
- request_timeout=1,
- request_timeout_millis=1,
- query="string",
- search=SearchCorporaParameters(
- corpora=[
- KeyedSearchCorpus(
- custom_dimensions={"string": 1.1},
- metadata_filter="string",
- lexical_interpolation=1.1,
- semantics="default",
- )
- ],
- offset=1,
- limit=1,
- context_configuration=ContextConfiguration(
- characters_before=1,
- characters_after=1,
- sentences_before=1,
- sentences_after=1,
- start_tag="string",
- end_tag="string",
- ),
- reranker=CustomerSpecificReranker(
- reranker_id="string",
- reranker_name="string",
- ),
- ),
- generation=GenerationParameters(
- generation_preset_name="string",
- prompt_name="string",
- max_used_search_results=1,
- prompt_template="string",
- prompt_text="string",
- max_response_characters=1,
- response_language="auto",
- model_parameters=ModelParameters(
- max_tokens=1,
- temperature=1.1,
- frequency_penalty=1.1,
- presence_penalty=1.1,
- ),
- citations=CitationParameters(
- style="none",
- url_pattern="string",
- text_pattern="string",
- ),
- enable_factual_consistency_score=True,
- ),
- chat=ChatParameters(
- store=True,
- ),
+ query="How can I use the Vectara platform?",
+ search=SearchCorporaParameters(),
)
for chunk in response:
yield chunk
@@ -604,6 +540,7 @@ def chat_stream(
"chat": convert_and_respect_annotation_metadata(
object_=chat, annotation=ChatParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": True,
},
headers={
@@ -615,15 +552,14 @@ def chat_stream(
) as _response:
try:
if 200 <= _response.status_code < 300:
- for _text in _response.iter_lines():
+ _event_source = httpx_sse.EventSource(_response)
+ for _sse in _event_source.iter_sse():
try:
- if len(_text) == 0:
- continue
yield typing.cast(
ChatStreamedResponse,
parse_obj_as(
type_=ChatStreamedResponse, # type: ignore
- object_=json.loads(_text),
+ object_=json.loads(_sse.data),
),
)
except:
@@ -674,6 +610,7 @@ def chat(
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
chat: typing.Optional[ChatParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> ChatFullResponse:
"""
@@ -696,6 +633,9 @@ def chat(
chat : typing.Optional[ChatParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the chat in both the chat and query history. This overrides `chat.store`.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -733,6 +673,7 @@ def chat(
"chat": convert_and_respect_annotation_metadata(
object_=chat, annotation=ChatParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": False,
},
headers={
@@ -881,6 +822,7 @@ def __init__(
self.corpora = AsyncCorporaClient(client_wrapper=self._client_wrapper)
self.upload = AsyncUploadClient(client_wrapper=self._client_wrapper)
self.documents = AsyncDocumentsClient(client_wrapper=self._client_wrapper)
+ self.index = AsyncIndexClient(client_wrapper=self._client_wrapper)
self.chats = AsyncChatsClient(client_wrapper=self._client_wrapper)
self.llms = AsyncLlmsClient(client_wrapper=self._client_wrapper)
self.generation_presets = AsyncGenerationPresetsClient(client_wrapper=self._client_wrapper)
@@ -890,6 +832,7 @@ def __init__(
self.users = AsyncUsersClient(client_wrapper=self._client_wrapper)
self.api_keys = AsyncApiKeysClient(client_wrapper=self._client_wrapper)
self.app_clients = AsyncAppClientsClient(client_wrapper=self._client_wrapper)
+ self.query_history = AsyncQueryHistoryClient(client_wrapper=self._client_wrapper)
self.auth = AsyncAuthClient(client_wrapper=self._client_wrapper)
async def query_stream(
@@ -900,17 +843,19 @@ async def query_stream(
request_timeout: typing.Optional[int] = None,
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> typing.AsyncIterator[QueryStreamedResponse]:
"""
- Perform a multi-purpose query to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
+ Perform a multipurpose query across to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
- - Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
- - Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
- will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
- - Specify a RAG-specific LLM like Mockingbird (`mockingbird-1.0-2024-07-16`) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
- - Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
- - Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
+ * Specify the unique `corpus_key` identifying the corpus to query. The `corpus_key` is [created in the Vectara Console UI](https://docs.vectara.com/docs/console-ui/creating-a-corpus) or the [Create Corpus API definition](https://docs.vectara.com/docs/api-reference/admin-apis/create-corpus). When creating a new corpus, you have the option to assign a custom `corpus_key` following your preferred naming convention. This key serves as a unique identifier for the corpus, allowing it to be referenced in search requests. For more information, see [Corpus Key Definition](https://docs.vectara.com/docs/api-reference/search-apis/search#corpus-key-definition).
+ * Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
+ * Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
+ will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
+ * Specify Vectara's RAG-focused LLM (Mockingbird) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
+ * Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
+ * Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
For more detailed information, see this [Query API guide](https://docs.vectara.com/docs/api-reference/search-apis/search).
@@ -929,6 +874,9 @@ async def query_stream(
generation : typing.Optional[GenerationParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the query in the query history.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -945,10 +893,8 @@ async def query_stream(
AsyncVectara,
CitationParameters,
ContextConfiguration,
- CustomerSpecificReranker,
GenerationParameters,
KeyedSearchCorpus,
- ModelParameters,
SearchCorporaParameters,
)
@@ -961,53 +907,28 @@ async def query_stream(
async def main() -> None:
response = await client.query_stream(
- request_timeout=1,
- request_timeout_millis=1,
- query="string",
+ query="hello, world?",
search=SearchCorporaParameters(
corpora=[
KeyedSearchCorpus(
- custom_dimensions={"string": 1.1},
- metadata_filter="string",
- lexical_interpolation=1.1,
- semantics="default",
+ lexical_interpolation=0.005,
)
],
- offset=1,
- limit=1,
+ offset=0,
+ limit=10,
context_configuration=ContextConfiguration(
- characters_before=1,
- characters_after=1,
- sentences_before=1,
- sentences_after=1,
- start_tag="string",
- end_tag="string",
- ),
- reranker=CustomerSpecificReranker(
- reranker_id="string",
- reranker_name="string",
+ sentences_before=2,
+ sentences_after=2,
+ start_tag="",
+ end_tag="",
),
),
generation=GenerationParameters(
- generation_preset_name="string",
- prompt_name="string",
- max_used_search_results=1,
- prompt_template="string",
- prompt_text="string",
- max_response_characters=1,
- response_language="auto",
- model_parameters=ModelParameters(
- max_tokens=1,
- temperature=1.1,
- frequency_penalty=1.1,
- presence_penalty=1.1,
- ),
+ max_used_search_results=5,
citations=CitationParameters(
style="none",
- url_pattern="string",
- text_pattern="string",
),
- enable_factual_consistency_score=True,
+ response_language="auto",
),
)
async for chunk in response:
@@ -1028,6 +949,7 @@ async def main() -> None:
"generation": convert_and_respect_annotation_metadata(
object_=generation, annotation=GenerationParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": True,
},
headers={
@@ -1039,15 +961,14 @@ async def main() -> None:
) as _response:
try:
if 200 <= _response.status_code < 300:
- async for _text in _response.aiter_lines():
+ _event_source = httpx_sse.EventSource(_response)
+ async for _sse in _event_source.aiter_sse():
try:
- if len(_text) == 0:
- continue
yield typing.cast(
QueryStreamedResponse,
parse_obj_as(
type_=QueryStreamedResponse, # type: ignore
- object_=json.loads(_text),
+ object_=json.loads(_sse.data),
),
)
except:
@@ -1097,17 +1018,19 @@ async def query(
request_timeout: typing.Optional[int] = None,
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> QueryFullResponse:
"""
- Perform a multi-purpose query to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
+ Perform a multipurpose query across to retrieve relevant information from one or more corpora and generate a response using Retrieval Augmented Generation (RAG).
- - Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
- - Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
- will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
- - Specify a RAG-specific LLM like Mockingbird (`mockingbird-1.0-2024-07-16`) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
- - Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
- - Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
+ * Specify the unique `corpus_key` identifying the corpus to query. The `corpus_key` is [created in the Vectara Console UI](https://docs.vectara.com/docs/console-ui/creating-a-corpus) or the [Create Corpus API definition](https://docs.vectara.com/docs/api-reference/admin-apis/create-corpus). When creating a new corpus, you have the option to assign a custom `corpus_key` following your preferred naming convention. This key serves as a unique identifier for the corpus, allowing it to be referenced in search requests. For more information, see [Corpus Key Definition](https://docs.vectara.com/docs/api-reference/search-apis/search#corpus-key-definition).
+ * Customize your search by specifying the query text (`query`), pagination details (`offset` and `limit`), and metadata filters (`metadata_filter`) to tailor your search results. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#query-definition)
+ * Leverage advanced search capabilities like reranking (`reranker`) and opt-in Retrieval Augmented Generation (RAG) (`generation`) for enhanced query performance. Generation is opt in by setting the `generation` property. By excluding the property or by setting it to null, the response
+ will not include generation. [Learn more](https://docs.vectara.com/docs/learn/grounded-generation/configure-query-summarization)
+ * Specify Vectara's RAG-focused LLM (Mockingbird) for the `generation_preset_name`. [Learn more](https://docs.vectara.com/docs/learn/mockingbird-llm)
+ * Use advanced summarization options that utilize detailed summarization parameters such as `max_response_characters`, `temperature`, and `frequency_penalty` for generating precise and relevant summaries. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#advanced-summarization-customization-options)
+ * Customize citation formats in summaries using the `citations` object to include numeric, HTML, or Markdown links. [Learn more](https://docs.vectara.com/docs/api-reference/search-apis/search#citation-format-in-summary)
For more detailed information, see this [Query API guide](https://docs.vectara.com/docs/api-reference/search-apis/search).
@@ -1126,6 +1049,9 @@ async def query(
generation : typing.Optional[GenerationParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the query in the query history.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -1168,6 +1094,7 @@ async def main() -> None:
"generation": convert_and_respect_annotation_metadata(
object_=generation, annotation=GenerationParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": False,
},
headers={
@@ -1230,6 +1157,7 @@ async def chat_stream(
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
chat: typing.Optional[ChatParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> typing.AsyncIterator[ChatStreamedResponse]:
"""
@@ -1252,6 +1180,9 @@ async def chat_stream(
chat : typing.Optional[ChatParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the chat in both the chat and query history. This overrides `chat.store`.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -1264,17 +1195,7 @@ async def chat_stream(
--------
import asyncio
- from vectara import (
- AsyncVectara,
- ChatParameters,
- CitationParameters,
- ContextConfiguration,
- CustomerSpecificReranker,
- GenerationParameters,
- KeyedSearchCorpus,
- ModelParameters,
- SearchCorporaParameters,
- )
+ from vectara import AsyncVectara, SearchCorporaParameters
client = AsyncVectara(
api_key="YOUR_API_KEY",
@@ -1285,57 +1206,8 @@ async def chat_stream(
async def main() -> None:
response = await client.chat_stream(
- request_timeout=1,
- request_timeout_millis=1,
- query="string",
- search=SearchCorporaParameters(
- corpora=[
- KeyedSearchCorpus(
- custom_dimensions={"string": 1.1},
- metadata_filter="string",
- lexical_interpolation=1.1,
- semantics="default",
- )
- ],
- offset=1,
- limit=1,
- context_configuration=ContextConfiguration(
- characters_before=1,
- characters_after=1,
- sentences_before=1,
- sentences_after=1,
- start_tag="string",
- end_tag="string",
- ),
- reranker=CustomerSpecificReranker(
- reranker_id="string",
- reranker_name="string",
- ),
- ),
- generation=GenerationParameters(
- generation_preset_name="string",
- prompt_name="string",
- max_used_search_results=1,
- prompt_template="string",
- prompt_text="string",
- max_response_characters=1,
- response_language="auto",
- model_parameters=ModelParameters(
- max_tokens=1,
- temperature=1.1,
- frequency_penalty=1.1,
- presence_penalty=1.1,
- ),
- citations=CitationParameters(
- style="none",
- url_pattern="string",
- text_pattern="string",
- ),
- enable_factual_consistency_score=True,
- ),
- chat=ChatParameters(
- store=True,
- ),
+ query="How can I use the Vectara platform?",
+ search=SearchCorporaParameters(),
)
async for chunk in response:
yield chunk
@@ -1358,6 +1230,7 @@ async def main() -> None:
"chat": convert_and_respect_annotation_metadata(
object_=chat, annotation=ChatParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": True,
},
headers={
@@ -1369,15 +1242,14 @@ async def main() -> None:
) as _response:
try:
if 200 <= _response.status_code < 300:
- async for _text in _response.aiter_lines():
+ _event_source = httpx_sse.EventSource(_response)
+ async for _sse in _event_source.aiter_sse():
try:
- if len(_text) == 0:
- continue
yield typing.cast(
ChatStreamedResponse,
parse_obj_as(
type_=ChatStreamedResponse, # type: ignore
- object_=json.loads(_text),
+ object_=json.loads(_sse.data),
),
)
except:
@@ -1428,6 +1300,7 @@ async def chat(
request_timeout_millis: typing.Optional[int] = None,
generation: typing.Optional[GenerationParameters] = OMIT,
chat: typing.Optional[ChatParameters] = OMIT,
+ save_history: typing.Optional[bool] = OMIT,
request_options: typing.Optional[RequestOptions] = None,
) -> ChatFullResponse:
"""
@@ -1450,6 +1323,9 @@ async def chat(
chat : typing.Optional[ChatParameters]
+ save_history : typing.Optional[bool]
+ Indicates whether to save the chat in both the chat and query history. This overrides `chat.store`.
+
request_options : typing.Optional[RequestOptions]
Request-specific configuration.
@@ -1495,6 +1371,7 @@ async def main() -> None:
"chat": convert_and_respect_annotation_metadata(
object_=chat, annotation=ChatParameters, direction="write"
),
+ "save_history": save_history,
"stream_response": False,
},
headers={