mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-06 10:58:17 -05:00
[PR #21066] [CLOSED] fix: web search not working in native FC mode when builtin_tools is disabled #25911
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/21066
Author: @ShikaiChen
Created: 1/31/2026
Status: ❌ Closed
Base:
dev← Head:fix/web-search-native-fc-decoupling📝 Commits (10+)
fe6783cMerge pull request #19030 from open-webui/devfc05e0aMerge pull request #19405 from open-webui/deve3faec6Merge pull request #19416 from open-webui/dev9899293Merge pull request #19448 from open-webui/dev140605eMerge pull request #19462 from open-webui/dev6f1486fMerge pull request #19466 from open-webui/devd95f533Merge pull request #19729 from open-webui/deva7271530.6.43 (#20093)6adde20Merge pull request #20394 from open-webui/devf9b0534Merge pull request #20522 from open-webui/dev📊 Changes
1 file changed (+21 additions, -0 deletions)
View changed files
📝
backend/open_webui/utils/middleware.py(+21 -0)📄 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.
Before submitting, make sure you've checked the following:
devbranch. Not targeting thedevbranch will lead to immediate closure of the PR.get_builtin_tools()to verify onlysearch_webandfetch_urlare kept while 20+ other tools are correctly filtered out.(...get("capabilities") or {})style consistent with surrounding code in dev branch).fix:Changelog Entry
Description
When
builtin_toolscapability is disabled on a model, web search breaks in native function calling (FC) mode — even though web search has its own independentweb_searchcapability toggle.Root cause: In
middleware.py,builtin_tools_enabledgates the entireget_builtin_tools()call. Disablingbuiltin_toolsprevents web search tools (search_web+fetch_url) from being injected into the native FC tool set.Fix: Add an
eliffallback after the existing builtin tools block that injects onlysearch_webandfetch_urlwhen:builtin_toolsis disabledENABLE_WEB_SEARCHconfig is trueweb_searchcapability is not explicitly disabledBehavior matrix
This is an additive-only change (21 new lines, 0 modified lines).
Added
Changed
Deprecated
Removed
Fixed
builtin_toolscapability is disabled on the modelSecurity
Breaking Changes
Additional Information
builtin_toolsis disabled)backend/open_webui/utils/middleware.pyis modifiedelifblock reusesget_builtin_tools()to create tool callables, then filters to onlysearch_webandfetch_urltools.py(line 440)Screenshots or Videos
Setting page:


Fixed:
A Note from Me
Apologies for the earlier closed PRs. This is my first contribution to Open WebUI and I was still figuring out the PR process and template requirements. I really enjoy using this project and would love to be part of the community. Thanks for your patience!
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.
🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.