mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-12 21:37:32 -08:00
fix(editor): Fix frontend project roles (#9901)
This commit is contained in:
parent
af69c80bf5
commit
f229577209
108
packages/editor-ui/src/stores/roles.store.test.ts
Normal file
108
packages/editor-ui/src/stores/roles.store.test.ts
Normal file
|
@ -0,0 +1,108 @@
|
||||||
|
import { useRolesStore } from '@/stores/roles.store';
|
||||||
|
import * as rolesApi from '@/api/roles.api';
|
||||||
|
import { createPinia, setActivePinia } from 'pinia';
|
||||||
|
|
||||||
|
let rolesStore: ReturnType<typeof useRolesStore>;
|
||||||
|
|
||||||
|
describe('roles store', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
setActivePinia(createPinia());
|
||||||
|
rolesStore = useRolesStore();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should use project roles defined in the frontend in correct order', async () => {
|
||||||
|
vi.spyOn(rolesApi, 'getRoles').mockResolvedValue({
|
||||||
|
global: [],
|
||||||
|
credential: [],
|
||||||
|
workflow: [],
|
||||||
|
project: [
|
||||||
|
{
|
||||||
|
name: 'Project Admin',
|
||||||
|
role: 'project:admin',
|
||||||
|
scopes: [
|
||||||
|
'workflow:create',
|
||||||
|
'workflow:read',
|
||||||
|
'workflow:update',
|
||||||
|
'workflow:delete',
|
||||||
|
'workflow:list',
|
||||||
|
'workflow:execute',
|
||||||
|
'workflow:move',
|
||||||
|
'credential:create',
|
||||||
|
'credential:read',
|
||||||
|
'credential:update',
|
||||||
|
'credential:delete',
|
||||||
|
'credential:list',
|
||||||
|
'credential:move',
|
||||||
|
'project:list',
|
||||||
|
'project:read',
|
||||||
|
'project:update',
|
||||||
|
'project:delete',
|
||||||
|
],
|
||||||
|
licensed: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Project Owner',
|
||||||
|
role: 'project:personalOwner',
|
||||||
|
scopes: [
|
||||||
|
'workflow:create',
|
||||||
|
'workflow:read',
|
||||||
|
'workflow:update',
|
||||||
|
'workflow:delete',
|
||||||
|
'workflow:list',
|
||||||
|
'workflow:execute',
|
||||||
|
'workflow:share',
|
||||||
|
'workflow:move',
|
||||||
|
'credential:create',
|
||||||
|
'credential:read',
|
||||||
|
'credential:update',
|
||||||
|
'credential:delete',
|
||||||
|
'credential:list',
|
||||||
|
'credential:share',
|
||||||
|
'credential:move',
|
||||||
|
'project:list',
|
||||||
|
'project:read',
|
||||||
|
],
|
||||||
|
licensed: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Project Editor',
|
||||||
|
role: 'project:editor',
|
||||||
|
scopes: [
|
||||||
|
'workflow:create',
|
||||||
|
'workflow:read',
|
||||||
|
'workflow:update',
|
||||||
|
'workflow:delete',
|
||||||
|
'workflow:list',
|
||||||
|
'workflow:execute',
|
||||||
|
'credential:create',
|
||||||
|
'credential:read',
|
||||||
|
'credential:update',
|
||||||
|
'credential:delete',
|
||||||
|
'credential:list',
|
||||||
|
'project:list',
|
||||||
|
'project:read',
|
||||||
|
],
|
||||||
|
licensed: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Project Viewer',
|
||||||
|
role: 'project:viewer',
|
||||||
|
scopes: [
|
||||||
|
'credential:list',
|
||||||
|
'credential:read',
|
||||||
|
'project:list',
|
||||||
|
'project:read',
|
||||||
|
'workflow:list',
|
||||||
|
'workflow:read',
|
||||||
|
],
|
||||||
|
licensed: true,
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
await rolesStore.fetchRoles();
|
||||||
|
expect(rolesStore.processedProjectRoles.map(({ role }) => role)).toEqual([
|
||||||
|
'project:editor',
|
||||||
|
'project:admin',
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
});
|
|
@ -20,12 +20,12 @@ export const useRolesStore = defineStore('roles', () => {
|
||||||
|
|
||||||
const processedProjectRoles = computed<RoleMap['project']>(() =>
|
const processedProjectRoles = computed<RoleMap['project']>(() =>
|
||||||
roles.value.project
|
roles.value.project
|
||||||
|
.filter((role) => projectRoleOrderMap.value.has(role.role))
|
||||||
.sort(
|
.sort(
|
||||||
(a, b) =>
|
(a, b) =>
|
||||||
(projectRoleOrderMap.value.get(a.role) ?? 0) -
|
(projectRoleOrderMap.value.get(a.role) ?? 0) -
|
||||||
(projectRoleOrderMap.value.get(b.role) ?? 0),
|
(projectRoleOrderMap.value.get(b.role) ?? 0),
|
||||||
)
|
),
|
||||||
.filter((role) => role.role !== 'project:personalOwner'),
|
|
||||||
);
|
);
|
||||||
|
|
||||||
const processedCredentialRoles = computed<RoleMap['credential']>(() =>
|
const processedCredentialRoles = computed<RoleMap['credential']>(() =>
|
||||||
|
|
Loading…
Reference in a new issue