UNPKG

@langchain/community

Version:
109 lines (108 loc) 3.41 kB
import { __exportAll } from "../_virtual/_rolldown/runtime.js"; import { Document } from "@langchain/core/documents"; import { ZepClient } from "@getzep/zep-cloud"; import { NotFoundError } from "@getzep/zep-cloud/api/index.js"; import { BaseRetriever } from "@langchain/core/retrievers"; //#region src/retrievers/zep_cloud.ts var zep_cloud_exports = /* @__PURE__ */ __exportAll({ ZepCloudRetriever: () => ZepCloudRetriever }); /** * Class for retrieving information from a Zep Cloud long-term memory store. * Extends the BaseRetriever class. * @example * ```typescript * const retriever = new ZepCloudRetriever({ * apiKey: "<zep cloud project api key>", * sessionId: "session_exampleUUID", * topK: 3, * }); * const query = "Can I drive red cars in France?"; * const docs = await retriever.getRelevantDocuments(query); * ``` */ var ZepCloudRetriever = class extends BaseRetriever { static lc_name() { return "ZepRetriever"; } lc_namespace = [ "langchain", "retrievers", "zep" ]; get lc_secrets() { return { apiKey: "ZEP_API_KEY" }; } get lc_aliases() { return { apiKey: "api_key" }; } client; sessionId; topK; searchScope; searchType; mmrLambda; filter; constructor(config) { super(config); this.sessionId = config.sessionId; this.topK = config.topK; this.searchScope = config.searchScope; this.searchType = config.searchType; this.mmrLambda = config.mmrLambda; this.filter = config.filter; this.client = new ZepClient({ apiKey: config.apiKey }); } /** * Converts an array of message search results to an array of Document objects. * @param {MemorySearchResult[]} results - The array of search results. * @returns {Document[]} An array of Document objects representing the search results. */ searchMessageResultToDoc(results) { return results.filter((r) => r.message).map(({ message: { content, metadata: messageMetadata } = {}, score, ...rest }) => new Document({ pageContent: content ?? "", metadata: { score, ...messageMetadata, ...rest } })); } /** * Converts an array of summary search results to an array of Document objects. * @param {MemorySearchResult[]} results - The array of search results. * @returns {Document[]} An array of Document objects representing the search results. */ searchSummaryResultToDoc(results) { return results.filter((r) => r.summary).map(({ summary: { content, metadata: summaryMetadata } = {}, score, ...rest }) => new Document({ pageContent: content ?? "", metadata: { score, ...summaryMetadata, ...rest } })); } /** * Retrieves the relevant documents based on the given query. * @param {string} query - The query string. * @returns {Promise<Document[]>} A promise that resolves to an array of relevant Document objects. */ async _getRelevantDocuments(query) { try { const results = await this.client.memory.search(this.sessionId, { text: query, metadata: this.filter, searchScope: this.searchScope, searchType: this.searchType, mmrLambda: this.mmrLambda, limit: this.topK }); return this.searchScope === "summary" ? this.searchSummaryResultToDoc(results) : this.searchMessageResultToDoc(results); } catch (error) { if (error instanceof NotFoundError) return Promise.resolve([]); throw error; } } }; //#endregion export { ZepCloudRetriever, zep_cloud_exports }; //# sourceMappingURL=zep_cloud.js.map