🌍 Environment Variable Configuration
Overview
Open WebUI provides a large range of environment variables that allow you to customize and configure various aspects of the application. This page serves as a comprehensive reference for all available environment variables, providing their types, default values, and descriptions. As new variables are introduced, this page will be updated to reflect the growing configuration options.
This page is up-to-date with Open WebUI release version v0.6.32, but is still a work in progress to later include more accurate descriptions, listing out options available for environment variables, defaults, and improving descriptions.
Important Note on PersistentConfig Environment Variables
When launching Open WebUI for the first time, all environment variables are treated equally and can be used to configure the application. However, for environment variables marked as PersistentConfig, their values are persisted and stored internally.
After the initial launch, if you restart the container, PersistentConfig environment variables will no longer use the external environment variable values. Instead, they will use the internally stored values.
In contrast, regular environment variables will continue to be updated and applied on each subsequent restart.
You can update the values of PersistentConfig environment variables directly from within Open WebUI, and these changes will be stored internally. This allows you to manage these configuration settings independently of the external environment variables.
Please note that PersistentConfig environment variables are clearly marked as such in the documentation below, so you can be aware of how they will behave.
To disable PersistentConfig and have Open WebUI treat all variables equally, you can set ENABLE_PERSISTENT_CONFIG to False.
App/Backend
The following environment variables are used by backend/open_webui/config.py to provide Open WebUI startup
configuration. Please note that some variables may have different default values depending on
whether you're running Open WebUI directly or via Docker. For more information on logging
environment variables, see our logging documentation.
General
WEBUI_URL
- Type:
str - Default:
http://localhost:3000 - Description: Specifies the URL where your Open WebUI installation is reachable. Needed for search engine support and OAuth/SSO.
- Persistence: This environment variable is a
PersistentConfigvariable.
This variable has to be set before you start using OAuth/SSO for authentication. Since this is a persistent config environment variable, you can only change it through one of the following options:
- Temporarily disabling persistent config using
ENABLE_PERSISTENT_CONFIG - Changing
WEBUI_URLin the admin panel > settings and changing "WebUI URL".
Failure to set WEBUI_URL before using OAuth/SSO will result in failure to log in.
ENABLE_SIGNUP
- Type:
bool - Default:
True - Description: Toggles user account creation.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_SIGNUP_PASSWORD_CONFIRMATION
- Type:
bool - Default:
False - Description: If set to True, a "Confirm Password" field is added to the sign-up page to help users avoid typos when creating their password.
ENABLE_LOGIN_FORM
- Type:
bool - Default:
True - Description: Toggles email, password, sign-in and "or" (only when
ENABLE_OAUTH_SIGNUPis set to True) elements. - Persistence: This environment variable is a
PersistentConfigvariable.
This should only ever be set to False when ENABLE_OAUTH_SIGNUP
is also being used and set to True. Failure to do so will result in the inability to login.
DEFAULT_LOCALE
- Type:
str - Default:
en - Description: Sets the default locale for the application.
- Persistence: This environment variable is a
PersistentConfigvariable.
DEFAULT_MODELS
- Type:
str - Default: Empty string (' '), since
None. - Description: Sets a default Language Model.
- Persistence: This environment variable is a
PersistentConfigvariable.
DEFAULT_USER_ROLE
- Type:
str - Options:
pending- New users are pending until their accounts are manually activated by an admin.user- New users are automatically activated with regular user permissions.admin- New users are automatically activated with administrator permissions.
- Default:
pending - Description: Sets the default role assigned to new users.
- Persistence: This environment variable is a
PersistentConfigvariable.
PENDING_USER_OVERLAY_TITLE
- Type:
str - Default: Empty string (' ')
- Description: Sets a custom title for the pending user overlay.
- Persistence: This environment variable is a
PersistentConfigvariable.
PENDING_USER_OVERLAY_CONTENT
- Type:
str - Default: Empty string (' ')
- Description: Sets a custom text content for the pending user overlay.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_CHANNELS
- Type:
bool - Default:
False - Description: Enables or disables channel support.
- Persistence: This environment variable is a
PersistentConfigvariable.
WEBHOOK_URL
- Type:
str - Description: Sets a webhook for integration with Discord/Slack/Microsoft Teams.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_ADMIN_EXPORT
- Type:
bool - Default:
True - Description: Controls whether admins can export data, chats and the database in the admin panel. Database exports only work for SQLite databases for now.
ENABLE_ADMIN_CHAT_ACCESS
- Type:
bool - Default:
True - Description: Enables admin users to directly access the chats of other users. When disabled, admins can no longer accesss user's chats in the admin panel. If you disable this, consider disabling
ENABLE_ADMIN_EXPORTtoo, if you are using SQLite, as the exports also contain user chats.
BYPASS_ADMIN_ACCESS_CONTROL
- Type:
bool - Default:
True - Description: When disabled, admin users are treated like regular users for workspace access (models, knowledge, prompts and tools) and only see items they have explicit permission to access through the existing access control system. This also applies to the visibility of models in the model selector - admins will be treated as regular users: base models and custom models they do not have explicit permission to access, will be hidden. If set to
True(Default), admins have access to all created items in the workspace area and all models in the model selector, regardless of access permissions.
ENABLE_USER_WEBHOOKS
- Type:
bool - Default:
True - Description: Enables or disables user webhooks.
- Persistence: This environment variable is a
PersistentConfigvariable.
RESPONSE_WATERMARK
- Type:
str - Default: Empty string (' ')
- Description: Sets a custom text that will be included when you copy a message in the chat. e.g.,
"This text is AI generated"-> will add "This text is AI generated" to every message, when copied. - Persistence: This environment variable is a
PersistentConfigvariable.
THREAD_POOL_SIZE
- Type:
int - Default:
0 - Description: Sets the thread pool size for FastAPI/AnyIO blocking calls. By default (when set to
0) FastAPI/AnyIO use40threads. In case of large instances and many concurrent users, it may be needed to increaseTHREAD_POOL_SIZEto prevent blocking.
MODELS_CACHE_TTL
- Type:
int - Default:
1 - Description: Sets the cache time-to-live in seconds for model list responses from OpenAI and Ollama endpoints. This reduces API calls by caching the available models list for the specified duration. Set to empty string to disable caching entirely.
This caches the external model lists retrieved from configured OpenAI-compatible and Ollama API endpoints (not Open WebUI's internal model configurations). Higher values improve performance by reducing redundant API requests to external providers but may delay visibility of newly added or removed models on those endpoints. A value of 0 disables caching and forces fresh API calls each time. In high-traffic scenarios, increasing this value (e.g., to 300 seconds) can significantly reduce load on external API endpoints while still providing reasonably fresh model data.
SHOW_ADMIN_DETAILS
- Type:
bool - Default:
True - Description: Toggles whether to show admin user details in the interface.
- Persistence: This environment variable is a
PersistentConfigvariable.
ADMIN_EMAIL
- Type:
str - Description: Sets the admin email shown by
SHOW_ADMIN_DETAILS - Persistence: This environment variable is a
PersistentConfigvariable.
ENV
- Type:
str - Options:
dev- Enables the FastAPI API documentation on/docsprod- Automatically configures several environment variables
- Default:
- Backend Default:
dev - Docker Default:
prod
- Backend Default:
- Description: Environment setting.
ENABLE_PERSISTENT_CONFIG
- Type:
bool - Default:
True - Description: If set to
False, allPersistentConfigvariables are treated as regular variables.
CUSTOM_NAME
- Type:
str - Description: Sets
WEBUI_NAMEbut polls api.openwebui.com for metadata.
WEBUI_NAME
- Type:
str - Default:
Open WebUI - Description: Sets the main WebUI name. Appends
(Open WebUI)if overridden.
PORT
- Type:
int - Default:
8080 - Description: Sets the port to run Open WebUI from.
If you're running the application via Python and using the open-webui serve command, you cannot set the port using the PORT configuration. Instead, you must specify it directly as a command-line argument using the --port flag. For example:
open-webui serve --port 9999
This will run the Open WebUI on port 9999. The PORT environment variable is disregarded in this mode.
ENABLE_REALTIME_CHAT_SAVE
- Type:
bool - Default:
False - Description: When enabled, the system saves each chunk of streamed chat data to the database in real time to ensure maximum data persistency. This feature provides robust data recovery and allows accurate session tracking. However, the tradeoff is increased latency, as saving to the database introduces a delay. Disabling this feature can improve performance and reduce delays, but it risks potential data loss in the event of a system failure or crash. Use based on your application's requirements and acceptable tradeoffs.
CHAT_RESPONSE_STREAM_DELTA_CHUNK_SIZE
- Type:
int - Default:
1 - Description: Sets a system-wide minimum value for the number of tokens to batch together before sending them to the client during a streaming response. This allows an administrator to enforce a baseline level of performance and stability across the entire system by preventing excessively small chunk sizes that can cause high CPU load. The final chunk size used for a response will be the highest value set among this global variable, the model's advanced parameters, or the per-chat settings. The default is 1, which applies no minimum batching at the global level.
It is recommended to set this to a high single-digit or low double-digit value if you run Open WebUI with high concurrency, many users, and very fast streaming models.
BYPASS_MODEL_ACCESS_CONTROL
- Type:
bool - Default:
False - Description: Bypasses model access control. When set to
true, all users (and admins alike) will have access to all models, regardless of the model's privacy setting (Private, Public, Shared with certain groups). This is useful for smaller or individual Open WebUI installations where model access restrictions may not be needed.
WEBUI_BUILD_HASH
- Type:
str - Default:
dev-build - Description: Used for identifying the Git SHA of the build for releases.
WEBUI_BANNERS
- Type:
listofdict - Default:
[] - Description: List of banners to show to users. The format for banners are:
[{"id": "string", "type": "string [info, success, warning, error]", "title": "string", "content": "string", "dismissible": false, "timestamp": 1000}]
- Persistence: This environment variable is a
PersistentConfigvariable.
When setting this environment variable in a .env file, make sure to escape the quotes by wrapping the entire value in double quotes and using escaped quotes (\") for the inner quotes. Example:
WEBUI_BANNERS="[{\"id\": \"1\", \"type\": \"warning\", \"title\": \"Your messages are stored.\", \"content\": \"Your messages are stored and may be reviewed by human people. LLM's are prone to hallucinations, check sources.\", \"dismissible\": true, \"timestamp\": 1000}]"
USE_CUDA_DOCKER
- Type:
bool - Default:
False - Description: Builds the Docker image with NVIDIA CUDA support. Enables GPU acceleration for local Whisper and embeddings.
EXTERNAL_PWA_MANIFEST_URL
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: When defined as a fully qualified URL (e.g., https://path/to/manifest.webmanifest), requests sent to /manifest.json will use the external manifest file. When not defined, the default manifest.json file will be used.
ENABLE_TITLE_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables chat title generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
LICENSE_KEY
- Type:
str - Default:
None - Description: Specifies the license key to use (for Enterprise users only).
- Persistence: This environment variable is a
PersistentConfigvariable.
SSL_ASSERT_FINGERPRINT
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the SSL assert fingerprint to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
DEFAULT_PROMPT_SUGGESTIONS
- Type:
listofdict - Default:
[](which means to use the built-in default prompt suggestions) - Description: List of prompt suggestions. The format for prompt suggestions are:
[{"title": ["Title part 1", "Title part 2"], "content": "prompt"}]
AIOHTTP Client
AIOHTTP_CLIENT_TIMEOUT
- Type:
int - Default:
300 - Description: Specifies the timeout duration in seconds for the AIOHTTP client. This impacts things such as connections to Ollama and OpenAI endpoints.
This is the maximum amount of time the client will wait for a response before timing out.
If set to an empty string (' '), the timeout will be set to None, effectively disabling the timeout and
allowing the client to wait indefinitely.
AIOHTTP_CLIENT_TIMEOUT_MODEL_LIST
- Type:
int - Default:
10 - Description: Sets the timeout in seconds for fetching the model list. This can be useful in cases where network latency requires a longer timeout duration to successfully retrieve the model list.
The AIOHTTP_CLIENT_TIMEOUT_MODEL_LIST is set to 10 seconds by default to help ensure that all necessary connections are available when opening the web UI. This duration allows enough time for retrieving the model list even in cases of higher network latency. You can lower this value if quicker timeouts are preferred, but keep in mind that doing so may lead to some connections being dropped, depending on your network conditions.
AIOHTTP_CLIENT_TIMEOUT_OPENAI_MODEL_LIST
- Type:
int - Description: Sets the timeout in seconds for fetching the model list. This can be useful in cases where network latency requires a longer timeout duration to successfully retrieve the model list.
Directories
DATA_DIR
- Type:
str - Default:
./data - Description: Specifies the base directory for data storage, including uploads, cache, vector database, etc.
FONTS_DIR
- Type:
str - Description: Specifies the directory for fonts.
FRONTEND_BUILD_DIR
- Type:
str - Default:
../build - Description: Specifies the location of the built frontend files.
STATIC_DIR
- Type:
str - Default:
./static - Description: Specifies the directory for static files, such as the favicon.
Ollama
ENABLE_OLLAMA_API
- Type:
bool - Default:
True - Description: Enables the use of Ollama APIs.
- Persistence: This environment variable is a
PersistentConfigvariable.
OLLAMA_BASE_URL (OLLAMA_API_BASE_URL is deprecated)
- Type:
str - Default:
http://localhost:11434 - Docker Default:
- If
K8S_FLAGis set:http://ollama-service.open-webui.svc.cluster.local:11434 - If
USE_OLLAMA_DOCKER=True:http://localhost:11434 - Else
http://host.docker.internal:11434
- If
- Description: Configures the Ollama backend URL.
OLLAMA_BASE_URLS
- Type:
str - Description: Configures load-balanced Ollama backend hosts, separated by
;. SeeOLLAMA_BASE_URL. Takes precedence overOLLAMA_BASE_URL. - Example:
http://host-one:11434;http://host-two:11434 - Persistence: This environment variable is a
PersistentConfigvariable.
USE_OLLAMA_DOCKER
- Type:
bool - Default:
False - Description: Builds the Docker image with a bundled Ollama instance.
K8S_FLAG
- Type:
bool - Default:
False - Description: If set, assumes Helm chart deployment and sets
OLLAMA_BASE_URLtohttp://ollama-service.open-webui.svc.cluster.local:11434
OpenAI
ENABLE_OPENAI_API
- Type:
bool - Default:
True - Description: Enables the use of OpenAI APIs.
- Persistence: This environment variable is a
PersistentConfigvariable.
OPENAI_API_BASE_URL
- Type:
str - Default:
https://api.openai.com/v1 - Description: Configures the OpenAI base API URL.
- Persistence: This environment variable is a
PersistentConfigvariable.
OPENAI_API_BASE_URLS
- Type:
str - Description: Supports balanced OpenAI base API URLs, semicolon-separated.
- Example:
http://host-one:11434;http://host-two:11434 - Persistence: This environment variable is a
PersistentConfigvariable.
OPENAI_API_KEY
- Type:
str - Description: Sets the OpenAI API key.
- Example:
sk-124781258123 - Persistence: This environment variable is a
PersistentConfigvariable.
OPENAI_API_KEYS
- Type:
str - Description: Supports multiple OpenAI API keys, semicolon-separated.
- Example:
sk-124781258123;sk-4389759834759834 - Persistence: This environment variable is a
PersistentConfigvariable.
Tasks
TASK_MODEL
- Type:
str - Description: The default model to use for tasks such as title and web search query generation when using Ollama models.
- Persistence: This environment variable is a
PersistentConfigvariable.
TASK_MODEL_EXTERNAL
- Type:
str - Description: The default model to use for tasks such as title and web search query generation when using OpenAI-compatible endpoints.
- Persistence: This environment variable is a
PersistentConfigvariable.
TITLE_GENERATION_PROMPT_TEMPLATE
- Type:
str - Description: Prompt to use when generating chat titles.
- Default: The value of
DEFAULT_TITLE_GENERATION_PROMPT_TEMPLATEenvironment variable.
DEFAULT_TITLE_GENERATION_PROMPT_TEMPLATE:
### Task:
Generate a concise, 3-5 word title with an emoji summarizing the chat history.
### Guidelines:
- The title should clearly represent the main theme or subject of the conversation.
- Use emojis that enhance understanding of the topic, but avoid quotation marks or special formatting.
- Write the title in the chat's primary language; default to English if multilingual.
- Prioritize accuracy over excessive creativity; keep it clear and simple.
### Output:
JSON format: { "title": "your concise title here" }
### Examples:
- { "title": "📉 Stock Market Trends" },
- { "title": "🍪 Perfect Chocolate Chip Recipe" },
- { "title": "Evolution of Music Streaming" },
- { "title": "Remote Work Productivity Tips" },
- { "title": "Artificial Intelligence in Healthcare" },
- { "title": "🎮 Video Game Development Insights" }
### Chat History:
<chat_history>
{{MESSAGES:END:2}}
</chat_history>
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_FOLLOW_UP_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables follow up generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
FOLLOW_UP_GENERATION_PROMPT_TEMPLATE
- Type:
str - Description: Prompt to use for generating several relevant follow-up questions.
- Default: The value of
DEFAULT_FOLLOW_UP_GENERATION_PROMPT_TEMPLATEenvironment variable.
DEFAULT_FOLLOW_UP_GENERATION_PROMPT_TEMPLATE:
### Task:
Suggest 3-5 relevant follow-up questions or prompts that the user might naturally ask next in this conversation as a **user**, based on the chat history, to help continue or deepen the discussion.
### Guidelines:
- Write all follow-up questions from the user’s point of view, directed to the assistant.
- Make questions concise, clear, and directly related to the discussed topic(s).
- Only suggest follow-ups that make sense given the chat content and do not repeat what was already covered.
- If the conversation is very short or not specific, suggest more general (but relevant) follow-ups the user might ask.
- Use the conversation's primary language; default to English if multilingual.
- Response must be a JSON array of strings, no extra text or formatting.
### Output:
JSON format: { "follow_ups": ["Question 1?", "Question 2?", "Question 3?"] }
### Chat History:
<chat_history>
{{MESSAGES:END:6}}
</chat_history>"
- Persistence: This environment variable is a
PersistentConfigvariable.
TOOLS_FUNCTION_CALLING_PROMPT_TEMPLATE
- Type:
str - Description: Prompt to use when calling tools.
- Default: The value of
DEFAULT_TOOLS_FUNCTION_CALLING_PROMPT_TEMPLATEenvironment variable.
DEFAULT_TOOLS_FUNCTION_CALLING_PROMPT_TEMPLATE:
Available Tools: {{TOOLS}}
Your task is to choose and return the correct tool(s) from the list of available tools based on the query. Follow these guidelines:
- Return only the JSON object, without any additional text or explanation.
- If no tools match the query, return an empty array:
{
"tool_calls": []
}
- If one or more tools match the query, construct a JSON response containing a "tool_calls" array with objects that include:
- "name": The tool's name.
- "parameters": A dictionary of required parameters and their corresponding values.
The format for the JSON response is strictly:
{
"tool_calls": [
{"name": "toolName1", "parameters": {"key1": "value1"}},
{"name": "toolName2", "parameters": {"key2": "value2"}}
]
}
- Persistence: This environment variable is a
PersistentConfigvariable.
Code Execution
ENABLE_CODE_EXECUTION
- Type:
bool - Default:
True - Description: Enables or disables code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_ENGINE
- Type:
str - Default:
pyodide - Description: Specifies the code execution engine to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_JUPYTER_URL
- Type:
str - Default:
None - Description: Specifies the Jupyter URL to use for code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_JUPYTER_AUTH
- Type:
str - Default:
None - Description: Specifies the Jupyter authentication method to use for code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_JUPYTER_AUTH_TOKEN
- Type:
str - Default:
None - Description: Specifies the Jupyter authentication token to use for code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_JUPYTER_AUTH_PASSWORD
- Type:
str - Default:
None - Description: Specifies the Jupyter authentication password to use for code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_EXECUTION_JUPYTER_TIMEOUT
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the timeout for Jupyter code execution.
- Persistence: This environment variable is a
PersistentConfigvariable.
Code Interpreter
ENABLE_CODE_INTERPRETER
- Type:
bool - Default:
True - Description: Enables or disables code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_ENGINE
- Type:
str - Default:
pyodide - Description: Specifies the code interpreter engine to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_BLACKLISTED_MODULES
- Type:
str(comma-separated list of module names) - Default: None
- Description: Specifies a comma-separated list of Python modules that are blacklisted and cannot be imported or used within the code interpreter. This enhances security by preventing access to potentially sensitive or system-level functionalities.
CODE_INTERPRETER_PROMPT_TEMPLATE
- Type:
str - Default:
None - Description: Specifies the prompt template to use for code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_JUPYTER_URL
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Jupyter URL to use for code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_JUPYTER_AUTH
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Jupyter authentication method to use for code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_JUPYTER_AUTH_TOKEN
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Jupyter authentication token to use for code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_JUPYTER_AUTH_PASSWORD
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Jupyter authentication password to use for code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
CODE_INTERPRETER_JUPYTER_TIMEOUT
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the timeout for the Jupyter code interpreter.
- Persistence: This environment variable is a
PersistentConfigvariable.
Direct Connections (OpenAPI/MCPO Tool Servers)
ENABLE_DIRECT_CONNECTIONS
- Type:
bool - Default:
True - Description: Enables or disables direct connections.
- Persistence: This environment variable is a
PersistentConfigvariable.
TOOL_SERVER_CONNECTIONS
- Type:
str(JSON array) - Default:
[] - Description: Specifies a JSON array of tool server connection configurations. Each connection should define the necessary parameters to connect to external tool servers that implement the OpenAPI/MCPO protocol. The JSON must be properly formatted or it will fallback to an empty array.
- Example:
'[{"name": "example-server", "url": "https://api.example.com", "api_key": "your-key"}]' - Persistence: This environment variable is a
PersistentConfigvariable.
Autocomplete
ENABLE_AUTOCOMPLETE_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables autocomplete generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
When enabling ENABLE_AUTOCOMPLETE_GENERATION, ensure that you also configure AUTOCOMPLETE_GENERATION_INPUT_MAX_LENGTH and AUTOCOMPLETE_GENERATION_PROMPT_TEMPLATE accordingly.
AUTOCOMPLETE_GENERATION_INPUT_MAX_LENGTH
- Type:
int - Default:
-1 - Description: Sets the maximum input length for autocomplete generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOCOMPLETE_GENERATION_PROMPT_TEMPLATE
- Type:
str - Default: The value of the
DEFAULT_AUTOCOMPLETE_GENERATION_PROMPT_TEMPLATEenvironment variable.
DEFAULT_AUTOCOMPLETE_GENERATION_PROMPT_TEMPLATE:
### Task:
You are an autocompletion system. Continue the text in `<text>` based on the **completion type** in `<type>` and the given language.
### **Instructions**:
1. Analyze `<text>` for context and meaning.
2. Use `<type>` to guide your output:
- **General**: Provide a natural, concise continuation.
- **Search Query**: Complete as if generating a realistic search query.
3. Start as if you are directly continuing `<text>`. Do **not** repeat, paraphrase, or respond as a model. Simply complete the text.
4. Ensure the continuation:
- Flows naturally from `<text>`.
- Avoids repetition, overexplaining, or unrelated ideas.
5. If unsure, return: `{ "text": "" }`.
### **Output Rules**:
- Respond only in JSON format: `{ "text": "<your_completion>" }`.
### **Examples**:
#### Example 1:
Input:
<type>General</type>
<text>The sun was setting over the horizon, painting the sky</text>
Output:
{ "text": "with vibrant shades of orange and pink." }
#### Example 2:
Input:
<type>Search Query</type>
<text>Top-rated restaurants in</text>
Output:
{ "text": "New York City for Italian cuisine." }
---
### Context:
<chat_history>
{{MESSAGES:END:6}}
</chat_history>
<type>{{TYPE}}</type>
<text>{{PROMPT}}</text>
#### Output:
- Description: Sets the prompt template for autocomplete generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
Evaluation Arena Model
ENABLE_EVALUATION_ARENA_MODELS
- Type:
bool - Default:
True - Description: Enables or disables evaluation arena models.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_MESSAGE_RATING
- Type:
bool - Default:
True - Description: Enables message rating feature.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_COMMUNITY_SHARING
- Type:
bool - Default:
True - Description: Controls whether users are shown the share to community button.
- Persistence: This environment variable is a
PersistentConfigvariable.
Tags Generation
ENABLE_TAGS_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables tag generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
TAGS_GENERATION_PROMPT_TEMPLATE
- Type:
str - Default: The value of
DEFAULT_TAGS_GENERATION_PROMPT_TEMPLATEenvironment variable.
DEFAULT_TAGS_GENERATION_PROMPT_TEMPLATE:
### Task:
Generate 1-3 broad tags categorizing the main themes of the chat history, along with 1-3 more specific subtopic tags.
### Guidelines:
- Start with high-level domains (e.g., Science, Technology, Philosophy, Arts, Politics, Business, Health, Sports, Entertainment, Education)
- Consider including relevant subfields/subdomains if they are strongly represented throughout the conversation
- If content is too short (less than 3 messages) or too diverse, use only ["General"]
- Use the chat's primary language; default to English if multilingual
- Prioritize accuracy over specificity
### Output:
JSON format: { "tags": ["tag1", "tag2", "tag3"] }
### Chat History:
<chat_history>
{{MESSAGES:END:6}}
</chat_history>
- Description: Sets the prompt template for tag generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
API Key Endpoint Restrictions
ENABLE_API_KEY
- Type:
bool - Default:
True - Description: Enables API key authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_API_KEY_ENDPOINT_RESTRICTIONS
- Type:
bool - Default:
False - Description: Enables API key endpoint restrictions for added security and configurability.
- Persistence: This environment variable is a
PersistentConfigvariable.
API_KEY_ALLOWED_ENDPOINTS
- Type:
str - Description: Specifies a comma-separated list of allowed API endpoints when API key endpoint restrictions are enabled.
- Persistence: This environment variable is a
PersistentConfigvariable.
The value of API_KEY_ALLOWED_ENDPOINTS should be a comma-separated list of endpoint URLs, such as /api/v1/messages, /api/v1/channels.
JWT_EXPIRES_IN
- Type:
str - Default:
4w - Description: Sets the JWT expiration time in seconds. Valid time units:
s,m,h,d,wor-1for no expiration. - Persistence: This environment variable is a
PersistentConfigvariable.
Setting JWT_EXPIRES_IN to -1 disables JWT expiration, making issued tokens valid forever. This is extremely dangerous in production and exposes your system to severe security risks if tokens are leaked or compromised.
Always set a reasonable expiration time in production environments (e.g., 3600s, 1h, 7d etc.) to limit the lifespan of authentication tokens.
NEVER use -1 in a production environment.
If you have already deployed with JWT_EXPIRES_IN=-1, you can rotate or change your WEBUI_SECRET_KEY to immediately invalidate all existing tokens.
Security Variables
ENABLE_FORWARD_USER_INFO_HEADERS
- type:
bool - Default:
False - Description: Forwards user information (name, ID, email, role and chat-id) as X-headers to OpenAI API and Ollama API.
If enabled, the following headers are forwarded:
X-OpenWebUI-User-NameX-OpenWebUI-User-IdX-OpenWebUI-User-EmailX-OpenWebUI-User-RoleX-OpenWebUI-Chat-Id
ENABLE_WEB_LOADER_SSL_VERIFICATION
- Type:
bool - Default:
True - Description: Bypass SSL Verification for RAG on Websites.
- Persistence: This environment variable is a
PersistentConfigvariable.
WEBUI_SESSION_COOKIE_SAME_SITE
- Type:
str - Options:
lax- Sets theSameSiteattribute to lax, allowing session cookies to be sent with requests initiated by third-party websites.strict- Sets theSameSiteattribute to strict, blocking session cookies from being sent with requests initiated by third-party websites.none- Sets theSameSiteattribute to none, allowing session cookies to be sent with requests initiated by third-party websites, but only over HTTPS.
- Default:
lax - Description: Sets the
SameSiteattribute for session cookies.
When ENABLE_OAUTH_SIGNUP is enabled, setting WEBUI_SESSION_COOKIE_SAME_SITE to strict can cause login failures. This is because Open WebUI uses a session cookie to validate the callback from the OAuth provider, which helps prevent CSRF attacks.
However, a strict session cookie is not sent with the callback request, leading to potential login issues. If you experience this problem, use the default lax value instead.
WEBUI_SESSION_COOKIE_SECURE
- Type:
bool - Default:
False - Description: Sets the
Secureattribute for session cookies if set toTrue.
WEBUI_AUTH_COOKIE_SAME_SITE
- Type:
str - Options:
lax- Sets theSameSiteattribute to lax, allowing auth cookies to be sent with requests initiated by third-party websites.strict- Sets theSameSiteattribute to strict, blocking auth cookies from being sent with requests initiated by third-party websites.none- Sets theSameSiteattribute to none, allowing auth cookies to be sent with requests initiated by third-party websites, but only over HTTPS.
- Default:
lax - Description: Sets the
SameSiteattribute for auth cookies.
If the value is not set, WEBUI_SESSION_COOKIE_SAME_SITE will be used as a fallback.
WEBUI_AUTH_COOKIE_SECURE
- Type:
bool - Default:
False - Description: Sets the
Secureattribute for auth cookies if set toTrue.
If the value is not set, WEBUI_SESSION_COOKIE_SECURE will be used as a fallback.
WEBUI_AUTH
- Type:
bool - Default:
True - Description: This setting enables or disables authentication.
If set to False, authentication will be disabled for your Open WebUI instance. However, it's
important to note that turning off authentication is only possible for fresh installations without
any existing users. If there are already users registered, you cannot disable authentication
directly. Ensure that no users are present in the database if you intend to turn off WEBUI_AUTH.
WEBUI_SECRET_KEY
- Type:
str - Default:
t0p-s3cr3t - Docker Default: Randomly generated on first start
- Description: Overrides the randomly generated string used for JSON Web Token.
This variable is always needed when using OAUTH, especially in clustered environments, but even in single-process environments.
Otherwise, OAUTH issues may occur.
ENABLE_VERSION_UPDATE_CHECK
- Type:
bool - Default:
True - Description: When enabled, the application makes automatic update checks and notifies you about version updates.
If OFFLINE_MODE is enabled, this ENABLE_VERSION_UPDATE_CHECK flag is always set to false automatically.
OFFLINE_MODE
- Type:
bool - Default:
False - Description: Disables Open WebUI's network connections for update checks and automatic model downloads.
Disabled when enabled:
- Automatic version update checks (see flag
ENABLE_VERSION_UPDATE_CHECK) - Downloads of embedding models from Hugging Face Hub
- If you did not download an embedding model prior to activating
OFFLINE_MODEany RAG, web search and document analysis functionality may not work properly
- If you did not download an embedding model prior to activating
- Update notifications in the UI (see flag
ENABLE_VERSION_UPDATE_CHECK)
Still functional:
- External LLM API connections (OpenAI, etc.)
- OAuth authentication providers
- Web search and RAG with external APIs
Read more about offline mode in the offline mode guide.
RESET_CONFIG_ON_START
- Type:
bool - Default:
False - Description: Resets the
config.jsonfile on startup.
SAFE_MODE
- Type:
bool - Default:
False - Description: Enables safe mode, which disables potentially unsafe features, deactivating all functions.
CORS_ALLOW_ORIGIN
- Type:
str - Default:
* - Description: Sets the allowed origins for Cross-Origin Resource Sharing (CORS).
CORS_ALLOW_CUSTOM_SCHEME
- Type
str - Default:
""(empty string) - Description: Sets a list of further allowed schemes for Cross-Origin Resource Sharing (CORS). Allows you to specify additional custom URL schemes, beyond the standard
httpandhttps, that are permitted as valid origins for Cross-Origin Resource Sharing (CORS).
This is particularly useful for scenarios such as:
- Integrating with desktop applications that use custom protocols (e.g.,
app://,custom-app-scheme://). - Local development environments or testing setups that might employ non-standard schemes (e.g.,
file://if applicable, orelectron://).
Provide a semicolon-separated list of scheme names without the ://. For example: app;file;electron;my-custom-scheme.
When configured, these custom schemes will be validated alongside http and https for any origins specified in CORS_ALLOW_ORIGIN.
RAG_EMBEDDING_MODEL_TRUST_REMOTE_CODE
- Type:
bool - Default:
False - Description: Determines whether to allow custom models defined on the Hub in their own modeling files.
RAG_RERANKING_MODEL_TRUST_REMOTE_CODE
- Type:
bool - Default:
False - Description: Determines whether to allow custom models defined on the Hub in their own. modeling files for reranking.
RAG_EMBEDDING_MODEL_AUTO_UPDATE
- Type:
bool - Default:
True - Description: Toggles automatic update of the Sentence-Transformer model.
RAG_RERANKING_MODEL_AUTO_UPDATE
- Type:
bool - Default:
True - Description: Toggles automatic update of the reranking model.
Vector Database
VECTOR_DB
- Type:
str - Options:
chroma,elasticsearch,milvus,opensearch,pgvector,qdrant,pinecone,s3vector,oracle23ai- Default:
chroma - Description: Specifies which vector database system to use. This setting determines which vector storage system will be used for managing embeddings.
PostgreSQL Dependencies
To use pgvector, ensure you have PostgreSQL dependencies installed:
pip install open-webui[all]
ChromaDB
CHROMA_TENANT
- Type:
str - Default: The value of
chromadb.DEFAULT_TENANT(a constant in thechromadbmodule) - Description: Sets the tenant for ChromaDB to use for RAG embeddings.
CHROMA_DATABASE
- Type:
str - Default: The value of
chromadb.DEFAULT_DATABASE(a constant in thechromadbmodule) - Description: Sets the database in the ChromaDB tenant to use for RAG embeddings.
CHROMA_HTTP_HOST
- Type:
str - Description: Specifies the hostname of a remote ChromaDB Server. Uses a local ChromaDB instance if not set.
CHROMA_HTTP_PORT
- Type:
int - Default:
8000 - Description: Specifies the port of a remote ChromaDB Server.
CHROMA_HTTP_HEADERS
- Type:
str - Description: A comma-separated list of HTTP headers to include with every ChromaDB request.
- Example:
Authorization=Bearer heuhagfuahefj,User-Agent=OpenWebUI.
CHROMA_HTTP_SSL
- Type:
bool - Default:
False - Description: Controls whether or not SSL is used for ChromaDB Server connections.
CHROMA_CLIENT_AUTH_PROVIDER
- Type:
str - Description: Specifies an authentication provider for remote ChromaDB Server.
- Example:
chromadb.auth.basic_authn.BasicAuthClientProvider
CHROMA_CLIENT_AUTH_CREDENTIALS
- Type:
str - Description: Specifies auth credentials for remote ChromaDB Server.
- Example:
username:password
Elasticsearch
ELASTICSEARCH_API_KEY
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Elasticsearch API key.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_CA_CERTS
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the path to the CA certificates for Elasticsearch.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_CLOUD_ID
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the Elasticsearch cloud ID.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_INDEX_PREFIX
- Type:
str - Default:
open_webui_collections - Description: Specifies the prefix for the Elasticsearch index.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_PASSWORD
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the password for Elasticsearch.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_URL
- Type:
str - Default:
https://localhost:9200 - Description: Specifies the URL for the Elasticsearch instance.
- Persistence: This environment variable is a
PersistentConfigvariable.
ELASTICSEARCH_USERNAME
- Type:
str - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the username for Elasticsearch.
- Persistence: This environment variable is a
PersistentConfigvariable.
Milvus
MILVUS_URI
- Type:
str - Default:
${DATA_DIR}/vector_db/milvus.db - Description: Specifies the URI for connecting to the Milvus vector database. This can point to a local or remote Milvus server based on the deployment configuration.
MILVUS_DB
- Type:
str - Default:
default - Description: Specifies the database to connect to within a Milvus instance.
MILVUS_TOKEN
- Type:
str - Default:
None - Description: Specifies an optional connection token for Milvus.
MILVUS_INDEX_TYPE
- Type:
str - Default:
HNSW - Options:
AUTOINDEX,FLAT,IVF_FLAT,HNSW,DISKANN - Description: Specifies the index type to use when creating a new collection in Milvus.
AUTOINDEXis generally recommended for Milvus standalone.HNSWmay offer better performance but requires a clustered Milvus setup and is not meant for standalone setups. - Persistence: This environment variable is a
PersistentConfigvariable.
MILVUS_METRIC_TYPE
- Type:
str - Default:
COSINE - Options:
COSINE,IP,L2 - Description: Specifies the metric type for vector similarity search in Milvus.
- Persistence: This environment variable is a
PersistentConfigvariable.
MILVUS_HNSW_M
- Type:
int - Default:
16 - Description: Specifies the
Mparameter for the HNSW index type in Milvus. This influences the number of bi-directional links created for each new element during construction. Only applicable ifMILVUS_INDEX_TYPEisHNSW. - Persistence: This environment variable is a
PersistentConfigvariable.
MILVUS_HNSW_EFCONSTRUCTION
- Type:
int - Default:
100 - Description: Specifies the
efConstructionparameter for the HNSW index type in Milvus. This influences the size of the dynamic list for the nearest neighbors during index construction. Only applicable ifMILVUS_INDEX_TYPEisHNSW. - Persistence: This environment variable is a
PersistentConfigvariable.
MILVUS_IVF_FLAT_NLIST
- Type:
int - Default:
128 - Description: Specifies the
nlistparameter for the IVF_FLAT index type in Milvus. This is the number of cluster units. Only applicable ifMILVUS_INDEX_TYPEisIVF_FLAT. - Persistence: This environment variable is a
PersistentConfigvariable.
MILVUS_DISKANN_MAX_DEGREE
- Type:
int - Default:
56 - Description: Sets the max degree for Milvus if Milvus is in DISKANN indexing mode. Generally recommended to leave as is.
MILVUS_DISKANN_SEARCH_LIST_SIZE
- Type:
int - Default:
100 - Description: Sets the Milvus DISKANN search list size. Generally recommended to leave as is.
ENABLE_MILVUS_MULTITENANCY_MODE
- Type:
bool - Default:
false - Description: Enables multitenancy pattern for Milvus collections management, which significantly reduces RAM usage and computational overhead by consolidating similar vector data structures. Controls whether Milvus uses multitenancy collection architecture. When enabled, all vector data is consolidated into 5 shared collections (memories, knowledge, files, web_search, hash_based) instead of creating individual collections per resource. Data isolation is achieved via a resource_id field rather than collection-level separation.
Benefits of multitenancy mode:
- Significantly reduced RAM consumption (5 collections vs potentially hundreds)
- Lower computational overhead from collection management
- Faster cold-start times
- Reduced index maintenance burden
Technical implementation:
- All memories go into
{prefix}_memories - All knowledge bases go into
{prefix}_knowledge - All uploaded files go into
{prefix}_files - Web search results go into
{prefix}_web_search - Hash-based collections go into
{prefix}_hash_based - Each entry includes a resource_id field matching the original collection name
- Queries automatically filter by resource_id to maintain data isolation
Migration from Legacy Mode to Multitenancy
What happens when you enable multitenancy when you already have a normal milvus database with data in it:
- Existing collections (pattern:
open_webui_{collection_name}) remain in Milvus but become inaccessible to Open WebUI - New data is written to the 5 shared multitenancy collections
- Application treats knowledge bases as empty until reindexed
- Files and memories are NOT automatically migrated to the new collection schema and will appear missing
Clean migration path from normal Milvus to multitenancy milvus:
- Before enabling multitenancy, export any critical knowledge content from the UI if possible
- Set
ENABLE_MILVUS_MULTITENANCY_MODE=trueand restart Open WebUI - Navigate to
Admin Settings > Documents > Click Reindex Knowledge Base
This rebuilds ONLY knowledge base vectors into the new multitenancy collections Files, user memories, and web search history are NOT migrated by this operation
Verify knowledge bases are accessible and functional
- Re-upload files if file-based retrieval is critical (file metadata remains but vectors are not migrated)
- User chat memories will need to be regenerated through new conversations
Cleaning up legacy collections: After successful migration (from milvus to multitenancy milvus), legacy collections still consume resources. Remove them manually:
- Connect to Milvus using the native client (pymilvus or Attu UI)
- Delete all old collections
Current UI limitations:
- No one-click "migrate and cleanup" button exists
- Vector DB reset from UI (Admin Settings > Documents > Reset Vector Storage/Knowledge) only affects the active mode's collections
- Legacy collections require manual cleanup via Milvus client tools
Critical Considerations
Before enabling multitenancy on an existing installation:
- Data loss risk: File vectors and user memory vectors are NOT migrated automatically. Only knowledge base content can be reindexed (migrated).
- Collection naming dependency: Multitenancy relies on Open WebUI's internal collection naming conventions (user-memory-, file-, web-search-, hash patterns). If Open WebUI changes these conventions in future updates, multitenancy routing may break, causing data corruption or incorrect data retrieval across isolated resources.
- No automatic rollback: Disabling multitenancy after data is written will not restore access to the shared collections. Data would need manual extraction and re-import.
For fresh installations:
- Multitenancy is recommended and enabled by default (true)
- No migration concerns exist
For existing installations with valuable data:
- Do not migrate to multitenancy mode if you do not want to handle migration and risk data loss
- Understand that files and memories require re-upload/regeneration
- Test migration on a backup/staging environment first
- Consider if RAM savings justify the migration effort for your use case
To perform a full reset and switch to multitenancy:
- Backup any critical knowledge base content externally
- Navigate to
Admin Settings > Documents - Click
Reset Vector Storage/Knowledge(this deletes all active mode collections and stored knowledge metadata) - Set
ENABLE_MILVUS_MULTITENANCY_MODE=true - Restart Open WebUI
- Re-upload/re-create knowledge bases from scratch
MILVUS_COLLECTION_PREFIX
- Type:
str - Default:
open_webui - Description: Sets the prefix for Milvus collection names. In multitenancy mode, collections become
{prefix}_memories,{prefix}_knowledge, etc. In legacy mode, collections are{prefix}_{collection_name}. Changing this value creates an entirely separate namespace—existing collections with the old prefix become invisible to Open WebUI but remain in Milvus consuming resources. Use this for true multi-instance isolation on a shared Milvus server, not for migration between modes. Milvus only accepts underscores, hyphens/dashes are not possible and will cause errors.
OpenSearch
OPENSEARCH_CERT_VERIFY
- Type:
bool - Default:
False - Description: Enables or disables OpenSearch certificate verification.
OPENSEARCH_PASSWORD
- Type:
str - Default:
None - Description: Sets the password for OpenSearch.
OPENSEARCH_SSL
- Type:
bool - Default:
True - Description: Enables or disables SSL for OpenSearch.
OPENSEARCH_URI
- Type:
str - Default:
https://localhost:9200 - Description: Sets the URI for OpenSearch.
OPENSEARCH_USERNAME
- Type:
str - Default:
None - Description: Sets the username for OpenSearch.
PGVector
PostgreSQL Dependencies
To use pgvector, ensure you have PostgreSQL dependencies installed:
pip install open-webui[all]
PGVECTOR_DB_URL
- Type:
str - Default: The value of the
DATABASE_URLenvironment variable - Description: Sets the database URL for model storage.
PGVECTOR_INITIALIZE_MAX_VECTOR_LENGTH
- Type:
str - Default:
1536 - Description: Specifies the maximum vector length for PGVector initialization.
PGVECTOR_CREATE_EXTENSION
- Type:
str - Default
true - Description: Creates the vector extension in the database
If set to false, open-webui will assume the postgreSQL database where embeddings will be stored is pre-configured with the vector extension. This also allows open-webui to run as a non superuser database user.
Qdrant
QDRANT_API_KEY
- Type:
str - Description: Sets the API key for Qdrant.
QDRANT_URI
- Type:
str - Description: Sets the URI for Qdrant.
QDRANT_ON_DISK
- Type:
bool - Default:
False - Description: Enable the usage of memmap(also known as on-disk) storage
QDRANT_PREFER_GRPC
- Type:
bool - Default:
False - Description: Use gPRC interface whenever possible.
If set to True, and QDRANT_URI points to a self-hosted server with TLS enabled and certificate signed by a private CA, set the environment variable GRPC_DEFAULT_SSL_ROOTS_FILE_PATH to the path of your PEM-encoded CA certificates file. See the gRPC Core Docs for more information.
QDRANT_GRPC_PORT
- Type:
int - Default:
6334 - Description: Sets the gRPC port number for Qdrant.
QDRANT_TIMEOUT
- Type:
int - Default:
5 - Description: Sets the timeout in seconds for all requests made to the Qdrant server, helping to prevent long-running queries from stalling the application.
QDRANT_HNSW_M
- Type:
int - Default:
16 - Description: Controls the HNSW (Hierarchical Navigable Small World) index construction. In standard mode, this sets the
mparameter. In multi-tenancy mode, this value is used for thepayload_mparameter to build indexes on the payload, as the globalmis disabled for performance, following Qdrant best practices.
ENABLE_QDRANT_MULTITENANCY_MODE
- Type:
bool - Default:
True - Description: Enables multitenancy pattern for Qdrant collections management, which significantly reduces RAM usage and computational overhead by consolidating similar vector data structures. Recommend turn on
This will disconect all Qdrant collections created in the previous pattern, which is non-multitenancy. Go to Admin Settings > Documents > Reindex Knowledge Base to migrate existing knowledges.
The Qdrant collections created in the previous pattern will still consume resources.
Currently, there is no button in the UI to only reset the vector DB. If you want to migrate knowledge to multitenancy:
- Remove all collections with the
open_webui-knowledgeprefix (oropen_webuiprefix to remove all collections related to Open WebUI) using the native Qdrant client - Go to
Admin Settings>Documents>Reindex Knowledge Baseto migrate existing knowledge base
Reindex Knowledge Base will ONLY migrate the knowledge base
If you decide to use the multitenancy pattern as your default and you don't need to migrate old knowledge, go to Admin Settings > Documents to reset vector and knowledge, which will delete all collections with the open_webui prefix and all stored knowledge.
QDRANT_COLLECTION_PREFIX
- Type:
str - Default:
open-webui - Description: Sets the prefix for Qdrant collection names. Useful for namespacing or isolating collections, especially in multitenancy mode. Changing this value will cause the application to use a different set of collections in Qdrant. Existing collections with a different prefix will not be affected.
Pinecone
When using Pinecone as the vector store, the following environment variables are used to control its behavior. Make sure to set these variables in your .env file or deployment environment.
PINECONE_API_KEY
- Type:
str - Default:
None - Description: Sets the API key used to authenticate with the Pinecone service.
PINECONE_ENVIRONMENT
- Type:
str - Default:
None - Description: Specifies the Pinecone environment to connect to (e.g.,
us-west1-gcp,gcp-starter, etc.).
PINECONE_INDEX_NAME
- Type:
str - Default:
open-webui-index - Description: Defines the name of the Pinecone index that will be used to store and query vector embeddings.
PINECONE_DIMENSION
- Type:
int - Default:
1536 - Description: The dimensionality of the vector embeddings. Must match the dimension expected by the index (commonly 768, 1024, 1536, or 3072 based on model used).
PINECONE_METRIC
- Type:
str - Default:
cosine - Options:
cosine,dotproduct,euclidean - Description: Specifies the similarity metric to use for vector comparisons within the Pinecone index.
PINECONE_CLOUD
- Type:
str - Default:
aws - Options:
aws,gcp,azure - Description: Specifies the cloud provider where the Pinecone index is hosted.
Oracle 23ai Vector Search (oracle23ai)
ORACLE_DB_USE_WALLET
- Type:
bool - Default:
false - Description: Determines the connection method to the Oracle Database.
- Set to
falsefor direct connections (e.g., to Oracle Database 23ai Free or DBCS instances) using host, port, and service name inORACLE_DB_DSN. - Set to
truefor wallet-based connections (e.g., to Oracle Autonomous Database (ADW/ATP)). Whentrue,ORACLE_WALLET_DIRandORACLE_WALLET_PASSWORDmust also be configured.
- Set to
ORACLE_DB_USER
- Type:
str - Default:
DEMOUSER - Description: Specifies the username used to connect to the Oracle Database.
ORACLE_DB_PASSWORD
- Type:
str - Default:
Welcome123456 - Description: Specifies the password for the
ORACLE_DB_USER.
ORACLE_DB_DSN
- Type:
str - Default:
localhost:1521/FREEPDB1 - Description: Defines the Data Source Name for the Oracle Database connection.
- If
ORACLE_DB_USE_WALLETisfalse, this should be in the formathostname:port/service_name(e.g.,localhost:1521/FREEPDB1). - If
ORACLE_DB_USE_WALLETistrue, this can be a TNS alias (e.g.,mediumfor ADW/ATP), or a full connection string.
- If
ORACLE_WALLET_DIR
- Type:
str - Default: Empty string (' ')
- Description: Required when
ORACLE_DB_USE_WALLETistrue. Specifies the absolute path to the directory containing the Oracle Cloud Wallet files (e.g.,cwallet.sso,sqlnet.ora,tnsnames.ora).
ORACLE_WALLET_PASSWORD
- Type:
str - Default: Empty string (' ')
- Description: Required when
ORACLE_DB_USE_WALLETistrue. Specifies the password for the Oracle Cloud Wallet.
ORACLE_VECTOR_LENGTH
- Type:
int - Default:
768 - Description: Sets the expected dimension or length of the vector embeddings stored in the Oracle Database. This must match the embedding model used.
ORACLE_DB_POOL_MIN
- Type:
int - Default:
2 - Description: The minimum number of connections to maintain in the Oracle Database connection pool.
ORACLE_DB_POOL_MAX
- Type:
int - Default:
10 - Description: The maximum number of connections allowed in the Oracle Database connection pool.
ORACLE_DB_POOL_INCREMENT
- Type:
int - Default:
1 - Description: The number of connections to create when the pool needs to grow.
S3 Vector Bucket
When using S3 Vector Bucket as the vector store, the following environment variables are used to control its behavior. Make sure to set these variables in your .env file or deployment environment.
Note: this configuration assumes that AWS credentials will be available to your Open WebUI environment. This could be through environment variables like AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY, or through IAM role permissions.
S3_VECTOR_BUCKET_NAME
- Type:
str - Description: Specifies the name of the S3 Vector Bucket to store vectors in.
S3_VECTOR_REGION
- Type:
str - Description: Specifies the AWS region where the S3 Vector Bucket is hosted.
RAG Content Extraction Engine
CONTENT_EXTRACTION_ENGINE
- Type:
str - Options:
- Leave empty to use default
external- Use external loadertika- Use a local Apache Tika serverdocling- Use Docling enginedocument_intelligence- Use Document Intelligence enginemistral_ocr- Use Mistral OCR engine
- Description: Sets the content extraction engine to use for document ingestion.
- Persistence: This environment variable is a
PersistentConfigvariable.
MISTRAL_OCR_API_KEY
- Type:
str - Default:
None - Description: Specifies the Mistral OCR API key to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
EXTERNAL_DOCUMENT_LOADER_URL
- Type:
str - Default:
None - Description: Sets the URL for the external document loader service.
- Persistence: This environment variable is a
PersistentConfigvariable.
EXTERNAL_DOCUMENT_LOADER_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for authenticating with the external document loader service.
- Persistence: This environment variable is a
PersistentConfigvariable.
TIKA_SERVER_URL
- Type:
str - Default:
http://localhost:9998 - Description: Sets the URL for the Apache Tika server.
- Persistence: This environment variable is a
PersistentConfigvariable.
DOCLING_SERVER_URL
- Type:
str - Default:
http://docling:5001 - Description: Specifies the URL for the Docling server. Requires Docling version 1.0.0 or later.
- Persistence: This environment variable is a
PersistentConfigvariable.
DOCLING_OCR_ENGINE
- Type:
str - Default:
tesseract - Description: Specifies the OCR engine used by Docling.
Supported values include:
tesseract(default),easyocr,ocrmac,rapidocr, andtesserocr. - Persistence: This environment variable is a
PersistentConfigvariable.
DOCLING_OCR_LANG
- Type:
str - Default:
eng,fra,deu,spa(when using the defaulttesseractengine) - Description: Specifies the OCR language(s) to be used with the configured
DOCLING_OCR_ENGINE. The format and available language codes depend on the selected OCR engine. - Persistence: This environment variable is a
PersistentConfigvariable.
Retrieval Augmented Generation (RAG)
Core Configuration
RAG_EMBEDDING_ENGINE
- Type:
str - Options:
- Leave empty for
Default (SentenceTransformers)- Uses SentenceTransformers for embeddings. ollama- Uses the Ollama API for embeddings.openai- Uses the OpenAI API for embeddings.azure_openai- Uses Azure OpenAI Services for embeddings.
- Leave empty for
- Description: Selects an embedding engine to use for RAG.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_EMBEDDING_MODEL
- Type:
str - Default:
sentence-transformers/all-MiniLM-L6-v2 - Description: Sets a model for embeddings. Locally, a Sentence-Transformer model is used.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_TOP_K
- Type:
int - Default:
3 - Description: Sets the default number of results to consider for the embedding when using RAG.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_TOP_K_RERANKER
- Type:
int - Default:
3 - Description: Sets the default number of results to consider for the reranker when using RAG.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_RELEVANCE_THRESHOLD
- Type:
float - Default:
0.0 - Description: Sets the relevance threshold to consider for documents when used with reranking.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_RAG_HYBRID_SEARCH
- Type:
bool - Default:
False - Description: Enables the use of ensemble search with
BM25+ChromaDB, with reranking usingsentence_transformersmodels. - Persistence: This environment variable is a
PersistentConfigvariable.
RAG_HYBRID_BM25_WEIGHT
- Type:
float - Default:
0.5 - Description: Sets the weight given to the keyword search (BM25) during hybrid search. 1 means only keyword search, 0 means only vector search.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_TEMPLATE
- Type:
str - Default: The value of
DEFAULT_RAG_TEMPLATEenvironment variable.
DEFAULT_RAG_TEMPLATE:
### Task:
Respond to the user query using the provided context, incorporating inline citations in the format [id] **only when the <source> tag includes an explicit id attribute** (e.g., <source id="1">).
### Guidelines:
- If you don't know the answer, clearly state that.
- If uncertain, ask the user for clarification.
- Respond in the same language as the user's query.
- If the context is unreadable or of poor quality, inform the user and provide the best possible answer.
- If the answer isn't present in the context but you possess the knowledge, explain this to the user and provide the answer using your own understanding.
- **Only include inline citations using [id] (e.g., [1], [2]) when the <source> tag includes an id attribute.**
- Do not cite if the <source> tag does not contain an id attribute.
- Do not use XML tags in your response.
- Ensure citations are concise and directly related to the information provided.
### Example of Citation:
If the user asks about a specific topic and the information is found in a source with a provided id attribute, the response should include the citation like in the following example:
* "According to the study, the proposed method increases efficiency by 20% [1]."
### Output:
Provide a clear and direct response to the user's query, including inline citations in the format [id] only when the <source> tag with id attribute is present in the context.
<context>
{{CONTEXT}}
</context>
<user_query>
{{QUERY}}
</user_query>
- Description: Template to use when injecting RAG documents into chat completion.
- Persistence: This environment variable is a
PersistentConfigvariable.
Document Processing
CHUNK_SIZE
- Type:
int - Default:
1000 - Description: Sets the document chunk size for embeddings.
- Persistence: This environment variable is a
PersistentConfigvariable.
CHUNK_OVERLAP
- Type:
int - Default:
100 - Description: Specifies how much overlap there should be between chunks.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_TEXT_SPLITTER
- Type:
str - Options:
charactertokenmarkdown_header
- Default:
character - Description: Sets the text splitter for RAG models.
- Persistence: This environment variable is a
PersistentConfigvariable.
TIKTOKEN_CACHE_DIR
- Type:
str - Default:
{CACHE_DIR}/tiktoken - Description: Sets the directory for TikToken cache.
TIKTOKEN_ENCODING_NAME
- Type:
str - Default:
cl100k_base - Description: Sets the encoding name for TikToken.
- Persistence: This environment variable is a
PersistentConfigvariable.
PDF_EXTRACT_IMAGES
- Type:
bool - Default:
False - Description: Extracts images from PDFs using OCR when loading documents.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_FILE_MAX_SIZE
- Type:
int - Description: Sets the maximum size of a file in megabytes that can be uploaded for document ingestion.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_FILE_MAX_COUNT
- Type:
int - Description: Sets the maximum number of files that can be uploaded at once for document ingestion.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_ALLOWED_FILE_EXTENSIONS
- Type:
listofstr - Default:
[](which means all supported file types are allowed) - Description: Specifies which file extensions are permitted for upload.
["pdf,docx,txt"]
- Persistence: This environment variable is a
PersistentConfigvariable.
When configuring RAG_FILE_MAX_SIZE and RAG_FILE_MAX_COUNT, ensure that the values are reasonable to prevent excessive file uploads and potential performance issues.
Embedding Engine Configuration
General Embedding Settings
RAG_EMBEDDING_BATCH_SIZE
- Type:
int - Default:
1 - Description: Sets the batch size for embedding in RAG (Retrieval-Augmented Generator) models.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_EMBEDDING_CONTENT_PREFIX
- Type:
str - Default:
None - Description: Specifies the prefix for the RAG embedding content.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_EMBEDDING_PREFIX_FIELD_NAME
- Type:
str - Default:
None - Description: Specifies the field name for the RAG embedding prefix.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_EMBEDDING_QUERY_PREFIX
- Type:
str - Default:
None - Description: Specifies the prefix for the RAG embedding query.
- Persistence: This environment variable is a
PersistentConfigvariable.
OpenAI Embeddings
RAG_OPENAI_API_BASE_URL
- Type:
str - Default:
${OPENAI_API_BASE_URL} - Description: Sets the OpenAI base API URL to use for RAG embeddings.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_OPENAI_API_KEY
- Type:
str - Default:
${OPENAI_API_KEY} - Description: Sets the OpenAI API key to use for RAG embeddings.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_EMBEDDING_OPENAI_BATCH_SIZE
- Type:
int - Default:
1 - Description: Sets the batch size for OpenAI embeddings.
Azure OpenAI Embeddings
RAG_AZURE_OPENAI_BASE_URL
- Type:
str - Default:
None - Description: Sets the base URL for Azure OpenAI Services when using Azure OpenAI for RAG embeddings. Should be in the format
https://{your-resource-name}.openai.azure.com. - Persistence: This environment variable is a
PersistentConfigvariable.
RAG_AZURE_OPENAI_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for Azure OpenAI Services when using Azure OpenAI for RAG embeddings.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_AZURE_OPENAI_API_VERSION
- Type:
str - Default:
None - Description: Sets the API version for Azure OpenAI Services when using Azure OpenAI for RAG embeddings. Common values include
2023-05-15,2023-12-01-preview, or2024-02-01. - Persistence: This environment variable is a
PersistentConfigvariable.
Ollama Embeddings
RAG_OLLAMA_BASE_URL
- Type:
str - Description: Sets the base URL for Ollama API used in RAG models.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_OLLAMA_API_KEY
- Type:
str - Description: Sets the API key for Ollama API used in RAG models.
- Persistence: This environment variable is a
PersistentConfigvariable.
Reranking
RAG_RERANKING_MODEL
- Type:
str - Description: Sets a model for reranking results. Locally, a Sentence-Transformer model is used.
- Persistence: This environment variable is a
PersistentConfigvariable.
Query Generation
ENABLE_RETRIEVAL_QUERY_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables retrieval query generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
QUERY_GENERATION_PROMPT_TEMPLATE
- Type:
str - Default: The value of
DEFAULT_QUERY_GENERATION_PROMPT_TEMPLATEenvironment variable.
DEFAULT_QUERY_GENERATION_PROMPT_TEMPLATE:
### Task:
Analyze the chat history to determine the necessity of generating search queries, in the given language. By default, **prioritize generating 1-3 broad and relevant search queries** unless it is absolutely certain that no additional information is required. The aim is to retrieve comprehensive, updated, and valuable information even with minimal uncertainty. If no search is unequivocally needed, return an empty list.
### Guidelines:
- Respond **EXCLUSIVELY** with a JSON object. Any form of extra commentary, explanation, or additional text is strictly prohibited.
- When generating search queries, respond in the format: { "queries": ["query1", "query2"] }, ensuring each query is distinct, concise, and relevant to the topic.
- If and only if it is entirely certain that no useful results can be retrieved by a search, return: { "queries": [] }.
- Err on the side of suggesting search queries if there is **any chance** they might provide useful or updated information.
- Be concise and focused on composing high-quality search queries, avoiding unnecessary elaboration, commentary, or assumptions.
- Today's date is: {{CURRENT_DATE}}.
- Always prioritize providing actionable and broad queries that maximize informational coverage.
### Output:
Strictly return in JSON format:
{
"queries": ["query1", "query2"]
}
### Chat History:
<chat_history>
{{MESSAGES:END:6}}
</chat_history>
- Description: Sets the prompt template for query generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
Document Intelligence (Azure)
DOCUMENT_INTELLIGENCE_ENDPOINT
- Type:
str - Default:
None - Description: Specifies the endpoint for document intelligence.
- Persistence: This environment variable is a
PersistentConfigvariable.
DOCUMENT_INTELLIGENCE_KEY
- Type:
str - Default:
None - Description: Specifies the key for document intelligence.
- Persistence: This environment variable is a
PersistentConfigvariable.
Advanced Settings
BYPASS_EMBEDDING_AND_RETRIEVAL
- Type:
bool - Default:
False - Description: Bypasses the embedding and retrieval process.
- Persistence: This environment variable is a
PersistentConfigvariable.
RAG_FULL_CONTEXT
- Type:
bool - Default:
False - Description: Specifies whether to use the full context for RAG.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_RAG_LOCAL_WEB_FETCH
- Type:
bool - Default:
False - Description: Enables or disables local web fetch for RAG.
- Persistence: This environment variable is a
PersistentConfigvariable.
Google Drive
ENABLE_GOOGLE_DRIVE_INTEGRATION
- Type:
bool - Default:
False - Description: Enables or disables Google Drive integration. If set to true, and
GOOGLE_DRIVE_CLIENT_ID&GOOGLE_DRIVE_API_KEYare both configured, Google Drive will appear as an upload option in the chat UI. - Persistence: This environment variable is a
PersistentConfigvariable.
When enabling GOOGLE_DRIVE_INTEGRATION, ensure that you have configured GOOGLE_DRIVE_CLIENT_ID and GOOGLE_DRIVE_API_KEY correctly, and have reviewed Google's terms of service and usage guidelines.
GOOGLE_DRIVE_CLIENT_ID
- Type:
str - Description: Sets the client ID for Google Drive (client must be configured with Drive API and Picker API enabled).
- Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_DRIVE_API_KEY
- Type:
str - Description: Sets the API key for Google Drive integration.
- Persistence: This environment variable is a
PersistentConfigvariable.
OneDrive
For a step-by-step setup guide, check out our tutorial: Configuring OneDrive & SharePoint Integration.
ENABLE_ONEDRIVE_INTEGRATION
- Type:
bool - Default:
False - Description: Enables or disables the Microsoft OneDrive integration feature globally.
- Persistence: This environment variable is a
PersistentConfigvariable.
Configuring OneDrive integration is a multi-step process that requires creating and correctly configuring an Azure App Registration. The authentication flow also depends on a browser pop-up window. Please ensure that your browser's pop-up blocker is disabled for your Open WebUI domain to allow the authentication and file selection window to appear.
ENABLE_ONEDRIVE_PERSONAL
- Type:
bool - Default:
True - Description: Controls whether the "Personal OneDrive" option appears in the attachment menu. Requires
ONEDRIVE_PERSONAL_CLIENT_IDto be configured. - Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_ONEDRIVE_BUSINESS
- Type:
bool - Default:
True - Description: Controls whether the "Work/School OneDrive" option appears in the attachment menu. Requires
ONEDRIVE_CLIENT_IDto be configured. - Persistence: This environment variable is a
PersistentConfigvariable.
ONEDRIVE_CLIENT_ID
- Type:
str - Default:
None - Description: Generic environment variable for the OneDrive Client ID. You should rather use the specific
ONEDRIVE_CLIENT_ID_PERSONALorONEDRIVE_CLIENT_ID_BUSINESSvariables. This exists as a legacy option for backwards compatibility.
ONEDRIVE_CLIENT_ID_PERSONAL
- Type:
str - Default:
None - Description: Specifies the Application (client) ID for the Personal OneDrive integration. This requires a separate Azure App Registration configured to support personal Microsoft accounts. Do not put the business OneDrive client ID here!
ONEDRIVE_CLIENT_ID_BUSINESS
- Type:
str - Default:
None - Description: Specifies the Application (client) ID for the Work/School (Business) OneDrive integration. This requires a separate Azure App Registration configured to support personal Microsoft accounts. Do not put the personal OneDrive client ID here!
This Client ID (also known as Application ID) is obtained from an Azure App Registration within your Microsoft Entra ID (formerly Azure AD) tenant. When configuring the App Registration in Azure, the Redirect URI must be set to the URL of your Open WebUI instance and configured as a Single-page application (SPA) type for the authentication to succeed.
ONEDRIVE_SHAREPOINT_URL
- Type:
str - Default:
None - Description: Specifies the root SharePoint site URL for the work/school integration, e.g.,
https://companyname.sharepoint.com. - Persistence: This environment variable is a
PersistentConfigvariable.
This variable is essential for the work/school integration. It should point to the root SharePoint site associated with your tenant, enabling access to SharePoint document libraries.
ONEDRIVE_SHAREPOINT_TENANT_ID
- Type:
str - Default:
None - Description: Specifies the Directory (tenant) ID for the work/school integration. This is obtained from your business-focused Azure App Registration.
- Persistence: This environment variable is a
PersistentConfigvariable.
This Tenant ID (also known as Directory ID) is required for the work/school integration. You can find this value on the main overview page of your Azure App Registration in the Microsoft Entra ID portal.
Web Search
ENABLE_WEB_SEARCH
- Type:
bool - Default:
False - Description: Enable web search toggle.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_SEARCH_QUERY_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables search query generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
WEB_SEARCH_TRUST_ENV
- Type:
bool - Default:
False - Description: Enables proxy set by
http_proxyandhttps_proxyduring web search content fetching. - Persistence: This environment variable is a
PersistentConfigvariable.
WEB_SEARCH_RESULT_COUNT
- Type:
int - Default:
3 - Description: Maximum number of search results to crawl.
- Persistence: This environment variable is a
PersistentConfigvariable.
WEB_LOADER_CONCURRENT_REQUESTS
- Type:
int - Default:
10 - Description: Specifies the number of concurrent requests used by the web loader to fetch content from web pages returned by search results. This directly impacts how many pages can be crawled simultaneously.
- Persistence: This environment variable is a
PersistentConfigvariable.
This environment variable was previously named "WEB_SEARCH_CONCURRENT_REQUESTS". If you were using the old name, please update your configurations to use "WEB_LOADER_CONCURRENT_REQUESTS" as the old variable name is now deprecated and will not be recognized. This renaming clarifies its function, as it specifically controls the concurrency of the web loader component that fetches content from search results, not the initial search engine query itself.
WEB_SEARCH_ENGINE
- Type:
str - Options:
searxng- Uses the SearXNG search engine.google_pse- Uses the Google Programmable Search Engine.brave- Uses the Brave search engine.kagi- Uses the Kagi search engine.mojeek- Uses the Mojeek search engine.bocha- Uses the Bocha search engine.serpstack- Uses the Serpstack search engine.serper- Uses the Serper search engine.serply- Uses the Serply search engine.searchapi- Uses the SearchAPI search engine.serpapi- Uses the SerpApi search engine.duckduckgo- Uses the DuckDuckGo search engine.tavily- Uses the Tavily search engine.jina- Uses the Jina search engine.bing- Uses the Bing search engine.exa- Uses the Exa search engine.perplexity- Uses the Perplexity API to access perplexity's AI models. Calls their AI models, which execute a search and also return a full response.perplexity_search- Uses the Perplexity Search API search engine. In contrast to theperplexityoption, this uses Perplexity's web search API for searching the web and retrieving results.sougou- Uses the Sougou search engine.ollama_cloud- Uses the Ollama Cloud search engine.
- Persistence: This environment variable is a
PersistentConfigvariable.
BYPASS_WEB_SEARCH_EMBEDDING_AND_RETRIEVAL
- Type:
bool - Default:
False - Description: Bypasses the web search embedding and retrieval process.
- Persistence: This environment variable is a
PersistentConfigvariable.
SEARXNG_QUERY_URL
- Type:
str - Description: The SearXNG search API URL supporting JSON output.
<query>is replaced with the search query. Example:http://searxng.local/search?q=<query> - Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_PSE_API_KEY
- Type:
str - Description: Sets the API key for the Google Programmable Search Engine (PSE) service.
- Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_PSE_ENGINE_ID
- Type:
str - Description: The engine ID for the Google Programmable Search Engine (PSE) service.
- Persistence: This environment variable is a
PersistentConfigvariable.
BRAVE_SEARCH_API_KEY
- Type:
str - Description: Sets the API key for the Brave Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
KAGI_SEARCH_API_KEY
- Type:
str - Description: Sets the API key for Kagi Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
MOJEEK_SEARCH_API_KEY
- Type:
str - Description: Sets the API key for Mojeek Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPSTACK_API_KEY
- Type:
str - Description: Sets the API key for Serpstack search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPSTACK_HTTPS
- Type:
bool - Default:
True - Description: Configures the use of HTTPS for Serpstack requests. Free tier requests are restricted to HTTP only.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPER_API_KEY
- Type:
str - Description: Sets the API key for Serper search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPLY_API_KEY
- Type:
str - Description: Sets the API key for Serply search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
SEARCHAPI_API_KEY
- Type:
str - Description: Sets the API key for SearchAPI.
- Persistence: This environment variable is a
PersistentConfigvariable.
SEARCHAPI_ENGINE
- Type:
str - Description: Sets the SearchAPI engine.
- Persistence: This environment variable is a
PersistentConfigvariable.
TAVILY_API_KEY
- Type:
str - Description: Sets the API key for Tavily search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
JINA_API_KEY
- Type:
str - Description: Sets the API key for Jina.
- Persistence: This environment variable is a
PersistentConfigvariable.
BING_SEARCH_V7_ENDPOINT
- Type:
str - Description: Sets the endpoint for Bing Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
BING_SEARCH_V7_SUBSCRIPTION_KEY
- Type:
str - Default:
https://api.bing.microsoft.com/v7.0/search - Description: Sets the subscription key for Bing Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
BOCHA_SEARCH_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for Bocha Search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
EXA_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for Exa search API.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPAPI_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for SerpAPI.
- Persistence: This environment variable is a
PersistentConfigvariable.
SERPAPI_ENGINE
- Type:
str - Default:
None - Description: Specifies the search engine to use for SerpAPI.
- Persistence: This environment variable is a
PersistentConfigvariable.
SOUGOU_API_SID
- Type:
str - Default:
None - Description: Sets the Sogou API SID.
- Persistence: This environment variable is a
PersistentConfigvariable.
SOUGOU_API_SK
- Type:
str - Default:
None - Description: Sets the Sogou API SK.
- Persistence: This environment variable is a
PersistentConfigvariable.
OLLAMA_CLOUD_WEB_SEARCH_API_KEY
- Type:
str - Default:
None - Description: Sets the Ollama Cloud Web Search API Key.
- Persistence: This environment variable is a
PersistentConfigvariable.
TAVILY_EXTRACT_DEPTH
- Type:
str - Default:
basic - Description: Specifies the extract depth for Tavily search results.
- Persistence: This environment variable is a
PersistentConfigvariable.
Web Loader Configuration
WEB_LOADER_ENGINE
- Type:
str - Default:
safe_web - Description: Specifies the loader to use for retrieving and processing web content.
- Options:
requests- Uses the Requests module with enhanced error handling.playwright- Uses Playwright for more advanced web page rendering and interaction.
- Persistence: This environment variable is a
PersistentConfigvariable.
When using playwright, you have two options:
- If
PLAYWRIGHT_WS_URIis not set, Playwright with Chromium dependencies will be automatically installed in the Open WebUI container on launch. - If
PLAYWRIGHT_WS_URIis set, Open WebUI will connect to a remote browser instance instead of installing dependencies locally.
PLAYWRIGHT_WS_URL
- Type:
str - Default:
None - Description: Specifies the WebSocket URI of a remote Playwright browser instance. When set, Open WebUI will use this remote browser instead of installing browser dependencies locally. This is particularly useful in containerized environments where you want to keep the Open WebUI container lightweight and separate browser concerns. Example:
ws://playwright:3000 - Persistence: This environment variable is a
PersistentConfigvariable.
Using a remote Playwright browser via PLAYWRIGHT_WS_URL can be beneficial for:
- Reducing the size of the Open WebUI container
- Using a different browser other than the default Chromium
- Connecting to a non-headless (GUI) browser
FIRECRAWL_API_BASE_URL
- Type:
str - Default:
https://api.firecrawl.dev - Description: Sets the base URL for Firecrawl API.
- Persistence: This environment variable is a
PersistentConfigvariable.
FIRECRAWL_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for Firecrawl API.
- Persistence: This environment variable is a
PersistentConfigvariable.
PERPLEXITY_API_KEY
- Type:
str - Default:
None - Description: Sets the API key for Perplexity API.
- Persistence: This environment variable is a
PersistentConfigvariable.
PLAYWRIGHT_TIMEOUT
- Type:
int - Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the timeout for Playwright requests.
- Persistence: This environment variable is a
PersistentConfigvariable.
YouTube Loader
YOUTUBE_LOADER_PROXY_URL
- Type:
str - Description: Sets the proxy URL for YouTube loader.
- Persistence: This environment variable is a
PersistentConfigvariable.
YOUTUBE_LOADER_LANGUAGE
- Type:
str - Default:
en - Description: Comma-separated list of language codes to try when fetching YouTube video transcriptions, in priority order.
- Example: If set to
es,de, Spanish transcriptions will be attempted first, then German if Spanish was not available, and lastly English.
Note: If none of the specified languages are available and en was not in your list, the system will automatically try English as a final fallback.
- Persistence: This environment variable is a
PersistentConfigvariable.
Audio
Whisper Speech-to-Text (Local)
WHISPER_MODEL
- Type:
str - Default:
base - Description: Sets the Whisper model to use for Speech-to-Text. The backend used is faster_whisper with quantization to
int8. - Persistence: This environment variable is a
PersistentConfigvariable.
WHISPER_MODEL_DIR
- Type:
str - Default:
${DATA_DIR}/cache/whisper/models - Description: Specifies the directory to store Whisper model files.
WHISPER_VAD_FILTER
- Type:
bool - Default:
False - Description: Specifies whether to apply a Voice Activity Detection (VAD) filter to Whisper Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
WHISPER_MODEL_AUTO_UPDATE
- Type:
bool - Default:
False - Description: Toggles automatic update of the Whisper model.
WHISPER_LANGUAGE
- Type:
str - Default:
None - Description: Specifies the ISO 639-1 language Whisper uses for STT (ISO 639-2 for Hawaiian and Cantonese). Whisper predicts the language by default.
Speech-to-Text (OpenAI)
AUDIO_STT_ENGINE
- Type:
str - Options:
- Leave empty to use the built-in local Whisper engine for Speech-to-Text.
openai- Uses OpenAI engine for Speech-to-Text.deepgram- Uses Deepgram engine for Speech-to-Text.azureUses Azure engine for Speech-to-Text.
- Description: Specifies the Speech-to-Text engine to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_STT_MODEL
- Type:
str - Default:
whisper-1 - Description: Specifies the Speech-to-Text model to use for OpenAI-compatible endpoints.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_STT_OPENAI_API_BASE_URL
- Type:
str - Default:
${OPENAI_API_BASE_URL} - Description: Sets the OpenAI-compatible base URL to use for Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_STT_OPENAI_API_KEY
- Type:
str - Default:
${OPENAI_API_KEY} - Description: Sets the OpenAI API key to use for Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
Speech-to-Text (Azure)
AUDIO_STT_AZURE_API_KEY
- Type:
str - Default:
None - Description: Specifies the Azure API key to use for Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_STT_AZURE_REGION
- Type:
str - Default:
None - Description: Specifies the Azure region to use for Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_STT_AZURE_LOCALES
- Type:
str - Default:
None - Description: Specifies the locales to use for Azure Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
Speech-to-Text (Deepgram)
DEEPGRAM_API_KEY
- Type:
str - Default:
None - Description: Specifies the Deepgram API key to use for Speech-to-Text.
- Persistence: This environment variable is a
PersistentConfigvariable.
Text-to-Speech
AUDIO_TTS_API_KEY
- Type:
str - Description: Sets the API key for Text-to-Speech.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_ENGINE
- Type:
str - Options:
- Leave empty to use the built-in WebAPI engine for Text-to-Speech.
azure- Uses Azure engine for Text-to-Speech.elevenlabs- Uses ElevenLabs engine for Text-to-Speechopenai- Uses OpenAI engine for Text-to-Speech.transformers- Uses SentenceTransformers for Text-to-Speech.
- Description: Specifies the Text-to-Speech engine to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_MODEL
- Type:
str - Default:
tts-1 - Description: Specifies the OpenAI text-to-speech model to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_VOICE
- Type:
str - Default:
alloy - Description: Sets the OpenAI text-to-speech voice to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_SPLIT_ON
- Type:
str - Default:
punctuation - Description: Sets the OpenAI text-to-speech split on to use.
- Persistence: This environment variable is a
PersistentConfigvariable.
Azure Text-to-Speech
AUDIO_TTS_AZURE_SPEECH_REGION
- Type:
str - Description: Sets the region for Azure Text to Speech.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_AZURE_SPEECH_OUTPUT_FORMAT
- Type:
str - Description: Sets the output format for Azure Text to Speech.
- Persistence: This environment variable is a
PersistentConfigvariable.
OpenAI Text-to-Speech
AUDIO_TTS_OPENAI_API_BASE_URL
- Type:
str - Default:
${OPENAI_API_BASE_URL} - Description: Sets the OpenAI-compatible base URL to use for text-to-speech.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUDIO_TTS_OPENAI_API_KEY
- Type:
str - Default:
${OPENAI_API_KEY} - Description: Sets the API key to use for text-to-speech.
- Persistence: This environment variable is a
PersistentConfigvariable.
Image Generation
IMAGE_GENERATION_ENGINE
- Type:
str - Options:
openai- Uses OpenAI DALL-E for image generation.comfyui- Uses ComfyUI engine for image generation.automatic1111- Uses AUTOMATIC1111 engine for image generation.gemini- Uses Gemini for image generation.
- Default:
openai - Description: Specifies the engine to use for image generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_IMAGE_GENERATION
- Type:
bool - Default:
False - Description: Enables or disables image generation features.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_IMAGE_PROMPT_GENERATION
- Type:
bool - Default:
True - Description: Enables or disables image prompt generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGE_PROMPT_GENERATION_PROMPT_TEMPLATE
- Type:
str - Default:
None - Description: Specifies the template to use for generating image prompts.
- Persistence: This environment variable is a
PersistentConfigvariable.
DEFAULT_IMAGE_PROMPT_GENERATION_PROMPT_TEMPLATE:
### Task:
Generate a detailed prompt for am image generation task based on the given language and context. Describe the image as if you were explaining it to someone who cannot see it. Include relevant details, colors, shapes, and any other important elements.
### Guidelines:
- Be descriptive and detailed, focusing on the most important aspects of the image.
- Avoid making assumptions or adding information not present in the image.
- Use the chat's primary language; default to English if multilingual.
- If the image is too complex, focus on the most prominent elements.
### Output:
Strictly return in JSON format:
{
"prompt": "Your detailed description here."
}
### Chat History:
<chat_history>
{{MESSAGES:END:6}}
</chat_history>
IMAGE_SIZE
- Type:
str - Default:
512x512 - Description: Sets the default image size to generate.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGE_STEPS
- Type:
int - Default:
50 - Description: Sets the default iteration steps for image generation. Used for ComfyUI and AUTOMATIC1111.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGE_GENERATION_MODEL
- Type:
str - Description: Default model to use for image generation
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOMATIC1111
AUTOMATIC1111_BASE_URL
- Type:
str - Description: Specifies the URL to AUTOMATIC1111's Stable Diffusion API.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOMATIC1111_API_AUTH
- Type:
str - Description: Sets the AUTOMATIC1111 API authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOMATIC1111_CFG_SCALE
- Type:
float - Description: Sets the scale for AUTOMATIC1111 inference.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOMATIC1111_SAMPLER
- Type:
str - Description: Sets the sampler for AUTOMATIC1111 inference.
- Persistence: This environment variable is a
PersistentConfigvariable.
AUTOMATIC1111_SCHEDULER
- Type:
str - Description: Sets the scheduler for AUTOMATIC1111 inference.
- Persistence: This environment variable is a
PersistentConfigvariable.
ComfyUI
COMFYUI_BASE_URL
- Type:
str - Description: Specifies the URL to the ComfyUI image generation API.
- Persistence: This environment variable is a
PersistentConfigvariable.
COMFYUI_API_KEY
- Type:
str - Description: Sets the API key for ComfyUI.
- Persistence: This environment variable is a
PersistentConfigvariable.
COMFYUI_WORKFLOW
- Type:
str - Default:
{
"3": {
"inputs": {
"seed": 0,
"steps": 20,
"cfg": 8,
"sampler_name": "euler",
"scheduler": "normal",
"denoise": 1,
"model": [
"4",
0
],
"positive": [
"6",
0
],
"negative": [
"7",
0
],
"latent_image": [
"5",
0
]
},
"class_type": "KSampler",
"_meta": {
"title": "KSampler"
}
},
"4": {
"inputs": {
"ckpt_name": "model.safetensors"
},
"class_type": "CheckpointLoaderSimple",
"_meta": {
"title": "Load Checkpoint"
}
},
"5": {
"inputs": {
"width": 512,
"height": 512,
"batch_size": 1
},
"class_type": "EmptyLatentImage",
"_meta": {
"title": "Empty Latent Image"
}
},
"6": {
"inputs": {
"text": "Prompt",
"clip": [
"4",
1
]
},
"class_type": "CLIPTextEncode",
"_meta": {
"title": "CLIP Text Encode (Prompt)"
}
},
"7": {
"inputs": {
"text": "",
"clip": [
"4",
1
]
},
"class_type": "CLIPTextEncode",
"_meta": {
"title": "CLIP Text Encode (Prompt)"
}
},
"8": {
"inputs": {
"samples": [
"3",
0
],
"vae": [
"4",
2
]
},
"class_type": "VAEDecode",
"_meta": {
"title": "VAE Decode"
}
},
"9": {
"inputs": {
"filename_prefix": "ComfyUI",
"images": [
"8",
0
]
},
"class_type": "SaveImage",
"_meta": {
"title": "Save Image"
}
}
}
- Description: Sets the ComfyUI workflow.
- Persistence: This environment variable is a
PersistentConfigvariable.
Gemini
GEMINI_API_BASE_URL
- Type:
str - Default:
None - Description: Specifies the URL to Gemini's API.
- Persistence: This environment variable is a
PersistentConfigvariable.
GEMINI_API_KEY
- Type:
str - Default:
None - Description: Sets the Gemini API key.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGES_GEMINI_API_BASE_URL
- Type:
str - Default:
None - Description: Specifies the URL to Gemini's image generation API.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGES_GEMINI_API_KEY
- Type:
str - Default:
None - Description: Sets the Gemini API key for image generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
OpenAI DALL-E
IMAGES_OPENAI_API_BASE_URL
- Type:
str - Default:
${OPENAI_API_BASE_URL} - Description: Sets the OpenAI-compatible base URL to use for DALL-E image generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
IMAGES_OPENAI_API_VERSION
- Type:
str - Default:
${OPENAI_API_VERSION} - Description: Optional setting. If provided it sets the
api-versionquery parameter when calling the image generation. If the Azure OpenAI service is used, this needs to be configured. - Persistence: This environment variable is a
PersistentConfigvariable.
IMAGES_OPENAI_API_KEY
- Type:
str - Default:
${OPENAI_API_KEY} - Description: Sets the API key to use for DALL-E image generation.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAuth
You can only configure one OAUTH provider at a time. You cannot have two or more OAUTH providers configured simultaneously.
ENABLE_OAUTH_SIGNUP
- Type:
bool - Default:
False - Description: Enables account creation when signing up via OAuth. Distinct from
ENABLE_SIGNUP. - Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_LOGIN_FORM must be set to False when ENABLE_OAUTH_SIGNUP is set to True. Failure to do so will result in the inability to login.
ENABLE_OAUTH_PERSISTENT_CONFIG
- Type:
bool - Default:
True - Description: Controls whether OAuth-related settings are persisted in the database after the first launch.
By default, OAuth configurations are stored in the database and managed via the Admin Panel after the initial setup. Set this variable to False to force Open WebUI to always read OAuth settings from the environment variables on every restart. This is ideal for environments using GitOps or immutable infrastructure where configuration is managed exclusively through external files (e.g., Docker Compose, Kubernetes ConfigMaps).
OAUTH_SUB_CLAIM
- Type:
str - Default:
None - Description: Overrides the default claim used to identify a user's unique ID (
sub) from the OAuth/OIDC provider's user info response. By default, Open WebUI attempts to infer this from the provider's configuration. This variable allows you to explicitly specify which claim to use. For example, if your identity provider uses 'employee_id' as the unique identifier, you would set this variable to 'employee_id'. - Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_MERGE_ACCOUNTS_BY_EMAIL
- Type:
bool - Default:
False - Description: If enabled, merges OAuth accounts with existing accounts using the same email address. This is considered unsafe as not all OAuth providers will verify email addresses and can lead to potential account takeovers.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_OAUTH_WITHOUT_EMAIL
- Type:
bool - Default:
False - Description: Enables authentication with OpenID Connect (OIDC) providers that do not support or expose an email scope. When enabled, Open WebUI will create and manage user accounts without requiring an email address from the OAuth provider.
- Persistence: This environment variable is a
PersistentConfigvariable.
Use with Caution
Enabling this option bypasses email-based user identification, which is the standard method for uniquely identifying users across authentication systems. When enabled:
- User accounts will be created using the
subclaim (or the claim specified inOAUTH_SUB_CLAIM) as the primary identifier - Email-based features such as password recovery, email notifications, and account merging via
OAUTH_MERGE_ACCOUNTS_BY_EMAILwill not function properly - Ensure your OIDC provider's
subclaim is stable and unique to prevent authentication conflicts
Only enable this if your identity provider does not support email scope and you have alternative user identification mechanisms in place.
This setting is designed for enterprise environments using identity providers that:
- Use employee IDs, usernames, or other non-email identifiers as the primary user claim
- Have privacy policies that prevent sharing email addresses via OAuth
- Operate in air-gapped or highly restricted networks where email-based services are unavailable
For most standard OAuth providers (Google, Microsoft, GitHub, etc.), this setting should remain False.
OAUTH_UPDATE_PICTURE_ON_LOGIN
- Type:
bool - Default:
False - Description: If enabled, updates the local user profile picture with the OAuth-provided picture on login.
- Persistence: This environment variable is a
PersistentConfigvariable.
If the OAuth picture claim is disabled by setting OAUTH_PICTURE_CLAIM to '' (empty string), then setting this variable to true will not update the user profile pictures.
ENABLE_OAUTH_ID_TOKEN_COOKIE
- Type:
bool - Default:
True - Description: Controls whether the legacy
oauth_id_tokencookie (unsafe, not recommended, token can go stale/orphaned) is set in the browser upon a successful OAuth login. This is provided for backward compatibility with custom tools or older versions that might rely on scraping this cookie. The new, recommended approach is to use the server-side session management. - Usage: For new and secure deployments, it is recommended to set this to
Falseto minimize the information exposed to the client-side. Keep it asTrueonly if you have integrations that depend on the old cookie-based method.
OAUTH_CLIENT_INFO_ENCRYPTION_KEY
- Type:
str - Default: Falls back to the value of
WEBUI_SECRET_KEY. - Description: Specifies the secret key used to encrypt and decrypt OAuth client tokens stored server-side in the database. This is a critical security component for OAuth client tokens. If not set, it defaults to using the main
WEBUI_SECRET_KEY, but it is highly recommended to set it to a unique, securely generated value for production environments.OAUTH_CLIENT_INFO_ENCRYPTION_KEYis used in conjunction with OAuth 2.1 MCP server authentication.
OAUTH_SESSION_TOKEN_ENCRYPTION_KEY
- Type:
str - Default: Falls back to the value of
WEBUI_SECRET_KEY. - Description: Specifies the secret key used to encrypt and decrypt OAuth tokens stored server-side in the database. This is a critical security component for protecting user credentials at rest. If not set, it defaults to using the main
WEBUI_SECRET_KEY, but it is highly recommended to set it to a unique, securely generated value for production environments.
Required for Multi-Replica Deployments In any production environment running more than one instance of Open WebUI (e.g., Docker Swarm, Kubernetes), this variable MUST be explicitly set to a persistent, shared secret. If left unset, each replica will generate or use a different key, causing session decryption to fail intermittently as user requests are load-balanced across instances.
WEBUI_AUTH_TRUSTED_EMAIL_HEADER
- Type:
str - Description: Defines the trusted request header for authentication. See SSO docs.
WEBUI_AUTH_TRUSTED_NAME_HEADER
- Type:
str - Description: Defines the trusted request header for the username of anyone registering with the
WEBUI_AUTH_TRUSTED_EMAIL_HEADERheader. See SSO docs.
WEBUI_AUTH_TRUSTED_GROUPS_HEADER
- Type:
str - Description: Defines the trusted request header containing a comma-separated list of group memberships for the user when using trusted header authentication. See SSO docs.
Google
See https://support.google.com/cloud/answer/6158849?hl=en
You must also set OPENID_PROVIDER_URL or otherwise logout may not work.
GOOGLE_CLIENT_ID
- Type:
str - Description: Sets the client ID for Google OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_CLIENT_SECRET
- Type:
str - Description: Sets the client secret for Google OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_OAUTH_SCOPE
- Type:
str - Default:
openid email profile - Description: Sets the scope for Google OAuth authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
GOOGLE_REDIRECT_URI
- Type:
str - Default:
<backend>/oauth/google/callback - Description: Sets the redirect URI for Google OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
Microsoft
See https://learn.microsoft.com/en-us/entra/identity-platform/quickstart-register-app
You must also set OPENID_PROVIDER_URL or otherwise logout may not work.
MICROSOFT_CLIENT_ID
- Type:
str - Description: Sets the client ID for Microsoft OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
MICROSOFT_CLIENT_SECRET
- Type:
str - Description: Sets the client secret for Microsoft OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
MICROSOFT_CLIENT_TENANT_ID
- Type:
str - Description: Sets the tenant ID for Microsoft OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
MICROSOFT_OAUTH_SCOPE
- Type:
str - Default:
openid email profile - Description: Sets the scope for Microsoft OAuth authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
MICROSOFT_REDIRECT_URI
- Type:
str - Default:
<backend>/oauth/microsoft/callback - Description: Sets the redirect URI for Microsoft OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
GitHub
See https://docs.github.com/en/apps/oauth-apps/building-oauth-apps/authorizing-oauth-apps
You must also set OPENID_PROVIDER_URL or otherwise logout may not work.
GITHUB_CLIENT_ID
- Type:
str - Description: Sets the client ID for GitHub OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
GITHUB_CLIENT_SECRET
- Type:
str - Description: Sets the client secret for GitHub OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
GITHUB_CLIENT_SCOPE
- Type:
str - Default:
user:email - Description: Specifies the scope for GitHub OAuth authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
GITHUB_CLIENT_REDIRECT_URI
- Type:
str - Default:
<backend>/oauth/github/callback - Description: Sets the redirect URI for GitHub OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
Feishu
See https://open.feishu.cn/document/sso/web-application-sso/login-overview
FEISHU_CLIENT_ID
- Type:
str - Description: Sets the client ID for Feishu OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
FEISHU_CLIENT_SECRET
- Type:
str - Description: Sets the client secret for Feishu OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
FEISHU_CLIENT_SCOPE
- Type:
str - Default:
contact:user.base:readonly - Description: Specifies the scope for Feishu OAuth authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
FEISHU_CLIENT_REDIRECT_URI
- Type:
str - Description: Sets the redirect URI for Feishu OAuth.
- Persistence: This environment variable is a
PersistentConfigvariable.
OpenID (OIDC)
OAUTH_CLIENT_ID
- Type:
str - Description: Sets the client ID for OIDC.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_CLIENT_SECRET
- Type:
str - Description: Sets the client secret for OIDC.
- Persistence: This environment variable is a
PersistentConfigvariable.
OPENID_PROVIDER_URL
- Type:
str - Description: Path to the
.well-known/openid-configurationendpoint - Persistence: This environment variable is a
PersistentConfigvariable.
The environment variable OPENID_PROVIDER_URL MUST be configured, otherwise the logout functionality will not work for most providers.
Even when using Microsoft, GitHub or other providers, you MUST set the OPENID_PROVIDER_URL environment variable.
OPENID_REDIRECT_URI
- Type:
str - Default:
<backend>/oauth/oidc/callback - Description: Sets the redirect URI for OIDC
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_SCOPES
- Type:
str - Default:
openid email profile - Description: Sets the scope for OIDC authentication.
openidandemailare required. - Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_CODE_CHALLENGE_METHOD
- Type:
str - Options:
S256- Hashcode_verifierwith SHA-256.
- Default: Empty string (' '), since
Noneis set as default. - Description: Specifies the code challenge method for OAuth authentication. Set to
S256when PKCE is required by the provider. - Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_PROVIDER_NAME
- Type:
str - Default:
SSO - Description: Sets the name for the OIDC provider.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_USERNAME_CLAIM
- Type:
str - Default:
name - Description: Set username claim for OpenID.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_EMAIL_CLAIM
- Type:
str - Default:
email - Description: Set email claim for OpenID.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_PICTURE_CLAIM
- Type:
str - Default:
picture - Description: Set picture (avatar) claim for OpenID.
- Persistence: This environment variable is a
PersistentConfigvariable.
If OAUTH_PICTURE_CLAIM is set to '' (empty string), then the OAuth picture claim is disabled and the user profile pictures will not be saved.
OAUTH_GROUP_CLAIM
- Type:
str - Default:
groups - Description: Specifies the group claim for OAuth authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_OAUTH_ROLE_MANAGEMENT
- Type:
bool - Default:
False - Description: Enables role management for OAuth delegation.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_OAUTH_GROUP_MANAGEMENT
- Type:
bool - Default:
False - Description: Enables or disables OAuth group management.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_ROLES_CLAIM
- Type:
str - Default:
roles - Description: Sets the roles claim to look for in the OIDC token.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_ALLOWED_ROLES
- Type:
str - Default:
user,admin - Description: Sets the roles that are allowed access to the platform.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_ADMIN_ROLES
- Type:
str - Default:
admin - Description: Sets the roles that are considered administrators.
- Persistence: This environment variable is a
PersistentConfigvariable.
OAUTH_ALLOWED_DOMAINS
- Type:
str - Default:
* - Description: Specifies the allowed domains for OAuth authentication. (e.g., "example1.com,example2.com").
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP
ENABLE_LDAP
- Type:
bool - Default:
False - Description: Enables or disables LDAP authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SERVER_LABEL
- Type:
str - Description: Sets the label of the LDAP server.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SERVER_HOST
- Type:
str - Default:
localhost - Description: Sets the hostname of the LDAP server.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SERVER_PORT
- Type:
int - Default:
389 - Description: Sets the port number of the LDAP server.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_ATTRIBUTE_FOR_MAIL
- Type:
str - Description: Sets the attribute to use as mail for LDAP authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_ATTRIBUTE_FOR_USERNAME
- Type:
str - Description: Sets the attribute to use as a username for LDAP authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_APP_DN
- Type:
str - Description: Sets the distinguished name for the LDAP application.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_APP_PASSWORD
- Type:
str - Description: Sets the password for the LDAP application.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SEARCH_BASE
- Type:
str - Description: Sets the base to search for LDAP authentication.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SEARCH_FILTER
- Type:
str - Default:
None - Description: Sets a single filter to use for LDAP search. Alternative to
LDAP_SEARCH_FILTERS. - Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_SEARCH_FILTERS
- Type:
str - Description: Sets the filter to use for LDAP search.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_USE_TLS
- Type:
bool - Default:
True - Description: Enables or disables TLS for LDAP connection.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_CA_CERT_FILE
- Type:
str - Description: Sets the path to the LDAP CA certificate file.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_VALIDATE_CERT
- Type:
bool - Description: Sets whether to validate the LDAP CA certificate.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_CIPHERS
- Type:
str - Default:
ALL - Description: Sets the ciphers to use for LDAP connection.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_LDAP_GROUP_MANAGEMENT
- Type:
bool - Default:
False - Description: Enables the group management feature.
- Persistence: This environment variable is a
PersistentConfigvariable.
ENABLE_LDAP_GROUP_CREATION
- Type:
bool - Default:
False - Description: If a group from LDAP does not exist in Open WebUI, it will be created automatically.
- Persistence: This environment variable is a
PersistentConfigvariable.
LDAP_ATTRIBUTE_FOR_GROUPS
- Type:
str - Default:
memberOf - Description: Specifies the LDAP attribute that contains the user's group memberships.
memberOfis a standard attribute for this purpose in Active Directory environments. - Persistence: This environment variable is a
PersistentConfigvariable.
SCIM
SCIM_ENABLED
- Type:
bool - Default:
False - Description: Enables or disables SCIM 2.0 (System for Cross-domain Identity Management) support for automated user and group provisioning from identity providers like Okta, Azure AD, and Google Workspace.
- Persistence: This environment variable is a
PersistentConfigvariable.
SCIM_TOKEN
- Type:
str - Default:
"" - Description: Sets the bearer token for SCIM authentication. This token must be provided by identity providers when making SCIM API requests. Generate a secure random token (e.g., using
openssl rand -base64 32) and configure it in both Open WebUI and your identity provider. - Persistence: This environment variable is a
PersistentConfigvariable.
User Permissions
Chat Permissions
USER_PERMISSIONS_CHAT_CONTROLS
- Type:
bool - Default:
True - Description: Acts as a master switch to enable or disable the main "Controls" button and panel in the chat interface. If this is set to False, users will not see the Controls button, and the granular permissions below will have no effect.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_VALVES
- Type:
bool - Default:
True - Description: When
USER_PERMISSIONS_CHAT_CONTROLSis enabled, this setting specifically controls the visibility of the "Valves" section within the chat controls panel.
USER_PERMISSIONS_CHAT_SYSTEM_PROMPT
- Type:
bool - Default:
True - Description: When
USER_PERMISSIONS_CHAT_CONTROLSis enabled, this setting specifically controls the visibility of the customizable "System Prompt" section within the chat controls panel, folders and the user settings.
USER_PERMISSIONS_CHAT_PARAMS
- Type:
bool - Default:
True - Description: When
USER_PERMISSIONS_CHAT_CONTROLSis enabled, this setting specifically controls the visibility of the "Advanced Parameters" section within the chat controls panel.
USER_PERMISSIONS_CHAT_FILE_UPLOAD
- Type:
bool - Default:
True - Description: Enables or disables user permission to upload files to chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_DELETE
- Type:
bool - Default:
True - Description: Enables or disables user permission to delete chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_EDIT
- Type:
bool - Default:
True - Description: Enables or disables user permission to edit chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_DELETE_MESSAGE
- Type:
bool - Default:
True - Description: Enables or disables user permission to delete individual messages within chats. This provides granular control over message deletion capabilities separate from full chat deletion.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_CONTINUE_RESPONSE
- Type:
bool - Default:
True - Description: Enables or disables user permission to continue AI responses. When disabled, users cannot use the "Continue Response" button, which helps prevent potential system prompt leakage through response continuation manipulation.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_REGENERATE_RESPONSE
- Type:
bool - Default:
True - Description: Enables or disables user permission to regenerate AI responses. Controls access to both the standard regenerate button and the guided regeneration menu.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_RATE_RESPONSE
- Type:
bool - Default:
True - Description: Enables or disables user permission to rate AI responses using the thumbs up/down feedback system. This controls access to the response rating functionality for evaluation and feedback collection.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_STT
- Type:
bool - Default:
True - Description: Enables or disables user permission to use Speech-to-Text in chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_TTS
- Type:
bool - Default:
True - Description: Enables or disables user permission to use Text-to-Speech in chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_CALL
- Type:
str - Default:
True - Description: Enables or disables user permission to make calls in chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_MULTIPLE_MODELS
- Type:
str - Default:
True - Description: Enables or disables user permission to use multiple models in chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_TEMPORARY
- Type:
bool - Default:
True - Description: Enables or disables user permission to create temporary chats.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_CHAT_TEMPORARY_ENFORCED
- Type:
str - Default:
False - Description: Enables or disables enforced temporary chats for users.
- Persistence: This environment variable is a
PersistentConfigvariable.
Feature Permissions
USER_PERMISSIONS_FEATURES_DIRECT_TOOL_SERVERS
- Type:
str - Default:
False - Description: Enables or disables user permission to access direct tool servers.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_FEATURES_WEB_SEARCH
- Type:
str - Default:
True - Description: Enables or disables user permission to use the web search feature.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_FEATURES_IMAGE_GENERATION
- Type:
str - Default:
True - Description: Enables or disables user permission to use the image generation feature.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_FEATURES_CODE_INTERPRETER
- Type:
str - Default:
True - Description: Enables or disables user permission to use code interpreter feature.
- Persistence: This environment variable is a
PersistentConfigvariable.
Workspace Permissions
USER_PERMISSIONS_WORKSPACE_MODELS_ACCESS
- Type:
bool - Default:
False - Description: Enables or disables user permission to access workspace models.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_KNOWLEDGE_ACCESS
- Type:
bool - Default:
False - Description: Enables or disables user permission to access workspace knowledge.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_PROMPTS_ACCESS
- Type:
bool - Default:
False - Description: Enables or disables user permission to access workspace prompts.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_TOOLS_ACCESS
- Type:
bool - Default:
False - Description: Enables or disables user permission to access workspace tools.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_MODELS_ALLOW_PUBLIC_SHARING
- Type:
str - Default:
False - Description: Enables or disables public sharing of workspace models.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_KNOWLEDGE_ALLOW_PUBLIC_SHARING
- Type:
str - Default:
False - Description: Enables or disables public sharing of workspace knowledge.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_PROMPTS_ALLOW_PUBLIC_SHARING
- Type:
str - Default:
False - Description: Enables or disables public sharing of workspace prompts.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_WORKSPACE_TOOLS_ALLOW_PUBLIC_SHARING
- Type:
str - Default:
False - Description: Enables or disables public sharing of workspace tools.
- Persistence: This environment variable is a
PersistentConfigvariable.
USER_PERMISSIONS_NOTES_ALLOW_PUBLIC_SHARING
- Type:
str - Default:
True - Description: Enables or disables public sharing of notes.
Misc Environment Variables
These variables are not specific to Open WebUI but can still be valuable in certain contexts.
Cloud Storage
STORAGE_PROVIDER
- Type:
str - Options:
s3- uses the S3 client library and related environment variables mentioned in Amazon S3 Storagegcs- uses the GCS client library and related environment variables mentioned in Google Cloud Storageazure- uses the Azure client library and related environment variables mentioned in Microsoft Azure Storage
- Default: empty string (' '), which defaults to
local - Description: Sets the storage provider.
Amazon S3 Storage
S3_ACCESS_KEY_ID
- Type:
str - Description: Sets the access key ID for S3 storage.
S3_ADDRESSING_STYLE
- Type:
str - Default:
None - Description: Specifies the addressing style to use for S3 storage (e.g., 'path', 'virtual').
S3_BUCKET_NAME
- Type:
str - Description: Sets the bucket name for S3 storage.
S3_ENDPOINT_URL
- Type:
str - Description: Sets the endpoint URL for S3 storage.
If the endpoint is an S3-compatible provider like MinIO that uses a TLS certificate signed by a private CA, set the environment variable AWS_CA_BUNDLE to the path of your PEM-encoded CA certificates file. See the Amazon SDK Docs for more information.
S3_KEY_PREFIX
- Type:
str - Description: Sets the key prefix for a S3 object.
S3_REGION_NAME
- Type:
str - Description: Sets the region name for S3 storage.
S3_SECRET_ACCESS_KEY
- Type:
str - Description: Sets the secret access key for S3 storage.
S3_USE_ACCELERATE_ENDPOINT
- Type:
str - Default:
False - Description: Specifies whether to use the accelerated endpoint for S3 storage.
S3_ENABLE_TAGGING
- Type:
str - Default:
False - Description: Enables S3 object tagging after uploads for better organization, searching, and integration with file management policies. Always set to
Falsewhen using Cloudflare R2, as R2 does not support object tagging.
Google Cloud Storage
GOOGLE_APPLICATION_CREDENTIALS_JSON
- Type:
str - Description: Contents of Google Application Credentials JSON file.
- Optional - if not provided, credentials will be taken from the environment. User credentials if run locally and Google Metadata server if run on a Google Compute Engine.
- A file can be generated for a service account following this guide.
GCS_BUCKET_NAME
- Type:
str - Description: Sets the bucket name for Google Cloud Storage. Bucket must already exist.
Microsoft Azure Storage
AZURE_STORAGE_ENDPOINT
- Type:
str - Description: Sets the endpoint URL for Azure Storage.
AZURE_STORAGE_CONTAINER_NAME
- Type:
str - Description: Sets the container name for Azure Storage.
AZURE_STORAGE_KEY
- Type:
str - Description: Set the access key for Azure Storage.
- Optional - if not provided, credentials will be taken from the environment. User credentials if run locally and Managed Identity if run in Azure services.
OpenTelemetry Configuration
ENABLE_OTEL
- Type:
bool - Default:
False - Description: Enables or disables OpenTelemetry for observability. When enabled, tracing, metrics, and logging data can be collected and exported to an OTLP endpoint.
ENABLE_OTEL_TRACES
- Type:
bool - Default:
False - Description: Enables or disables OpenTelemetry traces collection and export. This variable works in conjunction with
ENABLE_OTEL.
ENABLE_OTEL_METRICS
- Type:
bool - Default:
False - Description: Enables or disables OpenTelemetry metrics collection and export. This variable works in conjunction with
ENABLE_OTEL.
ENABLE_OTEL_LOGS
- Type:
bool - Default:
False - Description: Enables or disables OpenTelemetry logging export. When enabled, application logs are sent to the configured OTLP endpoint. This variable works in conjunction with
ENABLE_OTEL.
OTEL_EXPORTER_OTLP_ENDPOINT
- Type:
str - Default:
http://localhost:4317 - Description: Specifies the default OTLP (OpenTelemetry Protocol) endpoint for exporting traces, metrics, and logs. This can be overridden for metrics if
OTEL_METRICS_EXPORTER_OTLP_ENDPOINTis set, and for logs ifOTEL_LOGS_EXPORTER_OTLP_ENDPOINTis set.
OTEL_METRICS_EXPORTER_OTLP_ENDPOINT
- Type:
str - Default: Value of
OTEL_EXPORTER_OTLP_ENDPOINT - Description: Specifies the dedicated OTLP endpoint for exporting OpenTelemetry metrics. If not set, it defaults to the value of
OTEL_EXPORTER_OTLP_ENDPOINT. This is useful when separate endpoints for traces and metrics are used.
OTEL_LOGS_EXPORTER_OTLP_ENDPOINT
- Type:
str - Default: Value of
OTEL_EXPORTER_OTLP_ENDPOINT - Description: Specifies the dedicated OTLP endpoint for exporting OpenTelemetry logs. If not set, it defaults to the value of
OTEL_EXPORTER_OTLP_ENDPOINT. This is useful when separate endpoints for logs, traces, and metrics are used.
OTEL_EXPORTER_OTLP_INSECURE
- Type:
bool - Default:
False - Description: If set to
True, the OTLP exporter will use an insecure connection (e.g., HTTP for gRPC) for traces. For metrics, its behavior is governed byOTEL_METRICS_EXPORTER_OTLP_INSECURE, and for logs byOTEL_LOGS_EXPORTER_OTLP_INSECURE.
OTEL_METRICS_EXPORTER_OTLP_INSECURE
- Type:
bool - Default: Value of
OTEL_EXPORTER_OTLP_INSECURE - Description: If set to
True, the OTLP exporter will use an insecure connection for metrics. If not specified, it uses the value ofOTEL_EXPORTER_OTLP_INSECURE.
OTEL_LOGS_EXPORTER_OTLP_INSECURE
- Type:
bool - Default: Value of
OTEL_EXPORTER_OTLP_INSECURE - Description: If set to
True, the OTLP exporter will use an insecure connection for logs. If not specified, it uses the value ofOTEL_EXPORTER_OTLP_INSECURE.
OTEL_SERVICE_NAME
- Type:
str - Default:
open-webui - Description: Sets the service name that will be reported to your OpenTelemetry collector or observability platform. This helps identify your Open WebUI instance.
OTEL_RESOURCE_ATTRIBUTES
- Type:
str - Default: Empty string (' ')
- Description: Allows you to define additional resource attributes to be attached to all telemetry data, in a comma-separated
key1=val1,key2=val2format.
OTEL_TRACES_SAMPLER
- Type:
str - Options:
parentbased_always_on,always_on,always_off,parentbased_always_off, etc. - Default:
parentbased_always_on - Description: Configures the sampling strategy for OpenTelemetry traces. This determines which traces are collected and exported to reduce data volume.
OTEL_BASIC_AUTH_USERNAME
- Type:
str - Default: Empty string (' ')
- Description: Sets the username for basic authentication with the default OTLP endpoint. This applies to traces, and by default, to metrics and logs unless overridden by their specific authentication variables.
OTEL_BASIC_AUTH_PASSWORD
- Type:
str - Default: Empty string (' ')
- Description: Sets the password for basic authentication with the default OTLP endpoint. This applies to traces, and by default, to metrics and logs unless overridden by their specific authentication variables.
OTEL_METRICS_BASIC_AUTH_USERNAME
- Type:
str - Default: Value of
OTEL_BASIC_AUTH_USERNAME - Description: Sets the username for basic authentication specifically for the OTLP metrics endpoint. If not specified, it uses the value of
OTEL_BASIC_AUTH_USERNAME.
OTEL_METRICS_BASIC_AUTH_PASSWORD
- Type:
str - Default: Value of
OTEL_BASIC_AUTH_PASSWORD - Description: Sets the password for basic authentication specifically for the OTLP metrics endpoint. If not specified, it uses the value of
OTEL_BASIC_AUTH_PASSWORD.
OTEL_LOGS_BASIC_AUTH_USERNAME
- Type:
str - Default: Value of
OTEL_BASIC_AUTH_USERNAME - Description: Sets the username for basic authentication specifically for the OTLP logs endpoint. If not specified, it uses the value of
OTEL_BASIC_AUTH_USERNAME.
OTEL_LOGS_BASIC_AUTH_PASSWORD
- Type:
str - Default: Value of
OTEL_BASIC_AUTH_PASSWORD - Description: Sets the password for basic authentication specifically for the OTLP logs endpoint. If not specified, it uses the value of
OTEL_BASIC_AUTH_PASSWORD.
OTEL_OTLP_SPAN_EXPORTER
- Type:
str - Options:
grpc,http - Default:
grpc - Description: Specifies the default protocol for exporting OpenTelemetry traces (gRPC or HTTP). This can be overridden for metrics if
OTEL_METRICS_OTLP_SPAN_EXPORTERis set, and for logs ifOTEL_LOGS_OTLP_SPAN_EXPORTERis set.
OTEL_METRICS_OTLP_SPAN_EXPORTER
- Type:
str - Options:
grpc,http - Default: Value of
OTEL_OTLP_SPAN_EXPORTER - Description: Specifies the protocol for exporting OpenTelemetry metrics (gRPC or HTTP). If not specified, it uses the value of
OTEL_OTLP_SPAN_EXPORTER.
OTEL_LOGS_OTLP_SPAN_EXPORTER
- Type:
str - Options:
grpc,http - Default: Value of
OTEL_OTLP_SPAN_EXPORTER - Description: Specifies the protocol for exporting OpenTelemetry logs (gRPC or HTTP). If not specified, it uses the value of
OTEL_OTLP_SPAN_EXPORTER.
Database Pool
DATABASE_URL
- Type:
str - Default:
sqlite:///${DATA_DIR}/webui.db - Description: Specifies the complete database connection URL, following SQLAlchemy's URL scheme. This variable takes precedence over individual database connection parameters if explicitly set.
For PostgreSQL support, ensure you installed with pip install open-webui[all] instead of the basic installation.
Supports SQLite, Postgres, and encrypted SQLite via SQLCipher.
Changing the URL does not migrate data between databases.
Documentation on the URL scheme is available here.
If your database password contains special characters, please ensure they are properly URL-encoded. For example, a password like p@ssword should be encoded as p%40ssword.
For configuration using individual parameters or encrypted SQLite, see the relevant sections below.
DATABASE_TYPE
- Type:
str - Default:
None(automatically set tosqliteifDATABASE_URLuses default SQLite path) - Description: Specifies the database type (e.g.,
sqlite,postgresql,sqlite+sqlcipher). This is used in conjunction with other individual parameters to construct theDATABASE_URLif a completeDATABASE_URLis not explicitly defined. - Persistence: No
DATABASE_USER
- Type:
str - Default:
None - Description: Specifies the username for database authentication. This is used to construct the
DATABASE_URLwhen a completeDATABASE_URLis not explicitly defined. - Persistence: No
DATABASE_PASSWORD
- Type:
str - Default:
None - Description: Specifies the password for database authentication. This is used to construct the
DATABASE_URLwhen a completeDATABASE_URLis not explicitly defined. If your password contains special characters, please ensure they are properly URL-encoded. - Persistence: No
DATABASE_HOST
- Type:
str - Default:
None - Description: Specifies the hostname or IP address of the database server. This is used to construct the
DATABASE_URLwhen a completeDATABASE_URLis not explicitly defined. - Persistence: No
DATABASE_PORT
- Type:
int - Default:
None - Description: Specifies the port number of the database server. This is used to construct the
DATABASE_URLwhen a completeDATABASE_URLis not explicitly defined. - Persistence: No
DATABASE_NAME
- Type:
str - Default:
None - Description: Specifies the name of the database to connect to. This is used to construct the
DATABASE_URLwhen a completeDATABASE_URLis not explicitly defined. - Persistence: No
When DATABASE_URL is not explicitly set, Open WebUI will attempt to construct it using a combination of DATABASE_TYPE, DATABASE_USER, DATABASE_PASSWORD, DATABASE_HOST, DATABASE_PORT, and DATABASE_NAME. For this automatic construction to occur, all of these individual parameters must be provided. If any are missing, the default DATABASE_URL (SQLite file) or any explicitly set DATABASE_URL will be used instead.
Encrypted SQLite with SQLCipher
For enhanced security, Open WebUI supports at-rest encryption for its primary SQLite database using SQLCipher. This is recommended for deployments handling sensitive data where using a larger database like PostgreSQL is not needed.
To enable encryption, you must configure two environment variables:
- Set
DATABASE_TYPE="sqlite+sqlcipher". - Set
DATABASE_PASSWORD="your-secure-password".
When these are set and a full DATABASE_URL is not explicitly defined, Open WebUI will automatically create and use an encrypted database file at ./data/webui.db.
- The
DATABASE_PASSWORDenvironment variable is required when usingsqlite+sqlcipher. - The
DATABASE_TYPEvariable tells Open WebUI which connection logic to use. Setting it tosqlite+sqlcipheractivates the encryption feature.
Ensure the database password is kept secure, as it is needed to decrypt and access all application data.
DATABASE_SCHEMA
- Type:
str - Default:
None - Description: Specifies the database schema to connect to.
DATABASE_POOL_SIZE
- Type:
int - Default:
None - Description: Specifies the pooling strategy and size of the database pool. By default SQLAlchemy will automatically chose the proper pooling strategy for the selected database connection. A value of
0disables pooling. A value larger0will set the pooling strategy toQueuePooland the pool size accordingly.
DATABASE_POOL_MAX_OVERFLOW
- Type:
int - Default:
0 - Description: Specifies the database pool max overflow.
More information about this setting can be found here.
DATABASE_POOL_TIMEOUT
- Type:
int - Default:
30 - Description: Specifies the database pool timeout in seconds to get a connection.
More information about this setting can be found here.
DATABASE_POOL_RECYCLE
- Type:
int - Default:
3600 - Description: Specifies the database pool recycle time in seconds.
More information about this setting can be found here.
DATABASE_ENABLE_SQLITE_WAL
- Type:
bool - Default:
False - Description: Enables or disables SQLite WAL (Write-Ahead Logging) mode. When enabled, SQLite transactions can be managed more efficiently, allowing multiple readers and one writer concurrently, which can improve database performance, especially under high concurrency. This setting only applies to SQLite databases.
DATABASE_DEDUPLICATE_INTERVAL
- Type:
float - Default:
0.0 - Description: Sets a time interval in seconds during which certain database write operations (e.g., updating a user's
last_active_attimestamp) will be deduplicated. If a write operation is attempted within this interval for the same entity, it will be skipped. A value of0.0disables deduplication. Enabling this can reduce write conflicts and improve performance, but may result in less real-time accuracy for the affected fields.
Redis
REDIS_URL
- Type:
str - Description: Specifies the URL of the Redis instance or cluster host for storing application state.
- Examples:
redis://localhost:6379/0rediss://:password@localhost:6379/0(with password and TLS)rediss://redis-cluster.redis.svc.cluster.local:6379/0 ?ssl_cert_reqs=required&ssl_certfile=/tls/redis/tls.crt &ssl_keyfile=/tls/redis/tls.key&ssl_ca_certs=/tls/redis/ca.crt(with mTLS)
When deploying Open WebUI in a multi-node/worker cluster with a load balancer, you must ensure that the REDIS_URL value is set. Without it, session, persistency and consistency issues in the app state will occur as the workers would be unable to communicate.
REDIS_SENTINEL_HOSTS
- Type:
str - Description: Comma-separated list of Redis Sentinels for app state. If specified, the "hostname" in
REDIS_URLwill be interpreted as the Sentinel service name.
REDIS_SENTINEL_PORT
- Type:
int - Default:
26379 - Description: Sentinel port for app state Redis.
REDIS_CLUSTER
- Type:
bool - Default:
False - Description: Connect to a Redis Cluster instead of a single instance or using Redis Sentinels. If
True,REDIS_URLmust also be defined.
This option has no effect if REDIS_SENTINEL_HOSTS is defined.
REDIS_KEY_PREFIX
- Type:
str - Default:
open-webui - Description: Customizes the Redis key prefix used for storing configuration values. This allows multiple Open WebUI instances to share the same Redis instance without key conflicts. When operating in Redis cluster mode, the prefix is formatted as
{prefix}:(e.g.,{open-webui}:config:*) to enable multi-key operations on configuration keys within the same hash slot.
ENABLE_WEBSOCKET_SUPPORT
- Type:
bool - Default:
True - Description: Enables websocket support in Open WebUI.
When deploying Open WebUI in a multi-node/worker cluster with a load balancer, you must ensure that the ENABLE_WEBSOCKET_SUPPORT value is set. Without it, websocket consistency and persistency issues will occur.
WEBSOCKET_MANAGER
- Type:
str - Default:
redis - Description: Specifies the websocket manager to use (in this case, Redis).
When deploying Open WebUI in a multi-node/worker cluster with a load balancer, you must ensure that the WEBSOCKET_MANAGER value is set and a key-value NoSQL database like Redis is used. Without it, websocket consistency and persistency issues will occur.
WEBSOCKET_REDIS_URL
- Type:
str - Default:
${REDIS_URL} - Description: Specifies the URL of the Redis instance or cluster host for websocket communication. It is distinct from
REDIS_URLand in practice, it is recommended to set both.
When deploying Open WebUI in a multi-node/worker cluster with a load balancer, you must ensure that the WEBSOCKET_REDIS_URL value is set and a key-value NoSQL database like Redis is used. Without it, websocket consistency and persistency issues will occur.
WEBSOCKET_SENTINEL_HOSTS
- Type:
str - Description: Comma-separated list of Redis Sentinels for websocket. If specified, the "hostname" in
WEBSOCKET_REDIS_URLwill be interpreted as the Sentinel service name.
WEBSOCKET_SENTINEL_PORT
- Type:
int - Default:
26379 - Description: Sentinel port for websocket Redis.
WEBSOCKET_REDIS_CLUSTER
- Type:
bool - Default:
${REDIS_CLUSTER} - Description: Specifies that websocket should communicate with a Redis Cluster instead of a single instance or using Redis Sentinels. If
True,WEBSOCKET_REDIS_URLand/orREDIS_URLmust also be defined.
This option has no effect if WEBSOCKET_SENTINEL_HOSTS is defined.
ENABLE_STAR_SESSIONS_MIDDLEWARE
- Type:
bool - Default:
False - Description: Enables Redis-based session storage for OAuth authentication flows using the StarSessions middleware. When enabled, OAuth session state is stored in Redis instead of browser cookies, which can help resolve CSRF errors in multi-replica deployments where session data needs to be shared across pods.
- Persistence: This is an experimental environment variable.
Experimental Feature - Known Limitations
This feature is currently experimental and has known compatibility issues:
- Redis Sentinel and Redis Cluster configurations are not yet supported and will cause authentication failures if this setting is enabled
- Only basic Redis setups (single instance or standard Redis URL) are currently compatible
- This feature was introduced to address CSRF "mismatching_state" errors in multi-pod deployments, but it is disabled by default due to ongoing compatibility work
Only enable this setting if:
- You are experiencing persistent CSRF errors during OAuth login in a multi-replica deployment
- You are using a basic Redis setup (not Sentinel or Cluster)
- You have confirmed that
WEBUI_SECRET_KEYis set to the same value across all replicas - You understand this is an experimental feature that may change or be removed in future releases
For most deployments, the default browser cookie-based session management is sufficient and more stable.
Uvicorn Settings
UVICORN_WORKERS
- Type:
int - Default:
1 - Description: Controls the number of worker processes that Uvicorn spawns to handle requests. Each worker runs its own instance of the application in a separate process.
When deploying in orchestrated environments like Kubernetes or using Helm charts, it's recommended to keep UVICORN_WORKERS set to 1. Container orchestration platforms already provide their own scaling mechanisms through pod replication, and using multiple workers inside containers can lead to resource allocation issues and complicate horizontal scaling strategies.
If you use UVICORN_WORKERS, you also need to ensure that related environment variables for scalable multi-instance setups are set accordingly.
Cache Settings
CACHE_CONTROL
- Type:
str - Default: Not set (no Cache-Control header added)
- Description: Sets the Cache-Control header for all HTTP responses. Supports standard directives like
public,private,no-cache,no-store,must-revalidate,max-age=seconds, etc. If an invalid value is provided, defaults to"no-store, max-age=0"(no caching). - Examples:
"private, max-age=86400"- Cache privately for 24 hours"public, max-age=3600, must-revalidate"- Cache publicly for 1 hour, then revalidate"no-cache, no-store, must-revalidate"- Never cache
Proxy Settings
Open WebUI supports using proxies for HTTP and HTTPS retrievals. To specify proxy settings, Open WebUI uses the following environment variables:
http_proxy
- Type:
str - Description: Sets the URL for the HTTP proxy.
https_proxy
- Type:
str - Description: Sets the URL for the HTTPS proxy.
no_proxy
- Type:
str - Description: Lists domain extensions (or IP addresses) for which the proxy should not be used, separated by commas. For example, setting no_proxy to '.mit.edu' ensures that the proxy is bypassed when accessing documents from MIT.
Install Required Python Packages
Open WebUI provides environment variables to customize the pip installation process. Below are the environment variables used by Open WebUI for adjusting package installation behavior:
PIP_OPTIONS
- Type:
str - Description: Specifies additional command-line options that pip should use when installing packages. For example, you can include flags such as
--upgrade,--user, or--no-cache-dirto control the installation process.
PIP_PACKAGE_INDEX_OPTIONS
- Type:
str - Description: Defines custom package index behavior for pip. This can include specifying additional or alternate index URLs (e.g.,
--extra-index-url), authentication credentials, or other parameters to manage how packages are retrieved from different locations.