mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Remove circular dependency with isAllowedResource function (#3545)
Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
b6ba39c438
commit
2b3351bf9b
@ -19,9 +19,6 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { ClusterStore } from "./cluster-store";
|
|
||||||
import { getHostedClusterId } from "./utils";
|
|
||||||
|
|
||||||
export type KubeResource =
|
export type KubeResource =
|
||||||
"namespaces" | "nodes" | "events" | "resourcequotas" | "services" | "limitranges" |
|
"namespaces" | "nodes" | "events" | "resourcequotas" | "services" | "limitranges" |
|
||||||
"secrets" | "configmaps" | "ingresses" | "networkpolicies" | "persistentvolumeclaims" | "persistentvolumes" | "storageclasses" |
|
"secrets" | "configmaps" | "ingresses" | "networkpolicies" | "persistentvolumeclaims" | "persistentvolumes" | "storageclasses" |
|
||||||
@ -74,18 +71,3 @@ export const apiResourceRecord: Record<KubeResource, KubeApiResourceData> = {
|
|||||||
// TODO: auto-populate all resources dynamically (see: kubectl api-resources -o=wide -v=7)
|
// TODO: auto-populate all resources dynamically (see: kubectl api-resources -o=wide -v=7)
|
||||||
export const apiResources: KubeApiResource[] = Object.entries(apiResourceRecord)
|
export const apiResources: KubeApiResource[] = Object.entries(apiResourceRecord)
|
||||||
.map(([apiName, data]) => ({ apiName: apiName as KubeResource, ...data }));
|
.map(([apiName, data]) => ({ apiName: apiName as KubeResource, ...data }));
|
||||||
|
|
||||||
export function isAllowedResource(resources: KubeResource | KubeResource[]) {
|
|
||||||
if (!Array.isArray(resources)) {
|
|
||||||
resources = [resources];
|
|
||||||
}
|
|
||||||
const { allowedResources = [] } = ClusterStore.getInstance().getById(getHostedClusterId()) || {};
|
|
||||||
|
|
||||||
for (const resource of resources) {
|
|
||||||
if (!allowedResources.includes(resource)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|||||||
41
src/common/utils/allowed-resource.ts
Normal file
41
src/common/utils/allowed-resource.ts
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/**
|
||||||
|
* Copyright (c) 2021 OpenLens Authors
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
* this software and associated documentation files (the "Software"), to deal in
|
||||||
|
* the Software without restriction, including without limitation the rights to
|
||||||
|
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
* the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
* subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all
|
||||||
|
* copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
* COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
* IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { ClusterStore } from "../cluster-store";
|
||||||
|
import type { KubeResource } from "../rbac";
|
||||||
|
import { getHostedClusterId } from "./cluster-id-url-parsing";
|
||||||
|
|
||||||
|
export function isAllowedResource(resource: KubeResource | KubeResource[]) {
|
||||||
|
const resources = [resource].flat();
|
||||||
|
const cluster = ClusterStore.getInstance().getById(getHostedClusterId());
|
||||||
|
|
||||||
|
if (!cluster?.allowedResources) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (resources.length === 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
const allowedResources = new Set(cluster.allowedResources);
|
||||||
|
|
||||||
|
return resources.every(resource => allowedResources.has(resource));
|
||||||
|
}
|
||||||
@ -19,7 +19,7 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
export { isAllowedResource } from "../../common/rbac";
|
export { isAllowedResource } from "../../common/utils/allowed-resource";
|
||||||
export { ResourceStack } from "../../common/k8s/resource-stack";
|
export { ResourceStack } from "../../common/k8s/resource-stack";
|
||||||
export { apiManager } from "../../renderer/api/api-manager";
|
export { apiManager } from "../../renderer/api/api-manager";
|
||||||
export { KubeObjectStore } from "../../renderer/kube-object.store";
|
export { KubeObjectStore } from "../../renderer/kube-object.store";
|
||||||
|
|||||||
@ -27,7 +27,7 @@ import { Secrets } from "../+config-secrets";
|
|||||||
import { ResourceQuotas } from "../+config-resource-quotas";
|
import { ResourceQuotas } from "../+config-resource-quotas";
|
||||||
import { PodDisruptionBudgets } from "../+config-pod-disruption-budgets";
|
import { PodDisruptionBudgets } from "../+config-pod-disruption-budgets";
|
||||||
import { HorizontalPodAutoscalers } from "../+config-autoscalers";
|
import { HorizontalPodAutoscalers } from "../+config-autoscalers";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import { LimitRanges } from "../+config-limit-ranges";
|
import { LimitRanges } from "../+config-limit-ranges";
|
||||||
import * as routes from "../../../common/routes";
|
import * as routes from "../../../common/routes";
|
||||||
|
|
||||||
|
|||||||
@ -28,7 +28,7 @@ import { Services } from "../+network-services";
|
|||||||
import { Endpoints } from "../+network-endpoints";
|
import { Endpoints } from "../+network-endpoints";
|
||||||
import { Ingresses } from "../+network-ingresses";
|
import { Ingresses } from "../+network-ingresses";
|
||||||
import { NetworkPolicies } from "../+network-policies";
|
import { NetworkPolicies } from "../+network-policies";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import * as routes from "../../../common/routes";
|
import * as routes from "../../../common/routes";
|
||||||
|
|
||||||
@observer
|
@observer
|
||||||
|
|||||||
@ -27,7 +27,7 @@ import { TabLayout, TabLayoutRoute } from "../layout/tab-layout";
|
|||||||
import { PersistentVolumes } from "../+storage-volumes";
|
import { PersistentVolumes } from "../+storage-volumes";
|
||||||
import { StorageClasses } from "../+storage-classes";
|
import { StorageClasses } from "../+storage-classes";
|
||||||
import { PersistentVolumeClaims } from "../+storage-volume-claims";
|
import { PersistentVolumeClaims } from "../+storage-volume-claims";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import * as routes from "../../../common/routes";
|
import * as routes from "../../../common/routes";
|
||||||
|
|
||||||
@observer
|
@observer
|
||||||
|
|||||||
@ -25,7 +25,7 @@ import React from "react";
|
|||||||
import { observer } from "mobx-react";
|
import { observer } from "mobx-react";
|
||||||
import { TabLayout, TabLayoutRoute } from "../layout/tab-layout";
|
import { TabLayout, TabLayoutRoute } from "../layout/tab-layout";
|
||||||
import { PodSecurityPolicies } from "../+pod-security-policies";
|
import { PodSecurityPolicies } from "../+pod-security-policies";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import * as routes from "../../../common/routes";
|
import * as routes from "../../../common/routes";
|
||||||
import { ClusterRoleBindings } from "./+cluster-role-bindings";
|
import { ClusterRoleBindings } from "./+cluster-role-bindings";
|
||||||
import { ServiceAccounts } from "./+service-accounts";
|
import { ServiceAccounts } from "./+service-accounts";
|
||||||
|
|||||||
@ -28,10 +28,11 @@ import { Link } from "react-router-dom";
|
|||||||
import { workloadStores } from "../+workloads";
|
import { workloadStores } from "../+workloads";
|
||||||
import { namespaceStore } from "../+namespaces/namespace.store";
|
import { namespaceStore } from "../+namespaces/namespace.store";
|
||||||
import { NamespaceSelectFilter } from "../+namespaces/namespace-select-filter";
|
import { NamespaceSelectFilter } from "../+namespaces/namespace-select-filter";
|
||||||
import { isAllowedResource, KubeResource } from "../../../common/rbac";
|
import type { KubeResource } from "../../../common/rbac";
|
||||||
import { ResourceNames } from "../../utils/rbac";
|
import { ResourceNames } from "../../utils/rbac";
|
||||||
import { boundMethod } from "../../utils";
|
import { boundMethod } from "../../utils";
|
||||||
import { workloadURL } from "../../../common/routes";
|
import { workloadURL } from "../../../common/routes";
|
||||||
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
|
|
||||||
const resources: KubeResource[] = [
|
const resources: KubeResource[] = [
|
||||||
"pods",
|
"pods",
|
||||||
|
|||||||
@ -31,7 +31,7 @@ import { DaemonSets } from "../+workloads-daemonsets";
|
|||||||
import { StatefulSets } from "../+workloads-statefulsets";
|
import { StatefulSets } from "../+workloads-statefulsets";
|
||||||
import { Jobs } from "../+workloads-jobs";
|
import { Jobs } from "../+workloads-jobs";
|
||||||
import { CronJobs } from "../+workloads-cronjobs";
|
import { CronJobs } from "../+workloads-cronjobs";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import { ReplicaSets } from "../+workloads-replicasets";
|
import { ReplicaSets } from "../+workloads-replicasets";
|
||||||
import * as routes from "../../../common/routes";
|
import * as routes from "../../../common/routes";
|
||||||
|
|
||||||
|
|||||||
@ -31,7 +31,7 @@ import { Events } from "./+events/events";
|
|||||||
import { DeploymentScaleDialog } from "./+workloads-deployments/deployment-scale-dialog";
|
import { DeploymentScaleDialog } from "./+workloads-deployments/deployment-scale-dialog";
|
||||||
import { CronJobTriggerDialog } from "./+workloads-cronjobs/cronjob-trigger-dialog";
|
import { CronJobTriggerDialog } from "./+workloads-cronjobs/cronjob-trigger-dialog";
|
||||||
import { CustomResources } from "./+custom-resources/custom-resources";
|
import { CustomResources } from "./+custom-resources/custom-resources";
|
||||||
import { isAllowedResource } from "../../common/rbac";
|
import { isAllowedResource } from "../../common/utils/allowed-resource";
|
||||||
import logger from "../../main/logger";
|
import logger from "../../main/logger";
|
||||||
import { webFrame } from "electron";
|
import { webFrame } from "electron";
|
||||||
import { ClusterPageRegistry, getExtensionPageUrl } from "../../extensions/registries/page-registry";
|
import { ClusterPageRegistry, getExtensionPageUrl } from "../../extensions/registries/page-registry";
|
||||||
|
|||||||
@ -33,7 +33,7 @@ import { Network } from "../+network";
|
|||||||
import { crdStore } from "../+custom-resources/crd.store";
|
import { crdStore } from "../+custom-resources/crd.store";
|
||||||
import { CustomResources } from "../+custom-resources/custom-resources";
|
import { CustomResources } from "../+custom-resources/custom-resources";
|
||||||
import { isActiveRoute } from "../../navigation";
|
import { isActiveRoute } from "../../navigation";
|
||||||
import { isAllowedResource } from "../../../common/rbac";
|
import { isAllowedResource } from "../../../common/utils/allowed-resource";
|
||||||
import { Spinner } from "../spinner";
|
import { Spinner } from "../spinner";
|
||||||
import { ClusterPageMenuRegistration, ClusterPageMenuRegistry, ClusterPageRegistry, getExtensionPageUrl } from "../../../extensions/registries";
|
import { ClusterPageMenuRegistration, ClusterPageMenuRegistry, ClusterPageRegistry, getExtensionPageUrl } from "../../../extensions/registries";
|
||||||
import { SidebarItem } from "./sidebar-item";
|
import { SidebarItem } from "./sidebar-item";
|
||||||
|
|||||||
@ -20,7 +20,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import { isAllowedResource } from "../../common/rbac";
|
import { isAllowedResource } from "../../common/utils/allowed-resource";
|
||||||
import { WorkloadsOverviewDetailRegistry } from "../../extensions/registries";
|
import { WorkloadsOverviewDetailRegistry } from "../../extensions/registries";
|
||||||
import { Events } from "../components/+events";
|
import { Events } from "../components/+events";
|
||||||
import { OverviewStatuses } from "../components/+workloads-overview/overview-statuses";
|
import { OverviewStatuses } from "../components/+workloads-overview/overview-statuses";
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user