X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/6e6ef73c3a75b2cfb6d0ee11827630ca46266982..59100a72caedbc8f3c9872de1153bf3d4129122a:/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 672a6194..50760bb4 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -2,12 +2,33 @@ // // SPDX-License-Identifier: AGPL-3.0 -import Axios from "axios"; -import { API_HOST, serverApi } from "../../common/server-api"; +import { User } from "~/models/user"; +import { AxiosInstance } from "axios"; +import { ApiActions, ProgressFn } from "~/services/api/api-actions"; +import * as uuid from "uuid/v4"; -const API_TOKEN_KEY = 'api_token'; +export const API_TOKEN_KEY = 'apiToken'; +export const USER_EMAIL_KEY = 'userEmail'; +export const USER_FIRST_NAME_KEY = 'userFirstName'; +export const USER_LAST_NAME_KEY = 'userLastName'; +export const USER_UUID_KEY = 'userUuid'; +export const USER_OWNER_UUID_KEY = 'userOwnerUuid'; -export default class AuthService { +export interface UserDetailsResponse { + email: string; + first_name: string; + last_name: string; + uuid: string; + owner_uuid: string; + is_admin: boolean; +} + +export class AuthService { + + constructor( + protected apiClient: AxiosInstance, + protected baseUrl: string, + protected actions: ApiActions) { } public saveApiToken(token: string) { localStorage.setItem(API_TOKEN_KEY, token); @@ -18,20 +39,80 @@ export default class AuthService { } public getApiToken() { - return localStorage.getItem(API_TOKEN_KEY); + return localStorage.getItem(API_TOKEN_KEY) || undefined; + } + + public getUuid() { + return localStorage.getItem(USER_UUID_KEY) || undefined; + } + + public getOwnerUuid() { + return localStorage.getItem(USER_OWNER_UUID_KEY) || undefined; + } + + public getUser(): User | undefined { + const email = localStorage.getItem(USER_EMAIL_KEY); + const firstName = localStorage.getItem(USER_FIRST_NAME_KEY); + const lastName = localStorage.getItem(USER_LAST_NAME_KEY); + const uuid = localStorage.getItem(USER_UUID_KEY); + const ownerUuid = localStorage.getItem(USER_OWNER_UUID_KEY); + + return email && firstName && lastName && uuid && ownerUuid + ? { email, firstName, lastName, uuid, ownerUuid } + : undefined; + } + + public saveUser(user: User) { + localStorage.setItem(USER_EMAIL_KEY, user.email); + localStorage.setItem(USER_FIRST_NAME_KEY, user.firstName); + localStorage.setItem(USER_LAST_NAME_KEY, user.lastName); + localStorage.setItem(USER_UUID_KEY, user.uuid); + localStorage.setItem(USER_OWNER_UUID_KEY, user.ownerUuid); } - public isUserLoggedIn() { - return this.getApiToken() !== null; + public removeUser() { + localStorage.removeItem(USER_EMAIL_KEY); + localStorage.removeItem(USER_FIRST_NAME_KEY); + localStorage.removeItem(USER_LAST_NAME_KEY); + localStorage.removeItem(USER_UUID_KEY); + localStorage.removeItem(USER_OWNER_UUID_KEY); } public login() { const currentUrl = `${window.location.protocol}//${window.location.host}/token`; - window.location.href = `${API_HOST}/login?return_to=${currentUrl}`; + window.location.assign(`${this.baseUrl || ""}/login?return_to=${currentUrl}`); } - public logout(): Promise { + public logout() { const currentUrl = `${window.location.protocol}//${window.location.host}`; - return Axios.get(`${API_HOST}/logout?return_to=${currentUrl}`); + window.location.assign(`${this.baseUrl || ""}/logout?return_to=${currentUrl}`); + } + + public getUserDetails = (): Promise => { + const reqId = uuid(); + this.actions.progressFn(reqId, true); + return this.apiClient + .get('/users/current') + .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() { + const uuid = this.getOwnerUuid(); + const uuidParts = uuid ? uuid.split('-') : []; + return uuidParts.length > 1 ? `${uuidParts[0]}-${uuidParts[1]}` : undefined; } }