X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/f0ac109691369516a5adf9370838cb4eacf16a45..7b837842dac38a9bb654b759a5651c7c4975e10a:/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 57915f70..397b3193 100644 --- a/src/services/auth-service/auth-service.ts +++ b/src/services/auth-service/auth-service.ts @@ -4,6 +4,8 @@ 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'; @@ -11,6 +13,7 @@ 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 const USER_IS_ADMIN = 'isAdmin'; export interface UserDetailsResponse { email: string; @@ -25,7 +28,8 @@ export class AuthService { constructor( protected apiClient: AxiosInstance, - protected baseUrl: string) { } + protected baseUrl: string, + protected actions: ApiActions) { } public saveApiToken(token: string) { localStorage.setItem(API_TOKEN_KEY, token); @@ -47,15 +51,20 @@ export class AuthService { return localStorage.getItem(USER_OWNER_UUID_KEY) || undefined; } + public getIsAdmin(): boolean { + return !!localStorage.getItem(USER_IS_ADMIN); + } + 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); + const isAdmin = this.getIsAdmin(); return email && firstName && lastName && uuid && ownerUuid - ? { email, firstName, lastName, uuid, ownerUuid } + ? { email, firstName, lastName, uuid, ownerUuid, isAdmin } : undefined; } @@ -65,6 +74,7 @@ export class AuthService { localStorage.setItem(USER_LAST_NAME_KEY, user.lastName); localStorage.setItem(USER_UUID_KEY, user.uuid); localStorage.setItem(USER_OWNER_UUID_KEY, user.ownerUuid); + localStorage.setItem(USER_IS_ADMIN, JSON.stringify(user.isAdmin)); } public removeUser() { @@ -73,6 +83,7 @@ export class AuthService { localStorage.removeItem(USER_LAST_NAME_KEY); localStorage.removeItem(USER_UUID_KEY); localStorage.removeItem(USER_OWNER_UUID_KEY); + localStorage.removeItem(USER_IS_ADMIN); } public login() { @@ -86,15 +97,26 @@ export class AuthService { } public getUserDetails = (): Promise => { + 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, + isAdmin: resp.data.is_admin + }; + }) + .catch(e => { + this.actions.progressFn(reqId, false); + this.actions.errorFn(reqId, e); + throw e; + }); } public getRootUuid() {