1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-09-19 17:52:45 +02:00
unleash.unleash/frontend/src/component/providers/AccessProvider/AccessProvider.tsx
2023-04-11 14:47:54 +02:00

82 lines
2.0 KiB
TypeScript

import { ReactElement, ReactNode, useMemo } from 'react';
import AccessContext, { IAccessContext } from 'contexts/AccessContext';
import { ADMIN, SKIP_CHANGE_REQUEST } from './permissions';
import { IPermission } from 'interfaces/user';
import { useAuthPermissions } from 'hooks/api/getters/useAuth/useAuthPermissions';
interface IAccessProviderProps {
children: ReactNode;
}
export const AccessProvider = ({
children,
}: IAccessProviderProps): ReactElement => {
const { permissions } = useAuthPermissions();
const value: IAccessContext = useMemo(
() => ({
isAdmin: checkAdmin(permissions),
hasAccess: hasAccess.bind(null, permissions),
}),
[permissions]
);
return (
<AccessContext.Provider value={value}>
{children}
</AccessContext.Provider>
);
};
export const checkAdmin = (permissions: IPermission[] | undefined): boolean => {
if (!permissions) {
return false;
}
return permissions.some(p => {
return p.permission === ADMIN;
});
};
export const hasAccess = (
permissions: IPermission[] | undefined,
permission: string,
project?: string,
environment?: string
): boolean => {
if (!permissions) {
return false;
}
return permissions.some(p => {
return checkPermission(p, permission, project, environment);
});
};
const checkPermission = (
p: IPermission,
permission: string,
project?: string,
environment?: string
): boolean => {
if (!permission) {
console.warn(`Missing permission for AccessProvider: ${permission}`);
return false;
}
if (p.permission === ADMIN && permission !== SKIP_CHANGE_REQUEST) {
return true;
}
if (
p.permission === permission &&
(p.project === project || p.project === '*') &&
(!p.environment ||
p.environment === environment ||
p.environment === '*')
) {
return true;
}
return p.permission === permission && !p.project && !p.environment;
};