Class VertexAiRagRetrieval


public class VertexAiRagRetrieval extends BaseRetrievalTool
A retrieval tool that fetches context from Vertex AI RAG.

This tool allows to retrieve relevant information based on a query using Vertex AI RAG service. It supports configuration of rag resources and a vector distance threshold.

  • Constructor Details

    • VertexAiRagRetrieval

      public VertexAiRagRetrieval(@Nonnull String name, @Nonnull String description, @Nonnull com.google.cloud.aiplatform.v1.VertexRagServiceClient vertexRagServiceClient, @Nonnull String parent, @Nullable List<com.google.cloud.aiplatform.v1.RetrieveContextsRequest.VertexRagStore.RagResource> ragResources, @Nullable Double vectorDistanceThreshold)
  • Method Details

    • processLlmRequest

      @CanIgnoreReturnValue public io.reactivex.rxjava3.core.Completable processLlmRequest(LlmRequest.Builder llmRequestBuilder, ToolContext toolContext)
      Description copied from class: BaseTool
      Processes the outgoing LlmRequest.Builder.

      This implementation adds the current tool's BaseTool.declaration() to the GenerateContentConfig within the builder. If a tool with function declarations already exists, the current tool's declaration is merged into it. Otherwise, a new tool definition with the current tool's declaration is created. The current tool itself is also added to the builder's internal list of tools. Override this method for processing the outgoing request.

      Overrides:
      processLlmRequest in class BaseTool
    • runAsync

      public io.reactivex.rxjava3.core.Single<Map<String,Object>> runAsync(Map<String,Object> args, ToolContext toolContext)
      Description copied from class: BaseTool
      Calls a tool.
      Overrides:
      runAsync in class BaseTool