mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-06 10:58:17 -05:00
[PR #22758] [CLOSED] fix: Persist MCP OAuth client registration and add DCR fallback #49896
Reference in New Issue
Block a user
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
📋 Pull Request Information
Original PR: https://github.com/open-webui/open-webui/pull/22758
Author: @PedroFCM
Created: 3/17/2026
Status: ❌ Closed
Base:
dev← Head:fix/oauth-client-persistence📝 Commits (1)
82a96d6fix: 🐛 Persist MCP OAuth client registration and add DCR fallback📊 Changes
1 file changed (+10 additions, -2 deletions)
View changed files
📝
backend/open_webui/main.py(+10 -2)📄 Description
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. PRs targetingmainwill be immediately closed.devto ensure no unrelated commits (e.g. frommain) are included. Push updates to the existing PR branch instead of closing and reopening.Changelog Entry
Description
Fixes MCP OAuth 2.1 Dynamic Client Registration (DCR) not being persisted to the database, causing users to get a 404 on
/oauth/clients/mcp:<id>/authorize.Discussion: #22756
Related: #20869, #21190
Root cause:
register_client()updatesTOOL_SERVER_CONNECTIONSvia in-place list mutation (config.TOOL_SERVER_CONNECTIONS[idx] = {...}). SinceAppConfig.__getattr__returns the list reference directly, in-place mutation never triggersAppConfig.__setattr__→PersistentConfig.save(). Theoauth_client_infoonly lives in process memory.Impact:
Added
Changed
register_client()now reassignsTOOL_SERVER_CONNECTIONSwith a new list instead of mutating in-place, triggeringAppConfig.__setattr__→PersistentConfig.save()Fixed
oauth_client_infofrom MCP OAuth 2.1 DCR is now persisted to the databaseAdditional Information
main.py, no new dependenciesAppConfigattributes that hold mutable values (lists, dicts) — any code that modifies these in-place without reassigning the attribute will silently fail to persistScreenshots or Videos
Before fix: Non-admin user gets 404 on
/oauth/clients/mcp:gitlab-mcp/authorizeafter admin registers the MCP server.After fix: Non-admin user completes the full OAuth 2.1 flow and can use the MCP tool.
Contributor License Agreement
🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.