Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions backend/open_webui/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -1361,6 +1361,14 @@ def feishu_oauth_register(oauth: OAuth):
os.environ.get("USER_PERMISSIONS_CHAT_SYSTEM_PROMPT", "True").lower() == "true"
)

USER_PERMISSIONS_CHAT_IMAGE_CAPTURE = (
os.environ.get("USER_PERMISSIONS_CHAT_IMAGE_CAPTURE", "True").lower() == "true"
)

USER_PERMISSIONS_CHAT_ATTACH_KONWLEDGE = (
os.environ.get("USER_PERMISSIONS_CHAT_ATTACH_KONWLEDGE", "True").lower() == "true"
)

USER_PERMISSIONS_CHAT_PARAMS = (
os.environ.get("USER_PERMISSIONS_CHAT_PARAMS", "True").lower() == "true"
)
Expand Down Expand Up @@ -1493,6 +1501,8 @@ def feishu_oauth_register(oauth: OAuth):
"controls": USER_PERMISSIONS_CHAT_CONTROLS,
"valves": USER_PERMISSIONS_CHAT_VALVES,
"system_prompt": USER_PERMISSIONS_CHAT_SYSTEM_PROMPT,
"image_capture": USER_PERMISSIONS_CHAT_IMAGE_CAPTURE,
"attach_knowledge": USER_PERMISSIONS_CHAT_ATTACH_KONWLEDGE,
"params": USER_PERMISSIONS_CHAT_PARAMS,
"file_upload": USER_PERMISSIONS_CHAT_FILE_UPLOAD,
"delete": USER_PERMISSIONS_CHAT_DELETE,
Expand Down
2 changes: 2 additions & 0 deletions backend/open_webui/routers/users.py
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,8 @@ class ChatPermissions(BaseModel):
controls: bool = True
valves: bool = True
system_prompt: bool = True
image_capture: bool = True
attach_knowledge: bool = True
params: bool = True
file_upload: bool = True
delete: bool = True
Expand Down
2 changes: 2 additions & 0 deletions src/lib/components/admin/Users/Groups/EditGroupModal.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,8 @@
controls: true,
valves: true,
system_prompt: true,
image_capture: true,
attach_knowledge: true,
params: true,
file_upload: true,
delete: true,
Expand Down
34 changes: 34 additions & 0 deletions src/lib/components/admin/Users/Groups/Permissions.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,8 @@
valves: true,
system_prompt: true,
params: true,
image_capture: true,
attach_knowledge: true,
file_upload: true,
delete: true,
delete_message: true,
Expand Down Expand Up @@ -495,6 +497,38 @@
{/if}
</div>

<div class="flex flex-col w-full">
<div class="flex w-full justify-between my-1">
<div class=" self-center text-xs font-medium">
{$i18n.t('Allow Image capture')}
</div>
<Switch bind:state={permissions.chat.image_capture} />
</div>
{#if defaultPermissions?.chat?.image_capture && !permissions.chat.image_capture}
<div>
<div class="text-xs text-gray-500">
{$i18n.t('This is a default user permission and will remain enabled.')}
</div>
</div>
{/if}
</div>

<div class="flex flex-col w-full">
<div class="flex w-full justify-between my-1">
<div class=" self-center text-xs font-medium">
{$i18n.t('Allow Attach Knowledge')}
</div>
<Switch bind:state={permissions.chat.attach_knowledge} />
</div>
{#if defaultPermissions?.chat?.attach_knowledge && !permissions.chat.attach_knowledge}
<div>
<div class="text-xs text-gray-500">
{$i18n.t('This is a default user permission and will remain enabled.')}
</div>
</div>
{/if}
</div>

<div class="flex flex-col w-full">
<div class="flex w-full justify-between my-1">
<div class=" self-center text-xs font-medium">
Expand Down
4 changes: 4 additions & 0 deletions src/lib/components/chat/MessageInput/InputMenu.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,7 @@
</DropdownMenu.Item>
</Tooltip>

{#if $user?.role === 'admin' || $user?.permissions.chat?.image_capture}
<Tooltip
content={fileUploadCapableModels.length !== selectedModels.length
? $i18n.t('Model(s) do not support file upload')
Expand Down Expand Up @@ -193,6 +194,7 @@
<div class=" line-clamp-1">{$i18n.t('Capture')}</div>
</DropdownMenu.Item>
</Tooltip>
{/if}

<Tooltip
content={fileUploadCapableModels.length !== selectedModels.length
Expand Down Expand Up @@ -250,6 +252,7 @@
{/if}

{#if ($knowledge ?? []).length > 0}
{#if $user?.role === 'admin' || $user?.permissions.chat?.attach_knowledge}
<Tooltip
content={fileUploadCapableModels.length !== selectedModels.length
? $i18n.t('Model(s) do not support file upload')
Expand Down Expand Up @@ -279,6 +282,7 @@
</div>
</button>
</Tooltip>
{/if}
{/if}

{#if ($chats ?? []).length > 0}
Expand Down