You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Note to first-time contributors: Please open a discussion post in Discussions to discuss your idea/fix with the community before creating a pull request, and describe your changes before submitting a pull request.
This is to ensure large feature PRs are discussed with the community first, before starting work on it. If the community does not want this feature or it is not relevant for Open WebUI as a project, it can be identified in the discussion before working on the feature and submitting the PR.
Before submitting, make sure you've checked the following:
Target branch: Verify that the pull request targets the dev branch. Not targeting the dev branch will lead to immediate closure of the PR.
Description: Provide a concise description of the changes made in this pull request down below.
Changelog: Ensure a changelog entry following the format of Keep a Changelog is added at the bottom of the PR description.
Documentation: If necessary, update relevant documentation Open WebUI Docs like environment variables, the tutorials, or other documentation sources.
Dependencies: Are there any new dependencies? Have you updated the dependency versions in the documentation?
Testing: Perform manual tests to verify the implemented fix/feature works as intended AND does not break any other functionality. Take this as an opportunity to make screenshots of the feature/fix and include it in the PR description.
Agentic AI Code: Confirm this Pull Request is not written by any AI Agent or has at least gone through additional human review AND manual testing. If any AI Agent is the co-author of this PR, it may lead to immediate closure of the PR.
Code review: Have you performed a self-review of your code, addressing any coding standard issues and ensuring adherence to the project's coding standards?
Title Prefix: To clearly categorize this pull request, prefix the pull request title using one of the following:
BREAKING CHANGE: Significant changes that may affect compatibility
build: Changes that affect the build system or external dependencies
ci: Changes to our continuous integration processes or workflows
chore: Refactor, cleanup, or other non-functional code changes
docs: Documentation update or addition
feat: Introduces a new feature or enhancement to the codebase
fix: Bug fix or error correction
i18n: Internationalization or localization changes
perf: Performance improvement
refactor: Code restructuring for better maintainability, readability, or scalability
style: Changes that do not affect the meaning of the code (white space, formatting, missing semi-colons, etc.)
test: Adding missing tests or correcting existing tests
WIP: Work in progress, a temporary label for incomplete or ongoing work
Changelog Entry
Description
Add an opt-in OAuth/OIDC profile sync switch for existing users: OAUTH_SYNC_PROFILE_ON_LOGIN (default False).
When enabled, update name and email on login for accounts matched by provider + sub.
By submitting this pull request, I confirm that I have read and fully agree to the Contributor License Agreement (CLA), and I am providing my contributions under its terms.
Note
Deleting the CLA section will lead to immediate closure of your PR and it will not be merged in.
We appreciate you taking the time to submit a pull request to Open WebUI!
⚠️ Important: Testing Requirements
We've recently seen an increase in PRs that have significant issues:
PRs that don't actually fix the bug they claim to fix
PRs that don't implement the feature they describe
PRs that break existing functionality
PRs that are clearly AI-generated without proper testing being done by the author
PRs that simply don't work as intended
These untested PRs consume significant time from maintainers and volunteer contributors who review and test PRs in their free time.
Time that could be spent testing other PRs or improving Open WebUI in other ways.
Before marking your PR as "Ready for Review":
Please explicitly confirm:
✅ You have personally tested ALL changes in this PR
✅ How you tested it (specific steps you took to verify it works)
✅ Visual evidence where applicable (screenshots or videos showing the feature/fix working) - if applicable to your specific PR
If you're not certain your PR works exactly as intended, please leave it in DRAFT mode until you've thoroughly tested it.
Thank you for helping us maintain quality and respecting the time of our community! 🙏
New import AIOHTTP_CLIENT_TIMEOUT_MODEL_LIST introduced
📝 Detailed Analysis and Full Report (click to expand)
This PR touches two completely independent modules for distinct purposes. (1) Audio.py changes add timeout parameters to HTTP requests - this is a fix/optimization to prevent hanging requests in transcription and TTS functions. (2) OAuth.py changes add a new feature to synchronize mutable user profile fields (name/email) when existing users log in via OIDC. These are compound intentions - the Pre-factor test confirms they could have been merged as separate PRs: the OAuth profile sync feature could have been submitted independently, and the audio timeout configuration could have been submitted as a separate fix/optimization. The changes affect different architectural layers (Authentication vs Audio processing) with no technical dependency between them.
Why Atomic PRs With Narrow Scopes Matter
Atomic PRs (single-purpose PRs) are:
Easier to review - Reviewers can focus on one thing at a time
Easier to test - Each change can be verified independently
Easier to revert - If something breaks, we can revert just the problematic change
Faster to merge - Smaller, focused PRs get reviewed and merged quicker
What Makes a PR Atomic / Narrow in Scope?
An atomic PR should contain one semantic change:
✅ Just one bug fix (even if it touches multiple files)
✅ Just one feature (even if it requires changes across multiple files)
✅ Just i18n/translation updates
✅ Just documentation updates
✅ Just refactoring of one specific thing
✅ Just one performance improvement
What To Do
This is an automated analysis. If you believe this assessment is incorrect and your PR is actually atomic (all changes serve one unified purpose), please explain in a comment below.
Consider splitting this PR into separate, focused pull requests. Each PR should address one specific thing.
For example, if you have a bug fix and a new feature, submit them as two separate PRs.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Pull Request Checklist
Note to first-time contributors: Please open a discussion post in Discussions to discuss your idea/fix with the community before creating a pull request, and describe your changes before submitting a pull request.
This is to ensure large feature PRs are discussed with the community first, before starting work on it. If the community does not want this feature or it is not relevant for Open WebUI as a project, it can be identified in the discussion before working on the feature and submitting the PR.
Before submitting, make sure you've checked the following:
devbranch. Not targeting thedevbranch will lead to immediate closure of the PR.Changelog Entry
Description
OAUTH_SYNC_PROFILE_ON_LOGIN(defaultFalse).nameandemailon login for accounts matched by provider +sub.OAUTH_UPDATE_PICTURE_ON_LOGIN).auth.emailwhenuser.emailis synced.Added
OAUTH_SYNC_PROFILE_ON_LOGIN(oauth.sync_profile_on_login, defaultFalse).Changed
OAUTH_SYNC_PROFILE_ON_LOGINis enabled.user.emailandauth.email.Deprecated
Removed
Fixed
Security
Breaking Changes
Additional Information
backend/open_webui/config.pybackend/open_webui/utils/oauth.pypython3 -m py_compile backend/open_webui/config.py backend/open_webui/utils/oauth.pyScreenshots or Videos
Contributor License Agreement
By submitting this pull request, I confirm that I have read and fully agree to the Contributor License Agreement (CLA), and I am providing my contributions under its terms.
Note
Deleting the CLA section will lead to immediate closure of your PR and it will not be merged in.