Skip to main content

πŸ”— Open WebUI Integration

Overview​

Open WebUI v0.6+ supports seamless integration with external tools via the OpenAPI servers β€” meaning you can easily extend your LLM workflows using custom or community-powered tool servers 🧰.

In this guide, you'll learn how to launch an OpenAPI-compatible tool server and connect it to Open WebUI through the intuitive user interface. Let’s get started! πŸš€


Step 1: Launch an OpenAPI Tool Server​

To begin, you'll need to start one of the reference tool servers available in the openapi-servers repo. For quick testing, we’ll use the time tool server as an example.

πŸ› οΈ Example: Starting the time server locally

git clone https://github.com/open-webui/openapi-servers
cd openapi-servers

# Navigate to the time server
cd servers/time

# Install required dependencies
pip install -r requirements.txt

# Start the server
uvicorn main:app --host 0.0.0.0 --reload

Once running, this will host a local OpenAPI server at http://localhost:8000, which you can point Open WebUI to.

Time Server


Step 2: Connect Tool Server in Open WebUI​

Next, connect your running tool server to Open WebUI:

  1. Open WebUI in your browser.
  2. Open βš™οΈβ€―Settings.
  3. Click on βž• Tools to add a new tool server.
  4. Enter the URL where your OpenAPI tool server is running (e.g., http://localhost:8000).
  5. Click "Save".

Settings Page

πŸ§‘β€πŸ’» User Tool Servers vs. πŸ› οΈ Global Tool Servers​

There are two ways to register tool servers in Open WebUI:

1. User Tool Servers (added via regular Settings)​

  • Only accessible to the user who registered the tool server.
  • The connection is made directly from the browser (client-side) by the user.
  • Perfect for personal workflows or when testing custom/local tools.

2. Global Tool Servers (added via Admin Settings)​

Admins can manage shared tool servers available to all or selected users across the entire deployment:

  • Go to πŸ› οΈ Admin Settings > Tools.
  • Add the tool server URL just as you would in user settings.
  • These tools are treated similarly to Open WebUI’s built-in tools.

πŸ‘‰ Optional: Using a Config File with mcpo​

If you're running multiple tools through mcpo using a config file, take note:

🧩 Each tool is mounted under its own unique path!

For example, if you’re using memory and time tools simultaneously through mcpo, they’ll each be available at a distinct route:

This means:

  • When connecting a tool in Open WebUI, you must enter the full route to that specific tool β€” do NOT enter just the root URL (http://localhost:8000).
  • Add each tool individually in Open WebUI Settings using their respective subpath URLs.

MCPO Config Tools Setting

βœ… Good:

http://localhost:8000/time
http://localhost:8000/memory

🚫 Not valid:

http://localhost:8000

This ensures Open WebUI recognizes and communicates with each tool server correctly.


Step 3: Confirm Your Tool Server Is Connected βœ…β€‹

Once your tool server is successfully connected, Open WebUI will display a πŸ‘‡ tool server indicator directly in the message input area:

πŸ“ You'll now see this icon below the input box:

Tool Server Indicator

Clicking this icon opens a popup where you can:

  • View connected tool server information
  • See which tools are available and which server they're provided by
  • Debug or disconnect any tool if needed

πŸ” Here’s what the tool information modal looks like:

Tool Info Modal Expanded

πŸ› οΈ Global Tool Servers Look Different β€” And Are Hidden by Default!​

If you've connected a Global Tool Server (i.e., one that’s admin-configured), it will not appear automatically in the input area like user tool servers do.

Instead:

  • Global tools are hidden by default and must be explicitly activated per user.
  • To enable them, you'll need to click on the βž• button in the message input area (bottom left of the chat box), and manually toggle on the specific global tool(s) you want to use.

Here’s what that looks like:

Global Tool Server Message Input

⚠️ Important Notes for Global Tool Servers:

  • They will not show up in the tool indicator popup until enabled from the βž• menu.
  • Each global tool must be individually toggled on to become active inside your current chat.
  • Once toggled on, they function the same way as user tools.
  • Admins can control access to global tools via role-based permissions.

This is ideal for team setups or shared environments, where commonly-used tools (e.g. document search, memory, or web lookup) should be centrally accessible by multiple users.


(Optional) Step 4: Use "Native" Function Calling (ReACT-style) Tool Use πŸ§ β€‹

info

For this to work effectively, your selected model must support native tool calling. Some local models claim support but often produce poor results. We strongly recommend using GPT-4o or another OpenAI model that supports function calling natively for the best experience.

Want to enable ReACT-style (Reasoning + Acting) native function calls directly inside your conversations? You can switch Open WebUI to use native function calling.

✳️ How to enable native function calling:

  1. Open the chat window.
  2. Go to βš™οΈβ€―Chat Controls > Advanced Params.
  3. Change the Function Calling parameter from Default to Native.

Native Tool Call


Need More Tools? Explore & Expand! πŸ§±β€‹

The openapi-servers repo includes a variety of useful reference servers:

  • πŸ“‚ Filesystem access
  • 🧠 Memory & knowledge graphs
  • πŸ—ƒοΈ Git repo browsing
  • 🌎 Web search (WIP)
  • πŸ›’οΈ Database querying (WIP)

You can run any of these in the same way and connect them to Open WebUI by repeating the steps above.


Troubleshooting & Tips πŸ§©β€‹

  • ❌ Not connecting? Make sure the URL is correct and accessible from the browser used to run Open WebUI.
  • πŸ”’ If you're using remote servers, check firewalls and HTTPS configs!
  • πŸ“ To make servers persist, consider deploying them in Docker or with system services.

Need help? Visit the πŸ‘‰ Discussions page or open an issue.