mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-03 12:37:56 +00:00
In admin settings, this Pr will add the UI for managing custom roles ( ref: https://github.com/chatwoot/chatwoot/pull/9995 ). It also handles the routing logic changes to accommodate fine-tuned permissions. --------- Co-authored-by: Pranav <pranavrajs@gmail.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com> Co-authored-by: iamsivin <iamsivin@gmail.com> Co-authored-by: Muhsin Keloth <muhsinkeramam@gmail.com>
73 lines
2.2 KiB
JavaScript
73 lines
2.2 KiB
JavaScript
export const hasPermissions = (
|
|
requiredPermissions = [],
|
|
availablePermissions = []
|
|
) => {
|
|
return requiredPermissions.some(permission =>
|
|
availablePermissions.includes(permission)
|
|
);
|
|
};
|
|
|
|
export const getCurrentAccount = ({ accounts } = {}, accountId = null) => {
|
|
return accounts.find(account => Number(account.id) === Number(accountId));
|
|
};
|
|
|
|
export const getUserPermissions = (user, accountId) => {
|
|
const currentAccount = getCurrentAccount(user, accountId) || {};
|
|
return currentAccount.permissions || [];
|
|
};
|
|
|
|
const isPermissionsPresentInRoute = route =>
|
|
route.meta && route.meta.permissions;
|
|
|
|
export const buildPermissionsFromRouter = (routes = []) =>
|
|
routes.reduce((acc, route) => {
|
|
if (route.name) {
|
|
if (!isPermissionsPresentInRoute(route)) {
|
|
// eslint-disable-next-line
|
|
console.error(route);
|
|
throw new Error(
|
|
"The route doesn't have the required permissions defined"
|
|
);
|
|
}
|
|
acc[route.name] = route.meta.permissions;
|
|
}
|
|
|
|
if (route.children) {
|
|
acc = {
|
|
...acc,
|
|
...buildPermissionsFromRouter(route.children),
|
|
};
|
|
}
|
|
|
|
return acc;
|
|
}, {});
|
|
|
|
/**
|
|
* Filters and transforms items based on user permissions.
|
|
*
|
|
* @param {Object} items - An object containing items to be filtered.
|
|
* @param {Array} userPermissions - Array of permissions the user has.
|
|
* @param {Function} getPermissions - Function to extract required permissions from an item.
|
|
* @param {Function} [transformItem] - Optional function to transform each item after filtering.
|
|
* @returns {Array} Filtered and transformed items.
|
|
*/
|
|
export const filterItemsByPermission = (
|
|
items,
|
|
userPermissions,
|
|
getPermissions,
|
|
transformItem = (key, item) => ({ key, ...item })
|
|
) => {
|
|
// Helper function to check if an item has the required permissions
|
|
const hasRequiredPermissions = item => {
|
|
const requiredPermissions = getPermissions(item);
|
|
return (
|
|
requiredPermissions.length === 0 ||
|
|
hasPermissions(requiredPermissions, userPermissions)
|
|
);
|
|
};
|
|
|
|
return Object.entries(items)
|
|
.filter(([, item]) => hasRequiredPermissions(item)) // Keep only items with required permissions
|
|
.map(([key, item]) => transformItem(key, item)); // Transform each remaining item
|
|
};
|