Open-source multi-user ChatGPT for all LLMs, embedders, and vector databases. Unlimited documents, messages, and users in one privacy-focused app.
Go to file
2024-03-27 12:20:53 -07:00
.devcontainer devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
.github no build on embed changes 2024-02-02 15:29:38 -08:00
.vscode Update Ubuntu base image and improve Dockerfile (#609) 2024-03-06 16:34:45 -08:00
cloud-deployments Fix Docker container exit issue by changing ownership (#714) 2024-02-13 09:24:20 -08:00
collector [FIX] Update metadata tags in PDF collector script (#925) 2024-03-19 18:14:34 -07:00
docker update docs 2024-03-25 17:44:16 -07:00
embed auto highlight slash command on typing (#743) 2024-02-19 10:32:53 -08:00
frontend handle expired token being null and prevent constant rerender (#956) 2024-03-26 16:47:25 -07:00
images replace stored GIF with Github CDN hosted image 2024-01-04 10:59:24 -08:00
server sec: fix enable-multi-user preflight check to prevent error loop 2024-03-27 12:20:53 -07:00
.dockerignore devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
.editorconfig devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
.gitattributes dockerfile cleanup; enforce text LF line endings (#81) 2023-06-17 20:18:01 -07:00
.gitignore devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
.hadolint.yaml Update Ubuntu base image and improve Dockerfile (#609) 2024-03-06 16:34:45 -08:00
.nvmrc add .nvmrc in root 2023-06-08 10:35:36 -07:00
.prettierignore devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
.prettierrc devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
BARE_METAL.md update BARE_METAL setup 2024-01-24 14:27:52 -08:00
eslint.config.js devcontainer v1 (#297) 2024-01-08 15:31:06 -08:00
LICENSE inital commit 2023-06-03 19:28:07 -07:00
package.json [FEAT] Embedded AnythingLLM (#656) 2024-02-05 14:21:34 -08:00
pull_request_template.md Setup issue and PR templates (#559) 2024-01-09 14:25:53 -08:00
README.md 788 ollama embedder (#814) 2024-02-26 16:12:20 -08:00
SECURITY.md Create SECURITY.md 2023-09-08 16:31:30 -07:00

AnythingLLM logo

AnythingLLM: A private ChatGPT to chat with anything!.
An efficient, customizable, and open-source enterprise-ready document chatbot solution.

Discord | License | Docs | Hosted Instance

👉 AnythingLLM for desktop is in public beta! Download Now

A full-stack application that enables you to turn any document, resource, or piece of content into context that any LLM can use as references during chatting. This application allows you to pick and choose which LLM or Vector Database you want to use as well as supporting multi-user management and permissions.

Chatting

Watch the demo!

Watch the video

Product Overview

AnythingLLM is a full-stack application where you can use commercial off-the-shelf LLMs or popular open source LLMs and vectorDB solutions to build a private ChatGPT with no compromises that you can run locally as well as host remotely and be able to chat intelligently with any documents you provide it.

AnythingLLM divides your documents into objects called workspaces. A Workspace functions a lot like a thread, but with the addition of containerization of your documents. Workspaces can share documents, but they do not talk to each other so you can keep your context for each workspace clean.

Some cool features of AnythingLLM

  • Multi-user instance support and permissioning
  • New Custom Embeddable Chat widget for your website
  • Multiple document type support (PDF, TXT, DOCX, etc)
  • Manage documents in your vector database from a simple UI
  • Two chat modes conversation and query. Conversation retains previous questions and amendments. Query is simple QA against your documents
  • In-chat citations
  • 100% Cloud deployment ready.
  • "Bring your own LLM" model.
  • Extremely efficient cost-saving measures for managing very large documents. You'll never pay to embed a massive document or transcript more than once. 90% more cost effective than other document chatbot solutions.
  • Full Developer API for custom integrations!

Supported LLMs, Embedders, and Vector Databases

Supported LLMs:

Supported Embedding models:

Supported Vector Databases:

Technical Overview

This monorepo consists of three main sections:

  • frontend: A viteJS + React frontend that you can run to easily create and manage all your content the LLM can use.
  • server: A NodeJS express server to handle all the interactions and do all the vectorDB management and LLM interactions.
  • docker: Docker instructions and build process + information for building from source.
  • collector: NodeJS express server that process and parses documents from the UI.

🛳 Self Hosting

Mintplex Labs & the community maintain a number of deployment methods, scripts, and templates that you can use to run AnythingLLM locally. Refer to the table below to read how to deploy on your preferred environment or to automatically deploy.

Docker AWS GCP Digital Ocean Render.com
Deploy on Docker Deploy on AWS Deploy on GCP Deploy on DigitalOcean Deploy on Render.com
Railway
Deploy on Railway

or set up a production AnythingLLM instance without Docker →

How to setup for development

  • yarn setup To fill in the required .env files you'll need in each of the application sections (from root of repo).
    • Go fill those out before proceeding. Ensure server/.env.development is filled or else things won't work right.
  • yarn dev:server To boot the server locally (from root of repo).
  • yarn dev:frontend To boot the frontend locally (from root of repo).
  • yarn dev:collector To then run the document collector (from root of repo).

Learn about documents

Learn about vector caching

Contributing

  • create issue
  • create PR with branch name format of <issue number>-<short name>
  • yee haw let's merge
Telemetry for AnythingLLM

Telemetry

AnythingLLM by Mintplex Labs Inc contains a telemetry feature that collects anonymous usage information.

Why?

We use this information to help us understand how AnythingLLM is used, to help us prioritize work on new features and bug fixes, and to help us improve AnythingLLM's performance and stability.

Opting out

Set DISABLE_TELEMETRY in your server or docker .env settings to "true" to opt out of telemetry.

DISABLE_TELEMETRY="true"

What do you explicitly track?

We will only track usage details that help us make product and roadmap decisions, specifically:

  • Version of your installation
  • When a document is added or removed. No information about the document. Just that the event occurred. This gives us an idea of use.
  • Type of vector database in use. Let's us know which vector database provider is the most used to prioritize changes when updates arrive for that provider.
  • Type of LLM in use. Let's us know the most popular choice and prioritize changes when updates arrive for that provider.
  • Chat is sent. This is the most regular "event" and gives us an idea of the daily-activity of this project across all installations. Again, only the event is sent - we have no information on the nature or content of the chat itself.

You can verify these claims by finding all locations Telemetry.sendTelemetry is called. Additionally these events are written to the output log so you can also see the specific data which was sent - if enabled. No IP or other identifying information is collected. The Telemetry provider is PostHog - an open-source telemetry collection service.

🔗 More Products

  • VectorAdmin: An all-in-one GUI & tool-suite for managing vector databases.
  • OpenAI Assistant Swarm: Turn your entire library of OpenAI assistants into one single army commanded from a single agent.


Copyright © 2023 Mintplex Labs.
This project is MIT licensed.