mirror of https://github.com/portainer/portainer
68 lines
2.9 KiB
JavaScript
68 lines
2.9 KiB
JavaScript
import _ from 'lodash-es';
|
|||
|
|||
import { KubernetesNode, KubernetesNodeDetails } from 'Kubernetes/node/models';
|
|||
import KubernetesResourceReservationHelper from 'Kubernetes/helpers/resourceReservationHelper';
|
|||
|
|||
class KubernetesNodeConverter {
|
|||
static apiToNode(data, res) {
|
|||
if (!res) {
|
|||
res = new KubernetesNode();
|
|||
}
|
|||
res.Id = data.metadata.uid;
|
|||
const hostName = _.find(data.status.addresses, { type: 'Hostname' });
|
|||
res.Name = hostName ? hostName.address : data.metadata.Name;
|
|||
res.Labels = data.metadata.labels;
|
|||
|
res.Role = _.has(data.metadata.labels, 'node-role.kubernetes.io/master') ? 'Master' : 'Worker';
|
||
|
|||
const ready = _.find(data.status.conditions, { type: KubernetesNodeConditionTypes.READY });
|
|||
const memoryPressure = _.find(data.status.conditions, { type: KubernetesNodeConditionTypes.MEMORY_PRESSURE });
|
|||
const PIDPressure = _.find(data.status.conditions, { type: KubernetesNodeConditionTypes.PID_PRESSURE });
|
|||
const diskPressure = _.find(data.status.conditions, { type: KubernetesNodeConditionTypes.DISK_PRESSURE });
|
|||
const networkUnavailable = _.find(data.status.conditions, { type: KubernetesNodeConditionTypes.NETWORK_UNAVAILABLE });
|
|||
|
|||
res.Conditions = {
|
|||
MemoryPressure: memoryPressure && memoryPressure.status === 'True',
|
|||
PIDPressure: PIDPressure && PIDPressure.status === 'True',
|
|||
DiskPressure: diskPressure && diskPressure.status === 'True',
|
|||
NetworkUnavailable: networkUnavailable && networkUnavailable.status === 'True',
|
|||
};
|
|||
|
|||
if (ready.status === 'False') {
|
|||
res.Status = 'Unhealthy';
|
|||
} else if (ready.status === 'Unknown' || res.Conditions.MemoryPressure || res.Conditions.PIDPressure || res.Conditions.DiskPressure || res.Conditions.NetworkUnavailable) {
|
|||
res.Status = 'Warning';
|
|||
} else {
|
|||
res.Status = 'Ready';
|
|||
}
|
|||
|
|||
res.CPU = KubernetesResourceReservationHelper.parseCPU(data.status.allocatable.cpu);
|
|||
res.Memory = data.status.allocatable.memory;
|
|||
res.Version = data.status.nodeInfo.kubeletVersion;
|
|||
const internalIP = _.find(data.status.addresses, { type: 'InternalIP' });
|
|||
res.IPAddress = internalIP ? internalIP.address : '-';
|
|||
res.Taints = data.spec.taints ? data.spec.taints : [];
|
|||
return res;
|
|||
}
|
|||
|
|||
static apiToNodeDetails(data, yaml) {
|
|||
let res = new KubernetesNodeDetails();
|
|||
res = KubernetesNodeConverter.apiToNode(data, res);
|
|||
res.CreationDate = data.metadata.creationTimestamp;
|
|||
res.OS.Architecture = data.status.nodeInfo.architecture;
|
|||
res.OS.Platform = data.status.nodeInfo.operatingSystem;
|
|||
res.OS.Image = data.status.nodeInfo.osImage;
|
|||
res.Yaml = yaml ? yaml.data : '';
|
|||
return res;
|
|||
}
|
|||
}
|
|||
|
|||
export const KubernetesNodeConditionTypes = Object.freeze({
|
|||
READY: 'Ready',
|
|||
MEMORY_PRESSURE: 'MemoryPressure',
|
|||
PID_PRESSURE: 'PIDPressure',
|
|||
DISK_PRESSURE: 'DiskPressure',
|
|||
NETWORK_UNAVAILABLE: 'NetworkUnavailable',
|
|||
});
|
|||
|
|||
export default KubernetesNodeConverter;
|