From 295d62fd5e44819cb55737a86c42db633e097cd8 Mon Sep 17 00:00:00 2001 From: Michal Klobukowski Date: Sun, 16 Dec 2018 22:16:44 +0100 Subject: [PATCH] Implement group member removal Feature #14505 Arvados-DCO-1.1-Signed-off-by: Michal Klobukowski --- .../group-details-panel-actions.ts | 38 +++++++++-- .../groups-panel/groups-panel-actions.ts | 68 +++++++++++++++++++ 2 files changed, 100 insertions(+), 6 deletions(-) diff --git a/src/store/group-details-panel/group-details-panel-actions.ts b/src/store/group-details-panel/group-details-panel-actions.ts index a4370d0c..4ad01594 100644 --- a/src/store/group-details-panel/group-details-panel-actions.ts +++ b/src/store/group-details-panel/group-details-panel-actions.ts @@ -9,7 +9,7 @@ import { getProperty } from '~/store/properties/properties'; import { Person } from '~/views-components/sharing-dialog/people-select'; import { dialogActions } from '~/store/dialog/dialog-actions'; import { reset, startSubmit } from 'redux-form'; -import { addGroupMember } from '~/store/groups-panel/groups-panel-actions'; +import { addGroupMember, deleteGroupMember } from '~/store/groups-panel/groups-panel-actions'; import { getResource } from '~/store/resources/resources'; import { GroupResource } from '~/models/group'; import { RootState } from '~/store/store'; @@ -17,6 +17,7 @@ import { ServiceRepository } from '~/services/services'; import { PermissionResource } from '~/models/permission'; import { GroupDetailsPanel } from '~/views/group-details-panel/group-details-panel'; import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions'; +import { UserResource, getUserFullname } from '~/models/user'; export const GROUP_DETAILS_PANEL_ID = 'groupDetailsPanel'; export const ADD_GROUP_MEMBERS_DIALOG = 'addGrupMembers'; @@ -98,9 +99,34 @@ export const openRemoveGroupMemberDialog = (uuid: string) => }; export const removeGroupMember = (uuid: string) => - async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...' })); - await services.permissionService.delete(uuid); - dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000, kind: SnackbarKind.SUCCESS })); - dispatch(GroupDetailsPanelActions.REQUEST_ITEMS()); + + async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { + + const groupUuid = getCurrentGroupDetailsPanelUuid(getState().properties); + + if (groupUuid) { + + const group = getResource(groupUuid)(getState().resources); + const user = getResource(groupUuid)(getState().resources); + + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...' })); + + await deleteGroupMember({ + user: { + uuid, + name: user ? getUserFullname(user) : uuid, + }, + group: { + uuid: groupUuid, + name: group ? group.name : groupUuid, + }, + permissionService, + dispatch, + }); + + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000, kind: SnackbarKind.SUCCESS })); + dispatch(GroupDetailsPanelActions.REQUEST_ITEMS()); + + } + }; diff --git a/src/store/groups-panel/groups-panel-actions.ts b/src/store/groups-panel/groups-panel-actions.ts index 8bb0128c..1c6223bd 100644 --- a/src/store/groups-panel/groups-panel-actions.ts +++ b/src/store/groups-panel/groups-panel-actions.ts @@ -15,6 +15,7 @@ import { getCommonResourceServiceError, CommonResourceServiceError } from '~/ser import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions'; import { PermissionLevel, PermissionResource } from '~/models/permission'; import { PermissionService } from '~/services/permission-service/permission-service'; +import { FilterBuilder } from '~/services/api/filter-builder'; export const GROUPS_PANEL_ID = "groupsPanel"; export const CREATE_GROUP_DIALOG = "createGroupDialog"; @@ -109,6 +110,29 @@ export const createGroup = ({ name, users = [] }: CreateGroupFormData) => } }; +interface DeleteGroupMemberArgs { + user: { uuid: string, name: string }; + group: { uuid: string, name: string }; + dispatch: Dispatch; + permissionService: PermissionService; +} + +export const deleteGroupMember = async ({ user, group, ...args }: DeleteGroupMemberArgs) => { + + await deletePermission({ + tail: user, + head: group, + ...args, + }); + + await deletePermission({ + tail: group, + head: user, + ...args, + }); + +}; + interface AddGroupMemberArgs { user: { uuid: string, name: string }; group: { uuid: string, name: string }; @@ -163,4 +187,48 @@ const createPermission = async ({ head, tail, permissionLevel, dispatch, permiss } +}; + +interface DeletePermissionLinkArgs { + head: { uuid: string, name: string }; + tail: { uuid: string, name: string }; + dispatch: Dispatch; + permissionService: PermissionService; +} + +export const deletePermission = async ({ head, tail, dispatch, permissionService }: DeletePermissionLinkArgs) => { + + try { + + const permissionsResponse = await permissionService.list({ + + filters: new FilterBuilder() + .addEqual('tailUuid', tail.uuid) + .addEqual('headUuid', head.uuid) + .getFilters() + + }); + + const [permission] = permissionsResponse.items; + + if (permission) { + + await permissionService.delete(permission.uuid); + + } else { + + throw new Error('Permission not found'); + + } + + + } catch (e) { + + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: `Could not delete ${tail.name} -> ${head.name} relation`, + kind: SnackbarKind.ERROR, + })); + + } + }; \ No newline at end of file -- 2.30.2