Merge branch '21321-cran-mirror'
[arvados.git] / services / workbench2 / src / store / workflow-panel / workflow-panel-actions.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { Dispatch } from 'redux';
6 import { RootState } from 'store/store';
7 import { ServiceRepository } from 'services/services';
8 import { bindDataExplorerActions } from 'store/data-explorer/data-explorer-action';
9 import { propertiesActions } from 'store/properties/properties-actions';
10 import { getProperty } from 'store/properties/properties';
11 import { navigateToRunProcess, navigateTo } from 'store/navigation/navigation-action';
12 import {
13     goToStep,
14     runProcessPanelActions,
15     loadPresets,
16     getWorkflowRunnerSettings
17 } from 'store/run-process-panel/run-process-panel-actions';
18 import { snackbarActions, SnackbarKind } from 'store/snackbar/snackbar-actions';
19 import { initialize } from 'redux-form';
20 import { RUN_PROCESS_BASIC_FORM } from 'views/run-process-panel/run-process-basic-form';
21 import { RUN_PROCESS_INPUTS_FORM } from 'views/run-process-panel/run-process-inputs-form';
22 import { RUN_PROCESS_ADVANCED_FORM } from 'views/run-process-panel/run-process-advanced-form';
23 import { getResource } from 'store/resources/resources';
24 import { ProjectResource } from 'models/project';
25 import { UserResource } from 'models/user';
26 import { getWorkflowInputs, parseWorkflowDefinition } from 'models/workflow';
27
28 export const WORKFLOW_PANEL_ID = "workflowPanel";
29 const UUID_PREFIX_PROPERTY_NAME = 'uuidPrefix';
30 const WORKFLOW_PANEL_DETAILS_UUID = 'workflowPanelDetailsUuid';
31 export const workflowPanelActions = bindDataExplorerActions(WORKFLOW_PANEL_ID);
32
33 export const WORKFLOW_PROCESSES_PANEL_ID = "workflowProcessesPanel";
34 export const workflowProcessesPanelActions = bindDataExplorerActions(WORKFLOW_PROCESSES_PANEL_ID);
35
36 export const loadWorkflowPanel = () =>
37     async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
38         dispatch(workflowPanelActions.REQUEST_ITEMS());
39         const response = await services.workflowService.list();
40         dispatch(runProcessPanelActions.SET_WORKFLOWS(response.items));
41     };
42
43 export const setUuidPrefix = (uuidPrefix: string) =>
44     propertiesActions.SET_PROPERTY({ key: UUID_PREFIX_PROPERTY_NAME, value: uuidPrefix });
45
46 export const getUuidPrefix = (state: RootState) => {
47     return state.properties.uuidPrefix;
48 };
49
50 export const openRunProcess = (workflowUuid: string, ownerUuid?: string, name?: string, inputObj?: { [key: string]: any }) =>
51     async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
52         const response = await services.workflowService.list();
53         dispatch(runProcessPanelActions.SET_WORKFLOWS(response.items));
54
55         const workflows = getState().runProcessPanel.searchWorkflows;
56         const workflow = workflows.find(workflow => workflow.uuid === workflowUuid);
57         if (workflow) {
58             dispatch<any>(navigateToRunProcess);
59             dispatch<any>(goToStep(1));
60             dispatch(runProcessPanelActions.SET_STEP_CHANGED(true));
61             dispatch(runProcessPanelActions.SET_SELECTED_WORKFLOW(workflow));
62             dispatch<any>(loadPresets(workflow.uuid));
63
64             dispatch(initialize(RUN_PROCESS_ADVANCED_FORM, getWorkflowRunnerSettings(workflow)));
65             let owner;
66             if (ownerUuid) {
67                 // Must be writable.
68                 owner = getResource<ProjectResource | UserResource>(ownerUuid)(getState().resources);
69                 if (!owner || !owner.canWrite) {
70                     owner = undefined;
71                 }
72             }
73             if (owner) {
74                 dispatch(runProcessPanelActions.SET_PROCESS_OWNER_UUID(owner.uuid));
75             }
76
77             dispatch(initialize(RUN_PROCESS_BASIC_FORM, { name, owner }));
78
79             const definition = parseWorkflowDefinition(workflow);
80             if (definition) {
81                 const inputs = getWorkflowInputs(definition);
82                 if (inputs) {
83                     const values = inputs.reduce((values, input) => ({
84                         ...values,
85                         [input.id]: input.default,
86                     }), {});
87                     dispatch(initialize(RUN_PROCESS_INPUTS_FORM, values));
88                 }
89             }
90
91             if (inputObj) {
92                 dispatch(initialize(RUN_PROCESS_INPUTS_FORM, inputObj));
93             }
94         } else {
95             dispatch<any>(snackbarActions.OPEN_SNACKBAR({ message: `You can't run this process` }));
96         }
97     };
98
99 export const getPublicUserUuid = (state: RootState) => {
100     const prefix = state.auth.localCluster;
101     return `${prefix}-tpzed-anonymouspublic`;
102 };
103 export const getPublicGroupUuid = (state: RootState) => {
104     const prefix = state.auth.localCluster;
105     return `${prefix}-j7d0g-anonymouspublic`;
106 };
107 export const getAllUsersGroupUuid = (state: RootState) => {
108     const prefix = state.auth.localCluster;
109     return `${prefix}-j7d0g-fffffffffffffff`;
110 };
111
112 export const showWorkflowDetails = (uuid: string) =>
113     propertiesActions.SET_PROPERTY({ key: WORKFLOW_PANEL_DETAILS_UUID, value: uuid });
114
115 export const getWorkflowDetails = (state: RootState) => {
116     const uuid = getProperty<string>(WORKFLOW_PANEL_DETAILS_UUID)(state.properties);
117     const workflows = state.runProcessPanel.workflows;
118     const workflow = workflows.find(workflow => workflow.uuid === uuid);
119     return workflow || undefined;
120 };
121
122 export const deleteWorkflow = (workflowUuid: string, ownerUuid: string) =>
123     async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
124         dispatch<any>(navigateTo(ownerUuid));
125         dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...', kind: SnackbarKind.INFO }));
126         await services.workflowService.delete(workflowUuid);
127         dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removed.', hideDuration: 2000, kind: SnackbarKind.SUCCESS }));
128     };