mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-07 11:28:35 -05:00
[PR #21003] [CLOSED] perf: resolve N+1 queries in prompts list access control #41507
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/21003
Author: @Classic298
Created: 1/28/2026
Status: ❌ Closed
Base:
dev← Head:prompt-n+1📝 Commits (1)
35f9d59fix: resolve N+1 queries in models and prompts list access control📊 Changes
1 file changed (+6 additions, -1 deletions)
View changed files
📝
backend/open_webui/routers/prompts.py(+6 -1)📄 Description
Summary
Eliminates N+1 database queries in get_models (/models/list) and get_prompt_list (/prompts/list) endpoints. Previously, the has_access function would query the database for user groups on each item in the list.
Changes
routers/models.py
routers/prompts.py
Performance Impact
Before: N+1 queries - Groups.get_groups_by_member_id called once per item
After: 1 query total - reuses groups already fetched for filter construction
The has_access function already supported the user_group_ids parameter to skip the DB lookup, it just wasn't being used in these endpoints.
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.