X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/f528f6f6ca52c8654b52f84e52339da8e91a9d9c..c5fa0c4eed19a9d0c163ea1727189970533f0203:/src/store/processes/processes-actions.ts diff --git a/src/store/processes/processes-actions.ts b/src/store/processes/processes-actions.ts index f9f5ef72..b65a2202 100644 --- a/src/store/processes/processes-actions.ts +++ b/src/store/processes/processes-actions.ts @@ -10,11 +10,21 @@ import { FilterBuilder } from '~/services/api/filter-builder'; import { ContainerRequestResource } from '~/models/container-request'; import { Process } from './process'; import { dialogActions } from '~/store/dialog/dialog-actions'; -import { snackbarActions } from '~/store/snackbar/snackbar-actions'; +import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions'; import { projectPanelActions } from '~/store/project-panel/project-panel-action'; +import { navigateToRunProcess } from '~/store/navigation/navigation-action'; +import { goToStep, runProcessPanelActions } from '~/store/run-process-panel/run-process-panel-actions'; +import { getResource } from '~/store/resources/resources'; +import { initialize } from "redux-form"; +import { RUN_PROCESS_BASIC_FORM, RunProcessBasicFormData } from "~/views/run-process-panel/run-process-basic-form"; +import { RunProcessAdvancedFormData, RUN_PROCESS_ADVANCED_FORM } from "~/views/run-process-panel/run-process-advanced-form"; +import { MOUNT_PATH_CWL_WORKFLOW, MOUNT_PATH_CWL_INPUT } from '~/models/process'; +import { getWorkflowInputs } from "~/models/workflow"; export const loadProcess = (containerRequestUuid: string) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository): Promise => { + const response = await services.workflowService.list(); + dispatch(runProcessPanelActions.SET_WORKFLOWS(response.items)); const containerRequest = await services.containerRequestService.get(containerRequestUuid); dispatch(updateResources([containerRequest])); if (containerRequest.containerUuid) { @@ -44,9 +54,11 @@ export const loadSubprocesses = (containerUuid: string) => } }; +const MAX_AMOUNT_OF_SUBPROCESSES = 10000; + export const loadContainerRequests = (filters: string) => async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - const { items } = await services.containerRequestService.list({ filters }); + const { items } = await services.containerRequestService.list({ filters, limit: MAX_AMOUNT_OF_SUBPROCESSES }); dispatch(updateResources(items)); return items; }; @@ -58,6 +70,65 @@ export const loadContainers = (filters: string) => return items; }; +export const cancelRunningWorkflow = (uuid: string) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + try { + const process = await services.containerRequestService.update(uuid, { priority: 0 }); + return process; + } catch (e) { + throw new Error('Could not cancel the process.'); + } + }; + +export const reRunProcess = (processUuid: string, workflowUuid: string) => + (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + const process = getResource(processUuid)(getState().resources); + const workflows = getState().runProcessPanel.searchWorkflows; + const workflow = workflows.find(workflow => workflow.uuid === workflowUuid); + if (workflow && process) { + let inputs = getWorkflowInputs(process.mounts[MOUNT_PATH_CWL_WORKFLOW]); + inputs = getInputs(process); + const stringifiedDefinition = JSON.stringify(process.mounts[MOUNT_PATH_CWL_WORKFLOW].content); + const newWorkflow = { ...workflow, definition: stringifiedDefinition }; + + const basicInitialData: RunProcessBasicFormData = { name: `Copy of: ${process.name}`, description: process.description }; + dispatch(initialize(RUN_PROCESS_BASIC_FORM, basicInitialData)); + + const advancedInitialData: RunProcessAdvancedFormData = { + output: process.outputName, + runtime: process.schedulingParameters.max_run_time, + ram: process.runtimeConstraints.ram, + vcpus: process.runtimeConstraints.vcpus, + keep_cache_ram: process.runtimeConstraints.keep_cache_ram, + api: process.runtimeConstraints.API + }; + dispatch(initialize(RUN_PROCESS_ADVANCED_FORM, advancedInitialData)); + + dispatch(navigateToRunProcess); + dispatch(goToStep(1)); + dispatch(runProcessPanelActions.SET_STEP_CHANGED(true)); + dispatch(runProcessPanelActions.SET_SELECTED_WORKFLOW(newWorkflow)); + } else { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: `You can't re-run this process`, kind: SnackbarKind.ERROR })); + } + }; + +const getInputs = (data: any) => { + if (!data || !data.mounts || !data.mounts[MOUNT_PATH_CWL_WORKFLOW]) { return []; } + const inputs = getWorkflowInputs(data.mounts[MOUNT_PATH_CWL_WORKFLOW].content); + return inputs ? inputs.map( + (it: any) => ( + { + type: it.type, + id: it.id, + label: it.label, + default: data.mounts[MOUNT_PATH_CWL_INPUT].content[it.id], + doc: it.doc + } + ) + ) : []; +}; + export const openRemoveProcessDialog = (uuid: string) => (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { dispatch(dialogActions.OPEN_DIALOG({ @@ -74,11 +145,11 @@ export const openRemoveProcessDialog = (uuid: string) => export const REMOVE_PROCESS_DIALOG = 'removeProcessDialog'; export const removeProcessPermanently = (uuid: string) => - async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) =>{ - dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...' })); + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...', kind: SnackbarKind.INFO })); await services.containerRequestService.delete(uuid); dispatch(projectPanelActions.REQUEST_ITEMS()); - dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000 })); + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000, kind: SnackbarKind.SUCCESS })); }; - +