This tutorial is a community contribution and is not supported by the OpenWebUI team. It serves only as a demonstration on how to customize OpenWebUI for your specific use case. Want to contribute? Check out the contributing tutorial.
π¨ Image Generation
Open WebUI supports image generation through three backends: AUTOMATIC1111, ComfyUI, and OpenAI DALLΒ·E. This guide will help you set up and use either of these options.
AUTOMATIC1111β
Open WebUI supports image generation through the AUTOMATIC1111 API. Here are the steps to get started:
Initial Setupβ
-
Ensure that you have AUTOMATIC1111 installed.
-
Launch AUTOMATIC1111 with additional flags to enable API access:
./webui.sh --api --listen
-
For Docker installation of WebUI with the environment variables preset, use the following command:
docker run -d -p 3000:8080 --add-host=host.docker.internal:host-gateway -e AUTOMATIC1111_BASE_URL=http://host.docker.internal:7860/ -e ENABLE_IMAGE_GENERATION=True -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
Setting Up Open WebUI with AUTOMATIC1111β
-
In Open WebUI, navigate to the Admin Panel > Settings > Images menu.
-
Set the
Image Generation Engine
field toDefault (Automatic1111)
. -
In the API URL field, enter the address where AUTOMATIC1111's API is accessible:
http://<your_automatic1111_address>:7860/
If you're running a Docker installation of Open WebUI and AUTOMATIC1111 on the same host, use
http://host.docker.internal:7860/
as your address.
ComfyUIβ
ComfyUI provides an alternative interface for managing and interacting with image generation models. Learn more or download it from its GitHub page. Below are the setup instructions to get ComfyUI running alongside your other tools.
Initial Setupβ
-
Download and extract the ComfyUI software package from GitHub to your desired directory.
-
To start ComfyUI, run the following command:
python main.py
For systems with low VRAM, launch ComfyUI with additional flags to reduce memory usage:
python main.py --lowvram
-
For Docker installation of WebUI with the environment variables preset, use the following command:
docker run -d -p 3000:8080 --add-host=host.docker.internal:host-gateway -e COMFYUI_BASE_URL=http://host.docker.internal:7860/ -e ENABLE_IMAGE_GENERATION=True -v open-webui:/app/backend/data --name open-webui --restart always ghcr.io/open-webui/open-webui:main
Setting Up Open WebUI with ComfyUIβ
Setting Up FLUX.1 Modelsβ
- Model Checkpoints:
- Download either the
FLUX.1-schnell
orFLUX.1-dev
model from the black-forest-labs HuggingFace page. - Place the model checkpoint(s) in both the
models/checkpoints
andmodels/unet
directories of ComfyUI. Alternatively, you can create a symbolic link betweenmodels/checkpoints
andmodels/unet
to ensure both directories contain the same model checkpoints.
- VAE Model:
- Download
ae.safetensors
VAE from here. - Place it in the
models/vae
ComfyUI directory.
- CLIP Model:
- Download
clip_l.safetensors
from here. - Place it in the
models/clip
ComfyUI directory.
- T5XXL Model:
- Download either the
t5xxl_fp16.safetensors
ort5xxl_fp8_e4m3fn.safetensors
model from here. - Place it in the
models/clip
ComfyUI directory.
To integrate ComfyUI into Open WebUI, follow these steps:
Step 1: Configure Open WebUI Settingsβ
- Navigate to the Admin Panel in Open WebUI.
- Click on Settings and then select the Images tab.
- In the
Image Generation Engine
field, chooseComfyUI
. - In the API URL field, enter the address where ComfyUI's API is accessible, following this format:
http://<your_comfyui_address>:8188/
.- Set the environment variable
COMFYUI_BASE_URL
to this address to ensure it persists within the WebUI.
- Set the environment variable
Step 2: Verify the Connection and Enable Image Generationβ
- Ensure ComfyUI is running and that you've successfully verified the connection to Open WebUI. You won't be able to proceed without a successful connection.
- Once the connection is verified, toggle on Image Generation (Experimental). More options will be presented to you.
- Continue to step 3 for the final configuration steps.
Step 3: Configure ComfyUI Settings and Import Workflowβ
- Enable developer mode within ComfyUI. To do this, look for the gear icon above the Queue Prompt button within ComfyUI and enable the
Dev Mode
toggle. - Export the desired workflow from ComfyUI in
API format
using theSave (API Format)
button. The file will be downloaded asworkflow_api.json
if done correctly. - Return to Open WebUI and click the Click here to upload a workflow.json file button.
- Select the
workflow_api.json
file to import the exported workflow from ComfyUI into Open WebUI. - After importing the workflow, you must map the
ComfyUI Workflow Nodes
according to the imported workflow node IDs. - Set
Set Default Model
to the name of the model file being used, such asflux1-dev.safetensors
You may need to adjust an Input Key
or two within Open WebUI's ComfyUI Workflow Nodes
section to match a node within your workflow.
For example, seed
may need to be renamed to noise_seed
to match a node ID within your imported workflow.
Some workflows, such as ones that use any of the Flux models, may utilize multiple nodes IDs that is necessary to fill in for their node entry fields within Open WebUI. If a node entry field requires multiple IDs, the node IDs should be comma separated (e.g. 1
or 1, 2
).
- Click
Save
to apply the settings and enjoy image generation with ComfyUI integrated into Open WebUI!
After completing these steps, your ComfyUI setup should be integrated with Open WebUI, and you can use the Flux.1 models for image generation.
Configuring with SwarmUIβ
SwarmUI utilizes ComfyUI as its backend. In order to get Open WebUI to work with SwarmUI you will have to append ComfyBackendDirect
to the ComfyUI Base URL
. Additionally, you will want to setup SwarmUI with LAN access. After aforementioned adjustments, setting up SwarmUI to work with Open WebUI will be the same as Step one: Configure Open WebUI Settings as outlined above.
SwarmUI API URLβ
The address you will input as the ComfyUI Base URL will look like: http://<your_swarmui_address>:7801/ComfyBackendDirect
OpenAI DALLΒ·Eβ
Open WebUI also supports image generation through the OpenAI DALLΒ·E APIs. This option includes a selector for choosing between DALLΒ·E 2 and DALLΒ·E 3, each supporting different image sizes.
Initial Setupβ
- Obtain an API key from OpenAI.
Configuring Open WebUIβ
- In Open WebUI, navigate to the Admin Panel > Settings > Images menu.
- Set the
Image Generation Engine
field toOpen AI (Dall-E)
. - Enter your OpenAI API key.
- Choose the DALLΒ·E model you wish to use. Note that image size options will depend on the selected model:
- DALLΒ·E 2: Supports
256x256
,512x512
, or1024x1024
images. - DALLΒ·E 3: Supports
1024x1024
,1792x1024
, or1024x1792
images.
- DALLΒ·E 2: Supports
Azure OpenAIβ
Using Azure OpenAI Dall-E directly is unsupported, but you can set up a LiteLLM proxy which is compatible with the Open AI (Dall-E)
Image Generation Engine.
Using Image Generationβ
- First, use a text generation model to write a prompt for image generation.
- After the response has finished, you can click the Picture icon to generate an image.
- After the image has finished generating, it will be returned automatically in chat.
You can also edit the LLM's response and enter your image generation prompt as the message to send off for image generation instead of using the actual response provided by the LLM.