mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
PublicDashboards: Revoke all public dashboards access to a specific user (#78709)
This commit is contained in:
parent
b867505bd4
commit
5147bdeb4b
@ -5,18 +5,29 @@ import { GrafanaTheme2 } from '@grafana/data/src';
|
|||||||
import { Button, Modal, ModalsController, useStyles2 } from '@grafana/ui/src';
|
import { Button, Modal, ModalsController, useStyles2 } from '@grafana/ui/src';
|
||||||
import { SessionUser } from 'app/features/dashboard/components/ShareModal/SharePublicDashboard/SharePublicDashboardUtils';
|
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 styles = useStyles2(getStyles);
|
||||||
|
|
||||||
|
const onRevokeAccessClick = () => {
|
||||||
|
revokeAllAccess({ email: user.email });
|
||||||
|
hideModal();
|
||||||
|
};
|
||||||
|
|
||||||
return (
|
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}>
|
<p className={styles.description}>
|
||||||
The user {user.email} is currently present in {user.totalDashboards} public dashboard(s). If you wish to remove
|
This action will immediately revoke {user.email}'s access to all public dashboards.
|
||||||
this user, please navigate to the settings of the corresponding public dashboard.
|
|
||||||
</p>
|
</p>
|
||||||
<Modal.ButtonRow>
|
<Modal.ButtonRow>
|
||||||
<Button type="button" variant="secondary" onClick={onDismiss} fill="outline">
|
<Button type="button" variant="secondary" onClick={hideModal} fill="outline">
|
||||||
Close
|
Cancel
|
||||||
|
</Button>
|
||||||
|
<Button type="button" variant="destructive" onClick={onRevokeAccessClick}>
|
||||||
|
Revoke access
|
||||||
</Button>
|
</Button>
|
||||||
</Modal.ButtonRow>
|
</Modal.ButtonRow>
|
||||||
</Modal>
|
</Modal>
|
||||||
@ -29,7 +40,7 @@ export const DeleteUserModalButton = ({ user }: { user: SessionUser }) => (
|
|||||||
<Button
|
<Button
|
||||||
size="sm"
|
size="sm"
|
||||||
variant="destructive"
|
variant="destructive"
|
||||||
onClick={() => showModal(DeleteUserModal, { user, onDismiss: hideModal })}
|
onClick={() => showModal(DeleteUserModal, { user, hideModal })}
|
||||||
icon="times"
|
icon="times"
|
||||||
aria-label="Delete user"
|
aria-label="Delete user"
|
||||||
title="Delete user"
|
title="Delete user"
|
||||||
|
@ -140,7 +140,10 @@ export const publicDashboardApi = createApi({
|
|||||||
url: '',
|
url: '',
|
||||||
}),
|
}),
|
||||||
}),
|
}),
|
||||||
deleteRecipient: builder.mutation<void, { recipientUid: string; dashboardUid: string; uid: string }>({
|
deleteRecipient: builder.mutation<
|
||||||
|
void,
|
||||||
|
{ recipientUid: string; recipientEmail: string; dashboardUid: string; uid: string }
|
||||||
|
>({
|
||||||
query: () => ({
|
query: () => ({
|
||||||
url: '',
|
url: '',
|
||||||
}),
|
}),
|
||||||
@ -202,6 +205,11 @@ export const publicDashboardApi = createApi({
|
|||||||
'ActiveUserDashboards',
|
'ActiveUserDashboards',
|
||||||
],
|
],
|
||||||
}),
|
}),
|
||||||
|
revokeAllAccess: builder.mutation<void, { email: string }>({
|
||||||
|
query: () => ({
|
||||||
|
url: '',
|
||||||
|
}),
|
||||||
|
}),
|
||||||
}),
|
}),
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -216,4 +224,5 @@ export const {
|
|||||||
useReshareAccessToRecipientMutation,
|
useReshareAccessToRecipientMutation,
|
||||||
useGetActiveUsersQuery,
|
useGetActiveUsersQuery,
|
||||||
useGetActiveUserDashboardsQuery,
|
useGetActiveUserDashboardsQuery,
|
||||||
|
useRevokeAllAccessMutation,
|
||||||
} = publicDashboardApi;
|
} = publicDashboardApi;
|
||||||
|
@ -56,9 +56,9 @@ const EmailList = ({
|
|||||||
|
|
||||||
const isLoading = isDeleteLoading || isReshareLoading;
|
const isLoading = isDeleteLoading || isReshareLoading;
|
||||||
|
|
||||||
const onDeleteEmail = (recipientUid: string) => {
|
const onDeleteEmail = (recipientUid: string, recipientEmail: string) => {
|
||||||
DashboardInteractions.revokePublicDashboardEmailClicked();
|
DashboardInteractions.revokePublicDashboardEmailClicked();
|
||||||
deleteEmail({ recipientUid, dashboardUid: dashboardUid, uid: publicDashboardUid });
|
deleteEmail({ recipientUid, recipientEmail, dashboardUid: dashboardUid, uid: publicDashboardUid });
|
||||||
};
|
};
|
||||||
|
|
||||||
const onReshare = (recipientUid: string) => {
|
const onReshare = (recipientUid: string) => {
|
||||||
@ -82,7 +82,7 @@ const EmailList = ({
|
|||||||
title="Revoke"
|
title="Revoke"
|
||||||
size="sm"
|
size="sm"
|
||||||
disabled={isLoading}
|
disabled={isLoading}
|
||||||
onClick={() => onDeleteEmail(recipient.uid)}
|
onClick={() => onDeleteEmail(recipient.uid, recipient.recipient)}
|
||||||
data-testid={`${selectors.DeleteEmail}-${idx}`}
|
data-testid={`${selectors.DeleteEmail}-${idx}`}
|
||||||
>
|
>
|
||||||
Revoke
|
Revoke
|
||||||
|
Loading…
Reference in New Issue
Block a user