1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/frontend/src/component/providers/AccessProvider/AccessProvider.tsx
olav 213e8950d3 refactor: port login auth to TS/SWR (#680)
* refactor: allow existing tsc errors

* refactor: add missing component key

* refactor: port login auth to TS/SWR

* refactor: replace incorrect CREATE_TAG_TYPE with UPDATE_TAG_TYPE

* refactor: fix AccessProvider permission mocks

* refactor: add types to AccessContext

* refactor: fix file extension

* refactor: remove default export

* refactor: remove unused IAddedUser interface

* refactor: comment on the permissions prop

* refactor: split auth hooks

* feat: auth tests

* fix: setup separate e2e tests

* fix: naming

* fix: lint

* fix: spec path

* fix: missing store

* feat: add more tests

Co-authored-by: Fredrik Oseberg <fredrik.no@gmail.com>
2022-02-10 17:04:10 +01:00

112 lines
2.7 KiB
TypeScript

import { ReactElement, ReactNode, useCallback, useMemo } from 'react';
import AccessContext, { IAccessContext } from '../../../contexts/AccessContext';
import { ADMIN } from './permissions';
import { IPermission } from '../../../interfaces/user';
import { useAuthPermissions } from '../../../hooks/api/getters/useAuth/useAuthPermissions';
interface IAccessProviderProps {
children: ReactNode;
permissions: IPermission[];
}
// TODO(olav): Mock useAuth instead of using props.permissions in tests.
const AccessProvider = (props: IAccessProviderProps): ReactElement => {
const auth = useAuthPermissions();
const permissions = props.permissions ?? auth.permissions;
const isAdmin: boolean = useMemo(() => {
return checkAdmin(permissions);
}, [permissions]);
const hasAccess = useCallback(
(permission: string, project?: string, environment?: string) => {
return checkPermissions(
permissions,
permission,
project,
environment
);
},
[permissions]
);
const value: IAccessContext = useMemo(
() => ({
isAdmin,
hasAccess,
}),
[isAdmin, hasAccess]
);
return (
<AccessContext.Provider value={value}>
{props.children}
</AccessContext.Provider>
);
};
const checkAdmin = (permissions: IPermission[] | undefined): boolean => {
if (!permissions) {
return false;
}
return permissions.some(p => {
return p.permission === ADMIN;
});
};
const checkPermissions = (
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) {
return true;
}
if (
p.permission === permission &&
(p.project === project || p.project === '*') &&
(p.environment === environment || p.environment === '*')
) {
return true;
}
if (
p.permission === permission &&
(p.project === project || p.project === '*') &&
p.environment === null
) {
return true;
}
return (
p.permission === permission &&
p.project === undefined &&
p.environment === null
);
};
export default AccessProvider;