@k8slens/extensions 6.0.1-git.7ad7c89061.0 → 6.0.1-git.7d9c79b50a.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 (56) 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/get-configuration-file-model/get-configuration-file-model.injectable.d.ts +1 -1
  4. package/dist/src/common/k8s-api/endpoints/daemon-set.api.d.ts +1 -1
  5. package/dist/src/common/k8s-api/endpoints/index.d.ts +1 -0
  6. package/dist/src/common/k8s-api/endpoints/job.api.d.ts +4 -3
  7. package/dist/src/common/k8s-api/endpoints/metrics.api.d.ts +5 -2
  8. package/dist/src/common/k8s-api/endpoints/pod.api.d.ts +13 -129
  9. package/dist/src/common/k8s-api/endpoints/replica-set.api.d.ts +1 -1
  10. package/dist/src/common/k8s-api/endpoints/stateful-set.api.d.ts +1 -1
  11. package/dist/src/common/k8s-api/endpoints/types/capabilities.d.ts +17 -0
  12. package/dist/src/common/k8s-api/endpoints/types/container-port.d.ts +11 -0
  13. package/dist/src/common/k8s-api/endpoints/types/container.d.ts +158 -0
  14. package/dist/src/common/k8s-api/endpoints/types/env-from-source.d.ts +13 -0
  15. package/dist/src/common/k8s-api/endpoints/types/env-source.d.ts +11 -0
  16. package/dist/src/common/k8s-api/endpoints/types/env-var-key-selector.d.ts +9 -0
  17. package/dist/src/common/k8s-api/endpoints/types/env-var-source.d.ts +13 -0
  18. package/dist/src/common/k8s-api/endpoints/types/env-var.d.ts +10 -0
  19. package/dist/src/common/k8s-api/endpoints/types/exec-action.d.ts +18 -0
  20. package/dist/src/common/k8s-api/endpoints/types/handler.d.ts +15 -0
  21. package/dist/src/common/k8s-api/endpoints/types/http-get-action.d.ts +32 -0
  22. package/dist/src/common/k8s-api/endpoints/types/http-header.d.ts +17 -0
  23. package/dist/src/common/k8s-api/endpoints/types/index.d.ts +35 -0
  24. package/dist/src/common/k8s-api/endpoints/types/lifecycle.d.ts +15 -0
  25. package/dist/src/{main/routes/metrics/metrics-query.d.ts → common/k8s-api/endpoints/types/object-field-selector.d.ts} +4 -3
  26. package/dist/src/common/k8s-api/endpoints/types/pod-security-context.d.ts +20 -0
  27. package/dist/src/common/k8s-api/endpoints/types/probe.d.ts +70 -0
  28. package/dist/src/common/k8s-api/endpoints/types/resource-field-selector.d.ts +9 -0
  29. package/dist/src/common/k8s-api/endpoints/types/se-linux-options.d.ts +25 -0
  30. package/dist/src/common/k8s-api/endpoints/types/seccomp-profile.d.ts +27 -0
  31. package/dist/src/common/k8s-api/endpoints/types/security-context.d.ts +45 -0
  32. package/dist/src/common/k8s-api/endpoints/types/tcp-socket-action.d.ts +17 -0
  33. package/dist/src/common/k8s-api/endpoints/types/volume-device.d.ts +17 -0
  34. package/dist/src/common/k8s-api/endpoints/types/volume-mount.d.ts +12 -0
  35. package/dist/src/common/k8s-api/endpoints/types/windows-security-context-options.d.ts +36 -0
  36. package/dist/src/common/utils/singleton.d.ts +1 -1
  37. package/dist/src/common/vars/package-json.injectable.d.ts +1 -0
  38. package/dist/src/extensions/as-legacy-globals-for-extension-api/as-legacy-global-object-for-extension-api-with-modifications.d.ts +1 -1
  39. package/dist/src/extensions/common-api/k8s-api.d.ts +1 -1
  40. package/dist/src/extensions/extension-api.js +626 -273
  41. package/dist/src/extensions/extension-store.d.ts +1 -1
  42. package/dist/src/{behaviours → features}/pod-logs/download-logs.test.d.ts +0 -0
  43. package/dist/src/features/telemetry/emit-telemetry-from-specific-function-calls.test.d.ts +1 -0
  44. package/dist/src/features/telemetry/renderer/emit-telemetry.injectable.d.ts +5 -0
  45. package/dist/src/features/telemetry/renderer/telemetry-decorator.injectable.d.ts +11 -0
  46. package/dist/src/features/telemetry/renderer/telemetry-white-list-for-functions.injectable.d.ts +2 -0
  47. package/dist/src/main/prometheus/helm-14.d.ts +14 -0
  48. package/dist/src/renderer/components/+workloads-pods/details/volumes/variant-helpers.d.ts +1 -1
  49. package/dist/src/renderer/components/+workloads-pods/pod-container-env.d.ts +4 -10
  50. package/dist/src/renderer/components/+workloads-pods/pod-details-container.d.ts +2 -2
  51. package/dist/src/renderer/components/dock/logs/create-pod-logs-tab.injectable.d.ts +2 -2
  52. package/dist/src/renderer/components/layout/sidebar-item.d.ts +0 -1
  53. package/dist/src/renderer/navigation/index.d.ts +0 -4
  54. package/dist/src/renderer/navigation/match-route.injectable.d.ts +3 -1
  55. package/dist/src/renderer/utils/storageHelper.d.ts +1 -1
  56. package/package.json +1 -1
@@ -0,0 +1,35 @@
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 * from "./aggregation-rule";
6
+ export * from "./capabilities";
7
+ export * from "./container";
8
+ export * from "./container-port";
9
+ export * from "./env-from-source";
10
+ export * from "./env-source";
11
+ export * from "./env-var-key-selector";
12
+ export * from "./env-var-source";
13
+ export * from "./env-var";
14
+ export * from "./exec-action";
15
+ export * from "./handler";
16
+ export * from "./http-get-action";
17
+ export * from "./http-header";
18
+ export * from "./job-template-spec";
19
+ export * from "./lifecycle";
20
+ export * from "./object-field-selector";
21
+ export * from "./persistent-volume-claim-template-spec";
22
+ export * from "./pod-security-context";
23
+ export * from "./pod-template-spec";
24
+ export * from "./policy-rule";
25
+ export * from "./probe";
26
+ export * from "./resource-field-selector";
27
+ export * from "./resource-requirements";
28
+ export * from "./role-ref";
29
+ export * from "./se-linux-options";
30
+ export * from "./seccomp-profile";
31
+ export * from "./subject";
32
+ export * from "./tcp-socket-action";
33
+ export * from "./volume-device";
34
+ export * from "./volume-mount";
35
+ export * from "./windows-security-context-options";
@@ -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 { Handler } from "./handler";
6
+ /**
7
+ * Lifecycle describes actions that the management system should take in response to container
8
+ * lifecycle events. For the PostStart and PreStop lifecycle handlers, management of the container
9
+ * blocks until the action is complete, unless the container process fails, in which case the
10
+ * handler is aborted.
11
+ */
12
+ export interface Lifecycle {
13
+ postStart?: Handler;
14
+ preStop?: Handler;
15
+ }
@@ -2,6 +2,7 @@
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
- export declare type IMetricsQuery = string | string[] | {
6
- [metricName: string]: string;
7
- };
5
+ export interface ObjectFieldSelector {
6
+ apiVersion?: string;
7
+ fieldPath: string;
8
+ }
@@ -0,0 +1,20 @@
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 { SeLinuxOptions } from "./se-linux-options";
6
+ import type { SeccompProfile } from "./seccomp-profile";
7
+ import type { WindowsSecurityContextOptions } from "./windows-security-context-options";
8
+ import type { Sysctl } from "../pod.api";
9
+ export interface PodSecurityContext {
10
+ fsGroup?: number;
11
+ fsGroupChangePolicy?: string;
12
+ runAsGroup?: number;
13
+ runAsNonRoot?: boolean;
14
+ runAsUser?: number;
15
+ seLinuxOptions?: SeLinuxOptions;
16
+ seccompProfile?: SeccompProfile;
17
+ supplementalGroups?: number[];
18
+ sysctls?: Sysctl;
19
+ windowsOptions?: WindowsSecurityContextOptions;
20
+ }
@@ -0,0 +1,70 @@
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
+ * Describes a health check to be performed against a container to determine whether it is alive or ready to receive traffic.
10
+ */
11
+ export interface Probe {
12
+ exec?: ExecAction;
13
+ /**
14
+ * Minimum consecutive failures for the probe to be considered failed after having succeeded.
15
+ *
16
+ * @default 3
17
+ * @minimum 1
18
+ */
19
+ failureThreshold?: number;
20
+ httpGet?: HttpGetAction;
21
+ /**
22
+ * Duration after the container has started before liveness probes are initiated.
23
+ *
24
+ * More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
25
+ */
26
+ initialDelaySeconds?: number;
27
+ /**
28
+ * How often to perform the probe.
29
+ *
30
+ * @default 10
31
+ * @minimum 1
32
+ */
33
+ periodSeconds?: number;
34
+ /**
35
+ * Minimum consecutive successes for the probe to be considered successful after having failed.
36
+ *
37
+ * Must be 1 for liveness and startup.
38
+ *
39
+ * @default 1
40
+ * @minimum 1
41
+ */
42
+ successThreshold?: number;
43
+ tcpSocket?: TcpSocketAction;
44
+ /**
45
+ * Duration the pod needs to terminate gracefully upon probe failure.
46
+ *
47
+ * The grace period is the duration in seconds after the processes running in the pod are sent a
48
+ * termination signal and the time when the processes are forcibly halted with a kill signal.
49
+ *
50
+ * Set this value longer than the expected cleanup time for your process.
51
+ *
52
+ * If this value is not set, the pod's terminationGracePeriodSeconds will be used. Otherwise,
53
+ * this value overrides the value provided by the pod spec. Value must be non-negative integer.
54
+ * The value zero indicates stop immediately via the kill signal (no opportunity to shut down).
55
+ *
56
+ * This is a beta field and requires enabling ProbeTerminationGracePeriod feature gate.
57
+ *
58
+ * @minimum 1
59
+ */
60
+ terminationGracePeriodSeconds?: number;
61
+ /**
62
+ * Duration after which the probe times out.
63
+ *
64
+ * More info: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle#container-probes
65
+ *
66
+ * @default 1
67
+ * @minimum 1
68
+ */
69
+ timeoutSeconds?: number;
70
+ }
@@ -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 ResourceFieldSelector {
6
+ containerName?: string;
7
+ divisor?: string;
8
+ resource: string;
9
+ }
@@ -0,0 +1,25 @@
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
+ * SELinuxOptions are the labels to be applied to the container
7
+ */
8
+ export interface SeLinuxOptions {
9
+ /**
10
+ * The SELinux `level` label that applies to the container.
11
+ */
12
+ level?: string;
13
+ /**
14
+ * The SELinux `role` label that applies to the container.
15
+ */
16
+ role?: string;
17
+ /**
18
+ * The SELinux `type` label that applies to the container.
19
+ */
20
+ type?: string;
21
+ /**
22
+ * The SELinux `user` label that applies to the container.
23
+ */
24
+ user?: string;
25
+ }
@@ -0,0 +1,27 @@
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
+ * Defines a pod's or a container's seccomp profile settings. Only one profile source may be set.
7
+ */
8
+ export interface SeccompProfile {
9
+ /**
10
+ * Indicates a profile defined in a file on the node should be used. The profile must be
11
+ * preconfigured on the node to work. Must be a descending path, relative to the kubelet's
12
+ * configured seccomp profile location. Must only be set if type is "Localhost".
13
+ */
14
+ localhostProfile?: string;
15
+ /**
16
+ * Indicates which kind of seccomp profile will be applied.
17
+ *
18
+ * Options:
19
+ *
20
+ * | Value | Description |
21
+ * |--|--|
22
+ * | `Localhost` | A profile defined in a file on the node should be used. |
23
+ * | `RuntimeDefault` | The container runtime default profile should be used. |
24
+ * | `Unconfined` | No profile should be applied. |
25
+ */
26
+ type: "Localhost" | "RuntimeDefault" | "Unconfined";
27
+ }
@@ -0,0 +1,45 @@
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 { Capabilities } from "./capabilities";
6
+ import type { SeLinuxOptions } from "./se-linux-options";
7
+ import type { SeccompProfile } from "./seccomp-profile";
8
+ import type { WindowsSecurityContextOptions } from "./windows-security-context-options";
9
+ /**
10
+ * SecurityContext holds security configuration that will be applied to a container. Some fields are present in both SecurityContext and PodSecurityContext. When both are set, the values in SecurityContext take precedence.
11
+ */
12
+ export interface SecurityContext {
13
+ /**
14
+ * AllowPrivilegeEscalation controls whether a process can gain more privileges than its parent process. This bool directly controls if the no_new_privs flag will be set on the container process. AllowPrivilegeEscalation is true always when the container is: 1) run as Privileged 2) has CAP_SYS_ADMIN
15
+ */
16
+ allowPrivilegeEscalation?: boolean;
17
+ capabilities?: Capabilities;
18
+ /**
19
+ * Run container in privileged mode. Processes in privileged containers are essentially equivalent to root on the host. Defaults to false.
20
+ */
21
+ privileged?: boolean;
22
+ /**
23
+ * procMount denotes the type of proc mount to use for the containers. The default is DefaultProcMount which uses the container runtime defaults for readonly paths and masked paths. This requires the ProcMountType feature flag to be enabled.
24
+ */
25
+ procMount?: string;
26
+ /**
27
+ * Whether this container has a read-only root filesystem. Default is false.
28
+ */
29
+ readOnlyRootFilesystem?: boolean;
30
+ /**
31
+ * The GID to run the entrypoint of the container process. Uses runtime default if unset. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.
32
+ */
33
+ runAsGroup?: number;
34
+ /**
35
+ * Indicates that the container must run as a non-root user. If true, the Kubelet will validate the image at runtime to ensure that it does not run as UID 0 (root) and fail to start the container if it does. If unset or false, no such validation will be performed. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.
36
+ */
37
+ runAsNonRoot?: boolean;
38
+ /**
39
+ * The UID to run the entrypoint of the container process. Defaults to user specified in image metadata if unspecified. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.
40
+ */
41
+ runAsUser?: number;
42
+ seLinuxOptions?: SeLinuxOptions;
43
+ seccompProfile?: SeccompProfile;
44
+ windowsOptions?: WindowsSecurityContextOptions;
45
+ }
@@ -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
+ * An action based on opening a socket
7
+ */
8
+ export interface TcpSocketAction {
9
+ /**
10
+ * Host name to connect to, defaults to the pod IP.
11
+ */
12
+ host?: string;
13
+ /**
14
+ * Port to connect to
15
+ */
16
+ port: number | string;
17
+ }
@@ -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 mapping of a raw block device within a container.
7
+ */
8
+ export interface VolumeDevice {
9
+ /**
10
+ * The path inside of the container that the device will be mapped to.
11
+ */
12
+ devicePath: string;
13
+ /**
14
+ * Must match the name of a persistentVolumeClaim in the pod
15
+ */
16
+ name: string;
17
+ }
@@ -0,0 +1,12 @@
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 VolumeMount {
6
+ name: string;
7
+ readOnly?: boolean;
8
+ mountPath: string;
9
+ mountPropagation?: string;
10
+ subPath?: string;
11
+ subPathExpr?: string;
12
+ }
@@ -0,0 +1,36 @@
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
+ * Windows-specific options and credentials.
7
+ */
8
+ export interface WindowsSecurityContextOptions {
9
+ /**
10
+ * The location of the GMSA admission webhook (https://github.com/kubernetes-sigs/windows-gmsa)
11
+ * inlines the contents of the GMSA credential spec named by the GMSACredentialSpecName field.
12
+ */
13
+ gmsaCredentialSpec?: string;
14
+ /**
15
+ * The name of the GMSA credential spec to use.
16
+ */
17
+ gmsaCredentialSpecName?: string;
18
+ /**
19
+ * Determines if a container should be run as a 'Host Process' container.
20
+ *
21
+ * This field is alpha-level and will only be honored by components that enable the
22
+ * WindowsHostProcessContainers feature flag.
23
+ *
24
+ * Setting this field without the feature flag will result in errors when validating the Pod.
25
+ *
26
+ * All of a Pod's containers must have the same effective HostProcess value (it is not allowed to
27
+ * have a mix of HostProcess containers and non-HostProcess containers).
28
+ *
29
+ * In addition, if HostProcess is true then HostNetwork must also be set to true.
30
+ */
31
+ hostProcess?: boolean;
32
+ /**
33
+ * The UserName in Windows to run the entrypoint of the container process. Defaults to the user specified in image metadata if unspecified. May also be set in PodSecurityContext. If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence.
34
+ */
35
+ runAsUserName?: string;
36
+ }
@@ -21,7 +21,7 @@ export declare class Singleton {
21
21
  * @param args The constructor arguments for the child class
22
22
  * @returns An instance of the child class
23
23
  */
24
- static createInstance<T, R extends any[]>(this: StaticThis<T, R>, ...args: R): T;
24
+ static createInstance<T extends Singleton, R extends any[]>(this: StaticThis<T, R>, ...args: R): T;
25
25
  /**
26
26
  * Get the instance of the child class that was previously created.
27
27
  * @param this Implicit argument that is the child class type
@@ -332,6 +332,7 @@ declare const packageJsonInjectable: import("@ogre-tools/injectable").Injectable
332
332
  playwright: string;
333
333
  postcss: string;
334
334
  "postcss-loader": string;
335
+ "query-string": string;
335
336
  randomcolor: string;
336
337
  "react-beautiful-dnd": string;
337
338
  "react-refresh": string;
@@ -2,4 +2,4 @@ import type { Injectable } from "@ogre-tools/injectable";
2
2
  /**
3
3
  * @deprecated use asLegacyGlobalForExtensionApi instead, and use proper implementations instead of "modifications".
4
4
  */
5
- export declare const asLegacyGlobalObjectForExtensionApiWithModifications: <InjectableInstance extends InjectionTokenInstance, InjectionTokenInstance, ModificationObject extends object>(injectable: Injectable<InjectableInstance, InjectionTokenInstance, void>, modificationObject: ModificationObject) => InjectableInstance & ModificationObject;
5
+ export declare const asLegacyGlobalObjectForExtensionApiWithModifications: <InjectableInstance extends InjectionTokenInstance & object, InjectionTokenInstance, ModificationObject extends object>(injectable: Injectable<InjectableInstance, InjectionTokenInstance, void>, modificationObject: ModificationObject) => InjectableInstance & ModificationObject;
@@ -8,4 +8,4 @@ export { KubeApi, forCluster, forRemoteCluster, type ILocalKubeApiConfig, type I
8
8
  export { KubeObject, KubeStatus, type OwnerReference, type KubeObjectMetadata, type NamespaceScopedMetadata, type ClusterScopedMetadata, type BaseKubeJsonApiObjectMetadata, type KubeJsonApiObjectMetadata, type KubeStatusData, } from "../../common/k8s-api/kube-object";
9
9
  export { type KubeJsonApiData, } from "../../common/k8s-api/kube-json-api";
10
10
  export { KubeObjectStore, type JsonPatch, type KubeObjectStoreLoadAllParams, type KubeObjectStoreLoadingParams, type KubeObjectStoreSubscribeParams, } from "../../common/k8s-api/kube-object.store";
11
- export { type PodContainer as IPodContainer, type PodContainerStatus as IPodContainerStatus, Pod, PodApi as PodsApi, Node, NodeApi as NodesApi, Deployment, DeploymentApi, DaemonSet, StatefulSet, Job, CronJob, ConfigMap, type SecretReference as ISecretRef, Secret, ReplicaSet, ResourceQuota, LimitRange, HorizontalPodAutoscaler, PodDisruptionBudget, PriorityClass, Service, Endpoints as Endpoint, Ingress, IngressApi, NetworkPolicy, PersistentVolume, PersistentVolumeClaim, PersistentVolumeClaimApi as PersistentVolumeClaimsApi, StorageClass, Namespace, KubeEvent, ServiceAccount, Role, RoleBinding, ClusterRole, ClusterRoleBinding, CustomResourceDefinition, } from "../../common/k8s-api/endpoints";
11
+ export { type Container as IPodContainer, type PodContainerStatus as IPodContainerStatus, Pod, PodApi as PodsApi, Node, NodeApi as NodesApi, Deployment, DeploymentApi, DaemonSet, StatefulSet, Job, CronJob, ConfigMap, type SecretReference as ISecretRef, Secret, ReplicaSet, ResourceQuota, LimitRange, HorizontalPodAutoscaler, PodDisruptionBudget, PriorityClass, Service, Endpoints as Endpoint, Ingress, IngressApi, NetworkPolicy, PersistentVolume, PersistentVolumeClaim, PersistentVolumeClaimApi as PersistentVolumeClaimsApi, StorageClass, Namespace, KubeEvent, ServiceAccount, Role, RoleBinding, ClusterRole, ClusterRoleBinding, CustomResourceDefinition, } from "../../common/k8s-api/endpoints";