1
0
mirror of https://github.com/lensapp/lens.git synced 2025-05-20 05:10:56 +00:00
lens/src/renderer/components/+storage/storage.tsx
Lauri Nevala 424eeef761 Check is persistent volume claims resource to allowed for user (#1850)
Signed-off-by: Lauri Nevala <lauri.nevala@gmail.com>
2020-12-30 16:47:03 +02:00

55 lines
1.7 KiB
TypeScript

import "./storage.scss";
import React from "react";
import { observer } from "mobx-react";
import { Trans } from "@lingui/macro";
import { TabLayout, TabLayoutRoute } from "../layout/tab-layout";
import { PersistentVolumes, volumesRoute, volumesURL } from "../+storage-volumes";
import { StorageClasses, storageClassesRoute, storageClassesURL } from "../+storage-classes";
import { PersistentVolumeClaims, volumeClaimsRoute, volumeClaimsURL } from "../+storage-volume-claims";
import { namespaceStore } from "../+namespaces/namespace.store";
import { isAllowedResource } from "../../../common/rbac";
@observer
export class Storage extends React.Component {
static get tabRoutes() {
const tabRoutes: TabLayoutRoute[] = [];
const query = namespaceStore.getContextParams();
if (isAllowedResource("persistentvolumeclaims")) {
tabRoutes.push({
title: <Trans>Persistent Volume Claims</Trans>,
component: PersistentVolumeClaims,
url: volumeClaimsURL({ query }),
routePath: volumeClaimsRoute.path.toString(),
});
}
if (isAllowedResource("persistentvolumes")) {
tabRoutes.push({
title: <Trans>Persistent Volumes</Trans>,
component: PersistentVolumes,
url: volumesURL(),
routePath: volumesRoute.path.toString(),
});
}
if (isAllowedResource("storageclasses")) {
tabRoutes.push({
title: <Trans>Storage Classes</Trans>,
component: StorageClasses,
url: storageClassesURL(),
routePath: storageClassesRoute.path.toString(),
});
}
return tabRoutes;
}
render() {
return (
<TabLayout className="Storage" tabs={Storage.tabRoutes}/>
);
}
}