X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/12f7c81e19e444b35bf7fd0de34cd4761ec7d5e7..83e9d2714298456b24b2836c783fe9e2430c263d:/src/store/process-logs-panel/process-logs-panel-actions.ts diff --git a/src/store/process-logs-panel/process-logs-panel-actions.ts b/src/store/process-logs-panel/process-logs-panel-actions.ts index 77a3cef7..bf0dc935 100644 --- a/src/store/process-logs-panel/process-logs-panel-actions.ts +++ b/src/store/process-logs-panel/process-logs-panel-actions.ts @@ -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 { navigateToCollection } 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(), ADD_PROCESS_LOGS_PANEL_ITEM: ofType<{ logType: string, log: string }>(), @@ -23,8 +28,12 @@ export const processLogsPanelActions = unionize({ export type ProcessLogsPanelAction = UnionOf; +export const setProcessLogsPanelFilter = (filter: string) => + processLogsPanelActions.SET_PROCESS_LOGS_PANEL_FILTER(filter); + export const initProcessLogsPanel = (processUuid: string) => async (dispatch: Dispatch, getState: () => RootState, { logService }: ServiceRepository) => { + dispatch(processLogsPanelActions.RESET_PROCESS_LOGS_PANEL()); const process = await dispatch(loadProcess(processUuid)); if (process.container) { const logResources = await loadContainerLogs(process.container.uuid, logService); @@ -33,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) @@ -51,19 +84,32 @@ const loadContainerLogs = async (containerUuid: string, logService: LogService) }; const createInitialLogPanelState = (logResources: LogResource[]) => { - const allLogs = logResources.map(({ properties }) => properties.text); + const allLogs = logsToLines(logResources); const groupedLogResources = groupBy(logResources, log => log.eventType); const groupedLogs = Object .keys(groupedLogResources) .reduce((grouped, key) => ({ ...grouped, - [key]: groupedLogResources[key].map(({ properties }) => properties.text) + [key]: logsToLines(groupedLogResources[key]) }), {}); const filters = [SUMMARIZED_FILTER_TYPE, ...Object.keys(groupedLogs)]; const logs = { [SUMMARIZED_FILTER_TYPE]: allLogs, ...groupedLogs }; return { filters, logs }; }; +const logsToLines = (logs: LogResource[]) => + logs.map(({ properties }) => properties.text); + +export const navigateToLogCollection = (uuid: string) => + async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => { + try { + await services.collectionService.get(uuid); + dispatch(navigateToCollection(uuid)); + } catch { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'This collection does not exists!', hideDuration: 2000, kind: SnackbarKind.ERROR })); + } + }; + const MAX_AMOUNT_OF_LOGS = 10000; const SUMMARIZED_FILTER_TYPE = 'Summarized';