diff --git a/backend/open_webui/config.py b/backend/open_webui/config.py index 2d66e37b6..0ac92bd23 100644 --- a/backend/open_webui/config.py +++ b/backend/open_webui/config.py @@ -1029,6 +1029,10 @@ USER_PERMISSIONS_CHAT_TEMPORARY = ( os.environ.get("USER_PERMISSIONS_CHAT_TEMPORARY", "True").lower() == "true" ) +USER_PERMISSIONS_CHAT_TEMPORARY_ENFORCED = ( + os.environ.get("USER_PERMISSIONS_CHAT_TEMPORARY_ENFORCED", "False").lower() + == "true" +) USER_PERMISSIONS_FEATURES_WEB_SEARCH = ( os.environ.get("USER_PERMISSIONS_FEATURES_WEB_SEARCH", "True").lower() == "true" @@ -1064,6 +1068,7 @@ DEFAULT_USER_PERMISSIONS = { "delete": USER_PERMISSIONS_CHAT_DELETE, "edit": USER_PERMISSIONS_CHAT_EDIT, "temporary": USER_PERMISSIONS_CHAT_TEMPORARY, + "temporary_enforced": USER_PERMISSIONS_CHAT_TEMPORARY_ENFORCED, }, "features": { "web_search": USER_PERMISSIONS_FEATURES_WEB_SEARCH, diff --git a/backend/open_webui/routers/users.py b/backend/open_webui/routers/users.py index 825a39723..4cf9102e1 100644 --- a/backend/open_webui/routers/users.py +++ b/backend/open_webui/routers/users.py @@ -89,6 +89,7 @@ class ChatPermissions(BaseModel): delete: bool = True edit: bool = True temporary: bool = True + temporary_enforced: bool = False class FeaturesPermissions(BaseModel): diff --git a/src/lib/components/admin/Users/Groups.svelte b/src/lib/components/admin/Users/Groups.svelte index 89b4141d6..15497cb20 100644 --- a/src/lib/components/admin/Users/Groups.svelte +++ b/src/lib/components/admin/Users/Groups.svelte @@ -52,12 +52,19 @@ prompts: false, tools: false }, + sharing: { + public_models: false, + public_knowledge: false, + public_prompts: false, + public_tools: false + }, chat: { controls: true, file_upload: true, delete: true, edit: true, - temporary: true + temporary: true, + temporary_enforced: true }, features: { web_search: true, diff --git a/src/lib/components/admin/Users/Groups/Permissions.svelte b/src/lib/components/admin/Users/Groups/Permissions.svelte index 157c8f7ca..e1aa73f2a 100644 --- a/src/lib/components/admin/Users/Groups/Permissions.svelte +++ b/src/lib/components/admin/Users/Groups/Permissions.svelte @@ -23,8 +23,9 @@ controls: true, delete: true, edit: true, + file_upload: true, temporary: true, - file_upload: true + temporary_enforced: true }, features: { web_search: true, @@ -277,6 +278,16 @@ + + {#if permissions.chat.temporary} +
+
+ {$i18n.t('Enforce Temporary Chat')} +
+ + +
+ {/if}
diff --git a/src/lib/components/chat/ModelSelector.svelte b/src/lib/components/chat/ModelSelector.svelte index 9b77cd8ce..b400f5c86 100644 --- a/src/lib/components/chat/ModelSelector.svelte +++ b/src/lib/components/chat/ModelSelector.svelte @@ -46,7 +46,8 @@ model: model }))} showTemporaryChatControl={$user.role === 'user' - ? ($user?.permissions?.chat?.temporary ?? true) + ? ($user?.permissions?.chat?.temporary ?? true) && + !($user?.permissions?.chat?.temporary_enforced ?? false) : true} bind:value={selectedModel} /> diff --git a/src/routes/(app)/+layout.svelte b/src/routes/(app)/+layout.svelte index 52e7eaefd..b68cc67a0 100644 --- a/src/routes/(app)/+layout.svelte +++ b/src/routes/(app)/+layout.svelte @@ -199,6 +199,12 @@ temporaryChatEnabled.set(true); } + console.log($user.permissions); + + if ($user?.permissions?.chat?.temporary_enforced) { + temporaryChatEnabled.set(true); + } + // Check for version updates if ($user.role === 'admin') { // Check if the user has dismissed the update toast in the last 24 hours