LLAMARA - Large Language Assistant for Model-Augmented Retrieval and Analysis - is an LLM-based assistant for information retrieval from a provided knowledge base. It aims at supporting researchers working with scientific papers, whitepapers and documentation, as well as possibly serving research findings in an accessible way to the public.
NOTE: This repository contains the LLAMARA backend only.
- Retrieval-Augmented-Generation (RAG) chat functionality with provided knowledge
- Support uploading the following file types as knowledge source:
- Microsoft Word DOCX
- Markdown
- TXT
- and everything else supported by Apache Tika
- Provide reference to the source of knowledge in the generated response with the ability to download the file-based source
- Configurable prompt template for RAG
- Interchangeable LLM (chat model) for each request
- Extensive management of knowledge (including the ability to set label and tags)
- Multi-User support with Single-Sign-On (SSO) support through external OIDC providers (we recommend Keycloak):
- Admins can manage all knowledge added to LLAMARA.
- Users can add individual knowledge and share it with other users of LLAMARA through fine-grained permissions.
- Anonymous access can be enabled to allow anyone to make us of the publicly shared knowledge.
- Multiple sessions per user with server-side chat history
- Serve a JavaScript Single-Page-Application (SPA) as frontend
- Integration with the following LLM (chat model) providers:
- Configure common model parameters such as temperature, top-p, frequency penalty & presence penalty for each model
- Integration with the following embedding model providers:
- Integration with the following embedding stores:
- Build with Quarkus, the Supersonic Subatomic Java Framework
- Uses LangChain4j, the versatile LLM integration library
- Relies on battle-tested open-source software such as PostgreSQL, MinIO & Redis
LLAMARA comes with a default configuration that can be overridden by providing an application.yaml
file in the config directory.
Refer to config/README.md for more information.
The easiest way to run LLAMARA is to use the provided Docker container with Docker Compose.
Please refer to llamara-deployment-docker for more information.
For development, you only need to set up the AI Model Provider dependency, as the other dependencies are provided by Quarkus Dev Services. See DEVELOPMENT.md for more information.
This application requires an OIDC authentication provider to be set up.
The OIDC provider requires the auth-server-url
and client-id
to be set in the application.yaml
file and the QUARKUS_OIDC_CREDENTIALS_SECRET
environment variables.
For Keycloak, you need to add the microprofile-jwt
and profile
scopes for the Quarkus client, see Keycloak Server Documentation.
With the default configuration, LLAMARA relies on GPT-4o mini and text-embeddding-3-large
from OpenAI.
You therefore need to provide an OpenAI API key through the OPENAI_API_KEY
environment variable, e.g. through an .env
file.
The application requires a PostgreSQL database on localhost:5432
(default).
If needed, specify a password through the QUARKUS_DATASOURCE_PASSWORD
environment variable.
The application requires its tables to be available in the configured JDBC database.
The application requires a MinIO object storage on localhost:9000
(default).
You need to set up access and secret key through the MinIO web interface and provide them through the QUARKUS_MINIO_ACCESS_KEY
and QUARKUS_MINIO_SECRET_KEY
environment variables.
This application requires a Redis server on localhost:6379
(default).
It uses database 1 (default) for chat memory and database 2 (default) for chat history.
If needed, specify passwords through the QUARKUS_REDIS_CHAT_MEMORY_PASSWORD
and QUARKUS_REDIS_CHAT_HISTORY_PASSWORD
environment variables.
This application requires a Qdrant Vector Database on localhost:6334
(gRPC) (default).
If needed, specify an API key through the QDRANT_API_KEY
environment variable.
LLAMARA will create the required collection according to the configured collection name and vector size,
and enable payload index for the knowledge_id
payload key.
How to do that manually
Before using Qdrant, you need to create the required collection:
- Visit http://localhost:6333/dashboard#/tutorial/quickstart
- Create a collection
${COLLECTION_NAME}
with the vector size matching the used embedding model - Enable payload index for the
knowledge_id
payload key by executing the following in http://localhost:6333/dashboard#/console:PUT /collections/${COLLECTION_NAME}/index { "field_name": "knowledge_id", "field_schema": "uuid" }
${COLLECTION_NAME}
is the configured collection name.
Common embedding models and their vector size and recommended distance calculation are:
Provider | Embedding Model | Vector Size | Distance Calculation | Refs |
---|---|---|---|---|
OpenAI | text-embedding-3-small |
1536 | Dot Product | Docs |
OpenAI | text-embedding-3-large |
3072 | Dot Product | Docs |
Ollama | nomic-embed-text |
768 | Dot Product | Ollama |
LLAMARA backend provides a REST API on the /rest
path to be consumed by a user interface.
You can explore it through Swagger UI on the /q/swagger-ui
endpoint,
or use the OpenAPI YAML or JSON API scheme definitions available from CI artifacts.
The /q/info
endpoint provides information about LLAMARA backend, including Git, Java, OS and build details.
LLAMARA backend exposes four REST endpoints according to the Eclipse Microprofile specification:
/q/health/live
: The application is up and running./q/health/ready
: The application is ready to serve requests./q/health/started
: The application is started./q/health
: Accumulating all health check procedures in the application.
LLAMARA backend is able to serve a JavaScript Single-Page-Application, such as a React, Vue or Angular application, as its frontend.
To do so, you need to place the build output of your bundler, e.g. Webpack or Vite, into the META-INF/resources
folder during build-time of LLAMARA backend.
The bundled JavaScript SPA will then be part of the build JAR and automatically served by Quarkus on the applications root path.
LLAMARA backend redirects all 404 requests outside of its own endpoints to the index page to allow the SPA's router to take over.
LLAMARA Distribution provides a build of LLAMARA backend that includes LLAMARA frontend, making it the easiest way to deploy LLAMARA.
- Filtering embeddings by permissions in the retrieval step only works if knowledge has only a single permission set. The contains filter from langchain4j/langchain4j#2344 is needed to properly implement permissions in the retrieval step.
- Native image does not work with Qdrant embedding store, see quarkiverse/quarkus-langchain4j#1216.