mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-01-18 00:15:30 +01:00
feat: Implement prompt permissions management and access control middleware fix: agent deletion process to remove associated permissions and ACL entries fix: Import Permissions for enhanced access control in GrantAccessDialog feat: use PromptGroup for access control - Added migration script for PromptGroup permissions, categorizing groups into global view access and private groups. - Created unit tests for the migration script to ensure correct categorization and permission granting. - Introduced middleware for checking access permissions on PromptGroups and prompts via their groups. - Updated routes to utilize new access control middleware for PromptGroups. - Enhanced access role definitions to include roles specific to PromptGroups. - Modified ACL entry schema and types to accommodate PromptGroup resource type. - Updated data provider to include new access role identifiers for PromptGroups. feat: add generic access management dialogs and hooks for resource permissions fix: remove duplicate imports in FileContext component fix: remove duplicate mongoose dependency in package.json feat: add access permissions handling for dynamic resource types and add promptGroup roles feat: implement centralized role localization and update access role types refactor: simplify author handling in prompt group routes and enhance ACL checks feat: implement addPromptToGroup functionality and update PromptForm to use it feat: enhance permission handling in ChatGroupItem, DashGroupItem, and PromptForm components chore: rename migration script for prompt group permissions and update package.json scripts chore: update prompt tests
39 lines
1.1 KiB
TypeScript
39 lines
1.1 KiB
TypeScript
import { useMemo } from 'react';
|
|
import { PermissionTypes, Permissions } from 'librechat-data-provider';
|
|
import { useHasAccess } from '~/hooks';
|
|
|
|
/**
|
|
* Hook to check people picker permissions and return the appropriate type filter
|
|
* @returns Object with permission states and type filter
|
|
*/
|
|
export const usePeoplePickerPermissions = () => {
|
|
const canViewUsers = useHasAccess({
|
|
permissionType: PermissionTypes.PEOPLE_PICKER,
|
|
permission: Permissions.VIEW_USERS,
|
|
});
|
|
|
|
const canViewGroups = useHasAccess({
|
|
permissionType: PermissionTypes.PEOPLE_PICKER,
|
|
permission: Permissions.VIEW_GROUPS,
|
|
});
|
|
|
|
const hasPeoplePickerAccess = canViewUsers || canViewGroups;
|
|
|
|
const peoplePickerTypeFilter = useMemo(() => {
|
|
if (canViewUsers && canViewGroups) {
|
|
return null; // Both types allowed
|
|
} else if (canViewUsers) {
|
|
return 'user' as const;
|
|
} else if (canViewGroups) {
|
|
return 'group' as const;
|
|
}
|
|
return null;
|
|
}, [canViewUsers, canViewGroups]);
|
|
|
|
return {
|
|
canViewUsers,
|
|
canViewGroups,
|
|
hasPeoplePickerAccess,
|
|
peoplePickerTypeFilter,
|
|
};
|
|
};
|