init api token, add model and service, create dialogs and panel
[arvados-workbench2.git] / src / store / api-client-authorizations / api-client-authorizations-actions.ts
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { Dispatch } from "redux";
6 import { unionize, ofType, UnionOf } from "~/common/unionize";
7 import { RootState } from '~/store/store';
8 import { setBreadcrumbs } from '~/store/breadcrumbs/breadcrumbs-actions';
9 import { ServiceRepository } from "~/services/services";
10 import { dialogActions } from '~/store/dialog/dialog-actions';
11 import { snackbarActions } from '~/store/snackbar/snackbar-actions';
12 import { navigateToRootProject } from '~/store/navigation/navigation-action';
13 import { ApiClientAuthorization } from '~/models/api-client-authorization';
14
15 export const apiClientAuthorizationsActions = unionize({
16     SET_API_CLIENT_AUTHORIZATIONS: ofType<ApiClientAuthorization[]>(),
17     REMOVE_API_CLIENT_AUTHORIZATION: ofType<string>()
18 });
19
20 export type ApiClientAuthorizationsActions = UnionOf<typeof apiClientAuthorizationsActions>;
21
22 export const API_CLIENT_AUTHORIZATION_REMOVE_DIALOG = 'apiClientAuthorizationRemoveDialog';
23 export const API_CLIENT_AUTHORIZATION_ATTRIBUTES_DIALOG = 'apiClientAuthorizationAttributesDialog';
24
25 export const loadApiClientAuthorizationsPanel = () =>
26     async (dispatch: Dispatch<any>, getState: () => RootState, services: ServiceRepository) => {
27         const user = getState().auth.user;
28         if (user && user.isAdmin) {
29             try {
30                 dispatch(setBreadcrumbs([{ label: 'Api client authorizations' }]));
31                 const response = await services.apiClientAuthorizationService.list();
32                 dispatch(apiClientAuthorizationsActions.SET_API_CLIENT_AUTHORIZATIONS(response.items));
33             } catch (e) {
34                 dispatch(snackbarActions.OPEN_SNACKBAR({ message: "You don't have permissions to view this page", hideDuration: 2000 }));
35                 return;
36             }
37         } else {
38             dispatch(navigateToRootProject);
39             dispatch(snackbarActions.OPEN_SNACKBAR({ message: "You don't have permissions to view this page", hideDuration: 2000 }));
40         }
41     };
42
43 export const openApiClientAuthorizationAttributesDialog = (uuid: string) =>
44     (dispatch: Dispatch, getState: () => RootState) => {
45         const apiClientAuthorization = getState().apiClientAuthorizations.find(node => node.uuid === uuid);
46         dispatch(dialogActions.OPEN_DIALOG({ id: API_CLIENT_AUTHORIZATION_ATTRIBUTES_DIALOG, data: { apiClientAuthorization } }));
47     };
48
49 export const openApiClientAuthorizationRemoveDialog = (uuid: string) =>
50     (dispatch: Dispatch, getState: () => RootState) => {
51         dispatch(dialogActions.OPEN_DIALOG({
52             id: API_CLIENT_AUTHORIZATION_REMOVE_DIALOG,
53             data: {
54                 title: 'Remove api client authorization',
55                 text: 'Are you sure you want to remove this api client authorization?',
56                 confirmButtonLabel: 'Remove',
57                 uuid
58             }
59         }));
60     };
61
62 export const removeApiClientAuthorization = (uuid: string) =>
63     async (dispatch: Dispatch, getState: () => RootState, services: ServiceRepository) => {
64         dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Removing ...' }));
65         try {
66             await services.apiClientAuthorizationService.delete(uuid);
67             dispatch(apiClientAuthorizationsActions.REMOVE_API_CLIENT_AUTHORIZATION(uuid));
68             dispatch(snackbarActions.OPEN_SNACKBAR({ message: 'Api client authorization has been successfully removed.', hideDuration: 2000 }));
69         } catch (e) {
70             return;
71         }
72     };