MCP server for managing Open WebUI - users, groups, models, knowledge bases, and more
Project description
Open WebUI MCP Server
An MCP (Model Context Protocol) server that exposes Open WebUI's admin APIs as tools, allowing AI assistants to manage users, groups, models, knowledge bases, and more.
Features
- User Management: List, get, update roles, delete users
- Group Management: Create, update, add/remove members, delete groups
- Model Management: Create custom models, update system prompts, manage parameters
- Knowledge Base Management: Create, list, delete knowledge bases
- Chat Management: List, view, delete chats
- Tool & Function Discovery: List available tools and functions
- Permission-Aware: All operations respect the logged-in user's permissions
Security
Important: This server passes through the user's authentication token to Open WebUI. This means:
- Admin operations require admin API keys
- Regular users can only access their own resources
- All permission checks are enforced by Open WebUI's API
Installation
Package not yet publicly published to pypi.org Use a local development version (see Development)
pip install openwebui-mcp-server
Or with uv:
uv pip install openwebui-mcp-server
Configuration
Set the required environment variable:
export WEBUI_URL=https://your-openwebui-instance.com
Optionally, set a default API key (can be overridden per-request):
export WEBUI_API_KEY=your-api-key
Usage
With Claude Desktop
Add to your Claude Desktop config (~/.config/claude/claude_desktop_config.json):
{
"mcpServers": {
"openwebui": {
"command": "openwebui-mcp",
"env": {
"WEBUI_URL": "https://your-openwebui-instance.com",
"WEBUI_API_KEY": "your-api-key"
}
}
}
}
With Open WebUI (via MCPO)
- Start the server in HTTP mode:
export WEBUI_URL=https://your-openwebui-instance.com
export MCP_TRANSPORT=http
export MCP_HTTP_PORT=8001
openwebui-mcp
- Add as MCP server in Open WebUI:
- Go to Admin Settings → External Tools
- Add new MCP server with URL:
http://localhost:8001/mcp
Programmatic Usage
from openwebui_mcp.client import OpenWebUIClient
client = OpenWebUIClient(
base_url="https://your-openwebui-instance.com",
api_key="your-api-key"
)
# List all users (admin only)
users = await client.list_users()
# Create a group
group = await client.create_group("Engineering", "Engineering team")
# Create a custom model
model = await client.create_model(
id="my-assistant",
name="My Assistant",
base_model_id="gpt-4",
meta={"system": "You are a helpful assistant."},
params={"temperature": 0.7}
)
Available Tools
User Management
| Tool | Description | Permission |
|---|---|---|
get_current_user |
Get authenticated user's profile | Any |
list_users |
List all users | Admin |
get_user |
Get specific user details | Admin |
update_user_role |
Change user role | Admin |
delete_user |
Delete a user | Admin |
Group Management
| Tool | Description | Permission |
|---|---|---|
list_groups |
List all groups | Any |
create_group |
Create a new group | Admin |
get_group |
Get group details | Any |
update_group |
Update group name/description | Admin |
add_user_to_group |
Add user to group | Admin |
remove_user_from_group |
Remove user from group | Admin |
delete_group |
Delete a group | Admin |
Model Management
| Tool | Description | Permission |
|---|---|---|
list_models |
List all models | Any |
get_model |
Get model configuration | Any |
create_model |
Create custom model | Admin |
update_model |
Update model settings | Admin |
delete_model |
Delete a model | Admin |
Knowledge Base Management
| Tool | Description | Permission |
|---|---|---|
list_knowledge_bases |
List knowledge bases | Any |
get_knowledge_base |
Get knowledge base details | Any |
create_knowledge_base |
Create knowledge base | Any |
delete_knowledge_base |
Delete knowledge base | Owner |
Chat Management
| Tool | Description | Permission |
|---|---|---|
list_chats |
List user's chats | Own |
get_chat |
Get chat messages | Own |
delete_chat |
Delete a chat | Own |
delete_all_chats |
Delete all chats | Own |
System
| Tool | Description | Permission |
|---|---|---|
list_tools |
List available tools | Any |
list_functions |
List functions/filters | Any |
get_system_config |
Get system config | Admin |
Development
# Clone the repo
git clone https://github.com/troylar/open-webui-mcp-server.git
cd open-webui-mcp-server
# Install dev dependencies and the package itself
pip install -e ".[dev]"
or using uv:
# Install dependencies (with optional dev dependencies)
uv lock && uv sync --extra="dev"
# Install the project as a package in editable mode (using optional dev dependencies)
uv pip install -e ".[dev]"
# Check your new executable
which openwebui-mcp
open-webui-mcp-server/.venv/bin/openwebui-mcp
Linter
# Run linter
ruff --config pyproject.toml check src/
# Fix linting issues
ruff --config pyproject.toml check --fix src/
Tests
# Run tests
pytest tests;
# or via `uv`
uv run pytest tests/ -v;
License
MIT License - see LICENSE for details.
Contributing
Contributions welcome! Please open an issue or PR on GitHub.
Consider for adoption
Related Projects
- Open WebUI - The web UI this server manages
- FastMCP - The MCP framework used
- MCPO - MCP to OpenAPI proxy
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file openwebui_mcp_server-0.2.0.tar.gz.
File metadata
- Download URL: openwebui_mcp_server-0.2.0.tar.gz
- Upload date:
- Size: 165.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc0ec0a2657bce4b749030c56e2a61ef80d53eaf4aa2286b129875e2f4894303
|
|
| MD5 |
64167cfc9f75c67c53a9e1c83d23548c
|
|
| BLAKE2b-256 |
cafd9fd49a9ff3315e699006cc93f3ad622e5c74245c945b11b7f13e6895e5cc
|
Provenance
The following attestation bundles were made for openwebui_mcp_server-0.2.0.tar.gz:
Publisher:
publish.yml on stephanschielke/open-webui-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
openwebui_mcp_server-0.2.0.tar.gz -
Subject digest:
cc0ec0a2657bce4b749030c56e2a61ef80d53eaf4aa2286b129875e2f4894303 - Sigstore transparency entry: 1154269234
- Sigstore integration time:
-
Permalink:
stephanschielke/open-webui-mcp-server@5cfb2c8bb28a0e84c567dfbcb99c1f80f5bcf654 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/stephanschielke
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5cfb2c8bb28a0e84c567dfbcb99c1f80f5bcf654 -
Trigger Event:
push
-
Statement type:
File details
Details for the file openwebui_mcp_server-0.2.0-py3-none-any.whl.
File metadata
- Download URL: openwebui_mcp_server-0.2.0-py3-none-any.whl
- Upload date:
- Size: 15.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d534ad6b31263ea1dc1889baf3601de05104e64dbe355af37d52ae70d9e328e6
|
|
| MD5 |
855b1f15c03d215cd71468230241ce5a
|
|
| BLAKE2b-256 |
8c181953e690b7be596c3649cd0c289a02aa710b47fb6df3b08c4ac0a7c8ff7a
|
Provenance
The following attestation bundles were made for openwebui_mcp_server-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on stephanschielke/open-webui-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
openwebui_mcp_server-0.2.0-py3-none-any.whl -
Subject digest:
d534ad6b31263ea1dc1889baf3601de05104e64dbe355af37d52ae70d9e328e6 - Sigstore transparency entry: 1154269238
- Sigstore integration time:
-
Permalink:
stephanschielke/open-webui-mcp-server@5cfb2c8bb28a0e84c567dfbcb99c1f80f5bcf654 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/stephanschielke
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5cfb2c8bb28a0e84c567dfbcb99c1f80f5bcf654 -
Trigger Event:
push
-
Statement type: