15672: Update container runtime every 5 seconds
[arvados-workbench2.git] / src / websocket / websocket.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { RootStore } from '~/store/store';
6 import { AuthService } from '~/services/auth-service/auth-service';
7 import { Config } from '~/common/config';
8 import { WebSocketService } from './websocket-service';
9 import { ResourceEventMessage } from './resource-event-message';
10 import { ResourceKind } from '~/models/resource';
11 import { loadProcess } from '~/store/processes/processes-actions';
12 // import { loadContainers } from '~/store/processes/processes-actions';
13 import { LogEventType } from '~/models/log';
14 import { addProcessLogsPanelItem } from '../store/process-logs-panel/process-logs-panel-actions';
15 // import { FilterBuilder } from "~/services/api/filter-builder";
16 import { subprocessPanelActions } from "~/store/subprocess-panel/subprocess-panel-actions";
17 import { projectPanelActions } from "~/store/project-panel/project-panel-action";
18 import { getProjectPanelCurrentUuid } from '~/store/project-panel/project-panel-action';
19
20 export const initWebSocket = (config: Config, authService: AuthService, store: RootStore) => {
21     if (config.websocketUrl) {
22         const webSocketService = new WebSocketService(config.websocketUrl, authService);
23         webSocketService.setMessageListener(messageListener(store));
24         webSocketService.connect();
25     } else {
26         console.warn("WARNING: Websocket ExternalURL is not set on the cluster config.");
27     }
28 };
29
30 const messageListener = (store: RootStore) => (message: ResourceEventMessage) => {
31     if (message.eventType === LogEventType.CREATE || message.eventType === LogEventType.UPDATE) {
32         switch (message.objectKind) {
33             case ResourceKind.CONTAINER_REQUEST:
34                 if (store.getState().processPanel.containerRequestUuid === message.objectUuid) {
35                     store.dispatch(loadProcess(message.objectUuid));
36                 }
37             // fall through, this will happen for container requests as well.
38             case ResourceKind.CONTAINER:
39                 store.dispatch(subprocessPanelActions.REQUEST_ITEMS());
40                 if (message.objectOwnerUuid === getProjectPanelCurrentUuid(store.getState())) {
41                     store.dispatch(projectPanelActions.REQUEST_ITEMS());
42                 }
43                 return;
44             default:
45                 return;
46         }
47     } else {
48         return store.dispatch(addProcessLogsPanelItem(message as ResourceEventMessage<{ text: string }>));
49     }
50 };