Skip to content

Add Large Language Models to Discord. Add DeepSeek R-1, Llama 3.3, Gemini, and other models.

License

Notifications You must be signed in to change notification settings

jake83741/vnc-lm

Repository files navigation

vnc-lm

Introduction

Add Large Language Models to Discord. Add DeepSeek R-1, Llama 3.3, Gemini, and other models.

vnc-lm is a Discord bot for messaging with language models. Configure model parameters, branch conversations, and edit prompts to improve responses. It is integrated with LiteLLM and ollama.

Supported Providers
Supported Providers
OpenAI Huggingface Cloudflare Workers AI
OpenAI (Text Completion) Databricks DeepInfra
OpenAI-Compatible Endpoints IBM watsonx.ai AI21
Azure OpenAI Predibase NLP Cloud
Azure AI Studio Nvidia NIM Replicate
VertexAI XAI Together AI
Gemini - Google AI Studio LM Studio Voyage AI
Anthropic Cerebras Jina AI
AWS Sagemaker Volcano Engine Aleph Alpha
AWS Bedrock Triton Inference Server Baseten
LiteLLM Proxy (LLM Gateway) Ollama OpenRouter
Mistral AI API Perplexity AI PaLM API - Google
Codestral API FriendliAI Sambanova
Cohere Groq Custom API Server
Anyscale Github Petals
Fireworks AI Deepseek Xinference
Clarifai VLLM

Screen Recording 2024-12-10 at 11 32 16 PM

Features

Model Management

Load models using the /model command. Configure model behavior by adjusting the system_prompt (base instructions), temperature (response randomness), and num_ctx (context length) parameters.

# model loading / configuration examples

# loading a model without configuring it
/model model:gemini-exp-1206
# loading a model with system prompt and temperature
/model model:gemini-exp-1206 system_prompt: You are a helpful assistant. temperature: 0.4
# loading an ollama model with num_ctx
/model model:deepseek-r1:8b-llama-distill-fp16 num_ctx:32000

A new thread will be created once the model loads. To switch models within a thread, use + followed by any distinctive part of the model name.

# model switching examples

# switch to deepseek-r1
+ deepseek, +r1
# switch to gemini-exp-1206
+ gemini, + exp, + 1206
# switch to claude-sonnet-3.5
+ claude, + sonnet, + 3.5

Message Handling

Message Handling

Long messages are automatically split into pages. The context window supports text files, links, and images. Images can be handled either with multi-modal models or with OCR depending on how the .env is configured. The bot can be configured to require mention or to respond without a direct mention.

Edit any prompt to refine a model's response. Conversations are stored in bot_cache.json and persist across Docker container restarts with a bash script.

Reply branch to any message in a thread to create a new branch of the conversation. The new branch will include a link to the original thread and a conversation summary. Hop between branches while keeping separate conversation histories, letting you explore different paths with any model.

LiteLLM Integration

With LiteLLM integration, a wide range of language model APIs can be accessed through a single proxy interface. Any model provider available through LiteLLM is supported.

LiteLLM includes support for OpenAI-compatible APIs. This opens up support for many popular open source local LLM services.

Add models by filling out litellm_config.yaml file in the vnc-lm/ directory. The configuration supports all providers and parameters available through LiteLLM's proxy.

LiteLLM is packaged with the bot and starts automatically when the Docker container is built. While LiteLLM integration is available, the bot can function solely with ollama.

ollama Integration

Download ollama models by sending a model tag link in a channel.

# model tag link examples
https://ollama.com/library/deepseek-r1:8b-llama-distill-fp16

Local models can be removed with the remove parameter of /model.

# ollama model removal example
/model model:deepseek-r1:8b-llama-distill-fp16 remove:True

Note

Enable model downloading and removal by adding your Discord user ID to the .env.

The num_ctx parameter for /model can only be used with ollama models.

Requirements

Docker: Docker is a platform designed to help developers build, share, and run container applications. We handle the tedious setup, so you can focus on the code.

Environment Configuration

# clone the repository or download a recent release
git clone https://github.com/jake83741/vnc-lm.git

# enter the directory
cd vnc-lm

# rename the env file
mv .env.example .env

# configure the below .env fields

# Discord bot token
TOKEN=
# administrator Discord user id
ADMIN=
# require bot mention (default: false)
REQUIRE_MENTION=

# turn vision on or off. turning vision off will turn ocr on. (default: false)
USE_VISION=

# leave blank to not use ollama
OLLAMAURL=http://host.docker.internal:11434
# example provider api keys
OPENAI_API_KEY=sk-...8YIH
ANTHROPIC_API_KEY=sk-...2HZF

Generating a bot token
Inviting the bot to a server

LiteLLM configuration

# add models to the litellm_config.yaml
# it is not necessary to include ollama models here
model_list:
- model_name: gpt-3.5-turbo-instruct
  litellm_params:
    model: openai/gpt-3.5-turbo-instruct
    api_key: os.environ/OPENAI_API_KEY
- model_name: 
  litellm_params:
    model: 
    api_key: 

Additional parameters may be required

Docker Installation

# build the container with Docker
docker compose up --build --no-color

Screen Recording 2024-11-24 at 12 51 26 PM successful build

Note

Send /help for instructions on how to use the bot.

Tree Diagram

Tree Diagram
.
├── api-connections/             
│   ├── base-client.ts           # Abstract base class defining common client interface and methods
│   ├── factory.ts               # Factory class for instantiating appropriate model clients
│   └── provider/                
│       ├── litellm/            
│       │   └── client.ts        # Client implementation for LiteLLM API integration
│       └── ollama/
│           └── client.ts        # Client implementation for Ollama API integration
├── bot.ts                       # Main bot initialization and event handling setup
├── commands/                    
│   ├── base.ts                  # Base command class with shared command functionality
│   ├── handlers.ts              # Implementation of individual bot commands
│   └── registry.ts              # Command registration and slash command setup
├── managers/                    
│   ├── cache/                   
│   │   ├── entrypoint.sh        # Cache initialization script
│   │   ├── manager.ts           # Cache management implementation
│   │   └── store.ts             # Cache storage and persistence
│   └── generation/              
│       ├── core.ts              # Core message generation logic
│       ├── formatter.ts         # Message formatting and pagination
│       └── generator.ts         # Stream-based response generation
└── utilities/                   
    ├── error-handler.ts         # Global error handling
    ├── index.ts                 # Central export point for utilities
    └── settings.ts              # Global settings and configuration

Dependencies


{
  "dependencies": {
    "@mozilla/readability": "^0.5.0",  # Library for extracting readable content from web pages
    "axios": "^1.7.2",                 # HTTP client for making API requests
    "discord.js": "^14.15.3",          # Discord API wrapper for building Discord bots
    "dotenv": "^16.4.5",               # Loads environment variables from .env files
    "jsdom": "^24.1.3",                # DOM implementation for parsing HTML in Node.js
    "keyword-extractor": "^0.0.27",    # Extracts keywords from text for generating thread names
    "sharp": "^0.33.5",                # Image processing library for resizing/optimizing images  
    "tesseract.js": "^5.1.0"           # Optical Character Recognition (OCR) for extracting text from images
  },
  "devDependencies": {
    "@types/axios": "^0.14.0",
    "@types/dotenv": "^8.2.0",
    "@types/jsdom": "^21.1.7",
    "@types/node": "^18.15.25",
    "typescript": "^5.1.3"
  }
}

Troubleshooting

Context Window Issues

When sending text files to a local model, be sure to set a proportional num_ctx value with /model.

Discord API issues

Occasionally the Discord API will throw up errors in the console.

# Discord api error examples
DiscordAPIError[10062]: Unknown interaction

DiscordAPIError[40060]: Interaction has already been acknowledged

The errors usually seem to be related to clicking through pages of an embedded response. The errors are not critical and should not cause the bot to crash.

OpenAI-Compatible API Issues

When adding a model to the litellm_config.yaml from a service that uses a local API (text-generation-webui for example), use this example:

# add openai/ prefix to route as OpenAI provider
# add api base, use host.docker.interal:{port}/v1
# api key to send your model. use a placeholder when the service doesn't use api keys
model_list:
  - model_name: my-model
    litellm_params:
      model: openai/<your-model-name>
      api_base: <model-api-base>       
      api_key: api-key                 

LiteLLM Issues

If LiteLLM is exiting in the console log when doing docker compose up --build --no-color. Open the docker-compose.yaml and revise the following line and run docker compose up --build --no-color again to see more descriptive logs.

# original
command: -c "exec litellm --config /app/config.yaml >/dev/null 2>&1"
# revised
command: -c "exec litellm --config /app/config.yaml"

Most issues will be related to the litellm_config.yaml file. Double check your model_list vs the examples shown in the LiteLLM docs. Some providers require additional litellm_params.

Cache issues

Cache issues are rare and difficult to reproduce but if one does occur, deleting bot_cache.json and re-building the bot should correct it.

License

This project is licensed under the MPL-2.0 license.