X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/986ff42ab49d2fd9a2da53fcc0f08a7933719b64..4b961d16b8f8ef8afbd13697a79fe4684acd0416:/src/store/sharing-dialog/sharing-dialog-actions.ts diff --git a/src/store/sharing-dialog/sharing-dialog-actions.ts b/src/store/sharing-dialog/sharing-dialog-actions.ts index fe23b328..17b237ec 100644 --- a/src/store/sharing-dialog/sharing-dialog-actions.ts +++ b/src/store/sharing-dialog/sharing-dialog-actions.ts @@ -18,6 +18,9 @@ import { PermissionResource } from '~/models/permission'; import { differenceWith } from "lodash"; import { withProgress } from "~/store/progress-indicator/with-progress"; import { progressIndicatorActions } from '~/store/progress-indicator/progress-indicator-actions.ts'; +import { snackbarActions, SnackbarKind } from "../snackbar/snackbar-actions"; +import { extractUuidKind, ResourceKind } from "~/models/resource"; +import { LinkClass } from "~/models/link"; export const openSharingDialog = (resourceUuid: string) => (dispatch: Dispatch) => { @@ -41,16 +44,32 @@ export const saveSharingDialogChanges = async (dispatch: Dispatch) => { await dispatch(loadSharingDialog); }; +export const sendSharingInvitations = async (dispatch: Dispatch) => { + dispatch(progressIndicatorActions.START_WORKING(SHARING_DIALOG_NAME)); + await dispatch(sendInvitations); + dispatch(closeSharingDialog()); + dispatch(snackbarActions.OPEN_SNACKBAR({ + message: 'Resource has been shared', + kind: SnackbarKind.SUCCESS, + })); + dispatch(progressIndicatorActions.STOP_WORKING(SHARING_DIALOG_NAME)); +}; + const loadSharingDialog = async (dispatch: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { const dialog = getDialog(getState().dialog, SHARING_DIALOG_NAME); - if (dialog) { dispatch(progressIndicatorActions.START_WORKING(SHARING_DIALOG_NAME)); - const { items } = await permissionService.listResourcePermissions(dialog.data); - dispatch(initializePublicAccessForm(items)); - await dispatch(initializeManagementForm(items)); - dispatch(progressIndicatorActions.STOP_WORKING(SHARING_DIALOG_NAME)); + try { + const { items } = await permissionService.listResourcePermissions(dialog.data); + dispatch(initializePublicAccessForm(items)); + await dispatch(initializeManagementForm(items)); + dispatch(progressIndicatorActions.STOP_WORKING(SHARING_DIALOG_NAME)); + } catch (e) { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'You do not have access to share this item', hideDuration: 2000, kind: SnackbarKind.ERROR })); + dispatch(dialogActions.CLOSE_DIALOG({ id: SHARING_DIALOG_NAME })); + dispatch(progressIndicatorActions.STOP_WORKING(SHARING_DIALOG_NAME)); + } } }; @@ -172,15 +191,32 @@ const saveManagementChanges = async (_: Dispatch, getState: () => RootState, { p } }; -const sendInvitations = async (_: Dispatch, getState: () => RootState, { permissionService }: ServiceRepository) => { +const sendInvitations = async (_: Dispatch, getState: () => RootState, { permissionService, userService }: ServiceRepository) => { const state = getState(); const { user } = state.auth; const dialog = getDialog(state.dialog, SHARING_DIALOG_NAME); if (dialog && user) { - const invitations = getFormValues(SHARING_INVITATION_FORM_NAME)(state) as SharingInvitationFormData; - const invitationData = invitations.invitedPeople + const getGroupsFromForm = invitations.invitedPeople.filter((invitation) => extractUuidKind(invitation.uuid) === ResourceKind.GROUP); + const getUsersFromForm = invitations.invitedPeople.filter((invitation) => extractUuidKind(invitation.uuid) === ResourceKind.USER); + const uuids = getGroupsFromForm.map(group => group.uuid); + + const permissions = await permissionService.list({ + filters: new FilterBuilder() + .addIn('tailUuid', uuids) + .addEqual('linkClass', LinkClass.PERMISSION) + .getFilters() + }); + + const usersFromGroups = await userService.list({ + filters: new FilterBuilder() + .addIn('uuid', permissions.items.map(item => item.headUuid)) + .getFilters() + + }); + + const invitationDataUsers = getUsersFromForm .map(person => ({ ownerUuid: user.uuid, headUuid: dialog.data, @@ -188,9 +224,19 @@ const sendInvitations = async (_: Dispatch, getState: () => RootState, { permiss name: invitations.permissions })); - for (const invitation of invitationData) { + const invitationsDataGroups = usersFromGroups.items.map( + person => ({ + ownerUuid: user.uuid, + headUuid: dialog.data, + tailUuid: person.uuid, + name: invitations.permissions + }) + ); + + const data = invitationDataUsers.concat(invitationsDataGroups); + + for (const invitation of data) { await permissionService.create(invitation); } - } };