X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/10ce16c28de952f6533ca3cc9df909269e3d2a53..0349b8735dda91aeaeb60ef6c435442a2045e61b:/src/services/auth-service/auth-service.ts diff --git a/src/services/auth-service/auth-service.ts b/src/services/auth-service/auth-service.ts index 1879e6a0..50760bb4 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -2,9 +2,10 @@ // // SPDX-License-Identifier: AGPL-3.0 -import { API_HOST } from "../../common/api/server-api"; -import { User } from "../../models/user"; -import { AxiosInstance } from "../../../node_modules/axios"; +import { User } from "~/models/user"; +import { AxiosInstance } from "axios"; +import { ApiActions, ProgressFn } from "~/services/api/api-actions"; +import * as uuid from "uuid/v4"; export const API_TOKEN_KEY = 'apiToken'; export const USER_EMAIL_KEY = 'userEmail'; @@ -24,7 +25,10 @@ export interface UserDetailsResponse { export class AuthService { - constructor(protected serverApi: AxiosInstance) { } + constructor( + protected apiClient: AxiosInstance, + protected baseUrl: string, + protected actions: ApiActions) { } public saveApiToken(token: string) { localStorage.setItem(API_TOKEN_KEY, token); @@ -76,24 +80,34 @@ export class AuthService { public login() { const currentUrl = `${window.location.protocol}//${window.location.host}/token`; - window.location.assign(`${API_HOST}/login?return_to=${currentUrl}`); + window.location.assign(`${this.baseUrl || ""}/login?return_to=${currentUrl}`); } public logout() { const currentUrl = `${window.location.protocol}//${window.location.host}`; - window.location.assign(`${API_HOST}/logout?return_to=${currentUrl}`); + window.location.assign(`${this.baseUrl || ""}/logout?return_to=${currentUrl}`); } public getUserDetails = (): Promise => { - return this.serverApi + const reqId = uuid(); + this.actions.progressFn(reqId, true); + return this.apiClient .get('/users/current') - .then(resp => ({ - email: resp.data.email, - firstName: resp.data.first_name, - lastName: resp.data.last_name, - uuid: resp.data.uuid, - ownerUuid: resp.data.owner_uuid - })); + .then(resp => { + this.actions.progressFn(reqId, false); + return { + email: resp.data.email, + firstName: resp.data.first_name, + lastName: resp.data.last_name, + uuid: resp.data.uuid, + ownerUuid: resp.data.owner_uuid + }; + }) + .catch(e => { + this.actions.progressFn(reqId, false); + this.actions.errorFn(reqId, e); + throw e; + }); } public getRootUuid() {