X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/847ac07f82a1432d6472390aab5e8c2198d425a5..1514f6a2ae8103f75f08034299115ad751d8a785:/src/store/run-process-panel/run-process-panel-actions.ts diff --git a/src/store/run-process-panel/run-process-panel-actions.ts b/src/store/run-process-panel/run-process-panel-actions.ts index 299f387e..7112f715 100644 --- a/src/store/run-process-panel/run-process-panel-actions.ts +++ b/src/store/run-process-panel/run-process-panel-actions.ts @@ -6,16 +6,90 @@ import { Dispatch } from 'redux'; import { unionize, ofType, UnionOf } from "~/common/unionize"; import { ServiceRepository } from "~/services/services"; import { RootState } from '~/store/store'; +import { WorkflowResource } from '~/models/workflow'; +import { getFormValues } from 'redux-form'; +import { RUN_PROCESS_BASIC_FORM, RunProcessBasicFormData } from '~/views/run-process-panel/run-process-basic-form'; +import { RUN_PROCESS_INPUTS_FORM } from '~/views/run-process-panel/run-process-inputs-form'; +import { WorkflowInputsData } from '~/models/workflow'; +import { createWorkflowMounts } from '~/models/process'; +import { ContainerRequestState } from '~/models/container-request'; +import { navigateToProcess } from '../navigation/navigation-action'; +import { RunProcessAdvancedFormData, RUN_PROCESS_ADVANCED_FORM } from '~/views/run-process-panel/run-process-advanced-form'; export const runProcessPanelActions = unionize({ - SET_CURRENT_STEP: ofType() + SET_PROCESS_OWNER_UUID: ofType(), + SET_CURRENT_STEP: ofType(), + SET_WORKFLOWS: ofType(), + SET_SELECTED_WORKFLOW: ofType(), + SEARCH_WORKFLOWS: ofType() }); +export interface RunProcessSecondStepDataFormProps { + name: string; + description: string; +} + +export const RUN_PROCESS_SECOND_STEP_FORM_NAME = 'runProcessSecondStepFormName'; + export type RunProcessPanelAction = UnionOf; export const loadRunProcessPanel = () => - (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { - + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + try { + const response = await services.workflowService.list(); + dispatch(runProcessPanelActions.SET_WORKFLOWS(response.items)); + } catch (e) { + return; + } + }; + +export const setWorkflow = (workflow: WorkflowResource) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + dispatch(runProcessPanelActions.SET_SELECTED_WORKFLOW(workflow)); }; -export const goToStep = (step: number) => runProcessPanelActions.SET_CURRENT_STEP(step); \ No newline at end of file +export const goToStep = (step: number) => runProcessPanelActions.SET_CURRENT_STEP(step); + +export const runProcess = async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + const state = getState(); + const basicForm = getFormValues(RUN_PROCESS_BASIC_FORM)(state) as RunProcessBasicFormData; + const inputsForm = getFormValues(RUN_PROCESS_INPUTS_FORM)(state) as WorkflowInputsData; + const advancedForm = getFormValues(RUN_PROCESS_ADVANCED_FORM)(state) as RunProcessAdvancedFormData; + const { processOwnerUuid, selectedWorkflow } = state.runProcessPanel; + if (selectedWorkflow) { + const newProcessData = { + ownerUuid: processOwnerUuid, + name: basicForm.name, + description: basicForm.description, + state: ContainerRequestState.COMMITTED, + mounts: createWorkflowMounts(selectedWorkflow, normalizeInputKeys(inputsForm)), + runtimeConstraints: { + API: true, + vcpus: 1, + ram: 1073741824, + }, + containerImage: 'arvados/jobs:1.1.4.20180618144723', + cwd: '/var/spool/cwl', + command: [ + 'arvados-cwl-runner', + '--local', + '--api=containers', + `--project-uuid=${processOwnerUuid}`, + '/var/lib/cwl/workflow.json#main', + '/var/lib/cwl/cwl.input.json' + ], + outputPath: '/var/spool/cwl', + priority: 1, + outputName: advancedForm && advancedForm.output ? advancedForm.output : undefined, + }; + const newProcess = await services.containerRequestService.create(newProcessData); + dispatch(navigateToProcess(newProcess.uuid)); + } +}; + +const normalizeInputKeys = (inputs: WorkflowInputsData): WorkflowInputsData => + Object.keys(inputs).reduce((normalizedInputs, key) => ({ + ...normalizedInputs, + [key.split('/').slice(1).join('/')]: inputs[key], + }), {}); +export const searchWorkflows = (term: string) => runProcessPanelActions.SEARCH_WORKFLOWS(term);