@k8slens/extensions 6.0.1-git.7ad7c89061.0 → 6.0.1-git.7c937db437.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/dist/src/common/app-event-bus/app-event-bus.global-override-for-injectable.d.ts +5 -0
  2. package/dist/src/common/base-store.d.ts +1 -1
  3. package/dist/src/common/fs/exec-file.injectable.d.ts +3 -1
  4. package/dist/src/common/get-configuration-file-model/get-configuration-file-model.injectable.d.ts +1 -1
  5. package/dist/src/common/k8s-api/endpoints/daemon-set.api.d.ts +1 -1
  6. package/dist/src/common/k8s-api/endpoints/index.d.ts +1 -0
  7. package/dist/src/common/k8s-api/endpoints/job.api.d.ts +4 -3
  8. package/dist/src/common/k8s-api/endpoints/metrics.api.d.ts +5 -2
  9. package/dist/src/common/k8s-api/endpoints/pod.api.d.ts +13 -129
  10. package/dist/src/common/k8s-api/endpoints/replica-set.api.d.ts +1 -1
  11. package/dist/src/common/k8s-api/endpoints/stateful-set.api.d.ts +1 -1
  12. package/dist/src/common/k8s-api/endpoints/types/capabilities.d.ts +17 -0
  13. package/dist/src/common/k8s-api/endpoints/types/container-port.d.ts +11 -0
  14. package/dist/src/common/k8s-api/endpoints/types/container.d.ts +158 -0
  15. package/dist/src/common/k8s-api/endpoints/types/env-from-source.d.ts +13 -0
  16. package/dist/src/common/k8s-api/endpoints/types/env-source.d.ts +11 -0
  17. package/dist/src/common/k8s-api/endpoints/types/env-var-key-selector.d.ts +9 -0
  18. package/dist/src/common/k8s-api/endpoints/types/env-var-source.d.ts +13 -0
  19. package/dist/src/common/k8s-api/endpoints/types/env-var.d.ts +10 -0
  20. package/dist/src/common/k8s-api/endpoints/types/exec-action.d.ts +18 -0
  21. package/dist/src/common/k8s-api/endpoints/types/handler.d.ts +15 -0
  22. package/dist/src/common/k8s-api/endpoints/types/http-get-action.d.ts +32 -0
  23. package/dist/src/common/k8s-api/endpoints/types/http-header.d.ts +17 -0
  24. package/dist/src/common/k8s-api/endpoints/types/index.d.ts +35 -0
  25. package/dist/src/common/k8s-api/endpoints/types/lifecycle.d.ts +15 -0
  26. package/dist/src/{main/routes/metrics/metrics-query.d.ts → common/k8s-api/endpoints/types/object-field-selector.d.ts} +4 -3
  27. package/dist/src/common/k8s-api/endpoints/types/pod-security-context.d.ts +20 -0
  28. package/dist/src/common/k8s-api/endpoints/types/probe.d.ts +70 -0
  29. package/dist/src/common/k8s-api/endpoints/types/resource-field-selector.d.ts +9 -0
  30. package/dist/src/common/k8s-api/endpoints/types/se-linux-options.d.ts +25 -0
  31. package/dist/src/common/k8s-api/endpoints/types/seccomp-profile.d.ts +27 -0
  32. package/dist/src/common/k8s-api/endpoints/types/security-context.d.ts +45 -0
  33. package/dist/src/common/k8s-api/endpoints/types/tcp-socket-action.d.ts +17 -0
  34. package/dist/src/common/k8s-api/endpoints/types/volume-device.d.ts +17 -0
  35. package/dist/src/common/k8s-api/endpoints/types/volume-mount.d.ts +12 -0
  36. package/dist/src/common/k8s-api/endpoints/types/windows-security-context-options.d.ts +36 -0
  37. package/dist/src/common/utils/singleton.d.ts +1 -1
  38. package/dist/src/common/vars/package-json.injectable.d.ts +1 -0
  39. package/dist/src/extensions/as-legacy-globals-for-extension-api/as-legacy-global-object-for-extension-api-with-modifications.d.ts +1 -1
  40. package/dist/src/extensions/common-api/k8s-api.d.ts +1 -1
  41. package/dist/src/extensions/extension-api.js +629 -276
  42. package/dist/src/extensions/extension-discovery/extension-discovery.d.ts +1 -2
  43. package/dist/src/extensions/extension-store.d.ts +1 -1
  44. package/dist/src/{behaviours → features}/pod-logs/download-logs.test.d.ts +0 -0
  45. package/dist/src/features/telemetry/emit-telemetry-from-specific-function-calls.test.d.ts +1 -0
  46. package/dist/src/features/telemetry/renderer/emit-telemetry.injectable.d.ts +5 -0
  47. package/dist/src/features/telemetry/renderer/telemetry-decorator.injectable.d.ts +11 -0
  48. package/dist/src/features/telemetry/renderer/telemetry-white-list-for-functions.injectable.d.ts +2 -0
  49. package/dist/src/main/helm/exec-helm/exec-helm.injectable.d.ts +2 -1
  50. package/dist/src/main/helm/helm-release-manager.d.ts +1 -6
  51. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-helm-manifest/call-for-helm-manifest.injectable.d.ts +4 -0
  52. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-kube-resources-by-manifest/call-for-kube-resources-by-manifest.injectable.d.ts +5 -0
  53. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-kube-resources-by-manifest/exec-file-with-input/exec-file-with-input.global-override-for-injectable.d.ts +5 -0
  54. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-kube-resources-by-manifest/exec-file-with-input/exec-file-with-input.injectable.d.ts +8 -0
  55. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-kube-resources-by-manifest/exec-file-with-input/exec-file-with-input.test.d.ts +1 -0
  56. package/dist/src/main/helm/helm-service/get-helm-release-resources/call-for-kube-resources-by-manifest/exec-file-with-input/non-promise-exec-file.injectable.d.ts +4 -0
  57. package/dist/src/main/helm/helm-service/get-helm-release-resources/get-helm-release-resources.injectable.d.ts +4 -0
  58. package/dist/src/main/helm/helm-service/get-helm-release-resources/get-helm-release-resources.test.d.ts +5 -0
  59. package/dist/src/main/helm/helm-service/get-helm-release.global-override-for-injectable.d.ts +5 -0
  60. package/dist/src/main/helm/helm-service/update-helm-release.global-override-for-injectable.d.ts +11 -0
  61. package/dist/src/main/prometheus/helm-14.d.ts +14 -0
  62. package/dist/src/main/router/router.d.ts +1 -1
  63. package/dist/src/renderer/components/+helm-releases/release-details/release-details-drawer-toolbar.d.ts +12 -0
  64. package/dist/src/renderer/components/+helm-releases/release-details/release-details-drawer.d.ts +12 -0
  65. package/dist/src/renderer/components/+helm-releases/release-details/release-details-model/call-for-helm-release/call-for-helm-release.injectable.d.ts +2 -1
  66. package/dist/src/renderer/components/+helm-releases/release-details/release-details-model/release-details-model.injectable.d.ts +13 -14
  67. package/dist/src/renderer/components/+workloads-pods/__tests__/pod-container-env.test.d.ts +5 -0
  68. package/dist/src/renderer/components/+workloads-pods/details/volumes/variant-helpers.d.ts +1 -1
  69. package/dist/src/renderer/components/+workloads-pods/pod-container-env.d.ts +4 -10
  70. package/dist/src/renderer/components/+workloads-pods/pod-details-container.d.ts +2 -2
  71. package/dist/src/renderer/components/dock/logs/create-pod-logs-tab.injectable.d.ts +2 -2
  72. package/dist/src/renderer/components/layout/sidebar-item.d.ts +0 -1
  73. package/dist/src/renderer/components/status-bar/status-bar-registration.d.ts +5 -0
  74. package/dist/src/renderer/navigation/index.d.ts +0 -4
  75. package/dist/src/renderer/navigation/match-route.injectable.d.ts +3 -1
  76. package/dist/src/renderer/themes/active-type.injectable.d.ts +5 -0
  77. package/dist/src/renderer/themes/store.d.ts +2 -1
  78. package/dist/src/renderer/utils/storageHelper.d.ts +1 -1
  79. package/package.json +1 -1
  80. package/dist/src/extensions/extension-discovery/is-compatible-bundled-extension/is-compatible-bundled-extension.d.ts +0 -11
  81. package/dist/src/extensions/extension-discovery/is-compatible-bundled-extension/is-compatible-bundled-extension.injectable.d.ts +0 -2
@@ -0,0 +1,5 @@
1
+ declare const _default: {
2
+ injectable: import("@ogre-tools/injectable").Injectable<(data_0: import("./event-bus").AppEvent) => void, unknown, void>;
3
+ overridingInstantiate: import("@ogre-tools/injectable").Instantiate<(data_0: import("./event-bus").AppEvent) => void, void>;
4
+ };
5
+ export default _default;
@@ -16,7 +16,7 @@ export interface BaseStoreParams<T> extends ConfOptions<T> {
16
16
  /**
17
17
  * Note: T should only contain base JSON serializable types.
18
18
  */
19
- export declare abstract class BaseStore<T> extends Singleton {
19
+ export declare abstract class BaseStore<T extends object> extends Singleton {
20
20
  protected params: BaseStoreParams<T>;
21
21
  protected storeConfig?: Config<T>;
22
22
  protected syncDisposers: Disposer[];
@@ -1,3 +1,5 @@
1
- export declare type ExecFile = (filePath: string, args: string[]) => Promise<string>;
1
+ /// <reference types="node" />
2
+ import type { ExecFileOptions } from "child_process";
3
+ export declare type ExecFile = (filePath: string, args: string[], options: ExecFileOptions) => Promise<string>;
2
4
  declare const execFileInjectable: import("@ogre-tools/injectable").Injectable<ExecFile, unknown, void>;
3
5
  export default execFileInjectable;
@@ -1,4 +1,4 @@
1
1
  import Config from "conf";
2
2
  import type { BaseStoreParams } from "../base-store";
3
- declare const getConfigurationFileModelInjectable: import("@ogre-tools/injectable").Injectable<(<ConfigurationContent>(content: BaseStoreParams<ConfigurationContent>) => Config<ConfigurationContent>), unknown, void>;
3
+ declare const getConfigurationFileModelInjectable: import("@ogre-tools/injectable").Injectable<(<T extends object>(content: BaseStoreParams<T>) => Config<T>), unknown, void>;
4
4
  export default getConfigurationFileModelInjectable;
@@ -44,7 +44,7 @@ export declare class DaemonSet extends KubeObject<NamespaceScopedMetadata, Daemo
44
44
  getTolerations(): import("../kube-object").Toleration[];
45
45
  getAffinity(): import("../kube-object").Affinity | undefined;
46
46
  getAffinityNumber(): number;
47
- getImages(): string[];
47
+ getImages(): (string | undefined)[];
48
48
  }
49
49
  export declare class DaemonSetApi extends KubeApi<DaemonSet> {
50
50
  constructor(opts?: DerivedKubeApiOptions & IgnoredKubeApiOptions);
@@ -37,3 +37,4 @@ export * from "./service-account.api";
37
37
  export * from "./stateful-set.api";
38
38
  export * from "./storage-class.api";
39
39
  export * from "./legacy-globals";
40
+ export * from "./types";
@@ -4,7 +4,8 @@
4
4
  */
5
5
  import type { DerivedKubeApiOptions, IgnoredKubeApiOptions } from "../kube-api";
6
6
  import { KubeApi } from "../kube-api";
7
- import type { PodContainer, PodMetricData, PodSpec } from "./pod.api";
7
+ import type { PodMetricData, PodSpec } from "./pod.api";
8
+ import type { Container } from "./types/container";
8
9
  import type { KubeObjectStatus, LabelSelector, NamespaceScopedMetadata } from "../kube-object";
9
10
  import { KubeObject } from "../kube-object";
10
11
  export interface JobSpec {
@@ -20,7 +21,7 @@ export interface JobSpec {
20
21
  };
21
22
  spec: PodSpec;
22
23
  };
23
- containers?: PodContainer[];
24
+ containers?: Container[];
24
25
  restartPolicy?: string;
25
26
  terminationGracePeriodSeconds?: number;
26
27
  dnsPolicy?: string;
@@ -47,7 +48,7 @@ export declare class Job extends KubeObject<NamespaceScopedMetadata, JobStatus,
47
48
  getCompletions(): number;
48
49
  getParallelism(): number | undefined;
49
50
  getCondition(): import("../kube-object").BaseKubeObjectCondition | undefined;
50
- getImages(): string[];
51
+ getImages(): (string | undefined)[];
51
52
  }
52
53
  export declare class JobApi extends KubeApi<Job> {
53
54
  constructor(opts?: DerivedKubeApiOptions & IgnoredKubeApiOptions);
@@ -2,7 +2,6 @@
2
2
  * Copyright (c) OpenLens Authors. All rights reserved.
3
3
  * Licensed under MIT License. See LICENSE in root directory for more information.
4
4
  */
5
- import type { IMetricsQuery } from "../../../main/routes/metrics/metrics-query";
6
5
  export interface MetricData {
7
6
  status: string;
8
7
  data: {
@@ -44,11 +43,15 @@ export interface IResourceMetrics<T extends MetricData> {
44
43
  networkReceive: T;
45
44
  networkTransmit: T;
46
45
  }
46
+ declare function getMetrics(query: string, reqParams?: IMetricsReqParams): Promise<MetricData>;
47
+ declare function getMetrics(query: string[], reqParams?: IMetricsReqParams): Promise<MetricData[]>;
48
+ declare function getMetrics<MetricNames extends string>(query: Record<MetricNames, Partial<Record<string, string>>>, reqParams?: IMetricsReqParams): Promise<Record<MetricNames, MetricData>>;
47
49
  export declare const metricsApi: {
48
- getMetrics<T = IMetricsQuery>(query: T, reqParams?: IMetricsReqParams): Promise<T extends object ? T extends infer T_1 ? { [K in keyof T_1]: MetricData; } : never : MetricData>;
50
+ getMetrics: typeof getMetrics;
49
51
  getMetricProviders(): Promise<MetricProviderInfo[]>;
50
52
  };
51
53
  export declare function normalizeMetrics(metrics: MetricData | undefined | null, frames?: number): MetricData;
52
54
  export declare function isMetricsEmpty(metrics: Partial<Record<string, MetricData>>): boolean;
53
55
  export declare function getItemMetrics(metrics: Partial<Record<string, MetricData>> | null | undefined, itemName: string): Partial<Record<string, MetricData>> | undefined;
54
56
  export declare function getMetricLastPoints<T extends Partial<Record<string, MetricData>>>(metrics: T): Record<keyof T, number>;
57
+ export {};
@@ -6,10 +6,13 @@ import type { MetricData } from "./metrics.api";
6
6
  import type { DerivedKubeApiOptions, IgnoredKubeApiOptions, ResourceDescriptor } from "../kube-api";
7
7
  import { KubeApi } from "../kube-api";
8
8
  import type { RequireExactlyOne } from "type-fest";
9
- import type { KubeObjectMetadata, LocalObjectReference, Affinity, Toleration, LabelSelector, NamespaceScopedMetadata } from "../kube-object";
9
+ import type { KubeObjectMetadata, LocalObjectReference, Affinity, Toleration, NamespaceScopedMetadata } from "../kube-object";
10
10
  import type { SecretReference } from "./secret.api";
11
11
  import type { PersistentVolumeClaimSpec } from "./persistent-volume-claim.api";
12
12
  import { KubeObject } from "../kube-object";
13
+ import type { PodSecurityContext } from "./types/pod-security-context";
14
+ import type { Container } from "./types/container";
15
+ import type { ObjectFieldSelector, ResourceFieldSelector } from "./types";
13
16
  export declare class PodApi extends KubeApi<Pod> {
14
17
  constructor(opts?: DerivedKubeApiOptions & IgnoredKubeApiOptions);
15
18
  getLogs(params: ResourceDescriptor, query?: PodLogsQuery): Promise<string>;
@@ -44,87 +47,6 @@ export declare enum PodStatusPhase {
44
47
  SUCCEEDED = "Succeeded",
45
48
  EVICTED = "Evicted"
46
49
  }
47
- export interface ContainerPort {
48
- containerPort: number;
49
- hostIP?: string;
50
- hostPort?: number;
51
- name?: string;
52
- protocol?: "UDP" | "TCP" | "SCTP";
53
- }
54
- export interface VolumeMount {
55
- name: string;
56
- readOnly?: boolean;
57
- mountPath: string;
58
- mountPropagation?: string;
59
- subPath?: string;
60
- subPathExpr?: string;
61
- }
62
- export interface PodContainer extends Partial<Record<PodContainerProbe, IContainerProbe>> {
63
- name: string;
64
- image: string;
65
- command?: string[];
66
- args?: string[];
67
- ports?: ContainerPort[];
68
- resources?: {
69
- limits?: {
70
- cpu: string;
71
- memory: string;
72
- };
73
- requests?: {
74
- cpu: string;
75
- memory: string;
76
- };
77
- };
78
- terminationMessagePath?: string;
79
- terminationMessagePolicy?: string;
80
- env?: {
81
- name: string;
82
- value?: string;
83
- valueFrom?: {
84
- fieldRef?: {
85
- apiVersion: string;
86
- fieldPath: string;
87
- };
88
- secretKeyRef?: {
89
- key: string;
90
- name: string;
91
- };
92
- configMapKeyRef?: {
93
- key: string;
94
- name: string;
95
- };
96
- };
97
- }[];
98
- envFrom?: {
99
- configMapRef?: LocalObjectReference;
100
- secretRef?: LocalObjectReference;
101
- }[];
102
- volumeMounts?: VolumeMount[];
103
- imagePullPolicy?: string;
104
- }
105
- export declare type PodContainerProbe = "livenessProbe" | "readinessProbe" | "startupProbe";
106
- interface IContainerProbe {
107
- httpGet?: {
108
- path?: string;
109
- /**
110
- * either a port number or an IANA_SVC_NAME string referring to a port defined in the container
111
- */
112
- port: number | string;
113
- scheme: string;
114
- host?: string;
115
- };
116
- exec?: {
117
- command: string[];
118
- };
119
- tcpSocket?: {
120
- port: number;
121
- };
122
- initialDelaySeconds?: number;
123
- timeoutSeconds?: number;
124
- periodSeconds?: number;
125
- successThreshold?: number;
126
- failureThreshold?: number;
127
- }
128
50
  export interface ContainerStateRunning {
129
51
  startedAt: string;
130
52
  }
@@ -385,15 +307,6 @@ export interface ConfigMapProjection {
385
307
  items?: KeyToPath[];
386
308
  optional?: boolean;
387
309
  }
388
- export interface ObjectFieldSelector {
389
- fieldPath: string;
390
- apiVersion?: string;
391
- }
392
- export interface ResourceFieldSelector {
393
- resource: string;
394
- containerName?: string;
395
- divisor?: string;
396
- }
397
310
  export interface DownwardAPIVolumeFile {
398
311
  path: string;
399
312
  fieldRef?: ObjectFieldSelector;
@@ -580,45 +493,17 @@ export interface HostAlias {
580
493
  ip: string;
581
494
  hostnames: string[];
582
495
  }
583
- export interface SELinuxOptions {
584
- level?: string;
585
- role?: string;
586
- type?: string;
587
- user?: string;
588
- }
589
- export interface SeccompProfile {
590
- localhostProfile?: string;
591
- type: string;
592
- }
593
496
  export interface Sysctl {
594
497
  name: string;
595
498
  value: string;
596
499
  }
597
- export interface WindowsSecurityContextOptions {
598
- labelSelector?: LabelSelector;
599
- maxSkew: number;
600
- topologyKey: string;
601
- whenUnsatisfiable: string;
602
- }
603
- export interface PodSecurityContext {
604
- fsGroup?: number;
605
- fsGroupChangePolicy?: string;
606
- runAsGroup?: number;
607
- runAsNonRoot?: boolean;
608
- runAsUser?: number;
609
- seLinuxOptions?: SELinuxOptions;
610
- seccompProfile?: SeccompProfile;
611
- supplementalGroups?: number[];
612
- sysctls?: Sysctl;
613
- windowsOptions?: WindowsSecurityContextOptions;
614
- }
615
500
  export interface TopologySpreadConstraint {
616
501
  }
617
502
  export interface PodSpec {
618
503
  activeDeadlineSeconds?: number;
619
504
  affinity?: Affinity;
620
505
  automountServiceAccountToken?: boolean;
621
- containers?: PodContainer[];
506
+ containers?: Container[];
622
507
  dnsPolicy?: string;
623
508
  enableServiceLinks?: boolean;
624
509
  ephemeralContainers?: unknown[];
@@ -628,7 +513,7 @@ export interface PodSpec {
628
513
  hostNetwork?: boolean;
629
514
  hostPID?: boolean;
630
515
  imagePullSecrets?: LocalObjectReference[];
631
- initContainers?: PodContainer[];
516
+ initContainers?: Container[];
632
517
  nodeName?: string;
633
518
  nodeSelector?: Partial<Record<string, string>>;
634
519
  overhead?: Partial<Record<string, string>>;
@@ -677,10 +562,10 @@ export declare class Pod extends KubeObject<NamespaceScopedMetadata, PodStatus,
677
562
  static namespaced: boolean;
678
563
  static apiBase: string;
679
564
  getAffinityNumber(): number;
680
- getInitContainers(): PodContainer[];
681
- getContainers(): PodContainer[];
682
- getAllContainers(): PodContainer[];
683
- getRunningContainers(): PodContainer[];
565
+ getInitContainers(): Container[];
566
+ getContainers(): Container[];
567
+ getAllContainers(): Container[];
568
+ getRunningContainers(): Container[];
684
569
  getContainerStatuses(includeInitContainers?: boolean): PodContainerStatus[];
685
570
  getRestartsCount(): number;
686
571
  getQosClass(): string;
@@ -697,12 +582,11 @@ export declare class Pod extends KubeObject<NamespaceScopedMetadata, PodStatus,
697
582
  getTolerations(): Toleration[];
698
583
  getAffinity(): Affinity;
699
584
  hasIssues(): boolean;
700
- getLivenessProbe(container: PodContainer): string[];
701
- getReadinessProbe(container: PodContainer): string[];
702
- getStartupProbe(container: PodContainer): string[];
585
+ getLivenessProbe(container: Container): string[];
586
+ getReadinessProbe(container: Container): string[];
587
+ getStartupProbe(container: Container): string[];
703
588
  private getProbe;
704
589
  getNodeName(): string | undefined;
705
590
  getSelectedNodeOs(): string | undefined;
706
591
  getIPs(): string[];
707
592
  }
708
- export {};
@@ -50,5 +50,5 @@ export declare class ReplicaSet extends KubeObject<NamespaceScopedMetadata, Repl
50
50
  getDesired(): number;
51
51
  getCurrent(): number;
52
52
  getReady(): number;
53
- getImages(): string[];
53
+ getImages(): (string | undefined)[];
54
54
  }
@@ -52,5 +52,5 @@ export declare class StatefulSet extends KubeObject<NamespaceScopedMetadata, Sta
52
52
  getAffinity(): import("../kube-object").Affinity;
53
53
  getAffinityNumber(): number;
54
54
  getReplicas(): number;
55
- getImages(): string[];
55
+ getImages(): (string | undefined)[];
56
56
  }
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ /**
6
+ * Adds and removes POSIX capabilities from running containers.
7
+ */
8
+ export interface Capabilities {
9
+ /**
10
+ * Added capabilities
11
+ */
12
+ add?: string[];
13
+ /**
14
+ * Removed capabilities
15
+ */
16
+ drop?: string[];
17
+ }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ export interface ContainerPort {
6
+ containerPort: number;
7
+ hostIP?: string;
8
+ hostPort?: number;
9
+ name?: string;
10
+ protocol?: "UDP" | "TCP" | "SCTP";
11
+ }
@@ -0,0 +1,158 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { Lifecycle } from "./lifecycle";
6
+ import type { ResourceRequirements } from "./resource-requirements";
7
+ import type { SecurityContext } from "./security-context";
8
+ import type { Probe } from "./probe";
9
+ import type { VolumeDevice } from "./volume-device";
10
+ import type { VolumeMount } from "./volume-mount";
11
+ import type { ContainerPort } from "./container-port";
12
+ import type { EnvFromSource } from "./env-from-source";
13
+ import type { EnvVar } from "./env-var";
14
+ /**
15
+ * A single application container that you want to run within a pod.
16
+ */
17
+ export interface Container {
18
+ /**
19
+ * Arguments to the entrypoint. The docker image's CMD is used if this is not provided. Variable
20
+ * references `$(VAR_NAME)` are expanded using the container's environment.
21
+ *
22
+ * If a variable cannot be resolved, the reference in the input string will be unchanged.
23
+ * Double `$$` are reduced to a single `$`, which allows for escaping the `$(VAR_NAME)` syntax:
24
+ * i.e. `"$$(VAR_NAME)"` will produce the string literal `"$(VAR_NAME)`".
25
+ *
26
+ * Escaped references will never be expanded, regardless of whether the variable exists or not.
27
+ * Cannot be updated.
28
+ *
29
+ * More info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell
30
+ */
31
+ args?: string[];
32
+ /**
33
+ * Entrypoint array. Not executed within a shell. The docker image's ENTRYPOINT is used if this
34
+ * is not provided. Variable references `$(VAR_NAME)` are expanded using the container's
35
+ * environment.
36
+ *
37
+ * If a variable cannot be resolved, the reference in the input string will be unchanged.
38
+ * Double `$$` are reduced to a single `$`, which allows for escaping the `$(VAR_NAME)` syntax:
39
+ * i.e. `"$$(VAR_NAME)"` will produce the string literal `"$(VAR_NAME)`".
40
+ *
41
+ * Escaped references will never be expanded, regardless of whether the variable exists or not.
42
+ * Cannot be updated.
43
+ *
44
+ * More info: https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell
45
+ */
46
+ command?: string[];
47
+ /**
48
+ * List of environment variables to set in the container. Cannot be updated.
49
+ */
50
+ env?: EnvVar[];
51
+ /**
52
+ * List of sources to populate environment variables in the container. The keys defined within a
53
+ * source must be a C_IDENTIFIER. All invalid keys will be reported as an event when the
54
+ * container is starting.
55
+ *
56
+ * When a key exists in multiple sources, the value associated with the last source will take
57
+ * precedence. Values defined by an Env with a duplicate key will take precedence. Cannot be
58
+ * updated.
59
+ */
60
+ envFrom?: EnvFromSource[];
61
+ /**
62
+ * Docker image name.
63
+ *
64
+ * More info: https://kubernetes.io/docs/concepts/containers/images
65
+ */
66
+ image?: string;
67
+ /**
68
+ * Image pull policy. Defaults to `"Always"` if :latest tag is specified, or `"IfNotPresent"`
69
+ * otherwise. Cannot be updated.
70
+ *
71
+ * More info: https://kubernetes.io/docs/concepts/containers/images#updating-images
72
+ */
73
+ imagePullPolicy?: "Always" | "Never" | "IfNotPresent";
74
+ lifecycle?: Lifecycle;
75
+ livenessProbe?: Probe;
76
+ /**
77
+ * Name of the container specified as a DNS_LABEL. Each container in a pod must have a unique
78
+ * name. Cannot be updated.
79
+ */
80
+ name: string;
81
+ /**
82
+ * List of ports to expose from the container. Exposing a port here gives the system additional
83
+ * information about the network connections a container uses, but is primarily informational.
84
+ * Not specifying a port here DOES NOT prevent that port from being exposed. Any port which is
85
+ * listening on the default `"0.0.0.0"` address inside a container will be accessible from the
86
+ * network. Cannot be updated.
87
+ */
88
+ ports?: ContainerPort[];
89
+ readinessProbe?: Probe;
90
+ resources?: ResourceRequirements;
91
+ securityContext?: SecurityContext;
92
+ startupProbe?: Probe;
93
+ /**
94
+ * Whether this container should allocate a buffer for stdin in the container runtime. If this is
95
+ * not set, reads from stdin in the container will always result in EOF.
96
+ *
97
+ * @default false
98
+ */
99
+ stdin?: boolean;
100
+ /**
101
+ * Whether the container runtime should close the stdin channel after it has been opened by a
102
+ * single attach. When stdin is true the stdin stream will remain open across multiple attach
103
+ * sessions.
104
+ *
105
+ * If stdinOnce is set to true, stdin is opened on container start, is empty until the first
106
+ * client attaches to stdin, and then remains open and accepts data until the client disconnects,
107
+ * at which time stdin is closed and remains closed until the container is restarted.
108
+ *
109
+ * If this flag is false, a container processes that reads from stdin will never receive an EOF.
110
+ *
111
+ * @default false
112
+ */
113
+ stdinOnce?: boolean;
114
+ /**
115
+ * Path at which the file to which the container's termination message will be written
116
+ * is mounted into the container's filesystem. Message written is intended to be brief final
117
+ * status, such as an assertion failure message.
118
+ *
119
+ * Will be truncated by the node if greater than 4096 bytes.
120
+ * The total message length across all containers will be limited to 12kb. Cannot be updated.
121
+ *
122
+ * @default "/dev/termination-log"
123
+ */
124
+ terminationMessagePath?: string;
125
+ /**
126
+ * Indicate how the termination message should be populated.
127
+ *
128
+ * - `File`: will use the contents of {@link terminationMessagePath} to populate the container
129
+ * status message on both success and failure.
130
+ *
131
+ * - `FallbackToLogsOnError`: will use the last chunk of container log output if the
132
+ * termination message file is empty and the container exited with an error.
133
+ *
134
+ * The log output is limited to 2048 bytes or 80 lines, whichever is smaller. Cannot be updated.
135
+ *
136
+ * @default "File"
137
+ */
138
+ terminationMessagePolicy?: "File" | "FallbackToLogsOnError";
139
+ /**
140
+ * Whether this container should allocate a TTY for itself, also requires 'stdin' to be true.
141
+ *
142
+ * @default false
143
+ */
144
+ tty?: boolean;
145
+ /**
146
+ * volumeDevices is the list of block devices to be used by the container.
147
+ */
148
+ volumeDevices?: VolumeDevice[];
149
+ /**
150
+ * Pod volumes to mount into the container's filesystem. Cannot be updated.
151
+ */
152
+ volumeMounts?: VolumeMount[];
153
+ /**
154
+ * Container's working directory. If not specified, the container runtime's default will be used,
155
+ * which might be configured in the container image. Cannot be updated.
156
+ */
157
+ workingDir?: string;
158
+ }
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { EnvSource } from "./env-source";
6
+ export interface EnvFromSource {
7
+ configMapRef?: EnvSource;
8
+ /**
9
+ * An identifier to prepend to each key in the ConfigMap. Must be a C_IDENTIFIER.
10
+ */
11
+ prefix?: string;
12
+ secretRef?: EnvSource;
13
+ }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { LocalObjectReference } from "../../kube-object";
6
+ export interface EnvSource extends LocalObjectReference {
7
+ /**
8
+ * Whether the object must be defined
9
+ */
10
+ optional?: boolean;
11
+ }
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ export interface EnvVarKeySelector {
6
+ key: string;
7
+ name?: string;
8
+ optional?: boolean;
9
+ }
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { EnvVarKeySelector } from "./env-var-key-selector";
6
+ import type { ObjectFieldSelector } from "./object-field-selector";
7
+ import type { ResourceFieldSelector } from "./resource-field-selector";
8
+ export interface EnvVarSource {
9
+ configMapKeyRef?: EnvVarKeySelector;
10
+ fieldRef?: ObjectFieldSelector;
11
+ resourceFieldRef?: ResourceFieldSelector;
12
+ secretKeyRef?: EnvVarKeySelector;
13
+ }
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { EnvVarSource } from "./env-var-source";
6
+ export interface EnvVar {
7
+ name: string;
8
+ value?: string;
9
+ valueFrom?: EnvVarSource;
10
+ }
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ /**
6
+ * ExecAction describes a "run in container" action.
7
+ */
8
+ export interface ExecAction {
9
+ /**
10
+ * Command is the command line to execute inside the container, the working directory for the
11
+ * command is root ('\\') in the container's filesystem. The command is simply exec'd, it is not
12
+ * run inside a shell, so traditional shell instructions ('|', etc) won't work. To use a shell,
13
+ * you need to explicitly call out to that shell.
14
+ *
15
+ * Exit status of 0 is treated as live/healthy and non-zero is unhealthy.
16
+ */
17
+ command?: string[];
18
+ }
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { ExecAction } from "./exec-action";
6
+ import type { HttpGetAction } from "./http-get-action";
7
+ import type { TcpSocketAction } from "./tcp-socket-action";
8
+ /**
9
+ * Handler defines a specific action that should be taken.
10
+ */
11
+ export interface Handler {
12
+ exec?: ExecAction;
13
+ httpGet?: HttpGetAction;
14
+ tcpSocket?: TcpSocketAction;
15
+ }
@@ -0,0 +1,32 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ import type { HttpHeader } from "./http-header";
6
+ /**
7
+ * An action based on HTTP Get requests.
8
+ */
9
+ export interface HttpGetAction {
10
+ /**
11
+ * Host name to connect to, defaults to the pod IP. You probably want to set \"Host\" in httpHeaders instead.
12
+ */
13
+ host?: string;
14
+ /**
15
+ * Custom headers to set in the request. HTTP allows repeated headers.
16
+ */
17
+ httpHeaders?: HttpHeader[];
18
+ /**
19
+ * Path to access on the HTTP server.
20
+ */
21
+ path?: string;
22
+ /**
23
+ * The PORT to request from.
24
+ */
25
+ port: string | number;
26
+ /**
27
+ * Scheme to use for connecting to the host.
28
+ *
29
+ * @default "HTTP"
30
+ */
31
+ scheme?: string;
32
+ }
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Copyright (c) OpenLens Authors. All rights reserved.
3
+ * Licensed under MIT License. See LICENSE in root directory for more information.
4
+ */
5
+ /**
6
+ * A custom header to be used in HTTP probes and get actions
7
+ */
8
+ export interface HttpHeader {
9
+ /**
10
+ * Field name
11
+ */
12
+ name: string;
13
+ /**
14
+ * The value of the field
15
+ */
16
+ value: string;
17
+ }