mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Remove all usages of legacy global logger Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global storageClassApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global serviceApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global secretApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global resourceQuotaApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global persistentVolumeClaimApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global nodeApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global networkPolicyApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix formatting Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global configMapApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global jobApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global cronJobApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global podApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global roleApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove exports of NonInjected components - To improve auto-complete Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global catalogEntityRegistry Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add lint against using legacy global works Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint in KubeObject file Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global catalogCategoryRegistry Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global navigation Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global navigate Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove unneeded index file Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global customResourceDefinitionStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global eventStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global podSecurityPolicyStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global storageClassStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global persistentVolumeStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global clusterRoleBindingStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global clusterRoleStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global roleBindingStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move files around Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global roleStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global serviceAccountStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove usages of legacy global podStore Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove final uses of asLegacyGlobalForExtensionApi in application code Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint rule and start fixing lint errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make listHelmReleases injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make installHelmChart injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make deleteHelmRelease injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make getHelmReleaseValues injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make getHelmReleaseHistory injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make rollbackHelmRelease injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove unnecessary overrides from getDiForUnitTesting Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add global override for logger Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add global override for history Signed-off-by: Sebastian Malton <sebastian@malton.name> * Cleanup typing around getting injectables within jest Signed-off-by: Sebastian Malton <sebastian@malton.name> * Move some more overrides to global if needed Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add global override for forcusWindow Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint in KubeApi Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint in catalog/index.ts Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove last usages of legacy global getDetailsUrl Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove last usages of legacy global showDetails Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add functions back to extension API Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove all uses of legacy global Notification functions Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove no longer existing export Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove unnecessary overrides Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix injecting side effects by using more injectables Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix cluster role binding dialog Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix cluster role dialog Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix create service account dialog Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix history override Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make KubeApi consume its dependencies while not breaking the extension API Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Update snapshots Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix CephFs tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix user store tests by using override of config Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in hotbar store tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Add direct devDep of memfs Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in cluster store tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in router tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in kube auth proxy tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in log resource selector tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in hotbar remove command tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in the select component tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove mock-fs as a dependency Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove no longer necessary mocks Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix namespace select filter tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove use of mockFs in the extension loader tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixing edit-namespace-from-new-tab test Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix app paths tests by making the tests run in "production" mode Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove last vestiges of isTestEnv and the is* globals Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix delete-cluster-dialog tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix install-helm-chart-from-previously-opened-tab tests - Split out storage initialization to a runnable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove unnecessary override of non side effect injectable Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix disable-kube-object-detail-items-when-cluster-is-not-relevant tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix reactively-hide-kube-object-detail-item tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint Signed-off-by: Sebastian Malton <sebastian@malton.name> * Update snapshots Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix sidebar-and-tab-navigation-for-core tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove need to override lensLocalStoragePath in tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Replace more overrides with global ones Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix typings Signed-off-by: Sebastian Malton <sebastian@malton.name> * Remove no longer needed technical test Signed-off-by: Sebastian Malton <sebastian@malton.name> * Update snapshots Signed-off-by: Sebastian Malton <sebastian@malton.name> Signed-off-by: Sebastian Malton <sebastian@malton.name>
264 lines
6.2 KiB
TypeScript
264 lines
6.2 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import type { BaseKubeObjectCondition, ClusterScopedMetadata } from "../kube-object";
|
|
import { KubeObject } from "../kube-object";
|
|
import { cpuUnitsToNumber, unitsToBytes, isObject } from "../../../renderer/utils";
|
|
import type { DerivedKubeApiOptions, KubeApiDependencies } from "../kube-api";
|
|
import { KubeApi } from "../kube-api";
|
|
import { TypedRegEx } from "typed-regex";
|
|
|
|
export class NodeApi extends KubeApi<Node> {
|
|
constructor(deps: KubeApiDependencies, opts?: DerivedKubeApiOptions) {
|
|
super(deps, {
|
|
...opts ?? {},
|
|
objectConstructor: Node,
|
|
});
|
|
}
|
|
}
|
|
|
|
export interface NodeTaint {
|
|
key: string;
|
|
value?: string;
|
|
effect: string;
|
|
timeAdded: string;
|
|
}
|
|
|
|
export function formatNodeTaint(taint: NodeTaint): string {
|
|
if (taint.value) {
|
|
return `${taint.key}=${taint.value}:${taint.effect}`;
|
|
}
|
|
|
|
return `${taint.key}:${taint.effect}`;
|
|
}
|
|
|
|
export interface NodeCondition extends BaseKubeObjectCondition {
|
|
/**
|
|
* Last time we got an update on a given condition.
|
|
*/
|
|
lastHeartbeatTime?: string;
|
|
}
|
|
|
|
/**
|
|
* These role label prefixs are the ones that are for master nodes
|
|
*
|
|
* The `master` label has been deprecated in Kubernetes 1.20, and will be removed in 1.25 so we
|
|
* have to also use the newer `control-plane` label
|
|
*/
|
|
const masterNodeLabels = [
|
|
"master",
|
|
"control-plane",
|
|
];
|
|
|
|
/**
|
|
* This regex is used in the `getRoleLabels()` method bellow, but placed here
|
|
* as factoring out regexes is best practice.
|
|
*/
|
|
const nodeRoleLabelKeyMatcher = TypedRegEx("^.*node-role.kubernetes.io/+(?<role>.+)$");
|
|
|
|
export interface NodeSpec {
|
|
podCIDR?: string;
|
|
podCIDRs?: string[];
|
|
providerID?: string;
|
|
/**
|
|
* @deprecated see https://issues.k8s.io/61966
|
|
*/
|
|
externalID?: string;
|
|
taints?: NodeTaint[];
|
|
unschedulable?: boolean;
|
|
}
|
|
|
|
export interface NodeAddress {
|
|
type: "Hostname" | "ExternalIP" | "InternalIP";
|
|
address: string;
|
|
}
|
|
|
|
export interface NodeStatusResources extends Partial<Record<string, string>> {
|
|
cpu?: string;
|
|
"ephemeral-storage"?: string;
|
|
"hugepages-1Gi"?: string;
|
|
"hugepages-2Mi"?: string;
|
|
memory?: string;
|
|
pods?: string;
|
|
}
|
|
|
|
export interface ConfigMapNodeConfigSource {
|
|
kubeletConfigKey: string;
|
|
name: string;
|
|
namespace: string;
|
|
resourceVersion?: string;
|
|
uid?: string;
|
|
}
|
|
|
|
export interface NodeConfigSource {
|
|
configMap?: ConfigMapNodeConfigSource;
|
|
}
|
|
|
|
export interface NodeConfigStatus {
|
|
active?: NodeConfigSource;
|
|
assigned?: NodeConfigSource;
|
|
lastKnownGood?: NodeConfigSource;
|
|
error?: string;
|
|
}
|
|
|
|
export interface DaemonEndpoint {
|
|
Port: number; //it must be uppercase for backwards compatibility
|
|
}
|
|
|
|
export interface NodeDaemonEndpoints {
|
|
kubeletEndpoint?: DaemonEndpoint;
|
|
}
|
|
|
|
export interface ContainerImage {
|
|
names?: string[];
|
|
sizeBytes?: number;
|
|
}
|
|
|
|
export interface NodeSystemInfo {
|
|
architecture: string;
|
|
bootID: string;
|
|
containerRuntimeVersion: string;
|
|
kernelVersion: string;
|
|
kubeProxyVersion: string;
|
|
kubeletVersion: string;
|
|
machineID: string;
|
|
operatingSystem: string;
|
|
osImage: string;
|
|
systemUUID: string;
|
|
}
|
|
|
|
export interface AttachedVolume {
|
|
name: string;
|
|
devicePath: string;
|
|
}
|
|
|
|
export interface NodeStatus {
|
|
capacity?: NodeStatusResources;
|
|
allocatable?: NodeStatusResources;
|
|
conditions?: NodeCondition[];
|
|
addresses?: NodeAddress[];
|
|
config?: NodeConfigStatus;
|
|
daemonEndpoints?: NodeDaemonEndpoints;
|
|
images?: ContainerImage[];
|
|
nodeInfo?: NodeSystemInfo;
|
|
phase?: string;
|
|
volumesInUse?: string[];
|
|
volumesAttached?: AttachedVolume[];
|
|
}
|
|
|
|
export class Node extends KubeObject<
|
|
ClusterScopedMetadata,
|
|
NodeStatus,
|
|
NodeSpec
|
|
> {
|
|
static readonly kind = "Node";
|
|
static readonly namespaced = false;
|
|
static readonly apiBase = "/api/v1/nodes";
|
|
|
|
/**
|
|
* Returns the concatination of all current condition types which have a status
|
|
* of `"True"`
|
|
*/
|
|
getNodeConditionText(): string {
|
|
if (!this.status?.conditions) {
|
|
return "";
|
|
}
|
|
|
|
return this.status.conditions
|
|
.filter(condition => condition.status === "True")
|
|
.map(condition => condition.type)
|
|
.join(" ");
|
|
}
|
|
|
|
getTaints() {
|
|
return this.spec.taints || [];
|
|
}
|
|
|
|
isMasterNode(): boolean {
|
|
return this.getRoleLabelItems()
|
|
.some(roleLabel => masterNodeLabels.includes(roleLabel));
|
|
}
|
|
|
|
getRoleLabelItems(): string[] {
|
|
const { labels } = this.metadata;
|
|
const roleLabels: string[] = [];
|
|
|
|
if (!isObject(labels)) {
|
|
return roleLabels;
|
|
}
|
|
|
|
for (const labelKey of Object.keys(labels)) {
|
|
const match = nodeRoleLabelKeyMatcher.match(labelKey);
|
|
|
|
if (match?.groups) {
|
|
roleLabels.push(match.groups.role);
|
|
}
|
|
}
|
|
|
|
if (typeof labels["kubernetes.io/role"] === "string") {
|
|
roleLabels.push(labels["kubernetes.io/role"]);
|
|
}
|
|
|
|
if (typeof labels["node.kubernetes.io/role"] === "string") {
|
|
roleLabels.push(labels["node.kubernetes.io/role"]);
|
|
}
|
|
|
|
return roleLabels;
|
|
}
|
|
|
|
getRoleLabels(): string {
|
|
return this.getRoleLabelItems().join(", ");
|
|
}
|
|
|
|
getCpuCapacity() {
|
|
if (!this.status?.capacity || !this.status.capacity.cpu) return 0;
|
|
|
|
return cpuUnitsToNumber(this.status.capacity.cpu);
|
|
}
|
|
|
|
getMemoryCapacity() {
|
|
if (!this.status?.capacity || !this.status.capacity.memory) return 0;
|
|
|
|
return unitsToBytes(this.status.capacity.memory);
|
|
}
|
|
|
|
getConditions(): NodeCondition[] {
|
|
const conditions = this.status?.conditions || [];
|
|
|
|
if (this.isUnschedulable()) {
|
|
return [{ type: "SchedulingDisabled", status: "True" }, ...conditions];
|
|
}
|
|
|
|
return conditions;
|
|
}
|
|
|
|
getActiveConditions() {
|
|
return this.getConditions().filter(c => c.status === "True");
|
|
}
|
|
|
|
getWarningConditions() {
|
|
const goodConditions = ["Ready", "HostUpgrades", "SchedulingDisabled"];
|
|
|
|
return this.getActiveConditions().filter(condition => {
|
|
return !goodConditions.includes(condition.type);
|
|
});
|
|
}
|
|
|
|
getKubeletVersion() {
|
|
return this.status?.nodeInfo?.kubeletVersion ?? "<unknown>";
|
|
}
|
|
|
|
getOperatingSystem(): string {
|
|
return this.metadata?.labels?.["kubernetes.io/os"]
|
|
|| this.metadata?.labels?.["beta.kubernetes.io/os"]
|
|
|| this.status?.nodeInfo?.operatingSystem
|
|
|| "linux";
|
|
}
|
|
|
|
isUnschedulable() {
|
|
return this.spec.unschedulable;
|
|
}
|
|
}
|