mirror of
				https://github.com/lingble/chatwoot.git
				synced 2025-11-04 04:57:51 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
export const getCurrentAccount = ({ accounts } = {}, accountId) => {
 | 
						|
  return accounts.find(account => account.id === accountId);
 | 
						|
};
 | 
						|
 | 
						|
export const getUserRole = ({ accounts } = {}, accountId) => {
 | 
						|
  const currentAccount = getCurrentAccount({ accounts }, accountId) || {};
 | 
						|
  return currentAccount.role || null;
 | 
						|
};
 | 
						|
 | 
						|
export const routeIsAccessibleFor = (route, role, roleWiseRoutes) => {
 | 
						|
  return roleWiseRoutes[role].includes(route);
 | 
						|
};
 | 
						|
 | 
						|
const validateActiveAccountRoutes = (to, user, roleWiseRoutes) => {
 | 
						|
  // If the current account is active, then check for the route permissions
 | 
						|
  const accountDashboardURL = `accounts/${to.params.accountId}/dashboard`;
 | 
						|
 | 
						|
  // If the user is trying to access suspended route, redirect them to dashboard
 | 
						|
  if (to.name === 'account_suspended') {
 | 
						|
    return accountDashboardURL;
 | 
						|
  }
 | 
						|
 | 
						|
  const userRole = getUserRole(user, Number(to.params.accountId));
 | 
						|
  const isAccessible = routeIsAccessibleFor(to.name, userRole, roleWiseRoutes);
 | 
						|
  // If the route is not accessible for the user, return to dashboard screen
 | 
						|
  return isAccessible ? null : accountDashboardURL;
 | 
						|
};
 | 
						|
 | 
						|
export const validateLoggedInRoutes = (to, user, roleWiseRoutes) => {
 | 
						|
  const currentAccount = getCurrentAccount(user, Number(to.params.accountId));
 | 
						|
 | 
						|
  // If current account is missing, either user does not have
 | 
						|
  // access to the account or the account is deleted, return to login screen
 | 
						|
  if (!currentAccount) {
 | 
						|
    return `app/login`;
 | 
						|
  }
 | 
						|
 | 
						|
  const isCurrentAccountActive = currentAccount.status === 'active';
 | 
						|
 | 
						|
  if (isCurrentAccountActive) {
 | 
						|
    return validateActiveAccountRoutes(to, user, roleWiseRoutes);
 | 
						|
  }
 | 
						|
 | 
						|
  // If the current account is not active, then redirect the user to the suspended screen
 | 
						|
  if (to.name !== 'account_suspended') {
 | 
						|
    return `accounts/${to.params.accountId}/suspended`;
 | 
						|
  }
 | 
						|
 | 
						|
  // Proceed to the route if none of the above conditions are met
 | 
						|
  return null;
 | 
						|
};
 |