mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
* Add check for incomplete SelfSubjectRulesReview to fix GKE Signed-off-by: Sebastian Malton <sebastian@malton.name> * Adding namespaced for KubeApiResource Signed-off-by: Sebastian Malton <sebastian@malton.name> * Refactoring of AuthorizationNamespaceReview Signed-off-by: Sebastian Malton <sebastian@malton.name> * Removing dead code Signed-off-by: Sebastian Malton <sebastian@malton.name> * Refactoring ListApiResources Signed-off-by: Sebastian Malton <sebastian@malton.name> * Extract ClusterContext into deps for KubeObjectStore to fix circular import Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix remaining type errors Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix crash in frame by consolidating setup into runnables Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix type errors and remove dead code Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix core resources not showing up Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix namespaces not being shown Signed-off-by: Sebastian Malton <sebastian@malton.name> * Simplify ClusterContext to remove something only NamespaceStore needs Signed-off-by: Sebastian Malton <sebastian@malton.name> * Make sure the public API doesn't change Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fixing namespace-select-filter tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix other tests requiring overrides Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix kludge in cluster-frame tests Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix remaining test failures Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix integration test due to incorrect casting Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix integration test and kube watches not working at all Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix secret details test Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix lint Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix non-ApplicationBuilder tests by adding overrides Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix crash due to trying to read hostedCluster too soon Signed-off-by: Sebastian Malton <sebastian@malton.name> * Fix crash due to timing issues - Make injectable phases more explicit for renderer Signed-off-by: Sebastian Malton <sebastian@malton.name> Signed-off-by: Sebastian Malton <sebastian@malton.name>
79 lines
2.7 KiB
TypeScript
79 lines
2.7 KiB
TypeScript
/**
|
|
* Copyright (c) OpenLens Authors. All rights reserved.
|
|
* Licensed under MIT License. See LICENSE in root directory for more information.
|
|
*/
|
|
|
|
import type { KubeConfig } from "@kubernetes/client-node";
|
|
import { AuthorizationV1Api } from "@kubernetes/client-node";
|
|
import { getInjectable } from "@ogre-tools/injectable";
|
|
import loggerInjectable from "../logger.injectable";
|
|
import type { KubeApiResource } from "../rbac";
|
|
|
|
export type CanListResource = (resource: KubeApiResource) => boolean;
|
|
|
|
/**
|
|
* Requests the permissions for actions on the kube cluster
|
|
* @param namespace The namespace of the resources
|
|
*/
|
|
export type RequestNamespaceListPermissions = (namespace: string) => Promise<CanListResource>;
|
|
|
|
/**
|
|
* @param proxyConfig This config's `currentContext` field must be set, and will be used as the target cluster
|
|
*/
|
|
export type RequestNamespaceListPermissionsFor = (proxyConfig: KubeConfig) => RequestNamespaceListPermissions;
|
|
|
|
const requestNamespaceListPermissionsForInjectable = getInjectable({
|
|
id: "request-namespace-list-permissions-for",
|
|
instantiate: (di): RequestNamespaceListPermissionsFor => {
|
|
const logger = di.inject(loggerInjectable);
|
|
|
|
return (proxyConfig) => {
|
|
const api = proxyConfig.makeApiClient(AuthorizationV1Api);
|
|
|
|
return async (namespace) => {
|
|
try {
|
|
const { body: { status }} = await api.createSelfSubjectRulesReview({
|
|
apiVersion: "authorization.k8s.io/v1",
|
|
kind: "SelfSubjectRulesReview",
|
|
spec: { namespace },
|
|
});
|
|
|
|
if (!status || status.incomplete) {
|
|
logger.warn(`[AUTHORIZATION-NAMESPACE-REVIEW]: allowing all resources in namespace="${namespace}" due to incomplete SelfSubjectRulesReview: ${status?.evaluationError}`);
|
|
|
|
return () => true;
|
|
}
|
|
|
|
const { resourceRules } = status;
|
|
|
|
return (resource) => {
|
|
const resourceRule = resourceRules.find(({
|
|
apiGroups = [],
|
|
resources = [],
|
|
}) => {
|
|
const isAboutRelevantApiGroup = apiGroups.includes("*") || apiGroups.includes(resource.group);
|
|
const isAboutResource = resources.includes("*") || resources.includes(resource.apiName);
|
|
|
|
return isAboutRelevantApiGroup && isAboutResource;
|
|
});
|
|
|
|
if (!resourceRule) {
|
|
return false;
|
|
}
|
|
|
|
const { verbs } = resourceRule;
|
|
|
|
return verbs.includes("*") || verbs.includes("list");
|
|
};
|
|
} catch (error) {
|
|
logger.error(`[AUTHORIZATION-NAMESPACE-REVIEW]: failed to create subject rules review`, { namespace, error });
|
|
|
|
return () => true;
|
|
}
|
|
};
|
|
};
|
|
},
|
|
});
|
|
|
|
export default requestNamespaceListPermissionsForInjectable;
|