15230: Link to other workbenches when double-clicking search results.
[arvados-workbench2.git] / src / store / process-logs-panel / process-logs-panel-actions.ts
index 395d26fe5fb71d5120c6c3a7c07fc50da75043e4..fcb1b0ea970bc528dd0c254d08590e6fdba743d1 100644 (file)
@@ -3,19 +3,24 @@
 // SPDX-License-Identifier: AGPL-3.0
 
 import { unionize, ofType, UnionOf } from "~/common/unionize";
-import { ProcessLogs } from './process-logs-panel';
+import { ProcessLogs, getProcessLogsPanelCurrentUuid } from './process-logs-panel';
 import { LogEventType } from '~/models/log';
 import { RootState } from '~/store/store';
 import { ServiceRepository } from '~/services/services';
 import { Dispatch } from 'redux';
-import { FilterBuilder } from '~/common/api/filter-builder';
 import { groupBy } from 'lodash';
 import { loadProcess } from '~/store/processes/processes-actions';
-import { OrderBuilder } from '~/common/api/order-builder';
 import { LogResource } from '~/models/log';
 import { LogService } from '~/services/log-service/log-service';
+import { ResourceEventMessage } from '~/websocket/resource-event-message';
+import { getProcess } from '~/store/processes/process';
+import { FilterBuilder } from "~/services/api/filter-builder";
+import { OrderBuilder } from "~/services/api/order-builder";
+import { navigateTo } from '~/store/navigation/navigation-action';
+import { snackbarActions, SnackbarKind } from '~/store/snackbar/snackbar-actions';
 
 export const processLogsPanelActions = unionize({
+    RESET_PROCESS_LOGS_PANEL: ofType<{}>(),
     INIT_PROCESS_LOGS_PANEL: ofType<{ filters: string[], logs: ProcessLogs }>(),
     SET_PROCESS_LOGS_PANEL_FILTER: ofType<string>(),
     ADD_PROCESS_LOGS_PANEL_ITEM: ofType<{ logType: string, log: string }>(),
@@ -28,6 +33,7 @@ export const setProcessLogsPanelFilter = (filter: string) =>
 
 export const initProcessLogsPanel = (processUuid: string) =>
     async (dispatch: Dispatch, getState: () => RootState, { logService }: ServiceRepository) => {
+        dispatch(processLogsPanelActions.RESET_PROCESS_LOGS_PANEL());
         const process = await dispatch<any>(loadProcess(processUuid));
         if (process.container) {
             const logResources = await loadContainerLogs(process.container.uuid, logService);
@@ -36,6 +42,30 @@ export const initProcessLogsPanel = (processUuid: string) =>
         }
     };
 
+export const addProcessLogsPanelItem = (message: ResourceEventMessage<{ text: string }>) =>
+    async (dispatch: Dispatch, getState: () => RootState, { logService }: ServiceRepository) => {
+        if (PROCESS_PANEL_LOG_EVENT_TYPES.indexOf(message.eventType) > -1) {
+            const uuid = getProcessLogsPanelCurrentUuid(getState());
+            if (uuid) {
+                const process = getProcess(uuid)(getState().resources);
+                if (process) {
+                    const { containerRequest, container } = process;
+                    if (message.objectUuid === containerRequest.uuid
+                        || container && message.objectUuid === container.uuid) {
+                        dispatch(processLogsPanelActions.ADD_PROCESS_LOGS_PANEL_ITEM({
+                            logType: SUMMARIZED_FILTER_TYPE,
+                            log: message.properties.text
+                        }));
+                        dispatch(processLogsPanelActions.ADD_PROCESS_LOGS_PANEL_ITEM({
+                            logType: message.eventType,
+                            log: message.properties.text
+                        }));
+                    }
+                }
+            }
+        }
+    };
+
 const loadContainerLogs = async (containerUuid: string, logService: LogService) => {
     const requestFilters = new FilterBuilder()
         .addEqual('objectUuid', containerUuid)
@@ -67,8 +97,18 @@ const createInitialLogPanelState = (logResources: LogResource[]) => {
     return { filters, logs };
 };
 
-const logsToLines = (logs: LogResource[]) => 
-    logs.map(({properties}) => properties.text);
+const logsToLines = (logs: LogResource[]) =>
+    logs.map(({ properties }) => properties.text);
+
+export const navigateToLogCollection = (uuid: string) =>
+    async (dispatch: Dispatch<any>, getState: () => RootState, services: ServiceRepository) => {
+        try {
+            await services.collectionService.get(uuid);
+            dispatch<any>(navigateTo(uuid));
+        } catch {
+            dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'This collection does not exists!', hideDuration: 2000, kind: SnackbarKind.ERROR }));
+        }
+    };
 
 const MAX_AMOUNT_OF_LOGS = 10000;