open-webui/src/lib/components/admin/Users/Groups/Permissions.svelte

286 lines
8.4 KiB
Svelte
Raw Normal View History

2024-11-14 05:21:50 +00:00
<script lang="ts">
2025-01-16 07:01:43 +00:00
import { getContext, onMount } from 'svelte';
2024-11-14 05:21:50 +00:00
const i18n = getContext('i18n');
2024-11-15 04:51:49 +00:00
import Tooltip from '$lib/components/common/Tooltip.svelte';
import PermissionSwitch from './PermissionSwitch.svelte';
2024-11-15 04:51:49 +00:00
2025-01-16 07:01:43 +00:00
// Default values for permissions
const DEFAULT_PERMISSIONS = {
2024-11-15 04:51:49 +00:00
workspace: {
models: false,
knowledge: false,
prompts: false,
tools: false
},
2025-04-01 00:15:51 +00:00
sharing: {
public_models: false,
public_knowledge: false,
public_prompts: false,
public_tools: false,
public_notes: false
2025-04-01 00:15:51 +00:00
},
2024-11-15 04:51:49 +00:00
chat: {
2025-01-16 07:01:43 +00:00
controls: true,
2025-07-31 14:58:58 +00:00
valves: true,
system_prompt: true,
params: true,
2025-04-14 08:40:22 +00:00
file_upload: true,
2024-11-15 04:51:49 +00:00
delete: true,
delete_message: true,
continue_response: true,
regenerate_response: true,
rate_response: true,
2024-11-15 04:51:49 +00:00
edit: true,
2025-04-23 05:43:33 +00:00
share: true,
export: true,
2025-04-14 08:40:22 +00:00
stt: true,
tts: true,
call: true,
multiple_models: true,
2024-11-16 10:31:04 +00:00
temporary: true,
temporary_enforced: false
2025-01-16 07:01:43 +00:00
},
features: {
2025-04-03 01:36:03 +00:00
direct_tool_servers: false,
2025-01-16 07:01:43 +00:00
web_search: true,
2025-02-04 05:56:35 +00:00
image_generation: true,
2025-05-04 13:22:51 +00:00
code_interpreter: true,
notes: true
2024-11-15 04:51:49 +00:00
}
};
2025-01-16 07:01:43 +00:00
export let permissions = {};
export let defaultPermissions = {};
2025-01-16 07:01:43 +00:00
// Reactive statement to ensure all fields are present in `permissions`
$: {
permissions = fillMissingProperties(permissions, DEFAULT_PERMISSIONS);
2025-01-16 07:01:43 +00:00
}
function fillMissingProperties(obj: any, defaults: any) {
return {
...defaults,
...obj,
workspace: { ...defaults.workspace, ...obj.workspace },
2025-04-01 00:15:51 +00:00
sharing: { ...defaults.sharing, ...obj.sharing },
2025-01-16 07:01:43 +00:00
chat: { ...defaults.chat, ...obj.chat },
features: { ...defaults.features, ...obj.features }
};
}
onMount(() => {
permissions = fillMissingProperties(permissions, DEFAULT_PERMISSIONS);
2025-01-16 07:01:43 +00:00
});
2024-11-14 05:21:50 +00:00
</script>
<div class="space-y-2">
2024-11-14 05:21:50 +00:00
<div>
<div class=" mb-2 text-sm font-medium">{$i18n.t('Workspace Permissions')}</div>
<div class="flex flex-col space-y-2">
<PermissionSwitch
label={$i18n.t('Models Access')}
bind:state={permissions.workspace.models}
defaultState={defaultPermissions?.workspace?.models}
/>
<PermissionSwitch
label={$i18n.t('Knowledge Access')}
bind:state={permissions.workspace.knowledge}
defaultState={defaultPermissions?.workspace?.knowledge}
/>
<PermissionSwitch
label={$i18n.t('Prompts Access')}
bind:state={permissions.workspace.prompts}
defaultState={defaultPermissions?.workspace?.prompts}
/>
<PermissionSwitch
label={$i18n.t('Tools Access')}
bind:state={permissions.workspace.tools}
defaultState={defaultPermissions?.workspace?.tools}
tooltip={$i18n.t(
2024-11-15 04:51:49 +00:00
'Warning: Enabling this will allow users to upload arbitrary code on the server.'
)}
/>
2024-11-14 05:21:50 +00:00
</div>
</div>
<hr class=" border-gray-100 dark:border-gray-850" />
2025-04-01 00:15:51 +00:00
<div>
<div class=" mb-2 text-sm font-medium">{$i18n.t('Sharing Permissions')}</div>
<div class="flex flex-col space-y-2">
<PermissionSwitch
label={$i18n.t('Models Public Sharing')}
bind:state={permissions.sharing.public_models}
defaultState={defaultPermissions?.sharing?.public_models}
/>
<PermissionSwitch
label={$i18n.t('Knowledge Public Sharing')}
bind:state={permissions.sharing.public_knowledge}
defaultState={defaultPermissions?.sharing?.public_knowledge}
/>
<PermissionSwitch
label={$i18n.t('Prompts Public Sharing')}
bind:state={permissions.sharing.public_prompts}
defaultState={defaultPermissions?.sharing?.public_prompts}
/>
<PermissionSwitch
label={$i18n.t('Tools Public Sharing')}
bind:state={permissions.sharing.public_tools}
defaultState={defaultPermissions?.sharing?.public_tools}
/>
<PermissionSwitch
label={$i18n.t('Notes Public Sharing')}
bind:state={permissions.sharing.public_notes}
defaultState={defaultPermissions?.sharing?.public_notes}
/>
</div>
2025-04-01 00:15:51 +00:00
</div>
<hr class=" border-gray-100 dark:border-gray-850" />
2024-11-14 05:21:50 +00:00
<div>
<div class=" mb-2 text-sm font-medium">{$i18n.t('Chat Permissions')}</div>
<div class="flex flex-col space-y-2">
<PermissionSwitch
label={$i18n.t('Allow File Upload')}
bind:state={permissions.chat.file_upload}
defaultState={defaultPermissions?.chat?.file_upload}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat Controls')}
bind:state={permissions.chat.controls}
defaultState={defaultPermissions?.chat?.controls}
/>
{#if permissions.chat.controls}
<div class="flex flex-col space-y-2 pl-4">
<PermissionSwitch
label={$i18n.t('Allow Chat Valves')}
bind:state={permissions.chat.valves}
defaultState={defaultPermissions?.chat?.valves}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat System Prompt')}
bind:state={permissions.chat.system_prompt}
defaultState={defaultPermissions?.chat?.system_prompt}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat Params')}
bind:state={permissions.chat.params}
defaultState={defaultPermissions?.chat?.params}
/>
</div>
{/if}
<PermissionSwitch
label={$i18n.t('Allow Chat Edit')}
bind:state={permissions.chat.edit}
defaultState={defaultPermissions?.chat?.edit}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat Delete')}
bind:state={permissions.chat.delete}
defaultState={defaultPermissions?.chat?.delete}
/>
<PermissionSwitch
label={$i18n.t('Allow Delete Messages')}
bind:state={permissions.chat.delete_message}
defaultState={defaultPermissions?.chat?.delete_message}
/>
<PermissionSwitch
label={$i18n.t('Allow Continue Response')}
bind:state={permissions.chat.continue_response}
defaultState={defaultPermissions?.chat?.continue_response}
/>
<PermissionSwitch
label={$i18n.t('Allow Regenerate Response')}
bind:state={permissions.chat.regenerate_response}
defaultState={defaultPermissions?.chat?.regenerate_response}
/>
<PermissionSwitch
label={$i18n.t('Allow Rate Response')}
bind:state={permissions.chat.rate_response}
defaultState={defaultPermissions?.chat?.rate_response}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat Share')}
bind:state={permissions.chat.share}
defaultState={defaultPermissions?.chat?.share}
/>
<PermissionSwitch
label={$i18n.t('Allow Chat Export')}
bind:state={permissions.chat.export}
defaultState={defaultPermissions?.chat?.export}
/>
<PermissionSwitch
label={$i18n.t('Allow Speech to Text')}
bind:state={permissions.chat.stt}
defaultState={defaultPermissions?.chat?.stt}
/>
<PermissionSwitch
label={$i18n.t('Allow Text to Speech')}
bind:state={permissions.chat.tts}
defaultState={defaultPermissions?.chat?.tts}
/>
<PermissionSwitch
label={$i18n.t('Allow Call')}
bind:state={permissions.chat.call}
defaultState={defaultPermissions?.chat?.call}
/>
<PermissionSwitch
label={$i18n.t('Allow Multiple Models in Chat')}
bind:state={permissions.chat.multiple_models}
defaultState={defaultPermissions?.chat?.multiple_models}
/>
<PermissionSwitch
label={$i18n.t('Allow Temporary Chat')}
bind:state={permissions.chat.temporary}
defaultState={defaultPermissions?.chat?.temporary}
/>
{#if permissions.chat.temporary}
<div class="pl-4">
<PermissionSwitch
label={$i18n.t('Enforce Temporary Chat')}
bind:state={permissions.chat.temporary_enforced}
defaultState={defaultPermissions?.chat?.temporary_enforced}
/>
</div>
{/if}
2025-04-14 08:40:22 +00:00
</div>
2024-11-14 05:21:50 +00:00
</div>
2025-01-16 07:01:43 +00:00
<hr class=" border-gray-100 dark:border-gray-850" />
2025-01-16 07:01:43 +00:00
<div>
<div class=" mb-2 text-sm font-medium">{$i18n.t('Features Permissions')}</div>
<div class="flex flex-col space-y-2">
<PermissionSwitch
label={$i18n.t('Direct Tool Servers')}
bind:state={permissions.features.direct_tool_servers}
defaultState={defaultPermissions?.features?.direct_tool_servers}
/>
<PermissionSwitch
label={$i18n.t('Web Search')}
bind:state={permissions.features.web_search}
defaultState={defaultPermissions?.features?.web_search}
/>
<PermissionSwitch
label={$i18n.t('Image Generation')}
bind:state={permissions.features.image_generation}
defaultState={defaultPermissions?.features?.image_generation}
/>
<PermissionSwitch
label={$i18n.t('Code Interpreter')}
bind:state={permissions.features.code_interpreter}
defaultState={defaultPermissions?.features?.code_interpreter}
/>
<PermissionSwitch
label={$i18n.t('Notes')}
bind:state={permissions.features.notes}
defaultState={defaultPermissions?.features?.notes}
/>
2025-05-04 13:22:51 +00:00
</div>
2025-01-16 07:01:43 +00:00
</div>
</div>