Skip to content

Commit

Permalink
ui: add pods reducer typing
Browse files Browse the repository at this point in the history
Refs: #2999
  • Loading branch information
JBWatenbergScality committed Dec 24, 2020
1 parent d7c80fa commit 604d898
Showing 1 changed file with 26 additions and 6 deletions.
32 changes: 26 additions & 6 deletions ui/src/ducks/app/pods.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//@flow
import { V1ContainerStatus, V1Pod, V1PodList } from '@kubernetes/client-node/dist/gen/model/models';
import { call, put, takeLatest } from 'redux-saga/effects';
import * as CoreApi from '../../services/k8s/core';

Expand All @@ -10,7 +12,25 @@ const defaultState = {
list: [],
};

export default function reducer(state = defaultState, action = {}) {
export type Pod = {
name: string,
namespace: string,
nodeName: string,
status: string,
startTime: string,
restartCount: number,
volumes: {
name: string,
persistentVolumeClaim: string,
}[],
containerStatuses: V1ContainerStatus[],
}

export type PodsState = {
list: Pod[]
}

export default function reducer(state: PodsState = defaultState, action: any = {}) {
switch (action.type) {
case SET_PODS:
return { ...state, list: action.payload };
Expand All @@ -24,17 +44,17 @@ export const fetchPodsAction = () => {
return { type: FETCH_PODS };
};

export const setPodsAction = (payload) => {
export const setPodsAction = (payload: Pod[]) => {
return { type: SET_PODS, payload };
};

// Sagas
export function* fetchPods() {
export function* fetchPods(): Generator<any, void, {body: V1PodList} | {error: any}> {
const result = yield call(CoreApi.getPods);
if (!result.error) {
yield put(
setPodsAction(
result.body.items.map((pod) => ({
result.body.items.map((pod: V1Pod) => ({
name: pod.metadata.name,
namespace: pod.metadata.namespace,
nodeName: pod.spec.nodeName,
Expand All @@ -44,7 +64,7 @@ export function* fetchPods() {
pod.status.containerStatuses && pod.status.containerStatuses.length
? pod.status.containerStatuses[0].restartCount
: 0,
volumes: pod?.spec?.volumes?.map((volume) => ({
volumes: (pod?.spec?.volumes || []).map((volume) => ({
name: volume.name,
persistentVolumeClaim: volume?.persistentVolumeClaim?.claimName,
})),
Expand All @@ -55,6 +75,6 @@ export function* fetchPods() {
}
}

export function* podsSaga() {
export function* podsSaga(): Generator<void, void, void> {
yield takeLatest(FETCH_PODS, fetchPods);
}

0 comments on commit 604d898

Please sign in to comment.