You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
langchain/libs/community/langchain_community/utilities/rememberizer.py

51 lines
1.6 KiB
Python

"""Wrapper for Rememberizer APIs."""
from typing import Dict, List, Optional, cast
import requests
from langchain_core.documents import Document
from langchain_core.pydantic_v1 import BaseModel, root_validator
from langchain_core.utils import get_from_dict_or_env
class RememberizerAPIWrapper(BaseModel):
"""Wrapper for Rememberizer APIs."""
top_k_results: int = 10
rememberizer_api_key: Optional[str] = None
@root_validator()
def validate_environment(cls, values: Dict) -> Dict:
"""Validate that api key in environment."""
rememberizer_api_key = get_from_dict_or_env(
values, "rememberizer_api_key", "REMEMBERIZER_API_KEY"
)
values["rememberizer_api_key"] = rememberizer_api_key
return values
def search(self, query: str) -> dict:
"""Search for a query in the Rememberizer API."""
url = f"https://api.rememberizer.ai/api/v1/documents/search?q={query}&n={self.top_k_results}"
response = requests.get(
url, headers={"x-api-key": cast(str, self.rememberizer_api_key)}
)
data = response.json()
if response.status_code != 200:
raise ValueError(f"API Error: {data}")
matched_chunks = data.get("matched_chunks", [])
return matched_chunks
def load(self, query: str) -> List[Document]:
matched_chunks = self.search(query)
docs = []
for matched_chunk in matched_chunks:
docs.append(
Document(
page_content=matched_chunk["matched_content"],
metadata=matched_chunk["document"],
)
)
return docs