open-webui-mcp-server

troylar/open-webui-mcp-server

3.2

If you are the rightful owner of open-webui-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

An MCP server that integrates with Open WebUI to manage users, groups, models, and more through admin APIs.

Tools
4
Resources
0
Prompts
0

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

pip install openwebui-mcp-server

Or with uv:

uv pip install openwebui-mcp-server

Configuration

Set the required environment variable:

export OPENWEBUI_URL=https://your-openwebui-instance.com

Optionally, set a default API key (can be overridden per-request):

export OPENWEBUI_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": {
        "OPENWEBUI_URL": "https://your-openwebui-instance.com",
        "OPENWEBUI_API_KEY": "your-api-key"
      }
    }
  }
}

With Open WebUI (via MCPO)

  1. Start the server in HTTP mode:
export OPENWEBUI_URL=https://your-openwebui-instance.com
export MCP_TRANSPORT=http
export MCP_HTTP_PORT=8001
openwebui-mcp
  1. 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

ToolDescriptionPermission
get_current_userGet authenticated user's profileAny
list_usersList all usersAdmin
get_userGet specific user detailsAdmin
update_user_roleChange user roleAdmin
delete_userDelete a userAdmin

Group Management

ToolDescriptionPermission
list_groupsList all groupsAny
create_groupCreate a new groupAdmin
get_groupGet group detailsAny
update_groupUpdate group name/descriptionAdmin
add_user_to_groupAdd user to groupAdmin
remove_user_from_groupRemove user from groupAdmin
delete_groupDelete a groupAdmin

Model Management

ToolDescriptionPermission
list_modelsList all modelsAny
get_modelGet model configurationAny
create_modelCreate custom modelAdmin
update_modelUpdate model settingsAdmin
delete_modelDelete a modelAdmin

Knowledge Base Management

ToolDescriptionPermission
list_knowledge_basesList knowledge basesAny
get_knowledge_baseGet knowledge base detailsAny
create_knowledge_baseCreate knowledge baseAny
delete_knowledge_baseDelete knowledge baseOwner

Chat Management

ToolDescriptionPermission
list_chatsList user's chatsOwn
get_chatGet chat messagesOwn
delete_chatDelete a chatOwn
delete_all_chatsDelete all chatsOwn

System

ToolDescriptionPermission
list_toolsList available toolsAny
list_functionsList functions/filtersAny
get_system_configGet system configAdmin

Development

# Clone the repo
git clone https://github.com/troylar/open-webui-mcp-server.git
cd open-webui-mcp-server

# Install dev dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Run linter
ruff check src/

License

MIT License - see for details.

Contributing

Contributions welcome! Please open an issue or PR on GitHub.

Related Projects

  • Open WebUI - The web UI this server manages
  • FastMCP - The MCP framework used
  • MCPO - MCP to OpenAPI proxy