mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-06 10:58:17 -05:00
[PR #22675] [CLOSED] fix: register memory tools when model declares capabilities.memory #26809
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/22675
Author: @Thump604
Created: 3/14/2026
Status: ❌ Closed
Base:
dev← Head:fix/memory-tools-capability-fallback📝 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 (+1 additions, -1 deletions)
View changed files
📝
backend/open_webui/utils/tools.py(+1 -1)📄 Description
Pull Request Checklist
devfix:Changelog Entry
Description
When a model declares
capabilities.memory: truein its meta config, memory tools (add_memory,search_memories, etc.) should be registered for execution. Without this fix, models with native function calling and memory capability enter a 30-iteration tool retry loop becauseadd_memoryappears in the tool schema but isn't in the execution dict.Root Cause
get_builtin_tools()inutils/tools.pyonly checkedfeatures.get("memory")(per-chat toggle sent by frontend). This could beFalseeven when:capabilities.memory: truefeatures.memory: truefor some chats but not othersThis is inconsistent with how other capabilities like
web_searchandimage_generationare handled elsewhere in the codebase.Changed
backend/open_webui/utils/tools.py:get_builtin_tools()now also checksget_model_capability("memory", False)as a fallback whenfeatures.get("memory")is not setSteps to Reproduce (Before Fix)
capabilities.memory: trueandfunction_calling: nativeadd_memorybut tool is not in execution dict → empty result → 30-iteration retry loopSteps to Verify (After Fix)
add_memorycall → DB row createdsearch_memories→ correct recallFixes #22666
Contributor License Agreement
🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.