Merge branch '14434-display-workflow-name'
[arvados-workbench2.git] / src / views-components / api-token / api-token.tsx
1 // Copyright (C) The Arvados Authors. All rights reserved.
2 //
3 // SPDX-License-Identifier: AGPL-3.0
4
5 import { RouteProps } from "react-router";
6 import * as React from "react";
7 import { connect, DispatchProp } from "react-redux";
8 import { authActions, getUserDetails, saveApiToken } from "~/store/auth/auth-action";
9 import { getUrlParameter } from "~/common/url";
10 import { AuthService } from "~/services/auth-service/auth-service";
11 import { navigateToRootProject } from "~/store/navigation/navigation-action";
12 import { User } from "~/models/user";
13 import { Config } from "~/common/config";
14 import { initSessions } from "~/store/auth/auth-action-session";
15
16 interface ApiTokenProps {
17     authService: AuthService;
18     config: Config;
19 }
20
21 export const ApiToken = connect()(
22     class extends React.Component<ApiTokenProps & RouteProps & DispatchProp<any>, {}> {
23         componentDidMount() {
24             const search = this.props.location ? this.props.location.search : "";
25             const apiToken = getUrlParameter(search, 'api_token');
26             this.props.dispatch(saveApiToken(apiToken));
27             this.props.dispatch<any>(getUserDetails()).then((user: User) => {
28                 this.props.dispatch(initSessions(this.props.authService, this.props.config, user));
29             }).finally(() => {
30                 this.props.dispatch(navigateToRootProject);
31             });
32         }
33         render() {
34             return <div/>;
35         }
36     }
37 );