import "./pod-details-container.scss"; import React from "react"; import { IPodContainer, IPodContainerStatus, Pod } from "../../api/endpoints"; import { DrawerItem } from "../drawer"; import { cssNames } from "../../utils"; import { StatusBrick } from "../status-brick"; import { Badge } from "../badge"; import { ContainerEnvironment } from "./pod-container-env"; import { PodContainerPort } from "./pod-container-port"; import { ResourceMetrics } from "../resource-metrics"; import { IMetrics } from "../../api/endpoints/metrics.api"; import { ContainerCharts } from "./container-charts"; import { userStore } from "../../../common/user-store"; import { ResourceType } from "../+preferences/select-metrics-dialog"; interface Props { pod: Pod; container: IPodContainer; metrics?: { [key: string]: IMetrics }; } export class PodDetailsContainer extends React.Component { renderStatus(state: string, status: IPodContainerStatus) { const ready = status ? status.ready : ""; return ( {state}{ready ? `, ready` : ""} {state === "terminated" ? ` - ${status.state.terminated.reason} (exit code: ${status.state.terminated.exitCode})` : ""} ); } renderLastState(lastState: string, status: IPodContainerStatus) { if (lastState === "terminated") { return ( {lastState}
Reason: {status.lastState.terminated.reason} - exit code: {status.lastState.terminated.exitCode}
Started at: {status.lastState.terminated.startedAt}
Finished at: {status.lastState.terminated.finishedAt}
); } } render() { const { pod, container, metrics } = this.props; if (!pod || !container) return null; const { name, image, imagePullPolicy, ports, volumeMounts, command, args } = container; const status = pod.getContainerStatuses().find(status => status.name === container.name); const state = status ? Object.keys(status.state)[0] : ""; const lastState = status ? Object.keys(status.lastState)[0] : ""; const ready = status ? status.ready : ""; const liveness = pod.getLivenessProbe(container); const readiness = pod.getReadinessProbe(container); const startup = pod.getStartupProbe(container); const isInitContainer = !!pod.getInitContainers().find(c => c.name == name); const metricTabs = [ "CPU", "Memory", "Filesystem", ]; const isMetricHidden = userStore.isMetricHidden(ResourceType.Container); return (
{name}
{!isMetricHidden && !isInitContainer && } {status && {this.renderStatus(state, status)} } {lastState && {this.renderLastState(lastState, status)} } {image} {imagePullPolicy && imagePullPolicy !== "IfNotPresent" && {imagePullPolicy} } {ports && ports.length > 0 && { ports.map((port) => { const key = `${container.name}-port-${port.containerPort}-${port.protocol}`; return( ); }) } } {} {volumeMounts && volumeMounts.length > 0 && { volumeMounts.map(mount => { const { name, mountPath, readOnly } = mount; return ( {mountPath} from {name} ({readOnly ? "ro" : "rw"}) ); }) } } {liveness.length > 0 && { liveness.map((value, index) => ( )) } } {readiness.length > 0 && { readiness.map((value, index) => ( )) } } {startup.length > 0 && { startup.map((value, index) => ( )) } } {command && {command.join(" ")} } {args && {args.join(" ")} }
); } }