X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/cf9e11013710478809fe44b5cad7d3b77f6d5a1f..a23cfd6defb8dab9ac9afe13034f7b667f07acca:/src/store/process-logs-panel/process-logs-panel-actions.ts?ds=inline 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 62c9a25dd3..d4f5ab5924 100644 --- a/src/store/process-logs-panel/process-logs-panel-actions.ts +++ b/src/store/process-logs-panel/process-logs-panel-actions.ts @@ -2,20 +2,21 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { unionize, ofType, UnionOf } from "~/common/unionize"; +import { unionize, ofType, UnionOf } from "common/unionize"; import { ProcessLogs, getProcessLogsPanelCurrentUuid } from './process-logs-panel'; -import { LogEventType } from '~/models/log'; -import { RootState } from '~/store/store'; -import { ServiceRepository } from '~/services/services'; +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 { 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<{}>(), @@ -32,8 +33,8 @@ 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(loadProcess(processUuid)); - if (process.container) { + const process = getProcess(processUuid)(getState().resources); + if (process && process.container) { const logResources = await loadContainerLogs(process.container.uuid, logService); const initialState = createInitialLogPanelState(logResources); dispatch(processLogsPanelActions.INIT_PROCESS_LOGS_PANEL(initialState)); @@ -43,22 +44,26 @@ 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 uuid = getProcessLogsPanelCurrentUuid(getState().router); + if (!uuid) { return } + const process = getProcess(uuid)(getState().resources); + if (!process) { return } + const { containerRequest, container } = process; + if (message.objectUuid === containerRequest.uuid + || (container && message.objectUuid === container.uuid)) { + dispatch(processLogsPanelActions.ADD_PROCESS_LOGS_PANEL_ITEM({ + logType: ALL_FILTER_TYPE, + log: message.properties.text + })); + dispatch(processLogsPanelActions.ADD_PROCESS_LOGS_PANEL_ITEM({ + logType: message.eventType, + log: message.properties.text + })); + if (MAIN_EVENT_TYPES.indexOf(message.eventType) > -1) { + dispatch(processLogsPanelActions.ADD_PROCESS_LOGS_PANEL_ITEM({ + logType: MAIN_FILTER_TYPE, + log: message.properties.text + })); } } } @@ -66,8 +71,8 @@ export const addProcessLogsPanelItem = (message: ResourceEventMessage<{ text: st const loadContainerLogs = async (containerUuid: string, logService: LogService) => { const requestFilters = new FilterBuilder() - .addEqual('objectUuid', containerUuid) - .addIn('eventType', PROCESS_PANEL_LOG_EVENT_TYPES) + .addEqual('object_uuid', containerUuid) + .addIn('event_type', PROCESS_PANEL_LOG_EVENT_TYPES) .getFilters(); const requestOrder = new OrderBuilder() .addAsc('eventAt') @@ -83,6 +88,9 @@ const loadContainerLogs = async (containerUuid: string, logService: LogService) const createInitialLogPanelState = (logResources: LogResource[]) => { const allLogs = logsToLines(logResources); + const mainLogs = logsToLines(logResources.filter( + e => MAIN_EVENT_TYPES.indexOf(e.eventType) > -1 + )); const groupedLogResources = groupBy(logResources, log => log.eventType); const groupedLogs = Object .keys(groupedLogResources) @@ -90,17 +98,38 @@ const createInitialLogPanelState = (logResources: LogResource[]) => { ...grouped, [key]: logsToLines(groupedLogResources[key]) }), {}); - const filters = [SUMMARIZED_FILTER_TYPE, ...Object.keys(groupedLogs)]; - const logs = { [SUMMARIZED_FILTER_TYPE]: allLogs, ...groupedLogs }; + const filters = [MAIN_FILTER_TYPE, ALL_FILTER_TYPE, ...Object.keys(groupedLogs)]; + const logs = { + [MAIN_FILTER_TYPE]: mainLogs, + [ALL_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(navigateTo(uuid)); + } catch { + dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Could not request collection', hideDuration: 2000, kind: SnackbarKind.ERROR })); + } + }; + const MAX_AMOUNT_OF_LOGS = 10000; -const SUMMARIZED_FILTER_TYPE = 'Summarized'; +const ALL_FILTER_TYPE = 'All logs'; + +const MAIN_FILTER_TYPE = 'Main logs'; +const MAIN_EVENT_TYPES = [ + LogEventType.CRUNCH_RUN, + LogEventType.STDERR, + LogEventType.STDOUT, +]; const PROCESS_PANEL_LOG_EVENT_TYPES = [ LogEventType.ARV_MOUNT, @@ -111,4 +140,6 @@ const PROCESS_PANEL_LOG_EVENT_TYPES = [ LogEventType.NODE_INFO, LogEventType.STDERR, LogEventType.STDOUT, + LogEventType.CONTAINER, + LogEventType.KEEPSTORE, ];