mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-07 11:28:35 -05:00
[PR #21616] [CLOSED] perf: Eliminate N+1 access grant queries in prompts listing #49212
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/21616
Author: @Classic298
Created: 2/19/2026
Status: ❌ Closed
Base:
dev← Head:perf-prompt-list📝 Commits (1)
ae9e9eeEliminate N+1 access grant queries in prompts listing📊 Changes
2 files changed (+68 additions, -11 deletions)
View changed files
📝
backend/open_webui/models/access_grants.py(+30 -0)📝
backend/open_webui/models/prompts.py(+38 -11)📄 Description
The prompts listing endpoints were calling _get_access_grants() per
prompt (N+1 queries) via _to_prompt_model(). Additionally,
get_prompts_by_user_id() called has_access() per prompt for filtering
(another N+1). Now:
get_grants_by_resources() method on AccessGrants
instead of per-prompt has_access() calls
_to_prompt_model() calls
For 30 prompts this reduces ~31 DB queries to ~3.
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.