PublicDashboards: Revoke all public dashboards access to a specific user (#78709)

This commit is contained in:
Juan Cabanas 2023-12-11 16:55:16 -03:00 committed by GitHub
parent b867505bd4
commit 5147bdeb4b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 31 additions and 11 deletions

View File

@ -5,18 +5,29 @@ import { GrafanaTheme2 } from '@grafana/data/src';
import { Button, Modal, ModalsController, useStyles2 } from '@grafana/ui/src';
import { SessionUser } from 'app/features/dashboard/components/ShareModal/SharePublicDashboard/SharePublicDashboardUtils';
const DeleteUserModal = ({ user, onDismiss }: { user: SessionUser; onDismiss: () => void }) => {
import { useRevokeAllAccessMutation } from '../../dashboard/api/publicDashboardApi';
const DeleteUserModal = ({ user, hideModal }: { user: SessionUser; hideModal: () => void }) => {
const [revokeAllAccess] = useRevokeAllAccessMutation();
const styles = useStyles2(getStyles);
const onRevokeAccessClick = () => {
revokeAllAccess({ email: user.email });
hideModal();
};
return (
<Modal className={styles.modal} isOpen title="Delete" onDismiss={onDismiss}>
<Modal className={styles.modal} isOpen title="Revoke access" onDismiss={hideModal}>
<p className={styles.description}>Are you sure you want to revoke access for {user.email}?</p>
<p className={styles.description}>
The user {user.email} is currently present in {user.totalDashboards} public dashboard(s). If you wish to remove
this user, please navigate to the settings of the corresponding public dashboard.
This action will immediately revoke {user.email}&apos;s access to all public dashboards.
</p>
<Modal.ButtonRow>
<Button type="button" variant="secondary" onClick={onDismiss} fill="outline">
Close
<Button type="button" variant="secondary" onClick={hideModal} fill="outline">
Cancel
</Button>
<Button type="button" variant="destructive" onClick={onRevokeAccessClick}>
Revoke access
</Button>
</Modal.ButtonRow>
</Modal>
@ -29,7 +40,7 @@ export const DeleteUserModalButton = ({ user }: { user: SessionUser }) => (
<Button
size="sm"
variant="destructive"
onClick={() => showModal(DeleteUserModal, { user, onDismiss: hideModal })}
onClick={() => showModal(DeleteUserModal, { user, hideModal })}
icon="times"
aria-label="Delete user"
title="Delete user"

View File

@ -140,7 +140,10 @@ export const publicDashboardApi = createApi({
url: '',
}),
}),
deleteRecipient: builder.mutation<void, { recipientUid: string; dashboardUid: string; uid: string }>({
deleteRecipient: builder.mutation<
void,
{ recipientUid: string; recipientEmail: string; dashboardUid: string; uid: string }
>({
query: () => ({
url: '',
}),
@ -202,6 +205,11 @@ export const publicDashboardApi = createApi({
'ActiveUserDashboards',
],
}),
revokeAllAccess: builder.mutation<void, { email: string }>({
query: () => ({
url: '',
}),
}),
}),
});
@ -216,4 +224,5 @@ export const {
useReshareAccessToRecipientMutation,
useGetActiveUsersQuery,
useGetActiveUserDashboardsQuery,
useRevokeAllAccessMutation,
} = publicDashboardApi;

View File

@ -56,9 +56,9 @@ const EmailList = ({
const isLoading = isDeleteLoading || isReshareLoading;
const onDeleteEmail = (recipientUid: string) => {
const onDeleteEmail = (recipientUid: string, recipientEmail: string) => {
DashboardInteractions.revokePublicDashboardEmailClicked();
deleteEmail({ recipientUid, dashboardUid: dashboardUid, uid: publicDashboardUid });
deleteEmail({ recipientUid, recipientEmail, dashboardUid: dashboardUid, uid: publicDashboardUid });
};
const onReshare = (recipientUid: string) => {
@ -82,7 +82,7 @@ const EmailList = ({
title="Revoke"
size="sm"
disabled={isLoading}
onClick={() => onDeleteEmail(recipient.uid)}
onClick={() => onDeleteEmail(recipient.uid, recipient.recipient)}
data-testid={`${selectors.DeleteEmail}-${idx}`}
>
Revoke