Skip to content

Commit

Permalink
feat(HMS-2721): add rbac control to every page
Browse files Browse the repository at this point in the history
This change leverage the rbac hook so it is checked
the permissions when a page is loaded. Out of the
scope is custom enable/disable controls for each
page.

Signed-off-by: Alejandro Visiedo <[email protected]>
  • Loading branch information
avisiedo committed May 29, 2024
1 parent 7c4bdba commit 1d53992
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 5 deletions.
14 changes: 12 additions & 2 deletions src/Routes/DefaultPage/DefaultPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -185,10 +185,20 @@ const DefaultPage = () => {
const [perPage, setPerPage] = useState<number>(10);
const offset = (page - 1) * perPage;
const [isLoading, setIsLoading] = useState<boolean>(true);
const navigate = useNavigate();

console.log('INFO:DefaultPage render');

useEffect(() => {
if (appContext.rbac.isLoading) {
console.debug('rbac is loading yet');
setIsLoading(true);
return;
}
console.debug('rbac is loaded');
if (!appContext.rbac.permissions.hasDomainsList) {
navigate('/no-permissions', { replace: true });
}
setIsLoading(true);
resources_api
.listDomains(undefined, offset, perPage, undefined)
Expand All @@ -203,7 +213,7 @@ const DefaultPage = () => {
console.log(reason);
setIsLoading(false);
});
}, [page, perPage]);
}, [page, perPage, appContext.rbac.isLoading]);

const changePageSize = (size: number) => {
setPerPage(size);
Expand Down Expand Up @@ -233,7 +243,7 @@ const DefaultPage = () => {
</>
);

if (isLoading) {
if (appContext.rbac.isLoading || isLoading) {
return loadingContent;
}
const content = appContext.totalDomains <= 0 ? emptyContent : listContent;
Expand Down
10 changes: 9 additions & 1 deletion src/Routes/DetailPage/DetailPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,14 @@ const DetailPage = () => {

// Load Domain to display
useEffect(() => {
if (appContext.rbac.isLoading) {
console.debug('rbac is loading yet');
return;
}
console.debug('rbac is loaded');
if (!appContext.rbac.permissions.hasDomainsRead) {
navigate('/no-permissions', { replace: true });
}
if (domain_id) {
resources_api
.readDomain(domain_id)
Expand All @@ -72,7 +80,7 @@ const DetailPage = () => {
navigate('/domains', { replace: true });
});
}
}, [domain_id]);
}, [domain_id, appContext.rbac.isLoading]);

// Kebab menu
const [isKebabOpen, setIsKebabOpen] = useState<boolean>(false);
Expand Down
23 changes: 22 additions & 1 deletion src/Routes/NoPermissionsPage/NoPermissionsPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,36 @@ import React, { useEffect } from 'react';

import { Main } from '@redhat-cloud-services/frontend-components/Main';
import { NotAuthorized } from '@redhat-cloud-services/frontend-components/NotAuthorized';
import { Button } from '@patternfly/react-core';
import useChrome from '@redhat-cloud-services/frontend-components/useChrome';

const NoPermissionsPage = () => {
useEffect(() => {
insights?.chrome?.appAction?.('no-permissions');
}, []);

const { isBeta } = useChrome();
const prefix = isBeta() ? '/beta' : '/preview';
const linkMyUserAccess = prefix + '/iam/my-user-access';

return (
<Main>
<NotAuthorized serviceName="Sample app" />
<NotAuthorized
serviceName="Directory and Domain"
showReturnButton
title="Access permissions needed"
description={
<>
To access identity domains, contact your organization <br />
administrator. Aternatively, visit
<br />
<Button component="a" variant="link" isInline iconPosition="right" href={linkMyUserAccess} ouiaId="LinkNoPermissionsMyUserAccess">
My User Access
</Button>{' '}
to learn more about your permissions.
</>
}
/>
</Main>
);
};
Expand Down
22 changes: 21 additions & 1 deletion src/Routes/WizardPage/WizardPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
* The goal is provide the steps to register and add
* a new domain service.
*/
import React, { useContext, useState } from 'react';
import React, { useContext, useEffect, useState } from 'react';
import { ExternalLinkAltIcon } from '@patternfly/react-icons/dist/esm/icons/external-link-alt-icon';

import { Button, Modal, ModalVariant, PageGroup, PageSection, PageSectionVariants, Text, Wizard, WizardStep } from '@patternfly/react-core';
Expand Down Expand Up @@ -43,6 +43,26 @@ const WizardPage = () => {
const linkLearnMoreAbout = 'https://access.redhat.com/articles/1586893';
const linkLearnMoreAboutRemovingDirectoryAndDomainServices = 'https://access.redhat.com/articles/1586893';

useEffect(() => {
if (appContext.rbac.isLoading) {
console.debug('rbac is loading yet');
return;
}
console.debug('rbac is loaded');
if (!appContext.rbac.permissions.hasTokenCreate) {
navigate('/no-permissions', { replace: true });
return;
}
if (!appContext.rbac.permissions.hasDomainsUpdate) {
navigate('/no-permissions', { replace: true });
return;
}
}, [appContext.rbac.isLoading]);

if (appContext.rbac.isLoading) {
return;
}

const notifyNotCompleted = () => {
const notificationID = 'domain-registration-cancelled-notification';
notifyError({
Expand Down

0 comments on commit 1d53992

Please sign in to comment.